From 7c493ca3b7dff5e0d84482599695cb5a4fdacfe6 Mon Sep 17 00:00:00 2001 From: Andres Date: Tue, 12 Jun 2018 12:30:13 +0200 Subject: [PATCH 01/13] Vendor update --- Gopkg.lock | 161 +- Gopkg.toml | 12 +- vendor/cloud.google.com/go/CONTRIBUTORS | 1 + .../github.com/Masterminds/semver/.travis.yml | 12 +- .../Masterminds/semver/CHANGELOG.md | 14 + .../github.com/Masterminds/semver/version.go | 11 +- .../beorn7/perks/quantile/stream.go | 34 +- vendor/github.com/dgrijalva/jwt-go/README.md | 27 +- .../dgrijalva/jwt-go/VERSION_HISTORY.md | 7 + vendor/github.com/dgrijalva/jwt-go/ecdsa.go | 1 + vendor/github.com/dgrijalva/jwt-go/hmac.go | 3 +- vendor/github.com/dgrijalva/jwt-go/parser.go | 113 +- vendor/github.com/dgrijalva/jwt-go/rsa.go | 5 +- .../github.com/dgrijalva/jwt-go/rsa_utils.go | 32 + .../disintegration/imaging/.travis.yml | 11 +- .../disintegration/imaging/README.md | 5 +- .../disintegration/imaging/adjust.go | 2 +- .../github.com/disintegration/imaging/doc.go | 2 +- .../disintegration/imaging/helpers.go | 101 +- .../disintegration/imaging/resize.go | 7 +- .../github.com/emicklei/go-restful/CHANGES.md | 3 + .../github.com/emicklei/go-restful/README.md | 18 +- .../emicklei/go-restful/entity_accessors.go | 12 +- vendor/github.com/emicklei/go-restful/go.mod | 1 + vendor/github.com/go-ini/ini/.gitignore | 6 - vendor/github.com/go-ini/ini/.travis.yml | 16 - vendor/github.com/go-ini/ini/LICENSE | 191 - vendor/github.com/go-ini/ini/Makefile | 15 - vendor/github.com/go-ini/ini/README.md | 790 - vendor/github.com/go-ini/ini/README_ZH.md | 777 - vendor/github.com/go-ini/ini/error.go | 32 - vendor/github.com/go-ini/ini/file.go | 403 - vendor/github.com/go-ini/ini/ini.go | 194 - vendor/github.com/go-ini/ini/key.go | 751 - vendor/github.com/go-ini/ini/parser.go | 401 - vendor/github.com/go-ini/ini/section.go | 257 - vendor/github.com/go-ini/ini/struct.go | 512 - .../go-openapi/jsonpointer/.travis.yml | 4 +- .../go-openapi/jsonreference/.travis.yml | 4 +- vendor/github.com/go-openapi/spec/bindata.go | 8 +- vendor/github.com/go-openapi/spec/expander.go | 51 +- vendor/github.com/go-openapi/swag/json.go | 22 +- .../github.com/golang/protobuf/proto/Makefile | 43 - .../github.com/golang/protobuf/proto/clone.go | 46 +- .../golang/protobuf/proto/decode.go | 668 +- .../golang/protobuf/proto/discard.go | 201 +- .../golang/protobuf/proto/encode.go | 1191 +- .../github.com/golang/protobuf/proto/equal.go | 30 +- .../golang/protobuf/proto/extensions.go | 204 +- .../github.com/golang/protobuf/proto/lib.go | 70 +- .../golang/protobuf/proto/message_set.go | 81 +- .../golang/protobuf/proto/pointer_reflect.go | 595 +- .../golang/protobuf/proto/pointer_unsafe.go | 366 +- .../golang/protobuf/proto/properties.go | 424 +- .../golang/protobuf/proto/table_marshal.go | 2681 +++ .../golang/protobuf/proto/table_merge.go | 654 + .../golang/protobuf/proto/table_unmarshal.go | 1967 ++ .../github.com/golang/protobuf/proto/text.go | 61 +- .../golang/protobuf/proto/text_parser.go | 77 +- .../golang/protobuf/ptypes/any/any.pb.go | 49 +- .../protobuf/ptypes/duration/duration.pb.go | 51 +- .../golang/protobuf/ptypes/regen.sh | 43 - .../protobuf/ptypes/timestamp/timestamp.pb.go | 53 +- .../protobuf/ptypes/timestamp/timestamp.proto | 2 +- .../github.com/google/go-jsonnet/ast/clone.go | 8 +- .../google/go-jsonnet/ast/stdast.go | 17579 +++++++++------- vendor/github.com/google/go-jsonnet/vm.go | 2 +- .../googleapis/gnostic/OpenAPIv2/OpenAPIv2.go | 616 +- .../gnostic/OpenAPIv2/OpenAPIv2.pb.go | 5 +- .../googleapis/gnostic/compiler/reader.go | 4 +- .../gnostic/extensions/extension.pb.go | 53 +- .../gnostic/extensions/extension.proto | 4 +- .../gophercloud/gophercloud/.gitignore | 1 + .../gophercloud/gophercloud/.travis.yml | 4 +- .../gophercloud/gophercloud/.zuul.yaml | 64 + .../github.com/gophercloud/gophercloud/FAQ.md | 148 - .../gophercloud/gophercloud/MIGRATING.md | 32 - .../gophercloud/gophercloud/README.md | 6 +- .../gophercloud/gophercloud/STYLEGUIDE.md | 79 - .../gophercloud/gophercloud/auth_options.go | 75 +- .../gophercloud/gophercloud/errors.go | 38 +- .../gophercloud/openstack/auth_env.go | 12 +- .../gophercloud/openstack/client.go | 46 +- .../openstack/identity/v3/tokens/requests.go | 73 +- .../openstack/utils/base_endpoint.go | 29 + .../gophercloud/gophercloud/params.go | 12 +- .../gophercloud/provider_client.go | 46 +- .../gophercloud/gophercloud/results.go | 21 + .../gophercloud/gophercloud/service_client.go | 26 + vendor/github.com/gorilla/context/.travis.yml | 8 +- vendor/github.com/gorilla/context/README.md | 3 + vendor/github.com/gorilla/context/doc.go | 6 + vendor/github.com/gorilla/mux/.travis.yml | 11 +- vendor/github.com/gorilla/mux/README.md | 299 +- vendor/github.com/gorilla/mux/doc.go | 7 +- vendor/github.com/gorilla/mux/middleware.go | 52 +- vendor/github.com/gorilla/mux/mux.go | 9 +- vendor/github.com/gorilla/mux/route.go | 10 +- vendor/github.com/gorilla/mux/test_helpers.go | 3 +- vendor/github.com/imdario/mergo/README.md | 25 +- vendor/github.com/imdario/mergo/map.go | 14 +- vendor/github.com/imdario/mergo/merge.go | 60 +- vendor/github.com/json-iterator/go/config.go | 13 +- .../json-iterator/go/reflect_map.go | 22 + .../mailru/easyjson/jlexer/lexer.go | 39 +- .../mailru/easyjson/jwriter/writer.go | 17 +- .../pbutil/.gitignore | 1 + .../pbutil/Makefile | 7 + .../prometheus/common/expfmt/decode.go | 4 +- .../prometheus/common/expfmt/text_parse.go | 4 +- .../prometheus/common/model/silence.go | 4 +- .../prometheus/common/model/value.go | 4 +- .../github.com/prometheus/procfs/net_dev.go | 2 +- .../github.com/prometheus/procfs/nfs/nfs.go | 20 +- .../github.com/prometheus/procfs/nfs/parse.go | 16 +- vendor/github.com/prometheus/procfs/ttar | 26 +- .../github.com/sirupsen/logrus/CHANGELOG.md | 5 + vendor/github.com/sirupsen/logrus/README.md | 4 +- vendor/github.com/sirupsen/logrus/entry.go | 49 +- .../sirupsen/logrus/terminal_bsd.go | 2 +- .../logrus/terminal_check_appengine.go | 2 +- .../logrus/terminal_check_notappengine.go | 2 +- .../sirupsen/logrus/terminal_linux.go | 2 +- vendor/github.com/spf13/cobra/.travis.yml | 4 +- vendor/github.com/spf13/cobra/README.md | 77 +- vendor/github.com/spf13/cobra/args.go | 25 +- .../spf13/cobra/bash_completions.go | 167 +- .../spf13/cobra/bash_completions.md | 31 +- vendor/github.com/spf13/cobra/cobra.go | 12 +- vendor/github.com/spf13/cobra/command.go | 130 +- vendor/github.com/spf13/pflag/bytes.go | 105 + vendor/github.com/spf13/pflag/count.go | 12 +- .../github.com/spf13/pflag/duration_slice.go | 128 + vendor/github.com/spf13/pflag/flag.go | 155 +- vendor/github.com/spf13/pflag/golangflag.go | 4 + vendor/github.com/spf13/pflag/int16.go | 88 + vendor/github.com/spf13/pflag/string_array.go | 8 +- vendor/github.com/spf13/pflag/string_slice.go | 20 + vendor/golang.org/x/crypto/openpgp/keys.go | 19 +- .../x/crypto/openpgp/packet/encrypted_key.go | 9 +- .../x/crypto/openpgp/packet/packet.go | 32 +- .../x/crypto/openpgp/packet/public_key.go | 11 +- .../golang.org/x/crypto/ssh/terminal/util.go | 4 +- .../x/crypto/ssh/terminal/util_solaris.go | 40 +- .../x/crypto/ssh/terminal/util_windows.go | 4 +- vendor/golang.org/x/image/tiff/reader.go | 3 + vendor/golang.org/x/net/http/httpguts/guts.go | 65 + .../{lex/httplex => http/httpguts}/httplex.go | 7 +- vendor/golang.org/x/net/http2/frame.go | 4 +- vendor/golang.org/x/net/http2/hpack/hpack.go | 6 + vendor/golang.org/x/net/http2/http2.go | 6 +- vendor/golang.org/x/net/http2/server.go | 72 +- vendor/golang.org/x/net/http2/transport.go | 19 +- vendor/golang.org/x/net/http2/write.go | 8 +- .../x/net/internal/timeseries/timeseries.go | 525 + vendor/golang.org/x/net/trace/events.go | 532 + vendor/golang.org/x/net/trace/histogram.go | 365 + vendor/golang.org/x/net/trace/trace.go | 1103 + vendor/golang.org/x/net/trace/trace_go16.go | 21 + vendor/golang.org/x/net/trace/trace_go17.go | 21 + vendor/golang.org/x/oauth2/CONTRIBUTING.md | 15 +- vendor/golang.org/x/oauth2/google/default.go | 68 +- vendor/golang.org/x/oauth2/google/doc_go19.go | 42 + .../x/oauth2/google/doc_not_go19.go | 43 + vendor/golang.org/x/oauth2/google/go19.go | 57 + vendor/golang.org/x/oauth2/google/google.go | 12 +- vendor/golang.org/x/oauth2/google/not_go19.go | 54 + vendor/golang.org/x/oauth2/internal/token.go | 2 + vendor/golang.org/x/oauth2/oauth2.go | 3 +- vendor/golang.org/x/oauth2/transport.go | 16 +- .../x/sys/unix/asm_dragonfly_amd64.s | 10 +- vendor/golang.org/x/sys/unix/cap_freebsd.go | 30 +- .../x/sys/unix/{flock.go => fcntl.go} | 6 + ...ck_linux_32bit.go => fcntl_linux_32bit.go} | 0 vendor/golang.org/x/sys/unix/mkerrors.sh | 58 +- vendor/golang.org/x/sys/unix/mkpost.go | 13 +- .../golang.org/x/sys/unix/openbsd_pledge.go | 4 +- vendor/golang.org/x/sys/unix/syscall.go | 11 +- vendor/golang.org/x/sys/unix/syscall_bsd.go | 41 - .../golang.org/x/sys/unix/syscall_darwin.go | 95 +- .../x/sys/unix/syscall_dragonfly.go | 2 + .../golang.org/x/sys/unix/syscall_freebsd.go | 15 +- vendor/golang.org/x/sys/unix/syscall_linux.go | 75 +- .../x/sys/unix/syscall_linux_amd64.go | 17 +- .../x/sys/unix/syscall_linux_arm64.go | 1 + .../x/sys/unix/syscall_linux_gccgo.go | 21 + .../x/sys/unix/syscall_linux_mips64x.go | 1 + .../x/sys/unix/syscall_linux_mipsx.go | 3 +- .../x/sys/unix/syscall_linux_ppc64x.go | 1 + .../x/sys/unix/syscall_linux_sparc64.go | 1 + .../golang.org/x/sys/unix/syscall_netbsd.go | 4 +- .../golang.org/x/sys/unix/syscall_openbsd.go | 6 +- .../x/sys/unix/syscall_openbsd_amd64.go | 4 + .../golang.org/x/sys/unix/syscall_solaris.go | 10 +- .../x/sys/unix/syscall_solaris_amd64.go | 5 - vendor/golang.org/x/sys/unix/syscall_unix.go | 97 +- vendor/golang.org/x/sys/unix/types_netbsd.go | 11 + .../x/sys/unix/zerrors_darwin_386.go | 292 +- .../x/sys/unix/zerrors_darwin_amd64.go | 292 +- .../x/sys/unix/zerrors_darwin_arm.go | 292 +- .../x/sys/unix/zerrors_darwin_arm64.go | 292 +- .../x/sys/unix/zerrors_dragonfly_amd64.go | 281 +- .../x/sys/unix/zerrors_freebsd_386.go | 270 +- .../x/sys/unix/zerrors_freebsd_amd64.go | 270 +- .../x/sys/unix/zerrors_freebsd_arm.go | 270 +- .../x/sys/unix/zerrors_linux_386.go | 595 +- .../x/sys/unix/zerrors_linux_amd64.go | 594 +- .../x/sys/unix/zerrors_linux_arm.go | 593 +- .../x/sys/unix/zerrors_linux_arm64.go | 595 +- .../x/sys/unix/zerrors_linux_mips.go | 599 +- .../x/sys/unix/zerrors_linux_mips64.go | 599 +- .../x/sys/unix/zerrors_linux_mips64le.go | 599 +- .../x/sys/unix/zerrors_linux_mipsle.go | 599 +- .../x/sys/unix/zerrors_linux_ppc64.go | 595 +- .../x/sys/unix/zerrors_linux_ppc64le.go | 595 +- .../x/sys/unix/zerrors_linux_s390x.go | 593 +- .../x/sys/unix/zerrors_netbsd_386.go | 269 +- .../x/sys/unix/zerrors_netbsd_amd64.go | 269 +- .../x/sys/unix/zerrors_netbsd_arm.go | 269 +- .../x/sys/unix/zerrors_openbsd_386.go | 259 +- .../x/sys/unix/zerrors_openbsd_amd64.go | 506 +- .../x/sys/unix/zerrors_openbsd_arm.go | 259 +- .../x/sys/unix/zerrors_solaris_amd64.go | 336 +- .../x/sys/unix/zsyscall_darwin_386.go | 92 + .../x/sys/unix/zsyscall_darwin_amd64.go | 92 + .../x/sys/unix/zsyscall_darwin_arm.go | 94 +- .../x/sys/unix/zsyscall_darwin_arm64.go | 92 + .../x/sys/unix/zsyscall_dragonfly_amd64.go | 30 + .../x/sys/unix/zsyscall_freebsd_386.go | 15 + .../x/sys/unix/zsyscall_freebsd_amd64.go | 15 + .../x/sys/unix/zsyscall_freebsd_arm.go | 15 + .../x/sys/unix/zsyscall_linux_386.go | 11 + .../x/sys/unix/zsyscall_linux_amd64.go | 37 +- .../x/sys/unix/zsyscall_linux_arm.go | 11 + .../x/sys/unix/zsyscall_linux_arm64.go | 21 + .../x/sys/unix/zsyscall_linux_mips.go | 27 +- .../x/sys/unix/zsyscall_linux_mips64.go | 21 + .../x/sys/unix/zsyscall_linux_mips64le.go | 21 + .../x/sys/unix/zsyscall_linux_mipsle.go | 27 +- .../x/sys/unix/zsyscall_linux_ppc64.go | 21 + .../x/sys/unix/zsyscall_linux_ppc64le.go | 21 + .../x/sys/unix/zsyscall_linux_s390x.go | 11 + .../x/sys/unix/zsyscall_linux_sparc64.go | 10 + .../x/sys/unix/zsyscall_netbsd_386.go | 40 + .../x/sys/unix/zsyscall_netbsd_amd64.go | 40 + .../x/sys/unix/zsyscall_netbsd_arm.go | 40 + .../x/sys/unix/zsyscall_openbsd_386.go | 51 + .../x/sys/unix/zsyscall_openbsd_amd64.go | 51 + .../x/sys/unix/zsyscall_openbsd_arm.go | 51 + .../x/sys/unix/zsyscall_solaris_amd64.go | 28 + .../x/sys/unix/zsysctl_openbsd_amd64.go | 51 +- .../x/sys/unix/zsysnum_linux_ppc64.go | 3 + .../x/sys/unix/zsysnum_linux_ppc64le.go | 3 + .../x/sys/unix/zsysnum_linux_s390x.go | 44 +- .../x/sys/unix/zsysnum_openbsd_amd64.go | 24 +- .../x/sys/unix/ztypes_darwin_386.go | 112 +- .../x/sys/unix/ztypes_darwin_amd64.go | 158 +- .../x/sys/unix/ztypes_darwin_arm.go | 112 +- .../x/sys/unix/ztypes_darwin_arm64.go | 158 +- .../x/sys/unix/ztypes_dragonfly_amd64.go | 100 +- .../golang.org/x/sys/unix/ztypes_linux_386.go | 1010 +- .../x/sys/unix/ztypes_linux_amd64.go | 978 +- .../golang.org/x/sys/unix/ztypes_linux_arm.go | 1012 +- .../x/sys/unix/ztypes_linux_arm64.go | 980 +- .../x/sys/unix/ztypes_linux_mips.go | 978 +- .../x/sys/unix/ztypes_linux_mips64.go | 976 +- .../x/sys/unix/ztypes_linux_mips64le.go | 976 +- .../x/sys/unix/ztypes_linux_mipsle.go | 978 +- .../x/sys/unix/ztypes_linux_ppc64.go | 986 +- .../x/sys/unix/ztypes_linux_ppc64le.go | 986 +- .../x/sys/unix/ztypes_linux_s390x.go | 958 +- .../x/sys/unix/ztypes_linux_sparc64.go | 208 +- .../x/sys/unix/ztypes_netbsd_386.go | 9 + .../x/sys/unix/ztypes_netbsd_amd64.go | 9 + .../x/sys/unix/ztypes_netbsd_arm.go | 9 + .../x/sys/unix/ztypes_openbsd_amd64.go | 91 +- .../x/sys/unix/ztypes_solaris_amd64.go | 174 +- .../x/sys/windows/asm_windows_386.s | 4 +- .../x/sys/windows/asm_windows_amd64.s | 2 +- vendor/golang.org/x/sys/windows/service.go | 1 + vendor/golang.org/x/sys/windows/syscall.go | 3 + .../x/sys/windows/zsyscall_windows.go | 13 + vendor/google.golang.org/genproto/LICENSE | 202 + .../googleapis/rpc/status/status.pb.go | 156 + vendor/google.golang.org/grpc/.travis.yml | 24 + vendor/google.golang.org/grpc/AUTHORS | 1 + vendor/google.golang.org/grpc/CONTRIBUTING.md | 36 + vendor/google.golang.org/grpc/LICENSE | 202 + vendor/google.golang.org/grpc/Makefile | 48 + vendor/google.golang.org/grpc/README.md | 45 + vendor/google.golang.org/grpc/backoff.go | 96 + vendor/google.golang.org/grpc/balancer.go | 416 + .../grpc/balancer/balancer.go | 228 + .../grpc/balancer/base/balancer.go | 208 + .../grpc/balancer/base/base.go | 52 + .../grpc/balancer/roundrobin/roundrobin.go | 79 + .../grpc/balancer_conn_wrappers.go | 300 + .../grpc/balancer_v1_wrapper.go | 372 + vendor/google.golang.org/grpc/call.go | 93 + .../google.golang.org/grpc/channelz/funcs.go | 573 + .../google.golang.org/grpc/channelz/types.go | 418 + vendor/google.golang.org/grpc/clientconn.go | 1591 ++ vendor/google.golang.org/grpc/codec.go | 50 + vendor/google.golang.org/grpc/codegen.sh | 17 + .../grpc/codes/code_string.go | 62 + vendor/google.golang.org/grpc/codes/codes.go | 184 + .../grpc/connectivity/connectivity.go | 72 + .../grpc/credentials/credentials.go | 220 + .../grpc/credentials/credentials_util_go17.go | 60 + .../grpc/credentials/credentials_util_go18.go | 38 + .../credentials/credentials_util_pre_go17.go | 57 + vendor/google.golang.org/grpc/doc.go | 24 + .../grpc/encoding/encoding.go | 118 + .../grpc/encoding/proto/proto.go | 110 + vendor/google.golang.org/grpc/envconfig.go | 37 + vendor/google.golang.org/grpc/go16.go | 70 + vendor/google.golang.org/grpc/go17.go | 71 + vendor/google.golang.org/grpc/grpclb.go | 341 + .../grpclb/grpc_lb_v1/messages/messages.pb.go | 799 + .../grpclb/grpc_lb_v1/messages/messages.proto | 155 + .../google.golang.org/grpc/grpclb_picker.go | 159 + .../grpc/grpclb_remote_balancer.go | 266 + vendor/google.golang.org/grpc/grpclb_util.go | 214 + .../google.golang.org/grpc/grpclog/grpclog.go | 126 + .../google.golang.org/grpc/grpclog/logger.go | 85 + .../grpc/grpclog/loggerv2.go | 195 + .../grpc/health/grpc_health_v1/health.pb.go | 227 + .../grpc/health/grpc_health_v1/health.proto | 44 + vendor/google.golang.org/grpc/interceptor.go | 77 + .../grpc/internal/internal.go | 27 + .../grpc/keepalive/keepalive.go | 65 + .../grpc/metadata/metadata.go | 210 + .../grpc/naming/dns_resolver.go | 290 + vendor/google.golang.org/grpc/naming/go17.go | 34 + vendor/google.golang.org/grpc/naming/go18.go | 28 + .../google.golang.org/grpc/naming/naming.go | 69 + vendor/google.golang.org/grpc/peer/peer.go | 51 + .../google.golang.org/grpc/picker_wrapper.go | 331 + vendor/google.golang.org/grpc/pickfirst.go | 108 + vendor/google.golang.org/grpc/proxy.go | 130 + .../grpc/resolver/dns/dns_resolver.go | 379 + .../grpc/resolver/dns/go17.go | 35 + .../grpc/resolver/dns/go18.go | 29 + .../grpc/resolver/passthrough/passthrough.go | 57 + .../grpc/resolver/resolver.go | 154 + .../grpc/resolver_conn_wrapper.go | 158 + vendor/google.golang.org/grpc/rpc_util.go | 727 + vendor/google.golang.org/grpc/server.go | 1486 ++ .../google.golang.org/grpc/service_config.go | 233 + .../google.golang.org/grpc/stats/handlers.go | 64 + vendor/google.golang.org/grpc/stats/stats.go | 296 + .../google.golang.org/grpc/status/status.go | 189 + vendor/google.golang.org/grpc/stream.go | 765 + vendor/google.golang.org/grpc/tap/tap.go | 51 + vendor/google.golang.org/grpc/trace.go | 113 + .../grpc/transport/bdp_estimator.go | 140 + .../grpc/transport/controlbuf.go | 769 + .../grpc/transport/flowcontrol.go | 236 + .../google.golang.org/grpc/transport/go16.go | 51 + .../google.golang.org/grpc/transport/go17.go | 52 + .../grpc/transport/handler_server.go | 451 + .../grpc/transport/http2_client.go | 1284 ++ .../grpc/transport/http2_server.go | 1137 + .../grpc/transport/http_util.go | 578 + .../google.golang.org/grpc/transport/log.go | 50 + .../grpc/transport/transport.go | 708 + vendor/google.golang.org/grpc/vet.sh | 93 + vendor/gopkg.in/inf.v0/dec.go | 2 +- vendor/gopkg.in/yaml.v2/README.md | 2 - vendor/gopkg.in/yaml.v2/apic.go | 2 +- vendor/gopkg.in/yaml.v2/decode.go | 13 +- vendor/gopkg.in/yaml.v2/emitterc.go | 2 +- vendor/gopkg.in/yaml.v2/encode.go | 16 +- vendor/gopkg.in/yaml.v2/readerc.go | 20 +- vendor/gopkg.in/yaml.v2/resolve.go | 29 +- vendor/gopkg.in/yaml.v2/scannerc.go | 18 +- vendor/gopkg.in/yaml.v2/sorter.go | 9 + vendor/gopkg.in/yaml.v2/yaml.go | 4 +- vendor/k8s.io/helm/pkg/chartutil/chartfile.go | 2 +- vendor/k8s.io/helm/pkg/chartutil/create.go | 1 - vendor/k8s.io/helm/pkg/chartutil/expand.go | 3 +- vendor/k8s.io/helm/pkg/chartutil/files.go | 4 +- vendor/k8s.io/helm/pkg/chartutil/save.go | 6 + vendor/k8s.io/helm/pkg/getter/httpgetter.go | 37 +- vendor/k8s.io/helm/pkg/helm/client.go | 522 + .../helm/pkg/helm/environment/environment.go | 3 + vendor/k8s.io/helm/pkg/helm/fake.go | 277 + vendor/k8s.io/helm/pkg/helm/interface.go | 39 + vendor/k8s.io/helm/pkg/helm/option.go | 444 + .../helm/pkg/proto/hapi/chart/metadata.pb.go | 59 +- .../helm/pkg/proto/hapi/release/hook.pb.go | 231 + .../helm/pkg/proto/hapi/release/info.pb.go | 90 + .../helm/pkg/proto/hapi/release/release.pb.go | 124 + .../helm/pkg/proto/hapi/release/status.pb.go | 141 + .../pkg/proto/hapi/release/test_run.pb.go | 118 + .../pkg/proto/hapi/release/test_suite.pb.go | 73 + .../helm/pkg/proto/hapi/services/tiller.pb.go | 1449 ++ vendor/k8s.io/helm/pkg/repo/chartrepo.go | 20 + vendor/k8s.io/helm/pkg/repo/repo.go | 3 +- vendor/k8s.io/helm/pkg/version/version.go | 2 +- .../k8s.io/kube-openapi/pkg/common/common.go | 2 +- 401 files changed, 65401 insertions(+), 22102 deletions(-) create mode 100644 vendor/github.com/emicklei/go-restful/go.mod delete mode 100644 vendor/github.com/go-ini/ini/.gitignore delete mode 100644 vendor/github.com/go-ini/ini/.travis.yml delete mode 100644 vendor/github.com/go-ini/ini/LICENSE delete mode 100644 vendor/github.com/go-ini/ini/Makefile delete mode 100644 vendor/github.com/go-ini/ini/README.md delete mode 100644 vendor/github.com/go-ini/ini/README_ZH.md delete mode 100644 vendor/github.com/go-ini/ini/error.go delete mode 100644 vendor/github.com/go-ini/ini/file.go delete mode 100644 vendor/github.com/go-ini/ini/ini.go delete mode 100644 vendor/github.com/go-ini/ini/key.go delete mode 100644 vendor/github.com/go-ini/ini/parser.go delete mode 100644 vendor/github.com/go-ini/ini/section.go delete mode 100644 vendor/github.com/go-ini/ini/struct.go delete mode 100644 vendor/github.com/golang/protobuf/proto/Makefile create mode 100644 vendor/github.com/golang/protobuf/proto/table_marshal.go create mode 100644 vendor/github.com/golang/protobuf/proto/table_merge.go create mode 100644 vendor/github.com/golang/protobuf/proto/table_unmarshal.go delete mode 100755 vendor/github.com/golang/protobuf/ptypes/regen.sh delete mode 100644 vendor/github.com/gophercloud/gophercloud/FAQ.md delete mode 100644 vendor/github.com/gophercloud/gophercloud/MIGRATING.md delete mode 100644 vendor/github.com/gophercloud/gophercloud/STYLEGUIDE.md create mode 100644 vendor/github.com/gophercloud/gophercloud/openstack/utils/base_endpoint.go create mode 100644 vendor/github.com/matttproud/golang_protobuf_extensions/pbutil/.gitignore create mode 100644 vendor/github.com/matttproud/golang_protobuf_extensions/pbutil/Makefile create mode 100644 vendor/github.com/spf13/pflag/bytes.go create mode 100644 vendor/github.com/spf13/pflag/duration_slice.go create mode 100644 vendor/github.com/spf13/pflag/int16.go create mode 100644 vendor/golang.org/x/net/http/httpguts/guts.go rename vendor/golang.org/x/net/{lex/httplex => http/httpguts}/httplex.go (97%) create mode 100644 vendor/golang.org/x/net/internal/timeseries/timeseries.go create mode 100644 vendor/golang.org/x/net/trace/events.go create mode 100644 vendor/golang.org/x/net/trace/histogram.go create mode 100644 vendor/golang.org/x/net/trace/trace.go create mode 100644 vendor/golang.org/x/net/trace/trace_go16.go create mode 100644 vendor/golang.org/x/net/trace/trace_go17.go create mode 100644 vendor/golang.org/x/oauth2/google/doc_go19.go create mode 100644 vendor/golang.org/x/oauth2/google/doc_not_go19.go create mode 100644 vendor/golang.org/x/oauth2/google/go19.go create mode 100644 vendor/golang.org/x/oauth2/google/not_go19.go rename vendor/golang.org/x/sys/unix/{flock.go => fcntl.go} (74%) rename vendor/golang.org/x/sys/unix/{flock_linux_32bit.go => fcntl_linux_32bit.go} (100%) create mode 100644 vendor/golang.org/x/sys/unix/syscall_linux_gccgo.go create mode 100644 vendor/google.golang.org/genproto/LICENSE create mode 100644 vendor/google.golang.org/genproto/googleapis/rpc/status/status.pb.go create mode 100644 vendor/google.golang.org/grpc/.travis.yml create mode 100644 vendor/google.golang.org/grpc/AUTHORS create mode 100644 vendor/google.golang.org/grpc/CONTRIBUTING.md create mode 100644 vendor/google.golang.org/grpc/LICENSE create mode 100644 vendor/google.golang.org/grpc/Makefile create mode 100644 vendor/google.golang.org/grpc/README.md create mode 100644 vendor/google.golang.org/grpc/backoff.go create mode 100644 vendor/google.golang.org/grpc/balancer.go create mode 100644 vendor/google.golang.org/grpc/balancer/balancer.go create mode 100644 vendor/google.golang.org/grpc/balancer/base/balancer.go create mode 100644 vendor/google.golang.org/grpc/balancer/base/base.go create mode 100644 vendor/google.golang.org/grpc/balancer/roundrobin/roundrobin.go create mode 100644 vendor/google.golang.org/grpc/balancer_conn_wrappers.go create mode 100644 vendor/google.golang.org/grpc/balancer_v1_wrapper.go create mode 100644 vendor/google.golang.org/grpc/call.go create mode 100644 vendor/google.golang.org/grpc/channelz/funcs.go create mode 100644 vendor/google.golang.org/grpc/channelz/types.go create mode 100644 vendor/google.golang.org/grpc/clientconn.go create mode 100644 vendor/google.golang.org/grpc/codec.go create mode 100755 vendor/google.golang.org/grpc/codegen.sh create mode 100644 vendor/google.golang.org/grpc/codes/code_string.go create mode 100644 vendor/google.golang.org/grpc/codes/codes.go create mode 100644 vendor/google.golang.org/grpc/connectivity/connectivity.go create mode 100644 vendor/google.golang.org/grpc/credentials/credentials.go create mode 100644 vendor/google.golang.org/grpc/credentials/credentials_util_go17.go create mode 100644 vendor/google.golang.org/grpc/credentials/credentials_util_go18.go create mode 100644 vendor/google.golang.org/grpc/credentials/credentials_util_pre_go17.go create mode 100644 vendor/google.golang.org/grpc/doc.go create mode 100644 vendor/google.golang.org/grpc/encoding/encoding.go create mode 100644 vendor/google.golang.org/grpc/encoding/proto/proto.go create mode 100644 vendor/google.golang.org/grpc/envconfig.go create mode 100644 vendor/google.golang.org/grpc/go16.go create mode 100644 vendor/google.golang.org/grpc/go17.go create mode 100644 vendor/google.golang.org/grpc/grpclb.go create mode 100644 vendor/google.golang.org/grpc/grpclb/grpc_lb_v1/messages/messages.pb.go create mode 100644 vendor/google.golang.org/grpc/grpclb/grpc_lb_v1/messages/messages.proto create mode 100644 vendor/google.golang.org/grpc/grpclb_picker.go create mode 100644 vendor/google.golang.org/grpc/grpclb_remote_balancer.go create mode 100644 vendor/google.golang.org/grpc/grpclb_util.go create mode 100644 vendor/google.golang.org/grpc/grpclog/grpclog.go create mode 100644 vendor/google.golang.org/grpc/grpclog/logger.go create mode 100644 vendor/google.golang.org/grpc/grpclog/loggerv2.go create mode 100644 vendor/google.golang.org/grpc/health/grpc_health_v1/health.pb.go create mode 100644 vendor/google.golang.org/grpc/health/grpc_health_v1/health.proto create mode 100644 vendor/google.golang.org/grpc/interceptor.go create mode 100644 vendor/google.golang.org/grpc/internal/internal.go create mode 100644 vendor/google.golang.org/grpc/keepalive/keepalive.go create mode 100644 vendor/google.golang.org/grpc/metadata/metadata.go create mode 100644 vendor/google.golang.org/grpc/naming/dns_resolver.go create mode 100644 vendor/google.golang.org/grpc/naming/go17.go create mode 100644 vendor/google.golang.org/grpc/naming/go18.go create mode 100644 vendor/google.golang.org/grpc/naming/naming.go create mode 100644 vendor/google.golang.org/grpc/peer/peer.go create mode 100644 vendor/google.golang.org/grpc/picker_wrapper.go create mode 100644 vendor/google.golang.org/grpc/pickfirst.go create mode 100644 vendor/google.golang.org/grpc/proxy.go create mode 100644 vendor/google.golang.org/grpc/resolver/dns/dns_resolver.go create mode 100644 vendor/google.golang.org/grpc/resolver/dns/go17.go create mode 100644 vendor/google.golang.org/grpc/resolver/dns/go18.go create mode 100644 vendor/google.golang.org/grpc/resolver/passthrough/passthrough.go create mode 100644 vendor/google.golang.org/grpc/resolver/resolver.go create mode 100644 vendor/google.golang.org/grpc/resolver_conn_wrapper.go create mode 100644 vendor/google.golang.org/grpc/rpc_util.go create mode 100644 vendor/google.golang.org/grpc/server.go create mode 100644 vendor/google.golang.org/grpc/service_config.go create mode 100644 vendor/google.golang.org/grpc/stats/handlers.go create mode 100644 vendor/google.golang.org/grpc/stats/stats.go create mode 100644 vendor/google.golang.org/grpc/status/status.go create mode 100644 vendor/google.golang.org/grpc/stream.go create mode 100644 vendor/google.golang.org/grpc/tap/tap.go create mode 100644 vendor/google.golang.org/grpc/trace.go create mode 100644 vendor/google.golang.org/grpc/transport/bdp_estimator.go create mode 100644 vendor/google.golang.org/grpc/transport/controlbuf.go create mode 100644 vendor/google.golang.org/grpc/transport/flowcontrol.go create mode 100644 vendor/google.golang.org/grpc/transport/go16.go create mode 100644 vendor/google.golang.org/grpc/transport/go17.go create mode 100644 vendor/google.golang.org/grpc/transport/handler_server.go create mode 100644 vendor/google.golang.org/grpc/transport/http2_client.go create mode 100644 vendor/google.golang.org/grpc/transport/http2_server.go create mode 100644 vendor/google.golang.org/grpc/transport/http_util.go create mode 100644 vendor/google.golang.org/grpc/transport/log.go create mode 100644 vendor/google.golang.org/grpc/transport/transport.go create mode 100755 vendor/google.golang.org/grpc/vet.sh create mode 100644 vendor/k8s.io/helm/pkg/helm/client.go create mode 100644 vendor/k8s.io/helm/pkg/helm/fake.go create mode 100644 vendor/k8s.io/helm/pkg/helm/interface.go create mode 100644 vendor/k8s.io/helm/pkg/helm/option.go create mode 100644 vendor/k8s.io/helm/pkg/proto/hapi/release/hook.pb.go create mode 100644 vendor/k8s.io/helm/pkg/proto/hapi/release/info.pb.go create mode 100644 vendor/k8s.io/helm/pkg/proto/hapi/release/release.pb.go create mode 100644 vendor/k8s.io/helm/pkg/proto/hapi/release/status.pb.go create mode 100644 vendor/k8s.io/helm/pkg/proto/hapi/release/test_run.pb.go create mode 100644 vendor/k8s.io/helm/pkg/proto/hapi/release/test_suite.pb.go create mode 100644 vendor/k8s.io/helm/pkg/proto/hapi/services/tiller.pb.go diff --git a/Gopkg.lock b/Gopkg.lock index 1c537e4489b..81918d4d6a8 100644 --- a/Gopkg.lock +++ b/Gopkg.lock @@ -4,8 +4,8 @@ [[projects]] name = "cloud.google.com/go" packages = ["compute/metadata"] - revision = "20d4028b8a750c2aca76bf9fefa8ed2d0109b573" - version = "v0.19.0" + revision = "0fd7230b2a7505833d5f69b75cbd6c9582401479" + version = "v0.23.0" [[projects]] name = "github.com/Azure/go-autorest" @@ -26,8 +26,8 @@ [[projects]] name = "github.com/Masterminds/semver" packages = ["."] - revision = "15d8430ab86497c5c0da827b748823945e1cf1e1" - version = "v1.4.0" + revision = "c7af12943936e8c39859482e61f0574c2fd7fc75" + version = "v1.4.2" [[projects]] name = "github.com/PuerkitoBio/purell" @@ -51,7 +51,7 @@ branch = "master" name = "github.com/beorn7/perks" packages = ["quantile"] - revision = "4c0e84591b9aa9e6dcfdf3e020114cd81f89d5f9" + revision = "3a771d992973f24aa725d07868b467d1ddfceafb" [[projects]] name = "github.com/davecgh/go-spew" @@ -62,14 +62,14 @@ [[projects]] name = "github.com/dgrijalva/jwt-go" packages = ["."] - revision = "dbeaa9332f19a944acb5736b4456cfcc02140e29" - version = "v3.1.0" + revision = "06ea1031745cb8b3dab3f6a236daf2b0aa468b7e" + version = "v3.2.0" [[projects]] name = "github.com/disintegration/imaging" packages = ["."] - revision = "b039796423f87e7caca7f8eaace36878f2cce73d" - version = "1.4.0" + revision = "bbcee2f5c9d5e94ca42c8b50ec847fec64a6c134" + version = "v1.4.2" [[projects]] branch = "master" @@ -92,8 +92,8 @@ ".", "log" ] - revision = "26b41036311f2da8242db402557a0dbd09dc83da" - version = "v2.6.0" + revision = "3658237ded108b4134956c1b3050349d93e7b895" + version = "v2.7.1" [[projects]] name = "github.com/emicklei/go-restful-swagger12" @@ -107,35 +107,29 @@ revision = "0ca9ea5df5451ffdf184b4428c902747c2c11cd7" version = "v1.0.0" -[[projects]] - name = "github.com/go-ini/ini" - packages = ["."] - revision = "6333e38ac20b8949a8dd68baa3650f4dee8f39f0" - version = "v1.33.0" - [[projects]] branch = "master" name = "github.com/go-openapi/jsonpointer" packages = ["."] - revision = "779f45308c19820f1a69e9a4cd965f496e0da10f" + revision = "3a0015ad55fa9873f41605d3e8f28cd279c32ab2" [[projects]] branch = "master" name = "github.com/go-openapi/jsonreference" packages = ["."] - revision = "36d33bfe519efae5632669801b180bf1a245da3b" + revision = "3fb327e6747da3043567ee86abd02bb6376b6be2" [[projects]] branch = "master" name = "github.com/go-openapi/spec" packages = ["."] - revision = "d8000b5bfbd1147255710505a27c735b6b2ae2ac" + revision = "bcff419492eeeb01f76e77d2ebc714dc97b607f5" [[projects]] branch = "master" name = "github.com/go-openapi/swag" packages = ["."] - revision = "ceb469cb0fdf2d792f28d771bc05da6c606f55e5" + revision = "811b1089cde9dad18d4d0c2d09fbdbf28dbd27a5" [[projects]] name = "github.com/gobwas/glob" @@ -171,7 +165,7 @@ branch = "master" name = "github.com/golang/groupcache" packages = ["lru"] - revision = "66deaeb636dff1ac7d938ce666d090556056a4b0" + revision = "24b0969c4cb722950103eed87108c8d291a8df00" [[projects]] name = "github.com/golang/protobuf" @@ -182,8 +176,8 @@ "ptypes/duration", "ptypes/timestamp" ] - revision = "925541529c1fa6821df4e44ce2723319eb2be768" - version = "v1.0.0" + revision = "b4deda0973fb4c70b50d226b1af49f3da59f5265" + version = "v1.1.0" [[projects]] branch = "master" @@ -192,14 +186,14 @@ revision = "e89373fe6b4a7413d7acd6da1725b83ef713e6e4" [[projects]] - branch = "master" name = "github.com/google/go-jsonnet" packages = [ ".", "ast", "parser" ] - revision = "405726fae23ace72b22c410a77b7bd825608f2c8" + revision = "dfddf2b4e3aec377b0dcdf247ff92e7d078b8179" + version = "v0.10.0" [[projects]] branch = "master" @@ -214,8 +208,8 @@ "compiler", "extensions" ] - revision = "ee43cbb60db7bd22502942cccbc39059117352ab" - version = "v0.1.0" + revision = "7c663266750e7d82587642f65e60bc4083f1f84e" + version = "v0.2.0" [[projects]] branch = "master" @@ -229,19 +223,19 @@ "openstack/utils", "pagination" ] - revision = "24d38e255f73b6eac52312031a9450f57e0c6b60" + revision = "5bd6a8f0bae89676ade094aa429146a25bf782e0" [[projects]] name = "github.com/gorilla/context" packages = ["."] - revision = "1ea25387ff6f684839d82767c1733ff4d4d15d0a" - version = "v1.1" + revision = "08b5f424b9271eedf6f9f0ce86cb9396ed337a42" + version = "v1.1.1" [[projects]] name = "github.com/gorilla/mux" packages = ["."] - revision = "53c1911da2b537f792e7cafcb446b05ffe33b996" - version = "v1.6.1" + revision = "e3702bed27f0d39777b0b37b664b6280e8ef8fbf" + version = "v1.6.2" [[projects]] branch = "master" @@ -286,8 +280,8 @@ [[projects]] name = "github.com/imdario/mergo" packages = ["."] - revision = "163f41321a19dd09362d4c63cc2489db2015f1f4" - version = "0.3.2" + revision = "9d5f1277e9a8ed20c3684bda8fde67c05628518c" + version = "v0.3.4" [[projects]] name = "github.com/inconshreveable/mousetrap" @@ -304,8 +298,8 @@ [[projects]] name = "github.com/json-iterator/go" packages = ["."] - revision = "3353055b2a1a5ae1b6a8dfde887a524e7088f3a2" - version = "1.1.2" + revision = "ca39e5af3ece67bbcda3d0f4f56a8e24d9f2dad4" + version = "1.1.3" [[projects]] name = "github.com/juju/ratelimit" @@ -339,7 +333,7 @@ "jlexer", "jwriter" ] - revision = "4a8a4c12c4d1b0c0a7de630426ce6dcb07141b17" + revision = "3fdea8d05856a0c8df22ed4bc71b3219245e4485" [[projects]] name = "github.com/mattn/go-isatty" @@ -356,8 +350,8 @@ [[projects]] name = "github.com/matttproud/golang_protobuf_extensions" packages = ["pbutil"] - revision = "3247c84500bff8d9fb6d579d800f20b3e091582c" - version = "v1.0.0" + revision = "c12348ce28de40eed0136aa2b644d0ee0650e56c" + version = "v1.0.1" [[projects]] name = "github.com/modern-go/concurrent" @@ -409,7 +403,7 @@ "internal/bitbucket.org/ww/goautoneg", "model" ] - revision = "6fb6fce6f8b75884b92e1889c150403fc0872c5e" + revision = "7600349dcfe1abd18d72d3a1770870d9800a7801" [[projects]] branch = "master" @@ -420,7 +414,7 @@ "nfs", "xfs" ] - revision = "1c7ff3de94ae006f58cba483a4c9c6d7c61e1d98" + revision = "94663424ae5ae9856b40a9f170762b4197024661" [[projects]] name = "github.com/rakyll/statik" @@ -437,20 +431,20 @@ [[projects]] name = "github.com/sirupsen/logrus" packages = ["."] - revision = "d682213848ed68c0a260ca37d6dd5ace8423f5ba" - version = "v1.0.4" + revision = "c155da19408a8799da419ed3eeb0cb5db0ad5dbc" + version = "v1.0.5" [[projects]] name = "github.com/spf13/cobra" packages = ["."] - revision = "7b2c5ac9fc04fc5efafb60700713d4fa609b777b" - version = "v0.0.1" + revision = "ef82de70bb3f60c65fb8eebacbb2d122ef517385" + version = "v0.0.3" [[projects]] name = "github.com/spf13/pflag" packages = ["."] - revision = "e57e3eeb33f795204c1ca35f56c44f83227c6e66" - version = "v1.0.0" + revision = "583c0c0531f06d5278b7d917446061adc344b5cd" + version = "v1.0.1" [[projects]] name = "github.com/stretchr/objx" @@ -508,7 +502,7 @@ "openpgp/s2k", "ssh/terminal" ] - revision = "85f98707c97e11569271e4d9b3d397e079c4f4d0" + revision = "8ac0e0d97ce45cd83d1d7243c060cb8461dda5e9" [[projects]] branch = "master" @@ -518,7 +512,7 @@ "tiff", "tiff/lzw" ] - revision = "12117c17ca67ffa1ce22e9409f3b0b0a93ac08c7" + revision = "af66defab954cb421ca110193eed9477c8541e2a" [[projects]] branch = "master" @@ -526,12 +520,14 @@ packages = [ "context", "context/ctxhttp", + "http/httpguts", "http2", "http2/hpack", "idna", - "lex/httplex" + "internal/timeseries", + "trace" ] - revision = "07e8617a6db2368fa55d4616f371ee1b1403c817" + revision = "1e491301e022f8f977054da4c2d852decd59571f" [[projects]] branch = "master" @@ -543,7 +539,7 @@ "jws", "jwt" ] - revision = "2f32c3ac0fa4fb807a0fcefb0b6f2468a0d99bd0" + revision = "1e0a3fa8ba9a5c9eb35c271780101fdaf1b205d7" [[projects]] branch = "master" @@ -552,7 +548,7 @@ "unix", "windows" ] - revision = "349b81fb5c64ec1734eb6ee148df25459ea48517" + revision = "9527bec2660bd847c050fda93a0f0c6dee0800bb" [[projects]] name = "golang.org/x/text" @@ -593,11 +589,49 @@ revision = "150dc57a1b433e64154302bdc40b6bb8aefa313a" version = "v1.0.0" +[[projects]] + branch = "master" + name = "google.golang.org/genproto" + packages = ["googleapis/rpc/status"] + revision = "81158efcc9f219c511e4d3c0d61a0e6e49c01a24" + +[[projects]] + name = "google.golang.org/grpc" + packages = [ + ".", + "balancer", + "balancer/base", + "balancer/roundrobin", + "channelz", + "codes", + "connectivity", + "credentials", + "encoding", + "encoding/proto", + "grpclb/grpc_lb_v1/messages", + "grpclog", + "health/grpc_health_v1", + "internal", + "keepalive", + "metadata", + "naming", + "peer", + "resolver", + "resolver/dns", + "resolver/passthrough", + "stats", + "status", + "tap", + "transport" + ] + revision = "7a6a684ca69eb4cae85ad0a484f2e531598c047b" + version = "v1.12.2" + [[projects]] name = "gopkg.in/inf.v0" packages = ["."] - revision = "3887ee99ecf07df5b447e9b00d9c0b2adaa9f3e4" - version = "v0.9.0" + revision = "d2d2541c53f18d2a059457998ce2876cc8e67cbf" + version = "v0.9.1" [[projects]] branch = "v2" @@ -614,8 +648,8 @@ [[projects]] name = "gopkg.in/yaml.v2" packages = ["."] - revision = "7f97868eec74b32b0982dd158a51a446d1da7eb5" - version = "v2.1.1" + revision = "5420a8b6744d3b0345ab293f6fcba19c978f1183" + version = "v2.2.1" [[projects]] name = "k8s.io/api" @@ -849,11 +883,14 @@ packages = [ "pkg/chartutil", "pkg/getter", + "pkg/helm", "pkg/helm/environment", "pkg/helm/helmpath", "pkg/ignore", "pkg/plugin", "pkg/proto/hapi/chart", + "pkg/proto/hapi/release", + "pkg/proto/hapi/services", "pkg/proto/hapi/version", "pkg/provenance", "pkg/repo", @@ -862,18 +899,18 @@ "pkg/urlutil", "pkg/version" ] - revision = "6af75a8fd72e2aa18a2b278cfe5c7a1c5feca7f2" - version = "v2.8.1" + revision = "20adb27c7c5868466912eebdf6664e7390ebe710" + version = "v2.9.1" [[projects]] branch = "master" name = "k8s.io/kube-openapi" packages = ["pkg/common"] - revision = "50ae88d24ede7b8bad68e23c805b5d3da5c8abaf" + revision = "8a9b82f00b3a86eac24681da3f9fe6c34c01cea2" [solve-meta] analyzer-name = "dep" analyzer-version = 1 - inputs-digest = "2ae98d1f21d5c51dc9f9e56416019c2c82d341da040f812784efdfb771fd039b" + inputs-digest = "51a3d63f3a76923268f58bb675a34afa4104db0bf48aaa746223f22940718c20" solver-name = "gps-cdcl" solver-version = 1 diff --git a/Gopkg.toml b/Gopkg.toml index 3e129012883..dd8ad5bdc0c 100644 --- a/Gopkg.toml +++ b/Gopkg.toml @@ -5,10 +5,6 @@ name = "github.com/ghodss/yaml" version = "1.0.0" -[[constraint]] - name = "github.com/go-ini/ini" - version = "1.32.0" - [[constraint]] branch = "master" name = "github.com/gosuri/uitable" @@ -25,6 +21,10 @@ name = "github.com/ksonnet/kubecfg" revision = "8634737e0b22b01bb93ffeb09a195d0a6d71a6e5" +[[constraint]] + name = "google.golang.org/grpc" + version = "1.7.2" + [[constraint]] name = "k8s.io/client-go" version = "5.0.1" @@ -39,6 +39,10 @@ name = "k8s.io/api" revision = "6c6dac0277229b9e9578c5ca3f74a4345d35cdc2" +[[constraint]] + name = "k8s.io/helm" + version = "2.9.1" + [[override]] name = "github.com/Azure/go-autorest" revision = "58f6f26e200fa5dfb40c9cd1c83f3e2c860d779d" diff --git a/vendor/cloud.google.com/go/CONTRIBUTORS b/vendor/cloud.google.com/go/CONTRIBUTORS index eb55275bf0d..3b3cbed98e9 100644 --- a/vendor/cloud.google.com/go/CONTRIBUTORS +++ b/vendor/cloud.google.com/go/CONTRIBUTORS @@ -22,6 +22,7 @@ David Symonds Filippo Valsorda Glenn Lewis Ingo Oeser +James Hall Johan Euphrosine Jonathan Amsterdam Kunpei Sakai diff --git a/vendor/github.com/Masterminds/semver/.travis.yml b/vendor/github.com/Masterminds/semver/.travis.yml index 09ccf0e44b9..3d9ebadb933 100644 --- a/vendor/github.com/Masterminds/semver/.travis.yml +++ b/vendor/github.com/Masterminds/semver/.travis.yml @@ -1,9 +1,11 @@ language: go go: - - 1.6 - - 1.7 - - 1.8 + - 1.6.x + - 1.7.x + - 1.8.x + - 1.9.x + - 1.10.x - tip # Setting sudo access to false will let Travis CI use containers rather than @@ -13,8 +15,8 @@ go: sudo: false script: - - GO15VENDOREXPERIMENT=1 make setup - - GO15VENDOREXPERIMENT=1 make test + - make setup + - make test notifications: webhooks: diff --git a/vendor/github.com/Masterminds/semver/CHANGELOG.md b/vendor/github.com/Masterminds/semver/CHANGELOG.md index ba84c546759..b888e20abaa 100644 --- a/vendor/github.com/Masterminds/semver/CHANGELOG.md +++ b/vendor/github.com/Masterminds/semver/CHANGELOG.md @@ -1,3 +1,17 @@ +# 1.4.2 (2018-04-10) + +## Changed +- #72: Updated the docs to point to vert for a console appliaction +- #71: Update the docs on pre-release comparator handling + +## Fixed +- #70: Fix the handling of pre-releases and the 0.0.0 release edge case + +# 1.4.1 (2018-04-02) + +## Fixed +- Fixed #64: Fix pre-release precedence issue (thanks @uudashr) + # 1.4.0 (2017-10-04) ## Changed diff --git a/vendor/github.com/Masterminds/semver/version.go b/vendor/github.com/Masterminds/semver/version.go index b29c593f239..9d22ea6308d 100644 --- a/vendor/github.com/Masterminds/semver/version.go +++ b/vendor/github.com/Masterminds/semver/version.go @@ -379,16 +379,15 @@ func comparePrePart(s, o string) int { // When s or o are empty we can use the other in an attempt to determine // the response. - if o == "" { - _, n := strconv.ParseInt(s, 10, 64) - if n != nil { + if s == "" { + if o != "" { return -1 } return 1 } - if s == "" { - _, n := strconv.ParseInt(o, 10, 64) - if n != nil { + + if o == "" { + if s != "" { return 1 } return -1 diff --git a/vendor/github.com/beorn7/perks/quantile/stream.go b/vendor/github.com/beorn7/perks/quantile/stream.go index f4cabd66956..d7d14f8eb63 100644 --- a/vendor/github.com/beorn7/perks/quantile/stream.go +++ b/vendor/github.com/beorn7/perks/quantile/stream.go @@ -77,15 +77,20 @@ func NewHighBiased(epsilon float64) *Stream { // is guaranteed to be within (Quantile±Epsilon). // // See http://www.cs.rutgers.edu/~muthu/bquant.pdf for time, space, and error properties. -func NewTargeted(targets map[float64]float64) *Stream { +func NewTargeted(targetMap map[float64]float64) *Stream { + // Convert map to slice to avoid slow iterations on a map. + // ƒ is called on the hot path, so converting the map to a slice + // beforehand results in significant CPU savings. + targets := targetMapToSlice(targetMap) + ƒ := func(s *stream, r float64) float64 { var m = math.MaxFloat64 var f float64 - for quantile, epsilon := range targets { - if quantile*s.n <= r { - f = (2 * epsilon * r) / quantile + for _, t := range targets { + if t.quantile*s.n <= r { + f = (2 * t.epsilon * r) / t.quantile } else { - f = (2 * epsilon * (s.n - r)) / (1 - quantile) + f = (2 * t.epsilon * (s.n - r)) / (1 - t.quantile) } if f < m { m = f @@ -96,6 +101,25 @@ func NewTargeted(targets map[float64]float64) *Stream { return newStream(ƒ) } +type target struct { + quantile float64 + epsilon float64 +} + +func targetMapToSlice(targetMap map[float64]float64) []target { + targets := make([]target, 0, len(targetMap)) + + for quantile, epsilon := range targetMap { + t := target{ + quantile: quantile, + epsilon: epsilon, + } + targets = append(targets, t) + } + + return targets +} + // Stream computes quantiles for a stream of float64s. It is not thread-safe by // design. Take care when using across multiple goroutines. type Stream struct { diff --git a/vendor/github.com/dgrijalva/jwt-go/README.md b/vendor/github.com/dgrijalva/jwt-go/README.md index 25aec486c63..d358d881b8d 100644 --- a/vendor/github.com/dgrijalva/jwt-go/README.md +++ b/vendor/github.com/dgrijalva/jwt-go/README.md @@ -1,11 +1,15 @@ -A [go](http://www.golang.org) (or 'golang' for search engine friendliness) implementation of [JSON Web Tokens](http://self-issued.info/docs/draft-ietf-oauth-json-web-token.html) +# jwt-go [![Build Status](https://travis-ci.org/dgrijalva/jwt-go.svg?branch=master)](https://travis-ci.org/dgrijalva/jwt-go) +[![GoDoc](https://godoc.org/github.com/dgrijalva/jwt-go?status.svg)](https://godoc.org/github.com/dgrijalva/jwt-go) + +A [go](http://www.golang.org) (or 'golang' for search engine friendliness) implementation of [JSON Web Tokens](http://self-issued.info/docs/draft-ietf-oauth-json-web-token.html) -**BREAKING CHANGES:*** Version 3.0.0 is here. It includes _a lot_ of changes including a few that break the API. We've tried to break as few things as possible, so there should just be a few type signature changes. A full list of breaking changes is available in `VERSION_HISTORY.md`. See `MIGRATION_GUIDE.md` for more information on updating your code. +**NEW VERSION COMING:** There have been a lot of improvements suggested since the version 3.0.0 released in 2016. I'm working now on cutting two different releases: 3.2.0 will contain any non-breaking changes or enhancements. 4.0.0 will follow shortly which will include breaking changes. See the 4.0.0 milestone to get an idea of what's coming. If you have other ideas, or would like to participate in 4.0.0, now's the time. If you depend on this library and don't want to be interrupted, I recommend you use your dependency mangement tool to pin to version 3. -**NOTICE:** It's important that you [validate the `alg` presented is what you expect](https://auth0.com/blog/2015/03/31/critical-vulnerabilities-in-json-web-token-libraries/). This library attempts to make it easy to do the right thing by requiring key types match the expected alg, but you should take the extra step to verify it in your usage. See the examples provided. +**SECURITY NOTICE:** Some older versions of Go have a security issue in the cryotp/elliptic. Recommendation is to upgrade to at least 1.8.3. See issue #216 for more detail. +**SECURITY NOTICE:** It's important that you [validate the `alg` presented is what you expect](https://auth0.com/blog/2015/03/31/critical-vulnerabilities-in-json-web-token-libraries/). This library attempts to make it easy to do the right thing by requiring key types match the expected alg, but you should take the extra step to verify it in your usage. See the examples provided. ## What the heck is a JWT? @@ -37,7 +41,7 @@ Here's an example of an extension that integrates with the Google App Engine sig ## Compliance -This library was last reviewed to comply with [RTF 7519](http://www.rfc-editor.org/info/rfc7519) dated May 2015 with a few notable differences: +This library was last reviewed to comply with [RTF 7519](http://www.rfc-editor.org/info/rfc7519) dated May 2015 with a few notable differences: * In order to protect against accidental use of [Unsecured JWTs](http://self-issued.info/docs/draft-ietf-oauth-json-web-token.html#UnsecuredJWT), tokens using `alg=none` will only be accepted if the constant `jwt.UnsafeAllowNoneSignatureType` is provided as the key. @@ -47,7 +51,10 @@ This library is considered production ready. Feedback and feature requests are This project uses [Semantic Versioning 2.0.0](http://semver.org). Accepted pull requests will land on `master`. Periodically, versions will be tagged from `master`. You can find all the releases on [the project releases page](https://github.com/dgrijalva/jwt-go/releases). -While we try to make it obvious when we make breaking changes, there isn't a great mechanism for pushing announcements out to users. You may want to use this alternative package include: `gopkg.in/dgrijalva/jwt-go.v2`. It will do the right thing WRT semantic versioning. +While we try to make it obvious when we make breaking changes, there isn't a great mechanism for pushing announcements out to users. You may want to use this alternative package include: `gopkg.in/dgrijalva/jwt-go.v3`. It will do the right thing WRT semantic versioning. + +**BREAKING CHANGES:*** +* Version 3.0.0 includes _a lot_ of changes from the 2.x line, including a few that break the API. We've tried to break as few things as possible, so there should just be a few type signature changes. A full list of breaking changes is available in `VERSION_HISTORY.md`. See `MIGRATION_GUIDE.md` for more information on updating your code. ## Usage Tips @@ -68,6 +75,14 @@ Symmetric signing methods, such as HSA, use only a single secret. This is probab Asymmetric signing methods, such as RSA, use different keys for signing and verifying tokens. This makes it possible to produce tokens with a private key, and allow any consumer to access the public key for verification. +### Signing Methods and Key Types + +Each signing method expects a different object type for its signing keys. See the package documentation for details. Here are the most common ones: + +* The [HMAC signing method](https://godoc.org/github.com/dgrijalva/jwt-go#SigningMethodHMAC) (`HS256`,`HS384`,`HS512`) expect `[]byte` values for signing and validation +* The [RSA signing method](https://godoc.org/github.com/dgrijalva/jwt-go#SigningMethodRSA) (`RS256`,`RS384`,`RS512`) expect `*rsa.PrivateKey` for signing and `*rsa.PublicKey` for validation +* The [ECDSA signing method](https://godoc.org/github.com/dgrijalva/jwt-go#SigningMethodECDSA) (`ES256`,`ES384`,`ES512`) expect `*ecdsa.PrivateKey` for signing and `*ecdsa.PublicKey` for validation + ### JWT and OAuth It's worth mentioning that OAuth and JWT are not the same thing. A JWT token is simply a signed JSON object. It can be used anywhere such a thing is useful. There is some confusion, though, as JWT is the most common type of bearer token used in OAuth2 authentication. @@ -77,7 +92,7 @@ Without going too far down the rabbit hole, here's a description of the interact * OAuth is a protocol for allowing an identity provider to be separate from the service a user is logging in to. For example, whenever you use Facebook to log into a different service (Yelp, Spotify, etc), you are using OAuth. * OAuth defines several options for passing around authentication data. One popular method is called a "bearer token". A bearer token is simply a string that _should_ only be held by an authenticated user. Thus, simply presenting this token proves your identity. You can probably derive from here why a JWT might make a good bearer token. * Because bearer tokens are used for authentication, it's important they're kept secret. This is why transactions that use bearer tokens typically happen over SSL. - + ## More Documentation can be found [on godoc.org](http://godoc.org/github.com/dgrijalva/jwt-go). diff --git a/vendor/github.com/dgrijalva/jwt-go/VERSION_HISTORY.md b/vendor/github.com/dgrijalva/jwt-go/VERSION_HISTORY.md index c21551f6bbd..6370298313a 100644 --- a/vendor/github.com/dgrijalva/jwt-go/VERSION_HISTORY.md +++ b/vendor/github.com/dgrijalva/jwt-go/VERSION_HISTORY.md @@ -1,5 +1,12 @@ ## `jwt-go` Version History +#### 3.2.0 + +* Added method `ParseUnverified` to allow users to split up the tasks of parsing and validation +* HMAC signing method returns `ErrInvalidKeyType` instead of `ErrInvalidKey` where appropriate +* Added options to `request.ParseFromRequest`, which allows for an arbitrary list of modifiers to parsing behavior. Initial set include `WithClaims` and `WithParser`. Existing usage of this function will continue to work as before. +* Deprecated `ParseFromRequestWithClaims` to simplify API in the future. + #### 3.1.0 * Improvements to `jwt` command line tool diff --git a/vendor/github.com/dgrijalva/jwt-go/ecdsa.go b/vendor/github.com/dgrijalva/jwt-go/ecdsa.go index 2f59a222363..f977381240e 100644 --- a/vendor/github.com/dgrijalva/jwt-go/ecdsa.go +++ b/vendor/github.com/dgrijalva/jwt-go/ecdsa.go @@ -14,6 +14,7 @@ var ( ) // Implements the ECDSA family of signing methods signing methods +// Expects *ecdsa.PrivateKey for signing and *ecdsa.PublicKey for verification type SigningMethodECDSA struct { Name string Hash crypto.Hash diff --git a/vendor/github.com/dgrijalva/jwt-go/hmac.go b/vendor/github.com/dgrijalva/jwt-go/hmac.go index c2299192545..addbe5d4018 100644 --- a/vendor/github.com/dgrijalva/jwt-go/hmac.go +++ b/vendor/github.com/dgrijalva/jwt-go/hmac.go @@ -7,6 +7,7 @@ import ( ) // Implements the HMAC-SHA family of signing methods signing methods +// Expects key type of []byte for both signing and validation type SigningMethodHMAC struct { Name string Hash crypto.Hash @@ -90,5 +91,5 @@ func (m *SigningMethodHMAC) Sign(signingString string, key interface{}) (string, return EncodeSegment(hasher.Sum(nil)), nil } - return "", ErrInvalidKey + return "", ErrInvalidKeyType } diff --git a/vendor/github.com/dgrijalva/jwt-go/parser.go b/vendor/github.com/dgrijalva/jwt-go/parser.go index 7bf1c4ea084..d6901d9adb5 100644 --- a/vendor/github.com/dgrijalva/jwt-go/parser.go +++ b/vendor/github.com/dgrijalva/jwt-go/parser.go @@ -21,55 +21,9 @@ func (p *Parser) Parse(tokenString string, keyFunc Keyfunc) (*Token, error) { } func (p *Parser) ParseWithClaims(tokenString string, claims Claims, keyFunc Keyfunc) (*Token, error) { - parts := strings.Split(tokenString, ".") - if len(parts) != 3 { - return nil, NewValidationError("token contains an invalid number of segments", ValidationErrorMalformed) - } - - var err error - token := &Token{Raw: tokenString} - - // parse Header - var headerBytes []byte - if headerBytes, err = DecodeSegment(parts[0]); err != nil { - if strings.HasPrefix(strings.ToLower(tokenString), "bearer ") { - return token, NewValidationError("tokenstring should not contain 'bearer '", ValidationErrorMalformed) - } - return token, &ValidationError{Inner: err, Errors: ValidationErrorMalformed} - } - if err = json.Unmarshal(headerBytes, &token.Header); err != nil { - return token, &ValidationError{Inner: err, Errors: ValidationErrorMalformed} - } - - // parse Claims - var claimBytes []byte - token.Claims = claims - - if claimBytes, err = DecodeSegment(parts[1]); err != nil { - return token, &ValidationError{Inner: err, Errors: ValidationErrorMalformed} - } - dec := json.NewDecoder(bytes.NewBuffer(claimBytes)) - if p.UseJSONNumber { - dec.UseNumber() - } - // JSON Decode. Special case for map type to avoid weird pointer behavior - if c, ok := token.Claims.(MapClaims); ok { - err = dec.Decode(&c) - } else { - err = dec.Decode(&claims) - } - // Handle decode error + token, parts, err := p.ParseUnverified(tokenString, claims) if err != nil { - return token, &ValidationError{Inner: err, Errors: ValidationErrorMalformed} - } - - // Lookup signature method - if method, ok := token.Header["alg"].(string); ok { - if token.Method = GetSigningMethod(method); token.Method == nil { - return token, NewValidationError("signing method (alg) is unavailable.", ValidationErrorUnverifiable) - } - } else { - return token, NewValidationError("signing method (alg) is unspecified.", ValidationErrorUnverifiable) + return token, err } // Verify signing method is in the required set @@ -96,6 +50,9 @@ func (p *Parser) ParseWithClaims(tokenString string, claims Claims, keyFunc Keyf } if key, err = keyFunc(token); err != nil { // keyFunc returned an error + if ve, ok := err.(*ValidationError); ok { + return token, ve + } return token, &ValidationError{Inner: err, Errors: ValidationErrorUnverifiable} } @@ -129,3 +86,63 @@ func (p *Parser) ParseWithClaims(tokenString string, claims Claims, keyFunc Keyf return token, vErr } + +// WARNING: Don't use this method unless you know what you're doing +// +// This method parses the token but doesn't validate the signature. It's only +// ever useful in cases where you know the signature is valid (because it has +// been checked previously in the stack) and you want to extract values from +// it. +func (p *Parser) ParseUnverified(tokenString string, claims Claims) (token *Token, parts []string, err error) { + parts = strings.Split(tokenString, ".") + if len(parts) != 3 { + return nil, parts, NewValidationError("token contains an invalid number of segments", ValidationErrorMalformed) + } + + token = &Token{Raw: tokenString} + + // parse Header + var headerBytes []byte + if headerBytes, err = DecodeSegment(parts[0]); err != nil { + if strings.HasPrefix(strings.ToLower(tokenString), "bearer ") { + return token, parts, NewValidationError("tokenstring should not contain 'bearer '", ValidationErrorMalformed) + } + return token, parts, &ValidationError{Inner: err, Errors: ValidationErrorMalformed} + } + if err = json.Unmarshal(headerBytes, &token.Header); err != nil { + return token, parts, &ValidationError{Inner: err, Errors: ValidationErrorMalformed} + } + + // parse Claims + var claimBytes []byte + token.Claims = claims + + if claimBytes, err = DecodeSegment(parts[1]); err != nil { + return token, parts, &ValidationError{Inner: err, Errors: ValidationErrorMalformed} + } + dec := json.NewDecoder(bytes.NewBuffer(claimBytes)) + if p.UseJSONNumber { + dec.UseNumber() + } + // JSON Decode. Special case for map type to avoid weird pointer behavior + if c, ok := token.Claims.(MapClaims); ok { + err = dec.Decode(&c) + } else { + err = dec.Decode(&claims) + } + // Handle decode error + if err != nil { + return token, parts, &ValidationError{Inner: err, Errors: ValidationErrorMalformed} + } + + // Lookup signature method + if method, ok := token.Header["alg"].(string); ok { + if token.Method = GetSigningMethod(method); token.Method == nil { + return token, parts, NewValidationError("signing method (alg) is unavailable.", ValidationErrorUnverifiable) + } + } else { + return token, parts, NewValidationError("signing method (alg) is unspecified.", ValidationErrorUnverifiable) + } + + return token, parts, nil +} diff --git a/vendor/github.com/dgrijalva/jwt-go/rsa.go b/vendor/github.com/dgrijalva/jwt-go/rsa.go index 0ae0b1984e5..e4caf1ca4a1 100644 --- a/vendor/github.com/dgrijalva/jwt-go/rsa.go +++ b/vendor/github.com/dgrijalva/jwt-go/rsa.go @@ -7,6 +7,7 @@ import ( ) // Implements the RSA family of signing methods signing methods +// Expects *rsa.PrivateKey for signing and *rsa.PublicKey for validation type SigningMethodRSA struct { Name string Hash crypto.Hash @@ -44,7 +45,7 @@ func (m *SigningMethodRSA) Alg() string { } // Implements the Verify method from SigningMethod -// For this signing method, must be an rsa.PublicKey structure. +// For this signing method, must be an *rsa.PublicKey structure. func (m *SigningMethodRSA) Verify(signingString, signature string, key interface{}) error { var err error @@ -73,7 +74,7 @@ func (m *SigningMethodRSA) Verify(signingString, signature string, key interface } // Implements the Sign method from SigningMethod -// For this signing method, must be an rsa.PrivateKey structure. +// For this signing method, must be an *rsa.PrivateKey structure. func (m *SigningMethodRSA) Sign(signingString string, key interface{}) (string, error) { var rsaKey *rsa.PrivateKey var ok bool diff --git a/vendor/github.com/dgrijalva/jwt-go/rsa_utils.go b/vendor/github.com/dgrijalva/jwt-go/rsa_utils.go index 213a90dbbf8..a5ababf956c 100644 --- a/vendor/github.com/dgrijalva/jwt-go/rsa_utils.go +++ b/vendor/github.com/dgrijalva/jwt-go/rsa_utils.go @@ -39,6 +39,38 @@ func ParseRSAPrivateKeyFromPEM(key []byte) (*rsa.PrivateKey, error) { return pkey, nil } +// Parse PEM encoded PKCS1 or PKCS8 private key protected with password +func ParseRSAPrivateKeyFromPEMWithPassword(key []byte, password string) (*rsa.PrivateKey, error) { + var err error + + // Parse PEM block + var block *pem.Block + if block, _ = pem.Decode(key); block == nil { + return nil, ErrKeyMustBePEMEncoded + } + + var parsedKey interface{} + + var blockDecrypted []byte + if blockDecrypted, err = x509.DecryptPEMBlock(block, []byte(password)); err != nil { + return nil, err + } + + if parsedKey, err = x509.ParsePKCS1PrivateKey(blockDecrypted); err != nil { + if parsedKey, err = x509.ParsePKCS8PrivateKey(blockDecrypted); err != nil { + return nil, err + } + } + + var pkey *rsa.PrivateKey + var ok bool + if pkey, ok = parsedKey.(*rsa.PrivateKey); !ok { + return nil, ErrNotRSAPrivateKey + } + + return pkey, nil +} + // Parse PEM encoded PKCS1 or PKCS8 public key func ParseRSAPublicKeyFromPEM(key []byte) (*rsa.PublicKey, error) { var err error diff --git a/vendor/github.com/disintegration/imaging/.travis.yml b/vendor/github.com/disintegration/imaging/.travis.yml index 24dd1e4640b..89370edcbad 100644 --- a/vendor/github.com/disintegration/imaging/.travis.yml +++ b/vendor/github.com/disintegration/imaging/.travis.yml @@ -1,12 +1,9 @@ language: go - -sudo: false - go: - - "1.7" - - "1.8" - - "1.9" - - "1.10" + - "1.7.x" + - "1.8.x" + - "1.9.x" + - "1.10.x" before_install: - go get github.com/mattn/goveralls diff --git a/vendor/github.com/disintegration/imaging/README.md b/vendor/github.com/disintegration/imaging/README.md index 34c31c00253..c7ee30fc85d 100644 --- a/vendor/github.com/disintegration/imaging/README.md +++ b/vendor/github.com/disintegration/imaging/README.md @@ -2,9 +2,10 @@ [![GoDoc](https://godoc.org/github.com/disintegration/imaging?status.svg)](https://godoc.org/github.com/disintegration/imaging) [![Build Status](https://travis-ci.org/disintegration/imaging.svg?branch=master)](https://travis-ci.org/disintegration/imaging) -[![Coverage Status](https://coveralls.io/repos/github/disintegration/imaging/badge.svg?branch=master)](https://coveralls.io/github/disintegration/imaging?branch=master) +[![Coverage Status](https://coveralls.io/repos/github/disintegration/imaging/badge.svg?branch=master&service=github)](https://coveralls.io/github/disintegration/imaging?branch=master) +[![Go Report Card](https://goreportcard.com/badge/github.com/disintegration/imaging)](https://goreportcard.com/report/github.com/disintegration/imaging) -Package imaging provides basic imaging processing functions (resize, rotate, crop, brightness/contrast adjustments, etc.). +Package imaging provides basic image processing functions (resize, rotate, crop, brightness/contrast adjustments, etc.). All the image processing functions provided by the package accept any image type that implements `image.Image` interface as an input, and return a new image of `*image.NRGBA` type (32bit RGBA colors, not premultiplied by alpha). diff --git a/vendor/github.com/disintegration/imaging/adjust.go b/vendor/github.com/disintegration/imaging/adjust.go index 8ebc931f7f3..fb3a9ce3c29 100644 --- a/vendor/github.com/disintegration/imaging/adjust.go +++ b/vendor/github.com/disintegration/imaging/adjust.go @@ -51,7 +51,7 @@ func Invert(img image.Image) *image.NRGBA { // AdjustContrast changes the contrast of the image using the percentage parameter and returns the adjusted image. // The percentage must be in range (-100, 100). The percentage = 0 gives the original image. -// The percentage = -100 gives solid grey image. +// The percentage = -100 gives solid gray image. // // Examples: // diff --git a/vendor/github.com/disintegration/imaging/doc.go b/vendor/github.com/disintegration/imaging/doc.go index dad4b9c8954..5d59b46e249 100644 --- a/vendor/github.com/disintegration/imaging/doc.go +++ b/vendor/github.com/disintegration/imaging/doc.go @@ -1,5 +1,5 @@ /* -Package imaging provides basic imaging processing functions (resize, rotate, crop, brightness/contrast adjustments, etc.). +Package imaging provides basic image processing functions (resize, rotate, crop, brightness/contrast adjustments, etc.). All the image processing functions provided by the package accept any image type that implements image.Image interface as an input, and return a new image of *image.NRGBA type (32bit RGBA colors, not premultiplied by alpha). diff --git a/vendor/github.com/disintegration/imaging/helpers.go b/vendor/github.com/disintegration/imaging/helpers.go index b54db5f4cde..dcb4d7ebbd2 100644 --- a/vendor/github.com/disintegration/imaging/helpers.go +++ b/vendor/github.com/disintegration/imaging/helpers.go @@ -1,6 +1,7 @@ package imaging import ( + "bytes" "errors" "image" "image/color" @@ -46,6 +47,26 @@ func (f Format) String() string { } } +var formatFromExt = map[string]Format{ + ".jpg": JPEG, + ".jpeg": JPEG, + ".png": PNG, + ".tif": TIFF, + ".tiff": TIFF, + ".bmp": BMP, + ".gif": GIF, +} + +// FormatFromFilename parses image format from filename extension: +// "jpg" (or "jpeg"), "png", "gif", "tif" (or "tiff") and "bmp" are supported. +func FormatFromFilename(filename string) (Format, error) { + ext := strings.ToLower(filepath.Ext(filename)) + if f, ok := formatFromExt[ext]; ok { + return f, nil + } + return -1, ErrUnsupportedFormat +} + var ( // ErrUnsupportedFormat means the given image format (or file extension) is unsupported. ErrUnsupportedFormat = errors.New("imaging: unsupported image format") @@ -80,17 +101,19 @@ func Open(filename string) (image.Image, error) { } type encodeConfig struct { - jpegQuality int - gifNumColors int - gifQuantizer draw.Quantizer - gifDrawer draw.Drawer + jpegQuality int + gifNumColors int + gifQuantizer draw.Quantizer + gifDrawer draw.Drawer + pngCompressionLevel png.CompressionLevel } var defaultEncodeConfig = encodeConfig{ - jpegQuality: 95, - gifNumColors: 256, - gifQuantizer: nil, - gifDrawer: nil, + jpegQuality: 95, + gifNumColors: 256, + gifQuantizer: nil, + gifDrawer: nil, + pngCompressionLevel: png.DefaultCompression, } // EncodeOption sets an optional parameter for the Encode and Save functions. @@ -128,6 +151,14 @@ func GIFDrawer(drawer draw.Drawer) EncodeOption { } } +// PNGCompressionLevel returns an EncodeOption that sets the compression level +// of the PNG-encoded image. Default is png.DefaultCompression. +func PNGCompressionLevel(level png.CompressionLevel) EncodeOption { + return func(c *encodeConfig) { + c.pngCompressionLevel = level + } +} + // Encode writes the image img to w in the specified format (JPEG, PNG, GIF, TIFF or BMP). func Encode(w io.Writer, img image.Image, format Format, opts ...EncodeOption) error { cfg := defaultEncodeConfig @@ -155,17 +186,22 @@ func Encode(w io.Writer, img image.Image, format Format, opts ...EncodeOption) e } case PNG: - err = png.Encode(w, img) + enc := png.Encoder{CompressionLevel: cfg.pngCompressionLevel} + err = enc.Encode(w, img) + case GIF: err = gif.Encode(w, img, &gif.Options{ NumColors: cfg.gifNumColors, Quantizer: cfg.gifQuantizer, Drawer: cfg.gifDrawer, }) + case TIFF: err = tiff.Encode(w, img, &tiff.Options{Compression: tiff.Deflate, Predictor: true}) + case BMP: err = bmp.Encode(w, img) + default: err = ErrUnsupportedFormat } @@ -184,22 +220,10 @@ func Encode(w io.Writer, img image.Image, format Format, opts ...EncodeOption) e // err := imaging.Save(img, "out.jpg", imaging.JPEGQuality(80)) // func Save(img image.Image, filename string, opts ...EncodeOption) (err error) { - formats := map[string]Format{ - ".jpg": JPEG, - ".jpeg": JPEG, - ".png": PNG, - ".tif": TIFF, - ".tiff": TIFF, - ".bmp": BMP, - ".gif": GIF, - } - - ext := strings.ToLower(filepath.Ext(filename)) - f, ok := formats[ext] - if !ok { - return ErrUnsupportedFormat + f, err := FormatFromFilename(filename) + if err != nil { + return err } - file, err := fs.Create(filename) if err != nil { return err @@ -221,33 +245,16 @@ func New(width, height int, fillColor color.Color) *image.NRGBA { return &image.NRGBA{} } - dst := image.NewNRGBA(image.Rect(0, 0, width, height)) c := color.NRGBAModel.Convert(fillColor).(color.NRGBA) - - if c.R == 0 && c.G == 0 && c.B == 0 && c.A == 0 { - return dst + if (c == color.NRGBA{0, 0, 0, 0}) { + return image.NewNRGBA(image.Rect(0, 0, width, height)) } - // Fill the first row. - i := 0 - for x := 0; x < width; x++ { - dst.Pix[i+0] = c.R - dst.Pix[i+1] = c.G - dst.Pix[i+2] = c.B - dst.Pix[i+3] = c.A - i += 4 + return &image.NRGBA{ + Pix: bytes.Repeat([]byte{c.R, c.G, c.B, c.A}, width*height), + Stride: 4 * width, + Rect: image.Rect(0, 0, width, height), } - - // Copy the first row to other rows. - size := width * 4 - parallel(1, height, func(ys <-chan int) { - for y := range ys { - i = y * dst.Stride - copy(dst.Pix[i:i+size], dst.Pix[0:size]) - } - }) - - return dst } // Clone returns a copy of the given image. diff --git a/vendor/github.com/disintegration/imaging/resize.go b/vendor/github.com/disintegration/imaging/resize.go index 2ed65a2139b..97f498a0a5b 100644 --- a/vendor/github.com/disintegration/imaging/resize.go +++ b/vendor/github.com/disintegration/imaging/resize.go @@ -178,18 +178,15 @@ func resizeNearest(img image.Image, width, height int) *image.NRGBA { dx := float64(img.Bounds().Dx()) / float64(width) dy := float64(img.Bounds().Dy()) / float64(height) - if height < img.Bounds().Dy() { + if dx > 1 && dy > 1 { src := newScanner(img) parallel(0, height, func(ys <-chan int) { - scanLine := make([]uint8, src.w*4) for y := range ys { srcY := int((float64(y) + 0.5) * dy) - src.scan(0, srcY, src.w, srcY+1, scanLine) dstOff := y * dst.Stride for x := 0; x < width; x++ { srcX := int((float64(x) + 0.5) * dx) - srcOff := srcX * 4 - copy(dst.Pix[dstOff:dstOff+4], scanLine[srcOff:srcOff+4]) + src.scan(srcX, srcY, srcX+1, srcY+1, dst.Pix[dstOff:dstOff+4]) dstOff += 4 } } diff --git a/vendor/github.com/emicklei/go-restful/CHANGES.md b/vendor/github.com/emicklei/go-restful/CHANGES.md index d23b5755538..7294637cd93 100644 --- a/vendor/github.com/emicklei/go-restful/CHANGES.md +++ b/vendor/github.com/emicklei/go-restful/CHANGES.md @@ -1,5 +1,8 @@ Change history of go-restful = +v2.6.1 +- add JSONNewDecoderFunc to allow custom JSON Decoder usage (go 1.10+) + v2.6.0 - Make JSR 311 routing and path param processing consistent - Adding description to RouteBuilder.Reads() diff --git a/vendor/github.com/emicklei/go-restful/README.md b/vendor/github.com/emicklei/go-restful/README.md index 002a08d9656..65c3d4f9d04 100644 --- a/vendor/github.com/emicklei/go-restful/README.md +++ b/vendor/github.com/emicklei/go-restful/README.md @@ -61,8 +61,20 @@ func (u UserResource) findUser(request *restful.Request, response *restful.Respo - Route errors produce HTTP 404/405/406/415 errors, customizable using ServiceErrorHandler(...) - Configurable (trace) logging - Customizable gzip/deflate readers and writers using CompressorProvider registration - -### Resources + +## How to customize +There are several hooks to customize the behavior of the go-restful package. + +- Router algorithm +- Panic recovery +- JSON decoder +- Trace logging +- Compression +- Encoders for other serializers + +TODO: write examples of these. + +## Resources - [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/) @@ -72,4 +84,4 @@ func (u UserResource) findUser(request *restful.Request, response *restful.Respo Type ```git shortlog -s``` for a full list of contributors. -© 2012 - 2017, http://ernestmicklei.com. MIT License. Contributions are welcome. +© 2012 - 2018, http://ernestmicklei.com. MIT License. Contributions are welcome. diff --git a/vendor/github.com/emicklei/go-restful/entity_accessors.go b/vendor/github.com/emicklei/go-restful/entity_accessors.go index 6ecf6c7f897..42957055ff8 100644 --- a/vendor/github.com/emicklei/go-restful/entity_accessors.go +++ b/vendor/github.com/emicklei/go-restful/entity_accessors.go @@ -7,6 +7,7 @@ package restful import ( "encoding/json" "encoding/xml" + "io" "strings" "sync" ) @@ -126,11 +127,16 @@ type entityJSONAccess struct { ContentType string } +// JSONNewDecoderFunc can be used to inject a different configration for the json Decoder instance. +var JSONNewDecoderFunc = func(r io.Reader) *json.Decoder { + decoder := json.NewDecoder(r) + decoder.UseNumber() + return decoder +} + // 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) + return JSONNewDecoderFunc(req.Request.Body).Decode(v) } // Write marshalls the value to JSON and set the Content-Type Header. diff --git a/vendor/github.com/emicklei/go-restful/go.mod b/vendor/github.com/emicklei/go-restful/go.mod new file mode 100644 index 00000000000..5fa37e774dd --- /dev/null +++ b/vendor/github.com/emicklei/go-restful/go.mod @@ -0,0 +1 @@ +module github.com/emicklei/go-restful/v2 diff --git a/vendor/github.com/go-ini/ini/.gitignore b/vendor/github.com/go-ini/ini/.gitignore deleted file mode 100644 index 12411127b39..00000000000 --- a/vendor/github.com/go-ini/ini/.gitignore +++ /dev/null @@ -1,6 +0,0 @@ -testdata/conf_out.ini -ini.sublime-project -ini.sublime-workspace -testdata/conf_reflect.ini -.idea -/.vscode diff --git a/vendor/github.com/go-ini/ini/.travis.yml b/vendor/github.com/go-ini/ini/.travis.yml deleted file mode 100644 index 75fe7b74b94..00000000000 --- a/vendor/github.com/go-ini/ini/.travis.yml +++ /dev/null @@ -1,16 +0,0 @@ -sudo: false -language: go -go: - - 1.5.x - - 1.6.x - - 1.7.x - - 1.8.x - - 1.9.x - - 1.10.x - -script: - - go get golang.org/x/tools/cmd/cover - - go get github.com/smartystreets/goconvey - - mkdir -p $HOME/gopath/src/gopkg.in - - ln -s $HOME/gopath/src/github.com/go-ini/ini $HOME/gopath/src/gopkg.in/ini.v1 - - go test -v -cover -race diff --git a/vendor/github.com/go-ini/ini/LICENSE b/vendor/github.com/go-ini/ini/LICENSE deleted file mode 100644 index d361bbcdf5c..00000000000 --- a/vendor/github.com/go-ini/ini/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 2014 Unknwon - - 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/github.com/go-ini/ini/Makefile b/vendor/github.com/go-ini/ini/Makefile deleted file mode 100644 index af27ff0768f..00000000000 --- a/vendor/github.com/go-ini/ini/Makefile +++ /dev/null @@ -1,15 +0,0 @@ -.PHONY: build test bench vet coverage - -build: vet bench - -test: - go test -v -cover -race - -bench: - go test -v -cover -race -test.bench=. -test.benchmem - -vet: - go vet - -coverage: - go test -coverprofile=c.out && go tool cover -html=c.out && rm c.out diff --git a/vendor/github.com/go-ini/ini/README.md b/vendor/github.com/go-ini/ini/README.md deleted file mode 100644 index 6b7b73fed11..00000000000 --- a/vendor/github.com/go-ini/ini/README.md +++ /dev/null @@ -1,790 +0,0 @@ -INI [![Build Status](https://travis-ci.org/go-ini/ini.svg?branch=master)](https://travis-ci.org/go-ini/ini) [![Sourcegraph](https://sourcegraph.com/github.com/go-ini/ini/-/badge.svg)](https://sourcegraph.com/github.com/go-ini/ini?badge) -=== - -![](https://avatars0.githubusercontent.com/u/10216035?v=3&s=200) - -Package ini provides INI file read and write functionality in Go. - -[简体中文](README_ZH.md) - -## Feature - -- Load multiple data sources(`[]byte`, file and `io.ReadCloser`) with overwrites. -- Read with recursion values. -- Read with parent-child sections. -- Read with auto-increment key names. -- Read with multiple-line values. -- Read with tons of helper methods. -- Read and convert values to Go types. -- Read and **WRITE** comments of sections and keys. -- Manipulate sections, keys and comments with ease. -- Keep sections and keys in order as you parse and save. - -## Installation - -To use a tagged revision: - - go get gopkg.in/ini.v1 - -To use with latest changes: - - go get github.com/go-ini/ini - -Please add `-u` flag to update in the future. - -### Testing - -If you want to test on your machine, please apply `-t` flag: - - go get -t gopkg.in/ini.v1 - -Please add `-u` flag to update in the future. - -## Getting Started - -### Loading from data sources - -A **Data Source** is either raw data in type `[]byte`, a file name with type `string` or `io.ReadCloser`. You can load **as many data sources as you want**. Passing other types will simply return an error. - -```go -cfg, err := ini.Load([]byte("raw data"), "filename", ioutil.NopCloser(bytes.NewReader([]byte("some other data")))) -``` - -Or start with an empty object: - -```go -cfg := ini.Empty() -``` - -When you cannot decide how many data sources to load at the beginning, you will still be able to **Append()** them later. - -```go -err := cfg.Append("other file", []byte("other raw data")) -``` - -If you have a list of files with possibilities that some of them may not available at the time, and you don't know exactly which ones, you can use `LooseLoad` to ignore nonexistent files without returning error. - -```go -cfg, err := ini.LooseLoad("filename", "filename_404") -``` - -The cool thing is, whenever the file is available to load while you're calling `Reload` method, it will be counted as usual. - -#### Ignore cases of key name - -When you do not care about cases of section and key names, you can use `InsensitiveLoad` to force all names to be lowercased while parsing. - -```go -cfg, err := ini.InsensitiveLoad("filename") -//... - -// sec1 and sec2 are the exactly same section object -sec1, err := cfg.GetSection("Section") -sec2, err := cfg.GetSection("SecTIOn") - -// key1 and key2 are the exactly same key object -key1, err := sec1.GetKey("Key") -key2, err := sec2.GetKey("KeY") -``` - -#### MySQL-like boolean key - -MySQL's configuration allows a key without value as follows: - -```ini -[mysqld] -... -skip-host-cache -skip-name-resolve -``` - -By default, this is considered as missing value. But if you know you're going to deal with those cases, you can assign advanced load options: - -```go -cfg, err := ini.LoadSources(ini.LoadOptions{AllowBooleanKeys: true}, "my.cnf")) -``` - -The value of those keys are always `true`, and when you save to a file, it will keep in the same foramt as you read. - -To generate such keys in your program, you could use `NewBooleanKey`: - -```go -key, err := sec.NewBooleanKey("skip-host-cache") -``` - -#### Comment - -Take care that following format will be treated as comment: - -1. Line begins with `#` or `;` -2. Words after `#` or `;` -3. Words after section name (i.e words after `[some section name]`) - -If you want to save a value with `#` or `;`, please quote them with ``` ` ``` or ``` """ ```. - -Alternatively, you can use following `LoadOptions` to completely ignore inline comments: - -```go -cfg, err := ini.LoadSources(ini.LoadOptions{IgnoreInlineComment: true}, "app.ini")) -``` - -### Working with sections - -To get a section, you would need to: - -```go -section, err := cfg.GetSection("section name") -``` - -For a shortcut for default section, just give an empty string as name: - -```go -section, err := cfg.GetSection("") -``` - -When you're pretty sure the section exists, following code could make your life easier: - -```go -section := cfg.Section("section name") -``` - -What happens when the section somehow does not exist? Don't panic, it automatically creates and returns a new section to you. - -To create a new section: - -```go -err := cfg.NewSection("new section") -``` - -To get a list of sections or section names: - -```go -sections := cfg.Sections() -names := cfg.SectionStrings() -``` - -### Working with keys - -To get a key under a section: - -```go -key, err := cfg.Section("").GetKey("key name") -``` - -Same rule applies to key operations: - -```go -key := cfg.Section("").Key("key name") -``` - -To check if a key exists: - -```go -yes := cfg.Section("").HasKey("key name") -``` - -To create a new key: - -```go -err := cfg.Section("").NewKey("name", "value") -``` - -To get a list of keys or key names: - -```go -keys := cfg.Section("").Keys() -names := cfg.Section("").KeyStrings() -``` - -To get a clone hash of keys and corresponding values: - -```go -hash := cfg.Section("").KeysHash() -``` - -### Working with values - -To get a string value: - -```go -val := cfg.Section("").Key("key name").String() -``` - -To validate key value on the fly: - -```go -val := cfg.Section("").Key("key name").Validate(func(in string) string { - if len(in) == 0 { - return "default" - } - return in -}) -``` - -If you do not want any auto-transformation (such as recursive read) for the values, you can get raw value directly (this way you get much better performance): - -```go -val := cfg.Section("").Key("key name").Value() -``` - -To check if raw value exists: - -```go -yes := cfg.Section("").HasValue("test value") -``` - -To get value with types: - -```go -// For boolean values: -// true when value is: 1, t, T, TRUE, true, True, YES, yes, Yes, y, ON, on, On -// false when value is: 0, f, F, FALSE, false, False, NO, no, No, n, OFF, off, Off -v, err = cfg.Section("").Key("BOOL").Bool() -v, err = cfg.Section("").Key("FLOAT64").Float64() -v, err = cfg.Section("").Key("INT").Int() -v, err = cfg.Section("").Key("INT64").Int64() -v, err = cfg.Section("").Key("UINT").Uint() -v, err = cfg.Section("").Key("UINT64").Uint64() -v, err = cfg.Section("").Key("TIME").TimeFormat(time.RFC3339) -v, err = cfg.Section("").Key("TIME").Time() // RFC3339 - -v = cfg.Section("").Key("BOOL").MustBool() -v = cfg.Section("").Key("FLOAT64").MustFloat64() -v = cfg.Section("").Key("INT").MustInt() -v = cfg.Section("").Key("INT64").MustInt64() -v = cfg.Section("").Key("UINT").MustUint() -v = cfg.Section("").Key("UINT64").MustUint64() -v = cfg.Section("").Key("TIME").MustTimeFormat(time.RFC3339) -v = cfg.Section("").Key("TIME").MustTime() // RFC3339 - -// Methods start with Must also accept one argument for default value -// when key not found or fail to parse value to given type. -// Except method MustString, which you have to pass a default value. - -v = cfg.Section("").Key("String").MustString("default") -v = cfg.Section("").Key("BOOL").MustBool(true) -v = cfg.Section("").Key("FLOAT64").MustFloat64(1.25) -v = cfg.Section("").Key("INT").MustInt(10) -v = cfg.Section("").Key("INT64").MustInt64(99) -v = cfg.Section("").Key("UINT").MustUint(3) -v = cfg.Section("").Key("UINT64").MustUint64(6) -v = cfg.Section("").Key("TIME").MustTimeFormat(time.RFC3339, time.Now()) -v = cfg.Section("").Key("TIME").MustTime(time.Now()) // RFC3339 -``` - -What if my value is three-line long? - -```ini -[advance] -ADDRESS = """404 road, -NotFound, State, 5000 -Earth""" -``` - -Not a problem! - -```go -cfg.Section("advance").Key("ADDRESS").String() - -/* --- start --- -404 road, -NotFound, State, 5000 -Earth ------- end --- */ -``` - -That's cool, how about continuation lines? - -```ini -[advance] -two_lines = how about \ - continuation lines? -lots_of_lines = 1 \ - 2 \ - 3 \ - 4 -``` - -Piece of cake! - -```go -cfg.Section("advance").Key("two_lines").String() // how about continuation lines? -cfg.Section("advance").Key("lots_of_lines").String() // 1 2 3 4 -``` - -Well, I hate continuation lines, how do I disable that? - -```go -cfg, err := ini.LoadSources(ini.LoadOptions{ - IgnoreContinuation: true, -}, "filename") -``` - -Holy crap! - -Note that single quotes around values will be stripped: - -```ini -foo = "some value" // foo: some value -bar = 'some value' // bar: some value -``` - -Sometimes you downloaded file from [Crowdin](https://crowdin.com/) has values like the following (value is surrounded by double quotes and quotes in the value are escaped): - -```ini -create_repo="created repository %s" -``` - -How do you transform this to regular format automatically? - -```go -cfg, err := ini.LoadSources(ini.LoadOptions{UnescapeValueDoubleQuotes: true}, "en-US.ini")) -cfg.Section("").Key("create_repo").String() -// You got: created repository %s -``` - -That's all? Hmm, no. - -#### Helper methods of working with values - -To get value with given candidates: - -```go -v = cfg.Section("").Key("STRING").In("default", []string{"str", "arr", "types"}) -v = cfg.Section("").Key("FLOAT64").InFloat64(1.1, []float64{1.25, 2.5, 3.75}) -v = cfg.Section("").Key("INT").InInt(5, []int{10, 20, 30}) -v = cfg.Section("").Key("INT64").InInt64(10, []int64{10, 20, 30}) -v = cfg.Section("").Key("UINT").InUint(4, []int{3, 6, 9}) -v = cfg.Section("").Key("UINT64").InUint64(8, []int64{3, 6, 9}) -v = cfg.Section("").Key("TIME").InTimeFormat(time.RFC3339, time.Now(), []time.Time{time1, time2, time3}) -v = cfg.Section("").Key("TIME").InTime(time.Now(), []time.Time{time1, time2, time3}) // RFC3339 -``` - -Default value will be presented if value of key is not in candidates you given, and default value does not need be one of candidates. - -To validate value in a given range: - -```go -vals = cfg.Section("").Key("FLOAT64").RangeFloat64(0.0, 1.1, 2.2) -vals = cfg.Section("").Key("INT").RangeInt(0, 10, 20) -vals = cfg.Section("").Key("INT64").RangeInt64(0, 10, 20) -vals = cfg.Section("").Key("UINT").RangeUint(0, 3, 9) -vals = cfg.Section("").Key("UINT64").RangeUint64(0, 3, 9) -vals = cfg.Section("").Key("TIME").RangeTimeFormat(time.RFC3339, time.Now(), minTime, maxTime) -vals = cfg.Section("").Key("TIME").RangeTime(time.Now(), minTime, maxTime) // RFC3339 -``` - -##### Auto-split values into a slice - -To use zero value of type for invalid inputs: - -```go -// Input: 1.1, 2.2, 3.3, 4.4 -> [1.1 2.2 3.3 4.4] -// Input: how, 2.2, are, you -> [0.0 2.2 0.0 0.0] -vals = cfg.Section("").Key("STRINGS").Strings(",") -vals = cfg.Section("").Key("FLOAT64S").Float64s(",") -vals = cfg.Section("").Key("INTS").Ints(",") -vals = cfg.Section("").Key("INT64S").Int64s(",") -vals = cfg.Section("").Key("UINTS").Uints(",") -vals = cfg.Section("").Key("UINT64S").Uint64s(",") -vals = cfg.Section("").Key("TIMES").Times(",") -``` - -To exclude invalid values out of result slice: - -```go -// Input: 1.1, 2.2, 3.3, 4.4 -> [1.1 2.2 3.3 4.4] -// Input: how, 2.2, are, you -> [2.2] -vals = cfg.Section("").Key("FLOAT64S").ValidFloat64s(",") -vals = cfg.Section("").Key("INTS").ValidInts(",") -vals = cfg.Section("").Key("INT64S").ValidInt64s(",") -vals = cfg.Section("").Key("UINTS").ValidUints(",") -vals = cfg.Section("").Key("UINT64S").ValidUint64s(",") -vals = cfg.Section("").Key("TIMES").ValidTimes(",") -``` - -Or to return nothing but error when have invalid inputs: - -```go -// Input: 1.1, 2.2, 3.3, 4.4 -> [1.1 2.2 3.3 4.4] -// Input: how, 2.2, are, you -> error -vals = cfg.Section("").Key("FLOAT64S").StrictFloat64s(",") -vals = cfg.Section("").Key("INTS").StrictInts(",") -vals = cfg.Section("").Key("INT64S").StrictInt64s(",") -vals = cfg.Section("").Key("UINTS").StrictUints(",") -vals = cfg.Section("").Key("UINT64S").StrictUint64s(",") -vals = cfg.Section("").Key("TIMES").StrictTimes(",") -``` - -### Save your configuration - -Finally, it's time to save your configuration to somewhere. - -A typical way to save configuration is writing it to a file: - -```go -// ... -err = cfg.SaveTo("my.ini") -err = cfg.SaveToIndent("my.ini", "\t") -``` - -Another way to save is writing to a `io.Writer` interface: - -```go -// ... -cfg.WriteTo(writer) -cfg.WriteToIndent(writer, "\t") -``` - -By default, spaces are used to align "=" sign between key and values, to disable that: - -```go -ini.PrettyFormat = false -``` - -## Advanced Usage - -### Recursive Values - -For all value of keys, there is a special syntax `%()s`, where `` is the key name in same section or default section, and `%()s` will be replaced by corresponding value(empty string if key not found). You can use this syntax at most 99 level of recursions. - -```ini -NAME = ini - -[author] -NAME = Unknwon -GITHUB = https://github.com/%(NAME)s - -[package] -FULL_NAME = github.com/go-ini/%(NAME)s -``` - -```go -cfg.Section("author").Key("GITHUB").String() // https://github.com/Unknwon -cfg.Section("package").Key("FULL_NAME").String() // github.com/go-ini/ini -``` - -### Parent-child Sections - -You can use `.` in section name to indicate parent-child relationship between two or more sections. If the key not found in the child section, library will try again on its parent section until there is no parent section. - -```ini -NAME = ini -VERSION = v1 -IMPORT_PATH = gopkg.in/%(NAME)s.%(VERSION)s - -[package] -CLONE_URL = https://%(IMPORT_PATH)s - -[package.sub] -``` - -```go -cfg.Section("package.sub").Key("CLONE_URL").String() // https://gopkg.in/ini.v1 -``` - -#### Retrieve parent keys available to a child section - -```go -cfg.Section("package.sub").ParentKeys() // ["CLONE_URL"] -``` - -### Same Key with Multiple Values - -Do you ever have a configuration file like this? - -```ini -[remote "origin"] -url = https://github.com/Antergone/test1.git -url = https://github.com/Antergone/test2.git -fetch = +refs/heads/*:refs/remotes/origin/* -``` - -By default, only the last read value will be kept for the key `url`. If you want to keep all copies of value of this key, you can use `ShadowLoad` to achieve it: - -```go -cfg, err := ini.ShadowLoad(".gitconfig") -// ... - -f.Section(`remote "origin"`).Key("url").String() -// Result: https://github.com/Antergone/test1.git - -f.Section(`remote "origin"`).Key("url").ValueWithShadows() -// Result: []string{ -// "https://github.com/Antergone/test1.git", -// "https://github.com/Antergone/test2.git", -// } -``` - -### Unparseable Sections - -Sometimes, you have sections that do not contain key-value pairs but raw content, to handle such case, you can use `LoadOptions.UnparsableSections`: - -```go -cfg, err := ini.LoadSources(ini.LoadOptions{UnparseableSections: []string{"COMMENTS"}}, `[COMMENTS] -<1> This slide has the fuel listed in the wrong units `)) - -body := cfg.Section("COMMENTS").Body() - -/* --- start --- -<1> This slide has the fuel listed in the wrong units ------- end --- */ -``` - -### Auto-increment Key Names - -If key name is `-` in data source, then it would be seen as special syntax for auto-increment key name start from 1, and every section is independent on counter. - -```ini -[features] --: Support read/write comments of keys and sections --: Support auto-increment of key names --: Support load multiple files to overwrite key values -``` - -```go -cfg.Section("features").KeyStrings() // []{"#1", "#2", "#3"} -``` - -### Map To Struct - -Want more objective way to play with INI? Cool. - -```ini -Name = Unknwon -age = 21 -Male = true -Born = 1993-01-01T20:17:05Z - -[Note] -Content = Hi is a good man! -Cities = HangZhou, Boston -``` - -```go -type Note struct { - Content string - Cities []string -} - -type Person struct { - Name string - Age int `ini:"age"` - Male bool - Born time.Time - Note - Created time.Time `ini:"-"` -} - -func main() { - cfg, err := ini.Load("path/to/ini") - // ... - p := new(Person) - err = cfg.MapTo(p) - // ... - - // Things can be simpler. - err = ini.MapTo(p, "path/to/ini") - // ... - - // Just map a section? Fine. - n := new(Note) - err = cfg.Section("Note").MapTo(n) - // ... -} -``` - -Can I have default value for field? Absolutely. - -Assign it before you map to struct. It will keep the value as it is if the key is not presented or got wrong type. - -```go -// ... -p := &Person{ - Name: "Joe", -} -// ... -``` - -It's really cool, but what's the point if you can't give me my file back from struct? - -### Reflect From Struct - -Why not? - -```go -type Embeded struct { - Dates []time.Time `delim:"|" comment:"Time data"` - Places []string `ini:"places,omitempty"` - None []int `ini:",omitempty"` -} - -type Author struct { - Name string `ini:"NAME"` - Male bool - Age int `comment:"Author's age"` - GPA float64 - NeverMind string `ini:"-"` - *Embeded `comment:"Embeded section"` -} - -func main() { - a := &Author{"Unknwon", true, 21, 2.8, "", - &Embeded{ - []time.Time{time.Now(), time.Now()}, - []string{"HangZhou", "Boston"}, - []int{}, - }} - cfg := ini.Empty() - err = ini.ReflectFrom(cfg, a) - // ... -} -``` - -So, what do I get? - -```ini -NAME = Unknwon -Male = true -; Author's age -Age = 21 -GPA = 2.8 - -; Embeded section -[Embeded] -; Time data -Dates = 2015-08-07T22:14:22+08:00|2015-08-07T22:14:22+08:00 -places = HangZhou,Boston -``` - -#### Name Mapper - -To save your time and make your code cleaner, this library supports [`NameMapper`](https://gowalker.org/gopkg.in/ini.v1#NameMapper) between struct field and actual section and key name. - -There are 2 built-in name mappers: - -- `AllCapsUnderscore`: it converts to format `ALL_CAPS_UNDERSCORE` then match section or key. -- `TitleUnderscore`: it converts to format `title_underscore` then match section or key. - -To use them: - -```go -type Info struct { - PackageName string -} - -func main() { - err = ini.MapToWithMapper(&Info{}, ini.TitleUnderscore, []byte("package_name=ini")) - // ... - - cfg, err := ini.Load([]byte("PACKAGE_NAME=ini")) - // ... - info := new(Info) - cfg.NameMapper = ini.AllCapsUnderscore - err = cfg.MapTo(info) - // ... -} -``` - -Same rules of name mapper apply to `ini.ReflectFromWithMapper` function. - -#### Value Mapper - -To expand values (e.g. from environment variables), you can use the `ValueMapper` to transform values: - -```go -type Env struct { - Foo string `ini:"foo"` -} - -func main() { - cfg, err := ini.Load([]byte("[env]\nfoo = ${MY_VAR}\n") - cfg.ValueMapper = os.ExpandEnv - // ... - env := &Env{} - err = cfg.Section("env").MapTo(env) -} -``` - -This would set the value of `env.Foo` to the value of the environment variable `MY_VAR`. - -#### Other Notes On Map/Reflect - -Any embedded struct is treated as a section by default, and there is no automatic parent-child relations in map/reflect feature: - -```go -type Child struct { - Age string -} - -type Parent struct { - Name string - Child -} - -type Config struct { - City string - Parent -} -``` - -Example configuration: - -```ini -City = Boston - -[Parent] -Name = Unknwon - -[Child] -Age = 21 -``` - -What if, yes, I'm paranoid, I want embedded struct to be in the same section. Well, all roads lead to Rome. - -```go -type Child struct { - Age string -} - -type Parent struct { - Name string - Child `ini:"Parent"` -} - -type Config struct { - City string - Parent -} -``` - -Example configuration: - -```ini -City = Boston - -[Parent] -Name = Unknwon -Age = 21 -``` - -## Getting Help - -- [API Documentation](https://gowalker.org/gopkg.in/ini.v1) -- [File An Issue](https://github.com/go-ini/ini/issues/new) - -## FAQs - -### What does `BlockMode` field do? - -By default, library lets you read and write values so we need a locker to make sure your data is safe. But in cases that you are very sure about only reading data through the library, you can set `cfg.BlockMode = false` to speed up read operations about **50-70%** faster. - -### Why another INI library? - -Many people are using my another INI library [goconfig](https://github.com/Unknwon/goconfig), so the reason for this one is I would like to make more Go style code. Also when you set `cfg.BlockMode = false`, this one is about **10-30%** faster. - -To make those changes I have to confirm API broken, so it's safer to keep it in another place and start using `gopkg.in` to version my package at this time.(PS: shorter import path) - -## License - -This project is under Apache v2 License. See the [LICENSE](LICENSE) file for the full license text. diff --git a/vendor/github.com/go-ini/ini/README_ZH.md b/vendor/github.com/go-ini/ini/README_ZH.md deleted file mode 100644 index 67a53630204..00000000000 --- a/vendor/github.com/go-ini/ini/README_ZH.md +++ /dev/null @@ -1,777 +0,0 @@ -本包提供了 Go 语言中读写 INI 文件的功能。 - -## 功能特性 - -- 支持覆盖加载多个数据源(`[]byte`、文件和 `io.ReadCloser`) -- 支持递归读取键值 -- 支持读取父子分区 -- 支持读取自增键名 -- 支持读取多行的键值 -- 支持大量辅助方法 -- 支持在读取时直接转换为 Go 语言类型 -- 支持读取和 **写入** 分区和键的注释 -- 轻松操作分区、键值和注释 -- 在保存文件时分区和键值会保持原有的顺序 - -## 下载安装 - -使用一个特定版本: - - go get gopkg.in/ini.v1 - -使用最新版: - - go get github.com/go-ini/ini - -如需更新请添加 `-u` 选项。 - -### 测试安装 - -如果您想要在自己的机器上运行测试,请使用 `-t` 标记: - - go get -t gopkg.in/ini.v1 - -如需更新请添加 `-u` 选项。 - -## 开始使用 - -### 从数据源加载 - -一个 **数据源** 可以是 `[]byte` 类型的原始数据,`string` 类型的文件路径或 `io.ReadCloser`。您可以加载 **任意多个** 数据源。如果您传递其它类型的数据源,则会直接返回错误。 - -```go -cfg, err := ini.Load([]byte("raw data"), "filename", ioutil.NopCloser(bytes.NewReader([]byte("some other data")))) -``` - -或者从一个空白的文件开始: - -```go -cfg := ini.Empty() -``` - -当您在一开始无法决定需要加载哪些数据源时,仍可以使用 **Append()** 在需要的时候加载它们。 - -```go -err := cfg.Append("other file", []byte("other raw data")) -``` - -当您想要加载一系列文件,但是不能够确定其中哪些文件是不存在的,可以通过调用函数 `LooseLoad` 来忽略它们(`Load` 会因为文件不存在而返回错误): - -```go -cfg, err := ini.LooseLoad("filename", "filename_404") -``` - -更牛逼的是,当那些之前不存在的文件在重新调用 `Reload` 方法的时候突然出现了,那么它们会被正常加载。 - -#### 忽略键名的大小写 - -有时候分区和键的名称大小写混合非常烦人,这个时候就可以通过 `InsensitiveLoad` 将所有分区和键名在读取里强制转换为小写: - -```go -cfg, err := ini.InsensitiveLoad("filename") -//... - -// sec1 和 sec2 指向同一个分区对象 -sec1, err := cfg.GetSection("Section") -sec2, err := cfg.GetSection("SecTIOn") - -// key1 和 key2 指向同一个键对象 -key1, err := sec1.GetKey("Key") -key2, err := sec2.GetKey("KeY") -``` - -#### 类似 MySQL 配置中的布尔值键 - -MySQL 的配置文件中会出现没有具体值的布尔类型的键: - -```ini -[mysqld] -... -skip-host-cache -skip-name-resolve -``` - -默认情况下这被认为是缺失值而无法完成解析,但可以通过高级的加载选项对它们进行处理: - -```go -cfg, err := ini.LoadSources(ini.LoadOptions{AllowBooleanKeys: true}, "my.cnf")) -``` - -这些键的值永远为 `true`,且在保存到文件时也只会输出键名。 - -如果您想要通过程序来生成此类键,则可以使用 `NewBooleanKey`: - -```go -key, err := sec.NewBooleanKey("skip-host-cache") -``` - -#### 关于注释 - -下述几种情况的内容将被视为注释: - -1. 所有以 `#` 或 `;` 开头的行 -2. 所有在 `#` 或 `;` 之后的内容 -3. 分区标签后的文字 (即 `[分区名]` 之后的内容) - -如果你希望使用包含 `#` 或 `;` 的值,请使用 ``` ` ``` 或 ``` """ ``` 进行包覆。 - -除此之外,您还可以通过 `LoadOptions` 完全忽略行内注释: - -```go -cfg, err := ini.LoadSources(ini.LoadOptions{IgnoreInlineComment: true}, "app.ini")) -``` - -### 操作分区(Section) - -获取指定分区: - -```go -section, err := cfg.GetSection("section name") -``` - -如果您想要获取默认分区,则可以用空字符串代替分区名: - -```go -section, err := cfg.GetSection("") -``` - -当您非常确定某个分区是存在的,可以使用以下简便方法: - -```go -section := cfg.Section("section name") -``` - -如果不小心判断错了,要获取的分区其实是不存在的,那会发生什么呢?没事的,它会自动创建并返回一个对应的分区对象给您。 - -创建一个分区: - -```go -err := cfg.NewSection("new section") -``` - -获取所有分区对象或名称: - -```go -sections := cfg.Sections() -names := cfg.SectionStrings() -``` - -### 操作键(Key) - -获取某个分区下的键: - -```go -key, err := cfg.Section("").GetKey("key name") -``` - -和分区一样,您也可以直接获取键而忽略错误处理: - -```go -key := cfg.Section("").Key("key name") -``` - -判断某个键是否存在: - -```go -yes := cfg.Section("").HasKey("key name") -``` - -创建一个新的键: - -```go -err := cfg.Section("").NewKey("name", "value") -``` - -获取分区下的所有键或键名: - -```go -keys := cfg.Section("").Keys() -names := cfg.Section("").KeyStrings() -``` - -获取分区下的所有键值对的克隆: - -```go -hash := cfg.Section("").KeysHash() -``` - -### 操作键值(Value) - -获取一个类型为字符串(string)的值: - -```go -val := cfg.Section("").Key("key name").String() -``` - -获取值的同时通过自定义函数进行处理验证: - -```go -val := cfg.Section("").Key("key name").Validate(func(in string) string { - if len(in) == 0 { - return "default" - } - return in -}) -``` - -如果您不需要任何对值的自动转变功能(例如递归读取),可以直接获取原值(这种方式性能最佳): - -```go -val := cfg.Section("").Key("key name").Value() -``` - -判断某个原值是否存在: - -```go -yes := cfg.Section("").HasValue("test value") -``` - -获取其它类型的值: - -```go -// 布尔值的规则: -// true 当值为:1, t, T, TRUE, true, True, YES, yes, Yes, y, ON, on, On -// false 当值为:0, f, F, FALSE, false, False, NO, no, No, n, OFF, off, Off -v, err = cfg.Section("").Key("BOOL").Bool() -v, err = cfg.Section("").Key("FLOAT64").Float64() -v, err = cfg.Section("").Key("INT").Int() -v, err = cfg.Section("").Key("INT64").Int64() -v, err = cfg.Section("").Key("UINT").Uint() -v, err = cfg.Section("").Key("UINT64").Uint64() -v, err = cfg.Section("").Key("TIME").TimeFormat(time.RFC3339) -v, err = cfg.Section("").Key("TIME").Time() // RFC3339 - -v = cfg.Section("").Key("BOOL").MustBool() -v = cfg.Section("").Key("FLOAT64").MustFloat64() -v = cfg.Section("").Key("INT").MustInt() -v = cfg.Section("").Key("INT64").MustInt64() -v = cfg.Section("").Key("UINT").MustUint() -v = cfg.Section("").Key("UINT64").MustUint64() -v = cfg.Section("").Key("TIME").MustTimeFormat(time.RFC3339) -v = cfg.Section("").Key("TIME").MustTime() // RFC3339 - -// 由 Must 开头的方法名允许接收一个相同类型的参数来作为默认值, -// 当键不存在或者转换失败时,则会直接返回该默认值。 -// 但是,MustString 方法必须传递一个默认值。 - -v = cfg.Seciont("").Key("String").MustString("default") -v = cfg.Section("").Key("BOOL").MustBool(true) -v = cfg.Section("").Key("FLOAT64").MustFloat64(1.25) -v = cfg.Section("").Key("INT").MustInt(10) -v = cfg.Section("").Key("INT64").MustInt64(99) -v = cfg.Section("").Key("UINT").MustUint(3) -v = cfg.Section("").Key("UINT64").MustUint64(6) -v = cfg.Section("").Key("TIME").MustTimeFormat(time.RFC3339, time.Now()) -v = cfg.Section("").Key("TIME").MustTime(time.Now()) // RFC3339 -``` - -如果我的值有好多行怎么办? - -```ini -[advance] -ADDRESS = """404 road, -NotFound, State, 5000 -Earth""" -``` - -嗯哼?小 case! - -```go -cfg.Section("advance").Key("ADDRESS").String() - -/* --- start --- -404 road, -NotFound, State, 5000 -Earth ------- end --- */ -``` - -赞爆了!那要是我属于一行的内容写不下想要写到第二行怎么办? - -```ini -[advance] -two_lines = how about \ - continuation lines? -lots_of_lines = 1 \ - 2 \ - 3 \ - 4 -``` - -简直是小菜一碟! - -```go -cfg.Section("advance").Key("two_lines").String() // how about continuation lines? -cfg.Section("advance").Key("lots_of_lines").String() // 1 2 3 4 -``` - -可是我有时候觉得两行连在一起特别没劲,怎么才能不自动连接两行呢? - -```go -cfg, err := ini.LoadSources(ini.LoadOptions{ - IgnoreContinuation: true, -}, "filename") -``` - -哇靠给力啊! - -需要注意的是,值两侧的单引号会被自动剔除: - -```ini -foo = "some value" // foo: some value -bar = 'some value' // bar: some value -``` - -有时您会获得像从 [Crowdin](https://crowdin.com/) 网站下载的文件那样具有特殊格式的值(值使用双引号括起来,内部的双引号被转义): - -```ini -create_repo="创建了仓库 %s" -``` - -那么,怎么自动地将这类值进行处理呢? - -```go -cfg, err := ini.LoadSources(ini.LoadOptions{UnescapeValueDoubleQuotes: true}, "en-US.ini")) -cfg.Section("").Key("create_repo").String() -// You got: 创建了仓库 %s -``` - -这就是全部了?哈哈,当然不是。 - -#### 操作键值的辅助方法 - -获取键值时设定候选值: - -```go -v = cfg.Section("").Key("STRING").In("default", []string{"str", "arr", "types"}) -v = cfg.Section("").Key("FLOAT64").InFloat64(1.1, []float64{1.25, 2.5, 3.75}) -v = cfg.Section("").Key("INT").InInt(5, []int{10, 20, 30}) -v = cfg.Section("").Key("INT64").InInt64(10, []int64{10, 20, 30}) -v = cfg.Section("").Key("UINT").InUint(4, []int{3, 6, 9}) -v = cfg.Section("").Key("UINT64").InUint64(8, []int64{3, 6, 9}) -v = cfg.Section("").Key("TIME").InTimeFormat(time.RFC3339, time.Now(), []time.Time{time1, time2, time3}) -v = cfg.Section("").Key("TIME").InTime(time.Now(), []time.Time{time1, time2, time3}) // RFC3339 -``` - -如果获取到的值不是候选值的任意一个,则会返回默认值,而默认值不需要是候选值中的一员。 - -验证获取的值是否在指定范围内: - -```go -vals = cfg.Section("").Key("FLOAT64").RangeFloat64(0.0, 1.1, 2.2) -vals = cfg.Section("").Key("INT").RangeInt(0, 10, 20) -vals = cfg.Section("").Key("INT64").RangeInt64(0, 10, 20) -vals = cfg.Section("").Key("UINT").RangeUint(0, 3, 9) -vals = cfg.Section("").Key("UINT64").RangeUint64(0, 3, 9) -vals = cfg.Section("").Key("TIME").RangeTimeFormat(time.RFC3339, time.Now(), minTime, maxTime) -vals = cfg.Section("").Key("TIME").RangeTime(time.Now(), minTime, maxTime) // RFC3339 -``` - -##### 自动分割键值到切片(slice) - -当存在无效输入时,使用零值代替: - -```go -// Input: 1.1, 2.2, 3.3, 4.4 -> [1.1 2.2 3.3 4.4] -// Input: how, 2.2, are, you -> [0.0 2.2 0.0 0.0] -vals = cfg.Section("").Key("STRINGS").Strings(",") -vals = cfg.Section("").Key("FLOAT64S").Float64s(",") -vals = cfg.Section("").Key("INTS").Ints(",") -vals = cfg.Section("").Key("INT64S").Int64s(",") -vals = cfg.Section("").Key("UINTS").Uints(",") -vals = cfg.Section("").Key("UINT64S").Uint64s(",") -vals = cfg.Section("").Key("TIMES").Times(",") -``` - -从结果切片中剔除无效输入: - -```go -// Input: 1.1, 2.2, 3.3, 4.4 -> [1.1 2.2 3.3 4.4] -// Input: how, 2.2, are, you -> [2.2] -vals = cfg.Section("").Key("FLOAT64S").ValidFloat64s(",") -vals = cfg.Section("").Key("INTS").ValidInts(",") -vals = cfg.Section("").Key("INT64S").ValidInt64s(",") -vals = cfg.Section("").Key("UINTS").ValidUints(",") -vals = cfg.Section("").Key("UINT64S").ValidUint64s(",") -vals = cfg.Section("").Key("TIMES").ValidTimes(",") -``` - -当存在无效输入时,直接返回错误: - -```go -// Input: 1.1, 2.2, 3.3, 4.4 -> [1.1 2.2 3.3 4.4] -// Input: how, 2.2, are, you -> error -vals = cfg.Section("").Key("FLOAT64S").StrictFloat64s(",") -vals = cfg.Section("").Key("INTS").StrictInts(",") -vals = cfg.Section("").Key("INT64S").StrictInt64s(",") -vals = cfg.Section("").Key("UINTS").StrictUints(",") -vals = cfg.Section("").Key("UINT64S").StrictUint64s(",") -vals = cfg.Section("").Key("TIMES").StrictTimes(",") -``` - -### 保存配置 - -终于到了这个时刻,是时候保存一下配置了。 - -比较原始的做法是输出配置到某个文件: - -```go -// ... -err = cfg.SaveTo("my.ini") -err = cfg.SaveToIndent("my.ini", "\t") -``` - -另一个比较高级的做法是写入到任何实现 `io.Writer` 接口的对象中: - -```go -// ... -cfg.WriteTo(writer) -cfg.WriteToIndent(writer, "\t") -``` - -默认情况下,空格将被用于对齐键值之间的等号以美化输出结果,以下代码可以禁用该功能: - -```go -ini.PrettyFormat = false -``` - -## 高级用法 - -### 递归读取键值 - -在获取所有键值的过程中,特殊语法 `%()s` 会被应用,其中 `` 可以是相同分区或者默认分区下的键名。字符串 `%()s` 会被相应的键值所替代,如果指定的键不存在,则会用空字符串替代。您可以最多使用 99 层的递归嵌套。 - -```ini -NAME = ini - -[author] -NAME = Unknwon -GITHUB = https://github.com/%(NAME)s - -[package] -FULL_NAME = github.com/go-ini/%(NAME)s -``` - -```go -cfg.Section("author").Key("GITHUB").String() // https://github.com/Unknwon -cfg.Section("package").Key("FULL_NAME").String() // github.com/go-ini/ini -``` - -### 读取父子分区 - -您可以在分区名称中使用 `.` 来表示两个或多个分区之间的父子关系。如果某个键在子分区中不存在,则会去它的父分区中再次寻找,直到没有父分区为止。 - -```ini -NAME = ini -VERSION = v1 -IMPORT_PATH = gopkg.in/%(NAME)s.%(VERSION)s - -[package] -CLONE_URL = https://%(IMPORT_PATH)s - -[package.sub] -``` - -```go -cfg.Section("package.sub").Key("CLONE_URL").String() // https://gopkg.in/ini.v1 -``` - -#### 获取上级父分区下的所有键名 - -```go -cfg.Section("package.sub").ParentKeys() // ["CLONE_URL"] -``` - -### 同个键名包含多个值 - -你是否也曾被下面的配置文件所困扰? - -```ini -[remote "origin"] -url = https://github.com/Antergone/test1.git -url = https://github.com/Antergone/test2.git -fetch = +refs/heads/*:refs/remotes/origin/* -``` - -没错!默认情况下,只有最后一次出现的值会被保存到 `url` 中,可我就是想要保留所有的值怎么办啊?不要紧,用 `ShadowLoad` 轻松解决你的烦恼: - -```go -cfg, err := ini.ShadowLoad(".gitconfig") -// ... - -f.Section(`remote "origin"`).Key("url").String() -// Result: https://github.com/Antergone/test1.git - -f.Section(`remote "origin"`).Key("url").ValueWithShadows() -// Result: []string{ -// "https://github.com/Antergone/test1.git", -// "https://github.com/Antergone/test2.git", -// } -``` - -### 无法解析的分区 - -如果遇到一些比较特殊的分区,它们不包含常见的键值对,而是没有固定格式的纯文本,则可以使用 `LoadOptions.UnparsableSections` 进行处理: - -```go -cfg, err := LoadSources(ini.LoadOptions{UnparseableSections: []string{"COMMENTS"}}, `[COMMENTS] -<1> This slide has the fuel listed in the wrong units `)) - -body := cfg.Section("COMMENTS").Body() - -/* --- start --- -<1> This slide has the fuel listed in the wrong units ------- end --- */ -``` - -### 读取自增键名 - -如果数据源中的键名为 `-`,则认为该键使用了自增键名的特殊语法。计数器从 1 开始,并且分区之间是相互独立的。 - -```ini -[features] --: Support read/write comments of keys and sections --: Support auto-increment of key names --: Support load multiple files to overwrite key values -``` - -```go -cfg.Section("features").KeyStrings() // []{"#1", "#2", "#3"} -``` - -### 映射到结构 - -想要使用更加面向对象的方式玩转 INI 吗?好主意。 - -```ini -Name = Unknwon -age = 21 -Male = true -Born = 1993-01-01T20:17:05Z - -[Note] -Content = Hi is a good man! -Cities = HangZhou, Boston -``` - -```go -type Note struct { - Content string - Cities []string -} - -type Person struct { - Name string - Age int `ini:"age"` - Male bool - Born time.Time - Note - Created time.Time `ini:"-"` -} - -func main() { - cfg, err := ini.Load("path/to/ini") - // ... - p := new(Person) - err = cfg.MapTo(p) - // ... - - // 一切竟可以如此的简单。 - err = ini.MapTo(p, "path/to/ini") - // ... - - // 嗯哼?只需要映射一个分区吗? - n := new(Note) - err = cfg.Section("Note").MapTo(n) - // ... -} -``` - -结构的字段怎么设置默认值呢?很简单,只要在映射之前对指定字段进行赋值就可以了。如果键未找到或者类型错误,该值不会发生改变。 - -```go -// ... -p := &Person{ - Name: "Joe", -} -// ... -``` - -这样玩 INI 真的好酷啊!然而,如果不能还给我原来的配置文件,有什么卵用? - -### 从结构反射 - -可是,我有说不能吗? - -```go -type Embeded struct { - Dates []time.Time `delim:"|" comment:"Time data"` - Places []string `ini:"places,omitempty"` - None []int `ini:",omitempty"` -} - -type Author struct { - Name string `ini:"NAME"` - Male bool - Age int `comment:"Author's age"` - GPA float64 - NeverMind string `ini:"-"` - *Embeded `comment:"Embeded section"` -} - -func main() { - a := &Author{"Unknwon", true, 21, 2.8, "", - &Embeded{ - []time.Time{time.Now(), time.Now()}, - []string{"HangZhou", "Boston"}, - []int{}, - }} - cfg := ini.Empty() - err = ini.ReflectFrom(cfg, a) - // ... -} -``` - -瞧瞧,奇迹发生了。 - -```ini -NAME = Unknwon -Male = true -; Author's age -Age = 21 -GPA = 2.8 - -; Embeded section -[Embeded] -; Time data -Dates = 2015-08-07T22:14:22+08:00|2015-08-07T22:14:22+08:00 -places = HangZhou,Boston -``` - -#### 名称映射器(Name Mapper) - -为了节省您的时间并简化代码,本库支持类型为 [`NameMapper`](https://gowalker.org/gopkg.in/ini.v1#NameMapper) 的名称映射器,该映射器负责结构字段名与分区名和键名之间的映射。 - -目前有 2 款内置的映射器: - -- `AllCapsUnderscore`:该映射器将字段名转换至格式 `ALL_CAPS_UNDERSCORE` 后再去匹配分区名和键名。 -- `TitleUnderscore`:该映射器将字段名转换至格式 `title_underscore` 后再去匹配分区名和键名。 - -使用方法: - -```go -type Info struct{ - PackageName string -} - -func main() { - err = ini.MapToWithMapper(&Info{}, ini.TitleUnderscore, []byte("package_name=ini")) - // ... - - cfg, err := ini.Load([]byte("PACKAGE_NAME=ini")) - // ... - info := new(Info) - cfg.NameMapper = ini.AllCapsUnderscore - err = cfg.MapTo(info) - // ... -} -``` - -使用函数 `ini.ReflectFromWithMapper` 时也可应用相同的规则。 - -#### 值映射器(Value Mapper) - -值映射器允许使用一个自定义函数自动展开值的具体内容,例如:运行时获取环境变量: - -```go -type Env struct { - Foo string `ini:"foo"` -} - -func main() { - cfg, err := ini.Load([]byte("[env]\nfoo = ${MY_VAR}\n") - cfg.ValueMapper = os.ExpandEnv - // ... - env := &Env{} - err = cfg.Section("env").MapTo(env) -} -``` - -本例中,`env.Foo` 将会是运行时所获取到环境变量 `MY_VAR` 的值。 - -#### 映射/反射的其它说明 - -任何嵌入的结构都会被默认认作一个不同的分区,并且不会自动产生所谓的父子分区关联: - -```go -type Child struct { - Age string -} - -type Parent struct { - Name string - Child -} - -type Config struct { - City string - Parent -} -``` - -示例配置文件: - -```ini -City = Boston - -[Parent] -Name = Unknwon - -[Child] -Age = 21 -``` - -很好,但是,我就是要嵌入结构也在同一个分区。好吧,你爹是李刚! - -```go -type Child struct { - Age string -} - -type Parent struct { - Name string - Child `ini:"Parent"` -} - -type Config struct { - City string - Parent -} -``` - -示例配置文件: - -```ini -City = Boston - -[Parent] -Name = Unknwon -Age = 21 -``` - -## 获取帮助 - -- [API 文档](https://gowalker.org/gopkg.in/ini.v1) -- [创建工单](https://github.com/go-ini/ini/issues/new) - -## 常见问题 - -### 字段 `BlockMode` 是什么? - -默认情况下,本库会在您进行读写操作时采用锁机制来确保数据时间。但在某些情况下,您非常确定只进行读操作。此时,您可以通过设置 `cfg.BlockMode = false` 来将读操作提升大约 **50-70%** 的性能。 - -### 为什么要写另一个 INI 解析库? - -许多人都在使用我的 [goconfig](https://github.com/Unknwon/goconfig) 来完成对 INI 文件的操作,但我希望使用更加 Go 风格的代码。并且当您设置 `cfg.BlockMode = false` 时,会有大约 **10-30%** 的性能提升。 - -为了做出这些改变,我必须对 API 进行破坏,所以新开一个仓库是最安全的做法。除此之外,本库直接使用 `gopkg.in` 来进行版本化发布。(其实真相是导入路径更短了) diff --git a/vendor/github.com/go-ini/ini/error.go b/vendor/github.com/go-ini/ini/error.go deleted file mode 100644 index 80afe743158..00000000000 --- a/vendor/github.com/go-ini/ini/error.go +++ /dev/null @@ -1,32 +0,0 @@ -// Copyright 2016 Unknwon -// -// 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 ini - -import ( - "fmt" -) - -type ErrDelimiterNotFound struct { - Line string -} - -func IsErrDelimiterNotFound(err error) bool { - _, ok := err.(ErrDelimiterNotFound) - return ok -} - -func (err ErrDelimiterNotFound) Error() string { - return fmt.Sprintf("key-value delimiter not found: %s", err.Line) -} diff --git a/vendor/github.com/go-ini/ini/file.go b/vendor/github.com/go-ini/ini/file.go deleted file mode 100644 index ae6264acfa2..00000000000 --- a/vendor/github.com/go-ini/ini/file.go +++ /dev/null @@ -1,403 +0,0 @@ -// Copyright 2017 Unknwon -// -// 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 ini - -import ( - "bytes" - "errors" - "fmt" - "io" - "io/ioutil" - "os" - "strings" - "sync" -) - -// File represents a combination of a or more INI file(s) in memory. -type File struct { - options LoadOptions - dataSources []dataSource - - // Should make things safe, but sometimes doesn't matter. - BlockMode bool - lock sync.RWMutex - - // To keep data in order. - sectionList []string - // Actual data is stored here. - sections map[string]*Section - - NameMapper - ValueMapper -} - -// newFile initializes File object with given data sources. -func newFile(dataSources []dataSource, opts LoadOptions) *File { - return &File{ - BlockMode: true, - dataSources: dataSources, - sections: make(map[string]*Section), - sectionList: make([]string, 0, 10), - options: opts, - } -} - -// Empty returns an empty file object. -func Empty() *File { - // Ignore error here, we sure our data is good. - f, _ := Load([]byte("")) - return f -} - -// NewSection creates a new section. -func (f *File) NewSection(name string) (*Section, error) { - if len(name) == 0 { - return nil, errors.New("error creating new section: empty section name") - } else if f.options.Insensitive && name != DEFAULT_SECTION { - name = strings.ToLower(name) - } - - if f.BlockMode { - f.lock.Lock() - defer f.lock.Unlock() - } - - if inSlice(name, f.sectionList) { - return f.sections[name], nil - } - - f.sectionList = append(f.sectionList, name) - f.sections[name] = newSection(f, name) - return f.sections[name], nil -} - -// NewRawSection creates a new section with an unparseable body. -func (f *File) NewRawSection(name, body string) (*Section, error) { - section, err := f.NewSection(name) - if err != nil { - return nil, err - } - - section.isRawSection = true - section.rawBody = body - return section, nil -} - -// NewSections creates a list of sections. -func (f *File) NewSections(names ...string) (err error) { - for _, name := range names { - if _, err = f.NewSection(name); err != nil { - return err - } - } - return nil -} - -// GetSection returns section by given name. -func (f *File) GetSection(name string) (*Section, error) { - if len(name) == 0 { - name = DEFAULT_SECTION - } - if f.options.Insensitive { - name = strings.ToLower(name) - } - - if f.BlockMode { - f.lock.RLock() - defer f.lock.RUnlock() - } - - sec := f.sections[name] - if sec == nil { - return nil, fmt.Errorf("section '%s' does not exist", name) - } - return sec, nil -} - -// Section assumes named section exists and returns a zero-value when not. -func (f *File) Section(name string) *Section { - sec, err := f.GetSection(name) - if err != nil { - // Note: It's OK here because the only possible error is empty section name, - // but if it's empty, this piece of code won't be executed. - sec, _ = f.NewSection(name) - return sec - } - return sec -} - -// Section returns list of Section. -func (f *File) Sections() []*Section { - if f.BlockMode { - f.lock.RLock() - defer f.lock.RUnlock() - } - - sections := make([]*Section, len(f.sectionList)) - for i, name := range f.sectionList { - sections[i] = f.sections[name] - } - return sections -} - -// ChildSections returns a list of child sections of given section name. -func (f *File) ChildSections(name string) []*Section { - return f.Section(name).ChildSections() -} - -// SectionStrings returns list of section names. -func (f *File) SectionStrings() []string { - list := make([]string, len(f.sectionList)) - copy(list, f.sectionList) - return list -} - -// DeleteSection deletes a section. -func (f *File) DeleteSection(name string) { - if f.BlockMode { - f.lock.Lock() - defer f.lock.Unlock() - } - - if len(name) == 0 { - name = DEFAULT_SECTION - } - - for i, s := range f.sectionList { - if s == name { - f.sectionList = append(f.sectionList[:i], f.sectionList[i+1:]...) - delete(f.sections, name) - return - } - } -} - -func (f *File) reload(s dataSource) error { - r, err := s.ReadCloser() - if err != nil { - return err - } - defer r.Close() - - return f.parse(r) -} - -// Reload reloads and parses all data sources. -func (f *File) Reload() (err error) { - for _, s := range f.dataSources { - if err = f.reload(s); err != nil { - // In loose mode, we create an empty default section for nonexistent files. - if os.IsNotExist(err) && f.options.Loose { - f.parse(bytes.NewBuffer(nil)) - continue - } - return err - } - } - return nil -} - -// Append appends one or more data sources and reloads automatically. -func (f *File) Append(source interface{}, others ...interface{}) error { - ds, err := parseDataSource(source) - if err != nil { - return err - } - f.dataSources = append(f.dataSources, ds) - for _, s := range others { - ds, err = parseDataSource(s) - if err != nil { - return err - } - f.dataSources = append(f.dataSources, ds) - } - return f.Reload() -} - -func (f *File) writeToBuffer(indent string) (*bytes.Buffer, error) { - equalSign := "=" - if PrettyFormat { - equalSign = " = " - } - - // Use buffer to make sure target is safe until finish encoding. - buf := bytes.NewBuffer(nil) - for i, sname := range f.sectionList { - sec := f.Section(sname) - if len(sec.Comment) > 0 { - if sec.Comment[0] != '#' && sec.Comment[0] != ';' { - sec.Comment = "; " + sec.Comment - } else { - sec.Comment = sec.Comment[:1] + " " + strings.TrimSpace(sec.Comment[1:]) - } - if _, err := buf.WriteString(sec.Comment + LineBreak); err != nil { - return nil, err - } - } - - if i > 0 || DefaultHeader { - if _, err := buf.WriteString("[" + sname + "]" + LineBreak); err != nil { - return nil, err - } - } else { - // Write nothing if default section is empty - if len(sec.keyList) == 0 { - continue - } - } - - if sec.isRawSection { - if _, err := buf.WriteString(sec.rawBody); err != nil { - return nil, err - } - - if PrettySection { - // Put a line between sections - if _, err := buf.WriteString(LineBreak); err != nil { - return nil, err - } - } - continue - } - - // Count and generate alignment length and buffer spaces using the - // longest key. Keys may be modifed if they contain certain characters so - // we need to take that into account in our calculation. - alignLength := 0 - if PrettyFormat { - for _, kname := range sec.keyList { - keyLength := len(kname) - // First case will surround key by ` and second by """ - if strings.ContainsAny(kname, "\"=:") { - keyLength += 2 - } else if strings.Contains(kname, "`") { - keyLength += 6 - } - - if keyLength > alignLength { - alignLength = keyLength - } - } - } - alignSpaces := bytes.Repeat([]byte(" "), alignLength) - - KEY_LIST: - for _, kname := range sec.keyList { - key := sec.Key(kname) - if len(key.Comment) > 0 { - if len(indent) > 0 && sname != DEFAULT_SECTION { - buf.WriteString(indent) - } - if key.Comment[0] != '#' && key.Comment[0] != ';' { - key.Comment = "; " + key.Comment - } else { - key.Comment = key.Comment[:1] + " " + strings.TrimSpace(key.Comment[1:]) - } - if _, err := buf.WriteString(key.Comment + LineBreak); err != nil { - return nil, err - } - } - - if len(indent) > 0 && sname != DEFAULT_SECTION { - buf.WriteString(indent) - } - - switch { - case key.isAutoIncrement: - kname = "-" - case strings.ContainsAny(kname, "\"=:"): - kname = "`" + kname + "`" - case strings.Contains(kname, "`"): - kname = `"""` + kname + `"""` - } - - for _, val := range key.ValueWithShadows() { - if _, err := buf.WriteString(kname); err != nil { - return nil, err - } - - if key.isBooleanType { - if kname != sec.keyList[len(sec.keyList)-1] { - buf.WriteString(LineBreak) - } - continue KEY_LIST - } - - // Write out alignment spaces before "=" sign - if PrettyFormat { - buf.Write(alignSpaces[:alignLength-len(kname)]) - } - - // In case key value contains "\n", "`", "\"", "#" or ";" - if strings.ContainsAny(val, "\n`") { - val = `"""` + val + `"""` - } else if !f.options.IgnoreInlineComment && strings.ContainsAny(val, "#;") { - val = "`" + val + "`" - } - if _, err := buf.WriteString(equalSign + val + LineBreak); err != nil { - return nil, err - } - } - - for _, val := range key.nestedValues { - if _, err := buf.WriteString(indent + " " + val + LineBreak); err != nil { - return nil, err - } - } - } - - if PrettySection { - // Put a line between sections - if _, err := buf.WriteString(LineBreak); err != nil { - return nil, err - } - } - } - - return buf, nil -} - -// WriteToIndent writes content into io.Writer with given indention. -// If PrettyFormat has been set to be true, -// it will align "=" sign with spaces under each section. -func (f *File) WriteToIndent(w io.Writer, indent string) (int64, error) { - buf, err := f.writeToBuffer(indent) - if err != nil { - return 0, err - } - return buf.WriteTo(w) -} - -// WriteTo writes file content into io.Writer. -func (f *File) WriteTo(w io.Writer) (int64, error) { - return f.WriteToIndent(w, "") -} - -// SaveToIndent writes content to file system with given value indention. -func (f *File) SaveToIndent(filename, indent string) error { - // Note: Because we are truncating with os.Create, - // so it's safer to save to a temporary file location and rename afte done. - buf, err := f.writeToBuffer(indent) - if err != nil { - return err - } - - return ioutil.WriteFile(filename, buf.Bytes(), 0666) -} - -// SaveTo writes content to file system. -func (f *File) SaveTo(filename string) error { - return f.SaveToIndent(filename, "") -} diff --git a/vendor/github.com/go-ini/ini/ini.go b/vendor/github.com/go-ini/ini/ini.go deleted file mode 100644 index 9f6ea3b4157..00000000000 --- a/vendor/github.com/go-ini/ini/ini.go +++ /dev/null @@ -1,194 +0,0 @@ -// Copyright 2014 Unknwon -// -// 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 ini provides INI file read and write functionality in Go. -package ini - -import ( - "bytes" - "fmt" - "io" - "io/ioutil" - "os" - "regexp" - "runtime" -) - -const ( - // Name for default section. You can use this constant or the string literal. - // In most of cases, an empty string is all you need to access the section. - DEFAULT_SECTION = "DEFAULT" - - // Maximum allowed depth when recursively substituing variable names. - _DEPTH_VALUES = 99 - _VERSION = "1.33.0" -) - -// Version returns current package version literal. -func Version() string { - return _VERSION -} - -var ( - // Delimiter to determine or compose a new line. - // This variable will be changed to "\r\n" automatically on Windows - // at package init time. - LineBreak = "\n" - - // Variable regexp pattern: %(variable)s - varPattern = regexp.MustCompile(`%\(([^\)]+)\)s`) - - // Indicate whether to align "=" sign with spaces to produce pretty output - // or reduce all possible spaces for compact format. - PrettyFormat = true - - // Explicitly write DEFAULT section header - DefaultHeader = false - - // Indicate whether to put a line between sections - PrettySection = true -) - -func init() { - if runtime.GOOS == "windows" { - LineBreak = "\r\n" - } -} - -func inSlice(str string, s []string) bool { - for _, v := range s { - if str == v { - return true - } - } - return false -} - -// dataSource is an interface that returns object which can be read and closed. -type dataSource interface { - ReadCloser() (io.ReadCloser, error) -} - -// sourceFile represents an object that contains content on the local file system. -type sourceFile struct { - name string -} - -func (s sourceFile) ReadCloser() (_ io.ReadCloser, err error) { - return os.Open(s.name) -} - -// sourceData represents an object that contains content in memory. -type sourceData struct { - data []byte -} - -func (s *sourceData) ReadCloser() (io.ReadCloser, error) { - return ioutil.NopCloser(bytes.NewReader(s.data)), nil -} - -// sourceReadCloser represents an input stream with Close method. -type sourceReadCloser struct { - reader io.ReadCloser -} - -func (s *sourceReadCloser) ReadCloser() (io.ReadCloser, error) { - return s.reader, nil -} - -func parseDataSource(source interface{}) (dataSource, error) { - switch s := source.(type) { - case string: - return sourceFile{s}, nil - case []byte: - return &sourceData{s}, nil - case io.ReadCloser: - return &sourceReadCloser{s}, nil - default: - return nil, fmt.Errorf("error parsing data source: unknown type '%s'", s) - } -} - -type LoadOptions struct { - // Loose indicates whether the parser should ignore nonexistent files or return error. - Loose bool - // Insensitive indicates whether the parser forces all section and key names to lowercase. - Insensitive bool - // IgnoreContinuation indicates whether to ignore continuation lines while parsing. - IgnoreContinuation bool - // IgnoreInlineComment indicates whether to ignore comments at the end of value and treat it as part of value. - IgnoreInlineComment bool - // AllowBooleanKeys indicates whether to allow boolean type keys or treat as value is missing. - // This type of keys are mostly used in my.cnf. - AllowBooleanKeys bool - // AllowShadows indicates whether to keep track of keys with same name under same section. - AllowShadows bool - // AllowNestedValues indicates whether to allow AWS-like nested values. - // Docs: http://docs.aws.amazon.com/cli/latest/topic/config-vars.html#nested-values - AllowNestedValues bool - // UnescapeValueDoubleQuotes indicates whether to unescape double quotes inside value to regular format - // when value is surrounded by double quotes, e.g. key="a \"value\"" => key=a "value" - UnescapeValueDoubleQuotes bool - // UnescapeValueCommentSymbols indicates to unescape comment symbols (\# and \;) inside value to regular format - // when value is NOT surrounded by any quotes. - // Note: UNSTABLE, behavior might change to only unescape inside double quotes but may noy necessary at all. - UnescapeValueCommentSymbols bool - // Some INI formats allow group blocks that store a block of raw content that doesn't otherwise - // conform to key/value pairs. Specify the names of those blocks here. - UnparseableSections []string -} - -func LoadSources(opts LoadOptions, source interface{}, others ...interface{}) (_ *File, err error) { - sources := make([]dataSource, len(others)+1) - sources[0], err = parseDataSource(source) - if err != nil { - return nil, err - } - for i := range others { - sources[i+1], err = parseDataSource(others[i]) - if err != nil { - return nil, err - } - } - f := newFile(sources, opts) - if err = f.Reload(); err != nil { - return nil, err - } - return f, nil -} - -// Load loads and parses from INI data sources. -// Arguments can be mixed of file name with string type, or raw data in []byte. -// It will return error if list contains nonexistent files. -func Load(source interface{}, others ...interface{}) (*File, error) { - return LoadSources(LoadOptions{}, source, others...) -} - -// LooseLoad has exactly same functionality as Load function -// except it ignores nonexistent files instead of returning error. -func LooseLoad(source interface{}, others ...interface{}) (*File, error) { - return LoadSources(LoadOptions{Loose: true}, source, others...) -} - -// InsensitiveLoad has exactly same functionality as Load function -// except it forces all section and key names to be lowercased. -func InsensitiveLoad(source interface{}, others ...interface{}) (*File, error) { - return LoadSources(LoadOptions{Insensitive: true}, source, others...) -} - -// InsensitiveLoad has exactly same functionality as Load function -// except it allows have shadow keys. -func ShadowLoad(source interface{}, others ...interface{}) (*File, error) { - return LoadSources(LoadOptions{AllowShadows: true}, source, others...) -} diff --git a/vendor/github.com/go-ini/ini/key.go b/vendor/github.com/go-ini/ini/key.go deleted file mode 100644 index 7c8566a1b4c..00000000000 --- a/vendor/github.com/go-ini/ini/key.go +++ /dev/null @@ -1,751 +0,0 @@ -// Copyright 2014 Unknwon -// -// 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 ini - -import ( - "bytes" - "errors" - "fmt" - "strconv" - "strings" - "time" -) - -// Key represents a key under a section. -type Key struct { - s *Section - Comment string - name string - value string - isAutoIncrement bool - isBooleanType bool - - isShadow bool - shadows []*Key - - nestedValues []string -} - -// newKey simply return a key object with given values. -func newKey(s *Section, name, val string) *Key { - return &Key{ - s: s, - name: name, - value: val, - } -} - -func (k *Key) addShadow(val string) error { - if k.isShadow { - return errors.New("cannot add shadow to another shadow key") - } else if k.isAutoIncrement || k.isBooleanType { - return errors.New("cannot add shadow to auto-increment or boolean key") - } - - shadow := newKey(k.s, k.name, val) - shadow.isShadow = true - k.shadows = append(k.shadows, shadow) - return nil -} - -// AddShadow adds a new shadow key to itself. -func (k *Key) AddShadow(val string) error { - if !k.s.f.options.AllowShadows { - return errors.New("shadow key is not allowed") - } - return k.addShadow(val) -} - -func (k *Key) addNestedValue(val string) error { - if k.isAutoIncrement || k.isBooleanType { - return errors.New("cannot add nested value to auto-increment or boolean key") - } - - k.nestedValues = append(k.nestedValues, val) - return nil -} - -func (k *Key) AddNestedValue(val string) error { - if !k.s.f.options.AllowNestedValues { - return errors.New("nested value is not allowed") - } - return k.addNestedValue(val) -} - -// ValueMapper represents a mapping function for values, e.g. os.ExpandEnv -type ValueMapper func(string) string - -// Name returns name of key. -func (k *Key) Name() string { - return k.name -} - -// Value returns raw value of key for performance purpose. -func (k *Key) Value() string { - return k.value -} - -// ValueWithShadows returns raw values of key and its shadows if any. -func (k *Key) ValueWithShadows() []string { - if len(k.shadows) == 0 { - return []string{k.value} - } - vals := make([]string, len(k.shadows)+1) - vals[0] = k.value - for i := range k.shadows { - vals[i+1] = k.shadows[i].value - } - return vals -} - -// NestedValues returns nested values stored in the key. -// It is possible returned value is nil if no nested values stored in the key. -func (k *Key) NestedValues() []string { - return k.nestedValues -} - -// transformValue takes a raw value and transforms to its final string. -func (k *Key) transformValue(val string) string { - if k.s.f.ValueMapper != nil { - val = k.s.f.ValueMapper(val) - } - - // Fail-fast if no indicate char found for recursive value - if !strings.Contains(val, "%") { - return val - } - for i := 0; i < _DEPTH_VALUES; i++ { - vr := varPattern.FindString(val) - if len(vr) == 0 { - break - } - - // Take off leading '%(' and trailing ')s'. - noption := strings.TrimLeft(vr, "%(") - noption = strings.TrimRight(noption, ")s") - - // Search in the same section. - nk, err := k.s.GetKey(noption) - if err != nil || k == nk { - // Search again in default section. - nk, _ = k.s.f.Section("").GetKey(noption) - } - - // Substitute by new value and take off leading '%(' and trailing ')s'. - val = strings.Replace(val, vr, nk.value, -1) - } - return val -} - -// String returns string representation of value. -func (k *Key) String() string { - return k.transformValue(k.value) -} - -// Validate accepts a validate function which can -// return modifed result as key value. -func (k *Key) Validate(fn func(string) string) string { - return fn(k.String()) -} - -// parseBool returns the boolean value represented by the string. -// -// It accepts 1, t, T, TRUE, true, True, YES, yes, Yes, y, ON, on, On, -// 0, f, F, FALSE, false, False, NO, no, No, n, OFF, off, Off. -// Any other value returns an error. -func parseBool(str string) (value bool, err error) { - switch str { - case "1", "t", "T", "true", "TRUE", "True", "YES", "yes", "Yes", "y", "ON", "on", "On": - return true, nil - case "0", "f", "F", "false", "FALSE", "False", "NO", "no", "No", "n", "OFF", "off", "Off": - return false, nil - } - return false, fmt.Errorf("parsing \"%s\": invalid syntax", str) -} - -// Bool returns bool type value. -func (k *Key) Bool() (bool, error) { - return parseBool(k.String()) -} - -// Float64 returns float64 type value. -func (k *Key) Float64() (float64, error) { - return strconv.ParseFloat(k.String(), 64) -} - -// Int returns int type value. -func (k *Key) Int() (int, error) { - return strconv.Atoi(k.String()) -} - -// Int64 returns int64 type value. -func (k *Key) Int64() (int64, error) { - return strconv.ParseInt(k.String(), 10, 64) -} - -// Uint returns uint type valued. -func (k *Key) Uint() (uint, error) { - u, e := strconv.ParseUint(k.String(), 10, 64) - return uint(u), e -} - -// Uint64 returns uint64 type value. -func (k *Key) Uint64() (uint64, error) { - return strconv.ParseUint(k.String(), 10, 64) -} - -// Duration returns time.Duration type value. -func (k *Key) Duration() (time.Duration, error) { - return time.ParseDuration(k.String()) -} - -// TimeFormat parses with given format and returns time.Time type value. -func (k *Key) TimeFormat(format string) (time.Time, error) { - return time.Parse(format, k.String()) -} - -// Time parses with RFC3339 format and returns time.Time type value. -func (k *Key) Time() (time.Time, error) { - return k.TimeFormat(time.RFC3339) -} - -// MustString returns default value if key value is empty. -func (k *Key) MustString(defaultVal string) string { - val := k.String() - if len(val) == 0 { - k.value = defaultVal - return defaultVal - } - return val -} - -// MustBool always returns value without error, -// it returns false if error occurs. -func (k *Key) MustBool(defaultVal ...bool) bool { - val, err := k.Bool() - if len(defaultVal) > 0 && err != nil { - k.value = strconv.FormatBool(defaultVal[0]) - return defaultVal[0] - } - return val -} - -// MustFloat64 always returns value without error, -// it returns 0.0 if error occurs. -func (k *Key) MustFloat64(defaultVal ...float64) float64 { - val, err := k.Float64() - if len(defaultVal) > 0 && err != nil { - k.value = strconv.FormatFloat(defaultVal[0], 'f', -1, 64) - return defaultVal[0] - } - return val -} - -// MustInt always returns value without error, -// it returns 0 if error occurs. -func (k *Key) MustInt(defaultVal ...int) int { - val, err := k.Int() - if len(defaultVal) > 0 && err != nil { - k.value = strconv.FormatInt(int64(defaultVal[0]), 10) - return defaultVal[0] - } - return val -} - -// MustInt64 always returns value without error, -// it returns 0 if error occurs. -func (k *Key) MustInt64(defaultVal ...int64) int64 { - val, err := k.Int64() - if len(defaultVal) > 0 && err != nil { - k.value = strconv.FormatInt(defaultVal[0], 10) - return defaultVal[0] - } - return val -} - -// MustUint always returns value without error, -// it returns 0 if error occurs. -func (k *Key) MustUint(defaultVal ...uint) uint { - val, err := k.Uint() - if len(defaultVal) > 0 && err != nil { - k.value = strconv.FormatUint(uint64(defaultVal[0]), 10) - return defaultVal[0] - } - return val -} - -// MustUint64 always returns value without error, -// it returns 0 if error occurs. -func (k *Key) MustUint64(defaultVal ...uint64) uint64 { - val, err := k.Uint64() - if len(defaultVal) > 0 && err != nil { - k.value = strconv.FormatUint(defaultVal[0], 10) - return defaultVal[0] - } - return val -} - -// MustDuration always returns value without error, -// it returns zero value if error occurs. -func (k *Key) MustDuration(defaultVal ...time.Duration) time.Duration { - val, err := k.Duration() - if len(defaultVal) > 0 && err != nil { - k.value = defaultVal[0].String() - return defaultVal[0] - } - return val -} - -// MustTimeFormat always parses with given format and returns value without error, -// it returns zero value if error occurs. -func (k *Key) MustTimeFormat(format string, defaultVal ...time.Time) time.Time { - val, err := k.TimeFormat(format) - if len(defaultVal) > 0 && err != nil { - k.value = defaultVal[0].Format(format) - return defaultVal[0] - } - return val -} - -// MustTime always parses with RFC3339 format and returns value without error, -// it returns zero value if error occurs. -func (k *Key) MustTime(defaultVal ...time.Time) time.Time { - return k.MustTimeFormat(time.RFC3339, defaultVal...) -} - -// In always returns value without error, -// it returns default value if error occurs or doesn't fit into candidates. -func (k *Key) In(defaultVal string, candidates []string) string { - val := k.String() - for _, cand := range candidates { - if val == cand { - return val - } - } - return defaultVal -} - -// InFloat64 always returns value without error, -// it returns default value if error occurs or doesn't fit into candidates. -func (k *Key) InFloat64(defaultVal float64, candidates []float64) float64 { - val := k.MustFloat64() - for _, cand := range candidates { - if val == cand { - return val - } - } - return defaultVal -} - -// InInt always returns value without error, -// it returns default value if error occurs or doesn't fit into candidates. -func (k *Key) InInt(defaultVal int, candidates []int) int { - val := k.MustInt() - for _, cand := range candidates { - if val == cand { - return val - } - } - return defaultVal -} - -// InInt64 always returns value without error, -// it returns default value if error occurs or doesn't fit into candidates. -func (k *Key) InInt64(defaultVal int64, candidates []int64) int64 { - val := k.MustInt64() - for _, cand := range candidates { - if val == cand { - return val - } - } - return defaultVal -} - -// InUint always returns value without error, -// it returns default value if error occurs or doesn't fit into candidates. -func (k *Key) InUint(defaultVal uint, candidates []uint) uint { - val := k.MustUint() - for _, cand := range candidates { - if val == cand { - return val - } - } - return defaultVal -} - -// InUint64 always returns value without error, -// it returns default value if error occurs or doesn't fit into candidates. -func (k *Key) InUint64(defaultVal uint64, candidates []uint64) uint64 { - val := k.MustUint64() - for _, cand := range candidates { - if val == cand { - return val - } - } - return defaultVal -} - -// InTimeFormat always parses with given format and returns value without error, -// it returns default value if error occurs or doesn't fit into candidates. -func (k *Key) InTimeFormat(format string, defaultVal time.Time, candidates []time.Time) time.Time { - val := k.MustTimeFormat(format) - for _, cand := range candidates { - if val == cand { - return val - } - } - return defaultVal -} - -// InTime always parses with RFC3339 format and returns value without error, -// it returns default value if error occurs or doesn't fit into candidates. -func (k *Key) InTime(defaultVal time.Time, candidates []time.Time) time.Time { - return k.InTimeFormat(time.RFC3339, defaultVal, candidates) -} - -// RangeFloat64 checks if value is in given range inclusively, -// and returns default value if it's not. -func (k *Key) RangeFloat64(defaultVal, min, max float64) float64 { - val := k.MustFloat64() - if val < min || val > max { - return defaultVal - } - return val -} - -// RangeInt checks if value is in given range inclusively, -// and returns default value if it's not. -func (k *Key) RangeInt(defaultVal, min, max int) int { - val := k.MustInt() - if val < min || val > max { - return defaultVal - } - return val -} - -// RangeInt64 checks if value is in given range inclusively, -// and returns default value if it's not. -func (k *Key) RangeInt64(defaultVal, min, max int64) int64 { - val := k.MustInt64() - if val < min || val > max { - return defaultVal - } - return val -} - -// RangeTimeFormat checks if value with given format is in given range inclusively, -// and returns default value if it's not. -func (k *Key) RangeTimeFormat(format string, defaultVal, min, max time.Time) time.Time { - val := k.MustTimeFormat(format) - if val.Unix() < min.Unix() || val.Unix() > max.Unix() { - return defaultVal - } - return val -} - -// RangeTime checks if value with RFC3339 format is in given range inclusively, -// and returns default value if it's not. -func (k *Key) RangeTime(defaultVal, min, max time.Time) time.Time { - return k.RangeTimeFormat(time.RFC3339, defaultVal, min, max) -} - -// Strings returns list of string divided by given delimiter. -func (k *Key) Strings(delim string) []string { - str := k.String() - if len(str) == 0 { - return []string{} - } - - runes := []rune(str) - vals := make([]string, 0, 2) - var buf bytes.Buffer - escape := false - idx := 0 - for { - if escape { - escape = false - if runes[idx] != '\\' && !strings.HasPrefix(string(runes[idx:]), delim) { - buf.WriteRune('\\') - } - buf.WriteRune(runes[idx]) - } else { - if runes[idx] == '\\' { - escape = true - } else if strings.HasPrefix(string(runes[idx:]), delim) { - idx += len(delim) - 1 - vals = append(vals, strings.TrimSpace(buf.String())) - buf.Reset() - } else { - buf.WriteRune(runes[idx]) - } - } - idx += 1 - if idx == len(runes) { - break - } - } - - if buf.Len() > 0 { - vals = append(vals, strings.TrimSpace(buf.String())) - } - - return vals -} - -// StringsWithShadows returns list of string divided by given delimiter. -// Shadows will also be appended if any. -func (k *Key) StringsWithShadows(delim string) []string { - vals := k.ValueWithShadows() - results := make([]string, 0, len(vals)*2) - for i := range vals { - if len(vals) == 0 { - continue - } - - results = append(results, strings.Split(vals[i], delim)...) - } - - for i := range results { - results[i] = k.transformValue(strings.TrimSpace(results[i])) - } - return results -} - -// Float64s returns list of float64 divided by given delimiter. Any invalid input will be treated as zero value. -func (k *Key) Float64s(delim string) []float64 { - vals, _ := k.parseFloat64s(k.Strings(delim), true, false) - return vals -} - -// Ints returns list of int divided by given delimiter. Any invalid input will be treated as zero value. -func (k *Key) Ints(delim string) []int { - vals, _ := k.parseInts(k.Strings(delim), true, false) - return vals -} - -// Int64s returns list of int64 divided by given delimiter. Any invalid input will be treated as zero value. -func (k *Key) Int64s(delim string) []int64 { - vals, _ := k.parseInt64s(k.Strings(delim), true, false) - return vals -} - -// Uints returns list of uint divided by given delimiter. Any invalid input will be treated as zero value. -func (k *Key) Uints(delim string) []uint { - vals, _ := k.parseUints(k.Strings(delim), true, false) - return vals -} - -// Uint64s returns list of uint64 divided by given delimiter. Any invalid input will be treated as zero value. -func (k *Key) Uint64s(delim string) []uint64 { - vals, _ := k.parseUint64s(k.Strings(delim), true, false) - return vals -} - -// TimesFormat parses with given format and returns list of time.Time divided by given delimiter. -// Any invalid input will be treated as zero value (0001-01-01 00:00:00 +0000 UTC). -func (k *Key) TimesFormat(format, delim string) []time.Time { - vals, _ := k.parseTimesFormat(format, k.Strings(delim), true, false) - return vals -} - -// Times parses with RFC3339 format and returns list of time.Time divided by given delimiter. -// Any invalid input will be treated as zero value (0001-01-01 00:00:00 +0000 UTC). -func (k *Key) Times(delim string) []time.Time { - return k.TimesFormat(time.RFC3339, delim) -} - -// ValidFloat64s returns list of float64 divided by given delimiter. If some value is not float, then -// it will not be included to result list. -func (k *Key) ValidFloat64s(delim string) []float64 { - vals, _ := k.parseFloat64s(k.Strings(delim), false, false) - return vals -} - -// ValidInts returns list of int divided by given delimiter. If some value is not integer, then it will -// not be included to result list. -func (k *Key) ValidInts(delim string) []int { - vals, _ := k.parseInts(k.Strings(delim), false, false) - return vals -} - -// ValidInt64s returns list of int64 divided by given delimiter. If some value is not 64-bit integer, -// then it will not be included to result list. -func (k *Key) ValidInt64s(delim string) []int64 { - vals, _ := k.parseInt64s(k.Strings(delim), false, false) - return vals -} - -// ValidUints returns list of uint divided by given delimiter. If some value is not unsigned integer, -// then it will not be included to result list. -func (k *Key) ValidUints(delim string) []uint { - vals, _ := k.parseUints(k.Strings(delim), false, false) - return vals -} - -// ValidUint64s returns list of uint64 divided by given delimiter. If some value is not 64-bit unsigned -// integer, then it will not be included to result list. -func (k *Key) ValidUint64s(delim string) []uint64 { - vals, _ := k.parseUint64s(k.Strings(delim), false, false) - return vals -} - -// ValidTimesFormat parses with given format and returns list of time.Time divided by given delimiter. -func (k *Key) ValidTimesFormat(format, delim string) []time.Time { - vals, _ := k.parseTimesFormat(format, k.Strings(delim), false, false) - return vals -} - -// ValidTimes parses with RFC3339 format and returns list of time.Time divided by given delimiter. -func (k *Key) ValidTimes(delim string) []time.Time { - return k.ValidTimesFormat(time.RFC3339, delim) -} - -// StrictFloat64s returns list of float64 divided by given delimiter or error on first invalid input. -func (k *Key) StrictFloat64s(delim string) ([]float64, error) { - return k.parseFloat64s(k.Strings(delim), false, true) -} - -// StrictInts returns list of int divided by given delimiter or error on first invalid input. -func (k *Key) StrictInts(delim string) ([]int, error) { - return k.parseInts(k.Strings(delim), false, true) -} - -// StrictInt64s returns list of int64 divided by given delimiter or error on first invalid input. -func (k *Key) StrictInt64s(delim string) ([]int64, error) { - return k.parseInt64s(k.Strings(delim), false, true) -} - -// StrictUints returns list of uint divided by given delimiter or error on first invalid input. -func (k *Key) StrictUints(delim string) ([]uint, error) { - return k.parseUints(k.Strings(delim), false, true) -} - -// StrictUint64s returns list of uint64 divided by given delimiter or error on first invalid input. -func (k *Key) StrictUint64s(delim string) ([]uint64, error) { - return k.parseUint64s(k.Strings(delim), false, true) -} - -// StrictTimesFormat parses with given format and returns list of time.Time divided by given delimiter -// or error on first invalid input. -func (k *Key) StrictTimesFormat(format, delim string) ([]time.Time, error) { - return k.parseTimesFormat(format, k.Strings(delim), false, true) -} - -// StrictTimes parses with RFC3339 format and returns list of time.Time divided by given delimiter -// or error on first invalid input. -func (k *Key) StrictTimes(delim string) ([]time.Time, error) { - return k.StrictTimesFormat(time.RFC3339, delim) -} - -// parseFloat64s transforms strings to float64s. -func (k *Key) parseFloat64s(strs []string, addInvalid, returnOnInvalid bool) ([]float64, error) { - vals := make([]float64, 0, len(strs)) - for _, str := range strs { - val, err := strconv.ParseFloat(str, 64) - if err != nil && returnOnInvalid { - return nil, err - } - if err == nil || addInvalid { - vals = append(vals, val) - } - } - return vals, nil -} - -// parseInts transforms strings to ints. -func (k *Key) parseInts(strs []string, addInvalid, returnOnInvalid bool) ([]int, error) { - vals := make([]int, 0, len(strs)) - for _, str := range strs { - val, err := strconv.Atoi(str) - if err != nil && returnOnInvalid { - return nil, err - } - if err == nil || addInvalid { - vals = append(vals, val) - } - } - return vals, nil -} - -// parseInt64s transforms strings to int64s. -func (k *Key) parseInt64s(strs []string, addInvalid, returnOnInvalid bool) ([]int64, error) { - vals := make([]int64, 0, len(strs)) - for _, str := range strs { - val, err := strconv.ParseInt(str, 10, 64) - if err != nil && returnOnInvalid { - return nil, err - } - if err == nil || addInvalid { - vals = append(vals, val) - } - } - return vals, nil -} - -// parseUints transforms strings to uints. -func (k *Key) parseUints(strs []string, addInvalid, returnOnInvalid bool) ([]uint, error) { - vals := make([]uint, 0, len(strs)) - for _, str := range strs { - val, err := strconv.ParseUint(str, 10, 0) - if err != nil && returnOnInvalid { - return nil, err - } - if err == nil || addInvalid { - vals = append(vals, uint(val)) - } - } - return vals, nil -} - -// parseUint64s transforms strings to uint64s. -func (k *Key) parseUint64s(strs []string, addInvalid, returnOnInvalid bool) ([]uint64, error) { - vals := make([]uint64, 0, len(strs)) - for _, str := range strs { - val, err := strconv.ParseUint(str, 10, 64) - if err != nil && returnOnInvalid { - return nil, err - } - if err == nil || addInvalid { - vals = append(vals, val) - } - } - return vals, nil -} - -// parseTimesFormat transforms strings to times in given format. -func (k *Key) parseTimesFormat(format string, strs []string, addInvalid, returnOnInvalid bool) ([]time.Time, error) { - vals := make([]time.Time, 0, len(strs)) - for _, str := range strs { - val, err := time.Parse(format, str) - if err != nil && returnOnInvalid { - return nil, err - } - if err == nil || addInvalid { - vals = append(vals, val) - } - } - return vals, nil -} - -// SetValue changes key value. -func (k *Key) SetValue(v string) { - if k.s.f.BlockMode { - k.s.f.lock.Lock() - defer k.s.f.lock.Unlock() - } - - k.value = v - k.s.keysHash[k.name] = v -} diff --git a/vendor/github.com/go-ini/ini/parser.go b/vendor/github.com/go-ini/ini/parser.go deleted file mode 100644 index db3af8f0044..00000000000 --- a/vendor/github.com/go-ini/ini/parser.go +++ /dev/null @@ -1,401 +0,0 @@ -// Copyright 2015 Unknwon -// -// 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 ini - -import ( - "bufio" - "bytes" - "fmt" - "io" - "strconv" - "strings" - "unicode" -) - -type tokenType int - -const ( - _TOKEN_INVALID tokenType = iota - _TOKEN_COMMENT - _TOKEN_SECTION - _TOKEN_KEY -) - -type parser struct { - buf *bufio.Reader - isEOF bool - count int - comment *bytes.Buffer -} - -func newParser(r io.Reader) *parser { - return &parser{ - buf: bufio.NewReader(r), - count: 1, - comment: &bytes.Buffer{}, - } -} - -// BOM handles header of UTF-8, UTF-16 LE and UTF-16 BE's BOM format. -// http://en.wikipedia.org/wiki/Byte_order_mark#Representations_of_byte_order_marks_by_encoding -func (p *parser) BOM() error { - mask, err := p.buf.Peek(2) - if err != nil && err != io.EOF { - return err - } else if len(mask) < 2 { - return nil - } - - switch { - case mask[0] == 254 && mask[1] == 255: - fallthrough - case mask[0] == 255 && mask[1] == 254: - p.buf.Read(mask) - case mask[0] == 239 && mask[1] == 187: - mask, err := p.buf.Peek(3) - if err != nil && err != io.EOF { - return err - } else if len(mask) < 3 { - return nil - } - if mask[2] == 191 { - p.buf.Read(mask) - } - } - return nil -} - -func (p *parser) readUntil(delim byte) ([]byte, error) { - data, err := p.buf.ReadBytes(delim) - if err != nil { - if err == io.EOF { - p.isEOF = true - } else { - return nil, err - } - } - return data, nil -} - -func cleanComment(in []byte) ([]byte, bool) { - i := bytes.IndexAny(in, "#;") - if i == -1 { - return nil, false - } - return in[i:], true -} - -func readKeyName(in []byte) (string, int, error) { - line := string(in) - - // Check if key name surrounded by quotes. - var keyQuote string - if line[0] == '"' { - if len(line) > 6 && string(line[0:3]) == `"""` { - keyQuote = `"""` - } else { - keyQuote = `"` - } - } else if line[0] == '`' { - keyQuote = "`" - } - - // Get out key name - endIdx := -1 - if len(keyQuote) > 0 { - startIdx := len(keyQuote) - // FIXME: fail case -> """"""name"""=value - pos := strings.Index(line[startIdx:], keyQuote) - if pos == -1 { - return "", -1, fmt.Errorf("missing closing key quote: %s", line) - } - pos += startIdx - - // Find key-value delimiter - i := strings.IndexAny(line[pos+startIdx:], "=:") - if i < 0 { - return "", -1, ErrDelimiterNotFound{line} - } - endIdx = pos + i - return strings.TrimSpace(line[startIdx:pos]), endIdx + startIdx + 1, nil - } - - endIdx = strings.IndexAny(line, "=:") - if endIdx < 0 { - return "", -1, ErrDelimiterNotFound{line} - } - return strings.TrimSpace(line[0:endIdx]), endIdx + 1, nil -} - -func (p *parser) readMultilines(line, val, valQuote string) (string, error) { - for { - data, err := p.readUntil('\n') - if err != nil { - return "", err - } - next := string(data) - - pos := strings.LastIndex(next, valQuote) - if pos > -1 { - val += next[:pos] - - comment, has := cleanComment([]byte(next[pos:])) - if has { - p.comment.Write(bytes.TrimSpace(comment)) - } - break - } - val += next - if p.isEOF { - return "", fmt.Errorf("missing closing key quote from '%s' to '%s'", line, next) - } - } - return val, nil -} - -func (p *parser) readContinuationLines(val string) (string, error) { - for { - data, err := p.readUntil('\n') - if err != nil { - return "", err - } - next := strings.TrimSpace(string(data)) - - if len(next) == 0 { - break - } - val += next - if val[len(val)-1] != '\\' { - break - } - val = val[:len(val)-1] - } - return val, nil -} - -// hasSurroundedQuote check if and only if the first and last characters -// are quotes \" or \'. -// It returns false if any other parts also contain same kind of quotes. -func hasSurroundedQuote(in string, quote byte) bool { - return len(in) >= 2 && in[0] == quote && in[len(in)-1] == quote && - strings.IndexByte(in[1:], quote) == len(in)-2 -} - -func (p *parser) readValue(in []byte, - ignoreContinuation, ignoreInlineComment, unescapeValueDoubleQuotes, unescapeValueCommentSymbols bool) (string, error) { - - line := strings.TrimLeftFunc(string(in), unicode.IsSpace) - if len(line) == 0 { - return "", nil - } - - var valQuote string - if len(line) > 3 && string(line[0:3]) == `"""` { - valQuote = `"""` - } else if line[0] == '`' { - valQuote = "`" - } else if unescapeValueDoubleQuotes && line[0] == '"' { - valQuote = `"` - } - - if len(valQuote) > 0 { - startIdx := len(valQuote) - pos := strings.LastIndex(line[startIdx:], valQuote) - // Check for multi-line value - if pos == -1 { - return p.readMultilines(line, line[startIdx:], valQuote) - } - - if unescapeValueDoubleQuotes && valQuote == `"` { - return strings.Replace(line[startIdx:pos+startIdx], `\"`, `"`, -1), nil - } - return line[startIdx : pos+startIdx], nil - } - - // Won't be able to reach here if value only contains whitespace - line = strings.TrimSpace(line) - - // Check continuation lines when desired - if !ignoreContinuation && line[len(line)-1] == '\\' { - return p.readContinuationLines(line[:len(line)-1]) - } - - // Check if ignore inline comment - if !ignoreInlineComment { - i := strings.IndexAny(line, "#;") - if i > -1 { - p.comment.WriteString(line[i:]) - line = strings.TrimSpace(line[:i]) - } - } - - // Trim single and double quotes - if hasSurroundedQuote(line, '\'') || - hasSurroundedQuote(line, '"') { - line = line[1 : len(line)-1] - } else if len(valQuote) == 0 && unescapeValueCommentSymbols { - if strings.Contains(line, `\;`) { - line = strings.Replace(line, `\;`, ";", -1) - } - if strings.Contains(line, `\#`) { - line = strings.Replace(line, `\#`, "#", -1) - } - } - return line, nil -} - -// parse parses data through an io.Reader. -func (f *File) parse(reader io.Reader) (err error) { - p := newParser(reader) - if err = p.BOM(); err != nil { - return fmt.Errorf("BOM: %v", err) - } - - // Ignore error because default section name is never empty string. - name := DEFAULT_SECTION - if f.options.Insensitive { - name = strings.ToLower(DEFAULT_SECTION) - } - section, _ := f.NewSection(name) - - // This "last" is not strictly equivalent to "previous one" if current key is not the first nested key - var isLastValueEmpty bool - var lastRegularKey *Key - - var line []byte - var inUnparseableSection bool - for !p.isEOF { - line, err = p.readUntil('\n') - if err != nil { - return err - } - - if f.options.AllowNestedValues && - isLastValueEmpty && len(line) > 0 { - if line[0] == ' ' || line[0] == '\t' { - lastRegularKey.addNestedValue(string(bytes.TrimSpace(line))) - continue - } - } - - line = bytes.TrimLeftFunc(line, unicode.IsSpace) - if len(line) == 0 { - continue - } - - // Comments - if line[0] == '#' || line[0] == ';' { - // Note: we do not care ending line break, - // it is needed for adding second line, - // so just clean it once at the end when set to value. - p.comment.Write(line) - continue - } - - // Section - if line[0] == '[' { - // Read to the next ']' (TODO: support quoted strings) - // TODO(unknwon): use LastIndexByte when stop supporting Go1.4 - closeIdx := bytes.LastIndex(line, []byte("]")) - if closeIdx == -1 { - return fmt.Errorf("unclosed section: %s", line) - } - - name := string(line[1:closeIdx]) - section, err = f.NewSection(name) - if err != nil { - return err - } - - comment, has := cleanComment(line[closeIdx+1:]) - if has { - p.comment.Write(comment) - } - - section.Comment = strings.TrimSpace(p.comment.String()) - - // Reset aotu-counter and comments - p.comment.Reset() - p.count = 1 - - inUnparseableSection = false - for i := range f.options.UnparseableSections { - if f.options.UnparseableSections[i] == name || - (f.options.Insensitive && strings.ToLower(f.options.UnparseableSections[i]) == strings.ToLower(name)) { - inUnparseableSection = true - continue - } - } - continue - } - - if inUnparseableSection { - section.isRawSection = true - section.rawBody += string(line) - continue - } - - kname, offset, err := readKeyName(line) - if err != nil { - // Treat as boolean key when desired, and whole line is key name. - if IsErrDelimiterNotFound(err) && f.options.AllowBooleanKeys { - kname, err := p.readValue(line, - f.options.IgnoreContinuation, - f.options.IgnoreInlineComment, - f.options.UnescapeValueDoubleQuotes, - f.options.UnescapeValueCommentSymbols) - if err != nil { - return err - } - key, err := section.NewBooleanKey(kname) - if err != nil { - return err - } - key.Comment = strings.TrimSpace(p.comment.String()) - p.comment.Reset() - continue - } - return err - } - - // Auto increment. - isAutoIncr := false - if kname == "-" { - isAutoIncr = true - kname = "#" + strconv.Itoa(p.count) - p.count++ - } - - value, err := p.readValue(line[offset:], - f.options.IgnoreContinuation, - f.options.IgnoreInlineComment, - f.options.UnescapeValueDoubleQuotes, - f.options.UnescapeValueCommentSymbols) - if err != nil { - return err - } - isLastValueEmpty = len(value) == 0 - - key, err := section.NewKey(kname, value) - if err != nil { - return err - } - key.isAutoIncrement = isAutoIncr - key.Comment = strings.TrimSpace(p.comment.String()) - p.comment.Reset() - lastRegularKey = key - } - return nil -} diff --git a/vendor/github.com/go-ini/ini/section.go b/vendor/github.com/go-ini/ini/section.go deleted file mode 100644 index d8a40261920..00000000000 --- a/vendor/github.com/go-ini/ini/section.go +++ /dev/null @@ -1,257 +0,0 @@ -// Copyright 2014 Unknwon -// -// 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 ini - -import ( - "errors" - "fmt" - "strings" -) - -// Section represents a config section. -type Section struct { - f *File - Comment string - name string - keys map[string]*Key - keyList []string - keysHash map[string]string - - isRawSection bool - rawBody string -} - -func newSection(f *File, name string) *Section { - return &Section{ - f: f, - name: name, - keys: make(map[string]*Key), - keyList: make([]string, 0, 10), - keysHash: make(map[string]string), - } -} - -// Name returns name of Section. -func (s *Section) Name() string { - return s.name -} - -// Body returns rawBody of Section if the section was marked as unparseable. -// It still follows the other rules of the INI format surrounding leading/trailing whitespace. -func (s *Section) Body() string { - return strings.TrimSpace(s.rawBody) -} - -// SetBody updates body content only if section is raw. -func (s *Section) SetBody(body string) { - if !s.isRawSection { - return - } - s.rawBody = body -} - -// NewKey creates a new key to given section. -func (s *Section) NewKey(name, val string) (*Key, error) { - if len(name) == 0 { - return nil, errors.New("error creating new key: empty key name") - } else if s.f.options.Insensitive { - name = strings.ToLower(name) - } - - if s.f.BlockMode { - s.f.lock.Lock() - defer s.f.lock.Unlock() - } - - if inSlice(name, s.keyList) { - if s.f.options.AllowShadows { - if err := s.keys[name].addShadow(val); err != nil { - return nil, err - } - } else { - s.keys[name].value = val - } - return s.keys[name], nil - } - - s.keyList = append(s.keyList, name) - s.keys[name] = newKey(s, name, val) - s.keysHash[name] = val - return s.keys[name], nil -} - -// NewBooleanKey creates a new boolean type key to given section. -func (s *Section) NewBooleanKey(name string) (*Key, error) { - key, err := s.NewKey(name, "true") - if err != nil { - return nil, err - } - - key.isBooleanType = true - return key, nil -} - -// GetKey returns key in section by given name. -func (s *Section) GetKey(name string) (*Key, error) { - // FIXME: change to section level lock? - if s.f.BlockMode { - s.f.lock.RLock() - } - if s.f.options.Insensitive { - name = strings.ToLower(name) - } - key := s.keys[name] - if s.f.BlockMode { - s.f.lock.RUnlock() - } - - if key == nil { - // Check if it is a child-section. - sname := s.name - for { - if i := strings.LastIndex(sname, "."); i > -1 { - sname = sname[:i] - sec, err := s.f.GetSection(sname) - if err != nil { - continue - } - return sec.GetKey(name) - } else { - break - } - } - return nil, fmt.Errorf("error when getting key of section '%s': key '%s' not exists", s.name, name) - } - return key, nil -} - -// HasKey returns true if section contains a key with given name. -func (s *Section) HasKey(name string) bool { - key, _ := s.GetKey(name) - return key != nil -} - -// Haskey is a backwards-compatible name for HasKey. -// TODO: delete me in v2 -func (s *Section) Haskey(name string) bool { - return s.HasKey(name) -} - -// HasValue returns true if section contains given raw value. -func (s *Section) HasValue(value string) bool { - if s.f.BlockMode { - s.f.lock.RLock() - defer s.f.lock.RUnlock() - } - - for _, k := range s.keys { - if value == k.value { - return true - } - } - return false -} - -// Key assumes named Key exists in section and returns a zero-value when not. -func (s *Section) Key(name string) *Key { - key, err := s.GetKey(name) - if err != nil { - // It's OK here because the only possible error is empty key name, - // but if it's empty, this piece of code won't be executed. - key, _ = s.NewKey(name, "") - return key - } - return key -} - -// Keys returns list of keys of section. -func (s *Section) Keys() []*Key { - keys := make([]*Key, len(s.keyList)) - for i := range s.keyList { - keys[i] = s.Key(s.keyList[i]) - } - return keys -} - -// ParentKeys returns list of keys of parent section. -func (s *Section) ParentKeys() []*Key { - var parentKeys []*Key - sname := s.name - for { - if i := strings.LastIndex(sname, "."); i > -1 { - sname = sname[:i] - sec, err := s.f.GetSection(sname) - if err != nil { - continue - } - parentKeys = append(parentKeys, sec.Keys()...) - } else { - break - } - - } - return parentKeys -} - -// KeyStrings returns list of key names of section. -func (s *Section) KeyStrings() []string { - list := make([]string, len(s.keyList)) - copy(list, s.keyList) - return list -} - -// KeysHash returns keys hash consisting of names and values. -func (s *Section) KeysHash() map[string]string { - if s.f.BlockMode { - s.f.lock.RLock() - defer s.f.lock.RUnlock() - } - - hash := map[string]string{} - for key, value := range s.keysHash { - hash[key] = value - } - return hash -} - -// DeleteKey deletes a key from section. -func (s *Section) DeleteKey(name string) { - if s.f.BlockMode { - s.f.lock.Lock() - defer s.f.lock.Unlock() - } - - for i, k := range s.keyList { - if k == name { - s.keyList = append(s.keyList[:i], s.keyList[i+1:]...) - delete(s.keys, name) - return - } - } -} - -// ChildSections returns a list of child sections of current section. -// For example, "[parent.child1]" and "[parent.child12]" are child sections -// of section "[parent]". -func (s *Section) ChildSections() []*Section { - prefix := s.name + "." - children := make([]*Section, 0, 3) - for _, name := range s.f.sectionList { - if strings.HasPrefix(name, prefix) { - children = append(children, s.f.sections[name]) - } - } - return children -} diff --git a/vendor/github.com/go-ini/ini/struct.go b/vendor/github.com/go-ini/ini/struct.go deleted file mode 100644 index 9719dc6985a..00000000000 --- a/vendor/github.com/go-ini/ini/struct.go +++ /dev/null @@ -1,512 +0,0 @@ -// Copyright 2014 Unknwon -// -// 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 ini - -import ( - "bytes" - "errors" - "fmt" - "reflect" - "strings" - "time" - "unicode" -) - -// NameMapper represents a ini tag name mapper. -type NameMapper func(string) string - -// Built-in name getters. -var ( - // AllCapsUnderscore converts to format ALL_CAPS_UNDERSCORE. - AllCapsUnderscore NameMapper = func(raw string) string { - newstr := make([]rune, 0, len(raw)) - for i, chr := range raw { - if isUpper := 'A' <= chr && chr <= 'Z'; isUpper { - if i > 0 { - newstr = append(newstr, '_') - } - } - newstr = append(newstr, unicode.ToUpper(chr)) - } - return string(newstr) - } - // TitleUnderscore converts to format title_underscore. - TitleUnderscore NameMapper = func(raw string) string { - newstr := make([]rune, 0, len(raw)) - for i, chr := range raw { - if isUpper := 'A' <= chr && chr <= 'Z'; isUpper { - if i > 0 { - newstr = append(newstr, '_') - } - chr -= ('A' - 'a') - } - newstr = append(newstr, chr) - } - return string(newstr) - } -) - -func (s *Section) parseFieldName(raw, actual string) string { - if len(actual) > 0 { - return actual - } - if s.f.NameMapper != nil { - return s.f.NameMapper(raw) - } - return raw -} - -func parseDelim(actual string) string { - if len(actual) > 0 { - return actual - } - return "," -} - -var reflectTime = reflect.TypeOf(time.Now()).Kind() - -// setSliceWithProperType sets proper values to slice based on its type. -func setSliceWithProperType(key *Key, field reflect.Value, delim string, allowShadow, isStrict bool) error { - var strs []string - if allowShadow { - strs = key.StringsWithShadows(delim) - } else { - strs = key.Strings(delim) - } - - numVals := len(strs) - if numVals == 0 { - return nil - } - - var vals interface{} - var err error - - sliceOf := field.Type().Elem().Kind() - switch sliceOf { - case reflect.String: - vals = strs - case reflect.Int: - vals, err = key.parseInts(strs, true, false) - case reflect.Int64: - vals, err = key.parseInt64s(strs, true, false) - case reflect.Uint: - vals, err = key.parseUints(strs, true, false) - case reflect.Uint64: - vals, err = key.parseUint64s(strs, true, false) - case reflect.Float64: - vals, err = key.parseFloat64s(strs, true, false) - case reflectTime: - vals, err = key.parseTimesFormat(time.RFC3339, strs, true, false) - default: - return fmt.Errorf("unsupported type '[]%s'", sliceOf) - } - if err != nil && isStrict { - return err - } - - slice := reflect.MakeSlice(field.Type(), numVals, numVals) - for i := 0; i < numVals; i++ { - switch sliceOf { - case reflect.String: - slice.Index(i).Set(reflect.ValueOf(vals.([]string)[i])) - case reflect.Int: - slice.Index(i).Set(reflect.ValueOf(vals.([]int)[i])) - case reflect.Int64: - slice.Index(i).Set(reflect.ValueOf(vals.([]int64)[i])) - case reflect.Uint: - slice.Index(i).Set(reflect.ValueOf(vals.([]uint)[i])) - case reflect.Uint64: - slice.Index(i).Set(reflect.ValueOf(vals.([]uint64)[i])) - case reflect.Float64: - slice.Index(i).Set(reflect.ValueOf(vals.([]float64)[i])) - case reflectTime: - slice.Index(i).Set(reflect.ValueOf(vals.([]time.Time)[i])) - } - } - field.Set(slice) - return nil -} - -func wrapStrictError(err error, isStrict bool) error { - if isStrict { - return err - } - return nil -} - -// setWithProperType sets proper value to field based on its type, -// but it does not return error for failing parsing, -// because we want to use default value that is already assigned to strcut. -func setWithProperType(t reflect.Type, key *Key, field reflect.Value, delim string, allowShadow, isStrict bool) error { - switch t.Kind() { - case reflect.String: - if len(key.String()) == 0 { - return nil - } - field.SetString(key.String()) - case reflect.Bool: - boolVal, err := key.Bool() - if err != nil { - return wrapStrictError(err, isStrict) - } - field.SetBool(boolVal) - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - durationVal, err := key.Duration() - // Skip zero value - if err == nil && int64(durationVal) > 0 { - field.Set(reflect.ValueOf(durationVal)) - return nil - } - - intVal, err := key.Int64() - if err != nil { - return wrapStrictError(err, isStrict) - } - field.SetInt(intVal) - // byte is an alias for uint8, so supporting uint8 breaks support for byte - case reflect.Uint, reflect.Uint16, reflect.Uint32, reflect.Uint64: - durationVal, err := key.Duration() - // Skip zero value - if err == nil && int(durationVal) > 0 { - field.Set(reflect.ValueOf(durationVal)) - return nil - } - - uintVal, err := key.Uint64() - if err != nil { - return wrapStrictError(err, isStrict) - } - field.SetUint(uintVal) - - case reflect.Float32, reflect.Float64: - floatVal, err := key.Float64() - if err != nil { - return wrapStrictError(err, isStrict) - } - field.SetFloat(floatVal) - case reflectTime: - timeVal, err := key.Time() - if err != nil { - return wrapStrictError(err, isStrict) - } - field.Set(reflect.ValueOf(timeVal)) - case reflect.Slice: - return setSliceWithProperType(key, field, delim, allowShadow, isStrict) - default: - return fmt.Errorf("unsupported type '%s'", t) - } - return nil -} - -func parseTagOptions(tag string) (rawName string, omitEmpty bool, allowShadow bool) { - opts := strings.SplitN(tag, ",", 3) - rawName = opts[0] - if len(opts) > 1 { - omitEmpty = opts[1] == "omitempty" - } - if len(opts) > 2 { - allowShadow = opts[2] == "allowshadow" - } - return rawName, omitEmpty, allowShadow -} - -func (s *Section) mapTo(val reflect.Value, isStrict bool) error { - if val.Kind() == reflect.Ptr { - val = val.Elem() - } - typ := val.Type() - - for i := 0; i < typ.NumField(); i++ { - field := val.Field(i) - tpField := typ.Field(i) - - tag := tpField.Tag.Get("ini") - if tag == "-" { - continue - } - - rawName, _, allowShadow := parseTagOptions(tag) - fieldName := s.parseFieldName(tpField.Name, rawName) - if len(fieldName) == 0 || !field.CanSet() { - continue - } - - isAnonymous := tpField.Type.Kind() == reflect.Ptr && tpField.Anonymous - isStruct := tpField.Type.Kind() == reflect.Struct - if isAnonymous { - field.Set(reflect.New(tpField.Type.Elem())) - } - - if isAnonymous || isStruct { - if sec, err := s.f.GetSection(fieldName); err == nil { - if err = sec.mapTo(field, isStrict); err != nil { - return fmt.Errorf("error mapping field(%s): %v", fieldName, err) - } - continue - } - } - - if key, err := s.GetKey(fieldName); err == nil { - delim := parseDelim(tpField.Tag.Get("delim")) - if err = setWithProperType(tpField.Type, key, field, delim, allowShadow, isStrict); err != nil { - return fmt.Errorf("error mapping field(%s): %v", fieldName, err) - } - } - } - return nil -} - -// MapTo maps section to given struct. -func (s *Section) MapTo(v interface{}) error { - typ := reflect.TypeOf(v) - val := reflect.ValueOf(v) - if typ.Kind() == reflect.Ptr { - typ = typ.Elem() - val = val.Elem() - } else { - return errors.New("cannot map to non-pointer struct") - } - - return s.mapTo(val, false) -} - -// MapTo maps section to given struct in strict mode, -// which returns all possible error including value parsing error. -func (s *Section) StrictMapTo(v interface{}) error { - typ := reflect.TypeOf(v) - val := reflect.ValueOf(v) - if typ.Kind() == reflect.Ptr { - typ = typ.Elem() - val = val.Elem() - } else { - return errors.New("cannot map to non-pointer struct") - } - - return s.mapTo(val, true) -} - -// MapTo maps file to given struct. -func (f *File) MapTo(v interface{}) error { - return f.Section("").MapTo(v) -} - -// MapTo maps file to given struct in strict mode, -// which returns all possible error including value parsing error. -func (f *File) StrictMapTo(v interface{}) error { - return f.Section("").StrictMapTo(v) -} - -// MapTo maps data sources to given struct with name mapper. -func MapToWithMapper(v interface{}, mapper NameMapper, source interface{}, others ...interface{}) error { - cfg, err := Load(source, others...) - if err != nil { - return err - } - cfg.NameMapper = mapper - return cfg.MapTo(v) -} - -// StrictMapToWithMapper maps data sources to given struct with name mapper in strict mode, -// which returns all possible error including value parsing error. -func StrictMapToWithMapper(v interface{}, mapper NameMapper, source interface{}, others ...interface{}) error { - cfg, err := Load(source, others...) - if err != nil { - return err - } - cfg.NameMapper = mapper - return cfg.StrictMapTo(v) -} - -// MapTo maps data sources to given struct. -func MapTo(v, source interface{}, others ...interface{}) error { - return MapToWithMapper(v, nil, source, others...) -} - -// StrictMapTo maps data sources to given struct in strict mode, -// which returns all possible error including value parsing error. -func StrictMapTo(v, source interface{}, others ...interface{}) error { - return StrictMapToWithMapper(v, nil, source, others...) -} - -// reflectSliceWithProperType does the opposite thing as setSliceWithProperType. -func reflectSliceWithProperType(key *Key, field reflect.Value, delim string) error { - slice := field.Slice(0, field.Len()) - if field.Len() == 0 { - return nil - } - - var buf bytes.Buffer - sliceOf := field.Type().Elem().Kind() - for i := 0; i < field.Len(); i++ { - switch sliceOf { - case reflect.String: - buf.WriteString(slice.Index(i).String()) - case reflect.Int, reflect.Int64: - buf.WriteString(fmt.Sprint(slice.Index(i).Int())) - case reflect.Uint, reflect.Uint64: - buf.WriteString(fmt.Sprint(slice.Index(i).Uint())) - case reflect.Float64: - buf.WriteString(fmt.Sprint(slice.Index(i).Float())) - case reflectTime: - buf.WriteString(slice.Index(i).Interface().(time.Time).Format(time.RFC3339)) - default: - return fmt.Errorf("unsupported type '[]%s'", sliceOf) - } - buf.WriteString(delim) - } - key.SetValue(buf.String()[:buf.Len()-1]) - return nil -} - -// reflectWithProperType does the opposite thing as setWithProperType. -func reflectWithProperType(t reflect.Type, key *Key, field reflect.Value, delim string) error { - switch t.Kind() { - case reflect.String: - key.SetValue(field.String()) - case reflect.Bool: - key.SetValue(fmt.Sprint(field.Bool())) - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - key.SetValue(fmt.Sprint(field.Int())) - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64: - key.SetValue(fmt.Sprint(field.Uint())) - case reflect.Float32, reflect.Float64: - key.SetValue(fmt.Sprint(field.Float())) - case reflectTime: - key.SetValue(fmt.Sprint(field.Interface().(time.Time).Format(time.RFC3339))) - case reflect.Slice: - return reflectSliceWithProperType(key, field, delim) - default: - return fmt.Errorf("unsupported type '%s'", t) - } - return nil -} - -// CR: copied from encoding/json/encode.go with modifications of time.Time support. -// TODO: add more test coverage. -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() - case reflectTime: - t, ok := v.Interface().(time.Time) - return ok && t.IsZero() - } - return false -} - -func (s *Section) reflectFrom(val reflect.Value) error { - if val.Kind() == reflect.Ptr { - val = val.Elem() - } - typ := val.Type() - - for i := 0; i < typ.NumField(); i++ { - field := val.Field(i) - tpField := typ.Field(i) - - tag := tpField.Tag.Get("ini") - if tag == "-" { - continue - } - - opts := strings.SplitN(tag, ",", 2) - if len(opts) == 2 && opts[1] == "omitempty" && isEmptyValue(field) { - continue - } - - fieldName := s.parseFieldName(tpField.Name, opts[0]) - if len(fieldName) == 0 || !field.CanSet() { - continue - } - - if (tpField.Type.Kind() == reflect.Ptr && tpField.Anonymous) || - (tpField.Type.Kind() == reflect.Struct && tpField.Type.Name() != "Time") { - // Note: The only error here is section doesn't exist. - sec, err := s.f.GetSection(fieldName) - if err != nil { - // Note: fieldName can never be empty here, ignore error. - sec, _ = s.f.NewSection(fieldName) - } - - // Add comment from comment tag - if len(sec.Comment) == 0 { - sec.Comment = tpField.Tag.Get("comment") - } - - if err = sec.reflectFrom(field); err != nil { - return fmt.Errorf("error reflecting field (%s): %v", fieldName, err) - } - continue - } - - // Note: Same reason as secion. - key, err := s.GetKey(fieldName) - if err != nil { - key, _ = s.NewKey(fieldName, "") - } - - // Add comment from comment tag - if len(key.Comment) == 0 { - key.Comment = tpField.Tag.Get("comment") - } - - if err = reflectWithProperType(tpField.Type, key, field, parseDelim(tpField.Tag.Get("delim"))); err != nil { - return fmt.Errorf("error reflecting field (%s): %v", fieldName, err) - } - - } - return nil -} - -// ReflectFrom reflects secion from given struct. -func (s *Section) ReflectFrom(v interface{}) error { - typ := reflect.TypeOf(v) - val := reflect.ValueOf(v) - if typ.Kind() == reflect.Ptr { - typ = typ.Elem() - val = val.Elem() - } else { - return errors.New("cannot reflect from non-pointer struct") - } - - return s.reflectFrom(val) -} - -// ReflectFrom reflects file from given struct. -func (f *File) ReflectFrom(v interface{}) error { - return f.Section("").ReflectFrom(v) -} - -// ReflectFrom reflects data sources from given struct with name mapper. -func ReflectFromWithMapper(cfg *File, v interface{}, mapper NameMapper) error { - cfg.NameMapper = mapper - return cfg.ReflectFrom(v) -} - -// ReflectFrom reflects data sources from given struct. -func ReflectFrom(cfg *File, v interface{}) error { - return ReflectFromWithMapper(cfg, v, nil) -} diff --git a/vendor/github.com/go-openapi/jsonpointer/.travis.yml b/vendor/github.com/go-openapi/jsonpointer/.travis.yml index d0f383a26ba..2ee3ab97581 100644 --- a/vendor/github.com/go-openapi/jsonpointer/.travis.yml +++ b/vendor/github.com/go-openapi/jsonpointer/.travis.yml @@ -1,6 +1,8 @@ language: go go: -- 1.7 +- "1.8" +- "1.9" +- "1.10" install: - go get -u github.com/stretchr/testify/assert - go get -u github.com/go-openapi/swag diff --git a/vendor/github.com/go-openapi/jsonreference/.travis.yml b/vendor/github.com/go-openapi/jsonreference/.travis.yml index 5b31a1b3e1a..7a261a651ed 100644 --- a/vendor/github.com/go-openapi/jsonreference/.travis.yml +++ b/vendor/github.com/go-openapi/jsonreference/.travis.yml @@ -1,6 +1,8 @@ language: go go: -- 1.7 +- "1.8" +- "1.9" +- "1.10" install: - go get -u github.com/stretchr/testify/assert - go get -u github.com/PuerkitoBio/purell diff --git a/vendor/github.com/go-openapi/spec/bindata.go b/vendor/github.com/go-openapi/spec/bindata.go index 9afb5df194e..693917a07bd 100644 --- a/vendor/github.com/go-openapi/spec/bindata.go +++ b/vendor/github.com/go-openapi/spec/bindata.go @@ -69,7 +69,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\x00\x00\x00\x00\xff\xc4\x57\x3d\x6f\xdb\x3c\x10\xde\xf3\x2b\x08\x26\x63\xf2\x2a\x2f\xd0\xc9\x5b\xd1\x2e\x01\x5a\x34\x43\x37\x23\x03\x6d\x9d\x6c\x06\x14\xa9\x50\x54\x60\xc3\xd0\x7f\x2f\x28\x4a\x14\x29\x91\x92\x2d\xa7\x8d\x97\x28\xbc\xaf\xe7\x8e\xf7\xc5\xd3\x0d\x42\x08\x61\x9a\xe2\x15\xc2\x7b\xa5\x8a\x55\x92\xbc\x96\x82\x3f\x94\xdb\x3d\xe4\xe4\x3f\x21\x77\x49\x2a\x49\xa6\x1e\x1e\xbf\x24\xe6\xec\x16\xdf\x1b\xa1\x3b\xf3\xff\x02\xc9\x14\xca\xad\xa4\x85\xa2\x82\x6b\xe9\x6f\x42\x02\x32\x2c\x28\x07\x45\x5a\x15\x3d\x77\x46\x39\xd5\xcc\x25\x5e\x21\x83\xb8\x21\x18\xb6\xaf\x52\x92\xa3\x47\x68\x88\xea\x58\x80\x56\x4e\x1a\xf2\xbd\x4f\xcc\x29\x7f\x52\x90\x6b\x7d\xff\x0f\x48\xb4\x3d\x3f\x21\x7c\x27\x21\xd3\x2a\x6e\x31\xaa\x2d\x53\xdd\xf3\xe3\x42\x94\x54\xd1\x77\x78\xe2\x0a\x76\x20\xe3\x20\x68\xcb\x30\x86\x41\xf3\x2a\xc7\x2b\xf4\x78\x8e\xfe\xef\x90\x91\x8a\xa9\xc7\xb1\x1d\xc2\xd8\x2f\x0d\x75\xed\xc1\x4e\x9c\xc8\x25\x43\xac\xa8\xbe\xd7\xcc\xa9\xd1\xa9\x21\xa0\x1a\xbd\x04\x61\x94\x34\x2f\x18\xfc\x3e\x16\x50\x8e\x4d\x03\x6f\x1c\x58\xdb\x48\x23\xbc\x11\x82\x01\xe1\xfa\xd3\x3a\x8e\x30\xaf\x18\x33\x7f\xf3\x8d\x39\x11\x9b\x57\xd8\x2a\xfd\x55\x2a\x49\xf9\x0e\xc7\xec\x37\xd4\x25\xf7\xec\x5c\x66\xc7\xd7\x99\xaa\xcf\x4f\x89\x8a\xd3\xb7\x0a\x3a\xaa\x92\x15\xf4\x30\x6f\x1c\xb0\xd6\x46\xe7\x98\x39\x2d\xa4\x28\x40\x2a\x3a\x88\x9e\x29\xba\x88\x37\x2d\xca\x60\x38\xfa\xba\x5b\x20\xac\xa8\x62\xb0\x4c\xd4\xaf\xda\x45\x0a\xba\x5c\x3b\xb9\xc7\x79\xc5\x14\x2d\x18\x34\x19\x1c\x51\xdb\x25\x4d\xb4\x7e\x06\x14\x38\x6c\x59\x55\xd2\x77\xf8\x69\x59\xfc\x7b\x73\xed\x93\x43\xcb\x32\x6d\x3c\x28\xdc\x1b\x9a\xd3\x62\xab\xc2\x27\xf7\x41\xc9\x08\x2b\x23\x08\xad\x13\x57\x21\x9c\xd3\x72\x0d\x42\x72\xf8\x01\x7c\xa7\xf6\x83\xce\x39\xd7\x82\x3c\x1f\x2f\xd6\x60\x1b\xa2\xdf\x35\x89\x52\x20\xe7\x73\x74\xe0\x66\x26\x64\x4e\xb4\x97\x58\xc2\x0e\x0e\xe1\x60\x92\x34\x6d\xa0\x10\xd6\xb5\x83\x61\x27\xe6\x47\xd3\x89\xbd\x63\xfd\x3b\x8d\x03\x3d\x6c\x42\x2d\x5b\x70\xee\xe8\xdf\x4b\xf4\x66\x4e\xe1\x01\x45\x17\x80\x74\xad\x4f\xc3\xf3\xae\xc6\x1d\xc6\xd7\xc2\xce\xc9\xe1\x29\x30\x86\x2f\x4a\xa6\x4b\x15\x84\x73\xc9\x6f\xfd\x7f\xa5\x6e\x9e\xbd\xf1\xb0\xd4\xdd\x45\x5a\xc2\x3e\x4b\x78\xab\xa8\x84\x74\x4a\x91\x3b\x92\x23\x05\xf2\x1c\x1e\x7b\xf3\x09\xf8\xcf\xab\x24\xb6\x60\xa2\xe8\x4c\x9f\x75\x77\xaa\x8c\xe6\x01\x45\x36\x86\xcf\xc3\x63\x3a\xea\xd4\x8d\x7e\x06\xac\x14\x0a\xe0\x29\xf0\xed\x07\x22\x1a\x65\xda\x44\xae\xa2\x73\x1a\xe6\x90\x69\xa2\x8c\x46\xb2\x2f\xde\x49\x38\x08\xed\xfe\xfd\x41\xaf\x9f\xa9\x55\xd7\xdd\x22\x8d\xfa\x45\x63\xc5\x0f\x80\xf3\xb4\x08\xd6\x79\x30\x9e\x93\xee\x59\xa6\xd0\x4b\xee\x22\xe3\x33\xc1\x3a\x27\x68\x36\x78\x7e\x87\x0a\x06\xd5\x2e\x20\xd3\xaf\x15\xfb\xd8\x3b\x73\x14\xbb\x92\xed\x05\x5d\x2e\x29\x38\x2c\x94\xe4\x42\x45\x5e\xd3\xb5\x7d\xdf\x47\xca\x38\xb4\x5c\xaf\xfb\x7d\xdd\x6d\xf4\xa1\x2d\x77\xdd\x2f\xce\x6d\xc4\x7b\x8b\x4e\x67\xa9\x6f\xfe\x04\x00\x00\xff\xff\xb1\xd1\x27\x78\x05\x11\x00\x00") func jsonschemaDraft04JSONBytes() ([]byte, error) { return bindataRead( @@ -84,12 +84,12 @@ func jsonschemaDraft04JSON() (*asset, error) { return nil, err } - info := bindataFileInfo{name: "jsonschema-draft-04.json", size: 4375, mode: os.FileMode(420), modTime: time.Unix(1482389892, 0)} + info := bindataFileInfo{name: "jsonschema-draft-04.json", size: 4357, mode: os.FileMode(420), modTime: time.Unix(1523760398, 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\x1f\xfd\x37\x00\x00\xff\xff\x69\x5d\x0a\x6a\x39\x9d\x00\x00") +var _v2SchemaJSON = []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\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\x1f\xfd\x37\x00\x00\xff\xff\x69\x5d\x0a\x6a\x39\x9d\x00\x00") func v2SchemaJSONBytes() ([]byte, error) { return bindataRead( @@ -104,7 +104,7 @@ func v2SchemaJSON() (*asset, error) { return nil, err } - info := bindataFileInfo{name: "v2/schema.json", size: 40249, mode: os.FileMode(420), modTime: time.Unix(1482389892, 0)} + info := bindataFileInfo{name: "v2/schema.json", size: 40249, mode: os.FileMode(420), modTime: time.Unix(1523760397, 0)} a := &asset{bytes: bytes, info: info} return a, nil } diff --git a/vendor/github.com/go-openapi/spec/expander.go b/vendor/github.com/go-openapi/spec/expander.go index cebb5cc5935..ad1529db5f2 100644 --- a/vendor/github.com/go-openapi/spec/expander.go +++ b/vendor/github.com/go-openapi/spec/expander.go @@ -491,7 +491,7 @@ func ExpandSpec(spec *Swagger, options *ExpandOptions) error { for key, definition := range spec.Definitions { var def *Schema var err error - if def, err = expandSchema(definition, []string{fmt.Sprintf("#/defintions/%s", key)}, resolver, specBasePath); shouldStopOnError(err, resolver.options) { + if def, err = expandSchema(definition, []string{fmt.Sprintf("#/definitions/%s", key)}, resolver, specBasePath); shouldStopOnError(err, resolver.options) { return err } if def != nil { @@ -679,6 +679,12 @@ func expandSchema(target Schema, parentRefs []string, resolver *schemaLoader, ba if t != nil { parentRefs = append(parentRefs, normalizedRef.String()) + var err error + resolver, err = transitiveResolver(basePath, target.Ref, resolver) + if shouldStopOnError(err, resolver.options) { + return nil, err + } + return expandSchema(*t, parentRefs, resolver, normalizedBasePath) } } @@ -814,6 +820,13 @@ func expandPathItem(pathItem *PathItem, resolver *schemaLoader, basePath string) if err := derefPathItem(pathItem, parentRefs, resolver, basePath); shouldStopOnError(err, resolver.options) { return err } + if pathItem.Ref.String() != "" { + var err error + resolver, err = transitiveResolver(basePath, pathItem.Ref, resolver) + if shouldStopOnError(err, resolver.options) { + return err + } + } pathItem.Ref = Ref{} parentRefs = parentRefs[0:] @@ -874,6 +887,28 @@ func expandOperation(op *Operation, resolver *schemaLoader, basePath string) err return nil } +func transitiveResolver(basePath string, ref Ref, resolver *schemaLoader) (*schemaLoader, error) { + if ref.IsRoot() || ref.HasFragmentOnly { + return resolver, nil + } + + baseRef, _ := NewRef(basePath) + currentRef := normalizeFileRef(&ref, basePath) + // Set a new root to resolve against + if !strings.HasPrefix(currentRef.String(), baseRef.String()) { + rootURL := currentRef.GetURL() + rootURL.Fragment = "" + root, _ := resolver.cache.Get(rootURL.String()) + var err error + resolver, err = defaultSchemaLoader(root, resolver.options, resolver.cache) + if err != nil { + return nil, err + } + } + + return resolver, nil +} + // ExpandResponse expands a response based on a basepath // This is the exported version of expandResponse // all refs inside response will be resolved relative to basePath @@ -922,6 +957,13 @@ func expandResponse(response *Response, resolver *schemaLoader, basePath string) if err := derefResponse(response, parentRefs, resolver, basePath); shouldStopOnError(err, resolver.options) { return err } + if response.Ref.String() != "" { + var err error + resolver, err = transitiveResolver(basePath, response.Ref, resolver) + if shouldStopOnError(err, resolver.options) { + return err + } + } response.Ref = Ref{} parentRefs = parentRefs[0:] @@ -984,6 +1026,13 @@ func expandParameter(parameter *Parameter, resolver *schemaLoader, basePath stri if err := derefParameter(parameter, parentRefs, resolver, basePath); shouldStopOnError(err, resolver.options) { return err } + if parameter.Ref.String() != "" { + var err error + resolver, err = transitiveResolver(basePath, parameter.Ref, resolver) + if shouldStopOnError(err, resolver.options) { + return err + } + } parameter.Ref = Ref{} parentRefs = parentRefs[0:] diff --git a/vendor/github.com/go-openapi/swag/json.go b/vendor/github.com/go-openapi/swag/json.go index 17ab0f61691..274331ef1d5 100644 --- a/vendor/github.com/go-openapi/swag/json.go +++ b/vendor/github.com/go-openapi/swag/json.go @@ -26,6 +26,9 @@ import ( "github.com/mailru/easyjson/jwriter" ) +// nullJSON represents a JSON object with null type +var nullJSON = []byte("null") + // DefaultJSONNameProvider the default cache for types var DefaultJSONNameProvider = NewNameProvider() @@ -90,16 +93,29 @@ func ConcatJSON(blobs ...[]byte) []byte { if len(blobs) == 0 { return nil } - if len(blobs) == 1 { + + last := len(blobs) - 1 + for blobs[last] == nil || bytes.Equal(blobs[last], nullJSON) { + // strips trailing null objects + last = last - 1 + if last < 0 { + // there was nothing but "null"s or nil... + return nil + } + } + if last == 0 { return blobs[0] } - last := len(blobs) - 1 var opening, closing byte var idx, a int buf := bytes.NewBuffer(nil) - for i, b := range blobs { + for i, b := range blobs[:last+1] { + if b == nil || bytes.Equal(b, nullJSON) { + // a null object is in the list: skip it + continue + } if len(b) > 0 && opening == 0 { // is this an array or an object? opening, closing = b[0], closers[b[0]] } diff --git a/vendor/github.com/golang/protobuf/proto/Makefile b/vendor/github.com/golang/protobuf/proto/Makefile deleted file mode 100644 index e2e0651a934..00000000000 --- a/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/github.com/golang/protobuf/proto/clone.go b/vendor/github.com/golang/protobuf/proto/clone.go index e392575b353..3cd3249f706 100644 --- a/vendor/github.com/golang/protobuf/proto/clone.go +++ b/vendor/github.com/golang/protobuf/proto/clone.go @@ -35,22 +35,39 @@ package proto import ( + "fmt" "log" "reflect" "strings" ) // Clone returns a deep copy of a protocol buffer. -func Clone(pb Message) Message { - in := reflect.ValueOf(pb) +func Clone(src Message) Message { + in := reflect.ValueOf(src) if in.IsNil() { - return pb + return src } - 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) + dst := out.Interface().(Message) + Merge(dst, src) + return dst +} + +// Merger is the interface representing objects that can merge messages of the same type. +type Merger interface { + // Merge merges src into this message. + // 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 may panic if called with a different argument type than the receiver. + Merge(src Message) +} + +// generatedMerger is the custom merge method that generated protos will have. +// We must add this method since a generate Merge method will conflict with +// many existing protos that have a Merge data field already defined. +type generatedMerger interface { + XXX_Merge(src Message) } // Merge merges src into dst. @@ -58,17 +75,24 @@ func Clone(pb Message) Message { // 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) { + if m, ok := dst.(Merger); ok { + m.Merge(src) + return + } + 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") + panic(fmt.Sprintf("proto.Merge(%T, %T) type mismatch", dst, src)) } if in.IsNil() { - // Merging nil into non-nil is a quiet no-op + return // Merge from nil src is a noop + } + if m, ok := dst.(generatedMerger); ok { + m.XXX_Merge(src) return } mergeStruct(out.Elem(), in.Elem()) @@ -84,7 +108,7 @@ func mergeStruct(out, in reflect.Value) { mergeAny(out.Field(i), in.Field(i), false, sprop.Prop[i]) } - if emIn, ok := extendable(in.Addr().Interface()); ok { + if emIn, err := extendable(in.Addr().Interface()); err == nil { emOut, _ := extendable(out.Addr().Interface()) mIn, muIn := emIn.extensionsRead() if mIn != nil { diff --git a/vendor/github.com/golang/protobuf/proto/decode.go b/vendor/github.com/golang/protobuf/proto/decode.go index aa207298f99..d9aa3c42d66 100644 --- a/vendor/github.com/golang/protobuf/proto/decode.go +++ b/vendor/github.com/golang/protobuf/proto/decode.go @@ -39,8 +39,6 @@ import ( "errors" "fmt" "io" - "os" - "reflect" ) // errOverflow is returned when an integer is too large to be represented. @@ -50,10 +48,6 @@ var errOverflow = errors.New("proto: integer overflow") // 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. @@ -267,9 +261,6 @@ func (p *Buffer) DecodeZigzag32() (x uint64, err error) { 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. @@ -311,81 +302,29 @@ func (p *Buffer) DecodeStringBytes() (s string, err error) { 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 +// unmarshal themselves. The argument points to data that may be // overwritten, so implementations should not keep references to the // buffer. +// Unmarshal implementations should not clear the receiver. +// Any unmarshaled data should be merged into the receiver. +// Callers of Unmarshal that do not want to retain existing data +// should Reset the receiver before calling Unmarshal. type Unmarshaler interface { Unmarshal([]byte) error } +// newUnmarshaler is the interface representing objects that can +// unmarshal themselves. The semantics are identical to Unmarshaler. +// +// This exists to support protoc-gen-go generated messages. +// The proto package will stop type-asserting to this interface in the future. +// +// DO NOT DEPEND ON THIS. +type newUnmarshaler interface { + XXX_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. @@ -395,7 +334,13 @@ type Unmarshaler interface { // to preserve and append to existing data. func Unmarshal(buf []byte, pb Message) error { pb.Reset() - return UnmarshalMerge(buf, pb) + if u, ok := pb.(newUnmarshaler); ok { + return u.XXX_Unmarshal(buf) + } + if u, ok := pb.(Unmarshaler); ok { + return u.Unmarshal(buf) + } + return NewBuffer(buf).Unmarshal(pb) } // UnmarshalMerge parses the protocol buffer representation in buf and @@ -405,8 +350,16 @@ func Unmarshal(buf []byte, pb Message) error { // 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.(newUnmarshaler); ok { + return u.XXX_Unmarshal(buf) + } if u, ok := pb.(Unmarshaler); ok { + // NOTE: The history of proto have unfortunately been inconsistent + // whether Unmarshaler should or should not implicitly clear itself. + // Some implementations do, most do not. + // Thus, calling this here may or may not do what people want. + // + // See https://github.com/golang/protobuf/issues/424 return u.Unmarshal(buf) } return NewBuffer(buf).Unmarshal(pb) @@ -422,12 +375,17 @@ func (p *Buffer) DecodeMessage(pb Message) error { } // DecodeGroup reads a tag-delimited group from the Buffer. +// StartGroup tag is already consumed. This function consumes +// EndGroup tag. func (p *Buffer) DecodeGroup(pb Message) error { - typ, base, err := getbase(pb) - if err != nil { - return err + b := p.buf[p.index:] + x, y := findEndGroup(b) + if x < 0 { + return io.ErrUnexpectedEOF } - return p.unmarshalType(typ.Elem(), GetProperties(typ.Elem()), true, base) + err := Unmarshal(b[:x], pb) + p.index += y + return err } // Unmarshal parses the protocol buffer representation in the @@ -438,533 +396,33 @@ func (p *Buffer) DecodeGroup(pb Message) error { // 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 { - err := u.Unmarshal(p.buf[p.index:]) + if u, ok := pb.(newUnmarshaler); ok { + err := u.XXX_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 { - 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) - } - 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 { + if u, ok := pb.(Unmarshaler); ok { + // NOTE: The history of proto have unfortunately been inconsistent + // whether Unmarshaler should or should not implicitly clear itself. + // Some implementations do, most do not. + // Thus, calling this here may or may not do what people want. + // + // See https://github.com/golang/protobuf/issues/424 + err := u.Unmarshal(p.buf[p.index:]) + p.index = len(p.buf) 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 - + // Slow workaround for messages that aren't Unmarshalers. + // This includes some hand-coded .pb.go files and + // bootstrap protos. + // TODO: fix all of those and then add Unmarshal to + // the Message interface. Then: + // The cast above and code below can be deleted. + // The old unmarshaler can be deleted. + // Clients can call Unmarshal directly (can already do that, actually). + var info InternalMessageInfo + err := info.Unmarshal(pb, p.buf[p.index:]) + p.index = len(p.buf) return err } diff --git a/vendor/github.com/golang/protobuf/proto/discard.go b/vendor/github.com/golang/protobuf/proto/discard.go index bd0e3bb4c85..dea2617ced3 100644 --- a/vendor/github.com/golang/protobuf/proto/discard.go +++ b/vendor/github.com/golang/protobuf/proto/discard.go @@ -35,8 +35,14 @@ import ( "fmt" "reflect" "strings" + "sync" + "sync/atomic" ) +type generatedDiscarder interface { + XXX_DiscardUnknown() +} + // DiscardUnknown recursively discards all unknown fields from this message // and all embedded messages. // @@ -49,9 +55,202 @@ import ( // For proto2 messages, the unknown fields of message extensions are only // discarded from messages that have been accessed via GetExtension. func DiscardUnknown(m Message) { + if m, ok := m.(generatedDiscarder); ok { + m.XXX_DiscardUnknown() + return + } + // TODO: Dynamically populate a InternalMessageInfo for legacy messages, + // but the master branch has no implementation for InternalMessageInfo, + // so it would be more work to replicate that approach. discardLegacy(m) } +// DiscardUnknown recursively discards all unknown fields. +func (a *InternalMessageInfo) DiscardUnknown(m Message) { + di := atomicLoadDiscardInfo(&a.discard) + if di == nil { + di = getDiscardInfo(reflect.TypeOf(m).Elem()) + atomicStoreDiscardInfo(&a.discard, di) + } + di.discard(toPointer(&m)) +} + +type discardInfo struct { + typ reflect.Type + + initialized int32 // 0: only typ is valid, 1: everything is valid + lock sync.Mutex + + fields []discardFieldInfo + unrecognized field +} + +type discardFieldInfo struct { + field field // Offset of field, guaranteed to be valid + discard func(src pointer) +} + +var ( + discardInfoMap = map[reflect.Type]*discardInfo{} + discardInfoLock sync.Mutex +) + +func getDiscardInfo(t reflect.Type) *discardInfo { + discardInfoLock.Lock() + defer discardInfoLock.Unlock() + di := discardInfoMap[t] + if di == nil { + di = &discardInfo{typ: t} + discardInfoMap[t] = di + } + return di +} + +func (di *discardInfo) discard(src pointer) { + if src.isNil() { + return // Nothing to do. + } + + if atomic.LoadInt32(&di.initialized) == 0 { + di.computeDiscardInfo() + } + + for _, fi := range di.fields { + sfp := src.offset(fi.field) + fi.discard(sfp) + } + + // For proto2 messages, only discard unknown fields in message extensions + // that have been accessed via GetExtension. + if em, err := extendable(src.asPointerTo(di.typ).Interface()); err == nil { + // Ignore lock since DiscardUnknown is not concurrency safe. + emm, _ := em.extensionsRead() + for _, mx := range emm { + if m, ok := mx.value.(Message); ok { + DiscardUnknown(m) + } + } + } + + if di.unrecognized.IsValid() { + *src.offset(di.unrecognized).toBytes() = nil + } +} + +func (di *discardInfo) computeDiscardInfo() { + di.lock.Lock() + defer di.lock.Unlock() + if di.initialized != 0 { + return + } + t := di.typ + n := t.NumField() + + for i := 0; i < n; i++ { + f := t.Field(i) + if strings.HasPrefix(f.Name, "XXX_") { + continue + } + + dfi := discardFieldInfo{field: toField(&f)} + tf := f.Type + + // Unwrap tf to get its most basic type. + var isPointer, isSlice bool + if tf.Kind() == reflect.Slice && tf.Elem().Kind() != reflect.Uint8 { + isSlice = true + tf = tf.Elem() + } + if tf.Kind() == reflect.Ptr { + isPointer = true + tf = tf.Elem() + } + if isPointer && isSlice && tf.Kind() != reflect.Struct { + panic(fmt.Sprintf("%v.%s cannot be a slice of pointers to primitive types", t, f.Name)) + } + + switch tf.Kind() { + case reflect.Struct: + switch { + case !isPointer: + panic(fmt.Sprintf("%v.%s cannot be a direct struct value", t, f.Name)) + case isSlice: // E.g., []*pb.T + di := getDiscardInfo(tf) + dfi.discard = func(src pointer) { + sps := src.getPointerSlice() + for _, sp := range sps { + if !sp.isNil() { + di.discard(sp) + } + } + } + default: // E.g., *pb.T + di := getDiscardInfo(tf) + dfi.discard = func(src pointer) { + sp := src.getPointer() + if !sp.isNil() { + di.discard(sp) + } + } + } + case reflect.Map: + switch { + case isPointer || isSlice: + panic(fmt.Sprintf("%v.%s cannot be a pointer to a map or a slice of map values", t, f.Name)) + default: // E.g., map[K]V + if tf.Elem().Kind() == reflect.Ptr { // Proto struct (e.g., *T) + dfi.discard = func(src pointer) { + sm := src.asPointerTo(tf).Elem() + if sm.Len() == 0 { + return + } + for _, key := range sm.MapKeys() { + val := sm.MapIndex(key) + DiscardUnknown(val.Interface().(Message)) + } + } + } else { + dfi.discard = func(pointer) {} // Noop + } + } + case reflect.Interface: + // Must be oneof field. + switch { + case isPointer || isSlice: + panic(fmt.Sprintf("%v.%s cannot be a pointer to a interface or a slice of interface values", t, f.Name)) + default: // E.g., interface{} + // TODO: Make this faster? + dfi.discard = func(src pointer) { + su := src.asPointerTo(tf).Elem() + if !su.IsNil() { + sv := su.Elem().Elem().Field(0) + if sv.Kind() == reflect.Ptr && sv.IsNil() { + return + } + switch sv.Type().Kind() { + case reflect.Ptr: // Proto struct (e.g., *T) + DiscardUnknown(sv.Interface().(Message)) + } + } + } + } + default: + continue + } + di.fields = append(di.fields, dfi) + } + + di.unrecognized = invalidField + if f, ok := t.FieldByName("XXX_unrecognized"); ok { + if f.Type != reflect.TypeOf([]byte{}) { + panic("expected XXX_unrecognized to be of type []byte") + } + di.unrecognized = toField(&f) + } + + atomic.StoreInt32(&di.initialized, 1) +} + func discardLegacy(m Message) { v := reflect.ValueOf(m) if v.Kind() != reflect.Ptr || v.IsNil() { @@ -139,7 +338,7 @@ func discardLegacy(m Message) { // For proto2 messages, only discard unknown fields in message extensions // that have been accessed via GetExtension. - if em, ok := extendable(m); ok { + if em, err := extendable(m); err == nil { // Ignore lock since discardLegacy is not concurrency safe. emm, _ := em.extensionsRead() for _, mx := range emm { diff --git a/vendor/github.com/golang/protobuf/proto/encode.go b/vendor/github.com/golang/protobuf/proto/encode.go index 8b84d1b22d4..c27d35f866b 100644 --- a/vendor/github.com/golang/protobuf/proto/encode.go +++ b/vendor/github.com/golang/protobuf/proto/encode.go @@ -39,7 +39,6 @@ import ( "errors" "fmt" "reflect" - "sort" ) // RequiredNotSetError is the error returned if Marshal is called with @@ -82,10 +81,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 @@ -119,18 +114,27 @@ func (p *Buffer) EncodeVarint(x uint64) error { // 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 + switch { + case x < 1<<7: + return 1 + case x < 1<<14: + return 2 + case x < 1<<21: + return 3 + case x < 1<<28: + return 4 + case x < 1<<35: + return 5 + case x < 1<<42: + return 6 + case x < 1<<49: + return 7 + case x < 1<<56: + return 8 + case x < 1<<63: + return 9 + } + return 10 } // EncodeFixed64 writes a 64-bit integer to the Buffer. @@ -149,10 +153,6 @@ func (p *Buffer) EncodeFixed64(x uint64) error { 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. @@ -165,20 +165,12 @@ func (p *Buffer) EncodeFixed32(x uint64) error { 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((x << 1) ^ uint64((int64(x) >> 63))) -} - -func sizeZigzag64(x uint64) int { - return sizeVarint((x << 1) ^ uint64((int64(x) >> 63))) + return p.EncodeVarint(uint64((x << 1) ^ uint64((int64(x) >> 63)))) } // EncodeZigzag32 writes a zigzag-encoded 32-bit integer @@ -189,10 +181,6 @@ func (p *Buffer) EncodeZigzag32(x uint64) error { 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. @@ -202,11 +190,6 @@ func (p *Buffer) EncodeRawBytes(b []byte) error { 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 { @@ -215,319 +198,17 @@ func (p *Buffer) EncodeStringBytes(s string) error { 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) - 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() - p.buf = append(p.buf, data...) - return err - } - - 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++ // Parens are to work around a goimports bug. - } - - 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++ // Parens are to work around a goimports bug. - } - - 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 + siz := Size(pb) + p.EncodeVarint(uint64(siz)) + return p.Marshal(pb) } // All protocol buffer fields are nillable, but be careful. @@ -538,825 +219,3 @@ func isNil(v reflect.Value) bool { } 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 += 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) - - v, mu := exts.extensionsRead() - if v == nil { - return nil - } - - mu.Lock() - defer mu.Unlock() - if err := encodeExtensionsMap(v); err != nil { - return err - } - - 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/github.com/golang/protobuf/proto/equal.go b/vendor/github.com/golang/protobuf/proto/equal.go index 2ed1cf59666..d4db5a1c145 100644 --- a/vendor/github.com/golang/protobuf/proto/equal.go +++ b/vendor/github.com/golang/protobuf/proto/equal.go @@ -109,15 +109,6 @@ func equalStruct(v1, v2 reflect.Value) bool { // 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]) { @@ -146,11 +137,7 @@ func equalStruct(v1, v2 reflect.Value) bool { u1 := uf.Bytes() u2 := v2.FieldByName("XXX_unrecognized").Bytes() - if !bytes.Equal(u1, u2) { - return false - } - - return true + return bytes.Equal(u1, u2) } // v1 and v2 are known to have the same type. @@ -261,6 +248,15 @@ func equalExtMap(base reflect.Type, em1, em2 map[int32]Extension) bool { m1, m2 := e1.value, e2.value + if m1 == nil && m2 == nil { + // Both have only encoded form. + if bytes.Equal(e1.enc, e2.enc) { + continue + } + // The bytes are different, but the extensions might still be + // equal. We need to decode them to compare. + } + if m1 != nil && m2 != nil { // Both are unencoded. if !equalAny(reflect.ValueOf(m1), reflect.ValueOf(m2), nil) { @@ -276,8 +272,12 @@ func equalExtMap(base reflect.Type, em1, em2 map[int32]Extension) bool { desc = m[extNum] } if desc == nil { + // If both have only encoded form and the bytes are the same, + // it is handled above. We get here when the bytes are different. + // We don't know how to decode it, so just compare them as byte + // slices. log.Printf("proto: don't know how to compare extension %d of %v", extNum, base) - continue + return false } var err error if m1 == nil { diff --git a/vendor/github.com/golang/protobuf/proto/extensions.go b/vendor/github.com/golang/protobuf/proto/extensions.go index eaad2183126..816a3b9d6c0 100644 --- a/vendor/github.com/golang/protobuf/proto/extensions.go +++ b/vendor/github.com/golang/protobuf/proto/extensions.go @@ -38,6 +38,7 @@ package proto import ( "errors" "fmt" + "io" "reflect" "strconv" "sync" @@ -91,14 +92,29 @@ 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 +func extendable(p interface{}) (extendableProto, error) { + switch p := p.(type) { + case extendableProto: + if isNilPtr(p) { + return nil, fmt.Errorf("proto: nil %T is not extendable", p) + } + return p, nil + case extendableProtoV1: + if isNilPtr(p) { + return nil, fmt.Errorf("proto: nil %T is not extendable", p) + } + return extensionAdapter{p}, nil } - return nil, false + // Don't allocate a specific error containing %T: + // this is the hot path for Clone and MarshalText. + return nil, errNotExtendable +} + +var errNotExtendable = errors.New("proto: not an extendable proto.Message") + +func isNilPtr(x interface{}) bool { + v := reflect.ValueOf(x) + return v.Kind() == reflect.Ptr && v.IsNil() } // XXX_InternalExtensions is an internal representation of proto extensions. @@ -143,9 +159,6 @@ func (e *XXX_InternalExtensions) extensionsRead() (map[int32]Extension, sync.Loc 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 { @@ -179,8 +192,8 @@ type Extension struct { // SetRawExtension is for testing only. func SetRawExtension(base Message, id int32, b []byte) { - epb, ok := extendable(base) - if !ok { + epb, err := extendable(base) + if err != nil { return } extmap := epb.extensionsWrite() @@ -205,7 +218,7 @@ func checkExtensionTypes(pb extendableProto, extension *ExtensionDesc) error { 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()) + return fmt.Errorf("proto: bad extended type; %v does not extend %v", b, a) } // Check the range. if !isExtensionField(pb, extension.Field) { @@ -250,85 +263,11 @@ 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 { - 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 { + epb, err := extendable(pb) + if err != nil { return false } extmap, mu := epb.extensionsRead() @@ -336,15 +275,15 @@ func HasExtension(pb Message, extension *ExtensionDesc) bool { return false } mu.Lock() - _, ok = extmap[extension.Field] + _, 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 { + epb, err := extendable(pb) + if err != nil { return } // TODO: Check types, field numbers, etc.? @@ -352,16 +291,26 @@ func ClearExtension(pb Message, extension *ExtensionDesc) { 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. +// GetExtension retrieves a proto2 extended field from pb. +// +// If the descriptor is type complete (i.e., ExtensionDesc.ExtensionType is non-nil), +// then GetExtension parses the encoded field and returns a Go value of the specified type. +// If the field is not present, then the default value is returned (if one is specified), +// otherwise ErrMissingExtension is reported. +// +// If the descriptor is not type complete (i.e., ExtensionDesc.ExtensionType is nil), +// then GetExtension returns the raw encoded bytes of the field extension. func GetExtension(pb Message, extension *ExtensionDesc) (interface{}, error) { - epb, ok := extendable(pb) - if !ok { - return nil, errors.New("proto: not an extendable proto") + epb, err := extendable(pb) + if err != nil { + return nil, err } - if err := checkExtensionTypes(epb, extension); err != nil { - return nil, err + if extension.ExtendedType != nil { + // can only check type if this is a complete descriptor + if err := checkExtensionTypes(epb, extension); err != nil { + return nil, err + } } emap, mu := epb.extensionsRead() @@ -388,6 +337,11 @@ func GetExtension(pb Message, extension *ExtensionDesc) (interface{}, error) { return e.value, nil } + if extension.ExtensionType == nil { + // incomplete descriptor + return e.enc, nil + } + v, err := decodeExtension(e.enc, extension) if err != nil { return nil, err @@ -405,6 +359,11 @@ func GetExtension(pb Message, extension *ExtensionDesc) (interface{}, error) { // defaultExtensionValue returns the default value for extension. // If no default for an extension is defined ErrMissingExtension is returned. func defaultExtensionValue(extension *ExtensionDesc) (interface{}, error) { + if extension.ExtensionType == nil { + // incomplete descriptor, so no default + return nil, ErrMissingExtension + } + t := reflect.TypeOf(extension.ExtensionType) props := extensionProperties(extension) @@ -439,31 +398,28 @@ func defaultExtensionValue(extension *ExtensionDesc) (interface{}, error) { // 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) + unmarshal := typeUnmarshaler(t, extension.Tag) // 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 }. + // Allocate space to store the pointer/slice. value := reflect.New(t).Elem() + var err error for { - // Discard wire type and field number varint. It isn't needed. - if _, err := o.DecodeVarint(); err != nil { - return nil, err + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF } + b = b[n:] + wire := int(x) & 7 - if err := props.dec(o, props, toStructPointer(value.Addr())); err != nil { + b, err = unmarshal(b, valToPointer(value.Addr()), wire) + if err != nil { return nil, err } - if o.index >= len(o.buf) { + if len(b) == 0 { break } } @@ -473,9 +429,9 @@ 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 := extendable(pb) - if !ok { - return nil, errors.New("proto: not an extendable proto") + epb, err := extendable(pb) + if err != nil { + return nil, err } extensions = make([]interface{}, len(es)) for i, e := range es { @@ -494,9 +450,9 @@ func GetExtensions(pb Message, es []*ExtensionDesc) (extensions []interface{}, e // 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) + epb, err := extendable(pb) + if err != nil { + return nil, err } registeredExtensions := RegisteredExtensions(pb) @@ -523,9 +479,9 @@ func ExtensionDescs(pb Message) ([]*ExtensionDesc, error) { // 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") + epb, err := extendable(pb) + if err != nil { + return err } if err := checkExtensionTypes(epb, extension); err != nil { return err @@ -550,8 +506,8 @@ func SetExtension(pb Message, extension *ExtensionDesc, value interface{}) error // ClearAllExtensions clears all extensions from pb. func ClearAllExtensions(pb Message) { - epb, ok := extendable(pb) - if !ok { + epb, err := extendable(pb) + if err != nil { return } m := epb.extensionsWrite() diff --git a/vendor/github.com/golang/protobuf/proto/lib.go b/vendor/github.com/golang/protobuf/proto/lib.go index 1c225504a01..0e2191b8ada 100644 --- a/vendor/github.com/golang/protobuf/proto/lib.go +++ b/vendor/github.com/golang/protobuf/proto/lib.go @@ -265,6 +265,7 @@ package proto import ( "encoding/json" + "errors" "fmt" "log" "reflect" @@ -273,6 +274,8 @@ import ( "sync" ) +var errInvalidUTF8 = errors.New("proto: invalid UTF-8 string") + // Message is implemented by generated protocol buffer messages. type Message interface { Reset() @@ -309,16 +312,7 @@ type Buffer struct { buf []byte // encode/decode byte stream index int // read 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 + deterministic bool } // NewBuffer allocates a new Buffer and initializes its internal data to @@ -343,6 +337,30 @@ func (p *Buffer) SetBuf(s []byte) { // Bytes returns the contents of the Buffer. func (p *Buffer) Bytes() []byte { return p.buf } +// SetDeterministic sets whether to use deterministic serialization. +// +// Deterministic serialization guarantees that for a given binary, equal +// messages will always be serialized to the same bytes. This implies: +// +// - Repeated serialization of a message will return the same bytes. +// - Different processes of the same binary (which may be executing on +// different machines) will serialize equal messages to the same bytes. +// +// Note that the deterministic serialization is NOT canonical across +// languages. It is not guaranteed to remain stable over time. It is unstable +// across different builds with schema changes due to unknown fields. +// Users who need canonical serialization (e.g., persistent storage in a +// canonical form, fingerprinting, etc.) should define their own +// canonicalization specification and implement their own serializer rather +// than relying on this API. +// +// If deterministic serialization is requested, map entries will be sorted +// by keys in lexographical order. This is an implementation detail and +// subject to change. +func (p *Buffer) SetDeterministic(deterministic bool) { + p.deterministic = deterministic +} + /* * Helper routines for simplifying the creation of optional fields of basic type. */ @@ -831,22 +849,12 @@ func fieldDefault(ft reflect.Type, prop *Properties) (sf *scalarField, nestedMes return sf, false, nil } +// mapKeys returns a sort.Interface to be used for sorting the map keys. // 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()) - }, - } + s := mapKeySorter{vs: vs} - // Type specialization per https://developers.google.com/protocol-buffers/docs/proto#maps; - // numeric keys are sorted numerically. + // Type specialization per https://developers.google.com/protocol-buffers/docs/proto#maps. if len(vs) == 0 { return s } @@ -855,6 +863,12 @@ func mapKeys(vs []reflect.Value) sort.Interface { 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() } + case reflect.Bool: + s.less = func(a, b reflect.Value) bool { return !a.Bool() && b.Bool() } // false < true + case reflect.String: + s.less = func(a, b reflect.Value) bool { return a.String() < b.String() } + default: + panic(fmt.Sprintf("unsupported map key type: %v", vs[0].Kind())) } return s @@ -895,3 +909,13 @@ 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 + +// InternalMessageInfo is a type used internally by generated .pb.go files. +// This type is not intended to be used by non-generated code. +// This type is not subject to any compatibility guarantee. +type InternalMessageInfo struct { + marshal *marshalInfo + unmarshal *unmarshalInfo + merge *mergeInfo + discard *discardInfo +} diff --git a/vendor/github.com/golang/protobuf/proto/message_set.go b/vendor/github.com/golang/protobuf/proto/message_set.go index fd982decd66..3b6ca41d5e5 100644 --- a/vendor/github.com/golang/protobuf/proto/message_set.go +++ b/vendor/github.com/golang/protobuf/proto/message_set.go @@ -42,6 +42,7 @@ import ( "fmt" "reflect" "sort" + "sync" ) // errNoMessageTypeID occurs when a protocol buffer does not have a message type ID. @@ -94,10 +95,7 @@ func (ms *messageSet) find(pb Message) *_MessageSet_Item { } func (ms *messageSet) Has(pb Message) bool { - if ms.find(pb) != nil { - return true - } - return false + return ms.find(pb) != nil } func (ms *messageSet) Unmarshal(pb Message) error { @@ -150,46 +148,42 @@ 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 + return marshalMessageSet(exts, false) +} + +// marshaMessageSet implements above function, with the opt to turn on / off deterministic during Marshal. +func marshalMessageSet(exts interface{}, deterministic bool) ([]byte, error) { switch exts := exts.(type) { case *XXX_InternalExtensions: - if err := encodeExtensions(exts); err != nil { - return nil, err - } - m, _ = exts.extensionsRead() + var u marshalInfo + siz := u.sizeMessageSet(exts) + b := make([]byte, 0, siz) + return u.appendMessageSet(b, exts, deterministic) + case map[int32]Extension: - if err := encodeExtensionsMap(exts); err != nil { - return nil, err + // This is an old-style extension map. + // Wrap it in a new-style XXX_InternalExtensions. + ie := XXX_InternalExtensions{ + p: &struct { + mu sync.Mutex + extensionMap map[int32]Extension + }{ + extensionMap: exts, + }, } - m = exts + + var u marshalInfo + siz := u.sizeMessageSet(&ie) + b := make([]byte, 0, siz) + return u.appendMessageSet(b, &ie, deterministic) + 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. +// It is called by 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) { @@ -235,7 +229,15 @@ func MarshalMessageSetJSON(exts interface{}) ([]byte, error) { var m map[int32]Extension switch exts := exts.(type) { case *XXX_InternalExtensions: - m, _ = exts.extensionsRead() + var mu sync.Locker + m, mu = exts.extensionsRead() + if m != nil { + // Keep the extensions map locked until we're done marshaling to prevent + // races between marshaling and unmarshaling the lazily-{en,de}coded + // values. + mu.Lock() + defer mu.Unlock() + } case map[int32]Extension: m = exts default: @@ -253,15 +255,16 @@ func MarshalMessageSetJSON(exts interface{}) ([]byte, error) { 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 } + + if i > 0 && b.Len() > 1 { + b.WriteByte(',') + } + fmt.Fprintf(&b, `"[%s]":`, msd.name) x := ext.value diff --git a/vendor/github.com/golang/protobuf/proto/pointer_reflect.go b/vendor/github.com/golang/protobuf/proto/pointer_reflect.go index fb512e2e16d..b6cad90834b 100644 --- a/vendor/github.com/golang/protobuf/proto/pointer_reflect.go +++ b/vendor/github.com/golang/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 purego 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 @@ -38,32 +38,13 @@ package proto import ( - "math" "reflect" + "sync" ) -// 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() -} +const unsafeAllowed = false -// 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. +// A field identifies a field in a struct, accessible from a pointer. // In this implementation, a field is identified by the sequence of field indices // passed to reflect's FieldByIndex. type field []int @@ -76,409 +57,301 @@ func toField(f *reflect.StructField) field { // invalidField is an invalid field identifier. var invalidField = field(nil) +// zeroField is a noop when calling pointer.offset. +var zeroField = field([]int{}) + // 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) +// The pointer type is for the table-driven decoder. +// The implementation here uses a reflect.Value of pointer type to +// create a generic pointer. In pointer_unsafe.go we use unsafe +// instead of reflect to implement the same (but faster) interface. +type pointer struct { + v reflect.Value } -// 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() +// toPointer converts an interface of pointer type to a pointer +// that points to the same target. +func toPointer(i *Message) pointer { + return pointer{v: reflect.ValueOf(*i)} } -// 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) +// toAddrPointer converts an interface to a pointer that points to +// the interface data. +func toAddrPointer(i *interface{}, isptr bool) pointer { + v := reflect.ValueOf(*i) + u := reflect.New(v.Type()) + u.Elem().Set(v) + return pointer{v: u} } -// 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) +// valToPointer converts v to a pointer. v must be of pointer type. +func valToPointer(v reflect.Value) pointer { + return pointer{v: v} } -// 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) +// offset converts from a pointer to a structure to a pointer to +// one of its fields. +func (p pointer) offset(f field) pointer { + return pointer{v: p.v.Elem().FieldByIndex(f).Addr()} } -// 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) +func (p pointer) isNil() bool { + return p.v.IsNil() } -// 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) +// grow updates the slice s in place to make it one element longer. +// s must be addressable. +// Returns the (addressable) new element. +func grow(s reflect.Value) reflect.Value { + n, m := s.Len(), s.Cap() + if n < m { + s.SetLen(n + 1) + } else { + s.Set(reflect.Append(s, reflect.Zero(s.Type().Elem()))) + } + return s.Index(n) } -// 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) +func (p pointer) toInt64() *int64 { + return p.v.Interface().(*int64) } - -// 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) +func (p pointer) toInt64Ptr() **int64 { + return p.v.Interface().(**int64) } - -// 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) +func (p pointer) toInt64Slice() *[]int64 { + return p.v.Interface().(*[]int64) } -// 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) -} +var int32ptr = reflect.TypeOf((*int32)(nil)) -// 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) +func (p pointer) toInt32() *int32 { + return p.v.Convert(int32ptr).Interface().(*int32) } -// 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() +// The toInt32Ptr/Slice methods don't work because of enums. +// Instead, we must use set/get methods for the int32ptr/slice case. +/* + func (p pointer) toInt32Ptr() **int32 { + return p.v.Interface().(**int32) } - -// SetStructPointer writes a *struct field in the struct. -func structPointer_SetStructPointer(p structPointer, f field, q structPointer) { - structPointer_field(p, f).Set(q.v) + func (p pointer) toInt32Slice() *[]int32 { + return p.v.Interface().(*[]int32) } - -// GetStructPointer reads a *struct field in the struct. -func structPointer_GetStructPointer(p structPointer, f field) structPointer { - return structPointer{structPointer_field(p, f)} +*/ +func (p pointer) getInt32Ptr() *int32 { + if p.v.Type().Elem().Elem() == reflect.TypeOf(int32(0)) { + // raw int32 type + return p.v.Elem().Interface().(*int32) + } + // an enum + return p.v.Elem().Convert(int32PtrType).Interface().(*int32) +} +func (p pointer) setInt32Ptr(v int32) { + // Allocate value in a *int32. Possibly convert that to a *enum. + // Then assign it to a **int32 or **enum. + // Note: we can convert *int32 to *enum, but we can't convert + // **int32 to **enum! + p.v.Elem().Set(reflect.ValueOf(&v).Convert(p.v.Type().Elem())) +} + +// getInt32Slice copies []int32 from p as a new slice. +// This behavior differs from the implementation in pointer_unsafe.go. +func (p pointer) getInt32Slice() []int32 { + if p.v.Type().Elem().Elem() == reflect.TypeOf(int32(0)) { + // raw int32 type + return p.v.Elem().Interface().([]int32) + } + // an enum + // Allocate a []int32, then assign []enum's values into it. + // Note: we can't convert []enum to []int32. + slice := p.v.Elem() + s := make([]int32, slice.Len()) + for i := 0; i < slice.Len(); i++ { + s[i] = int32(slice.Index(i).Int()) + } + return s } -// StructPointerSlice the address of a []*struct field in the struct. -func structPointer_StructPointerSlice(p structPointer, f field) structPointerSlice { - return structPointerSlice{structPointer_field(p, f)} +// setInt32Slice copies []int32 into p as a new slice. +// This behavior differs from the implementation in pointer_unsafe.go. +func (p pointer) setInt32Slice(v []int32) { + if p.v.Type().Elem().Elem() == reflect.TypeOf(int32(0)) { + // raw int32 type + p.v.Elem().Set(reflect.ValueOf(v)) + return + } + // an enum + // Allocate a []enum, then assign []int32's values into it. + // Note: we can't convert []enum to []int32. + slice := reflect.MakeSlice(p.v.Type().Elem(), len(v), cap(v)) + for i, x := range v { + slice.Index(i).SetInt(int64(x)) + } + p.v.Elem().Set(slice) } - -// 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 pointer) appendInt32Slice(v int32) { + grow(p.v.Elem()).SetInt(int64(v)) } -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)) +func (p pointer) toUint64() *uint64 { + return p.v.Interface().(*uint64) } - -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 +func (p pointer) toUint64Ptr() **uint64 { + return p.v.Interface().(**uint64) } - -// IsNil reports whether p is nil. -func word32_IsNil(p word32) bool { - return p.v.IsNil() +func (p pointer) toUint64Slice() *[]uint64 { + return p.v.Interface().(*[]uint64) } - -// 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))) +func (p pointer) toUint32() *uint32 { + return p.v.Interface().(*uint32) } - -// 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") +func (p pointer) toUint32Ptr() **uint32 { + return p.v.Interface().(**uint32) } - -// 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)} +func (p pointer) toUint32Slice() *[]uint32 { + return p.v.Interface().(*[]uint32) } - -// 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 +func (p pointer) toBool() *bool { + return p.v.Interface().(*bool) } - -// 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))) +func (p pointer) toBoolPtr() **bool { + return p.v.Interface().(**bool) } - -// 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") +func (p pointer) toBoolSlice() *[]bool { + return p.v.Interface().(*[]bool) } - -// 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)} +func (p pointer) toFloat64() *float64 { + return p.v.Interface().(*float64) } - -// 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 pointer) toFloat64Ptr() **float64 { + return p.v.Interface().(**float64) } - -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 pointer) toFloat64Slice() *[]float64 { + return p.v.Interface().(*[]float64) } - -func (p word32Slice) Len() int { - return p.v.Len() +func (p pointer) toFloat32() *float32 { + return p.v.Interface().(*float32) } - -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") +func (p pointer) toFloat32Ptr() **float32 { + return p.v.Interface().(**float32) } - -// 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)} +func (p pointer) toFloat32Slice() *[]float32 { + return p.v.Interface().(*[]float32) } - -// word64 is like word32 but for 64-bit values. -type word64 struct { - v reflect.Value +func (p pointer) toString() *string { + return p.v.Interface().(*string) } - -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 (p pointer) toStringPtr() **string { + return p.v.Interface().(**string) } - -func word64_IsNil(p word64) bool { - return p.v.IsNil() +func (p pointer) toStringSlice() *[]string { + return p.v.Interface().(*[]string) } - -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 (p pointer) toBytes() *[]byte { + return p.v.Interface().(*[]byte) } - -func structPointer_Word64(p structPointer, f field) word64 { - return word64{structPointer_field(p, f)} +func (p pointer) toBytesSlice() *[][]byte { + return p.v.Interface().(*[][]byte) +} +func (p pointer) toExtensions() *XXX_InternalExtensions { + return p.v.Interface().(*XXX_InternalExtensions) +} +func (p pointer) toOldExtensions() *map[int32]Extension { + return p.v.Interface().(*map[int32]Extension) +} +func (p pointer) getPointer() pointer { + return pointer{v: p.v.Elem()} +} +func (p pointer) setPointer(q pointer) { + p.v.Elem().Set(q.v) +} +func (p pointer) appendPointer(q pointer) { + grow(p.v.Elem()).Set(q.v) } -// word64Val is like word32Val but for 64-bit values. -type word64Val struct { - v reflect.Value +// getPointerSlice copies []*T from p as a new []pointer. +// This behavior differs from the implementation in pointer_unsafe.go. +func (p pointer) getPointerSlice() []pointer { + if p.v.IsNil() { + return nil + } + n := p.v.Elem().Len() + s := make([]pointer, n) + for i := 0; i < n; i++ { + s[i] = pointer{v: p.v.Elem().Index(i)} + } + return s } -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)) +// setPointerSlice copies []pointer into p as a new []*T. +// This behavior differs from the implementation in pointer_unsafe.go. +func (p pointer) setPointerSlice(v []pointer) { + if v == nil { + p.v.Elem().Set(reflect.New(p.v.Elem().Type()).Elem()) return } - panic("unreachable") + s := reflect.MakeSlice(p.v.Elem().Type(), 0, len(v)) + for _, p := range v { + s = reflect.Append(s, p.v) + } + p.v.Elem().Set(s) } -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()) +// getInterfacePointer returns a pointer that points to the +// interface data of the interface pointed by p. +func (p pointer) getInterfacePointer() pointer { + if p.v.Elem().IsNil() { + return pointer{v: p.v.Elem()} } - panic("unreachable") + return pointer{v: p.v.Elem().Elem().Elem().Field(0).Addr()} // *interface -> interface -> *struct -> struct } -func structPointer_Word64Val(p structPointer, f field) word64Val { - return word64Val{structPointer_field(p, f)} +func (p pointer) asPointerTo(t reflect.Type) reflect.Value { + // TODO: check that p.v.Type().Elem() == t? + return p.v } -type word64Slice struct { - v reflect.Value +func atomicLoadUnmarshalInfo(p **unmarshalInfo) *unmarshalInfo { + atomicLock.Lock() + defer atomicLock.Unlock() + return *p } - -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 atomicStoreUnmarshalInfo(p **unmarshalInfo, v *unmarshalInfo) { + atomicLock.Lock() + defer atomicLock.Unlock() + *p = v } - -func (p word64Slice) Len() int { - return p.v.Len() +func atomicLoadMarshalInfo(p **marshalInfo) *marshalInfo { + atomicLock.Lock() + defer atomicLock.Unlock() + return *p } - -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 atomicStoreMarshalInfo(p **marshalInfo, v *marshalInfo) { + atomicLock.Lock() + defer atomicLock.Unlock() + *p = v } - -func structPointer_Word64Slice(p structPointer, f field) word64Slice { - return word64Slice{structPointer_field(p, f)} +func atomicLoadMergeInfo(p **mergeInfo) *mergeInfo { + atomicLock.Lock() + defer atomicLock.Unlock() + return *p +} +func atomicStoreMergeInfo(p **mergeInfo, v *mergeInfo) { + atomicLock.Lock() + defer atomicLock.Unlock() + *p = v } +func atomicLoadDiscardInfo(p **discardInfo) *discardInfo { + atomicLock.Lock() + defer atomicLock.Unlock() + return *p +} +func atomicStoreDiscardInfo(p **discardInfo, v *discardInfo) { + atomicLock.Lock() + defer atomicLock.Unlock() + *p = v +} + +var atomicLock sync.Mutex diff --git a/vendor/github.com/golang/protobuf/proto/pointer_unsafe.go b/vendor/github.com/golang/protobuf/proto/pointer_unsafe.go index 6b5567d47cd..d55a335d945 100644 --- a/vendor/github.com/golang/protobuf/proto/pointer_unsafe.go +++ b/vendor/github.com/golang/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 !purego,!appengine,!js // This file contains the implementation of the proto field accesses using package unsafe. @@ -37,38 +37,13 @@ package proto import ( "reflect" + "sync/atomic" "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() -} +const unsafeAllowed = true -// A field identifies a field in a struct, accessible from a structPointer. +// A field identifies a field in a struct, accessible from a pointer. // In this implementation, a field is identified by its byte offset from the start of the struct. type field uintptr @@ -80,191 +55,254 @@ func toField(f *reflect.StructField) field { // invalidField is an invalid field identifier. const invalidField = ^field(0) +// zeroField is a noop when calling pointer.offset. +const zeroField = field(0) + // IsValid reports whether the field identifier is valid. func (f field) IsValid() bool { - return f != ^field(0) + return f != invalidField } -// 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))) +// The pointer type below is for the new table-driven encoder/decoder. +// The implementation here uses unsafe.Pointer to create a generic pointer. +// In pointer_reflect.go we use reflect instead of unsafe to implement +// the same (but slower) interface. +type pointer struct { + p unsafe.Pointer } -// 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))) -} +// size of pointer +var ptrSize = unsafe.Sizeof(uintptr(0)) -// 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))) +// toPointer converts an interface of pointer type to a pointer +// that points to the same target. +func toPointer(i *Message) pointer { + // Super-tricky - read pointer out of data word of interface value. + // Saves ~25ns over the equivalent: + // return valToPointer(reflect.ValueOf(*i)) + return pointer{p: (*[2]unsafe.Pointer)(unsafe.Pointer(i))[1]} } -// 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))) +// toAddrPointer converts an interface to a pointer that points to +// the interface data. +func toAddrPointer(i *interface{}, isptr bool) pointer { + // Super-tricky - read or get the address of data word of interface value. + if isptr { + // The interface is of pointer type, thus it is a direct interface. + // The data word is the pointer data itself. We take its address. + return pointer{p: unsafe.Pointer(uintptr(unsafe.Pointer(i)) + ptrSize)} + } + // The interface is not of pointer type. The data word is the pointer + // to the data. + return pointer{p: (*[2]unsafe.Pointer)(unsafe.Pointer(i))[1]} } -// 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))) +// valToPointer converts v to a pointer. v must be of pointer type. +func valToPointer(v reflect.Value) pointer { + return pointer{p: unsafe.Pointer(v.Pointer())} } -// 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))) +// offset converts from a pointer to a structure to a pointer to +// one of its fields. +func (p pointer) offset(f field) pointer { + // For safety, we should panic if !f.IsValid, however calling panic causes + // this to no longer be inlineable, which is a serious performance cost. + /* + if !f.IsValid() { + panic("invalid field") + } + */ + return pointer{p: unsafe.Pointer(uintptr(p.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))) +func (p pointer) isNil() bool { + return p.p == nil } -// 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))) +func (p pointer) toInt64() *int64 { + return (*int64)(p.p) } - -// 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 (p pointer) toInt64Ptr() **int64 { + return (**int64)(p.p) } - -func structPointer_ExtMap(p structPointer, f field) *map[int32]Extension { - return (*map[int32]Extension)(unsafe.Pointer(uintptr(p) + uintptr(f))) +func (p pointer) toInt64Slice() *[]int64 { + return (*[]int64)(p.p) } - -// 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))) +func (p pointer) toInt32() *int32 { + return (*int32)(p.p) } -// 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 +// See pointer_reflect.go for why toInt32Ptr/Slice doesn't exist. +/* + func (p pointer) toInt32Ptr() **int32 { + return (**int32)(p.p) + } + func (p pointer) toInt32Slice() *[]int32 { + return (*[]int32)(p.p) + } +*/ +func (p pointer) getInt32Ptr() *int32 { + return *(**int32)(p.p) } - -// GetStructPointer reads a *struct field in the struct. -func structPointer_GetStructPointer(p structPointer, f field) structPointer { - return *(*structPointer)(unsafe.Pointer(uintptr(p) + uintptr(f))) +func (p pointer) setInt32Ptr(v int32) { + *(**int32)(p.p) = &v } -// 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))) +// getInt32Slice loads a []int32 from p. +// The value returned is aliased with the original slice. +// This behavior differs from the implementation in pointer_reflect.go. +func (p pointer) getInt32Slice() []int32 { + return *(*[]int32)(p.p) } -// 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 +// setInt32Slice stores a []int32 to p. +// The value set is aliased with the input slice. +// This behavior differs from the implementation in pointer_reflect.go. +func (p pointer) setInt32Slice(v []int32) { + *(*[]int32)(p.p) = v } -// 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:] +// TODO: Can we get rid of appendInt32Slice and use setInt32Slice instead? +func (p pointer) appendInt32Slice(v int32) { + s := (*[]int32)(p.p) + *s = append(*s, v) } -// Get gets the value pointed at by *v. -func word32_Get(p word32) uint32 { - return **p +func (p pointer) toUint64() *uint64 { + return (*uint64)(p.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)))) +func (p pointer) toUint64Ptr() **uint64 { + return (**uint64)(p.p) } - -// 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 +func (p pointer) toUint64Slice() *[]uint64 { + return (*[]uint64)(p.p) } - -// Get gets the value pointed at by p. -func word32Val_Get(p word32Val) uint32 { - return *p +func (p pointer) toUint32() *uint32 { + return (*uint32)(p.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)))) +func (p pointer) toUint32Ptr() **uint32 { + return (**uint32)(p.p) } - -// 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))) +func (p pointer) toUint32Slice() *[]uint32 { + return (*[]uint32)(p.p) } - -// 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 (p pointer) toBool() *bool { + return (*bool)(p.p) } - -func word64_IsNil(p word64) bool { - return *p == nil +func (p pointer) toBoolPtr() **bool { + return (**bool)(p.p) } - -func word64_Get(p word64) uint64 { - return **p +func (p pointer) toBoolSlice() *[]bool { + return (*[]bool)(p.p) +} +func (p pointer) toFloat64() *float64 { + return (*float64)(p.p) +} +func (p pointer) toFloat64Ptr() **float64 { + return (**float64)(p.p) +} +func (p pointer) toFloat64Slice() *[]float64 { + return (*[]float64)(p.p) +} +func (p pointer) toFloat32() *float32 { + return (*float32)(p.p) +} +func (p pointer) toFloat32Ptr() **float32 { + return (**float32)(p.p) +} +func (p pointer) toFloat32Slice() *[]float32 { + return (*[]float32)(p.p) +} +func (p pointer) toString() *string { + return (*string)(p.p) +} +func (p pointer) toStringPtr() **string { + return (**string)(p.p) +} +func (p pointer) toStringSlice() *[]string { + return (*[]string)(p.p) +} +func (p pointer) toBytes() *[]byte { + return (*[]byte)(p.p) +} +func (p pointer) toBytesSlice() *[][]byte { + return (*[][]byte)(p.p) +} +func (p pointer) toExtensions() *XXX_InternalExtensions { + return (*XXX_InternalExtensions)(p.p) +} +func (p pointer) toOldExtensions() *map[int32]Extension { + return (*map[int32]Extension)(p.p) } -func structPointer_Word64(p structPointer, f field) word64 { - return word64((**uint64)(unsafe.Pointer(uintptr(p) + uintptr(f)))) +// getPointerSlice loads []*T from p as a []pointer. +// The value returned is aliased with the original slice. +// This behavior differs from the implementation in pointer_reflect.go. +func (p pointer) getPointerSlice() []pointer { + // Super-tricky - p should point to a []*T where T is a + // message type. We load it as []pointer. + return *(*[]pointer)(p.p) } -// word64Val is like word32Val but for 64-bit values. -type word64Val *uint64 +// setPointerSlice stores []pointer into p as a []*T. +// The value set is aliased with the input slice. +// This behavior differs from the implementation in pointer_reflect.go. +func (p pointer) setPointerSlice(v []pointer) { + // Super-tricky - p should point to a []*T where T is a + // message type. We store it as []pointer. + *(*[]pointer)(p.p) = v +} -func word64Val_Set(p word64Val, o *Buffer, x uint64) { - *p = x +// getPointer loads the pointer at p and returns it. +func (p pointer) getPointer() pointer { + return pointer{p: *(*unsafe.Pointer)(p.p)} } -func word64Val_Get(p word64Val) uint64 { - return *p +// setPointer stores the pointer q at p. +func (p pointer) setPointer(q pointer) { + *(*unsafe.Pointer)(p.p) = q.p } -func structPointer_Word64Val(p structPointer, f field) word64Val { - return word64Val((*uint64)(unsafe.Pointer(uintptr(p) + uintptr(f)))) +// append q to the slice pointed to by p. +func (p pointer) appendPointer(q pointer) { + s := (*[]unsafe.Pointer)(p.p) + *s = append(*s, q.p) } -// word64Slice is like word32Slice but for 64-bit values. -type word64Slice []uint64 +// getInterfacePointer returns a pointer that points to the +// interface data of the interface pointed by p. +func (p pointer) getInterfacePointer() pointer { + // Super-tricky - read pointer out of data word of interface value. + return pointer{p: (*(*[2]unsafe.Pointer)(p.p))[1]} +} -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] } +// asPointerTo returns a reflect.Value that is a pointer to an +// object of type t stored at p. +func (p pointer) asPointerTo(t reflect.Type) reflect.Value { + return reflect.NewAt(t, p.p) +} -func structPointer_Word64Slice(p structPointer, f field) *word64Slice { - return (*word64Slice)(unsafe.Pointer(uintptr(p) + uintptr(f))) +func atomicLoadUnmarshalInfo(p **unmarshalInfo) *unmarshalInfo { + return (*unmarshalInfo)(atomic.LoadPointer((*unsafe.Pointer)(unsafe.Pointer(p)))) +} +func atomicStoreUnmarshalInfo(p **unmarshalInfo, v *unmarshalInfo) { + atomic.StorePointer((*unsafe.Pointer)(unsafe.Pointer(p)), unsafe.Pointer(v)) +} +func atomicLoadMarshalInfo(p **marshalInfo) *marshalInfo { + return (*marshalInfo)(atomic.LoadPointer((*unsafe.Pointer)(unsafe.Pointer(p)))) +} +func atomicStoreMarshalInfo(p **marshalInfo, v *marshalInfo) { + atomic.StorePointer((*unsafe.Pointer)(unsafe.Pointer(p)), unsafe.Pointer(v)) +} +func atomicLoadMergeInfo(p **mergeInfo) *mergeInfo { + return (*mergeInfo)(atomic.LoadPointer((*unsafe.Pointer)(unsafe.Pointer(p)))) +} +func atomicStoreMergeInfo(p **mergeInfo, v *mergeInfo) { + atomic.StorePointer((*unsafe.Pointer)(unsafe.Pointer(p)), unsafe.Pointer(v)) +} +func atomicLoadDiscardInfo(p **discardInfo) *discardInfo { + return (*discardInfo)(atomic.LoadPointer((*unsafe.Pointer)(unsafe.Pointer(p)))) +} +func atomicStoreDiscardInfo(p **discardInfo, v *discardInfo) { + atomic.StorePointer((*unsafe.Pointer)(unsafe.Pointer(p)), unsafe.Pointer(v)) } diff --git a/vendor/github.com/golang/protobuf/proto/properties.go b/vendor/github.com/golang/protobuf/proto/properties.go index ec2289c0058..f710adab092 100644 --- a/vendor/github.com/golang/protobuf/proto/properties.go +++ b/vendor/github.com/golang/protobuf/proto/properties.go @@ -58,42 +58,6 @@ const ( 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. @@ -140,13 +104,6 @@ type StructProperties struct { 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. @@ -187,36 +144,19 @@ type Properties struct { 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 + + stype reflect.Type // set for struct types only + sprop *StructProperties // set for struct types only 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 += "," s += strconv.Itoa(p.Tag) if p.Required { s += ",req" @@ -262,29 +202,14 @@ func (p *Properties) Parse(s string) { 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 @@ -299,6 +224,7 @@ func (p *Properties) Parse(s string) { return } +outer: for i := 2; i < len(fields); i++ { f := fields[i] switch { @@ -326,229 +252,28 @@ func (p *Properties) Parse(s string) { if i+1 < len(fields) { // Commas aren't escaped, and def is always last. p.Default += "," + strings.Join(fields[i+1:], ",") - break + break outer } } } } -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 - +// setFieldProps initializes the field properties for submessages and maps. +func (p *Properties) setFieldProps(typ reflect.Type, f *reflect.StructField, lockGetProp bool) { 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: + if t1.Elem().Kind() == 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 - } + if t2 := t1.Elem(); t2.Kind() == reflect.Ptr && t2.Elem().Kind() == reflect.Struct { + p.stype = t2.Elem() } 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) @@ -562,20 +287,6 @@ func (p *Properties) setEncAndDec(typ reflect.Type, f *reflect.StructField, lock 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) @@ -586,32 +297,9 @@ func (p *Properties) setEncAndDec(typ reflect.Type, f *reflect.StructField, lock } var ( - marshalerType = reflect.TypeOf((*Marshaler)(nil)).Elem() - unmarshalerType = reflect.TypeOf((*Unmarshaler)(nil)).Elem() + marshalerType = reflect.TypeOf((*Marshaler)(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) @@ -621,14 +309,11 @@ func (p *Properties) init(typ reflect.Type, name, tag string, f *reflect.StructF // "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) + p.setFieldProps(typ, f, lockGetProp) } var ( @@ -678,9 +363,6 @@ func getPropertiesLocked(t reflect.Type) *StructProperties { 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()) @@ -690,17 +372,6 @@ 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 - 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. @@ -715,9 +386,6 @@ func getPropertiesLocked(t reflect.Type) *StructProperties { } 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. @@ -728,8 +396,7 @@ func getPropertiesLocked(t reflect.Type) *StructProperties { } 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 + _, _, _, oots = om.XXX_OneofFuncs() // Interpret oneof metadata. prop.OneofTypes = make(map[string]*OneofProperties) @@ -779,30 +446,6 @@ func getPropertiesLocked(t reflect.Type) *StructProperties { 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. @@ -826,20 +469,42 @@ func EnumValueMap(enumType string) map[string]int32 { // 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) + protoTypedNils = make(map[string]Message) // a map from proto names to typed nil pointers + protoMapTypes = make(map[string]reflect.Type) // a map from proto names to map types + 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 { + if _, ok := protoTypedNils[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 + if v := reflect.ValueOf(x); v.Kind() == reflect.Ptr && v.Pointer() == 0 { + // Generated code always calls RegisterType with nil x. + // This check is just for extra safety. + protoTypedNils[name] = x + } else { + protoTypedNils[name] = reflect.Zero(t).Interface().(Message) + } + revProtoTypes[t] = name +} + +// RegisterMapType is called from generated code and maps from the fully qualified +// proto name to the native map type of the proto map definition. +func RegisterMapType(x interface{}, name string) { + if reflect.TypeOf(x).Kind() != reflect.Map { + panic(fmt.Sprintf("RegisterMapType(%T, %q); want map", x, name)) + } + if _, ok := protoMapTypes[name]; ok { + log.Printf("proto: duplicate proto type registered: %s", name) + return + } + t := reflect.TypeOf(x) + protoMapTypes[name] = t revProtoTypes[t] = name } @@ -855,7 +520,14 @@ func MessageName(x Message) string { } // MessageType returns the message type (pointer to struct) for a named message. -func MessageType(name string) reflect.Type { return protoTypes[name] } +// The type is not guaranteed to implement proto.Message if the name refers to a +// map entry. +func MessageType(name string) reflect.Type { + if t, ok := protoTypedNils[name]; ok { + return reflect.TypeOf(t) + } + return protoMapTypes[name] +} // A registry of all linked proto files. var ( diff --git a/vendor/github.com/golang/protobuf/proto/table_marshal.go b/vendor/github.com/golang/protobuf/proto/table_marshal.go new file mode 100644 index 00000000000..0f212b3029d --- /dev/null +++ b/vendor/github.com/golang/protobuf/proto/table_marshal.go @@ -0,0 +1,2681 @@ +// 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 + +import ( + "errors" + "fmt" + "math" + "reflect" + "sort" + "strconv" + "strings" + "sync" + "sync/atomic" + "unicode/utf8" +) + +// a sizer takes a pointer to a field and the size of its tag, computes the size of +// the encoded data. +type sizer func(pointer, int) int + +// a marshaler takes a byte slice, a pointer to a field, and its tag (in wire format), +// marshals the field to the end of the slice, returns the slice and error (if any). +type marshaler func(b []byte, ptr pointer, wiretag uint64, deterministic bool) ([]byte, error) + +// marshalInfo is the information used for marshaling a message. +type marshalInfo struct { + typ reflect.Type + fields []*marshalFieldInfo + unrecognized field // offset of XXX_unrecognized + extensions field // offset of XXX_InternalExtensions + v1extensions field // offset of XXX_extensions + sizecache field // offset of XXX_sizecache + initialized int32 // 0 -- only typ is set, 1 -- fully initialized + messageset bool // uses message set wire format + hasmarshaler bool // has custom marshaler + sync.RWMutex // protect extElems map, also for initialization + extElems map[int32]*marshalElemInfo // info of extension elements +} + +// marshalFieldInfo is the information used for marshaling a field of a message. +type marshalFieldInfo struct { + field field + wiretag uint64 // tag in wire format + tagsize int // size of tag in wire format + sizer sizer + marshaler marshaler + isPointer bool + required bool // field is required + name string // name of the field, for error reporting + oneofElems map[reflect.Type]*marshalElemInfo // info of oneof elements +} + +// marshalElemInfo is the information used for marshaling an extension or oneof element. +type marshalElemInfo struct { + wiretag uint64 // tag in wire format + tagsize int // size of tag in wire format + sizer sizer + marshaler marshaler + isptr bool // elem is pointer typed, thus interface of this type is a direct interface (extension only) +} + +var ( + marshalInfoMap = map[reflect.Type]*marshalInfo{} + marshalInfoLock sync.Mutex +) + +// getMarshalInfo returns the information to marshal a given type of message. +// The info it returns may not necessarily initialized. +// t is the type of the message (NOT the pointer to it). +func getMarshalInfo(t reflect.Type) *marshalInfo { + marshalInfoLock.Lock() + u, ok := marshalInfoMap[t] + if !ok { + u = &marshalInfo{typ: t} + marshalInfoMap[t] = u + } + marshalInfoLock.Unlock() + return u +} + +// Size is the entry point from generated code, +// and should be ONLY called by generated code. +// It computes the size of encoded data of msg. +// a is a pointer to a place to store cached marshal info. +func (a *InternalMessageInfo) Size(msg Message) int { + u := getMessageMarshalInfo(msg, a) + ptr := toPointer(&msg) + if ptr.isNil() { + // We get here if msg is a typed nil ((*SomeMessage)(nil)), + // so it satisfies the interface, and msg == nil wouldn't + // catch it. We don't want crash in this case. + return 0 + } + return u.size(ptr) +} + +// Marshal is the entry point from generated code, +// and should be ONLY called by generated code. +// It marshals msg to the end of b. +// a is a pointer to a place to store cached marshal info. +func (a *InternalMessageInfo) Marshal(b []byte, msg Message, deterministic bool) ([]byte, error) { + u := getMessageMarshalInfo(msg, a) + ptr := toPointer(&msg) + if ptr.isNil() { + // We get here if msg is a typed nil ((*SomeMessage)(nil)), + // so it satisfies the interface, and msg == nil wouldn't + // catch it. We don't want crash in this case. + return b, ErrNil + } + return u.marshal(b, ptr, deterministic) +} + +func getMessageMarshalInfo(msg interface{}, a *InternalMessageInfo) *marshalInfo { + // u := a.marshal, but atomically. + // We use an atomic here to ensure memory consistency. + u := atomicLoadMarshalInfo(&a.marshal) + if u == nil { + // Get marshal information from type of message. + t := reflect.ValueOf(msg).Type() + if t.Kind() != reflect.Ptr { + panic(fmt.Sprintf("cannot handle non-pointer message type %v", t)) + } + u = getMarshalInfo(t.Elem()) + // Store it in the cache for later users. + // a.marshal = u, but atomically. + atomicStoreMarshalInfo(&a.marshal, u) + } + return u +} + +// size is the main function to compute the size of the encoded data of a message. +// ptr is the pointer to the message. +func (u *marshalInfo) size(ptr pointer) int { + if atomic.LoadInt32(&u.initialized) == 0 { + u.computeMarshalInfo() + } + + // If the message can marshal itself, let it do it, for compatibility. + // NOTE: This is not efficient. + if u.hasmarshaler { + m := ptr.asPointerTo(u.typ).Interface().(Marshaler) + b, _ := m.Marshal() + return len(b) + } + + n := 0 + for _, f := range u.fields { + if f.isPointer && ptr.offset(f.field).getPointer().isNil() { + // nil pointer always marshals to nothing + continue + } + n += f.sizer(ptr.offset(f.field), f.tagsize) + } + if u.extensions.IsValid() { + e := ptr.offset(u.extensions).toExtensions() + if u.messageset { + n += u.sizeMessageSet(e) + } else { + n += u.sizeExtensions(e) + } + } + if u.v1extensions.IsValid() { + m := *ptr.offset(u.v1extensions).toOldExtensions() + n += u.sizeV1Extensions(m) + } + if u.unrecognized.IsValid() { + s := *ptr.offset(u.unrecognized).toBytes() + n += len(s) + } + // cache the result for use in marshal + if u.sizecache.IsValid() { + atomic.StoreInt32(ptr.offset(u.sizecache).toInt32(), int32(n)) + } + return n +} + +// cachedsize gets the size from cache. If there is no cache (i.e. message is not generated), +// fall back to compute the size. +func (u *marshalInfo) cachedsize(ptr pointer) int { + if u.sizecache.IsValid() { + return int(atomic.LoadInt32(ptr.offset(u.sizecache).toInt32())) + } + return u.size(ptr) +} + +// marshal is the main function to marshal a message. It takes a byte slice and appends +// the encoded data to the end of the slice, returns the slice and error (if any). +// ptr is the pointer to the message. +// If deterministic is true, map is marshaled in deterministic order. +func (u *marshalInfo) marshal(b []byte, ptr pointer, deterministic bool) ([]byte, error) { + if atomic.LoadInt32(&u.initialized) == 0 { + u.computeMarshalInfo() + } + + // If the message can marshal itself, let it do it, for compatibility. + // NOTE: This is not efficient. + if u.hasmarshaler { + m := ptr.asPointerTo(u.typ).Interface().(Marshaler) + b1, err := m.Marshal() + b = append(b, b1...) + return b, err + } + + var err, errreq error + // The old marshaler encodes extensions at beginning. + if u.extensions.IsValid() { + e := ptr.offset(u.extensions).toExtensions() + if u.messageset { + b, err = u.appendMessageSet(b, e, deterministic) + } else { + b, err = u.appendExtensions(b, e, deterministic) + } + if err != nil { + return b, err + } + } + if u.v1extensions.IsValid() { + m := *ptr.offset(u.v1extensions).toOldExtensions() + b, err = u.appendV1Extensions(b, m, deterministic) + if err != nil { + return b, err + } + } + for _, f := range u.fields { + if f.required && errreq == nil { + if ptr.offset(f.field).getPointer().isNil() { + // Required field is not set. + // We record the error but keep going, to give a complete marshaling. + errreq = &RequiredNotSetError{f.name} + continue + } + } + if f.isPointer && ptr.offset(f.field).getPointer().isNil() { + // nil pointer always marshals to nothing + continue + } + b, err = f.marshaler(b, ptr.offset(f.field), f.wiretag, deterministic) + if err != nil { + if err1, ok := err.(*RequiredNotSetError); ok { + // Required field in submessage is not set. + // We record the error but keep going, to give a complete marshaling. + if errreq == nil { + errreq = &RequiredNotSetError{f.name + "." + err1.field} + } + continue + } + if err == errRepeatedHasNil { + err = errors.New("proto: repeated field " + f.name + " has nil element") + } + return b, err + } + } + if u.unrecognized.IsValid() { + s := *ptr.offset(u.unrecognized).toBytes() + b = append(b, s...) + } + return b, errreq +} + +// computeMarshalInfo initializes the marshal info. +func (u *marshalInfo) computeMarshalInfo() { + u.Lock() + defer u.Unlock() + if u.initialized != 0 { // non-atomic read is ok as it is protected by the lock + return + } + + t := u.typ + u.unrecognized = invalidField + u.extensions = invalidField + u.v1extensions = invalidField + u.sizecache = invalidField + + // If the message can marshal itself, let it do it, for compatibility. + // NOTE: This is not efficient. + if reflect.PtrTo(t).Implements(marshalerType) { + u.hasmarshaler = true + atomic.StoreInt32(&u.initialized, 1) + return + } + + // get oneof implementers + var oneofImplementers []interface{} + if m, ok := reflect.Zero(reflect.PtrTo(t)).Interface().(oneofMessage); ok { + _, _, _, oneofImplementers = m.XXX_OneofFuncs() + } + + n := t.NumField() + + // deal with XXX fields first + for i := 0; i < t.NumField(); i++ { + f := t.Field(i) + if !strings.HasPrefix(f.Name, "XXX_") { + continue + } + switch f.Name { + case "XXX_sizecache": + u.sizecache = toField(&f) + case "XXX_unrecognized": + u.unrecognized = toField(&f) + case "XXX_InternalExtensions": + u.extensions = toField(&f) + u.messageset = f.Tag.Get("protobuf_messageset") == "1" + case "XXX_extensions": + u.v1extensions = toField(&f) + case "XXX_NoUnkeyedLiteral": + // nothing to do + default: + panic("unknown XXX field: " + f.Name) + } + n-- + } + + // normal fields + fields := make([]marshalFieldInfo, n) // batch allocation + u.fields = make([]*marshalFieldInfo, 0, n) + for i, j := 0, 0; i < t.NumField(); i++ { + f := t.Field(i) + + if strings.HasPrefix(f.Name, "XXX_") { + continue + } + field := &fields[j] + j++ + field.name = f.Name + u.fields = append(u.fields, field) + if f.Tag.Get("protobuf_oneof") != "" { + field.computeOneofFieldInfo(&f, oneofImplementers) + continue + } + if f.Tag.Get("protobuf") == "" { + // field has no tag (not in generated message), ignore it + u.fields = u.fields[:len(u.fields)-1] + j-- + continue + } + field.computeMarshalFieldInfo(&f) + } + + // fields are marshaled in tag order on the wire. + sort.Sort(byTag(u.fields)) + + atomic.StoreInt32(&u.initialized, 1) +} + +// helper for sorting fields by tag +type byTag []*marshalFieldInfo + +func (a byTag) Len() int { return len(a) } +func (a byTag) Swap(i, j int) { a[i], a[j] = a[j], a[i] } +func (a byTag) Less(i, j int) bool { return a[i].wiretag < a[j].wiretag } + +// getExtElemInfo returns the information to marshal an extension element. +// The info it returns is initialized. +func (u *marshalInfo) getExtElemInfo(desc *ExtensionDesc) *marshalElemInfo { + // get from cache first + u.RLock() + e, ok := u.extElems[desc.Field] + u.RUnlock() + if ok { + return e + } + + t := reflect.TypeOf(desc.ExtensionType) // pointer or slice to basic type or struct + tags := strings.Split(desc.Tag, ",") + tag, err := strconv.Atoi(tags[1]) + if err != nil { + panic("tag is not an integer") + } + wt := wiretype(tags[0]) + sizer, marshaler := typeMarshaler(t, tags, false, false) + e = &marshalElemInfo{ + wiretag: uint64(tag)<<3 | wt, + tagsize: SizeVarint(uint64(tag) << 3), + sizer: sizer, + marshaler: marshaler, + isptr: t.Kind() == reflect.Ptr, + } + + // update cache + u.Lock() + if u.extElems == nil { + u.extElems = make(map[int32]*marshalElemInfo) + } + u.extElems[desc.Field] = e + u.Unlock() + return e +} + +// computeMarshalFieldInfo fills up the information to marshal a field. +func (fi *marshalFieldInfo) computeMarshalFieldInfo(f *reflect.StructField) { + // parse protobuf tag of the field. + // tag has format of "bytes,49,opt,name=foo,def=hello!" + tags := strings.Split(f.Tag.Get("protobuf"), ",") + if tags[0] == "" { + return + } + tag, err := strconv.Atoi(tags[1]) + if err != nil { + panic("tag is not an integer") + } + wt := wiretype(tags[0]) + if tags[2] == "req" { + fi.required = true + } + fi.setTag(f, tag, wt) + fi.setMarshaler(f, tags) +} + +func (fi *marshalFieldInfo) computeOneofFieldInfo(f *reflect.StructField, oneofImplementers []interface{}) { + fi.field = toField(f) + fi.wiretag = 1<<31 - 1 // Use a large tag number, make oneofs sorted at the end. This tag will not appear on the wire. + fi.isPointer = true + fi.sizer, fi.marshaler = makeOneOfMarshaler(fi, f) + fi.oneofElems = make(map[reflect.Type]*marshalElemInfo) + + ityp := f.Type // interface type + for _, o := range oneofImplementers { + t := reflect.TypeOf(o) + if !t.Implements(ityp) { + continue + } + sf := t.Elem().Field(0) // oneof implementer is a struct with a single field + tags := strings.Split(sf.Tag.Get("protobuf"), ",") + tag, err := strconv.Atoi(tags[1]) + if err != nil { + panic("tag is not an integer") + } + wt := wiretype(tags[0]) + sizer, marshaler := typeMarshaler(sf.Type, tags, false, true) // oneof should not omit any zero value + fi.oneofElems[t.Elem()] = &marshalElemInfo{ + wiretag: uint64(tag)<<3 | wt, + tagsize: SizeVarint(uint64(tag) << 3), + sizer: sizer, + marshaler: marshaler, + } + } +} + +type oneofMessage interface { + XXX_OneofFuncs() (func(Message, *Buffer) error, func(Message, int, int, *Buffer) (bool, error), func(Message) int, []interface{}) +} + +// wiretype returns the wire encoding of the type. +func wiretype(encoding string) uint64 { + switch encoding { + case "fixed32": + return WireFixed32 + case "fixed64": + return WireFixed64 + case "varint", "zigzag32", "zigzag64": + return WireVarint + case "bytes": + return WireBytes + case "group": + return WireStartGroup + } + panic("unknown wire type " + encoding) +} + +// setTag fills up the tag (in wire format) and its size in the info of a field. +func (fi *marshalFieldInfo) setTag(f *reflect.StructField, tag int, wt uint64) { + fi.field = toField(f) + fi.wiretag = uint64(tag)<<3 | wt + fi.tagsize = SizeVarint(uint64(tag) << 3) +} + +// setMarshaler fills up the sizer and marshaler in the info of a field. +func (fi *marshalFieldInfo) setMarshaler(f *reflect.StructField, tags []string) { + switch f.Type.Kind() { + case reflect.Map: + // map field + fi.isPointer = true + fi.sizer, fi.marshaler = makeMapMarshaler(f) + return + case reflect.Ptr, reflect.Slice: + fi.isPointer = true + } + fi.sizer, fi.marshaler = typeMarshaler(f.Type, tags, true, false) +} + +// typeMarshaler returns the sizer and marshaler of a given field. +// t is the type of the field. +// tags is the generated "protobuf" tag of the field. +// If nozero is true, zero value is not marshaled to the wire. +// If oneof is true, it is a oneof field. +func typeMarshaler(t reflect.Type, tags []string, nozero, oneof bool) (sizer, marshaler) { + encoding := tags[0] + + pointer := false + slice := false + if t.Kind() == reflect.Slice && t.Elem().Kind() != reflect.Uint8 { + slice = true + t = t.Elem() + } + if t.Kind() == reflect.Ptr { + pointer = true + t = t.Elem() + } + + packed := false + proto3 := false + for i := 2; i < len(tags); i++ { + if tags[i] == "packed" { + packed = true + } + if tags[i] == "proto3" { + proto3 = true + } + } + + switch t.Kind() { + case reflect.Bool: + if pointer { + return sizeBoolPtr, appendBoolPtr + } + if slice { + if packed { + return sizeBoolPackedSlice, appendBoolPackedSlice + } + return sizeBoolSlice, appendBoolSlice + } + if nozero { + return sizeBoolValueNoZero, appendBoolValueNoZero + } + return sizeBoolValue, appendBoolValue + case reflect.Uint32: + switch encoding { + case "fixed32": + if pointer { + return sizeFixed32Ptr, appendFixed32Ptr + } + if slice { + if packed { + return sizeFixed32PackedSlice, appendFixed32PackedSlice + } + return sizeFixed32Slice, appendFixed32Slice + } + if nozero { + return sizeFixed32ValueNoZero, appendFixed32ValueNoZero + } + return sizeFixed32Value, appendFixed32Value + case "varint": + if pointer { + return sizeVarint32Ptr, appendVarint32Ptr + } + if slice { + if packed { + return sizeVarint32PackedSlice, appendVarint32PackedSlice + } + return sizeVarint32Slice, appendVarint32Slice + } + if nozero { + return sizeVarint32ValueNoZero, appendVarint32ValueNoZero + } + return sizeVarint32Value, appendVarint32Value + } + case reflect.Int32: + switch encoding { + case "fixed32": + if pointer { + return sizeFixedS32Ptr, appendFixedS32Ptr + } + if slice { + if packed { + return sizeFixedS32PackedSlice, appendFixedS32PackedSlice + } + return sizeFixedS32Slice, appendFixedS32Slice + } + if nozero { + return sizeFixedS32ValueNoZero, appendFixedS32ValueNoZero + } + return sizeFixedS32Value, appendFixedS32Value + case "varint": + if pointer { + return sizeVarintS32Ptr, appendVarintS32Ptr + } + if slice { + if packed { + return sizeVarintS32PackedSlice, appendVarintS32PackedSlice + } + return sizeVarintS32Slice, appendVarintS32Slice + } + if nozero { + return sizeVarintS32ValueNoZero, appendVarintS32ValueNoZero + } + return sizeVarintS32Value, appendVarintS32Value + case "zigzag32": + if pointer { + return sizeZigzag32Ptr, appendZigzag32Ptr + } + if slice { + if packed { + return sizeZigzag32PackedSlice, appendZigzag32PackedSlice + } + return sizeZigzag32Slice, appendZigzag32Slice + } + if nozero { + return sizeZigzag32ValueNoZero, appendZigzag32ValueNoZero + } + return sizeZigzag32Value, appendZigzag32Value + } + case reflect.Uint64: + switch encoding { + case "fixed64": + if pointer { + return sizeFixed64Ptr, appendFixed64Ptr + } + if slice { + if packed { + return sizeFixed64PackedSlice, appendFixed64PackedSlice + } + return sizeFixed64Slice, appendFixed64Slice + } + if nozero { + return sizeFixed64ValueNoZero, appendFixed64ValueNoZero + } + return sizeFixed64Value, appendFixed64Value + case "varint": + if pointer { + return sizeVarint64Ptr, appendVarint64Ptr + } + if slice { + if packed { + return sizeVarint64PackedSlice, appendVarint64PackedSlice + } + return sizeVarint64Slice, appendVarint64Slice + } + if nozero { + return sizeVarint64ValueNoZero, appendVarint64ValueNoZero + } + return sizeVarint64Value, appendVarint64Value + } + case reflect.Int64: + switch encoding { + case "fixed64": + if pointer { + return sizeFixedS64Ptr, appendFixedS64Ptr + } + if slice { + if packed { + return sizeFixedS64PackedSlice, appendFixedS64PackedSlice + } + return sizeFixedS64Slice, appendFixedS64Slice + } + if nozero { + return sizeFixedS64ValueNoZero, appendFixedS64ValueNoZero + } + return sizeFixedS64Value, appendFixedS64Value + case "varint": + if pointer { + return sizeVarintS64Ptr, appendVarintS64Ptr + } + if slice { + if packed { + return sizeVarintS64PackedSlice, appendVarintS64PackedSlice + } + return sizeVarintS64Slice, appendVarintS64Slice + } + if nozero { + return sizeVarintS64ValueNoZero, appendVarintS64ValueNoZero + } + return sizeVarintS64Value, appendVarintS64Value + case "zigzag64": + if pointer { + return sizeZigzag64Ptr, appendZigzag64Ptr + } + if slice { + if packed { + return sizeZigzag64PackedSlice, appendZigzag64PackedSlice + } + return sizeZigzag64Slice, appendZigzag64Slice + } + if nozero { + return sizeZigzag64ValueNoZero, appendZigzag64ValueNoZero + } + return sizeZigzag64Value, appendZigzag64Value + } + case reflect.Float32: + if pointer { + return sizeFloat32Ptr, appendFloat32Ptr + } + if slice { + if packed { + return sizeFloat32PackedSlice, appendFloat32PackedSlice + } + return sizeFloat32Slice, appendFloat32Slice + } + if nozero { + return sizeFloat32ValueNoZero, appendFloat32ValueNoZero + } + return sizeFloat32Value, appendFloat32Value + case reflect.Float64: + if pointer { + return sizeFloat64Ptr, appendFloat64Ptr + } + if slice { + if packed { + return sizeFloat64PackedSlice, appendFloat64PackedSlice + } + return sizeFloat64Slice, appendFloat64Slice + } + if nozero { + return sizeFloat64ValueNoZero, appendFloat64ValueNoZero + } + return sizeFloat64Value, appendFloat64Value + case reflect.String: + if pointer { + return sizeStringPtr, appendStringPtr + } + if slice { + return sizeStringSlice, appendStringSlice + } + if nozero { + return sizeStringValueNoZero, appendStringValueNoZero + } + return sizeStringValue, appendStringValue + case reflect.Slice: + if slice { + return sizeBytesSlice, appendBytesSlice + } + if oneof { + // Oneof bytes field may also have "proto3" tag. + // We want to marshal it as a oneof field. Do this + // check before the proto3 check. + return sizeBytesOneof, appendBytesOneof + } + if proto3 { + return sizeBytes3, appendBytes3 + } + return sizeBytes, appendBytes + case reflect.Struct: + switch encoding { + case "group": + if slice { + return makeGroupSliceMarshaler(getMarshalInfo(t)) + } + return makeGroupMarshaler(getMarshalInfo(t)) + case "bytes": + if slice { + return makeMessageSliceMarshaler(getMarshalInfo(t)) + } + return makeMessageMarshaler(getMarshalInfo(t)) + } + } + panic(fmt.Sprintf("unknown or mismatched type: type: %v, wire type: %v", t, encoding)) +} + +// Below are functions to size/marshal a specific type of a field. +// They are stored in the field's info, and called by function pointers. +// They have type sizer or marshaler. + +func sizeFixed32Value(_ pointer, tagsize int) int { + return 4 + tagsize +} +func sizeFixed32ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toUint32() + if v == 0 { + return 0 + } + return 4 + tagsize +} +func sizeFixed32Ptr(ptr pointer, tagsize int) int { + p := *ptr.toUint32Ptr() + if p == nil { + return 0 + } + return 4 + tagsize +} +func sizeFixed32Slice(ptr pointer, tagsize int) int { + s := *ptr.toUint32Slice() + return (4 + tagsize) * len(s) +} +func sizeFixed32PackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toUint32Slice() + if len(s) == 0 { + return 0 + } + return 4*len(s) + SizeVarint(uint64(4*len(s))) + tagsize +} +func sizeFixedS32Value(_ pointer, tagsize int) int { + return 4 + tagsize +} +func sizeFixedS32ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toInt32() + if v == 0 { + return 0 + } + return 4 + tagsize +} +func sizeFixedS32Ptr(ptr pointer, tagsize int) int { + p := ptr.getInt32Ptr() + if p == nil { + return 0 + } + return 4 + tagsize +} +func sizeFixedS32Slice(ptr pointer, tagsize int) int { + s := ptr.getInt32Slice() + return (4 + tagsize) * len(s) +} +func sizeFixedS32PackedSlice(ptr pointer, tagsize int) int { + s := ptr.getInt32Slice() + if len(s) == 0 { + return 0 + } + return 4*len(s) + SizeVarint(uint64(4*len(s))) + tagsize +} +func sizeFloat32Value(_ pointer, tagsize int) int { + return 4 + tagsize +} +func sizeFloat32ValueNoZero(ptr pointer, tagsize int) int { + v := math.Float32bits(*ptr.toFloat32()) + if v == 0 { + return 0 + } + return 4 + tagsize +} +func sizeFloat32Ptr(ptr pointer, tagsize int) int { + p := *ptr.toFloat32Ptr() + if p == nil { + return 0 + } + return 4 + tagsize +} +func sizeFloat32Slice(ptr pointer, tagsize int) int { + s := *ptr.toFloat32Slice() + return (4 + tagsize) * len(s) +} +func sizeFloat32PackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toFloat32Slice() + if len(s) == 0 { + return 0 + } + return 4*len(s) + SizeVarint(uint64(4*len(s))) + tagsize +} +func sizeFixed64Value(_ pointer, tagsize int) int { + return 8 + tagsize +} +func sizeFixed64ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toUint64() + if v == 0 { + return 0 + } + return 8 + tagsize +} +func sizeFixed64Ptr(ptr pointer, tagsize int) int { + p := *ptr.toUint64Ptr() + if p == nil { + return 0 + } + return 8 + tagsize +} +func sizeFixed64Slice(ptr pointer, tagsize int) int { + s := *ptr.toUint64Slice() + return (8 + tagsize) * len(s) +} +func sizeFixed64PackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toUint64Slice() + if len(s) == 0 { + return 0 + } + return 8*len(s) + SizeVarint(uint64(8*len(s))) + tagsize +} +func sizeFixedS64Value(_ pointer, tagsize int) int { + return 8 + tagsize +} +func sizeFixedS64ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toInt64() + if v == 0 { + return 0 + } + return 8 + tagsize +} +func sizeFixedS64Ptr(ptr pointer, tagsize int) int { + p := *ptr.toInt64Ptr() + if p == nil { + return 0 + } + return 8 + tagsize +} +func sizeFixedS64Slice(ptr pointer, tagsize int) int { + s := *ptr.toInt64Slice() + return (8 + tagsize) * len(s) +} +func sizeFixedS64PackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toInt64Slice() + if len(s) == 0 { + return 0 + } + return 8*len(s) + SizeVarint(uint64(8*len(s))) + tagsize +} +func sizeFloat64Value(_ pointer, tagsize int) int { + return 8 + tagsize +} +func sizeFloat64ValueNoZero(ptr pointer, tagsize int) int { + v := math.Float64bits(*ptr.toFloat64()) + if v == 0 { + return 0 + } + return 8 + tagsize +} +func sizeFloat64Ptr(ptr pointer, tagsize int) int { + p := *ptr.toFloat64Ptr() + if p == nil { + return 0 + } + return 8 + tagsize +} +func sizeFloat64Slice(ptr pointer, tagsize int) int { + s := *ptr.toFloat64Slice() + return (8 + tagsize) * len(s) +} +func sizeFloat64PackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toFloat64Slice() + if len(s) == 0 { + return 0 + } + return 8*len(s) + SizeVarint(uint64(8*len(s))) + tagsize +} +func sizeVarint32Value(ptr pointer, tagsize int) int { + v := *ptr.toUint32() + return SizeVarint(uint64(v)) + tagsize +} +func sizeVarint32ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toUint32() + if v == 0 { + return 0 + } + return SizeVarint(uint64(v)) + tagsize +} +func sizeVarint32Ptr(ptr pointer, tagsize int) int { + p := *ptr.toUint32Ptr() + if p == nil { + return 0 + } + return SizeVarint(uint64(*p)) + tagsize +} +func sizeVarint32Slice(ptr pointer, tagsize int) int { + s := *ptr.toUint32Slice() + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v)) + tagsize + } + return n +} +func sizeVarint32PackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toUint32Slice() + if len(s) == 0 { + return 0 + } + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v)) + } + return n + SizeVarint(uint64(n)) + tagsize +} +func sizeVarintS32Value(ptr pointer, tagsize int) int { + v := *ptr.toInt32() + return SizeVarint(uint64(v)) + tagsize +} +func sizeVarintS32ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toInt32() + if v == 0 { + return 0 + } + return SizeVarint(uint64(v)) + tagsize +} +func sizeVarintS32Ptr(ptr pointer, tagsize int) int { + p := ptr.getInt32Ptr() + if p == nil { + return 0 + } + return SizeVarint(uint64(*p)) + tagsize +} +func sizeVarintS32Slice(ptr pointer, tagsize int) int { + s := ptr.getInt32Slice() + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v)) + tagsize + } + return n +} +func sizeVarintS32PackedSlice(ptr pointer, tagsize int) int { + s := ptr.getInt32Slice() + if len(s) == 0 { + return 0 + } + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v)) + } + return n + SizeVarint(uint64(n)) + tagsize +} +func sizeVarint64Value(ptr pointer, tagsize int) int { + v := *ptr.toUint64() + return SizeVarint(v) + tagsize +} +func sizeVarint64ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toUint64() + if v == 0 { + return 0 + } + return SizeVarint(v) + tagsize +} +func sizeVarint64Ptr(ptr pointer, tagsize int) int { + p := *ptr.toUint64Ptr() + if p == nil { + return 0 + } + return SizeVarint(*p) + tagsize +} +func sizeVarint64Slice(ptr pointer, tagsize int) int { + s := *ptr.toUint64Slice() + n := 0 + for _, v := range s { + n += SizeVarint(v) + tagsize + } + return n +} +func sizeVarint64PackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toUint64Slice() + if len(s) == 0 { + return 0 + } + n := 0 + for _, v := range s { + n += SizeVarint(v) + } + return n + SizeVarint(uint64(n)) + tagsize +} +func sizeVarintS64Value(ptr pointer, tagsize int) int { + v := *ptr.toInt64() + return SizeVarint(uint64(v)) + tagsize +} +func sizeVarintS64ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toInt64() + if v == 0 { + return 0 + } + return SizeVarint(uint64(v)) + tagsize +} +func sizeVarintS64Ptr(ptr pointer, tagsize int) int { + p := *ptr.toInt64Ptr() + if p == nil { + return 0 + } + return SizeVarint(uint64(*p)) + tagsize +} +func sizeVarintS64Slice(ptr pointer, tagsize int) int { + s := *ptr.toInt64Slice() + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v)) + tagsize + } + return n +} +func sizeVarintS64PackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toInt64Slice() + if len(s) == 0 { + return 0 + } + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v)) + } + return n + SizeVarint(uint64(n)) + tagsize +} +func sizeZigzag32Value(ptr pointer, tagsize int) int { + v := *ptr.toInt32() + return SizeVarint(uint64((uint32(v)<<1)^uint32((int32(v)>>31)))) + tagsize +} +func sizeZigzag32ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toInt32() + if v == 0 { + return 0 + } + return SizeVarint(uint64((uint32(v)<<1)^uint32((int32(v)>>31)))) + tagsize +} +func sizeZigzag32Ptr(ptr pointer, tagsize int) int { + p := ptr.getInt32Ptr() + if p == nil { + return 0 + } + v := *p + return SizeVarint(uint64((uint32(v)<<1)^uint32((int32(v)>>31)))) + tagsize +} +func sizeZigzag32Slice(ptr pointer, tagsize int) int { + s := ptr.getInt32Slice() + n := 0 + for _, v := range s { + n += SizeVarint(uint64((uint32(v)<<1)^uint32((int32(v)>>31)))) + tagsize + } + return n +} +func sizeZigzag32PackedSlice(ptr pointer, tagsize int) int { + s := ptr.getInt32Slice() + if len(s) == 0 { + return 0 + } + n := 0 + for _, v := range s { + n += SizeVarint(uint64((uint32(v) << 1) ^ uint32((int32(v) >> 31)))) + } + return n + SizeVarint(uint64(n)) + tagsize +} +func sizeZigzag64Value(ptr pointer, tagsize int) int { + v := *ptr.toInt64() + return SizeVarint(uint64(v<<1)^uint64((int64(v)>>63))) + tagsize +} +func sizeZigzag64ValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toInt64() + if v == 0 { + return 0 + } + return SizeVarint(uint64(v<<1)^uint64((int64(v)>>63))) + tagsize +} +func sizeZigzag64Ptr(ptr pointer, tagsize int) int { + p := *ptr.toInt64Ptr() + if p == nil { + return 0 + } + v := *p + return SizeVarint(uint64(v<<1)^uint64((int64(v)>>63))) + tagsize +} +func sizeZigzag64Slice(ptr pointer, tagsize int) int { + s := *ptr.toInt64Slice() + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v<<1)^uint64((int64(v)>>63))) + tagsize + } + return n +} +func sizeZigzag64PackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toInt64Slice() + if len(s) == 0 { + return 0 + } + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v<<1) ^ uint64((int64(v) >> 63))) + } + return n + SizeVarint(uint64(n)) + tagsize +} +func sizeBoolValue(_ pointer, tagsize int) int { + return 1 + tagsize +} +func sizeBoolValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toBool() + if !v { + return 0 + } + return 1 + tagsize +} +func sizeBoolPtr(ptr pointer, tagsize int) int { + p := *ptr.toBoolPtr() + if p == nil { + return 0 + } + return 1 + tagsize +} +func sizeBoolSlice(ptr pointer, tagsize int) int { + s := *ptr.toBoolSlice() + return (1 + tagsize) * len(s) +} +func sizeBoolPackedSlice(ptr pointer, tagsize int) int { + s := *ptr.toBoolSlice() + if len(s) == 0 { + return 0 + } + return len(s) + SizeVarint(uint64(len(s))) + tagsize +} +func sizeStringValue(ptr pointer, tagsize int) int { + v := *ptr.toString() + return len(v) + SizeVarint(uint64(len(v))) + tagsize +} +func sizeStringValueNoZero(ptr pointer, tagsize int) int { + v := *ptr.toString() + if v == "" { + return 0 + } + return len(v) + SizeVarint(uint64(len(v))) + tagsize +} +func sizeStringPtr(ptr pointer, tagsize int) int { + p := *ptr.toStringPtr() + if p == nil { + return 0 + } + v := *p + return len(v) + SizeVarint(uint64(len(v))) + tagsize +} +func sizeStringSlice(ptr pointer, tagsize int) int { + s := *ptr.toStringSlice() + n := 0 + for _, v := range s { + n += len(v) + SizeVarint(uint64(len(v))) + tagsize + } + return n +} +func sizeBytes(ptr pointer, tagsize int) int { + v := *ptr.toBytes() + if v == nil { + return 0 + } + return len(v) + SizeVarint(uint64(len(v))) + tagsize +} +func sizeBytes3(ptr pointer, tagsize int) int { + v := *ptr.toBytes() + if len(v) == 0 { + return 0 + } + return len(v) + SizeVarint(uint64(len(v))) + tagsize +} +func sizeBytesOneof(ptr pointer, tagsize int) int { + v := *ptr.toBytes() + return len(v) + SizeVarint(uint64(len(v))) + tagsize +} +func sizeBytesSlice(ptr pointer, tagsize int) int { + s := *ptr.toBytesSlice() + n := 0 + for _, v := range s { + n += len(v) + SizeVarint(uint64(len(v))) + tagsize + } + return n +} + +// appendFixed32 appends an encoded fixed32 to b. +func appendFixed32(b []byte, v uint32) []byte { + b = append(b, + byte(v), + byte(v>>8), + byte(v>>16), + byte(v>>24)) + return b +} + +// appendFixed64 appends an encoded fixed64 to b. +func appendFixed64(b []byte, v uint64) []byte { + b = append(b, + byte(v), + byte(v>>8), + byte(v>>16), + byte(v>>24), + byte(v>>32), + byte(v>>40), + byte(v>>48), + byte(v>>56)) + return b +} + +// appendVarint appends an encoded varint to b. +func appendVarint(b []byte, v uint64) []byte { + // TODO: make 1-byte (maybe 2-byte) case inline-able, once we + // have non-leaf inliner. + switch { + case v < 1<<7: + b = append(b, byte(v)) + case v < 1<<14: + b = append(b, + byte(v&0x7f|0x80), + byte(v>>7)) + case v < 1<<21: + b = append(b, + byte(v&0x7f|0x80), + byte((v>>7)&0x7f|0x80), + byte(v>>14)) + case v < 1<<28: + b = append(b, + byte(v&0x7f|0x80), + byte((v>>7)&0x7f|0x80), + byte((v>>14)&0x7f|0x80), + byte(v>>21)) + case v < 1<<35: + b = append(b, + byte(v&0x7f|0x80), + byte((v>>7)&0x7f|0x80), + byte((v>>14)&0x7f|0x80), + byte((v>>21)&0x7f|0x80), + byte(v>>28)) + case v < 1<<42: + b = append(b, + byte(v&0x7f|0x80), + byte((v>>7)&0x7f|0x80), + byte((v>>14)&0x7f|0x80), + byte((v>>21)&0x7f|0x80), + byte((v>>28)&0x7f|0x80), + byte(v>>35)) + case v < 1<<49: + b = append(b, + byte(v&0x7f|0x80), + byte((v>>7)&0x7f|0x80), + byte((v>>14)&0x7f|0x80), + byte((v>>21)&0x7f|0x80), + byte((v>>28)&0x7f|0x80), + byte((v>>35)&0x7f|0x80), + byte(v>>42)) + case v < 1<<56: + b = append(b, + byte(v&0x7f|0x80), + byte((v>>7)&0x7f|0x80), + byte((v>>14)&0x7f|0x80), + byte((v>>21)&0x7f|0x80), + byte((v>>28)&0x7f|0x80), + byte((v>>35)&0x7f|0x80), + byte((v>>42)&0x7f|0x80), + byte(v>>49)) + case v < 1<<63: + b = append(b, + byte(v&0x7f|0x80), + byte((v>>7)&0x7f|0x80), + byte((v>>14)&0x7f|0x80), + byte((v>>21)&0x7f|0x80), + byte((v>>28)&0x7f|0x80), + byte((v>>35)&0x7f|0x80), + byte((v>>42)&0x7f|0x80), + byte((v>>49)&0x7f|0x80), + byte(v>>56)) + default: + b = append(b, + byte(v&0x7f|0x80), + byte((v>>7)&0x7f|0x80), + byte((v>>14)&0x7f|0x80), + byte((v>>21)&0x7f|0x80), + byte((v>>28)&0x7f|0x80), + byte((v>>35)&0x7f|0x80), + byte((v>>42)&0x7f|0x80), + byte((v>>49)&0x7f|0x80), + byte((v>>56)&0x7f|0x80), + 1) + } + return b +} + +func appendFixed32Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toUint32() + b = appendVarint(b, wiretag) + b = appendFixed32(b, v) + return b, nil +} +func appendFixed32ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toUint32() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed32(b, v) + return b, nil +} +func appendFixed32Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toUint32Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed32(b, *p) + return b, nil +} +func appendFixed32Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toUint32Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendFixed32(b, v) + } + return b, nil +} +func appendFixed32PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toUint32Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + b = appendVarint(b, uint64(4*len(s))) + for _, v := range s { + b = appendFixed32(b, v) + } + return b, nil +} +func appendFixedS32Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt32() + b = appendVarint(b, wiretag) + b = appendFixed32(b, uint32(v)) + return b, nil +} +func appendFixedS32ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt32() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed32(b, uint32(v)) + return b, nil +} +func appendFixedS32Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := ptr.getInt32Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed32(b, uint32(*p)) + return b, nil +} +func appendFixedS32Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := ptr.getInt32Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendFixed32(b, uint32(v)) + } + return b, nil +} +func appendFixedS32PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := ptr.getInt32Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + b = appendVarint(b, uint64(4*len(s))) + for _, v := range s { + b = appendFixed32(b, uint32(v)) + } + return b, nil +} +func appendFloat32Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := math.Float32bits(*ptr.toFloat32()) + b = appendVarint(b, wiretag) + b = appendFixed32(b, v) + return b, nil +} +func appendFloat32ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := math.Float32bits(*ptr.toFloat32()) + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed32(b, v) + return b, nil +} +func appendFloat32Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toFloat32Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed32(b, math.Float32bits(*p)) + return b, nil +} +func appendFloat32Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toFloat32Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendFixed32(b, math.Float32bits(v)) + } + return b, nil +} +func appendFloat32PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toFloat32Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + b = appendVarint(b, uint64(4*len(s))) + for _, v := range s { + b = appendFixed32(b, math.Float32bits(v)) + } + return b, nil +} +func appendFixed64Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toUint64() + b = appendVarint(b, wiretag) + b = appendFixed64(b, v) + return b, nil +} +func appendFixed64ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toUint64() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed64(b, v) + return b, nil +} +func appendFixed64Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toUint64Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed64(b, *p) + return b, nil +} +func appendFixed64Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toUint64Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendFixed64(b, v) + } + return b, nil +} +func appendFixed64PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toUint64Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + b = appendVarint(b, uint64(8*len(s))) + for _, v := range s { + b = appendFixed64(b, v) + } + return b, nil +} +func appendFixedS64Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt64() + b = appendVarint(b, wiretag) + b = appendFixed64(b, uint64(v)) + return b, nil +} +func appendFixedS64ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt64() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed64(b, uint64(v)) + return b, nil +} +func appendFixedS64Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toInt64Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed64(b, uint64(*p)) + return b, nil +} +func appendFixedS64Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toInt64Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendFixed64(b, uint64(v)) + } + return b, nil +} +func appendFixedS64PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toInt64Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + b = appendVarint(b, uint64(8*len(s))) + for _, v := range s { + b = appendFixed64(b, uint64(v)) + } + return b, nil +} +func appendFloat64Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := math.Float64bits(*ptr.toFloat64()) + b = appendVarint(b, wiretag) + b = appendFixed64(b, v) + return b, nil +} +func appendFloat64ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := math.Float64bits(*ptr.toFloat64()) + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed64(b, v) + return b, nil +} +func appendFloat64Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toFloat64Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendFixed64(b, math.Float64bits(*p)) + return b, nil +} +func appendFloat64Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toFloat64Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendFixed64(b, math.Float64bits(v)) + } + return b, nil +} +func appendFloat64PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toFloat64Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + b = appendVarint(b, uint64(8*len(s))) + for _, v := range s { + b = appendFixed64(b, math.Float64bits(v)) + } + return b, nil +} +func appendVarint32Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toUint32() + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v)) + return b, nil +} +func appendVarint32ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toUint32() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v)) + return b, nil +} +func appendVarint32Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toUint32Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(*p)) + return b, nil +} +func appendVarint32Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toUint32Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v)) + } + return b, nil +} +func appendVarint32PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toUint32Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + // compute size + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v)) + } + b = appendVarint(b, uint64(n)) + for _, v := range s { + b = appendVarint(b, uint64(v)) + } + return b, nil +} +func appendVarintS32Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt32() + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v)) + return b, nil +} +func appendVarintS32ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt32() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v)) + return b, nil +} +func appendVarintS32Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := ptr.getInt32Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(*p)) + return b, nil +} +func appendVarintS32Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := ptr.getInt32Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v)) + } + return b, nil +} +func appendVarintS32PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := ptr.getInt32Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + // compute size + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v)) + } + b = appendVarint(b, uint64(n)) + for _, v := range s { + b = appendVarint(b, uint64(v)) + } + return b, nil +} +func appendVarint64Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toUint64() + b = appendVarint(b, wiretag) + b = appendVarint(b, v) + return b, nil +} +func appendVarint64ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toUint64() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, v) + return b, nil +} +func appendVarint64Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toUint64Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, *p) + return b, nil +} +func appendVarint64Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toUint64Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendVarint(b, v) + } + return b, nil +} +func appendVarint64PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toUint64Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + // compute size + n := 0 + for _, v := range s { + n += SizeVarint(v) + } + b = appendVarint(b, uint64(n)) + for _, v := range s { + b = appendVarint(b, v) + } + return b, nil +} +func appendVarintS64Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt64() + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v)) + return b, nil +} +func appendVarintS64ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt64() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v)) + return b, nil +} +func appendVarintS64Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toInt64Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(*p)) + return b, nil +} +func appendVarintS64Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toInt64Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v)) + } + return b, nil +} +func appendVarintS64PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toInt64Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + // compute size + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v)) + } + b = appendVarint(b, uint64(n)) + for _, v := range s { + b = appendVarint(b, uint64(v)) + } + return b, nil +} +func appendZigzag32Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt32() + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64((uint32(v)<<1)^uint32((int32(v)>>31)))) + return b, nil +} +func appendZigzag32ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt32() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64((uint32(v)<<1)^uint32((int32(v)>>31)))) + return b, nil +} +func appendZigzag32Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := ptr.getInt32Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + v := *p + b = appendVarint(b, uint64((uint32(v)<<1)^uint32((int32(v)>>31)))) + return b, nil +} +func appendZigzag32Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := ptr.getInt32Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64((uint32(v)<<1)^uint32((int32(v)>>31)))) + } + return b, nil +} +func appendZigzag32PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := ptr.getInt32Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + // compute size + n := 0 + for _, v := range s { + n += SizeVarint(uint64((uint32(v) << 1) ^ uint32((int32(v) >> 31)))) + } + b = appendVarint(b, uint64(n)) + for _, v := range s { + b = appendVarint(b, uint64((uint32(v)<<1)^uint32((int32(v)>>31)))) + } + return b, nil +} +func appendZigzag64Value(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt64() + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v<<1)^uint64((int64(v)>>63))) + return b, nil +} +func appendZigzag64ValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toInt64() + if v == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v<<1)^uint64((int64(v)>>63))) + return b, nil +} +func appendZigzag64Ptr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toInt64Ptr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + v := *p + b = appendVarint(b, uint64(v<<1)^uint64((int64(v)>>63))) + return b, nil +} +func appendZigzag64Slice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toInt64Slice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(v<<1)^uint64((int64(v)>>63))) + } + return b, nil +} +func appendZigzag64PackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toInt64Slice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + // compute size + n := 0 + for _, v := range s { + n += SizeVarint(uint64(v<<1) ^ uint64((int64(v) >> 63))) + } + b = appendVarint(b, uint64(n)) + for _, v := range s { + b = appendVarint(b, uint64(v<<1)^uint64((int64(v)>>63))) + } + return b, nil +} +func appendBoolValue(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toBool() + b = appendVarint(b, wiretag) + if v { + b = append(b, 1) + } else { + b = append(b, 0) + } + return b, nil +} +func appendBoolValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toBool() + if !v { + return b, nil + } + b = appendVarint(b, wiretag) + b = append(b, 1) + return b, nil +} + +func appendBoolPtr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toBoolPtr() + if p == nil { + return b, nil + } + b = appendVarint(b, wiretag) + if *p { + b = append(b, 1) + } else { + b = append(b, 0) + } + return b, nil +} +func appendBoolSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toBoolSlice() + for _, v := range s { + b = appendVarint(b, wiretag) + if v { + b = append(b, 1) + } else { + b = append(b, 0) + } + } + return b, nil +} +func appendBoolPackedSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toBoolSlice() + if len(s) == 0 { + return b, nil + } + b = appendVarint(b, wiretag&^7|WireBytes) + b = appendVarint(b, uint64(len(s))) + for _, v := range s { + if v { + b = append(b, 1) + } else { + b = append(b, 0) + } + } + return b, nil +} +func appendStringValue(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toString() + if !utf8.ValidString(v) { + return nil, errInvalidUTF8 + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(len(v))) + b = append(b, v...) + return b, nil +} +func appendStringValueNoZero(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toString() + if v == "" { + return b, nil + } + if !utf8.ValidString(v) { + return nil, errInvalidUTF8 + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(len(v))) + b = append(b, v...) + return b, nil +} +func appendStringPtr(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + p := *ptr.toStringPtr() + if p == nil { + return b, nil + } + v := *p + if !utf8.ValidString(v) { + return nil, errInvalidUTF8 + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(len(v))) + b = append(b, v...) + return b, nil +} +func appendStringSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toStringSlice() + for _, v := range s { + if !utf8.ValidString(v) { + return nil, errInvalidUTF8 + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(len(v))) + b = append(b, v...) + } + return b, nil +} +func appendBytes(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toBytes() + if v == nil { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(len(v))) + b = append(b, v...) + return b, nil +} +func appendBytes3(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toBytes() + if len(v) == 0 { + return b, nil + } + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(len(v))) + b = append(b, v...) + return b, nil +} +func appendBytesOneof(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + v := *ptr.toBytes() + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(len(v))) + b = append(b, v...) + return b, nil +} +func appendBytesSlice(b []byte, ptr pointer, wiretag uint64, _ bool) ([]byte, error) { + s := *ptr.toBytesSlice() + for _, v := range s { + b = appendVarint(b, wiretag) + b = appendVarint(b, uint64(len(v))) + b = append(b, v...) + } + return b, nil +} + +// makeGroupMarshaler returns the sizer and marshaler for a group. +// u is the marshal info of the underlying message. +func makeGroupMarshaler(u *marshalInfo) (sizer, marshaler) { + return func(ptr pointer, tagsize int) int { + p := ptr.getPointer() + if p.isNil() { + return 0 + } + return u.size(p) + 2*tagsize + }, + func(b []byte, ptr pointer, wiretag uint64, deterministic bool) ([]byte, error) { + p := ptr.getPointer() + if p.isNil() { + return b, nil + } + var err error + b = appendVarint(b, wiretag) // start group + b, err = u.marshal(b, p, deterministic) + b = appendVarint(b, wiretag+(WireEndGroup-WireStartGroup)) // end group + return b, err + } +} + +// makeGroupSliceMarshaler returns the sizer and marshaler for a group slice. +// u is the marshal info of the underlying message. +func makeGroupSliceMarshaler(u *marshalInfo) (sizer, marshaler) { + return func(ptr pointer, tagsize int) int { + s := ptr.getPointerSlice() + n := 0 + for _, v := range s { + if v.isNil() { + continue + } + n += u.size(v) + 2*tagsize + } + return n + }, + func(b []byte, ptr pointer, wiretag uint64, deterministic bool) ([]byte, error) { + s := ptr.getPointerSlice() + var err, errreq error + for _, v := range s { + if v.isNil() { + return b, errRepeatedHasNil + } + b = appendVarint(b, wiretag) // start group + b, err = u.marshal(b, v, deterministic) + b = appendVarint(b, wiretag+(WireEndGroup-WireStartGroup)) // end group + if err != nil { + if _, ok := err.(*RequiredNotSetError); ok { + // Required field in submessage is not set. + // We record the error but keep going, to give a complete marshaling. + if errreq == nil { + errreq = err + } + continue + } + if err == ErrNil { + err = errRepeatedHasNil + } + return b, err + } + } + return b, errreq + } +} + +// makeMessageMarshaler returns the sizer and marshaler for a message field. +// u is the marshal info of the message. +func makeMessageMarshaler(u *marshalInfo) (sizer, marshaler) { + return func(ptr pointer, tagsize int) int { + p := ptr.getPointer() + if p.isNil() { + return 0 + } + siz := u.size(p) + return siz + SizeVarint(uint64(siz)) + tagsize + }, + func(b []byte, ptr pointer, wiretag uint64, deterministic bool) ([]byte, error) { + p := ptr.getPointer() + if p.isNil() { + return b, nil + } + b = appendVarint(b, wiretag) + siz := u.cachedsize(p) + b = appendVarint(b, uint64(siz)) + return u.marshal(b, p, deterministic) + } +} + +// makeMessageSliceMarshaler returns the sizer and marshaler for a message slice. +// u is the marshal info of the message. +func makeMessageSliceMarshaler(u *marshalInfo) (sizer, marshaler) { + return func(ptr pointer, tagsize int) int { + s := ptr.getPointerSlice() + n := 0 + for _, v := range s { + if v.isNil() { + continue + } + siz := u.size(v) + n += siz + SizeVarint(uint64(siz)) + tagsize + } + return n + }, + func(b []byte, ptr pointer, wiretag uint64, deterministic bool) ([]byte, error) { + s := ptr.getPointerSlice() + var err, errreq error + for _, v := range s { + if v.isNil() { + return b, errRepeatedHasNil + } + b = appendVarint(b, wiretag) + siz := u.cachedsize(v) + b = appendVarint(b, uint64(siz)) + b, err = u.marshal(b, v, deterministic) + + if err != nil { + if _, ok := err.(*RequiredNotSetError); ok { + // Required field in submessage is not set. + // We record the error but keep going, to give a complete marshaling. + if errreq == nil { + errreq = err + } + continue + } + if err == ErrNil { + err = errRepeatedHasNil + } + return b, err + } + } + return b, errreq + } +} + +// makeMapMarshaler returns the sizer and marshaler for a map field. +// f is the pointer to the reflect data structure of the field. +func makeMapMarshaler(f *reflect.StructField) (sizer, marshaler) { + // figure out key and value type + t := f.Type + keyType := t.Key() + valType := t.Elem() + keyTags := strings.Split(f.Tag.Get("protobuf_key"), ",") + valTags := strings.Split(f.Tag.Get("protobuf_val"), ",") + keySizer, keyMarshaler := typeMarshaler(keyType, keyTags, false, false) // don't omit zero value in map + valSizer, valMarshaler := typeMarshaler(valType, valTags, false, false) // don't omit zero value in map + keyWireTag := 1<<3 | wiretype(keyTags[0]) + valWireTag := 2<<3 | wiretype(valTags[0]) + + // We create an interface to get the addresses of the map key and value. + // If value is pointer-typed, the interface is a direct interface, the + // idata itself is the value. Otherwise, the idata is the pointer to the + // value. + // Key cannot be pointer-typed. + valIsPtr := valType.Kind() == reflect.Ptr + return func(ptr pointer, tagsize int) int { + m := ptr.asPointerTo(t).Elem() // the map + n := 0 + for _, k := range m.MapKeys() { + ki := k.Interface() + vi := m.MapIndex(k).Interface() + kaddr := toAddrPointer(&ki, false) // pointer to key + vaddr := toAddrPointer(&vi, valIsPtr) // pointer to value + siz := keySizer(kaddr, 1) + valSizer(vaddr, 1) // tag of key = 1 (size=1), tag of val = 2 (size=1) + n += siz + SizeVarint(uint64(siz)) + tagsize + } + return n + }, + func(b []byte, ptr pointer, tag uint64, deterministic bool) ([]byte, error) { + m := ptr.asPointerTo(t).Elem() // the map + var err error + keys := m.MapKeys() + if len(keys) > 1 && deterministic { + sort.Sort(mapKeys(keys)) + } + for _, k := range keys { + ki := k.Interface() + vi := m.MapIndex(k).Interface() + kaddr := toAddrPointer(&ki, false) // pointer to key + vaddr := toAddrPointer(&vi, valIsPtr) // pointer to value + b = appendVarint(b, tag) + siz := keySizer(kaddr, 1) + valSizer(vaddr, 1) // tag of key = 1 (size=1), tag of val = 2 (size=1) + b = appendVarint(b, uint64(siz)) + b, err = keyMarshaler(b, kaddr, keyWireTag, deterministic) + if err != nil { + return b, err + } + b, err = valMarshaler(b, vaddr, valWireTag, deterministic) + if err != nil && err != ErrNil { // allow nil value in map + return b, err + } + } + return b, nil + } +} + +// makeOneOfMarshaler returns the sizer and marshaler for a oneof field. +// fi is the marshal info of the field. +// f is the pointer to the reflect data structure of the field. +func makeOneOfMarshaler(fi *marshalFieldInfo, f *reflect.StructField) (sizer, marshaler) { + // Oneof field is an interface. We need to get the actual data type on the fly. + t := f.Type + return func(ptr pointer, _ int) int { + p := ptr.getInterfacePointer() + if p.isNil() { + return 0 + } + v := ptr.asPointerTo(t).Elem().Elem().Elem() // *interface -> interface -> *struct -> struct + telem := v.Type() + e := fi.oneofElems[telem] + return e.sizer(p, e.tagsize) + }, + func(b []byte, ptr pointer, _ uint64, deterministic bool) ([]byte, error) { + p := ptr.getInterfacePointer() + if p.isNil() { + return b, nil + } + v := ptr.asPointerTo(t).Elem().Elem().Elem() // *interface -> interface -> *struct -> struct + telem := v.Type() + if telem.Field(0).Type.Kind() == reflect.Ptr && p.getPointer().isNil() { + return b, errOneofHasNil + } + e := fi.oneofElems[telem] + return e.marshaler(b, p, e.wiretag, deterministic) + } +} + +// sizeExtensions computes the size of encoded data for a XXX_InternalExtensions field. +func (u *marshalInfo) sizeExtensions(ext *XXX_InternalExtensions) int { + m, mu := ext.extensionsRead() + if m == nil { + return 0 + } + mu.Lock() + + n := 0 + 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. + ei := u.getExtElemInfo(e.desc) + v := e.value + p := toAddrPointer(&v, ei.isptr) + n += ei.sizer(p, ei.tagsize) + } + mu.Unlock() + return n +} + +// appendExtensions marshals a XXX_InternalExtensions field to the end of byte slice b. +func (u *marshalInfo) appendExtensions(b []byte, ext *XXX_InternalExtensions, deterministic bool) ([]byte, error) { + m, mu := ext.extensionsRead() + if m == nil { + return b, nil + } + mu.Lock() + defer mu.Unlock() + + var err error + + // Fast-path for common cases: zero or one extensions. + // Don't bother sorting the keys. + if len(m) <= 1 { + for _, e := range m { + if e.value == nil || e.desc == nil { + // Extension is only in its encoded form. + b = append(b, 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. + + ei := u.getExtElemInfo(e.desc) + v := e.value + p := toAddrPointer(&v, ei.isptr) + b, err = ei.marshaler(b, p, ei.wiretag, deterministic) + if err != nil { + return b, err + } + } + return b, nil + } + + // Sort the keys to provide a deterministic encoding. + // Not sure this is required, but the old code does it. + keys := make([]int, 0, len(m)) + for k := range m { + keys = append(keys, int(k)) + } + sort.Ints(keys) + + for _, k := range keys { + e := m[int32(k)] + if e.value == nil || e.desc == nil { + // Extension is only in its encoded form. + b = append(b, 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. + + ei := u.getExtElemInfo(e.desc) + v := e.value + p := toAddrPointer(&v, ei.isptr) + b, err = ei.marshaler(b, p, ei.wiretag, deterministic) + if err != nil { + return b, err + } + } + return b, nil +} + +// message set format is: +// message MessageSet { +// repeated group Item = 1 { +// required int32 type_id = 2; +// required string message = 3; +// }; +// } + +// sizeMessageSet computes the size of encoded data for a XXX_InternalExtensions field +// in message set format (above). +func (u *marshalInfo) sizeMessageSet(ext *XXX_InternalExtensions) int { + m, mu := ext.extensionsRead() + if m == nil { + return 0 + } + mu.Lock() + + n := 0 + for id, e := range m { + n += 2 // start group, end group. tag = 1 (size=1) + n += SizeVarint(uint64(id)) + 1 // type_id, tag = 2 (size=1) + + if e.value == nil || e.desc == nil { + // Extension is only in its encoded form. + msgWithLen := skipVarint(e.enc) // skip old tag, but leave the length varint + siz := len(msgWithLen) + n += siz + 1 // message, tag = 3 (size=1) + 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. + + ei := u.getExtElemInfo(e.desc) + v := e.value + p := toAddrPointer(&v, ei.isptr) + n += ei.sizer(p, 1) // message, tag = 3 (size=1) + } + mu.Unlock() + return n +} + +// appendMessageSet marshals a XXX_InternalExtensions field in message set format (above) +// to the end of byte slice b. +func (u *marshalInfo) appendMessageSet(b []byte, ext *XXX_InternalExtensions, deterministic bool) ([]byte, error) { + m, mu := ext.extensionsRead() + if m == nil { + return b, nil + } + mu.Lock() + defer mu.Unlock() + + var err error + + // Fast-path for common cases: zero or one extensions. + // Don't bother sorting the keys. + if len(m) <= 1 { + for id, e := range m { + b = append(b, 1<<3|WireStartGroup) + b = append(b, 2<<3|WireVarint) + b = appendVarint(b, uint64(id)) + + if e.value == nil || e.desc == nil { + // Extension is only in its encoded form. + msgWithLen := skipVarint(e.enc) // skip old tag, but leave the length varint + b = append(b, 3<<3|WireBytes) + b = append(b, msgWithLen...) + b = append(b, 1<<3|WireEndGroup) + 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. + + ei := u.getExtElemInfo(e.desc) + v := e.value + p := toAddrPointer(&v, ei.isptr) + b, err = ei.marshaler(b, p, 3<<3|WireBytes, deterministic) + if err != nil { + return b, err + } + b = append(b, 1<<3|WireEndGroup) + } + return b, nil + } + + // Sort the keys to provide a deterministic encoding. + keys := make([]int, 0, len(m)) + for k := range m { + keys = append(keys, int(k)) + } + sort.Ints(keys) + + for _, id := range keys { + e := m[int32(id)] + b = append(b, 1<<3|WireStartGroup) + b = append(b, 2<<3|WireVarint) + b = appendVarint(b, uint64(id)) + + if e.value == nil || e.desc == nil { + // Extension is only in its encoded form. + msgWithLen := skipVarint(e.enc) // skip old tag, but leave the length varint + b = append(b, 3<<3|WireBytes) + b = append(b, msgWithLen...) + b = append(b, 1<<3|WireEndGroup) + 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. + + ei := u.getExtElemInfo(e.desc) + v := e.value + p := toAddrPointer(&v, ei.isptr) + b, err = ei.marshaler(b, p, 3<<3|WireBytes, deterministic) + b = append(b, 1<<3|WireEndGroup) + if err != nil { + return b, err + } + } + return b, nil +} + +// sizeV1Extensions computes the size of encoded data for a V1-API extension field. +func (u *marshalInfo) sizeV1Extensions(m map[int32]Extension) int { + if m == nil { + return 0 + } + + n := 0 + 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. + + ei := u.getExtElemInfo(e.desc) + v := e.value + p := toAddrPointer(&v, ei.isptr) + n += ei.sizer(p, ei.tagsize) + } + return n +} + +// appendV1Extensions marshals a V1-API extension field to the end of byte slice b. +func (u *marshalInfo) appendV1Extensions(b []byte, m map[int32]Extension, deterministic bool) ([]byte, error) { + if m == nil { + return b, nil + } + + // Sort the keys to provide a deterministic encoding. + keys := make([]int, 0, len(m)) + for k := range m { + keys = append(keys, int(k)) + } + sort.Ints(keys) + + var err error + for _, k := range keys { + e := m[int32(k)] + if e.value == nil || e.desc == nil { + // Extension is only in its encoded form. + b = append(b, 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. + + ei := u.getExtElemInfo(e.desc) + v := e.value + p := toAddrPointer(&v, ei.isptr) + b, err = ei.marshaler(b, p, ei.wiretag, deterministic) + if err != nil { + return b, err + } + } + return b, nil +} + +// newMarshaler is the interface representing objects that can marshal themselves. +// +// This exists to support protoc-gen-go generated messages. +// The proto package will stop type-asserting to this interface in the future. +// +// DO NOT DEPEND ON THIS. +type newMarshaler interface { + XXX_Size() int + XXX_Marshal(b []byte, deterministic bool) ([]byte, error) +} + +// Size returns the encoded size of a protocol buffer message. +// This is the main entry point. +func Size(pb Message) int { + if m, ok := pb.(newMarshaler); ok { + return m.XXX_Size() + } + if m, ok := pb.(Marshaler); ok { + // If the message can marshal itself, let it do it, for compatibility. + // NOTE: This is not efficient. + b, _ := m.Marshal() + return len(b) + } + // in case somehow we didn't generate the wrapper + if pb == nil { + return 0 + } + var info InternalMessageInfo + return info.Size(pb) +} + +// Marshal takes a protocol buffer message +// and encodes it into the wire format, returning the data. +// This is the main entry point. +func Marshal(pb Message) ([]byte, error) { + if m, ok := pb.(newMarshaler); ok { + siz := m.XXX_Size() + b := make([]byte, 0, siz) + return m.XXX_Marshal(b, false) + } + if m, ok := pb.(Marshaler); ok { + // If the message can marshal itself, let it do it, for compatibility. + // NOTE: This is not efficient. + return m.Marshal() + } + // in case somehow we didn't generate the wrapper + if pb == nil { + return nil, ErrNil + } + var info InternalMessageInfo + siz := info.Size(pb) + b := make([]byte, 0, siz) + return info.Marshal(b, pb, false) +} + +// Marshal takes a protocol buffer message +// and encodes it into the wire format, writing the result to the +// Buffer. +// This is an alternative entry point. It is not necessary to use +// a Buffer for most applications. +func (p *Buffer) Marshal(pb Message) error { + var err error + if m, ok := pb.(newMarshaler); ok { + siz := m.XXX_Size() + p.grow(siz) // make sure buf has enough capacity + p.buf, err = m.XXX_Marshal(p.buf, p.deterministic) + return err + } + if m, ok := pb.(Marshaler); ok { + // If the message can marshal itself, let it do it, for compatibility. + // NOTE: This is not efficient. + b, err := m.Marshal() + p.buf = append(p.buf, b...) + return err + } + // in case somehow we didn't generate the wrapper + if pb == nil { + return ErrNil + } + var info InternalMessageInfo + siz := info.Size(pb) + p.grow(siz) // make sure buf has enough capacity + p.buf, err = info.Marshal(p.buf, pb, p.deterministic) + return err +} + +// grow grows the buffer's capacity, if necessary, to guarantee space for +// another n bytes. After grow(n), at least n bytes can be written to the +// buffer without another allocation. +func (p *Buffer) grow(n int) { + need := len(p.buf) + n + if need <= cap(p.buf) { + return + } + newCap := len(p.buf) * 2 + if newCap < need { + newCap = need + } + p.buf = append(make([]byte, 0, newCap), p.buf...) +} diff --git a/vendor/github.com/golang/protobuf/proto/table_merge.go b/vendor/github.com/golang/protobuf/proto/table_merge.go new file mode 100644 index 00000000000..5525def6a5d --- /dev/null +++ b/vendor/github.com/golang/protobuf/proto/table_merge.go @@ -0,0 +1,654 @@ +// 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 + +import ( + "fmt" + "reflect" + "strings" + "sync" + "sync/atomic" +) + +// Merge merges the src message into dst. +// This assumes that dst and src of the same type and are non-nil. +func (a *InternalMessageInfo) Merge(dst, src Message) { + mi := atomicLoadMergeInfo(&a.merge) + if mi == nil { + mi = getMergeInfo(reflect.TypeOf(dst).Elem()) + atomicStoreMergeInfo(&a.merge, mi) + } + mi.merge(toPointer(&dst), toPointer(&src)) +} + +type mergeInfo struct { + typ reflect.Type + + initialized int32 // 0: only typ is valid, 1: everything is valid + lock sync.Mutex + + fields []mergeFieldInfo + unrecognized field // Offset of XXX_unrecognized +} + +type mergeFieldInfo struct { + field field // Offset of field, guaranteed to be valid + + // isPointer reports whether the value in the field is a pointer. + // This is true for the following situations: + // * Pointer to struct + // * Pointer to basic type (proto2 only) + // * Slice (first value in slice header is a pointer) + // * String (first value in string header is a pointer) + isPointer bool + + // basicWidth reports the width of the field assuming that it is directly + // embedded in the struct (as is the case for basic types in proto3). + // The possible values are: + // 0: invalid + // 1: bool + // 4: int32, uint32, float32 + // 8: int64, uint64, float64 + basicWidth int + + // Where dst and src are pointers to the types being merged. + merge func(dst, src pointer) +} + +var ( + mergeInfoMap = map[reflect.Type]*mergeInfo{} + mergeInfoLock sync.Mutex +) + +func getMergeInfo(t reflect.Type) *mergeInfo { + mergeInfoLock.Lock() + defer mergeInfoLock.Unlock() + mi := mergeInfoMap[t] + if mi == nil { + mi = &mergeInfo{typ: t} + mergeInfoMap[t] = mi + } + return mi +} + +// merge merges src into dst assuming they are both of type *mi.typ. +func (mi *mergeInfo) merge(dst, src pointer) { + if dst.isNil() { + panic("proto: nil destination") + } + if src.isNil() { + return // Nothing to do. + } + + if atomic.LoadInt32(&mi.initialized) == 0 { + mi.computeMergeInfo() + } + + for _, fi := range mi.fields { + sfp := src.offset(fi.field) + + // As an optimization, we can avoid the merge function call cost + // if we know for sure that the source will have no effect + // by checking if it is the zero value. + if unsafeAllowed { + if fi.isPointer && sfp.getPointer().isNil() { // Could be slice or string + continue + } + if fi.basicWidth > 0 { + switch { + case fi.basicWidth == 1 && !*sfp.toBool(): + continue + case fi.basicWidth == 4 && *sfp.toUint32() == 0: + continue + case fi.basicWidth == 8 && *sfp.toUint64() == 0: + continue + } + } + } + + dfp := dst.offset(fi.field) + fi.merge(dfp, sfp) + } + + // TODO: Make this faster? + out := dst.asPointerTo(mi.typ).Elem() + in := src.asPointerTo(mi.typ).Elem() + if emIn, err := extendable(in.Addr().Interface()); err == nil { + emOut, _ := extendable(out.Addr().Interface()) + mIn, muIn := emIn.extensionsRead() + if mIn != nil { + mOut := emOut.extensionsWrite() + muIn.Lock() + mergeExtension(mOut, mIn) + muIn.Unlock() + } + } + + if mi.unrecognized.IsValid() { + if b := *src.offset(mi.unrecognized).toBytes(); len(b) > 0 { + *dst.offset(mi.unrecognized).toBytes() = append([]byte(nil), b...) + } + } +} + +func (mi *mergeInfo) computeMergeInfo() { + mi.lock.Lock() + defer mi.lock.Unlock() + if mi.initialized != 0 { + return + } + t := mi.typ + n := t.NumField() + + props := GetProperties(t) + for i := 0; i < n; i++ { + f := t.Field(i) + if strings.HasPrefix(f.Name, "XXX_") { + continue + } + + mfi := mergeFieldInfo{field: toField(&f)} + tf := f.Type + + // As an optimization, we can avoid the merge function call cost + // if we know for sure that the source will have no effect + // by checking if it is the zero value. + if unsafeAllowed { + switch tf.Kind() { + case reflect.Ptr, reflect.Slice, reflect.String: + // As a special case, we assume slices and strings are pointers + // since we know that the first field in the SliceSlice or + // StringHeader is a data pointer. + mfi.isPointer = true + case reflect.Bool: + mfi.basicWidth = 1 + case reflect.Int32, reflect.Uint32, reflect.Float32: + mfi.basicWidth = 4 + case reflect.Int64, reflect.Uint64, reflect.Float64: + mfi.basicWidth = 8 + } + } + + // Unwrap tf to get at its most basic type. + var isPointer, isSlice bool + if tf.Kind() == reflect.Slice && tf.Elem().Kind() != reflect.Uint8 { + isSlice = true + tf = tf.Elem() + } + if tf.Kind() == reflect.Ptr { + isPointer = true + tf = tf.Elem() + } + if isPointer && isSlice && tf.Kind() != reflect.Struct { + panic("both pointer and slice for basic type in " + tf.Name()) + } + + switch tf.Kind() { + case reflect.Int32: + switch { + case isSlice: // E.g., []int32 + mfi.merge = func(dst, src pointer) { + // NOTE: toInt32Slice is not defined (see pointer_reflect.go). + /* + sfsp := src.toInt32Slice() + if *sfsp != nil { + dfsp := dst.toInt32Slice() + *dfsp = append(*dfsp, *sfsp...) + if *dfsp == nil { + *dfsp = []int64{} + } + } + */ + sfs := src.getInt32Slice() + if sfs != nil { + dfs := dst.getInt32Slice() + dfs = append(dfs, sfs...) + if dfs == nil { + dfs = []int32{} + } + dst.setInt32Slice(dfs) + } + } + case isPointer: // E.g., *int32 + mfi.merge = func(dst, src pointer) { + // NOTE: toInt32Ptr is not defined (see pointer_reflect.go). + /* + sfpp := src.toInt32Ptr() + if *sfpp != nil { + dfpp := dst.toInt32Ptr() + if *dfpp == nil { + *dfpp = Int32(**sfpp) + } else { + **dfpp = **sfpp + } + } + */ + sfp := src.getInt32Ptr() + if sfp != nil { + dfp := dst.getInt32Ptr() + if dfp == nil { + dst.setInt32Ptr(*sfp) + } else { + *dfp = *sfp + } + } + } + default: // E.g., int32 + mfi.merge = func(dst, src pointer) { + if v := *src.toInt32(); v != 0 { + *dst.toInt32() = v + } + } + } + case reflect.Int64: + switch { + case isSlice: // E.g., []int64 + mfi.merge = func(dst, src pointer) { + sfsp := src.toInt64Slice() + if *sfsp != nil { + dfsp := dst.toInt64Slice() + *dfsp = append(*dfsp, *sfsp...) + if *dfsp == nil { + *dfsp = []int64{} + } + } + } + case isPointer: // E.g., *int64 + mfi.merge = func(dst, src pointer) { + sfpp := src.toInt64Ptr() + if *sfpp != nil { + dfpp := dst.toInt64Ptr() + if *dfpp == nil { + *dfpp = Int64(**sfpp) + } else { + **dfpp = **sfpp + } + } + } + default: // E.g., int64 + mfi.merge = func(dst, src pointer) { + if v := *src.toInt64(); v != 0 { + *dst.toInt64() = v + } + } + } + case reflect.Uint32: + switch { + case isSlice: // E.g., []uint32 + mfi.merge = func(dst, src pointer) { + sfsp := src.toUint32Slice() + if *sfsp != nil { + dfsp := dst.toUint32Slice() + *dfsp = append(*dfsp, *sfsp...) + if *dfsp == nil { + *dfsp = []uint32{} + } + } + } + case isPointer: // E.g., *uint32 + mfi.merge = func(dst, src pointer) { + sfpp := src.toUint32Ptr() + if *sfpp != nil { + dfpp := dst.toUint32Ptr() + if *dfpp == nil { + *dfpp = Uint32(**sfpp) + } else { + **dfpp = **sfpp + } + } + } + default: // E.g., uint32 + mfi.merge = func(dst, src pointer) { + if v := *src.toUint32(); v != 0 { + *dst.toUint32() = v + } + } + } + case reflect.Uint64: + switch { + case isSlice: // E.g., []uint64 + mfi.merge = func(dst, src pointer) { + sfsp := src.toUint64Slice() + if *sfsp != nil { + dfsp := dst.toUint64Slice() + *dfsp = append(*dfsp, *sfsp...) + if *dfsp == nil { + *dfsp = []uint64{} + } + } + } + case isPointer: // E.g., *uint64 + mfi.merge = func(dst, src pointer) { + sfpp := src.toUint64Ptr() + if *sfpp != nil { + dfpp := dst.toUint64Ptr() + if *dfpp == nil { + *dfpp = Uint64(**sfpp) + } else { + **dfpp = **sfpp + } + } + } + default: // E.g., uint64 + mfi.merge = func(dst, src pointer) { + if v := *src.toUint64(); v != 0 { + *dst.toUint64() = v + } + } + } + case reflect.Float32: + switch { + case isSlice: // E.g., []float32 + mfi.merge = func(dst, src pointer) { + sfsp := src.toFloat32Slice() + if *sfsp != nil { + dfsp := dst.toFloat32Slice() + *dfsp = append(*dfsp, *sfsp...) + if *dfsp == nil { + *dfsp = []float32{} + } + } + } + case isPointer: // E.g., *float32 + mfi.merge = func(dst, src pointer) { + sfpp := src.toFloat32Ptr() + if *sfpp != nil { + dfpp := dst.toFloat32Ptr() + if *dfpp == nil { + *dfpp = Float32(**sfpp) + } else { + **dfpp = **sfpp + } + } + } + default: // E.g., float32 + mfi.merge = func(dst, src pointer) { + if v := *src.toFloat32(); v != 0 { + *dst.toFloat32() = v + } + } + } + case reflect.Float64: + switch { + case isSlice: // E.g., []float64 + mfi.merge = func(dst, src pointer) { + sfsp := src.toFloat64Slice() + if *sfsp != nil { + dfsp := dst.toFloat64Slice() + *dfsp = append(*dfsp, *sfsp...) + if *dfsp == nil { + *dfsp = []float64{} + } + } + } + case isPointer: // E.g., *float64 + mfi.merge = func(dst, src pointer) { + sfpp := src.toFloat64Ptr() + if *sfpp != nil { + dfpp := dst.toFloat64Ptr() + if *dfpp == nil { + *dfpp = Float64(**sfpp) + } else { + **dfpp = **sfpp + } + } + } + default: // E.g., float64 + mfi.merge = func(dst, src pointer) { + if v := *src.toFloat64(); v != 0 { + *dst.toFloat64() = v + } + } + } + case reflect.Bool: + switch { + case isSlice: // E.g., []bool + mfi.merge = func(dst, src pointer) { + sfsp := src.toBoolSlice() + if *sfsp != nil { + dfsp := dst.toBoolSlice() + *dfsp = append(*dfsp, *sfsp...) + if *dfsp == nil { + *dfsp = []bool{} + } + } + } + case isPointer: // E.g., *bool + mfi.merge = func(dst, src pointer) { + sfpp := src.toBoolPtr() + if *sfpp != nil { + dfpp := dst.toBoolPtr() + if *dfpp == nil { + *dfpp = Bool(**sfpp) + } else { + **dfpp = **sfpp + } + } + } + default: // E.g., bool + mfi.merge = func(dst, src pointer) { + if v := *src.toBool(); v { + *dst.toBool() = v + } + } + } + case reflect.String: + switch { + case isSlice: // E.g., []string + mfi.merge = func(dst, src pointer) { + sfsp := src.toStringSlice() + if *sfsp != nil { + dfsp := dst.toStringSlice() + *dfsp = append(*dfsp, *sfsp...) + if *dfsp == nil { + *dfsp = []string{} + } + } + } + case isPointer: // E.g., *string + mfi.merge = func(dst, src pointer) { + sfpp := src.toStringPtr() + if *sfpp != nil { + dfpp := dst.toStringPtr() + if *dfpp == nil { + *dfpp = String(**sfpp) + } else { + **dfpp = **sfpp + } + } + } + default: // E.g., string + mfi.merge = func(dst, src pointer) { + if v := *src.toString(); v != "" { + *dst.toString() = v + } + } + } + case reflect.Slice: + isProto3 := props.Prop[i].proto3 + switch { + case isPointer: + panic("bad pointer in byte slice case in " + tf.Name()) + case tf.Elem().Kind() != reflect.Uint8: + panic("bad element kind in byte slice case in " + tf.Name()) + case isSlice: // E.g., [][]byte + mfi.merge = func(dst, src pointer) { + sbsp := src.toBytesSlice() + if *sbsp != nil { + dbsp := dst.toBytesSlice() + for _, sb := range *sbsp { + if sb == nil { + *dbsp = append(*dbsp, nil) + } else { + *dbsp = append(*dbsp, append([]byte{}, sb...)) + } + } + if *dbsp == nil { + *dbsp = [][]byte{} + } + } + } + default: // E.g., []byte + mfi.merge = func(dst, src pointer) { + sbp := src.toBytes() + if *sbp != nil { + dbp := dst.toBytes() + if !isProto3 || len(*sbp) > 0 { + *dbp = append([]byte{}, *sbp...) + } + } + } + } + case reflect.Struct: + switch { + case !isPointer: + panic(fmt.Sprintf("message field %s without pointer", tf)) + case isSlice: // E.g., []*pb.T + mi := getMergeInfo(tf) + mfi.merge = func(dst, src pointer) { + sps := src.getPointerSlice() + if sps != nil { + dps := dst.getPointerSlice() + for _, sp := range sps { + var dp pointer + if !sp.isNil() { + dp = valToPointer(reflect.New(tf)) + mi.merge(dp, sp) + } + dps = append(dps, dp) + } + if dps == nil { + dps = []pointer{} + } + dst.setPointerSlice(dps) + } + } + default: // E.g., *pb.T + mi := getMergeInfo(tf) + mfi.merge = func(dst, src pointer) { + sp := src.getPointer() + if !sp.isNil() { + dp := dst.getPointer() + if dp.isNil() { + dp = valToPointer(reflect.New(tf)) + dst.setPointer(dp) + } + mi.merge(dp, sp) + } + } + } + case reflect.Map: + switch { + case isPointer || isSlice: + panic("bad pointer or slice in map case in " + tf.Name()) + default: // E.g., map[K]V + mfi.merge = func(dst, src pointer) { + sm := src.asPointerTo(tf).Elem() + if sm.Len() == 0 { + return + } + dm := dst.asPointerTo(tf).Elem() + if dm.IsNil() { + dm.Set(reflect.MakeMap(tf)) + } + + switch tf.Elem().Kind() { + case reflect.Ptr: // Proto struct (e.g., *T) + for _, key := range sm.MapKeys() { + val := sm.MapIndex(key) + val = reflect.ValueOf(Clone(val.Interface().(Message))) + dm.SetMapIndex(key, val) + } + case reflect.Slice: // E.g. Bytes type (e.g., []byte) + for _, key := range sm.MapKeys() { + val := sm.MapIndex(key) + val = reflect.ValueOf(append([]byte{}, val.Bytes()...)) + dm.SetMapIndex(key, val) + } + default: // Basic type (e.g., string) + for _, key := range sm.MapKeys() { + val := sm.MapIndex(key) + dm.SetMapIndex(key, val) + } + } + } + } + case reflect.Interface: + // Must be oneof field. + switch { + case isPointer || isSlice: + panic("bad pointer or slice in interface case in " + tf.Name()) + default: // E.g., interface{} + // TODO: Make this faster? + mfi.merge = func(dst, src pointer) { + su := src.asPointerTo(tf).Elem() + if !su.IsNil() { + du := dst.asPointerTo(tf).Elem() + typ := su.Elem().Type() + if du.IsNil() || du.Elem().Type() != typ { + du.Set(reflect.New(typ.Elem())) // Initialize interface if empty + } + sv := su.Elem().Elem().Field(0) + if sv.Kind() == reflect.Ptr && sv.IsNil() { + return + } + dv := du.Elem().Elem().Field(0) + if dv.Kind() == reflect.Ptr && dv.IsNil() { + dv.Set(reflect.New(sv.Type().Elem())) // Initialize proto message if empty + } + switch sv.Type().Kind() { + case reflect.Ptr: // Proto struct (e.g., *T) + Merge(dv.Interface().(Message), sv.Interface().(Message)) + case reflect.Slice: // E.g. Bytes type (e.g., []byte) + dv.Set(reflect.ValueOf(append([]byte{}, sv.Bytes()...))) + default: // Basic type (e.g., string) + dv.Set(sv) + } + } + } + } + default: + panic(fmt.Sprintf("merger not found for type:%s", tf)) + } + mi.fields = append(mi.fields, mfi) + } + + mi.unrecognized = invalidField + if f, ok := t.FieldByName("XXX_unrecognized"); ok { + if f.Type != reflect.TypeOf([]byte{}) { + panic("expected XXX_unrecognized to be of type []byte") + } + mi.unrecognized = toField(&f) + } + + atomic.StoreInt32(&mi.initialized, 1) +} diff --git a/vendor/github.com/golang/protobuf/proto/table_unmarshal.go b/vendor/github.com/golang/protobuf/proto/table_unmarshal.go new file mode 100644 index 00000000000..55f0340a3fd --- /dev/null +++ b/vendor/github.com/golang/protobuf/proto/table_unmarshal.go @@ -0,0 +1,1967 @@ +// 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 + +import ( + "errors" + "fmt" + "io" + "math" + "reflect" + "strconv" + "strings" + "sync" + "sync/atomic" + "unicode/utf8" +) + +// Unmarshal is the entry point from the generated .pb.go files. +// This function is not intended to be used by non-generated code. +// This function is not subject to any compatibility guarantee. +// msg contains a pointer to a protocol buffer struct. +// b is the data to be unmarshaled into the protocol buffer. +// a is a pointer to a place to store cached unmarshal information. +func (a *InternalMessageInfo) Unmarshal(msg Message, b []byte) error { + // Load the unmarshal information for this message type. + // The atomic load ensures memory consistency. + u := atomicLoadUnmarshalInfo(&a.unmarshal) + if u == nil { + // Slow path: find unmarshal info for msg, update a with it. + u = getUnmarshalInfo(reflect.TypeOf(msg).Elem()) + atomicStoreUnmarshalInfo(&a.unmarshal, u) + } + // Then do the unmarshaling. + err := u.unmarshal(toPointer(&msg), b) + return err +} + +type unmarshalInfo struct { + typ reflect.Type // type of the protobuf struct + + // 0 = only typ field is initialized + // 1 = completely initialized + initialized int32 + lock sync.Mutex // prevents double initialization + dense []unmarshalFieldInfo // fields indexed by tag # + sparse map[uint64]unmarshalFieldInfo // fields indexed by tag # + reqFields []string // names of required fields + reqMask uint64 // 1< 0 { + // Read tag and wire type. + // Special case 1 and 2 byte varints. + var x uint64 + if b[0] < 128 { + x = uint64(b[0]) + b = b[1:] + } else if len(b) >= 2 && b[1] < 128 { + x = uint64(b[0]&0x7f) + uint64(b[1])<<7 + b = b[2:] + } else { + var n int + x, n = decodeVarint(b) + if n == 0 { + return io.ErrUnexpectedEOF + } + b = b[n:] + } + tag := x >> 3 + wire := int(x) & 7 + + // Dispatch on the tag to one of the unmarshal* functions below. + var f unmarshalFieldInfo + if tag < uint64(len(u.dense)) { + f = u.dense[tag] + } else { + f = u.sparse[tag] + } + if fn := f.unmarshal; fn != nil { + var err error + b, err = fn(b, m.offset(f.field), wire) + if err == nil { + reqMask |= f.reqMask + continue + } + if r, ok := err.(*RequiredNotSetError); ok { + // Remember this error, but keep parsing. We need to produce + // a full parse even if a required field is missing. + rnse = r + reqMask |= f.reqMask + continue + } + if err != errInternalBadWireType { + return err + } + // Fragments with bad wire type are treated as unknown fields. + } + + // Unknown tag. + if !u.unrecognized.IsValid() { + // Don't keep unrecognized data; just skip it. + var err error + b, err = skipField(b, wire) + if err != nil { + return err + } + continue + } + // Keep unrecognized data around. + // maybe in extensions, maybe in the unrecognized field. + z := m.offset(u.unrecognized).toBytes() + var emap map[int32]Extension + var e Extension + for _, r := range u.extensionRanges { + if uint64(r.Start) <= tag && tag <= uint64(r.End) { + if u.extensions.IsValid() { + mp := m.offset(u.extensions).toExtensions() + emap = mp.extensionsWrite() + e = emap[int32(tag)] + z = &e.enc + break + } + if u.oldExtensions.IsValid() { + p := m.offset(u.oldExtensions).toOldExtensions() + emap = *p + if emap == nil { + emap = map[int32]Extension{} + *p = emap + } + e = emap[int32(tag)] + z = &e.enc + break + } + panic("no extensions field available") + } + } + + // Use wire type to skip data. + var err error + b0 := b + b, err = skipField(b, wire) + if err != nil { + return err + } + *z = encodeVarint(*z, tag<<3|uint64(wire)) + *z = append(*z, b0[:len(b0)-len(b)]...) + + if emap != nil { + emap[int32(tag)] = e + } + } + if rnse != nil { + // A required field of a submessage/group is missing. Return that error. + return rnse + } + if reqMask != u.reqMask { + // A required field of this message is missing. + for _, n := range u.reqFields { + if reqMask&1 == 0 { + return &RequiredNotSetError{n} + } + reqMask >>= 1 + } + } + return nil +} + +// computeUnmarshalInfo fills in u with information for use +// in unmarshaling protocol buffers of type u.typ. +func (u *unmarshalInfo) computeUnmarshalInfo() { + u.lock.Lock() + defer u.lock.Unlock() + if u.initialized != 0 { + return + } + t := u.typ + n := t.NumField() + + // Set up the "not found" value for the unrecognized byte buffer. + // This is the default for proto3. + u.unrecognized = invalidField + u.extensions = invalidField + u.oldExtensions = invalidField + + // List of the generated type and offset for each oneof field. + type oneofField struct { + ityp reflect.Type // interface type of oneof field + field field // offset in containing message + } + var oneofFields []oneofField + + for i := 0; i < n; i++ { + f := t.Field(i) + if f.Name == "XXX_unrecognized" { + // The byte slice used to hold unrecognized input is special. + if f.Type != reflect.TypeOf(([]byte)(nil)) { + panic("bad type for XXX_unrecognized field: " + f.Type.Name()) + } + u.unrecognized = toField(&f) + continue + } + if f.Name == "XXX_InternalExtensions" { + // Ditto here. + if f.Type != reflect.TypeOf(XXX_InternalExtensions{}) { + panic("bad type for XXX_InternalExtensions field: " + f.Type.Name()) + } + u.extensions = toField(&f) + if f.Tag.Get("protobuf_messageset") == "1" { + u.isMessageSet = true + } + continue + } + if f.Name == "XXX_extensions" { + // An older form of the extensions field. + if f.Type != reflect.TypeOf((map[int32]Extension)(nil)) { + panic("bad type for XXX_extensions field: " + f.Type.Name()) + } + u.oldExtensions = toField(&f) + continue + } + if f.Name == "XXX_NoUnkeyedLiteral" || f.Name == "XXX_sizecache" { + continue + } + + oneof := f.Tag.Get("protobuf_oneof") + if oneof != "" { + oneofFields = append(oneofFields, oneofField{f.Type, toField(&f)}) + // The rest of oneof processing happens below. + continue + } + + tags := f.Tag.Get("protobuf") + tagArray := strings.Split(tags, ",") + if len(tagArray) < 2 { + panic("protobuf tag not enough fields in " + t.Name() + "." + f.Name + ": " + tags) + } + tag, err := strconv.Atoi(tagArray[1]) + if err != nil { + panic("protobuf tag field not an integer: " + tagArray[1]) + } + + name := "" + for _, tag := range tagArray[3:] { + if strings.HasPrefix(tag, "name=") { + name = tag[5:] + } + } + + // Extract unmarshaling function from the field (its type and tags). + unmarshal := fieldUnmarshaler(&f) + + // Required field? + var reqMask uint64 + if tagArray[2] == "req" { + bit := len(u.reqFields) + u.reqFields = append(u.reqFields, name) + reqMask = uint64(1) << uint(bit) + // TODO: if we have more than 64 required fields, we end up + // not verifying that all required fields are present. + // Fix this, perhaps using a count of required fields? + } + + // Store the info in the correct slot in the message. + u.setTag(tag, toField(&f), unmarshal, reqMask) + } + + // Find any types associated with oneof fields. + // TODO: XXX_OneofFuncs returns more info than we need. Get rid of some of it? + fn := reflect.Zero(reflect.PtrTo(t)).MethodByName("XXX_OneofFuncs") + if fn.IsValid() { + res := fn.Call(nil)[3] // last return value from XXX_OneofFuncs: []interface{} + for i := res.Len() - 1; i >= 0; i-- { + v := res.Index(i) // interface{} + tptr := reflect.ValueOf(v.Interface()).Type() // *Msg_X + typ := tptr.Elem() // Msg_X + + f := typ.Field(0) // oneof implementers have one field + baseUnmarshal := fieldUnmarshaler(&f) + tagstr := strings.Split(f.Tag.Get("protobuf"), ",")[1] + tag, err := strconv.Atoi(tagstr) + if err != nil { + panic("protobuf tag field not an integer: " + tagstr) + } + + // Find the oneof field that this struct implements. + // Might take O(n^2) to process all of the oneofs, but who cares. + for _, of := range oneofFields { + if tptr.Implements(of.ityp) { + // We have found the corresponding interface for this struct. + // That lets us know where this struct should be stored + // when we encounter it during unmarshaling. + unmarshal := makeUnmarshalOneof(typ, of.ityp, baseUnmarshal) + u.setTag(tag, of.field, unmarshal, 0) + } + } + } + } + + // Get extension ranges, if any. + fn = reflect.Zero(reflect.PtrTo(t)).MethodByName("ExtensionRangeArray") + if fn.IsValid() { + if !u.extensions.IsValid() && !u.oldExtensions.IsValid() { + panic("a message with extensions, but no extensions field in " + t.Name()) + } + u.extensionRanges = fn.Call(nil)[0].Interface().([]ExtensionRange) + } + + // Explicitly disallow tag 0. This will ensure we flag an error + // when decoding a buffer of all zeros. Without this code, we + // would decode and skip an all-zero buffer of even length. + // [0 0] is [tag=0/wiretype=varint varint-encoded-0]. + u.setTag(0, zeroField, func(b []byte, f pointer, w int) ([]byte, error) { + return nil, fmt.Errorf("proto: %s: illegal tag 0 (wire type %d)", t, w) + }, 0) + + // Set mask for required field check. + u.reqMask = uint64(1)<= 0 && (tag < 16 || tag < 2*n) { // TODO: what are the right numbers here? + for len(u.dense) <= tag { + u.dense = append(u.dense, unmarshalFieldInfo{}) + } + u.dense[tag] = i + return + } + if u.sparse == nil { + u.sparse = map[uint64]unmarshalFieldInfo{} + } + u.sparse[uint64(tag)] = i +} + +// fieldUnmarshaler returns an unmarshaler for the given field. +func fieldUnmarshaler(f *reflect.StructField) unmarshaler { + if f.Type.Kind() == reflect.Map { + return makeUnmarshalMap(f) + } + return typeUnmarshaler(f.Type, f.Tag.Get("protobuf")) +} + +// typeUnmarshaler returns an unmarshaler for the given field type / field tag pair. +func typeUnmarshaler(t reflect.Type, tags string) unmarshaler { + tagArray := strings.Split(tags, ",") + encoding := tagArray[0] + name := "unknown" + for _, tag := range tagArray[3:] { + if strings.HasPrefix(tag, "name=") { + name = tag[5:] + } + } + + // Figure out packaging (pointer, slice, or both) + slice := false + pointer := false + if t.Kind() == reflect.Slice && t.Elem().Kind() != reflect.Uint8 { + slice = true + t = t.Elem() + } + if t.Kind() == reflect.Ptr { + pointer = true + t = t.Elem() + } + + // We'll never have both pointer and slice for basic types. + if pointer && slice && t.Kind() != reflect.Struct { + panic("both pointer and slice for basic type in " + t.Name()) + } + + switch t.Kind() { + case reflect.Bool: + if pointer { + return unmarshalBoolPtr + } + if slice { + return unmarshalBoolSlice + } + return unmarshalBoolValue + case reflect.Int32: + switch encoding { + case "fixed32": + if pointer { + return unmarshalFixedS32Ptr + } + if slice { + return unmarshalFixedS32Slice + } + return unmarshalFixedS32Value + case "varint": + // this could be int32 or enum + if pointer { + return unmarshalInt32Ptr + } + if slice { + return unmarshalInt32Slice + } + return unmarshalInt32Value + case "zigzag32": + if pointer { + return unmarshalSint32Ptr + } + if slice { + return unmarshalSint32Slice + } + return unmarshalSint32Value + } + case reflect.Int64: + switch encoding { + case "fixed64": + if pointer { + return unmarshalFixedS64Ptr + } + if slice { + return unmarshalFixedS64Slice + } + return unmarshalFixedS64Value + case "varint": + if pointer { + return unmarshalInt64Ptr + } + if slice { + return unmarshalInt64Slice + } + return unmarshalInt64Value + case "zigzag64": + if pointer { + return unmarshalSint64Ptr + } + if slice { + return unmarshalSint64Slice + } + return unmarshalSint64Value + } + case reflect.Uint32: + switch encoding { + case "fixed32": + if pointer { + return unmarshalFixed32Ptr + } + if slice { + return unmarshalFixed32Slice + } + return unmarshalFixed32Value + case "varint": + if pointer { + return unmarshalUint32Ptr + } + if slice { + return unmarshalUint32Slice + } + return unmarshalUint32Value + } + case reflect.Uint64: + switch encoding { + case "fixed64": + if pointer { + return unmarshalFixed64Ptr + } + if slice { + return unmarshalFixed64Slice + } + return unmarshalFixed64Value + case "varint": + if pointer { + return unmarshalUint64Ptr + } + if slice { + return unmarshalUint64Slice + } + return unmarshalUint64Value + } + case reflect.Float32: + if pointer { + return unmarshalFloat32Ptr + } + if slice { + return unmarshalFloat32Slice + } + return unmarshalFloat32Value + case reflect.Float64: + if pointer { + return unmarshalFloat64Ptr + } + if slice { + return unmarshalFloat64Slice + } + return unmarshalFloat64Value + case reflect.Map: + panic("map type in typeUnmarshaler in " + t.Name()) + case reflect.Slice: + if pointer { + panic("bad pointer in slice case in " + t.Name()) + } + if slice { + return unmarshalBytesSlice + } + return unmarshalBytesValue + case reflect.String: + if pointer { + return unmarshalStringPtr + } + if slice { + return unmarshalStringSlice + } + return unmarshalStringValue + case reflect.Struct: + // message or group field + if !pointer { + panic(fmt.Sprintf("message/group field %s:%s without pointer", t, encoding)) + } + switch encoding { + case "bytes": + if slice { + return makeUnmarshalMessageSlicePtr(getUnmarshalInfo(t), name) + } + return makeUnmarshalMessagePtr(getUnmarshalInfo(t), name) + case "group": + if slice { + return makeUnmarshalGroupSlicePtr(getUnmarshalInfo(t), name) + } + return makeUnmarshalGroupPtr(getUnmarshalInfo(t), name) + } + } + panic(fmt.Sprintf("unmarshaler not found type:%s encoding:%s", t, encoding)) +} + +// Below are all the unmarshalers for individual fields of various types. + +func unmarshalInt64Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int64(x) + *f.toInt64() = v + return b, nil +} + +func unmarshalInt64Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int64(x) + *f.toInt64Ptr() = &v + return b, nil +} + +func unmarshalInt64Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + x, n = decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int64(x) + s := f.toInt64Slice() + *s = append(*s, v) + } + return res, nil + } + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int64(x) + s := f.toInt64Slice() + *s = append(*s, v) + return b, nil +} + +func unmarshalSint64Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int64(x>>1) ^ int64(x)<<63>>63 + *f.toInt64() = v + return b, nil +} + +func unmarshalSint64Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int64(x>>1) ^ int64(x)<<63>>63 + *f.toInt64Ptr() = &v + return b, nil +} + +func unmarshalSint64Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + x, n = decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int64(x>>1) ^ int64(x)<<63>>63 + s := f.toInt64Slice() + *s = append(*s, v) + } + return res, nil + } + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int64(x>>1) ^ int64(x)<<63>>63 + s := f.toInt64Slice() + *s = append(*s, v) + return b, nil +} + +func unmarshalUint64Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := uint64(x) + *f.toUint64() = v + return b, nil +} + +func unmarshalUint64Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := uint64(x) + *f.toUint64Ptr() = &v + return b, nil +} + +func unmarshalUint64Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + x, n = decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := uint64(x) + s := f.toUint64Slice() + *s = append(*s, v) + } + return res, nil + } + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := uint64(x) + s := f.toUint64Slice() + *s = append(*s, v) + return b, nil +} + +func unmarshalInt32Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int32(x) + *f.toInt32() = v + return b, nil +} + +func unmarshalInt32Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int32(x) + f.setInt32Ptr(v) + return b, nil +} + +func unmarshalInt32Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + x, n = decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int32(x) + f.appendInt32Slice(v) + } + return res, nil + } + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int32(x) + f.appendInt32Slice(v) + return b, nil +} + +func unmarshalSint32Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int32(x>>1) ^ int32(x)<<31>>31 + *f.toInt32() = v + return b, nil +} + +func unmarshalSint32Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int32(x>>1) ^ int32(x)<<31>>31 + f.setInt32Ptr(v) + return b, nil +} + +func unmarshalSint32Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + x, n = decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int32(x>>1) ^ int32(x)<<31>>31 + f.appendInt32Slice(v) + } + return res, nil + } + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := int32(x>>1) ^ int32(x)<<31>>31 + f.appendInt32Slice(v) + return b, nil +} + +func unmarshalUint32Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := uint32(x) + *f.toUint32() = v + return b, nil +} + +func unmarshalUint32Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := uint32(x) + *f.toUint32Ptr() = &v + return b, nil +} + +func unmarshalUint32Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + x, n = decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := uint32(x) + s := f.toUint32Slice() + *s = append(*s, v) + } + return res, nil + } + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + v := uint32(x) + s := f.toUint32Slice() + *s = append(*s, v) + return b, nil +} + +func unmarshalFixed64Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed64 { + return b, errInternalBadWireType + } + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56 + *f.toUint64() = v + return b[8:], nil +} + +func unmarshalFixed64Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed64 { + return b, errInternalBadWireType + } + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56 + *f.toUint64Ptr() = &v + return b[8:], nil +} + +func unmarshalFixed64Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56 + s := f.toUint64Slice() + *s = append(*s, v) + b = b[8:] + } + return res, nil + } + if w != WireFixed64 { + return b, errInternalBadWireType + } + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56 + s := f.toUint64Slice() + *s = append(*s, v) + return b[8:], nil +} + +func unmarshalFixedS64Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed64 { + return b, errInternalBadWireType + } + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := int64(b[0]) | int64(b[1])<<8 | int64(b[2])<<16 | int64(b[3])<<24 | int64(b[4])<<32 | int64(b[5])<<40 | int64(b[6])<<48 | int64(b[7])<<56 + *f.toInt64() = v + return b[8:], nil +} + +func unmarshalFixedS64Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed64 { + return b, errInternalBadWireType + } + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := int64(b[0]) | int64(b[1])<<8 | int64(b[2])<<16 | int64(b[3])<<24 | int64(b[4])<<32 | int64(b[5])<<40 | int64(b[6])<<48 | int64(b[7])<<56 + *f.toInt64Ptr() = &v + return b[8:], nil +} + +func unmarshalFixedS64Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := int64(b[0]) | int64(b[1])<<8 | int64(b[2])<<16 | int64(b[3])<<24 | int64(b[4])<<32 | int64(b[5])<<40 | int64(b[6])<<48 | int64(b[7])<<56 + s := f.toInt64Slice() + *s = append(*s, v) + b = b[8:] + } + return res, nil + } + if w != WireFixed64 { + return b, errInternalBadWireType + } + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := int64(b[0]) | int64(b[1])<<8 | int64(b[2])<<16 | int64(b[3])<<24 | int64(b[4])<<32 | int64(b[5])<<40 | int64(b[6])<<48 | int64(b[7])<<56 + s := f.toInt64Slice() + *s = append(*s, v) + return b[8:], nil +} + +func unmarshalFixed32Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed32 { + return b, errInternalBadWireType + } + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := uint32(b[0]) | uint32(b[1])<<8 | uint32(b[2])<<16 | uint32(b[3])<<24 + *f.toUint32() = v + return b[4:], nil +} + +func unmarshalFixed32Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed32 { + return b, errInternalBadWireType + } + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := uint32(b[0]) | uint32(b[1])<<8 | uint32(b[2])<<16 | uint32(b[3])<<24 + *f.toUint32Ptr() = &v + return b[4:], nil +} + +func unmarshalFixed32Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := uint32(b[0]) | uint32(b[1])<<8 | uint32(b[2])<<16 | uint32(b[3])<<24 + s := f.toUint32Slice() + *s = append(*s, v) + b = b[4:] + } + return res, nil + } + if w != WireFixed32 { + return b, errInternalBadWireType + } + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := uint32(b[0]) | uint32(b[1])<<8 | uint32(b[2])<<16 | uint32(b[3])<<24 + s := f.toUint32Slice() + *s = append(*s, v) + return b[4:], nil +} + +func unmarshalFixedS32Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed32 { + return b, errInternalBadWireType + } + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := int32(b[0]) | int32(b[1])<<8 | int32(b[2])<<16 | int32(b[3])<<24 + *f.toInt32() = v + return b[4:], nil +} + +func unmarshalFixedS32Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed32 { + return b, errInternalBadWireType + } + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := int32(b[0]) | int32(b[1])<<8 | int32(b[2])<<16 | int32(b[3])<<24 + f.setInt32Ptr(v) + return b[4:], nil +} + +func unmarshalFixedS32Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := int32(b[0]) | int32(b[1])<<8 | int32(b[2])<<16 | int32(b[3])<<24 + f.appendInt32Slice(v) + b = b[4:] + } + return res, nil + } + if w != WireFixed32 { + return b, errInternalBadWireType + } + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := int32(b[0]) | int32(b[1])<<8 | int32(b[2])<<16 | int32(b[3])<<24 + f.appendInt32Slice(v) + return b[4:], nil +} + +func unmarshalBoolValue(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + // Note: any length varint is allowed, even though any sane + // encoder will use one byte. + // See https://github.com/golang/protobuf/issues/76 + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + // TODO: check if x>1? Tests seem to indicate no. + v := x != 0 + *f.toBool() = v + return b[n:], nil +} + +func unmarshalBoolPtr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + v := x != 0 + *f.toBoolPtr() = &v + return b[n:], nil +} + +func unmarshalBoolSlice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + x, n = decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + v := x != 0 + s := f.toBoolSlice() + *s = append(*s, v) + b = b[n:] + } + return res, nil + } + if w != WireVarint { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + v := x != 0 + s := f.toBoolSlice() + *s = append(*s, v) + return b[n:], nil +} + +func unmarshalFloat64Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed64 { + return b, errInternalBadWireType + } + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := math.Float64frombits(uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56) + *f.toFloat64() = v + return b[8:], nil +} + +func unmarshalFloat64Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed64 { + return b, errInternalBadWireType + } + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := math.Float64frombits(uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56) + *f.toFloat64Ptr() = &v + return b[8:], nil +} + +func unmarshalFloat64Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := math.Float64frombits(uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56) + s := f.toFloat64Slice() + *s = append(*s, v) + b = b[8:] + } + return res, nil + } + if w != WireFixed64 { + return b, errInternalBadWireType + } + if len(b) < 8 { + return nil, io.ErrUnexpectedEOF + } + v := math.Float64frombits(uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 | uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56) + s := f.toFloat64Slice() + *s = append(*s, v) + return b[8:], nil +} + +func unmarshalFloat32Value(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed32 { + return b, errInternalBadWireType + } + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := math.Float32frombits(uint32(b[0]) | uint32(b[1])<<8 | uint32(b[2])<<16 | uint32(b[3])<<24) + *f.toFloat32() = v + return b[4:], nil +} + +func unmarshalFloat32Ptr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireFixed32 { + return b, errInternalBadWireType + } + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := math.Float32frombits(uint32(b[0]) | uint32(b[1])<<8 | uint32(b[2])<<16 | uint32(b[3])<<24) + *f.toFloat32Ptr() = &v + return b[4:], nil +} + +func unmarshalFloat32Slice(b []byte, f pointer, w int) ([]byte, error) { + if w == WireBytes { // packed + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + res := b[x:] + b = b[:x] + for len(b) > 0 { + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := math.Float32frombits(uint32(b[0]) | uint32(b[1])<<8 | uint32(b[2])<<16 | uint32(b[3])<<24) + s := f.toFloat32Slice() + *s = append(*s, v) + b = b[4:] + } + return res, nil + } + if w != WireFixed32 { + return b, errInternalBadWireType + } + if len(b) < 4 { + return nil, io.ErrUnexpectedEOF + } + v := math.Float32frombits(uint32(b[0]) | uint32(b[1])<<8 | uint32(b[2])<<16 | uint32(b[3])<<24) + s := f.toFloat32Slice() + *s = append(*s, v) + return b[4:], nil +} + +func unmarshalStringValue(b []byte, f pointer, w int) ([]byte, error) { + if w != WireBytes { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + v := string(b[:x]) + if !utf8.ValidString(v) { + return nil, errInvalidUTF8 + } + *f.toString() = v + return b[x:], nil +} + +func unmarshalStringPtr(b []byte, f pointer, w int) ([]byte, error) { + if w != WireBytes { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + v := string(b[:x]) + if !utf8.ValidString(v) { + return nil, errInvalidUTF8 + } + *f.toStringPtr() = &v + return b[x:], nil +} + +func unmarshalStringSlice(b []byte, f pointer, w int) ([]byte, error) { + if w != WireBytes { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + v := string(b[:x]) + if !utf8.ValidString(v) { + return nil, errInvalidUTF8 + } + s := f.toStringSlice() + *s = append(*s, v) + return b[x:], nil +} + +var emptyBuf [0]byte + +func unmarshalBytesValue(b []byte, f pointer, w int) ([]byte, error) { + if w != WireBytes { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + // The use of append here is a trick which avoids the zeroing + // that would be required if we used a make/copy pair. + // We append to emptyBuf instead of nil because we want + // a non-nil result even when the length is 0. + v := append(emptyBuf[:], b[:x]...) + *f.toBytes() = v + return b[x:], nil +} + +func unmarshalBytesSlice(b []byte, f pointer, w int) ([]byte, error) { + if w != WireBytes { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + v := append(emptyBuf[:], b[:x]...) + s := f.toBytesSlice() + *s = append(*s, v) + return b[x:], nil +} + +func makeUnmarshalMessagePtr(sub *unmarshalInfo, name string) unmarshaler { + return func(b []byte, f pointer, w int) ([]byte, error) { + if w != WireBytes { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + // First read the message field to see if something is there. + // The semantics of multiple submessages are weird. Instead of + // the last one winning (as it is for all other fields), multiple + // submessages are merged. + v := f.getPointer() + if v.isNil() { + v = valToPointer(reflect.New(sub.typ)) + f.setPointer(v) + } + err := sub.unmarshal(v, b[:x]) + if err != nil { + if r, ok := err.(*RequiredNotSetError); ok { + r.field = name + "." + r.field + } else { + return nil, err + } + } + return b[x:], err + } +} + +func makeUnmarshalMessageSlicePtr(sub *unmarshalInfo, name string) unmarshaler { + return func(b []byte, f pointer, w int) ([]byte, error) { + if w != WireBytes { + return b, errInternalBadWireType + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + v := valToPointer(reflect.New(sub.typ)) + err := sub.unmarshal(v, b[:x]) + if err != nil { + if r, ok := err.(*RequiredNotSetError); ok { + r.field = name + "." + r.field + } else { + return nil, err + } + } + f.appendPointer(v) + return b[x:], err + } +} + +func makeUnmarshalGroupPtr(sub *unmarshalInfo, name string) unmarshaler { + return func(b []byte, f pointer, w int) ([]byte, error) { + if w != WireStartGroup { + return b, errInternalBadWireType + } + x, y := findEndGroup(b) + if x < 0 { + return nil, io.ErrUnexpectedEOF + } + v := f.getPointer() + if v.isNil() { + v = valToPointer(reflect.New(sub.typ)) + f.setPointer(v) + } + err := sub.unmarshal(v, b[:x]) + if err != nil { + if r, ok := err.(*RequiredNotSetError); ok { + r.field = name + "." + r.field + } else { + return nil, err + } + } + return b[y:], err + } +} + +func makeUnmarshalGroupSlicePtr(sub *unmarshalInfo, name string) unmarshaler { + return func(b []byte, f pointer, w int) ([]byte, error) { + if w != WireStartGroup { + return b, errInternalBadWireType + } + x, y := findEndGroup(b) + if x < 0 { + return nil, io.ErrUnexpectedEOF + } + v := valToPointer(reflect.New(sub.typ)) + err := sub.unmarshal(v, b[:x]) + if err != nil { + if r, ok := err.(*RequiredNotSetError); ok { + r.field = name + "." + r.field + } else { + return nil, err + } + } + f.appendPointer(v) + return b[y:], err + } +} + +func makeUnmarshalMap(f *reflect.StructField) unmarshaler { + t := f.Type + kt := t.Key() + vt := t.Elem() + unmarshalKey := typeUnmarshaler(kt, f.Tag.Get("protobuf_key")) + unmarshalVal := typeUnmarshaler(vt, f.Tag.Get("protobuf_val")) + return func(b []byte, f pointer, w int) ([]byte, error) { + // The map entry is a submessage. Figure out how big it is. + if w != WireBytes { + return nil, fmt.Errorf("proto: bad wiretype for map field: got %d want %d", w, WireBytes) + } + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + b = b[n:] + if x > uint64(len(b)) { + return nil, io.ErrUnexpectedEOF + } + r := b[x:] // unused data to return + b = b[:x] // data for map entry + + // Note: we could use #keys * #values ~= 200 functions + // to do map decoding without reflection. Probably not worth it. + // Maps will be somewhat slow. Oh well. + + // Read key and value from data. + k := reflect.New(kt) + v := reflect.New(vt) + for len(b) > 0 { + x, n := decodeVarint(b) + if n == 0 { + return nil, io.ErrUnexpectedEOF + } + wire := int(x) & 7 + b = b[n:] + + var err error + switch x >> 3 { + case 1: + b, err = unmarshalKey(b, valToPointer(k), wire) + case 2: + b, err = unmarshalVal(b, valToPointer(v), wire) + default: + err = errInternalBadWireType // skip unknown tag + } + + if err == nil { + continue + } + if err != errInternalBadWireType { + return nil, err + } + + // Skip past unknown fields. + b, err = skipField(b, wire) + if err != nil { + return nil, err + } + } + + // Get map, allocate if needed. + m := f.asPointerTo(t).Elem() // an addressable map[K]T + if m.IsNil() { + m.Set(reflect.MakeMap(t)) + } + + // Insert into map. + m.SetMapIndex(k.Elem(), v.Elem()) + + return r, nil + } +} + +// makeUnmarshalOneof makes an unmarshaler for oneof fields. +// for: +// message Msg { +// oneof F { +// int64 X = 1; +// float64 Y = 2; +// } +// } +// typ is the type of the concrete entry for a oneof case (e.g. Msg_X). +// ityp is the interface type of the oneof field (e.g. isMsg_F). +// unmarshal is the unmarshaler for the base type of the oneof case (e.g. int64). +// Note that this function will be called once for each case in the oneof. +func makeUnmarshalOneof(typ, ityp reflect.Type, unmarshal unmarshaler) unmarshaler { + sf := typ.Field(0) + field0 := toField(&sf) + return func(b []byte, f pointer, w int) ([]byte, error) { + // Allocate holder for value. + v := reflect.New(typ) + + // Unmarshal data into holder. + // We unmarshal into the first field of the holder object. + var err error + b, err = unmarshal(b, valToPointer(v).offset(field0), w) + if err != nil { + return nil, err + } + + // Write pointer to holder into target field. + f.asPointerTo(ityp).Elem().Set(v) + + return b, nil + } +} + +// Error used by decode internally. +var errInternalBadWireType = errors.New("proto: internal error: bad wiretype") + +// skipField skips past a field of type wire and returns the remaining bytes. +func skipField(b []byte, wire int) ([]byte, error) { + switch wire { + case WireVarint: + _, k := decodeVarint(b) + if k == 0 { + return b, io.ErrUnexpectedEOF + } + b = b[k:] + case WireFixed32: + if len(b) < 4 { + return b, io.ErrUnexpectedEOF + } + b = b[4:] + case WireFixed64: + if len(b) < 8 { + return b, io.ErrUnexpectedEOF + } + b = b[8:] + case WireBytes: + m, k := decodeVarint(b) + if k == 0 || uint64(len(b)-k) < m { + return b, io.ErrUnexpectedEOF + } + b = b[uint64(k)+m:] + case WireStartGroup: + _, i := findEndGroup(b) + if i == -1 { + return b, io.ErrUnexpectedEOF + } + b = b[i:] + default: + return b, fmt.Errorf("proto: can't skip unknown wire type %d", wire) + } + return b, nil +} + +// findEndGroup finds the index of the next EndGroup tag. +// Groups may be nested, so the "next" EndGroup tag is the first +// unpaired EndGroup. +// findEndGroup returns the indexes of the start and end of the EndGroup tag. +// Returns (-1,-1) if it can't find one. +func findEndGroup(b []byte) (int, int) { + depth := 1 + i := 0 + for { + x, n := decodeVarint(b[i:]) + if n == 0 { + return -1, -1 + } + j := i + i += n + switch x & 7 { + case WireVarint: + _, k := decodeVarint(b[i:]) + if k == 0 { + return -1, -1 + } + i += k + case WireFixed32: + if len(b)-4 < i { + return -1, -1 + } + i += 4 + case WireFixed64: + if len(b)-8 < i { + return -1, -1 + } + i += 8 + case WireBytes: + m, k := decodeVarint(b[i:]) + if k == 0 { + return -1, -1 + } + i += k + if uint64(len(b)-i) < m { + return -1, -1 + } + i += int(m) + case WireStartGroup: + depth++ + case WireEndGroup: + depth-- + if depth == 0 { + return j, i + } + default: + return -1, -1 + } + } +} + +// encodeVarint appends a varint-encoded integer to b and returns the result. +func encodeVarint(b []byte, x uint64) []byte { + for x >= 1<<7 { + b = append(b, byte(x&0x7f|0x80)) + x >>= 7 + } + return append(b, byte(x)) +} + +// decodeVarint reads a varint-encoded integer from b. +// Returns the decoded integer and the number of bytes read. +// If there is an error, it returns 0,0. +func decodeVarint(b []byte) (uint64, int) { + var x, y uint64 + if len(b) <= 0 { + goto bad + } + x = uint64(b[0]) + if x < 0x80 { + return x, 1 + } + x -= 0x80 + + if len(b) <= 1 { + goto bad + } + y = uint64(b[1]) + x += y << 7 + if y < 0x80 { + return x, 2 + } + x -= 0x80 << 7 + + if len(b) <= 2 { + goto bad + } + y = uint64(b[2]) + x += y << 14 + if y < 0x80 { + return x, 3 + } + x -= 0x80 << 14 + + if len(b) <= 3 { + goto bad + } + y = uint64(b[3]) + x += y << 21 + if y < 0x80 { + return x, 4 + } + x -= 0x80 << 21 + + if len(b) <= 4 { + goto bad + } + y = uint64(b[4]) + x += y << 28 + if y < 0x80 { + return x, 5 + } + x -= 0x80 << 28 + + if len(b) <= 5 { + goto bad + } + y = uint64(b[5]) + x += y << 35 + if y < 0x80 { + return x, 6 + } + x -= 0x80 << 35 + + if len(b) <= 6 { + goto bad + } + y = uint64(b[6]) + x += y << 42 + if y < 0x80 { + return x, 7 + } + x -= 0x80 << 42 + + if len(b) <= 7 { + goto bad + } + y = uint64(b[7]) + x += y << 49 + if y < 0x80 { + return x, 8 + } + x -= 0x80 << 49 + + if len(b) <= 8 { + goto bad + } + y = uint64(b[8]) + x += y << 56 + if y < 0x80 { + return x, 9 + } + x -= 0x80 << 56 + + if len(b) <= 9 { + goto bad + } + y = uint64(b[9]) + x += y << 63 + if y < 2 { + return x, 10 + } + +bad: + return 0, 0 +} diff --git a/vendor/github.com/golang/protobuf/proto/text.go b/vendor/github.com/golang/protobuf/proto/text.go index 965876bf033..2205fdaadf8 100644 --- a/vendor/github.com/golang/protobuf/proto/text.go +++ b/vendor/github.com/golang/protobuf/proto/text.go @@ -50,7 +50,6 @@ import ( var ( newline = []byte("\n") spaces = []byte(" ") - gtNewline = []byte(">\n") endBraceNewline = []byte("}\n") backslashN = []byte{'\\', 'n'} backslashR = []byte{'\\', 'r'} @@ -170,11 +169,6 @@ func writeName(w *textWriter, props *Properties) error { 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 { @@ -269,6 +263,10 @@ func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { props := sprops.Prop[i] name := st.Field(i).Name + if name == "XXX_NoUnkeyedLiteral" { + continue + } + if strings.HasPrefix(name, "XXX_") { // There are two XXX_ fields: // XXX_unrecognized []byte @@ -436,12 +434,6 @@ func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { 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 { @@ -455,7 +447,7 @@ func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { // Extensions (the XXX_extensions field). pv := sv.Addr() - if _, ok := extendable(pv.Interface()); ok { + if _, err := extendable(pv.Interface()); err == nil { if err := tm.writeExtensions(w, pv); err != nil { return err } @@ -464,27 +456,6 @@ func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { 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) @@ -535,6 +506,19 @@ func (tm *TextMarshaler) writeAny(w *textWriter, v reflect.Value, props *Propert } } w.indent() + if v.CanAddr() { + // Calling v.Interface on a struct causes the reflect package to + // copy the entire struct. This is racy with the new Marshaler + // since we atomically update the XXX_sizecache. + // + // Thus, we retrieve a pointer to the struct if possible to avoid + // a race since v.Interface on the pointer doesn't copy the struct. + // + // If v is not addressable, then we are not worried about a race + // since it implies that the binary Marshaler cannot possibly be + // mutating this value. + v = v.Addr() + } if etm, ok := v.Interface().(encoding.TextMarshaler); ok { text, err := etm.MarshalText() if err != nil { @@ -543,8 +527,13 @@ func (tm *TextMarshaler) writeAny(w *textWriter, v reflect.Value, props *Propert if _, err = w.Write(text); err != nil { return err } - } else if err := tm.writeStruct(w, v); err != nil { - return err + } else { + if v.Kind() == reflect.Ptr { + v = v.Elem() + } + if err := tm.writeStruct(w, v); err != nil { + return err + } } w.unindent() if err := w.WriteByte(ket); err != nil { diff --git a/vendor/github.com/golang/protobuf/proto/text_parser.go b/vendor/github.com/golang/protobuf/proto/text_parser.go index 5e14513f28c..0685bae36d5 100644 --- a/vendor/github.com/golang/protobuf/proto/text_parser.go +++ b/vendor/github.com/golang/protobuf/proto/text_parser.go @@ -206,7 +206,6 @@ func (p *textParser) advance() { var ( errBadUTF8 = errors.New("proto: bad UTF-8") - errBadHex = errors.New("proto: bad hexadecimal") ) func unquoteC(s string, quote rune) (string, error) { @@ -277,60 +276,47 @@ func unescape(s string) (ch string, tail string, err error) { return "?", s, nil // trigraph workaround case '\'', '"', '\\': return string(r), s, nil - case '0', '1', '2', '3', '4', '5', '6', '7', 'x', 'X': + case '0', '1', '2', '3', '4', '5', '6', '7': if len(s) < 2 { return "", "", fmt.Errorf(`\%c requires 2 following digits`, r) } - base := 8 - ss := s[:2] + ss := string(r) + s[:2] s = s[2:] - if r == 'x' || r == 'X' { - base = 16 - } else { - ss = string(r) + ss - } - i, err := strconv.ParseUint(ss, base, 8) + i, err := strconv.ParseUint(ss, 8, 8) if err != nil { - return "", "", err + return "", "", fmt.Errorf(`\%s contains non-octal digits`, ss) } return string([]byte{byte(i)}), s, nil - case 'u', 'U': - n := 4 - if r == 'U' { + case 'x', 'X', 'u', 'U': + var n int + switch r { + case 'x', 'X': + n = 2 + case 'u': + n = 4 + case '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 + return "", "", fmt.Errorf(`\%c requires %d following digits`, r, n) } + ss := s[:n] s = s[n:] - return string(bs), s, nil + i, err := strconv.ParseUint(ss, 16, 64) + if err != nil { + return "", "", fmt.Errorf(`\%c%s contains non-hexadecimal digits`, r, ss) + } + if r == 'x' || r == 'X' { + return string([]byte{byte(i)}), s, nil + } + if i > utf8.MaxRune { + return "", "", fmt.Errorf(`\%c%s is not a valid Unicode code point`, r, ss) + } + return string(i), 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 } @@ -728,6 +714,9 @@ func (p *textParser) consumeExtName() (string, error) { if tok.err != nil { return "", p.errorf("unrecognized type_url or extension name: %s", tok.err) } + if p.done && tok.value != "]" { + return "", p.errorf("unclosed type_url or extension name") + } } return strings.Join(parts, ""), nil } @@ -865,7 +854,7 @@ func (p *textParser) readAny(v reflect.Value, props *Properties) error { return p.readStruct(fv, terminator) case reflect.Uint32: if x, err := strconv.ParseUint(tok.value, 0, 32); err == nil { - fv.SetUint(x) + fv.SetUint(uint64(x)) return nil } case reflect.Uint64: @@ -883,13 +872,9 @@ func (p *textParser) readAny(v reflect.Value, props *Properties) error { // UnmarshalText returns *RequiredNotSetError. func UnmarshalText(s string, pb Message) error { if um, ok := pb.(encoding.TextUnmarshaler); ok { - err := um.UnmarshalText([]byte(s)) - return err + return um.UnmarshalText([]byte(s)) } pb.Reset() v := reflect.ValueOf(pb) - if pe := newTextParser(s).readStruct(v.Elem(), ""); pe != nil { - return pe - } - return nil + return newTextParser(s).readStruct(v.Elem(), "") } diff --git a/vendor/github.com/golang/protobuf/ptypes/any/any.pb.go b/vendor/github.com/golang/protobuf/ptypes/any/any.pb.go index f34601723de..f67edc7dc2b 100644 --- a/vendor/github.com/golang/protobuf/ptypes/any/any.pb.go +++ b/vendor/github.com/golang/protobuf/ptypes/any/any.pb.go @@ -1,16 +1,7 @@ // Code generated by protoc-gen-go. DO NOT EDIT. // source: google/protobuf/any.proto -/* -Package any is a generated protocol buffer package. - -It is generated from these files: - google/protobuf/any.proto - -It has these top-level messages: - Any -*/ -package any +package any // import "github.com/golang/protobuf/ptypes/any" import proto "github.com/golang/protobuf/proto" import fmt "fmt" @@ -132,14 +123,36 @@ type Any struct { // TypeUrl string `protobuf:"bytes,1,opt,name=type_url,json=typeUrl" json:"type_url,omitempty"` // Must be a valid serialized protocol buffer of the above specified type. - Value []byte `protobuf:"bytes,2,opt,name=value,proto3" json:"value,omitempty"` + Value []byte `protobuf:"bytes,2,opt,name=value,proto3" json:"value,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *Any) Reset() { *m = Any{} } +func (m *Any) String() string { return proto.CompactTextString(m) } +func (*Any) ProtoMessage() {} +func (*Any) Descriptor() ([]byte, []int) { + return fileDescriptor_any_744b9ca530f228db, []int{0} +} +func (*Any) XXX_WellKnownType() string { return "Any" } +func (m *Any) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_Any.Unmarshal(m, b) +} +func (m *Any) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_Any.Marshal(b, m, deterministic) +} +func (dst *Any) XXX_Merge(src proto.Message) { + xxx_messageInfo_Any.Merge(dst, src) +} +func (m *Any) XXX_Size() int { + return xxx_messageInfo_Any.Size(m) +} +func (m *Any) XXX_DiscardUnknown() { + xxx_messageInfo_Any.DiscardUnknown(m) } -func (m *Any) Reset() { *m = Any{} } -func (m *Any) String() string { return proto.CompactTextString(m) } -func (*Any) ProtoMessage() {} -func (*Any) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{0} } -func (*Any) XXX_WellKnownType() string { return "Any" } +var xxx_messageInfo_Any proto.InternalMessageInfo func (m *Any) GetTypeUrl() string { if m != nil { @@ -159,9 +172,9 @@ func init() { proto.RegisterType((*Any)(nil), "google.protobuf.Any") } -func init() { proto.RegisterFile("google/protobuf/any.proto", fileDescriptor0) } +func init() { proto.RegisterFile("google/protobuf/any.proto", fileDescriptor_any_744b9ca530f228db) } -var fileDescriptor0 = []byte{ +var fileDescriptor_any_744b9ca530f228db = []byte{ // 185 bytes of a gzipped FileDescriptorProto 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x92, 0x4c, 0xcf, 0xcf, 0x4f, 0xcf, 0x49, 0xd5, 0x2f, 0x28, 0xca, 0x2f, 0xc9, 0x4f, 0x2a, 0x4d, 0xd3, 0x4f, 0xcc, 0xab, 0xd4, diff --git a/vendor/github.com/golang/protobuf/ptypes/duration/duration.pb.go b/vendor/github.com/golang/protobuf/ptypes/duration/duration.pb.go index b2410a098eb..4d75473b8b2 100644 --- a/vendor/github.com/golang/protobuf/ptypes/duration/duration.pb.go +++ b/vendor/github.com/golang/protobuf/ptypes/duration/duration.pb.go @@ -1,16 +1,7 @@ // Code generated by protoc-gen-go. DO NOT EDIT. // source: google/protobuf/duration.proto -/* -Package duration is a generated protocol buffer package. - -It is generated from these files: - google/protobuf/duration.proto - -It has these top-level messages: - Duration -*/ -package duration +package duration // import "github.com/golang/protobuf/ptypes/duration" import proto "github.com/golang/protobuf/proto" import fmt "fmt" @@ -98,14 +89,36 @@ type Duration struct { // of one second or more, a non-zero value for the `nanos` field must be // of the same sign as the `seconds` field. Must be from -999,999,999 // to +999,999,999 inclusive. - Nanos int32 `protobuf:"varint,2,opt,name=nanos" json:"nanos,omitempty"` + Nanos int32 `protobuf:"varint,2,opt,name=nanos" json:"nanos,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` } -func (m *Duration) Reset() { *m = Duration{} } -func (m *Duration) String() string { return proto.CompactTextString(m) } -func (*Duration) ProtoMessage() {} -func (*Duration) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{0} } -func (*Duration) XXX_WellKnownType() string { return "Duration" } +func (m *Duration) Reset() { *m = Duration{} } +func (m *Duration) String() string { return proto.CompactTextString(m) } +func (*Duration) ProtoMessage() {} +func (*Duration) Descriptor() ([]byte, []int) { + return fileDescriptor_duration_e7d612259e3f0613, []int{0} +} +func (*Duration) XXX_WellKnownType() string { return "Duration" } +func (m *Duration) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_Duration.Unmarshal(m, b) +} +func (m *Duration) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_Duration.Marshal(b, m, deterministic) +} +func (dst *Duration) XXX_Merge(src proto.Message) { + xxx_messageInfo_Duration.Merge(dst, src) +} +func (m *Duration) XXX_Size() int { + return xxx_messageInfo_Duration.Size(m) +} +func (m *Duration) XXX_DiscardUnknown() { + xxx_messageInfo_Duration.DiscardUnknown(m) +} + +var xxx_messageInfo_Duration proto.InternalMessageInfo func (m *Duration) GetSeconds() int64 { if m != nil { @@ -125,9 +138,11 @@ func init() { proto.RegisterType((*Duration)(nil), "google.protobuf.Duration") } -func init() { proto.RegisterFile("google/protobuf/duration.proto", fileDescriptor0) } +func init() { + proto.RegisterFile("google/protobuf/duration.proto", fileDescriptor_duration_e7d612259e3f0613) +} -var fileDescriptor0 = []byte{ +var fileDescriptor_duration_e7d612259e3f0613 = []byte{ // 190 bytes of a gzipped FileDescriptorProto 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x92, 0x4b, 0xcf, 0xcf, 0x4f, 0xcf, 0x49, 0xd5, 0x2f, 0x28, 0xca, 0x2f, 0xc9, 0x4f, 0x2a, 0x4d, 0xd3, 0x4f, 0x29, 0x2d, 0x4a, diff --git a/vendor/github.com/golang/protobuf/ptypes/regen.sh b/vendor/github.com/golang/protobuf/ptypes/regen.sh deleted file mode 100755 index b50a9414ac2..00000000000 --- a/vendor/github.com/golang/protobuf/ptypes/regen.sh +++ /dev/null @@ -1,43 +0,0 @@ -#!/bin/bash -e -# -# This script fetches and rebuilds the "well-known types" protocol buffers. -# To run this you will need protoc and goprotobuf installed; -# see https://github.com/golang/protobuf for instructions. -# You also need Go and Git installed. - -PKG=github.com/golang/protobuf/ptypes -UPSTREAM=https://github.com/google/protobuf -UPSTREAM_SUBDIR=src/google/protobuf -PROTO_FILES=(any duration empty struct timestamp wrappers) - -function die() { - echo 1>&2 $* - exit 1 -} - -# Sanity check that the right tools are accessible. -for tool in go git protoc protoc-gen-go; do - q=$(which $tool) || die "didn't find $tool" - echo 1>&2 "$tool: $q" -done - -tmpdir=$(mktemp -d -t regen-wkt.XXXXXX) -trap 'rm -rf $tmpdir' EXIT - -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" - -echo 1>&2 "fetching latest protos... " -git clone -q $UPSTREAM $tmpdir - -for file in ${PROTO_FILES[@]}; do - echo 1>&2 "* $file" - protoc --go_out=. -I$tmpdir/src $tmpdir/src/google/protobuf/$file.proto || die - cp $tmpdir/src/google/protobuf/$file.proto $PKG/$file -done - -echo 1>&2 "All OK" diff --git a/vendor/github.com/golang/protobuf/ptypes/timestamp/timestamp.pb.go b/vendor/github.com/golang/protobuf/ptypes/timestamp/timestamp.pb.go index e23e4a25daf..e9c22228216 100644 --- a/vendor/github.com/golang/protobuf/ptypes/timestamp/timestamp.pb.go +++ b/vendor/github.com/golang/protobuf/ptypes/timestamp/timestamp.pb.go @@ -1,16 +1,7 @@ // Code generated by protoc-gen-go. DO NOT EDIT. // source: google/protobuf/timestamp.proto -/* -Package timestamp is a generated protocol buffer package. - -It is generated from these files: - google/protobuf/timestamp.proto - -It has these top-level messages: - Timestamp -*/ -package timestamp +package timestamp // import "github.com/golang/protobuf/ptypes/timestamp" import proto "github.com/golang/protobuf/proto" import fmt "fmt" @@ -101,7 +92,7 @@ const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package // to this format using [`strftime`](https://docs.python.org/2/library/time.html#time.strftime) // with the time format spec '%Y-%m-%dT%H:%M:%S.%fZ'. Likewise, in Java, one // can use the Joda Time's [`ISODateTimeFormat.dateTime()`]( -// http://joda-time.sourceforge.net/apidocs/org/joda/time/format/ISODateTimeFormat.html#dateTime()) +// http://www.joda.org/joda-time/apidocs/org/joda/time/format/ISODateTimeFormat.html#dateTime--) // to obtain a formatter capable of generating timestamps in this format. // // @@ -114,14 +105,36 @@ type Timestamp struct { // second values with fractions must still have non-negative nanos values // that count forward in time. Must be from 0 to 999,999,999 // inclusive. - Nanos int32 `protobuf:"varint,2,opt,name=nanos" json:"nanos,omitempty"` + Nanos int32 `protobuf:"varint,2,opt,name=nanos" json:"nanos,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` } -func (m *Timestamp) Reset() { *m = Timestamp{} } -func (m *Timestamp) String() string { return proto.CompactTextString(m) } -func (*Timestamp) ProtoMessage() {} -func (*Timestamp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{0} } -func (*Timestamp) XXX_WellKnownType() string { return "Timestamp" } +func (m *Timestamp) Reset() { *m = Timestamp{} } +func (m *Timestamp) String() string { return proto.CompactTextString(m) } +func (*Timestamp) ProtoMessage() {} +func (*Timestamp) Descriptor() ([]byte, []int) { + return fileDescriptor_timestamp_b826e8e5fba671a8, []int{0} +} +func (*Timestamp) XXX_WellKnownType() string { return "Timestamp" } +func (m *Timestamp) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_Timestamp.Unmarshal(m, b) +} +func (m *Timestamp) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_Timestamp.Marshal(b, m, deterministic) +} +func (dst *Timestamp) XXX_Merge(src proto.Message) { + xxx_messageInfo_Timestamp.Merge(dst, src) +} +func (m *Timestamp) XXX_Size() int { + return xxx_messageInfo_Timestamp.Size(m) +} +func (m *Timestamp) XXX_DiscardUnknown() { + xxx_messageInfo_Timestamp.DiscardUnknown(m) +} + +var xxx_messageInfo_Timestamp proto.InternalMessageInfo func (m *Timestamp) GetSeconds() int64 { if m != nil { @@ -141,9 +154,11 @@ func init() { proto.RegisterType((*Timestamp)(nil), "google.protobuf.Timestamp") } -func init() { proto.RegisterFile("google/protobuf/timestamp.proto", fileDescriptor0) } +func init() { + proto.RegisterFile("google/protobuf/timestamp.proto", fileDescriptor_timestamp_b826e8e5fba671a8) +} -var fileDescriptor0 = []byte{ +var fileDescriptor_timestamp_b826e8e5fba671a8 = []byte{ // 191 bytes of a gzipped FileDescriptorProto 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x92, 0x4f, 0xcf, 0xcf, 0x4f, 0xcf, 0x49, 0xd5, 0x2f, 0x28, 0xca, 0x2f, 0xc9, 0x4f, 0x2a, 0x4d, 0xd3, 0x2f, 0xc9, 0xcc, 0x4d, diff --git a/vendor/github.com/golang/protobuf/ptypes/timestamp/timestamp.proto b/vendor/github.com/golang/protobuf/ptypes/timestamp/timestamp.proto index b7cbd17502f..06750ab1f12 100644 --- a/vendor/github.com/golang/protobuf/ptypes/timestamp/timestamp.proto +++ b/vendor/github.com/golang/protobuf/ptypes/timestamp/timestamp.proto @@ -114,7 +114,7 @@ option objc_class_prefix = "GPB"; // to this format using [`strftime`](https://docs.python.org/2/library/time.html#time.strftime) // with the time format spec '%Y-%m-%dT%H:%M:%S.%fZ'. Likewise, in Java, one // can use the Joda Time's [`ISODateTimeFormat.dateTime()`]( -// http://joda-time.sourceforge.net/apidocs/org/joda/time/format/ISODateTimeFormat.html#dateTime()) +// http://www.joda.org/joda-time/apidocs/org/joda/time/format/ISODateTimeFormat.html#dateTime--) // to obtain a formatter capable of generating timestamps in this format. // // diff --git a/vendor/github.com/google/go-jsonnet/ast/clone.go b/vendor/github.com/google/go-jsonnet/ast/clone.go index faa76f04f35..84ca8611ece 100644 --- a/vendor/github.com/google/go-jsonnet/ast/clone.go +++ b/vendor/github.com/google/go-jsonnet/ast/clone.go @@ -25,9 +25,11 @@ import ( func cloneForSpec(specPtr *ForSpec) { clone(&specPtr.Expr) oldOuter := specPtr.Outer - specPtr.Outer = new(ForSpec) - *specPtr.Outer = *oldOuter - cloneForSpec(specPtr.Outer) + if oldOuter != nil { + specPtr.Outer = new(ForSpec) + *specPtr.Outer = *oldOuter + cloneForSpec(specPtr.Outer) + } for i := range specPtr.Conditions { clone(&specPtr.Conditions[i].Expr) } diff --git a/vendor/github.com/google/go-jsonnet/ast/stdast.go b/vendor/github.com/google/go-jsonnet/ast/stdast.go index 3433a965086..b0b23d6cf8f 100644 --- a/vendor/github.com/google/go-jsonnet/ast/stdast.go +++ b/vendor/github.com/google/go-jsonnet/ast/stdast.go @@ -11,1836 +11,3440 @@ var p3Var = "$" var p3 = &p3Var var p9Var = "object " var p9 = &p9Var -var p43Var = "object " -var p43 = &p43Var -var p54Var = "thunk from >" +var p11Var = "object " +var p11 = &p11Var +var p35Var = "object " +var p35 = &p35Var +var p39Var = "object " +var p39 = &p39Var +var p42Var = "object " +var p42 = &p42Var +var p45Var = "object " +var p45 = &p45Var +var p48Var = "object " +var p48 = &p48Var +var p51Var = "object " +var p51 = &p51Var +var p54Var = "object " var p54 = &p54Var -var p69Var = "function " -var p69 = &p69Var -var p78Var = "thunk from >" -var p78 = &p78Var -var p95Var = "function " -var p95 = &p95Var -var p104Var = "thunk from >" -var p104 = &p104Var -var p121Var = "function " -var p121 = &p121Var -var p130Var = "thunk from >" -var p130 = &p130Var -var p147Var = "function " -var p147 = &p147Var -var p156Var = "thunk from >" -var p156 = &p156Var -var p173Var = "function " -var p173 = &p173Var -var p182Var = "thunk from >" -var p182 = &p182Var -var p199Var = "function " -var p199 = &p199Var -var p208Var = "thunk from >" -var p208 = &p208Var -var p217Var = "function " +var p57Var = "object " +var p57 = &p57Var +var p62Var = "thunk from >" +var p62 = &p62Var +var p64Var = "thunk from >" +var p64 = &p64Var +var p68Var = "object " +var p68 = &p68Var +var p80Var = "function " +var p80 = &p80Var +var p89Var = "thunk from >" +var p89 = &p89Var +var p96Var = "object " +var p96 = &p96Var +var p98Var = "object " +var p98 = &p98Var +var p122Var = "object " +var p122 = &p122Var +var p126Var = "object " +var p126 = &p126Var +var p129Var = "object " +var p129 = &p129Var +var p132Var = "object " +var p132 = &p132Var +var p135Var = "object " +var p135 = &p135Var +var p138Var = "object " +var p138 = &p138Var +var p141Var = "object " +var p141 = &p141Var +var p144Var = "object " +var p144 = &p144Var +var p149Var = "thunk from >" +var p149 = &p149Var +var p151Var = "thunk from >" +var p151 = &p151Var +var p165Var = "function " +var p165 = &p165Var +var p174Var = "thunk from >" +var p174 = &p174Var +var p181Var = "object " +var p181 = &p181Var +var p183Var = "object " +var p183 = &p183Var +var p207Var = "object " +var p207 = &p207Var +var p211Var = "object " +var p211 = &p211Var +var p214Var = "object " +var p214 = &p214Var +var p217Var = "object " var p217 = &p217Var -var p236Var = "thunk from >" +var p220Var = "object " +var p220 = &p220Var +var p223Var = "object " +var p223 = &p223Var +var p226Var = "object " +var p226 = &p226Var +var p229Var = "object " +var p229 = &p229Var +var p234Var = "thunk from >" +var p234 = &p234Var +var p236Var = "thunk from >" var p236 = &p236Var -var p252Var = "function " -var p252 = &p252Var -var p273Var = "thunk from >" -var p273 = &p273Var -var p290Var = "thunk from >" -var p290 = &p290Var -var p313Var = "thunk from >" -var p313 = &p313Var -var p330Var = "thunk from >" -var p330 = &p330Var -var p353Var = "thunk from >" +var p250Var = "function " +var p250 = &p250Var +var p259Var = "thunk from >" +var p259 = &p259Var +var p266Var = "object " +var p266 = &p266Var +var p268Var = "object " +var p268 = &p268Var +var p292Var = "object " +var p292 = &p292Var +var p296Var = "object " +var p296 = &p296Var +var p299Var = "object " +var p299 = &p299Var +var p302Var = "object " +var p302 = &p302Var +var p305Var = "object " +var p305 = &p305Var +var p308Var = "object " +var p308 = &p308Var +var p311Var = "object " +var p311 = &p311Var +var p314Var = "object " +var p314 = &p314Var +var p319Var = "thunk from >" +var p319 = &p319Var +var p321Var = "thunk from >" +var p321 = &p321Var +var p335Var = "function " +var p335 = &p335Var +var p344Var = "thunk from >" +var p344 = &p344Var +var p351Var = "object " +var p351 = &p351Var +var p353Var = "object " var p353 = &p353Var -var p370Var = "thunk from >" -var p370 = &p370Var -var p395Var = "thunk from >" -var p395 = &p395Var -var p405Var = "thunk from >>" -var p405 = &p405Var -var p411Var = "function " -var p411 = &p411Var -var p427Var = "function " -var p427 = &p427Var -var p440Var = "thunk from >" -var p440 = &p440Var -var p451Var = "thunk from >" -var p451 = &p451Var -var p471Var = "thunk from >" -var p471 = &p471Var -var p483Var = "thunk from >>" -var p483 = &p483Var -var p493Var = "function " -var p493 = &p493Var -var p506Var = "thunk from >" -var p506 = &p506Var -var p517Var = "thunk from >" -var p517 = &p517Var -var p537Var = "thunk from >" -var p537 = &p537Var -var p550Var = "thunk from >>" -var p550 = &p550Var -var p561Var = "thunk from >>" -var p561 = &p561Var -var p572Var = "thunk from >>" -var p572 = &p572Var +var p377Var = "object " +var p377 = &p377Var +var p381Var = "object " +var p381 = &p381Var +var p384Var = "object " +var p384 = &p384Var +var p387Var = "object " +var p387 = &p387Var +var p390Var = "object " +var p390 = &p390Var +var p393Var = "object " +var p393 = &p393Var +var p396Var = "object " +var p396 = &p396Var +var p399Var = "object " +var p399 = &p399Var +var p404Var = "thunk from >" +var p404 = &p404Var +var p406Var = "thunk from >" +var p406 = &p406Var +var p420Var = "function " +var p420 = &p420Var +var p429Var = "thunk from >" +var p429 = &p429Var +var p436Var = "object " +var p436 = &p436Var +var p438Var = "object " +var p438 = &p438Var +var p462Var = "object " +var p462 = &p462Var +var p466Var = "object " +var p466 = &p466Var +var p469Var = "object " +var p469 = &p469Var +var p472Var = "object " +var p472 = &p472Var +var p475Var = "object " +var p475 = &p475Var +var p478Var = "object " +var p478 = &p478Var +var p481Var = "object " +var p481 = &p481Var +var p484Var = "object " +var p484 = &p484Var +var p489Var = "thunk from >" +var p489 = &p489Var +var p491Var = "thunk from >" +var p491 = &p491Var +var p505Var = "function " +var p505 = &p505Var +var p514Var = "thunk from >" +var p514 = &p514Var +var p521Var = "object " +var p521 = &p521Var +var p523Var = "object " +var p523 = &p523Var +var p547Var = "object " +var p547 = &p547Var +var p551Var = "object " +var p551 = &p551Var +var p554Var = "object " +var p554 = &p554Var +var p557Var = "object " +var p557 = &p557Var +var p560Var = "object " +var p560 = &p560Var +var p563Var = "object " +var p563 = &p563Var +var p566Var = "object " +var p566 = &p566Var +var p569Var = "object " +var p569 = &p569Var +var p574Var = "thunk from >" +var p574 = &p574Var +var p576Var = "thunk from >" +var p576 = &p576Var var p582Var = "function " var p582 = &p582Var -var p591Var = "thunk from >" -var p591 = &p591Var -var p600Var = "thunk from >>" -var p600 = &p600Var -var p606Var = "function " -var p606 = &p606Var -var p618Var = "function " -var p618 = &p618Var -var p622Var = "thunk from >" -var p622 = &p622Var -var p625Var = "function " -var p625 = &p625Var -var p654Var = "thunk from >" +var p601Var = "thunk from >" +var p601 = &p601Var +var p615Var = "object " +var p615 = &p615Var +var p617Var = "object " +var p617 = &p617Var +var p641Var = "object " +var p641 = &p641Var +var p645Var = "object " +var p645 = &p645Var +var p648Var = "object " +var p648 = &p648Var +var p651Var = "object " +var p651 = &p651Var +var p654Var = "object " var p654 = &p654Var -var p672Var = "thunk from >" -var p672 = &p672Var -var p683Var = "thunk from >>" -var p683 = &p683Var -var p694Var = "thunk from >>" -var p694 = &p694Var -var p696Var = "function " -var p696 = &p696Var -var p705Var = "thunk from >" -var p705 = &p705Var -var p734Var = "thunk from >" -var p734 = &p734Var -var p750Var = "thunk from >>" -var p750 = &p750Var -var p765Var = "thunk from >" -var p765 = &p765Var -var p773Var = "thunk from >>" -var p773 = &p773Var -var p782Var = "function " -var p782 = &p782Var -var p803Var = "thunk from >" -var p803 = &p803Var -var p820Var = "thunk from >" -var p820 = &p820Var -var p843Var = "thunk from >" -var p843 = &p843Var -var p860Var = "thunk from >" -var p860 = &p860Var -var p883Var = "thunk from >" -var p883 = &p883Var -var p900Var = "thunk from >" -var p900 = &p900Var -var p911Var = "thunk from >" -var p911 = &p911Var -var p923Var = "function " +var p657Var = "object " +var p657 = &p657Var +var p660Var = "object " +var p660 = &p660Var +var p663Var = "object " +var p663 = &p663Var +var p668Var = "thunk from >" +var p668 = &p668Var +var p670Var = "thunk from >" +var p670 = &p670Var +var p676Var = "function " +var p676 = &p676Var +var p697Var = "thunk from >" +var p697 = &p697Var +var p714Var = "thunk from >" +var p714 = &p714Var +var p737Var = "thunk from >" +var p737 = &p737Var +var p754Var = "thunk from >" +var p754 = &p754Var +var p777Var = "thunk from >" +var p777 = &p777Var +var p794Var = "thunk from >" +var p794 = &p794Var +var p819Var = "thunk from >" +var p819 = &p819Var +var p829Var = "thunk from >>" +var p829 = &p829Var +var p835Var = "function " +var p835 = &p835Var +var p849Var = "object " +var p849 = &p849Var +var p851Var = "object " +var p851 = &p851Var +var p875Var = "object " +var p875 = &p875Var +var p879Var = "object " +var p879 = &p879Var +var p882Var = "object " +var p882 = &p882Var +var p885Var = "object " +var p885 = &p885Var +var p888Var = "object " +var p888 = &p888Var +var p891Var = "object " +var p891 = &p891Var +var p894Var = "object " +var p894 = &p894Var +var p897Var = "object " +var p897 = &p897Var +var p902Var = "thunk from >" +var p902 = &p902Var +var p904Var = "thunk from >" +var p904 = &p904Var +var p910Var = "function " +var p910 = &p910Var +var p923Var = "thunk from >" var p923 = &p923Var -var p944Var = "thunk from >" -var p944 = &p944Var -var p961Var = "thunk from >" -var p961 = &p961Var -var p984Var = "thunk from >" -var p984 = &p984Var -var p1001Var = "thunk from >" -var p1001 = &p1001Var -var p1024Var = "thunk from >" -var p1024 = &p1024Var -var p1041Var = "thunk from >" -var p1041 = &p1041Var -var p1064Var = "thunk from >" -var p1064 = &p1064Var -var p1081Var = "thunk from >" -var p1081 = &p1081Var -var p1087Var = "thunk from >" -var p1087 = &p1087Var -var p1091Var = "function " -var p1091 = &p1091Var -var p1095Var = "thunk from >" -var p1095 = &p1095Var -var p1105Var = "thunk from >" -var p1105 = &p1105Var -var p1125Var = "thunk from >" -var p1125 = &p1125Var -var p1135Var = "thunk from >" -var p1135 = &p1135Var -var p1178Var = "thunk from >" -var p1178 = &p1178Var -var p1188Var = "thunk from >" -var p1188 = &p1188Var -var p1202Var = "thunk from >>" -var p1202 = &p1202Var -var p1211Var = "thunk from >" -var p1211 = &p1211Var -var p1231Var = "thunk from >" -var p1231 = &p1231Var -var p1254Var = "function " -var p1254 = &p1254Var -var p1263Var = "thunk from >" -var p1263 = &p1263Var -var p1285Var = "thunk from >" +var p934Var = "thunk from >" +var p934 = &p934Var +var p954Var = "thunk from >" +var p954 = &p954Var +var p966Var = "thunk from >>" +var p966 = &p966Var +var p974Var = "object " +var p974 = &p974Var +var p976Var = "object " +var p976 = &p976Var +var p1000Var = "object " +var p1000 = &p1000Var +var p1004Var = "object " +var p1004 = &p1004Var +var p1007Var = "object " +var p1007 = &p1007Var +var p1010Var = "object " +var p1010 = &p1010Var +var p1013Var = "object " +var p1013 = &p1013Var +var p1016Var = "object " +var p1016 = &p1016Var +var p1019Var = "object " +var p1019 = &p1019Var +var p1022Var = "object " +var p1022 = &p1022Var +var p1027Var = "thunk from >" +var p1027 = &p1027Var +var p1029Var = "thunk from >" +var p1029 = &p1029Var +var p1035Var = "function " +var p1035 = &p1035Var +var p1048Var = "thunk from >" +var p1048 = &p1048Var +var p1059Var = "thunk from >" +var p1059 = &p1059Var +var p1079Var = "thunk from >" +var p1079 = &p1079Var +var p1092Var = "thunk from >>" +var p1092 = &p1092Var +var p1103Var = "thunk from >>" +var p1103 = &p1103Var +var p1114Var = "thunk from >>" +var p1114 = &p1114Var +var p1122Var = "object " +var p1122 = &p1122Var +var p1124Var = "object " +var p1124 = &p1124Var +var p1148Var = "object " +var p1148 = &p1148Var +var p1152Var = "object " +var p1152 = &p1152Var +var p1155Var = "object " +var p1155 = &p1155Var +var p1158Var = "object " +var p1158 = &p1158Var +var p1161Var = "object " +var p1161 = &p1161Var +var p1164Var = "object " +var p1164 = &p1164Var +var p1167Var = "object " +var p1167 = &p1167Var +var p1170Var = "object " +var p1170 = &p1170Var +var p1175Var = "thunk from >" +var p1175 = &p1175Var +var p1177Var = "thunk from >" +var p1177 = &p1177Var +var p1183Var = "function " +var p1183 = &p1183Var +var p1192Var = "thunk from >" +var p1192 = &p1192Var +var p1201Var = "thunk from >>" +var p1201 = &p1201Var +var p1207Var = "function " +var p1207 = &p1207Var +var p1217Var = "object " +var p1217 = &p1217Var +var p1219Var = "object " +var p1219 = &p1219Var +var p1243Var = "object " +var p1243 = &p1243Var +var p1247Var = "object " +var p1247 = &p1247Var +var p1250Var = "object " +var p1250 = &p1250Var +var p1253Var = "object " +var p1253 = &p1253Var +var p1256Var = "object " +var p1256 = &p1256Var +var p1259Var = "object " +var p1259 = &p1259Var +var p1262Var = "object " +var p1262 = &p1262Var +var p1265Var = "object " +var p1265 = &p1265Var +var p1270Var = "thunk from >" +var p1270 = &p1270Var +var p1272Var = "thunk from >" +var p1272 = &p1272Var +var p1278Var = "function " +var p1278 = &p1278Var +var p1282Var = "thunk from >" +var p1282 = &p1282Var +var p1285Var = "function " var p1285 = &p1285Var -var p1307Var = "thunk from >" -var p1307 = &p1307Var -var p1329Var = "thunk from >" -var p1329 = &p1329Var -var p1338Var = "thunk from from >>" -var p1338 = &p1338Var -var p1344Var = "thunk from >" -var p1344 = &p1344Var -var p1353Var = "thunk from from >>" -var p1353 = &p1353Var -var p1359Var = "thunk from >" -var p1359 = &p1359Var -var p1379Var = "function " -var p1379 = &p1379Var -var p1396Var = "thunk from >" -var p1396 = &p1396Var -var p1400Var = "function " -var p1400 = &p1400Var -var p1435Var = "thunk from >" -var p1435 = &p1435Var -var p1441Var = "thunk from >" -var p1441 = &p1441Var -var p1454Var = "thunk from from >>" -var p1454 = &p1454Var -var p1462Var = "thunk from >" -var p1462 = &p1462Var -var p1495Var = "thunk from >" +var p1314Var = "thunk from >" +var p1314 = &p1314Var +var p1332Var = "thunk from >" +var p1332 = &p1332Var +var p1343Var = "thunk from >>" +var p1343 = &p1343Var +var p1354Var = "thunk from >>" +var p1354 = &p1354Var +var p1356Var = "function " +var p1356 = &p1356Var +var p1365Var = "thunk from >" +var p1365 = &p1365Var +var p1394Var = "thunk from >" +var p1394 = &p1394Var +var p1410Var = "thunk from >>" +var p1410 = &p1410Var +var p1425Var = "thunk from >" +var p1425 = &p1425Var +var p1433Var = "thunk from >>" +var p1433 = &p1433Var +var p1440Var = "object " +var p1440 = &p1440Var +var p1442Var = "object " +var p1442 = &p1442Var +var p1466Var = "object " +var p1466 = &p1466Var +var p1470Var = "object " +var p1470 = &p1470Var +var p1473Var = "object " +var p1473 = &p1473Var +var p1476Var = "object " +var p1476 = &p1476Var +var p1479Var = "object " +var p1479 = &p1479Var +var p1482Var = "object " +var p1482 = &p1482Var +var p1485Var = "object " +var p1485 = &p1485Var +var p1488Var = "object " +var p1488 = &p1488Var +var p1493Var = "thunk from >" +var p1493 = &p1493Var +var p1495Var = "thunk from >" var p1495 = &p1495Var -var p1526Var = "thunk from >" -var p1526 = &p1526Var -var p1537Var = "thunk from >>" -var p1537 = &p1537Var -var p1547Var = "thunk from >" -var p1547 = &p1547Var -var p1564Var = "function " -var p1564 = &p1564Var -var p1568Var = "thunk from >" -var p1568 = &p1568Var -var p1577Var = "thunk from >" -var p1577 = &p1577Var -var p1581Var = "function " -var p1581 = &p1581Var -var p1593Var = "thunk from >" -var p1593 = &p1593Var -var p1604Var = "thunk from >" -var p1604 = &p1604Var -var p1616Var = "thunk from >" -var p1616 = &p1616Var -var p1624Var = "thunk from >>" -var p1624 = &p1624Var -var p1638Var = "thunk from >" -var p1638 = &p1638Var -var p1648Var = "thunk from >>" -var p1648 = &p1648Var -var p1659Var = "thunk from >>>" -var p1659 = &p1659Var -var p1667Var = "function " -var p1667 = &p1667Var -var p1671Var = "thunk from >" -var p1671 = &p1671Var -var p1680Var = "thunk from >" -var p1680 = &p1680Var -var p1684Var = "function " -var p1684 = &p1684Var -var p1696Var = "thunk from >" -var p1696 = &p1696Var -var p1707Var = "thunk from >" -var p1707 = &p1707Var -var p1719Var = "thunk from >" -var p1719 = &p1719Var -var p1727Var = "thunk from >>" -var p1727 = &p1727Var -var p1741Var = "thunk from >" -var p1741 = &p1741Var -var p1751Var = "thunk from >>" -var p1751 = &p1751Var -var p1762Var = "thunk from >>>" +var p1501Var = "function " +var p1501 = &p1501Var +var p1522Var = "thunk from >" +var p1522 = &p1522Var +var p1539Var = "thunk from >" +var p1539 = &p1539Var +var p1562Var = "thunk from >" +var p1562 = &p1562Var +var p1579Var = "thunk from >" +var p1579 = &p1579Var +var p1602Var = "thunk from >" +var p1602 = &p1602Var +var p1619Var = "thunk from >" +var p1619 = &p1619Var +var p1630Var = "thunk from >" +var p1630 = &p1630Var +var p1640Var = "object " +var p1640 = &p1640Var +var p1642Var = "object " +var p1642 = &p1642Var +var p1666Var = "object " +var p1666 = &p1666Var +var p1670Var = "object " +var p1670 = &p1670Var +var p1673Var = "object " +var p1673 = &p1673Var +var p1676Var = "object " +var p1676 = &p1676Var +var p1679Var = "object " +var p1679 = &p1679Var +var p1682Var = "object " +var p1682 = &p1682Var +var p1685Var = "object " +var p1685 = &p1685Var +var p1688Var = "object " +var p1688 = &p1688Var +var p1693Var = "thunk from >" +var p1693 = &p1693Var +var p1695Var = "thunk from >" +var p1695 = &p1695Var +var p1701Var = "function " +var p1701 = &p1701Var +var p1722Var = "thunk from >" +var p1722 = &p1722Var +var p1739Var = "thunk from >" +var p1739 = &p1739Var +var p1762Var = "thunk from >" var p1762 = &p1762Var -var p1770Var = "function " -var p1770 = &p1770Var var p1779Var = "thunk from >" var p1779 = &p1779Var -var p1792Var = "function " -var p1792 = &p1792Var -var p1804Var = "function " -var p1804 = &p1804Var -var p1808Var = "thunk from >" -var p1808 = &p1808Var -var p1813Var = "object " -var p1813 = &p1813Var -var p1855Var = "thunk from >" -var p1855 = &p1855Var -var p1886Var = "thunk from >" -var p1886 = &p1886Var -var p1898Var = "thunk from >" -var p1898 = &p1898Var -var p1945Var = "thunk from >" -var p1945 = &p1945Var +var p1802Var = "thunk from >" +var p1802 = &p1802Var +var p1819Var = "thunk from >" +var p1819 = &p1819Var +var p1842Var = "thunk from >" +var p1842 = &p1842Var +var p1859Var = "thunk from >" +var p1859 = &p1859Var +var p1865Var = "thunk from >" +var p1865 = &p1865Var +var p1869Var = "function " +var p1869 = &p1869Var +var p1873Var = "thunk from >" +var p1873 = &p1873Var +var p1883Var = "thunk from >" +var p1883 = &p1883Var +var p1903Var = "thunk from >" +var p1903 = &p1903Var +var p1913Var = "thunk from >" +var p1913 = &p1913Var +var p1956Var = "thunk from >" +var p1956 = &p1956Var +var p1966Var = "thunk from >" +var p1966 = &p1966Var +var p1980Var = "thunk from >>" +var p1980 = &p1980Var +var p1989Var = "thunk from >" +var p1989 = &p1989Var var p2009Var = "thunk from >" var p2009 = &p2009Var -var p2031Var = "thunk from >" -var p2031 = &p2031Var -var p2054Var = "thunk from >" -var p2054 = &p2054Var -var p2060Var = "thunk from >" -var p2060 = &p2060Var -var p2064Var = "function " -var p2064 = &p2064Var -var p2094Var = "thunk from >" -var p2094 = &p2094Var -var p2131Var = "thunk from >>" -var p2131 = &p2131Var -var p2155Var = "thunk from >" -var p2155 = &p2155Var -var p2184Var = "function " -var p2184 = &p2184Var -var p2193Var = "thunk from >" -var p2193 = &p2193Var -var p2202Var = "thunk from >>" -var p2202 = &p2202Var -var p2214Var = "function " -var p2214 = &p2214Var -var p2226Var = "function " -var p2226 = &p2226Var -var p2247Var = "thunk from >" -var p2247 = &p2247Var -var p2267Var = "thunk from >" -var p2267 = &p2267Var -var p2279Var = "thunk from >" -var p2279 = &p2279Var -var p2302Var = "thunk from >" -var p2302 = &p2302Var -var p2314Var = "thunk from >" -var p2314 = &p2314Var -var p2338Var = "thunk from >" -var p2338 = &p2338Var -var p2350Var = "thunk from >" -var p2350 = &p2350Var -var p2359Var = "function " -var p2359 = &p2359Var -var p2380Var = "thunk from >" -var p2380 = &p2380Var -var p2397Var = "thunk from >" -var p2397 = &p2397Var -var p2422Var = "thunk from >" -var p2422 = &p2422Var -var p2444Var = "thunk from >" +var p2020Var = "object " +var p2020 = &p2020Var +var p2022Var = "object " +var p2022 = &p2022Var +var p2046Var = "object " +var p2046 = &p2046Var +var p2050Var = "object " +var p2050 = &p2050Var +var p2053Var = "object " +var p2053 = &p2053Var +var p2056Var = "object " +var p2056 = &p2056Var +var p2059Var = "object " +var p2059 = &p2059Var +var p2062Var = "object " +var p2062 = &p2062Var +var p2065Var = "object " +var p2065 = &p2065Var +var p2068Var = "object " +var p2068 = &p2068Var +var p2073Var = "thunk from >" +var p2073 = &p2073Var +var p2075Var = "thunk from >" +var p2075 = &p2075Var +var p2091Var = "function " +var p2091 = &p2091Var +var p2100Var = "thunk from >" +var p2100 = &p2100Var +var p2122Var = "thunk from >" +var p2122 = &p2122Var +var p2144Var = "thunk from >" +var p2144 = &p2144Var +var p2166Var = "thunk from >" +var p2166 = &p2166Var +var p2175Var = "thunk from from >>" +var p2175 = &p2175Var +var p2181Var = "thunk from >" +var p2181 = &p2181Var +var p2190Var = "thunk from from >>" +var p2190 = &p2190Var +var p2196Var = "thunk from >" +var p2196 = &p2196Var +var p2216Var = "function " +var p2216 = &p2216Var +var p2233Var = "thunk from >" +var p2233 = &p2233Var +var p2237Var = "function " +var p2237 = &p2237Var +var p2272Var = "thunk from >" +var p2272 = &p2272Var +var p2278Var = "thunk from >" +var p2278 = &p2278Var +var p2291Var = "thunk from from >>" +var p2291 = &p2291Var +var p2299Var = "thunk from >" +var p2299 = &p2299Var +var p2332Var = "thunk from >" +var p2332 = &p2332Var +var p2363Var = "thunk from >" +var p2363 = &p2363Var +var p2374Var = "thunk from >>" +var p2374 = &p2374Var +var p2384Var = "thunk from >" +var p2384 = &p2384Var +var p2399Var = "object " +var p2399 = &p2399Var +var p2401Var = "object " +var p2401 = &p2401Var +var p2425Var = "object " +var p2425 = &p2425Var +var p2429Var = "object " +var p2429 = &p2429Var +var p2432Var = "object " +var p2432 = &p2432Var +var p2435Var = "object " +var p2435 = &p2435Var +var p2438Var = "object " +var p2438 = &p2438Var +var p2441Var = "object " +var p2441 = &p2441Var +var p2444Var = "object " var p2444 = &p2444Var -var p2461Var = "thunk from >" -var p2461 = &p2461Var -var p2472Var = "thunk from >" -var p2472 = &p2472Var -var p2481Var = "thunk from >>" -var p2481 = &p2481Var -var p2487Var = "function " -var p2487 = &p2487Var -var p2493Var = "thunk from >" -var p2493 = &p2493Var -var p2505Var = "function " -var p2505 = &p2505Var -var p2526Var = "thunk from >" -var p2526 = &p2526Var -var p2543Var = "thunk from >" -var p2543 = &p2543Var -var p2568Var = "thunk from >" -var p2568 = &p2568Var -var p2590Var = "thunk from >" -var p2590 = &p2590Var -var p2607Var = "thunk from >" -var p2607 = &p2607Var -var p2618Var = "thunk from >" -var p2618 = &p2618Var -var p2627Var = "thunk from >>" -var p2627 = &p2627Var -var p2633Var = "function " -var p2633 = &p2633Var -var p2639Var = "thunk from >" +var p2447Var = "object " +var p2447 = &p2447Var +var p2452Var = "thunk from >" +var p2452 = &p2452Var +var p2454Var = "thunk from >" +var p2454 = &p2454Var +var p2460Var = "function " +var p2460 = &p2460Var +var p2464Var = "thunk from >" +var p2464 = &p2464Var +var p2473Var = "thunk from >" +var p2473 = &p2473Var +var p2477Var = "function " +var p2477 = &p2477Var +var p2489Var = "thunk from >" +var p2489 = &p2489Var +var p2500Var = "thunk from >" +var p2500 = &p2500Var +var p2512Var = "thunk from >" +var p2512 = &p2512Var +var p2520Var = "thunk from >>" +var p2520 = &p2520Var +var p2534Var = "thunk from >" +var p2534 = &p2534Var +var p2544Var = "thunk from >>" +var p2544 = &p2544Var +var p2555Var = "thunk from >>>" +var p2555 = &p2555Var +var p2561Var = "object " +var p2561 = &p2561Var +var p2563Var = "object " +var p2563 = &p2563Var +var p2587Var = "object " +var p2587 = &p2587Var +var p2591Var = "object " +var p2591 = &p2591Var +var p2594Var = "object " +var p2594 = &p2594Var +var p2597Var = "object " +var p2597 = &p2597Var +var p2600Var = "object " +var p2600 = &p2600Var +var p2603Var = "object " +var p2603 = &p2603Var +var p2606Var = "object " +var p2606 = &p2606Var +var p2609Var = "object " +var p2609 = &p2609Var +var p2614Var = "thunk from >" +var p2614 = &p2614Var +var p2616Var = "thunk from >" +var p2616 = &p2616Var +var p2622Var = "function " +var p2622 = &p2622Var +var p2626Var = "thunk from >" +var p2626 = &p2626Var +var p2635Var = "thunk from >" +var p2635 = &p2635Var +var p2639Var = "function " var p2639 = &p2639Var -var p2653Var = "function " -var p2653 = &p2653Var -var p2674Var = "thunk from >" +var p2651Var = "thunk from >" +var p2651 = &p2651Var +var p2662Var = "thunk from >" +var p2662 = &p2662Var +var p2674Var = "thunk from >" var p2674 = &p2674Var -var p2691Var = "thunk from >" -var p2691 = &p2691Var -var p2714Var = "thunk from >" -var p2714 = &p2714Var -var p2731Var = "thunk from >" -var p2731 = &p2731Var -var p2761Var = "object " -var p2761 = &p2761Var -var p2767Var = "thunk from >" -var p2767 = &p2767Var -var p2784Var = "thunk from >" +var p2682Var = "thunk from >>" +var p2682 = &p2682Var +var p2696Var = "thunk from >" +var p2696 = &p2696Var +var p2706Var = "thunk from >>" +var p2706 = &p2706Var +var p2717Var = "thunk from >>>" +var p2717 = &p2717Var +var p2723Var = "object " +var p2723 = &p2723Var +var p2725Var = "object " +var p2725 = &p2725Var +var p2749Var = "object " +var p2749 = &p2749Var +var p2753Var = "object " +var p2753 = &p2753Var +var p2756Var = "object " +var p2756 = &p2756Var +var p2759Var = "object " +var p2759 = &p2759Var +var p2762Var = "object " +var p2762 = &p2762Var +var p2765Var = "object " +var p2765 = &p2765Var +var p2768Var = "object " +var p2768 = &p2768Var +var p2771Var = "object " +var p2771 = &p2771Var +var p2776Var = "thunk from >" +var p2776 = &p2776Var +var p2778Var = "thunk from >" +var p2778 = &p2778Var +var p2784Var = "function " var p2784 = &p2784Var -var p2792Var = "function " -var p2792 = &p2792Var -var p2796Var = "thunk from >" -var p2796 = &p2796Var -var p2800Var = "function " -var p2800 = &p2800Var -var p2815Var = "thunk from >" -var p2815 = &p2815Var -var p2842Var = "thunk from >" +var p2793Var = "thunk from >" +var p2793 = &p2793Var +var p2806Var = "function " +var p2806 = &p2806Var +var p2816Var = "object " +var p2816 = &p2816Var +var p2818Var = "object " +var p2818 = &p2818Var +var p2842Var = "object " var p2842 = &p2842Var -var p2874Var = "thunk from >" -var p2874 = &p2874Var -var p2889Var = "thunk from >" -var p2889 = &p2889Var -var p2906Var = "thunk from >" -var p2906 = &p2906Var -var p2915Var = "thunk from >>" -var p2915 = &p2915Var -var p2928Var = "thunk from >>" +var p2846Var = "object " +var p2846 = &p2846Var +var p2849Var = "object " +var p2849 = &p2849Var +var p2852Var = "object " +var p2852 = &p2852Var +var p2855Var = "object " +var p2855 = &p2855Var +var p2858Var = "object " +var p2858 = &p2858Var +var p2861Var = "object " +var p2861 = &p2861Var +var p2864Var = "object " +var p2864 = &p2864Var +var p2869Var = "thunk from >" +var p2869 = &p2869Var +var p2871Var = "thunk from >" +var p2871 = &p2871Var +var p2877Var = "function " +var p2877 = &p2877Var +var p2881Var = "thunk from >" +var p2881 = &p2881Var +var p2886Var = "object " +var p2886 = &p2886Var +var p2928Var = "thunk from >" var p2928 = &p2928Var -var p2944Var = "thunk from >" -var p2944 = &p2944Var -var p2968Var = "thunk from >" -var p2968 = &p2968Var -var p3011Var = "thunk from >" -var p3011 = &p3011Var -var p3028Var = "thunk from >" -var p3028 = &p3028Var -var p3049Var = "thunk from >" -var p3049 = &p3049Var -var p3058Var = "thunk from >" -var p3058 = &p3058Var +var p2959Var = "thunk from >" +var p2959 = &p2959Var +var p2971Var = "thunk from >" +var p2971 = &p2971Var +var p3018Var = "thunk from >" +var p3018 = &p3018Var var p3082Var = "thunk from >" var p3082 = &p3082Var -var p3091Var = "thunk from >" -var p3091 = &p3091Var -var p3110Var = "thunk from >" -var p3110 = &p3110Var -var p3118Var = "function " -var p3118 = &p3118Var +var p3104Var = "thunk from >" +var p3104 = &p3104Var var p3127Var = "thunk from >" var p3127 = &p3127Var -var p3135Var = "thunk from >>" -var p3135 = &p3135Var -var p3142Var = "function " -var p3142 = &p3142Var -var p3153Var = "thunk from >" -var p3153 = &p3153Var -var p3168Var = "thunk from >" -var p3168 = &p3168Var -var p3179Var = "thunk from >" -var p3179 = &p3179Var -var p3195Var = "thunk from >>" -var p3195 = &p3195Var -var p3204Var = "thunk from >>>" +var p3133Var = "thunk from >" +var p3133 = &p3133Var +var p3137Var = "function " +var p3137 = &p3137Var +var p3167Var = "thunk from >" +var p3167 = &p3167Var +var p3204Var = "thunk from >>" var p3204 = &p3204Var var p3228Var = "thunk from >" var p3228 = &p3228Var -var p3236Var = "function " -var p3236 = &p3236Var -var p3240Var = "thunk from >" -var p3240 = &p3240Var -var p3244Var = "function " -var p3244 = &p3244Var -var p3259Var = "thunk from >" -var p3259 = &p3259Var -var p3267Var = "thunk from >" -var p3267 = &p3267Var -var p3290Var = "thunk from >" -var p3290 = &p3290Var -var p3294Var = "function " +var p3255Var = "object " +var p3255 = &p3255Var +var p3257Var = "object " +var p3257 = &p3257Var +var p3281Var = "object " +var p3281 = &p3281Var +var p3285Var = "object " +var p3285 = &p3285Var +var p3288Var = "object " +var p3288 = &p3288Var +var p3291Var = "object " +var p3291 = &p3291Var +var p3294Var = "object " var p3294 = &p3294Var -var p3309Var = "thunk from >" -var p3309 = &p3309Var -var p3317Var = "thunk from >" -var p3317 = &p3317Var -var p3344Var = "thunk from >" -var p3344 = &p3344Var -var p3362Var = "object " -var p3362 = &p3362Var -var p3376Var = "thunk from >" -var p3376 = &p3376Var +var p3297Var = "object " +var p3297 = &p3297Var +var p3300Var = "object " +var p3300 = &p3300Var +var p3303Var = "object " +var p3303 = &p3303Var +var p3308Var = "thunk from >" +var p3308 = &p3308Var +var p3310Var = "thunk from >" +var p3310 = &p3310Var +var p3316Var = "function " +var p3316 = &p3316Var +var p3325Var = "thunk from >" +var p3325 = &p3325Var +var p3334Var = "thunk from >>" +var p3334 = &p3334Var +var p3346Var = "function " +var p3346 = &p3346Var +var p3356Var = "object " +var p3356 = &p3356Var +var p3358Var = "object " +var p3358 = &p3358Var +var p3382Var = "object " +var p3382 = &p3382Var +var p3386Var = "object " +var p3386 = &p3386Var var p3389Var = "object " var p3389 = &p3389Var -var p3397Var = "thunk from >" -var p3397 = &p3397Var -var p3401Var = "function " +var p3392Var = "object " +var p3392 = &p3392Var +var p3395Var = "object " +var p3395 = &p3395Var +var p3398Var = "object " +var p3398 = &p3398Var +var p3401Var = "object " var p3401 = &p3401Var -var p3405Var = "thunk from >" -var p3405 = &p3405Var -var p3409Var = "function " +var p3404Var = "object " +var p3404 = &p3404Var +var p3409Var = "thunk from >" var p3409 = &p3409Var -var p3424Var = "thunk from >" -var p3424 = &p3424Var -var p3432Var = "thunk from >" -var p3432 = &p3432Var -var p3457Var = "thunk from >" -var p3457 = &p3457Var -var p3472Var = "object " -var p3472 = &p3472Var -var p3492Var = "thunk from >" -var p3492 = &p3492Var -var p3507Var = "object " -var p3507 = &p3507Var -var p3527Var = "thunk from >" -var p3527 = &p3527Var -var p3542Var = "object " -var p3542 = &p3542Var -var p3562Var = "thunk from >" -var p3562 = &p3562Var -var p3577Var = "object " -var p3577 = &p3577Var -var p3597Var = "thunk from >" -var p3597 = &p3597Var -var p3612Var = "object " -var p3612 = &p3612Var -var p3618Var = "object " -var p3618 = &p3618Var -var p3629Var = "thunk from >" -var p3629 = &p3629Var -var p3637Var = "object " -var p3637 = &p3637Var -var p3650Var = "thunk from >" -var p3650 = &p3650Var -var p3654Var = "function " -var p3654 = &p3654Var -var p3671Var = "thunk from >" -var p3671 = &p3671Var -var p3693Var = "object " -var p3693 = &p3693Var -var p3704Var = "thunk from >" -var p3704 = &p3704Var -var p3708Var = "function " -var p3708 = &p3708Var -var p3723Var = "thunk from >" -var p3723 = &p3723Var -var p3731Var = "thunk from >" +var p3411Var = "thunk from >" +var p3411 = &p3411Var +var p3417Var = "function " +var p3417 = &p3417Var +var p3438Var = "thunk from >" +var p3438 = &p3438Var +var p3458Var = "thunk from >" +var p3458 = &p3458Var +var p3470Var = "thunk from >" +var p3470 = &p3470Var +var p3493Var = "thunk from >" +var p3493 = &p3493Var +var p3505Var = "thunk from >" +var p3505 = &p3505Var +var p3529Var = "thunk from >" +var p3529 = &p3529Var +var p3541Var = "thunk from >" +var p3541 = &p3541Var +var p3548Var = "object " +var p3548 = &p3548Var +var p3550Var = "object " +var p3550 = &p3550Var +var p3574Var = "object " +var p3574 = &p3574Var +var p3578Var = "object " +var p3578 = &p3578Var +var p3581Var = "object " +var p3581 = &p3581Var +var p3584Var = "object " +var p3584 = &p3584Var +var p3587Var = "object " +var p3587 = &p3587Var +var p3590Var = "object " +var p3590 = &p3590Var +var p3593Var = "object " +var p3593 = &p3593Var +var p3596Var = "object " +var p3596 = &p3596Var +var p3601Var = "thunk from >" +var p3601 = &p3601Var +var p3603Var = "thunk from >" +var p3603 = &p3603Var +var p3609Var = "function " +var p3609 = &p3609Var +var p3630Var = "thunk from >" +var p3630 = &p3630Var +var p3647Var = "thunk from >" +var p3647 = &p3647Var +var p3672Var = "thunk from >" +var p3672 = &p3672Var +var p3694Var = "thunk from >" +var p3694 = &p3694Var +var p3711Var = "thunk from >" +var p3711 = &p3711Var +var p3722Var = "thunk from >" +var p3722 = &p3722Var +var p3731Var = "thunk from >>" var p3731 = &p3731Var -var p3756Var = "thunk from >" -var p3756 = &p3756Var -var p3790Var = "thunk from >" -var p3790 = &p3790Var -var p3824Var = "thunk from >" -var p3824 = &p3824Var -var p3858Var = "thunk from >" -var p3858 = &p3858Var -var p3892Var = "thunk from >" -var p3892 = &p3892Var -var p3926Var = "thunk from >" -var p3926 = &p3926Var -var p3960Var = "thunk from >" +var p3737Var = "function " +var p3737 = &p3737Var +var p3743Var = "thunk from >" +var p3743 = &p3743Var +var p3753Var = "object " +var p3753 = &p3753Var +var p3755Var = "object " +var p3755 = &p3755Var +var p3779Var = "object " +var p3779 = &p3779Var +var p3783Var = "object " +var p3783 = &p3783Var +var p3786Var = "object " +var p3786 = &p3786Var +var p3789Var = "object " +var p3789 = &p3789Var +var p3792Var = "object " +var p3792 = &p3792Var +var p3795Var = "object " +var p3795 = &p3795Var +var p3798Var = "object " +var p3798 = &p3798Var +var p3801Var = "object " +var p3801 = &p3801Var +var p3806Var = "thunk from >" +var p3806 = &p3806Var +var p3808Var = "thunk from >" +var p3808 = &p3808Var +var p3814Var = "function " +var p3814 = &p3814Var +var p3835Var = "thunk from >" +var p3835 = &p3835Var +var p3852Var = "thunk from >" +var p3852 = &p3852Var +var p3877Var = "thunk from >" +var p3877 = &p3877Var +var p3899Var = "thunk from >" +var p3899 = &p3899Var +var p3916Var = "thunk from >" +var p3916 = &p3916Var +var p3927Var = "thunk from >" +var p3927 = &p3927Var +var p3936Var = "thunk from >>" +var p3936 = &p3936Var +var p3942Var = "function " +var p3942 = &p3942Var +var p3948Var = "thunk from >" +var p3948 = &p3948Var +var p3960Var = "object " var p3960 = &p3960Var -var p3994Var = "thunk from >" -var p3994 = &p3994Var -var p4028Var = "thunk from >" -var p4028 = &p4028Var -var p4062Var = "thunk from >" -var p4062 = &p4062Var -var p4082Var = "object " +var p3962Var = "object " +var p3962 = &p3962Var +var p3986Var = "object " +var p3986 = &p3986Var +var p3990Var = "object " +var p3990 = &p3990Var +var p3993Var = "object " +var p3993 = &p3993Var +var p3996Var = "object " +var p3996 = &p3996Var +var p3999Var = "object " +var p3999 = &p3999Var +var p4002Var = "object " +var p4002 = &p4002Var +var p4005Var = "object " +var p4005 = &p4005Var +var p4008Var = "object " +var p4008 = &p4008Var +var p4013Var = "thunk from >" +var p4013 = &p4013Var +var p4015Var = "thunk from >" +var p4015 = &p4015Var +var p4021Var = "function " +var p4021 = &p4021Var +var p4042Var = "thunk from >" +var p4042 = &p4042Var +var p4059Var = "thunk from >" +var p4059 = &p4059Var +var p4082Var = "thunk from >" var p4082 = &p4082Var -var p4093Var = "thunk from >" -var p4093 = &p4093Var -var p4102Var = "thunk from >" -var p4102 = &p4102Var -var p4106Var = "function " -var p4106 = &p4106Var -var p4121Var = "thunk from >" -var p4121 = &p4121Var -var p4129Var = "thunk from >" +var p4099Var = "thunk from >" +var p4099 = &p4099Var +var p4129Var = "object " var p4129 = &p4129Var -var p4154Var = "thunk from >" -var p4154 = &p4154Var -var p4166Var = "object " -var p4166 = &p4166Var -var p4174Var = "thunk from >" -var p4174 = &p4174Var -var p4178Var = "function " -var p4178 = &p4178Var -var p4193Var = "thunk from >" -var p4193 = &p4193Var -var p4201Var = "thunk from >" -var p4201 = &p4201Var -var p4257Var = "thunk from >" -var p4257 = &p4257Var -var p4261Var = "function " -var p4261 = &p4261Var -var p4276Var = "thunk from >" -var p4276 = &p4276Var -var p4284Var = "thunk from >" -var p4284 = &p4284Var -var p4334Var = "object " -var p4334 = &p4334Var -var p4361Var = "object " -var p4361 = &p4361Var -var p4388Var = "object " -var p4388 = &p4388Var -var p4415Var = "object " -var p4415 = &p4415Var -var p4442Var = "object " -var p4442 = &p4442Var -var p4469Var = "object " -var p4469 = &p4469Var -var p4496Var = "object " -var p4496 = &p4496Var -var p4523Var = "object " -var p4523 = &p4523Var -var p4550Var = "object " -var p4550 = &p4550Var -var p4577Var = "object " -var p4577 = &p4577Var -var p4604Var = "object " +var p4135Var = "thunk from >" +var p4135 = &p4135Var +var p4152Var = "thunk from >" +var p4152 = &p4152Var +var p4158Var = "object " +var p4158 = &p4158Var +var p4160Var = "object " +var p4160 = &p4160Var +var p4184Var = "object " +var p4184 = &p4184Var +var p4188Var = "object " +var p4188 = &p4188Var +var p4191Var = "object " +var p4191 = &p4191Var +var p4194Var = "object " +var p4194 = &p4194Var +var p4197Var = "object " +var p4197 = &p4197Var +var p4200Var = "object " +var p4200 = &p4200Var +var p4203Var = "object " +var p4203 = &p4203Var +var p4206Var = "object " +var p4206 = &p4206Var +var p4211Var = "thunk from >" +var p4211 = &p4211Var +var p4213Var = "thunk from >" +var p4213 = &p4213Var +var p4219Var = "function " +var p4219 = &p4219Var +var p4223Var = "thunk from >" +var p4223 = &p4223Var +var p4227Var = "function " +var p4227 = &p4227Var +var p4242Var = "thunk from >" +var p4242 = &p4242Var +var p4269Var = "thunk from >" +var p4269 = &p4269Var +var p4301Var = "thunk from >" +var p4301 = &p4301Var +var p4316Var = "thunk from >" +var p4316 = &p4316Var +var p4333Var = "thunk from >" +var p4333 = &p4333Var +var p4342Var = "thunk from >>" +var p4342 = &p4342Var +var p4355Var = "thunk from >>" +var p4355 = &p4355Var +var p4371Var = "thunk from >" +var p4371 = &p4371Var +var p4395Var = "thunk from >" +var p4395 = &p4395Var +var p4438Var = "thunk from >" +var p4438 = &p4438Var +var p4455Var = "thunk from >" +var p4455 = &p4455Var +var p4476Var = "thunk from >" +var p4476 = &p4476Var +var p4485Var = "thunk from >" +var p4485 = &p4485Var +var p4509Var = "thunk from >" +var p4509 = &p4509Var +var p4518Var = "thunk from >" +var p4518 = &p4518Var +var p4537Var = "thunk from >" +var p4537 = &p4537Var +var p4543Var = "object " +var p4543 = &p4543Var +var p4545Var = "object " +var p4545 = &p4545Var +var p4569Var = "object " +var p4569 = &p4569Var +var p4573Var = "object " +var p4573 = &p4573Var +var p4576Var = "object " +var p4576 = &p4576Var +var p4579Var = "object " +var p4579 = &p4579Var +var p4582Var = "object " +var p4582 = &p4582Var +var p4585Var = "object " +var p4585 = &p4585Var +var p4588Var = "object " +var p4588 = &p4588Var +var p4591Var = "object " +var p4591 = &p4591Var +var p4596Var = "thunk from >" +var p4596 = &p4596Var +var p4598Var = "thunk from >" +var p4598 = &p4598Var +var p4604Var = "function " var p4604 = &p4604Var -var p4631Var = "object " -var p4631 = &p4631Var -var p4658Var = "object " -var p4658 = &p4658Var -var p4678Var = "thunk from >" -var p4678 = &p4678Var -var p4682Var = "function " -var p4682 = &p4682Var -var p4697Var = "thunk from >" -var p4697 = &p4697Var -var p4705Var = "thunk from >" -var p4705 = &p4705Var -var p4711Var = "thunk from from >>" -var p4711 = &p4711Var -var p4719Var = "thunk from >" -var p4719 = &p4719Var -var p4725Var = "thunk from from >>" -var p4725 = &p4725Var -var p4736Var = "thunk from >" -var p4736 = &p4736Var -var p4742Var = "thunk from from >>" -var p4742 = &p4742Var -var p4753Var = "thunk from >" -var p4753 = &p4753Var -var p4759Var = "thunk from from >>" -var p4759 = &p4759Var -var p4770Var = "thunk from >" -var p4770 = &p4770Var -var p4776Var = "thunk from from >>" -var p4776 = &p4776Var -var p4787Var = "thunk from >" -var p4787 = &p4787Var -var p4793Var = "thunk from from >>" -var p4793 = &p4793Var -var p4802Var = "object " -var p4802 = &p4802Var -var p4813Var = "object " -var p4813 = &p4813Var -var p4852Var = "thunk from >" -var p4852 = &p4852Var -var p4856Var = "function " -var p4856 = &p4856Var -var p4871Var = "thunk from >" +var p4613Var = "thunk from >" +var p4613 = &p4613Var +var p4621Var = "thunk from >>" +var p4621 = &p4621Var +var p4626Var = "object " +var p4626 = &p4626Var +var p4628Var = "object " +var p4628 = &p4628Var +var p4652Var = "object " +var p4652 = &p4652Var +var p4656Var = "object " +var p4656 = &p4656Var +var p4659Var = "object " +var p4659 = &p4659Var +var p4662Var = "object " +var p4662 = &p4662Var +var p4665Var = "object " +var p4665 = &p4665Var +var p4668Var = "object " +var p4668 = &p4668Var +var p4671Var = "object " +var p4671 = &p4671Var +var p4674Var = "object " +var p4674 = &p4674Var +var p4679Var = "thunk from >" +var p4679 = &p4679Var +var p4681Var = "thunk from >" +var p4681 = &p4681Var +var p4687Var = "function " +var p4687 = &p4687Var +var p4698Var = "thunk from >" +var p4698 = &p4698Var +var p4713Var = "thunk from >" +var p4713 = &p4713Var +var p4724Var = "thunk from >" +var p4724 = &p4724Var +var p4740Var = "thunk from >>" +var p4740 = &p4740Var +var p4749Var = "thunk from >>>" +var p4749 = &p4749Var +var p4773Var = "thunk from >" +var p4773 = &p4773Var +var p4779Var = "object " +var p4779 = &p4779Var +var p4781Var = "object " +var p4781 = &p4781Var +var p4805Var = "object " +var p4805 = &p4805Var +var p4809Var = "object " +var p4809 = &p4809Var +var p4812Var = "object " +var p4812 = &p4812Var +var p4815Var = "object " +var p4815 = &p4815Var +var p4818Var = "object " +var p4818 = &p4818Var +var p4821Var = "object " +var p4821 = &p4821Var +var p4824Var = "object " +var p4824 = &p4824Var +var p4827Var = "object " +var p4827 = &p4827Var +var p4832Var = "thunk from >" +var p4832 = &p4832Var +var p4834Var = "thunk from >" +var p4834 = &p4834Var +var p4840Var = "function " +var p4840 = &p4840Var +var p4844Var = "thunk from >" +var p4844 = &p4844Var +var p4848Var = "function " +var p4848 = &p4848Var +var p4863Var = "thunk from >" +var p4863 = &p4863Var +var p4871Var = "thunk from >" var p4871 = &p4871Var -var p4881Var = "thunk from >" -var p4881 = &p4881Var -var p4887Var = "thunk from >" -var p4887 = &p4887Var -var p4910Var = "thunk from >" -var p4910 = &p4910Var -var p4916Var = "thunk from from >>" -var p4916 = &p4916Var -var p4929Var = "thunk from >" -var p4929 = &p4929Var -var p4944Var = "thunk from >>" -var p4944 = &p4944Var -var p4958Var = "thunk from >" -var p4958 = &p4958Var -var p4977Var = "thunk from >" -var p4977 = &p4977Var -var p4983Var = "thunk from from >>" -var p4983 = &p4983Var -var p4992Var = "thunk from >" -var p4992 = &p4992Var -var p4995Var = "function " -var p4995 = &p4995Var -var p4999Var = "thunk from >" -var p4999 = &p4999Var -var p5003Var = "function " -var p5003 = &p5003Var -var p5018Var = "thunk from >" -var p5018 = &p5018Var -var p5035Var = "thunk from >" -var p5035 = &p5035Var -var p5042Var = "thunk from >" -var p5042 = &p5042Var -var p5046Var = "function " -var p5046 = &p5046Var -var p5054Var = "thunk from >" -var p5054 = &p5054Var -var p5067Var = "thunk from >>" -var p5067 = &p5067Var -var p5077Var = "thunk from >" -var p5077 = &p5077Var -var p5081Var = "function " -var p5081 = &p5081Var -var p5091Var = "thunk from >" -var p5091 = &p5091Var -var p5104Var = "thunk from >>" -var p5104 = &p5104Var -var p5112Var = "thunk from >" -var p5112 = &p5112Var -var p5116Var = "function " -var p5116 = &p5116Var -var p5120Var = "thunk from >" -var p5120 = &p5120Var -var p5129Var = "thunk from from >>" -var p5129 = &p5129Var -var p5135Var = "thunk from >" -var p5135 = &p5135Var -var p5139Var = "function " -var p5139 = &p5139Var -var p5162Var = "thunk from >" -var p5162 = &p5162Var -var p5171Var = "thunk from >>" -var p5171 = &p5171Var -var p5193Var = "thunk from >" -var p5193 = &p5193Var -var p5212Var = "thunk from from >>" -var p5212 = &p5212Var -var p5222Var = "thunk from from >>" +var p4894Var = "thunk from >" +var p4894 = &p4894Var +var p4898Var = "function " +var p4898 = &p4898Var +var p4913Var = "thunk from >" +var p4913 = &p4913Var +var p4921Var = "thunk from >" +var p4921 = &p4921Var +var p4948Var = "thunk from >" +var p4948 = &p4948Var +var p4966Var = "object " +var p4966 = &p4966Var +var p4980Var = "thunk from >" +var p4980 = &p4980Var +var p4993Var = "object " +var p4993 = &p4993Var +var p5001Var = "thunk from >" +var p5001 = &p5001Var +var p5005Var = "function " +var p5005 = &p5005Var +var p5009Var = "thunk from >" +var p5009 = &p5009Var +var p5013Var = "function " +var p5013 = &p5013Var +var p5028Var = "thunk from >" +var p5028 = &p5028Var +var p5036Var = "thunk from >" +var p5036 = &p5036Var +var p5061Var = "thunk from >" +var p5061 = &p5061Var +var p5076Var = "object " +var p5076 = &p5076Var +var p5096Var = "thunk from >" +var p5096 = &p5096Var +var p5111Var = "object " +var p5111 = &p5111Var +var p5131Var = "thunk from >" +var p5131 = &p5131Var +var p5146Var = "object " +var p5146 = &p5146Var +var p5166Var = "thunk from >" +var p5166 = &p5166Var +var p5181Var = "object " +var p5181 = &p5181Var +var p5201Var = "thunk from >" +var p5201 = &p5201Var +var p5216Var = "object " +var p5216 = &p5216Var +var p5222Var = "object " var p5222 = &p5222Var -var p5231Var = "thunk from from >>>" -var p5231 = &p5231Var -var p5237Var = "thunk from >" -var p5237 = &p5237Var -var p5246Var = "thunk from >" -var p5246 = &p5246Var -var p5268Var = "thunk from >" -var p5268 = &p5268Var -var p5277Var = "thunk from from >>" -var p5277 = &p5277Var -var p5285Var = "thunk from >" -var p5285 = &p5285Var -var p5291Var = "thunk from from >>" -var p5291 = &p5291Var -var p5320Var = "thunk from >" -var p5320 = &p5320Var -var p5324Var = "function " -var p5324 = &p5324Var -var p5328Var = "thunk from >" -var p5328 = &p5328Var -var p5333Var = "thunk from from >>" -var p5333 = &p5333Var -var p5350Var = "thunk from from >>" -var p5350 = &p5350Var -var p5359Var = "thunk from from >>" -var p5359 = &p5359Var -var p5369Var = "thunk from >" -var p5369 = &p5369Var -var p5378Var = "thunk from from >>" -var p5378 = &p5378Var -var p5384Var = "thunk from >" -var p5384 = &p5384Var -var p5388Var = "function " -var p5388 = &p5388Var -var p5410Var = "thunk from >" -var p5410 = &p5410Var -var p5419Var = "thunk from >>" -var p5419 = &p5419Var -var p5443Var = "thunk from >" -var p5443 = &p5443Var -var p5462Var = "thunk from from >>" +var p5233Var = "thunk from >" +var p5233 = &p5233Var +var p5241Var = "object " +var p5241 = &p5241Var +var p5254Var = "thunk from >" +var p5254 = &p5254Var +var p5258Var = "function " +var p5258 = &p5258Var +var p5275Var = "thunk from >" +var p5275 = &p5275Var +var p5297Var = "object " +var p5297 = &p5297Var +var p5308Var = "thunk from >" +var p5308 = &p5308Var +var p5312Var = "function " +var p5312 = &p5312Var +var p5327Var = "thunk from >" +var p5327 = &p5327Var +var p5335Var = "thunk from >" +var p5335 = &p5335Var +var p5360Var = "thunk from >" +var p5360 = &p5360Var +var p5394Var = "thunk from >" +var p5394 = &p5394Var +var p5428Var = "thunk from >" +var p5428 = &p5428Var +var p5462Var = "thunk from >" var p5462 = &p5462Var -var p5472Var = "thunk from from >>" -var p5472 = &p5472Var -var p5481Var = "thunk from from >>>" -var p5481 = &p5481Var -var p5487Var = "thunk from >" -var p5487 = &p5487Var -var p5496Var = "thunk from >" +var p5496Var = "thunk from >" var p5496 = &p5496Var -var p5526Var = "thunk from >" -var p5526 = &p5526Var -var p5535Var = "thunk from from >>" -var p5535 = &p5535Var -var p5543Var = "thunk from >" -var p5543 = &p5543Var -var p5562Var = "thunk from from >>" -var p5562 = &p5562Var -var p5591Var = "thunk from >" -var p5591 = &p5591Var -var p5595Var = "function " -var p5595 = &p5595Var -var p5599Var = "thunk from >" -var p5599 = &p5599Var -var p5603Var = "function " -var p5603 = &p5603Var -var p5634Var = "thunk from >" -var p5634 = &p5634Var -var p5650Var = "thunk from >" -var p5650 = &p5650Var -var p5664Var = "thunk from >" -var p5664 = &p5664Var -var p5677Var = "thunk from >>" -var p5677 = &p5677Var -var p5684Var = "thunk from >" -var p5684 = &p5684Var -var p5688Var = "function " -var p5688 = &p5688Var -var p5692Var = "thunk from >" -var p5692 = &p5692Var -var p5701Var = "thunk from from >>" -var p5701 = &p5701Var -var p5707Var = "thunk from >" -var p5707 = &p5707Var -var p5716Var = "thunk from from >>" -var p5716 = &p5716Var -var p5722Var = "thunk from >" -var p5722 = &p5722Var -var p5747Var = "thunk from >" -var p5747 = &p5747Var -var p5761Var = "thunk from >" -var p5761 = &p5761Var -var p5767Var = "thunk from from >>" -var p5767 = &p5767Var -var p5778Var = "thunk from from >>>" +var p5530Var = "thunk from >" +var p5530 = &p5530Var +var p5564Var = "thunk from >" +var p5564 = &p5564Var +var p5598Var = "thunk from >" +var p5598 = &p5598Var +var p5632Var = "thunk from >" +var p5632 = &p5632Var +var p5666Var = "thunk from >" +var p5666 = &p5666Var +var p5686Var = "object " +var p5686 = &p5686Var +var p5697Var = "thunk from >" +var p5697 = &p5697Var +var p5706Var = "thunk from >" +var p5706 = &p5706Var +var p5710Var = "function " +var p5710 = &p5710Var +var p5725Var = "thunk from >" +var p5725 = &p5725Var +var p5733Var = "thunk from >" +var p5733 = &p5733Var +var p5758Var = "thunk from >" +var p5758 = &p5758Var +var p5770Var = "object " +var p5770 = &p5770Var +var p5778Var = "thunk from >" var p5778 = &p5778Var -var p5818Var = "thunk from >" -var p5818 = &p5818Var -var p5827Var = "thunk from from >>" -var p5827 = &p5827Var -var p5846Var = "thunk from from >>>" -var p5846 = &p5846Var -var p5865Var = "thunk from >" +var p5782Var = "function " +var p5782 = &p5782Var +var p5797Var = "thunk from >" +var p5797 = &p5797Var +var p5805Var = "thunk from >" +var p5805 = &p5805Var +var p5861Var = "thunk from >" +var p5861 = &p5861Var +var p5865Var = "function " var p5865 = &p5865Var -var p5871Var = "thunk from from >>" -var p5871 = &p5871Var -var p5899Var = "thunk from >" -var p5899 = &p5899Var -var p5909Var = "thunk from >" -var p5909 = &p5909Var -var p5913Var = "function " -var p5913 = &p5913Var -var p5917Var = "thunk from >" -var p5917 = &p5917Var -var p5926Var = "thunk from from >>" -var p5926 = &p5926Var -var p5937Var = "thunk from from >>>" -var p5937 = &p5937Var -var p5946Var = "thunk from from >>>>" -var p5946 = &p5946Var -var p5957Var = "thunk from from >>>" -var p5957 = &p5957Var -var p5962Var = "thunk from >" -var p5962 = &p5962Var -var p5976Var = "thunk from from >>" -var p5976 = &p5976Var -var p5988Var = "thunk from >" -var p5988 = &p5988Var -var p6001Var = "thunk from from >>" -var p6001 = &p6001Var -var p6008Var = "thunk from >" -var p6008 = &p6008Var -var p6021Var = "thunk from from >>" -var p6021 = &p6021Var -var p6031Var = "thunk from >" -var p6031 = &p6031Var -var p6051Var = "thunk from >" -var p6051 = &p6051Var -var p6055Var = "function " -var p6055 = &p6055Var -var p6059Var = "thunk from >" -var p6059 = &p6059Var -var p6068Var = "thunk from >" -var p6068 = &p6068Var -var p6090Var = "thunk from >" -var p6090 = &p6090Var -var p6112Var = "thunk from >" -var p6112 = &p6112Var -var p6156Var = "thunk from >" -var p6156 = &p6156Var -var p6195Var = "thunk from >" -var p6195 = &p6195Var -var p6219Var = "thunk from >" -var p6219 = &p6219Var -var p6227Var = "thunk from >" -var p6227 = &p6227Var -var p6282Var = "thunk from >" +var p5880Var = "thunk from >" +var p5880 = &p5880Var +var p5888Var = "thunk from >" +var p5888 = &p5888Var +var p5938Var = "object " +var p5938 = &p5938Var +var p5965Var = "object " +var p5965 = &p5965Var +var p5992Var = "object " +var p5992 = &p5992Var +var p6019Var = "object " +var p6019 = &p6019Var +var p6046Var = "object " +var p6046 = &p6046Var +var p6073Var = "object " +var p6073 = &p6073Var +var p6100Var = "object " +var p6100 = &p6100Var +var p6127Var = "object " +var p6127 = &p6127Var +var p6154Var = "object " +var p6154 = &p6154Var +var p6181Var = "object " +var p6181 = &p6181Var +var p6208Var = "object " +var p6208 = &p6208Var +var p6235Var = "object " +var p6235 = &p6235Var +var p6262Var = "object " +var p6262 = &p6262Var +var p6282Var = "thunk from >" var p6282 = &p6282Var -var p6306Var = "thunk from >" -var p6306 = &p6306Var -var p6312Var = "thunk from >" -var p6312 = &p6312Var -var p6327Var = "thunk from >" -var p6327 = &p6327Var -var p6383Var = "thunk from >" -var p6383 = &p6383Var -var p6407Var = "thunk from >" -var p6407 = &p6407Var -var p6415Var = "thunk from >" -var p6415 = &p6415Var -var p6478Var = "thunk from >" -var p6478 = &p6478Var -var p6502Var = "thunk from >" -var p6502 = &p6502Var -var p6510Var = "thunk from >" -var p6510 = &p6510Var -var p6569Var = "thunk from >" -var p6569 = &p6569Var -var p6593Var = "thunk from >" -var p6593 = &p6593Var -var p6601Var = "thunk from >" -var p6601 = &p6601Var -var p6665Var = "thunk from >" -var p6665 = &p6665Var -var p6689Var = "thunk from >" -var p6689 = &p6689Var -var p6695Var = "thunk from >" +var p6286Var = "function " +var p6286 = &p6286Var +var p6301Var = "thunk from >" +var p6301 = &p6301Var +var p6309Var = "thunk from >" +var p6309 = &p6309Var +var p6315Var = "thunk from from >>" +var p6315 = &p6315Var +var p6323Var = "thunk from >" +var p6323 = &p6323Var +var p6329Var = "thunk from from >>" +var p6329 = &p6329Var +var p6340Var = "thunk from >" +var p6340 = &p6340Var +var p6346Var = "thunk from from >>" +var p6346 = &p6346Var +var p6357Var = "thunk from >" +var p6357 = &p6357Var +var p6363Var = "thunk from from >>" +var p6363 = &p6363Var +var p6374Var = "thunk from >" +var p6374 = &p6374Var +var p6380Var = "thunk from from >>" +var p6380 = &p6380Var +var p6391Var = "thunk from >" +var p6391 = &p6391Var +var p6397Var = "thunk from from >>" +var p6397 = &p6397Var +var p6406Var = "object " +var p6406 = &p6406Var +var p6417Var = "object " +var p6417 = &p6417Var +var p6456Var = "thunk from >" +var p6456 = &p6456Var +var p6460Var = "function " +var p6460 = &p6460Var +var p6475Var = "thunk from >" +var p6475 = &p6475Var +var p6485Var = "thunk from >" +var p6485 = &p6485Var +var p6491Var = "thunk from >" +var p6491 = &p6491Var +var p6514Var = "thunk from >" +var p6514 = &p6514Var +var p6520Var = "thunk from from >>" +var p6520 = &p6520Var +var p6533Var = "thunk from >" +var p6533 = &p6533Var +var p6548Var = "thunk from >>" +var p6548 = &p6548Var +var p6562Var = "thunk from >" +var p6562 = &p6562Var +var p6581Var = "thunk from >" +var p6581 = &p6581Var +var p6587Var = "thunk from from >>" +var p6587 = &p6587Var +var p6596Var = "thunk from >" +var p6596 = &p6596Var +var p6599Var = "function " +var p6599 = &p6599Var +var p6603Var = "thunk from >" +var p6603 = &p6603Var +var p6607Var = "function " +var p6607 = &p6607Var +var p6622Var = "thunk from >" +var p6622 = &p6622Var +var p6639Var = "thunk from >" +var p6639 = &p6639Var +var p6646Var = "thunk from >" +var p6646 = &p6646Var +var p6650Var = "function " +var p6650 = &p6650Var +var p6658Var = "thunk from >" +var p6658 = &p6658Var +var p6671Var = "thunk from >>" +var p6671 = &p6671Var +var p6681Var = "thunk from >" +var p6681 = &p6681Var +var p6685Var = "function " +var p6685 = &p6685Var +var p6695Var = "thunk from >" var p6695 = &p6695Var -var p6704Var = "thunk from from >>" -var p6704 = &p6704Var -var p6715Var = "thunk from from >>>" -var p6715 = &p6715Var -var p6724Var = "thunk from from >>>>" +var p6708Var = "thunk from >>" +var p6708 = &p6708Var +var p6716Var = "thunk from >" +var p6716 = &p6716Var +var p6720Var = "function " +var p6720 = &p6720Var +var p6724Var = "thunk from >" var p6724 = &p6724Var -var p6735Var = "thunk from from >>>" -var p6735 = &p6735Var -var p6758Var = "thunk from >" -var p6758 = &p6758Var -var p6796Var = "thunk from >" -var p6796 = &p6796Var -var p6805Var = "thunk from from >>" -var p6805 = &p6805Var -var p6817Var = "thunk from >" -var p6817 = &p6817Var -var p6882Var = "thunk from >" -var p6882 = &p6882Var -var p6894Var = "thunk from >" -var p6894 = &p6894Var -var p6915Var = "thunk from >" -var p6915 = &p6915Var -var p6937Var = "thunk from >" +var p6733Var = "thunk from from >>" +var p6733 = &p6733Var +var p6739Var = "thunk from >" +var p6739 = &p6739Var +var p6743Var = "function " +var p6743 = &p6743Var +var p6766Var = "thunk from >" +var p6766 = &p6766Var +var p6775Var = "thunk from >>" +var p6775 = &p6775Var +var p6797Var = "thunk from >" +var p6797 = &p6797Var +var p6816Var = "thunk from from >>" +var p6816 = &p6816Var +var p6826Var = "thunk from from >>" +var p6826 = &p6826Var +var p6835Var = "thunk from from >>>" +var p6835 = &p6835Var +var p6841Var = "thunk from >" +var p6841 = &p6841Var +var p6850Var = "thunk from >" +var p6850 = &p6850Var +var p6872Var = "thunk from >" +var p6872 = &p6872Var +var p6881Var = "thunk from from >>" +var p6881 = &p6881Var +var p6889Var = "thunk from >" +var p6889 = &p6889Var +var p6895Var = "thunk from from >>" +var p6895 = &p6895Var +var p6924Var = "thunk from >" +var p6924 = &p6924Var +var p6928Var = "function " +var p6928 = &p6928Var +var p6932Var = "thunk from >" +var p6932 = &p6932Var +var p6937Var = "thunk from from >>" var p6937 = &p6937Var -var p6956Var = "thunk from >" -var p6956 = &p6956Var -var p6972Var = "thunk from >" -var p6972 = &p6972Var -var p6988Var = "thunk from >" +var p6954Var = "thunk from from >>" +var p6954 = &p6954Var +var p6963Var = "thunk from from >>" +var p6963 = &p6963Var +var p6973Var = "thunk from >" +var p6973 = &p6973Var +var p6982Var = "thunk from from >>" +var p6982 = &p6982Var +var p6988Var = "thunk from >" var p6988 = &p6988Var -var p6992Var = "function " +var p6992Var = "function " var p6992 = &p6992Var -var p7007Var = "thunk from >" -var p7007 = &p7007Var -var p7024Var = "thunk from >" -var p7024 = &p7024Var -var p7044Var = "thunk from >" -var p7044 = &p7044Var -var p7055Var = "thunk from >" -var p7055 = &p7055Var -var p7080Var = "thunk from >" -var p7080 = &p7080Var -var p7089Var = "thunk from >" -var p7089 = &p7089Var -var p7110Var = "thunk from >" -var p7110 = &p7110Var -var p7131Var = "object " -var p7131 = &p7131Var -var p7152Var = "thunk from >" -var p7152 = &p7152Var -var p7168Var = "thunk from >" -var p7168 = &p7168Var -var p7181Var = "object " -var p7181 = &p7181Var -var p7193Var = "thunk from >" -var p7193 = &p7193Var -var p7214Var = "object " -var p7214 = &p7214Var -var p7241Var = "thunk from >" -var p7241 = &p7241Var -var p7257Var = "thunk from >" -var p7257 = &p7257Var -var p7273Var = "object " -var p7273 = &p7273Var -var p7288Var = "thunk from >" +var p7014Var = "thunk from >" +var p7014 = &p7014Var +var p7023Var = "thunk from >>" +var p7023 = &p7023Var +var p7047Var = "thunk from >" +var p7047 = &p7047Var +var p7066Var = "thunk from from >>" +var p7066 = &p7066Var +var p7076Var = "thunk from from >>" +var p7076 = &p7076Var +var p7085Var = "thunk from from >>>" +var p7085 = &p7085Var +var p7091Var = "thunk from >" +var p7091 = &p7091Var +var p7100Var = "thunk from >" +var p7100 = &p7100Var +var p7130Var = "thunk from >" +var p7130 = &p7130Var +var p7139Var = "thunk from from >>" +var p7139 = &p7139Var +var p7147Var = "thunk from >" +var p7147 = &p7147Var +var p7166Var = "thunk from from >>" +var p7166 = &p7166Var +var p7195Var = "thunk from >" +var p7195 = &p7195Var +var p7199Var = "function " +var p7199 = &p7199Var +var p7203Var = "thunk from >" +var p7203 = &p7203Var +var p7207Var = "function " +var p7207 = &p7207Var +var p7238Var = "thunk from >" +var p7238 = &p7238Var +var p7254Var = "thunk from >" +var p7254 = &p7254Var +var p7268Var = "thunk from >" +var p7268 = &p7268Var +var p7281Var = "thunk from >>" +var p7281 = &p7281Var +var p7288Var = "thunk from >" var p7288 = &p7288Var -var p7297Var = "thunk from >" -var p7297 = &p7297Var -var p7312Var = "thunk from from >>" -var p7312 = &p7312Var -var p7334Var = "thunk from from >>" -var p7334 = &p7334Var -var p7340Var = "thunk from >" -var p7340 = &p7340Var -var p7363Var = "thunk from from >>" -var p7363 = &p7363Var -var p7383Var = "thunk from >" -var p7383 = &p7383Var -var p7399Var = "thunk from from >>" -var p7399 = &p7399Var -var p7413Var = "thunk from from >>" -var p7413 = &p7413Var -var p7425Var = "thunk from >" -var p7425 = &p7425Var -var p7454Var = "thunk from >" -var p7454 = &p7454Var -var p7475Var = "thunk from >" +var p7292Var = "function " +var p7292 = &p7292Var +var p7296Var = "thunk from >" +var p7296 = &p7296Var +var p7305Var = "thunk from from >>" +var p7305 = &p7305Var +var p7311Var = "thunk from >" +var p7311 = &p7311Var +var p7320Var = "thunk from from >>" +var p7320 = &p7320Var +var p7326Var = "thunk from >" +var p7326 = &p7326Var +var p7351Var = "thunk from >" +var p7351 = &p7351Var +var p7365Var = "thunk from >" +var p7365 = &p7365Var +var p7371Var = "thunk from from >>" +var p7371 = &p7371Var +var p7382Var = "thunk from from >>>" +var p7382 = &p7382Var +var p7422Var = "thunk from >" +var p7422 = &p7422Var +var p7431Var = "thunk from from >>" +var p7431 = &p7431Var +var p7450Var = "thunk from from >>>" +var p7450 = &p7450Var +var p7469Var = "thunk from >" +var p7469 = &p7469Var +var p7475Var = "thunk from from >>" var p7475 = &p7475Var -var p7479Var = "function " -var p7479 = &p7479Var -var p7494Var = "thunk from >" -var p7494 = &p7494Var -var p7502Var = "thunk from >" -var p7502 = &p7502Var -var p7527Var = "thunk from >" -var p7527 = &p7527Var -var p7536Var = "thunk from >" -var p7536 = &p7536Var -var p7555Var = "thunk from >" -var p7555 = &p7555Var -var p7582Var = "thunk from >" -var p7582 = &p7582Var -var p7609Var = "thunk from >" -var p7609 = &p7609Var -var p7636Var = "thunk from >" -var p7636 = &p7636Var -var p7647Var = "thunk from from >>" -var p7647 = &p7647Var -var p7668Var = "thunk from >" -var p7668 = &p7668Var -var p7691Var = "thunk from from >>" -var p7691 = &p7691Var -var p7705Var = "thunk from >" -var p7705 = &p7705Var -var p7721Var = "thunk from from >>" -var p7721 = &p7721Var -var p7732Var = "thunk from from >>" -var p7732 = &p7732Var -var p7743Var = "thunk from >" -var p7743 = &p7743Var -var p7777Var = "thunk from >" -var p7777 = &p7777Var -var p7786Var = "thunk from >" -var p7786 = &p7786Var -var p7812Var = "thunk from >" -var p7812 = &p7812Var -var p7821Var = "thunk from >" -var p7821 = &p7821Var -var p7833Var = "thunk from >" -var p7833 = &p7833Var -var p7839Var = "thunk from >>" -var p7839 = &p7839Var -var p7850Var = "function " -var p7850 = &p7850Var -var p7854Var = "thunk from >" -var p7854 = &p7854Var -var p7858Var = "function " -var p7858 = &p7858Var -var p7873Var = "thunk from >" -var p7873 = &p7873Var -var p7883Var = "thunk from >>" -var p7883 = &p7883Var -var p7902Var = "thunk from >" -var p7902 = &p7902Var -var p7919Var = "thunk from >>" -var p7919 = &p7919Var -var p7928Var = "function " -var p7928 = &p7928Var -var p7932Var = "thunk from >" -var p7932 = &p7932Var -var p7936Var = "function " -var p7936 = &p7936Var -var p7951Var = "thunk from >" -var p7951 = &p7951Var -var p7961Var = "thunk from >" -var p7961 = &p7961Var -var p7971Var = "thunk from >>" -var p7971 = &p7971Var -var p7990Var = "thunk from >" -var p7990 = &p7990Var -var p8003Var = "function " -var p8003 = &p8003Var -var p8024Var = "thunk from >" -var p8024 = &p8024Var -var p8041Var = "thunk from >" -var p8041 = &p8041Var -var p8064Var = "thunk from >" -var p8064 = &p8064Var -var p8081Var = "thunk from >" -var p8081 = &p8081Var -var p8104Var = "thunk from >" -var p8104 = &p8104Var -var p8121Var = "thunk from >" -var p8121 = &p8121Var -var p8132Var = "thunk from >" -var p8132 = &p8132Var -var p8143Var = "thunk from >>" -var p8143 = &p8143Var -var p8153Var = "function " -var p8153 = &p8153Var -var p8188Var = "function " -var p8188 = &p8188Var -var p8209Var = "thunk from >" -var p8209 = &p8209Var -var p8226Var = "thunk from >" -var p8226 = &p8226Var -var p8247Var = "function " -var p8247 = &p8247Var -var p8268Var = "thunk from >" -var p8268 = &p8268Var -var p8285Var = "thunk from >" -var p8285 = &p8285Var -var p8311Var = "function " -var p8311 = &p8311Var -var p8332Var = "thunk from >" -var p8332 = &p8332Var -var p8349Var = "thunk from >" -var p8349 = &p8349Var -var p8372Var = "thunk from >" -var p8372 = &p8372Var -var p8389Var = "thunk from >" -var p8389 = &p8389Var -var p8409Var = "function " +var p7503Var = "thunk from >" +var p7503 = &p7503Var +var p7513Var = "thunk from >" +var p7513 = &p7513Var +var p7517Var = "function " +var p7517 = &p7517Var +var p7521Var = "thunk from >" +var p7521 = &p7521Var +var p7530Var = "thunk from from >>" +var p7530 = &p7530Var +var p7541Var = "thunk from from >>>" +var p7541 = &p7541Var +var p7550Var = "thunk from from >>>>" +var p7550 = &p7550Var +var p7561Var = "thunk from from >>>" +var p7561 = &p7561Var +var p7566Var = "thunk from >" +var p7566 = &p7566Var +var p7580Var = "thunk from from >>" +var p7580 = &p7580Var +var p7592Var = "thunk from >" +var p7592 = &p7592Var +var p7605Var = "thunk from from >>" +var p7605 = &p7605Var +var p7612Var = "thunk from >" +var p7612 = &p7612Var +var p7625Var = "thunk from from >>" +var p7625 = &p7625Var +var p7635Var = "thunk from >" +var p7635 = &p7635Var +var p7655Var = "thunk from >" +var p7655 = &p7655Var +var p7659Var = "function " +var p7659 = &p7659Var +var p7663Var = "thunk from >" +var p7663 = &p7663Var +var p7672Var = "thunk from >" +var p7672 = &p7672Var +var p7694Var = "thunk from >" +var p7694 = &p7694Var +var p7716Var = "thunk from >" +var p7716 = &p7716Var +var p7760Var = "thunk from >" +var p7760 = &p7760Var +var p7799Var = "thunk from >" +var p7799 = &p7799Var +var p7823Var = "thunk from >" +var p7823 = &p7823Var +var p7831Var = "thunk from >" +var p7831 = &p7831Var +var p7886Var = "thunk from >" +var p7886 = &p7886Var +var p7910Var = "thunk from >" +var p7910 = &p7910Var +var p7916Var = "thunk from >" +var p7916 = &p7916Var +var p7931Var = "thunk from >" +var p7931 = &p7931Var +var p7987Var = "thunk from >" +var p7987 = &p7987Var +var p8011Var = "thunk from >" +var p8011 = &p8011Var +var p8019Var = "thunk from >" +var p8019 = &p8019Var +var p8082Var = "thunk from >" +var p8082 = &p8082Var +var p8106Var = "thunk from >" +var p8106 = &p8106Var +var p8114Var = "thunk from >" +var p8114 = &p8114Var +var p8173Var = "thunk from >" +var p8173 = &p8173Var +var p8197Var = "thunk from >" +var p8197 = &p8197Var +var p8205Var = "thunk from >" +var p8205 = &p8205Var +var p8269Var = "thunk from >" +var p8269 = &p8269Var +var p8293Var = "thunk from >" +var p8293 = &p8293Var +var p8299Var = "thunk from >" +var p8299 = &p8299Var +var p8308Var = "thunk from from >>" +var p8308 = &p8308Var +var p8319Var = "thunk from from >>>" +var p8319 = &p8319Var +var p8328Var = "thunk from from >>>>" +var p8328 = &p8328Var +var p8339Var = "thunk from from >>>" +var p8339 = &p8339Var +var p8362Var = "thunk from >" +var p8362 = &p8362Var +var p8400Var = "thunk from >" +var p8400 = &p8400Var +var p8409Var = "thunk from from >>" var p8409 = &p8409Var -var p8430Var = "thunk from >" -var p8430 = &p8430Var -var p8447Var = "thunk from >" -var p8447 = &p8447Var -var p8470Var = "thunk from >" -var p8470 = &p8470Var -var p8487Var = "thunk from >" -var p8487 = &p8487Var -var p8507Var = "function " -var p8507 = &p8507Var -var p8516Var = "thunk from >" -var p8516 = &p8516Var -var p8519Var = "function " +var p8421Var = "thunk from >" +var p8421 = &p8421Var +var p8486Var = "thunk from >" +var p8486 = &p8486Var +var p8498Var = "thunk from >" +var p8498 = &p8498Var +var p8519Var = "thunk from >" var p8519 = &p8519Var -var p8534Var = "function " -var p8534 = &p8534Var -var p8538Var = "thunk from >" -var p8538 = &p8538Var -var p8542Var = "function " -var p8542 = &p8542Var -var p8551Var = "thunk from >" -var p8551 = &p8551Var -var p8567Var = "thunk from >>" -var p8567 = &p8567Var -var p8571Var = "thunk from >>>" -var p8571 = &p8571Var -var p8596Var = "thunk from >>>" +var p8541Var = "thunk from >" +var p8541 = &p8541Var +var p8560Var = "thunk from >" +var p8560 = &p8560Var +var p8576Var = "thunk from >" +var p8576 = &p8576Var +var p8592Var = "thunk from >" +var p8592 = &p8592Var +var p8596Var = "function " var p8596 = &p8596Var -var p8622Var = "thunk from >>>" -var p8622 = &p8622Var -var p8627Var = "thunk from >>>>" -var p8627 = &p8627Var -var p8645Var = "thunk from >>>" -var p8645 = &p8645Var -var p8650Var = "thunk from >>>>" -var p8650 = &p8650Var -var p8663Var = "thunk from >>" -var p8663 = &p8663Var -var p8669Var = "thunk from >" -var p8669 = &p8669Var -var p8673Var = "function " -var p8673 = &p8673Var -var p8687Var = "thunk from >" -var p8687 = &p8687Var -var p8692Var = "thunk from >>" -var p8692 = &p8692Var -var p8700Var = "thunk from >" -var p8700 = &p8700Var -var p8703Var = "thunk from >" -var p8703 = &p8703Var -var p8714Var = "thunk from from >>" +var p8611Var = "thunk from >" +var p8611 = &p8611Var +var p8628Var = "thunk from >" +var p8628 = &p8628Var +var p8648Var = "thunk from >" +var p8648 = &p8648Var +var p8659Var = "thunk from >" +var p8659 = &p8659Var +var p8684Var = "thunk from >" +var p8684 = &p8684Var +var p8693Var = "thunk from >" +var p8693 = &p8693Var +var p8714Var = "thunk from >" var p8714 = &p8714Var -var p8723Var = "thunk from from >>" -var p8723 = &p8723Var -var p8744Var = "thunk from from >>" -var p8744 = &p8744Var -var p8750Var = "thunk from from >>>" -var p8750 = &p8750Var -var p8762Var = "thunk from >" -var p8762 = &p8762Var -var p8771Var = "thunk from from >>" -var p8771 = &p8771Var -var p8785Var = "thunk from >" +var p8735Var = "object " +var p8735 = &p8735Var +var p8756Var = "thunk from >" +var p8756 = &p8756Var +var p8772Var = "thunk from >" +var p8772 = &p8772Var +var p8785Var = "object " var p8785 = &p8785Var -var p8801Var = "thunk from >>" -var p8801 = &p8801Var -var p8806Var = "thunk from >>" -var p8806 = &p8806Var -var p8813Var = "function " -var p8813 = &p8813Var -var p8817Var = "thunk from >" -var p8817 = &p8817Var -var p8826Var = "thunk from from >>" -var p8826 = &p8826Var -var p8832Var = "thunk from >" -var p8832 = &p8832Var -var p8836Var = "function " -var p8836 = &p8836Var -var p8938Var = "thunk from >" +var p8797Var = "thunk from >" +var p8797 = &p8797Var +var p8818Var = "object " +var p8818 = &p8818Var +var p8845Var = "thunk from >" +var p8845 = &p8845Var +var p8861Var = "thunk from >" +var p8861 = &p8861Var +var p8877Var = "object " +var p8877 = &p8877Var +var p8892Var = "thunk from >" +var p8892 = &p8892Var +var p8901Var = "thunk from >" +var p8901 = &p8901Var +var p8916Var = "thunk from from >>" +var p8916 = &p8916Var +var p8938Var = "thunk from from >>" var p8938 = &p8938Var -var p8947Var = "thunk from from >>" -var p8947 = &p8947Var -var p8983Var = "thunk from >" -var p8983 = &p8983Var -var p9005Var = "thunk from >" -var p9005 = &p9005Var -var p9021Var = "thunk from >>" -var p9021 = &p9021Var -var p9027Var = "thunk from >>>" -var p9027 = &p9027Var -var p9038Var = "thunk from >>" -var p9038 = &p9038Var -var p9046Var = "function " -var p9046 = &p9046Var -var p9055Var = "thunk from >" -var p9055 = &p9055Var -var p9063Var = "function " -var p9063 = &p9063Var -var p9067Var = "thunk from >" -var p9067 = &p9067Var -var p9076Var = "thunk from from >>" -var p9076 = &p9076Var -var p9082Var = "thunk from >" -var p9082 = &p9082Var -var p9086Var = "function " -var p9086 = &p9086Var -var p9120Var = "thunk from >" -var p9120 = &p9120Var -var p9136Var = "thunk from >>" -var p9136 = &p9136Var -var p9142Var = "thunk from >>>" -var p9142 = &p9142Var -var p9153Var = "thunk from >>" -var p9153 = &p9153Var -var p9161Var = "function " -var p9161 = &p9161Var -var p9165Var = "thunk from >" -var p9165 = &p9165Var -var p9174Var = "thunk from from >>" -var p9174 = &p9174Var -var p9180Var = "thunk from >" -var p9180 = &p9180Var -var p9184Var = "function " -var p9184 = &p9184Var -var p9209Var = "thunk from >" -var p9209 = &p9209Var -var p9213Var = "function " +var p8944Var = "thunk from >" +var p8944 = &p8944Var +var p8967Var = "thunk from from >>" +var p8967 = &p8967Var +var p8987Var = "thunk from >" +var p8987 = &p8987Var +var p9003Var = "thunk from from >>" +var p9003 = &p9003Var +var p9017Var = "thunk from from >>" +var p9017 = &p9017Var +var p9029Var = "thunk from >" +var p9029 = &p9029Var +var p9058Var = "thunk from >" +var p9058 = &p9058Var +var p9079Var = "thunk from >" +var p9079 = &p9079Var +var p9083Var = "function " +var p9083 = &p9083Var +var p9098Var = "thunk from >" +var p9098 = &p9098Var +var p9106Var = "thunk from >" +var p9106 = &p9106Var +var p9131Var = "thunk from >" +var p9131 = &p9131Var +var p9140Var = "thunk from >" +var p9140 = &p9140Var +var p9159Var = "thunk from >" +var p9159 = &p9159Var +var p9186Var = "thunk from >" +var p9186 = &p9186Var +var p9213Var = "thunk from >" var p9213 = &p9213Var -var p9223Var = "thunk from >" -var p9223 = &p9223Var -var p9234Var = "thunk from >>" -var p9234 = &p9234Var -var p9243Var = "function " -var p9243 = &p9243Var -var p9252Var = "thunk from >" -var p9252 = &p9252Var -var p9261Var = "function " -var p9261 = &p9261Var -var p9265Var = "thunk from >" -var p9265 = &p9265Var -var p9269Var = "function " -var p9269 = &p9269Var -var p9330Var = "thunk from >" -var p9330 = &p9330Var -var p9357Var = "thunk from >" -var p9357 = &p9357Var -var p9369Var = "thunk from >" -var p9369 = &p9369Var -var p9390Var = "thunk from >" +var p9240Var = "thunk from >" +var p9240 = &p9240Var +var p9251Var = "thunk from from >>" +var p9251 = &p9251Var +var p9272Var = "thunk from >" +var p9272 = &p9272Var +var p9295Var = "thunk from from >>" +var p9295 = &p9295Var +var p9309Var = "thunk from >" +var p9309 = &p9309Var +var p9325Var = "thunk from from >>" +var p9325 = &p9325Var +var p9336Var = "thunk from from >>" +var p9336 = &p9336Var +var p9347Var = "thunk from >" +var p9347 = &p9347Var +var p9381Var = "thunk from >" +var p9381 = &p9381Var +var p9390Var = "thunk from >" var p9390 = &p9390Var -var p9419Var = "thunk from >" -var p9419 = &p9419Var -var p9426Var = "thunk from >" -var p9426 = &p9426Var -var p9435Var = "thunk from from >>" -var p9435 = &p9435Var -var p9447Var = "thunk from from >>>" -var p9447 = &p9447Var -var p9454Var = "thunk from >" +var p9416Var = "thunk from >" +var p9416 = &p9416Var +var p9425Var = "thunk from >" +var p9425 = &p9425Var +var p9437Var = "thunk from >" +var p9437 = &p9437Var +var p9443Var = "thunk from >>" +var p9443 = &p9443Var +var p9452Var = "object " +var p9452 = &p9452Var +var p9454Var = "object " var p9454 = &p9454Var -var p9464Var = "thunk from >" -var p9464 = &p9464Var -var p9471Var = "thunk from from >>" -var p9471 = &p9471Var -var p9481Var = "thunk from from >>" -var p9481 = &p9481Var -var p9484Var = "thunk from from >>>" -var p9484 = &p9484Var -var p9500Var = "thunk from from >>>" +var p9478Var = "object " +var p9478 = &p9478Var +var p9482Var = "object " +var p9482 = &p9482Var +var p9485Var = "object " +var p9485 = &p9485Var +var p9488Var = "object " +var p9488 = &p9488Var +var p9491Var = "object " +var p9491 = &p9491Var +var p9494Var = "object " +var p9494 = &p9494Var +var p9497Var = "object " +var p9497 = &p9497Var +var p9500Var = "object " var p9500 = &p9500Var -var p9504Var = "thunk from from >>>>" -var p9504 = &p9504Var -var p9514Var = "thunk from from >>>>>" -var p9514 = &p9514Var -var p9528Var = "thunk from from >>>>>>" -var p9528 = &p9528Var -var p9538Var = "thunk from from >>" -var p9538 = &p9538Var -var p9555Var = "thunk from >" -var p9555 = &p9555Var -var p9577Var = "thunk from >" -var p9577 = &p9577Var -var p9584Var = "thunk from >" -var p9584 = &p9584Var -var p9591Var = "thunk from from >>" +var p9505Var = "thunk from >" +var p9505 = &p9505Var +var p9507Var = "thunk from >" +var p9507 = &p9507Var +var p9513Var = "function " +var p9513 = &p9513Var +var p9517Var = "thunk from >" +var p9517 = &p9517Var +var p9521Var = "function " +var p9521 = &p9521Var +var p9536Var = "thunk from >" +var p9536 = &p9536Var +var p9546Var = "thunk from >>" +var p9546 = &p9546Var +var p9565Var = "thunk from >" +var p9565 = &p9565Var +var p9582Var = "thunk from >>" +var p9582 = &p9582Var +var p9589Var = "object " +var p9589 = &p9589Var +var p9591Var = "object " var p9591 = &p9591Var -var p9601Var = "thunk from from >>" -var p9601 = &p9601Var -var p9604Var = "thunk from from >>>" -var p9604 = &p9604Var -var p9620Var = "thunk from from >>>" -var p9620 = &p9620Var -var p9624Var = "thunk from from >>>>" -var p9624 = &p9624Var -var p9645Var = "thunk from from >>>>>" -var p9645 = &p9645Var -var p9654Var = "thunk from from >>>>>" +var p9615Var = "object " +var p9615 = &p9615Var +var p9619Var = "object " +var p9619 = &p9619Var +var p9622Var = "object " +var p9622 = &p9622Var +var p9625Var = "object " +var p9625 = &p9625Var +var p9628Var = "object " +var p9628 = &p9628Var +var p9631Var = "object " +var p9631 = &p9631Var +var p9634Var = "object " +var p9634 = &p9634Var +var p9637Var = "object " +var p9637 = &p9637Var +var p9642Var = "thunk from >" +var p9642 = &p9642Var +var p9644Var = "thunk from >" +var p9644 = &p9644Var +var p9650Var = "function " +var p9650 = &p9650Var +var p9654Var = "thunk from >" var p9654 = &p9654Var -var p9668Var = "thunk from from >>>>>>" -var p9668 = &p9668Var -var p9685Var = "thunk from from >>>" -var p9685 = &p9685Var -var p9691Var = "thunk from from >>" -var p9691 = &p9691Var -var p9708Var = "thunk from >" -var p9708 = &p9708Var -var p9718Var = "thunk from >" -var p9718 = &p9718Var -var p9728Var = "function " -var p9728 = &p9728Var -var p9732Var = "thunk from >" -var p9732 = &p9732Var -var p9736Var = "function " -var p9736 = &p9736Var -var p9797Var = "thunk from >" -var p9797 = &p9797Var -var p9824Var = "thunk from >" -var p9824 = &p9824Var -var p9831Var = "thunk from >" -var p9831 = &p9831Var -var p9840Var = "thunk from from >>" -var p9840 = &p9840Var -var p9880Var = "thunk from >" -var p9880 = &p9880Var -var p9889Var = "thunk from from >>" -var p9889 = &p9889Var -var p9901Var = "thunk from >" -var p9901 = &p9901Var -var p9911Var = "thunk from >>" -var p9911 = &p9911Var -var p9934Var = "thunk from >>" +var p9658Var = "function " +var p9658 = &p9658Var +var p9673Var = "thunk from >" +var p9673 = &p9673Var +var p9683Var = "thunk from >" +var p9683 = &p9683Var +var p9693Var = "thunk from >>" +var p9693 = &p9693Var +var p9712Var = "thunk from >" +var p9712 = &p9712Var +var p9723Var = "object " +var p9723 = &p9723Var +var p9725Var = "object " +var p9725 = &p9725Var +var p9749Var = "object " +var p9749 = &p9749Var +var p9753Var = "object " +var p9753 = &p9753Var +var p9756Var = "object " +var p9756 = &p9756Var +var p9759Var = "object " +var p9759 = &p9759Var +var p9762Var = "object " +var p9762 = &p9762Var +var p9765Var = "object " +var p9765 = &p9765Var +var p9768Var = "object " +var p9768 = &p9768Var +var p9771Var = "object " +var p9771 = &p9771Var +var p9776Var = "thunk from >" +var p9776 = &p9776Var +var p9778Var = "thunk from >" +var p9778 = &p9778Var +var p9784Var = "function " +var p9784 = &p9784Var +var p9805Var = "thunk from >" +var p9805 = &p9805Var +var p9822Var = "thunk from >" +var p9822 = &p9822Var +var p9845Var = "thunk from >" +var p9845 = &p9845Var +var p9862Var = "thunk from >" +var p9862 = &p9862Var +var p9885Var = "thunk from >" +var p9885 = &p9885Var +var p9902Var = "thunk from >" +var p9902 = &p9902Var +var p9913Var = "thunk from >" +var p9913 = &p9913Var +var p9924Var = "thunk from >>" +var p9924 = &p9924Var +var p9932Var = "object " +var p9932 = &p9932Var +var p9934Var = "object " var p9934 = &p9934Var -var p9947Var = "thunk from >" -var p9947 = &p9947Var -var p9968Var = "thunk from >" +var p9958Var = "object " +var p9958 = &p9958Var +var p9962Var = "object " +var p9962 = &p9962Var +var p9965Var = "object " +var p9965 = &p9965Var +var p9968Var = "object " var p9968 = &p9968Var -var p9997Var = "thunk from >" -var p9997 = &p9997Var -var p10019Var = "thunk from >" -var p10019 = &p10019Var -var p10027Var = "thunk from >" -var p10027 = &p10027Var -var p10036Var = "thunk from from >>" -var p10036 = &p10036Var -var p10048Var = "thunk from from >>>" -var p10048 = &p10048Var -var p10055Var = "thunk from >" -var p10055 = &p10055Var -var p10078Var = "thunk from from >>" -var p10078 = &p10078Var -var p10084Var = "thunk from from >>>" -var p10084 = &p10084Var -var p10100Var = "thunk from from >>>>" -var p10100 = &p10100Var -var p10105Var = "thunk from >" -var p10105 = &p10105Var -var p10131Var = "thunk from >" -var p10131 = &p10131Var -var p10160Var = "thunk from >" -var p10160 = &p10160Var -var p10182Var = "thunk from >" -var p10182 = &p10182Var -var p10190Var = "thunk from >" -var p10190 = &p10190Var -var p10213Var = "thunk from from >>" -var p10213 = &p10213Var -var p10230Var = "thunk from from >>>" -var p10230 = &p10230Var -var p10239Var = "thunk from from >>>" -var p10239 = &p10239Var -var p10255Var = "thunk from from >>>>" -var p10255 = &p10255Var -var p10260Var = "thunk from >" -var p10260 = &p10260Var -var p10269Var = "thunk from from >>" +var p9971Var = "object " +var p9971 = &p9971Var +var p9974Var = "object " +var p9974 = &p9974Var +var p9977Var = "object " +var p9977 = &p9977Var +var p9980Var = "object " +var p9980 = &p9980Var +var p9985Var = "thunk from >" +var p9985 = &p9985Var +var p9987Var = "thunk from >" +var p9987 = &p9987Var +var p9993Var = "function " +var p9993 = &p9993Var +var p10026Var = "object " +var p10026 = &p10026Var +var p10028Var = "object " +var p10028 = &p10028Var +var p10052Var = "object " +var p10052 = &p10052Var +var p10056Var = "object " +var p10056 = &p10056Var +var p10059Var = "object " +var p10059 = &p10059Var +var p10062Var = "object " +var p10062 = &p10062Var +var p10065Var = "object " +var p10065 = &p10065Var +var p10068Var = "object " +var p10068 = &p10068Var +var p10071Var = "object " +var p10071 = &p10071Var +var p10074Var = "object " +var p10074 = &p10074Var +var p10079Var = "thunk from >" +var p10079 = &p10079Var +var p10081Var = "thunk from >" +var p10081 = &p10081Var +var p10087Var = "function " +var p10087 = &p10087Var +var p10108Var = "thunk from >" +var p10108 = &p10108Var +var p10125Var = "thunk from >" +var p10125 = &p10125Var +var p10144Var = "object " +var p10144 = &p10144Var +var p10146Var = "object " +var p10146 = &p10146Var +var p10170Var = "object " +var p10170 = &p10170Var +var p10174Var = "object " +var p10174 = &p10174Var +var p10177Var = "object " +var p10177 = &p10177Var +var p10180Var = "object " +var p10180 = &p10180Var +var p10183Var = "object " +var p10183 = &p10183Var +var p10186Var = "object " +var p10186 = &p10186Var +var p10189Var = "object " +var p10189 = &p10189Var +var p10192Var = "object " +var p10192 = &p10192Var +var p10197Var = "thunk from >" +var p10197 = &p10197Var +var p10199Var = "thunk from >" +var p10199 = &p10199Var +var p10205Var = "function " +var p10205 = &p10205Var +var p10226Var = "thunk from >" +var p10226 = &p10226Var +var p10243Var = "thunk from >" +var p10243 = &p10243Var +var p10267Var = "object " +var p10267 = &p10267Var +var p10269Var = "object " var p10269 = &p10269Var -var p10292Var = "thunk from >" -var p10292 = &p10292Var -var p10302Var = "thunk from >" -var p10302 = &p10302Var -var p10314Var = "function " -var p10314 = &p10314Var -var p10335Var = "thunk from >" -var p10335 = &p10335Var -var p10352Var = "thunk from >" -var p10352 = &p10352Var -var p10368Var = "thunk from >" -var p10368 = &p10368Var -var p10384Var = "thunk from >>" -var p10384 = &p10384Var -var p10393Var = "thunk from >>>" -var p10393 = &p10393Var -var p10404Var = "function " -var p10404 = &p10404Var -var p10423Var = "thunk from >" -var p10423 = &p10423Var -var p10452Var = "thunk from from >>" -var p10452 = &p10452Var -var p10457Var = "thunk from from >>>" +var p10293Var = "object " +var p10293 = &p10293Var +var p10297Var = "object " +var p10297 = &p10297Var +var p10300Var = "object " +var p10300 = &p10300Var +var p10303Var = "object " +var p10303 = &p10303Var +var p10306Var = "object " +var p10306 = &p10306Var +var p10309Var = "object " +var p10309 = &p10309Var +var p10312Var = "object " +var p10312 = &p10312Var +var p10315Var = "object " +var p10315 = &p10315Var +var p10320Var = "thunk from >" +var p10320 = &p10320Var +var p10322Var = "thunk from >" +var p10322 = &p10322Var +var p10328Var = "function " +var p10328 = &p10328Var +var p10349Var = "thunk from >" +var p10349 = &p10349Var +var p10366Var = "thunk from >" +var p10366 = &p10366Var +var p10389Var = "thunk from >" +var p10389 = &p10389Var +var p10406Var = "thunk from >" +var p10406 = &p10406Var +var p10424Var = "object " +var p10424 = &p10424Var +var p10426Var = "object " +var p10426 = &p10426Var +var p10450Var = "object " +var p10450 = &p10450Var +var p10454Var = "object " +var p10454 = &p10454Var +var p10457Var = "object " var p10457 = &p10457Var -var p10466Var = "thunk from from >>>>" +var p10460Var = "object " +var p10460 = &p10460Var +var p10463Var = "object " +var p10463 = &p10463Var +var p10466Var = "object " var p10466 = &p10466Var -var p10477Var = "thunk from from >>>>" +var p10469Var = "object " +var p10469 = &p10469Var +var p10472Var = "object " +var p10472 = &p10472Var +var p10477Var = "thunk from >" var p10477 = &p10477Var -var p10484Var = "thunk from >" -var p10484 = &p10484Var -var p10493Var = "thunk from from >>" -var p10493 = &p10493Var -var p10508Var = "thunk from >" -var p10508 = &p10508Var -var p10517Var = "thunk from >>" -var p10517 = &p10517Var -var p10539Var = "thunk from >" -var p10539 = &p10539Var -var p10555Var = "thunk from >" -var p10555 = &p10555Var -var p10564Var = "thunk from >>" -var p10564 = &p10564Var -var p10580Var = "thunk from >>>" -var p10580 = &p10580Var -var p10589Var = "thunk from >>>>" -var p10589 = &p10589Var -var p10612Var = "thunk from >" -var p10612 = &p10612Var -var p10628Var = "thunk from >" -var p10628 = &p10628Var -var p10637Var = "thunk from >>" -var p10637 = &p10637Var -var p10658Var = "thunk from >" -var p10658 = &p10658Var -var p10682Var = "thunk from >" -var p10682 = &p10682Var -var p10694Var = "thunk from >" -var p10694 = &p10694Var -var p10745Var = "function " +var p10479Var = "thunk from >" +var p10479 = &p10479Var +var p10485Var = "function " +var p10485 = &p10485Var +var p10506Var = "thunk from >" +var p10506 = &p10506Var +var p10523Var = "thunk from >" +var p10523 = &p10523Var +var p10546Var = "thunk from >" +var p10546 = &p10546Var +var p10563Var = "thunk from >" +var p10563 = &p10563Var +var p10581Var = "object " +var p10581 = &p10581Var +var p10583Var = "object " +var p10583 = &p10583Var +var p10607Var = "object " +var p10607 = &p10607Var +var p10611Var = "object " +var p10611 = &p10611Var +var p10614Var = "object " +var p10614 = &p10614Var +var p10617Var = "object " +var p10617 = &p10617Var +var p10620Var = "object " +var p10620 = &p10620Var +var p10623Var = "object " +var p10623 = &p10623Var +var p10626Var = "object " +var p10626 = &p10626Var +var p10629Var = "object " +var p10629 = &p10629Var +var p10634Var = "thunk from >" +var p10634 = &p10634Var +var p10636Var = "thunk from >" +var p10636 = &p10636Var +var p10642Var = "function " +var p10642 = &p10642Var +var p10651Var = "thunk from >" +var p10651 = &p10651Var +var p10654Var = "function " +var p10654 = &p10654Var +var p10667Var = "object " +var p10667 = &p10667Var +var p10669Var = "object " +var p10669 = &p10669Var +var p10693Var = "object " +var p10693 = &p10693Var +var p10697Var = "object " +var p10697 = &p10697Var +var p10700Var = "object " +var p10700 = &p10700Var +var p10703Var = "object " +var p10703 = &p10703Var +var p10706Var = "object " +var p10706 = &p10706Var +var p10709Var = "object " +var p10709 = &p10709Var +var p10712Var = "object " +var p10712 = &p10712Var +var p10715Var = "object " +var p10715 = &p10715Var +var p10720Var = "thunk from >" +var p10720 = &p10720Var +var p10722Var = "thunk from >" +var p10722 = &p10722Var +var p10728Var = "function " +var p10728 = &p10728Var +var p10732Var = "thunk from >" +var p10732 = &p10732Var +var p10736Var = "function " +var p10736 = &p10736Var +var p10745Var = "thunk from >" var p10745 = &p10745Var -var p10771Var = "thunk from from >>" -var p10771 = &p10771Var -var p10776Var = "thunk from from >>>" -var p10776 = &p10776Var -var p10787Var = "thunk from from >>>>" -var p10787 = &p10787Var -var p10794Var = "thunk from >" -var p10794 = &p10794Var -var p10803Var = "thunk from from >>" -var p10803 = &p10803Var -var p10814Var = "thunk from >" -var p10814 = &p10814Var -var p10822Var = "thunk from >>" -var p10822 = &p10822Var -var p10829Var = "function " -var p10829 = &p10829Var -var p10842Var = "thunk from >" -var p10842 = &p10842Var -var p10864Var = "thunk from >" -var p10864 = &p10864Var -var p10870Var = "thunk from >" -var p10870 = &p10870Var -var p10874Var = "function " -var p10874 = &p10874Var -var p10885Var = "thunk from >" -var p10885 = &p10885Var -var p10893Var = "thunk from >" -var p10893 = &p10893Var -var p10902Var = "thunk from >" -var p10902 = &p10902Var -var p10915Var = "thunk from from >>" -var p10915 = &p10915Var -var p10935Var = "thunk from from >>" -var p10935 = &p10935Var -var p10945Var = "thunk from >" -var p10945 = &p10945Var -var p10959Var = "thunk from >" -var p10959 = &p10959Var -var p10993Var = "thunk from >" -var p10993 = &p10993Var -var p11002Var = "thunk from from >>" -var p11002 = &p11002Var -var p11026Var = "thunk from from >>>" -var p11026 = &p11026Var -var p11031Var = "thunk from from >>>>" +var p10761Var = "thunk from >>" +var p10761 = &p10761Var +var p10765Var = "thunk from >>>" +var p10765 = &p10765Var +var p10790Var = "thunk from >>>" +var p10790 = &p10790Var +var p10816Var = "thunk from >>>" +var p10816 = &p10816Var +var p10821Var = "thunk from >>>>" +var p10821 = &p10821Var +var p10839Var = "thunk from >>>" +var p10839 = &p10839Var +var p10844Var = "thunk from >>>>" +var p10844 = &p10844Var +var p10857Var = "thunk from >>" +var p10857 = &p10857Var +var p10863Var = "thunk from >" +var p10863 = &p10863Var +var p10867Var = "function " +var p10867 = &p10867Var +var p10881Var = "thunk from >" +var p10881 = &p10881Var +var p10886Var = "thunk from >>" +var p10886 = &p10886Var +var p10894Var = "thunk from >" +var p10894 = &p10894Var +var p10897Var = "thunk from >" +var p10897 = &p10897Var +var p10908Var = "thunk from from >>" +var p10908 = &p10908Var +var p10917Var = "thunk from from >>" +var p10917 = &p10917Var +var p10938Var = "thunk from from >>" +var p10938 = &p10938Var +var p10944Var = "thunk from from >>>" +var p10944 = &p10944Var +var p10956Var = "thunk from >" +var p10956 = &p10956Var +var p10965Var = "thunk from from >>" +var p10965 = &p10965Var +var p10979Var = "thunk from >" +var p10979 = &p10979Var +var p10995Var = "thunk from >>" +var p10995 = &p10995Var +var p11000Var = "thunk from >>" +var p11000 = &p11000Var +var p11005Var = "object " +var p11005 = &p11005Var +var p11007Var = "object " +var p11007 = &p11007Var +var p11031Var = "object " var p11031 = &p11031Var -var p11048Var = "thunk from from >>>" -var p11048 = &p11048Var -var p11059Var = "thunk from >" -var p11059 = &p11059Var -var p11063Var = "thunk from >>" -var p11063 = &p11063Var -var p11084Var = "thunk from >>>" -var p11084 = &p11084Var -var p11090Var = "thunk from >>>>" -var p11090 = &p11090Var -var p11104Var = "thunk from >" -var p11104 = &p11104Var -var p11112Var = "function " -var p11112 = &p11112Var -var p11116Var = "thunk from >" -var p11116 = &p11116Var -var p11135Var = "thunk from from >>" -var p11135 = &p11135Var -var p11147Var = "thunk from from >>" -var p11147 = &p11147Var -var p11151Var = "function " -var p11151 = &p11151Var -var p11160Var = "thunk from >" -var p11160 = &p11160Var -var p11170Var = "thunk from >" -var p11170 = &p11170Var -var p11174Var = "function " -var p11174 = &p11174Var -var p11189Var = "thunk from >" -var p11189 = &p11189Var -var p11211Var = "thunk from >" -var p11211 = &p11211Var -var p11217Var = "thunk from >" -var p11217 = &p11217Var -var p11260Var = "thunk from >" -var p11260 = &p11260Var -var p11291Var = "thunk from >" +var p11035Var = "object " +var p11035 = &p11035Var +var p11038Var = "object " +var p11038 = &p11038Var +var p11041Var = "object " +var p11041 = &p11041Var +var p11044Var = "object " +var p11044 = &p11044Var +var p11047Var = "object " +var p11047 = &p11047Var +var p11050Var = "object " +var p11050 = &p11050Var +var p11053Var = "object " +var p11053 = &p11053Var +var p11058Var = "thunk from >" +var p11058 = &p11058Var +var p11060Var = "thunk from >" +var p11060 = &p11060Var +var p11066Var = "function " +var p11066 = &p11066Var +var p11070Var = "thunk from >" +var p11070 = &p11070Var +var p11079Var = "thunk from from >>" +var p11079 = &p11079Var +var p11085Var = "thunk from >" +var p11085 = &p11085Var +var p11089Var = "function " +var p11089 = &p11089Var +var p11191Var = "thunk from >" +var p11191 = &p11191Var +var p11200Var = "thunk from from >>" +var p11200 = &p11200Var +var p11236Var = "thunk from >" +var p11236 = &p11236Var +var p11258Var = "thunk from >" +var p11258 = &p11258Var +var p11274Var = "thunk from >>" +var p11274 = &p11274Var +var p11280Var = "thunk from >>>" +var p11280 = &p11280Var +var p11291Var = "thunk from >>" var p11291 = &p11291Var -var p11297Var = "thunk from >" +var p11297Var = "object " var p11297 = &p11297Var -var p11378Var = "thunk from >" -var p11378 = &p11378Var -var p11395Var = "thunk from >" -var p11395 = &p11395Var -var p11508Var = "thunk from >" -var p11508 = &p11508Var -var p11525Var = "thunk from >" -var p11525 = &p11525Var -var p11534Var = "thunk from from >>" -var p11534 = &p11534Var -var p11537Var = "function " -var p11537 = &p11537Var -var p11563Var = "thunk from >" +var p11299Var = "object " +var p11299 = &p11299Var +var p11323Var = "object " +var p11323 = &p11323Var +var p11327Var = "object " +var p11327 = &p11327Var +var p11330Var = "object " +var p11330 = &p11330Var +var p11333Var = "object " +var p11333 = &p11333Var +var p11336Var = "object " +var p11336 = &p11336Var +var p11339Var = "object " +var p11339 = &p11339Var +var p11342Var = "object " +var p11342 = &p11342Var +var p11345Var = "object " +var p11345 = &p11345Var +var p11350Var = "thunk from >" +var p11350 = &p11350Var +var p11352Var = "thunk from >" +var p11352 = &p11352Var +var p11358Var = "function " +var p11358 = &p11358Var +var p11367Var = "thunk from >" +var p11367 = &p11367Var +var p11373Var = "object " +var p11373 = &p11373Var +var p11375Var = "object " +var p11375 = &p11375Var +var p11399Var = "object " +var p11399 = &p11399Var +var p11403Var = "object " +var p11403 = &p11403Var +var p11406Var = "object " +var p11406 = &p11406Var +var p11409Var = "object " +var p11409 = &p11409Var +var p11412Var = "object " +var p11412 = &p11412Var +var p11415Var = "object " +var p11415 = &p11415Var +var p11418Var = "object " +var p11418 = &p11418Var +var p11421Var = "object " +var p11421 = &p11421Var +var p11426Var = "thunk from >" +var p11426 = &p11426Var +var p11428Var = "thunk from >" +var p11428 = &p11428Var +var p11434Var = "function " +var p11434 = &p11434Var +var p11438Var = "thunk from >" +var p11438 = &p11438Var +var p11447Var = "thunk from from >>" +var p11447 = &p11447Var +var p11453Var = "thunk from >" +var p11453 = &p11453Var +var p11457Var = "function " +var p11457 = &p11457Var +var p11491Var = "thunk from >" +var p11491 = &p11491Var +var p11507Var = "thunk from >>" +var p11507 = &p11507Var +var p11513Var = "thunk from >>>" +var p11513 = &p11513Var +var p11524Var = "thunk from >>" +var p11524 = &p11524Var +var p11530Var = "object " +var p11530 = &p11530Var +var p11532Var = "object " +var p11532 = &p11532Var +var p11556Var = "object " +var p11556 = &p11556Var +var p11560Var = "object " +var p11560 = &p11560Var +var p11563Var = "object " var p11563 = &p11563Var -var p11573Var = "function " -var p11573 = &p11573Var -var p11602Var = "thunk from >" -var p11602 = &p11602Var -var p11623Var = "thunk from >" -var p11623 = &p11623Var -var p11627Var = "function " -var p11627 = &p11627Var -var p11642Var = "thunk from >" -var p11642 = &p11642Var -var p11650Var = "thunk from >" -var p11650 = &p11650Var -var p11654Var = "thunk from from >>" -var p11654 = &p11654Var -var p11689Var = "thunk from >" -var p11689 = &p11689Var -var p11714Var = "thunk from from >>" -var p11714 = &p11714Var -var p11755Var = "thunk from >" -var p11755 = &p11755Var -var p11780Var = "thunk from from >>" -var p11780 = &p11780Var -var p11820Var = "thunk from >" -var p11820 = &p11820Var -var p11847Var = "thunk from >" -var p11847 = &p11847Var -var p11857Var = "function " -var p11857 = &p11857Var -var p11861Var = "thunk from >" -var p11861 = &p11861Var -var p11870Var = "thunk from from >>" -var p11870 = &p11870Var -var p11881Var = "thunk from >" -var p11881 = &p11881Var -var p11891Var = "thunk from >>" -var p11891 = &p11891Var -var p11895Var = "function " -var p11895 = &p11895Var -var p11904Var = "thunk from >" -var p11904 = &p11904Var -var p11914Var = "function " -var p11914 = &p11914Var -var p11918Var = "thunk from >" -var p11918 = &p11918Var -var p11927Var = "thunk from from >>" -var p11927 = &p11927Var -var p11948Var = "thunk from >" -var p11948 = &p11948Var -var p11956Var = "thunk from >" -var p11956 = &p11956Var -var p11965Var = "thunk from >" -var p11965 = &p11965Var -var p11974Var = "thunk from from >>" +var p11566Var = "object " +var p11566 = &p11566Var +var p11569Var = "object " +var p11569 = &p11569Var +var p11572Var = "object " +var p11572 = &p11572Var +var p11575Var = "object " +var p11575 = &p11575Var +var p11578Var = "object " +var p11578 = &p11578Var +var p11583Var = "thunk from >" +var p11583 = &p11583Var +var p11585Var = "thunk from >" +var p11585 = &p11585Var +var p11591Var = "function " +var p11591 = &p11591Var +var p11595Var = "thunk from >" +var p11595 = &p11595Var +var p11604Var = "thunk from from >>" +var p11604 = &p11604Var +var p11610Var = "thunk from >" +var p11610 = &p11610Var +var p11614Var = "function " +var p11614 = &p11614Var +var p11639Var = "thunk from >" +var p11639 = &p11639Var +var p11643Var = "function " +var p11643 = &p11643Var +var p11653Var = "thunk from >" +var p11653 = &p11653Var +var p11664Var = "thunk from >>" +var p11664 = &p11664Var +var p11671Var = "object " +var p11671 = &p11671Var +var p11673Var = "object " +var p11673 = &p11673Var +var p11697Var = "object " +var p11697 = &p11697Var +var p11701Var = "object " +var p11701 = &p11701Var +var p11704Var = "object " +var p11704 = &p11704Var +var p11707Var = "object " +var p11707 = &p11707Var +var p11710Var = "object " +var p11710 = &p11710Var +var p11713Var = "object " +var p11713 = &p11713Var +var p11716Var = "object " +var p11716 = &p11716Var +var p11719Var = "object " +var p11719 = &p11719Var +var p11724Var = "thunk from >" +var p11724 = &p11724Var +var p11726Var = "thunk from >" +var p11726 = &p11726Var +var p11732Var = "function " +var p11732 = &p11732Var +var p11741Var = "thunk from >" +var p11741 = &p11741Var +var p11748Var = "object " +var p11748 = &p11748Var +var p11750Var = "object " +var p11750 = &p11750Var +var p11774Var = "object " +var p11774 = &p11774Var +var p11778Var = "object " +var p11778 = &p11778Var +var p11781Var = "object " +var p11781 = &p11781Var +var p11784Var = "object " +var p11784 = &p11784Var +var p11787Var = "object " +var p11787 = &p11787Var +var p11790Var = "object " +var p11790 = &p11790Var +var p11793Var = "object " +var p11793 = &p11793Var +var p11796Var = "object " +var p11796 = &p11796Var +var p11801Var = "thunk from >" +var p11801 = &p11801Var +var p11803Var = "thunk from >" +var p11803 = &p11803Var +var p11809Var = "function " +var p11809 = &p11809Var +var p11813Var = "thunk from >" +var p11813 = &p11813Var +var p11817Var = "function " +var p11817 = &p11817Var +var p11878Var = "thunk from >" +var p11878 = &p11878Var +var p11905Var = "thunk from >" +var p11905 = &p11905Var +var p11917Var = "thunk from >" +var p11917 = &p11917Var +var p11938Var = "thunk from >" +var p11938 = &p11938Var +var p11967Var = "thunk from >" +var p11967 = &p11967Var +var p11974Var = "thunk from >" var p11974 = &p11974Var -var p11983Var = "function " +var p11983Var = "thunk from from >>" var p11983 = &p11983Var -var p11996Var = "thunk from >" -var p11996 = &p11996Var -var p12005Var = "thunk from from >>" -var p12005 = &p12005Var -var p12009Var = "function " -var p12009 = &p12009Var -var p12021Var = "thunk from >" -var p12021 = &p12021Var -var p12030Var = "thunk from from >>" -var p12030 = &p12030Var -var p12034Var = "function " -var p12034 = &p12034Var -var p12055Var = "thunk from >" -var p12055 = &p12055Var -var p12061Var = "thunk from >" -var p12061 = &p12061Var -var p12072Var = "thunk from >" -var p12072 = &p12072Var -var p12080Var = "function " -var p12080 = &p12080Var -var p12084Var = "thunk from >" -var p12084 = &p12084Var -var p12088Var = "function " -var p12088 = &p12088Var -var p12107Var = "thunk from >" -var p12107 = &p12107Var -var p12114Var = "thunk from >" -var p12114 = &p12114Var -var p12141Var = "thunk from >" -var p12141 = &p12141Var -var p12156Var = "thunk from >" -var p12156 = &p12156Var -var p12167Var = "thunk from >" -var p12167 = &p12167Var -var p12178Var = "function " -var p12178 = &p12178Var -var p12187Var = "thunk from >" -var p12187 = &p12187Var -var p12196Var = "thunk from >>" -var p12196 = &p12196Var -var p12204Var = "function " -var p12204 = &p12204Var -var p12215Var = "thunk from >" -var p12215 = &p12215Var -var p12224Var = "thunk from >>" -var p12224 = &p12224Var -var p12228Var = "thunk from >>>" -var p12228 = &p12228Var -var p12239Var = "function " +var p11995Var = "thunk from from >>>" +var p11995 = &p11995Var +var p12002Var = "thunk from >" +var p12002 = &p12002Var +var p12012Var = "thunk from >" +var p12012 = &p12012Var +var p12019Var = "thunk from from >>" +var p12019 = &p12019Var +var p12029Var = "thunk from from >>" +var p12029 = &p12029Var +var p12032Var = "thunk from from >>>" +var p12032 = &p12032Var +var p12048Var = "thunk from from >>>" +var p12048 = &p12048Var +var p12052Var = "thunk from from >>>>" +var p12052 = &p12052Var +var p12062Var = "thunk from from >>>>>" +var p12062 = &p12062Var +var p12076Var = "thunk from from >>>>>>" +var p12076 = &p12076Var +var p12086Var = "thunk from from >>" +var p12086 = &p12086Var +var p12103Var = "thunk from >" +var p12103 = &p12103Var +var p12125Var = "thunk from >" +var p12125 = &p12125Var +var p12132Var = "thunk from >" +var p12132 = &p12132Var +var p12139Var = "thunk from from >>" +var p12139 = &p12139Var +var p12149Var = "thunk from from >>" +var p12149 = &p12149Var +var p12152Var = "thunk from from >>>" +var p12152 = &p12152Var +var p12168Var = "thunk from from >>>" +var p12168 = &p12168Var +var p12172Var = "thunk from from >>>>" +var p12172 = &p12172Var +var p12193Var = "thunk from from >>>>>" +var p12193 = &p12193Var +var p12202Var = "thunk from from >>>>>" +var p12202 = &p12202Var +var p12216Var = "thunk from from >>>>>>" +var p12216 = &p12216Var +var p12233Var = "thunk from from >>>" +var p12233 = &p12233Var +var p12239Var = "thunk from from >>" var p12239 = &p12239Var -var p12248Var = "thunk from >" -var p12248 = &p12248Var -var p12260Var = "function " -var p12260 = &p12260Var -var p12264Var = "thunk from >" -var p12264 = &p12264Var -var p12268Var = "function " -var p12268 = &p12268Var -var p12285Var = "thunk from >" -var p12285 = &p12285Var -var p12300Var = "thunk from >" +var p12256Var = "thunk from >" +var p12256 = &p12256Var +var p12266Var = "thunk from >" +var p12266 = &p12266Var +var p12274Var = "object " +var p12274 = &p12274Var +var p12276Var = "object " +var p12276 = &p12276Var +var p12300Var = "object " var p12300 = &p12300Var -var p12332Var = "thunk from >" -var p12332 = &p12332Var -var p12354Var = "thunk from >>" -var p12354 = &p12354Var -var p12382Var = "thunk from >" -var p12382 = &p12382Var -var p12401Var = "thunk from >" -var p12401 = &p12401Var -var p12420Var = "thunk from >" -var p12420 = &p12420Var -var p12433Var = "function " -var p12433 = &p12433Var -var p12437Var = "thunk from >" -var p12437 = &p12437Var -var p12441Var = "function " -var p12441 = &p12441Var -var p12456Var = "thunk from >" -var p12456 = &p12456Var -var p12475Var = "thunk from >" -var p12475 = &p12475Var -var p12483Var = "thunk from >" -var p12483 = &p12483Var -var p12502Var = "thunk from >>" -var p12502 = &p12502Var -var p12536Var = "thunk from >" -var p12536 = &p12536Var -var p12574Var = "thunk from >" -var p12574 = &p12574Var -var p12593Var = "thunk from >>" -var p12593 = &p12593Var -var p12605Var = "thunk from >" -var p12605 = &p12605Var -var p12624Var = "thunk from >" -var p12624 = &p12624Var -var p12637Var = "function " -var p12637 = &p12637Var -var p12656Var = "thunk from >" -var p12656 = &p12656Var -var p12663Var = "thunk from >" -var p12663 = &p12663Var -var p12682Var = "thunk from from >>" -var p12682 = &p12682Var -var p12692Var = "thunk from >" -var p12692 = &p12692Var -var p12711Var = "thunk from from >>" -var p12711 = &p12711Var -var p12723Var = "thunk from from >>" -var p12723 = &p12723Var -var p12751Var = "thunk from >" +var p12304Var = "object " +var p12304 = &p12304Var +var p12307Var = "object " +var p12307 = &p12307Var +var p12310Var = "object " +var p12310 = &p12310Var +var p12313Var = "object " +var p12313 = &p12313Var +var p12316Var = "object " +var p12316 = &p12316Var +var p12319Var = "object " +var p12319 = &p12319Var +var p12322Var = "object " +var p12322 = &p12322Var +var p12327Var = "thunk from >" +var p12327 = &p12327Var +var p12329Var = "thunk from >" +var p12329 = &p12329Var +var p12335Var = "function " +var p12335 = &p12335Var +var p12339Var = "thunk from >" +var p12339 = &p12339Var +var p12343Var = "function " +var p12343 = &p12343Var +var p12404Var = "thunk from >" +var p12404 = &p12404Var +var p12431Var = "thunk from >" +var p12431 = &p12431Var +var p12438Var = "thunk from >" +var p12438 = &p12438Var +var p12447Var = "thunk from from >>" +var p12447 = &p12447Var +var p12487Var = "thunk from >" +var p12487 = &p12487Var +var p12496Var = "thunk from from >>" +var p12496 = &p12496Var +var p12508Var = "thunk from >" +var p12508 = &p12508Var +var p12518Var = "thunk from >>" +var p12518 = &p12518Var +var p12541Var = "thunk from >>" +var p12541 = &p12541Var +var p12554Var = "thunk from >" +var p12554 = &p12554Var +var p12575Var = "thunk from >" +var p12575 = &p12575Var +var p12604Var = "thunk from >" +var p12604 = &p12604Var +var p12626Var = "thunk from >" +var p12626 = &p12626Var +var p12634Var = "thunk from >" +var p12634 = &p12634Var +var p12643Var = "thunk from from >>" +var p12643 = &p12643Var +var p12655Var = "thunk from from >>>" +var p12655 = &p12655Var +var p12662Var = "thunk from >" +var p12662 = &p12662Var +var p12699Var = "thunk from from >>" +var p12699 = &p12699Var +var p12705Var = "thunk from from >>>" +var p12705 = &p12705Var +var p12720Var = "thunk from from >>>>" +var p12720 = &p12720Var +var p12725Var = "thunk from >" +var p12725 = &p12725Var +var p12751Var = "thunk from >" var p12751 = &p12751Var -var p12762Var = "thunk from from >>" -var p12762 = &p12762Var -var p12774Var = "thunk from from >>" -var p12774 = &p12774Var -var p12780Var = "thunk from >" +var p12780Var = "thunk from >" var p12780 = &p12780Var -var p12789Var = "thunk from from >>" -var p12789 = &p12789Var -var p12800Var = "thunk from from >>>" -var p12800 = &p12800Var -var p12830Var = "object " -var p12830 = &p12830Var -var p12843Var = "thunk from >" -var p12843 = &p12843Var -var p12866Var = "thunk from >" -var p12866 = &p12866Var -var p12879Var = "thunk from >" -var p12879 = &p12879Var -var p12895Var = "thunk from >" -var p12895 = &p12895Var -var p12916Var = "thunk from >" -var p12916 = &p12916Var -var p12928Var = "function " -var p12928 = &p12928Var -var p12937Var = "thunk from >" -var p12937 = &p12937Var -var p12946Var = "function " -var p12946 = &p12946Var -var p12955Var = "thunk from >" -var p12955 = &p12955Var -var p12964Var = "function " -var p12964 = &p12964Var -var p12973Var = "thunk from >" -var p12973 = &p12973Var -var p12984Var = "function " -var p12984 = &p12984Var -var p12993Var = "thunk from >" -var p12993 = &p12993Var -var p13004Var = "function " -var p13004 = &p13004Var -var p13008Var = "thunk from >" -var p13008 = &p13008Var -var p13017Var = "thunk from from >>" -var p13017 = &p13017Var -var p13023Var = "thunk from >" -var p13023 = &p13023Var -var p13032Var = "thunk from from >>" -var p13032 = &p13032Var -var p13047Var = "thunk from >" -var p13047 = &p13047Var -var p13063Var = "thunk from >" -var p13063 = &p13063Var -var p13070Var = "thunk from >" +var p12802Var = "thunk from >" +var p12802 = &p12802Var +var p12810Var = "thunk from >" +var p12810 = &p12810Var +var p12833Var = "thunk from from >>" +var p12833 = &p12833Var +var p12846Var = "thunk from from >>>" +var p12846 = &p12846Var +var p12855Var = "thunk from from >>>" +var p12855 = &p12855Var +var p12870Var = "thunk from from >>>>" +var p12870 = &p12870Var +var p12875Var = "thunk from >" +var p12875 = &p12875Var +var p12884Var = "thunk from from >>" +var p12884 = &p12884Var +var p12907Var = "thunk from >" +var p12907 = &p12907Var +var p12921Var = "thunk from >" +var p12921 = &p12921Var +var p12930Var = "object " +var p12930 = &p12930Var +var p12932Var = "object " +var p12932 = &p12932Var +var p12956Var = "object " +var p12956 = &p12956Var +var p12960Var = "object " +var p12960 = &p12960Var +var p12963Var = "object " +var p12963 = &p12963Var +var p12966Var = "object " +var p12966 = &p12966Var +var p12969Var = "object " +var p12969 = &p12969Var +var p12972Var = "object " +var p12972 = &p12972Var +var p12975Var = "object " +var p12975 = &p12975Var +var p12978Var = "object " +var p12978 = &p12978Var +var p12983Var = "thunk from >" +var p12983 = &p12983Var +var p12985Var = "thunk from >" +var p12985 = &p12985Var +var p12991Var = "function " +var p12991 = &p12991Var +var p13012Var = "thunk from >" +var p13012 = &p13012Var +var p13029Var = "thunk from >" +var p13029 = &p13029Var +var p13045Var = "thunk from >" +var p13045 = &p13045Var +var p13061Var = "thunk from >>" +var p13061 = &p13061Var +var p13070Var = "thunk from >>>" var p13070 = &p13070Var -var p13079Var = "thunk from from >>" +var p13079Var = "object " var p13079 = &p13079Var -var p13094Var = "thunk from >" -var p13094 = &p13094Var -var p13105Var = "thunk from >>" +var p13081Var = "object " +var p13081 = &p13081Var +var p13105Var = "object " var p13105 = &p13105Var -var p13112Var = "thunk from >" +var p13109Var = "object " +var p13109 = &p13109Var +var p13112Var = "object " var p13112 = &p13112Var -var p13116Var = "function " -var p13116 = &p13116Var -var p13156Var = "thunk from >" -var p13156 = &p13156Var -var p13171Var = "thunk from >" -var p13171 = &p13171Var -var p13187Var = "thunk from >" -var p13187 = &p13187Var -var p13194Var = "thunk from >" -var p13194 = &p13194Var -var p13203Var = "thunk from from >>" -var p13203 = &p13203Var -var p13209Var = "thunk from >" -var p13209 = &p13209Var -var p13218Var = "thunk from from >>" -var p13218 = &p13218Var -var p13243Var = "thunk from >" -var p13243 = &p13243Var -var p13250Var = "thunk from >" -var p13250 = &p13250Var -var p13254Var = "function " -var p13254 = &p13254Var -var p13269Var = "thunk from >" -var p13269 = &p13269Var -var p13304Var = "thunk from >" -var p13304 = &p13304Var -var p13319Var = "thunk from >" -var p13319 = &p13319Var -var p13333Var = "thunk from >" -var p13333 = &p13333Var -var p13343Var = "function " -var p13343 = &p13343Var -var p13347Var = "thunk from >" -var p13347 = &p13347Var -var p13356Var = "thunk from from >>" -var p13356 = &p13356Var -var p13368Var = "thunk from >" -var p13368 = &p13368Var -var p13380Var = "thunk from >>" -var p13380 = &p13380Var -var p13391Var = "thunk from >>>" -var p13391 = &p13391Var -var p13398Var = "function " -var p13398 = &p13398Var -var p13408Var = "thunk from >>" -var p13408 = &p13408Var -var p13416Var = "function " -var p13416 = &p13416Var -var p13420Var = "thunk from >" -var p13420 = &p13420Var -var p13424Var = "function " -var p13424 = &p13424Var -var p13428Var = "thunk from >" -var p13428 = &p13428Var -var p13437Var = "thunk from from >>" -var p13437 = &p13437Var -var p13477Var = "thunk from >" -var p13477 = &p13477Var -var p13504Var = "thunk from >" -var p13504 = &p13504Var -var p13512Var = "thunk from >" +var p13115Var = "object " +var p13115 = &p13115Var +var p13118Var = "object " +var p13118 = &p13118Var +var p13121Var = "object " +var p13121 = &p13121Var +var p13124Var = "object " +var p13124 = &p13124Var +var p13127Var = "object " +var p13127 = &p13127Var +var p13132Var = "thunk from >" +var p13132 = &p13132Var +var p13134Var = "thunk from >" +var p13134 = &p13134Var +var p13140Var = "function " +var p13140 = &p13140Var +var p13159Var = "thunk from >" +var p13159 = &p13159Var +var p13188Var = "thunk from from >>" +var p13188 = &p13188Var +var p13193Var = "thunk from from >>>" +var p13193 = &p13193Var +var p13202Var = "thunk from from >>>>" +var p13202 = &p13202Var +var p13213Var = "thunk from from >>>>" +var p13213 = &p13213Var +var p13220Var = "thunk from >" +var p13220 = &p13220Var +var p13229Var = "thunk from from >>" +var p13229 = &p13229Var +var p13244Var = "thunk from >" +var p13244 = &p13244Var +var p13253Var = "thunk from >>" +var p13253 = &p13253Var +var p13275Var = "thunk from >" +var p13275 = &p13275Var +var p13291Var = "thunk from >" +var p13291 = &p13291Var +var p13300Var = "thunk from >>" +var p13300 = &p13300Var +var p13316Var = "thunk from >>>" +var p13316 = &p13316Var +var p13325Var = "thunk from >>>>" +var p13325 = &p13325Var +var p13348Var = "thunk from >" +var p13348 = &p13348Var +var p13364Var = "thunk from >" +var p13364 = &p13364Var +var p13373Var = "thunk from >>" +var p13373 = &p13373Var +var p13394Var = "thunk from >" +var p13394 = &p13394Var +var p13418Var = "thunk from >" +var p13418 = &p13418Var +var p13430Var = "thunk from >" +var p13430 = &p13430Var +var p13479Var = "object " +var p13479 = &p13479Var +var p13481Var = "object " +var p13481 = &p13481Var +var p13505Var = "object " +var p13505 = &p13505Var +var p13509Var = "object " +var p13509 = &p13509Var +var p13512Var = "object " var p13512 = &p13512Var -var p13521Var = "thunk from from >>" +var p13515Var = "object " +var p13515 = &p13515Var +var p13518Var = "object " +var p13518 = &p13518Var +var p13521Var = "object " var p13521 = &p13521Var -var p13555Var = "thunk from >" -var p13555 = &p13555Var -var p13564Var = "thunk from >>" -var p13564 = &p13564Var -var p13570Var = "thunk from >" -var p13570 = &p13570Var -var p13579Var = "thunk from >>" -var p13579 = &p13579Var -var p13624Var = "thunk from >" +var p13524Var = "object " +var p13524 = &p13524Var +var p13527Var = "object " +var p13527 = &p13527Var +var p13532Var = "thunk from >" +var p13532 = &p13532Var +var p13534Var = "thunk from >" +var p13534 = &p13534Var +var p13540Var = "function " +var p13540 = &p13540Var +var p13566Var = "thunk from from >>" +var p13566 = &p13566Var +var p13571Var = "thunk from from >>>" +var p13571 = &p13571Var +var p13582Var = "thunk from from >>>>" +var p13582 = &p13582Var +var p13589Var = "thunk from >" +var p13589 = &p13589Var +var p13598Var = "thunk from from >>" +var p13598 = &p13598Var +var p13609Var = "thunk from >" +var p13609 = &p13609Var +var p13617Var = "thunk from >>" +var p13617 = &p13617Var +var p13622Var = "object " +var p13622 = &p13622Var +var p13624Var = "object " var p13624 = &p13624Var -var p13633Var = "thunk from >>" -var p13633 = &p13633Var var p13648Var = "object " var p13648 = &p13648Var -var p13657Var = "thunk from >" -var p13657 = &p13657Var -var p13673Var = "thunk from >" -var p13673 = &p13673Var +var p13652Var = "object " +var p13652 = &p13652Var +var p13655Var = "object " +var p13655 = &p13655Var +var p13658Var = "object " +var p13658 = &p13658Var +var p13661Var = "object " +var p13661 = &p13661Var +var p13664Var = "object " +var p13664 = &p13664Var +var p13667Var = "object " +var p13667 = &p13667Var +var p13670Var = "object " +var p13670 = &p13670Var +var p13675Var = "thunk from >" +var p13675 = &p13675Var +var p13677Var = "thunk from >" +var p13677 = &p13677Var +var p13683Var = "function " +var p13683 = &p13683Var +var p13696Var = "thunk from >" +var p13696 = &p13696Var +var p13718Var = "thunk from >" +var p13718 = &p13718Var +var p13724Var = "thunk from >" +var p13724 = &p13724Var +var p13728Var = "function " +var p13728 = &p13728Var +var p13739Var = "thunk from >" +var p13739 = &p13739Var +var p13747Var = "thunk from >" +var p13747 = &p13747Var +var p13756Var = "thunk from >" +var p13756 = &p13756Var +var p13769Var = "thunk from from >>" +var p13769 = &p13769Var +var p13789Var = "thunk from from >>" +var p13789 = &p13789Var +var p13799Var = "thunk from >" +var p13799 = &p13799Var +var p13813Var = "thunk from >" +var p13813 = &p13813Var +var p13847Var = "thunk from >" +var p13847 = &p13847Var +var p13856Var = "thunk from from >>" +var p13856 = &p13856Var +var p13880Var = "thunk from from >>>" +var p13880 = &p13880Var +var p13885Var = "thunk from from >>>>" +var p13885 = &p13885Var +var p13902Var = "thunk from from >>>" +var p13902 = &p13902Var +var p13913Var = "thunk from >" +var p13913 = &p13913Var +var p13917Var = "thunk from >>" +var p13917 = &p13917Var +var p13938Var = "thunk from >>>" +var p13938 = &p13938Var +var p13944Var = "thunk from >>>>" +var p13944 = &p13944Var +var p13958Var = "thunk from >" +var p13958 = &p13958Var +var p13964Var = "object " +var p13964 = &p13964Var +var p13966Var = "object " +var p13966 = &p13966Var +var p13990Var = "object " +var p13990 = &p13990Var +var p13994Var = "object " +var p13994 = &p13994Var +var p13997Var = "object " +var p13997 = &p13997Var +var p14000Var = "object " +var p14000 = &p14000Var +var p14003Var = "object " +var p14003 = &p14003Var +var p14006Var = "object " +var p14006 = &p14006Var +var p14009Var = "object " +var p14009 = &p14009Var +var p14012Var = "object " +var p14012 = &p14012Var +var p14017Var = "thunk from >" +var p14017 = &p14017Var +var p14019Var = "thunk from >" +var p14019 = &p14019Var +var p14025Var = "function " +var p14025 = &p14025Var +var p14029Var = "thunk from >" +var p14029 = &p14029Var +var p14048Var = "thunk from from >>" +var p14048 = &p14048Var +var p14060Var = "thunk from from >>" +var p14060 = &p14060Var +var p14064Var = "function " +var p14064 = &p14064Var +var p14073Var = "thunk from >" +var p14073 = &p14073Var +var p14083Var = "thunk from >" +var p14083 = &p14083Var +var p14087Var = "function " +var p14087 = &p14087Var +var p14102Var = "thunk from >" +var p14102 = &p14102Var +var p14124Var = "thunk from >" +var p14124 = &p14124Var +var p14130Var = "thunk from >" +var p14130 = &p14130Var +var p14173Var = "thunk from >" +var p14173 = &p14173Var +var p14204Var = "thunk from >" +var p14204 = &p14204Var +var p14210Var = "thunk from >" +var p14210 = &p14210Var +var p14291Var = "thunk from >" +var p14291 = &p14291Var +var p14308Var = "thunk from >" +var p14308 = &p14308Var +var p14421Var = "thunk from >" +var p14421 = &p14421Var +var p14438Var = "thunk from >" +var p14438 = &p14438Var +var p14447Var = "thunk from from >>" +var p14447 = &p14447Var +var p14450Var = "function " +var p14450 = &p14450Var +var p14476Var = "thunk from >" +var p14476 = &p14476Var +var p14484Var = "object " +var p14484 = &p14484Var +var p14486Var = "object " +var p14486 = &p14486Var +var p14510Var = "object " +var p14510 = &p14510Var +var p14514Var = "object " +var p14514 = &p14514Var +var p14517Var = "object " +var p14517 = &p14517Var +var p14520Var = "object " +var p14520 = &p14520Var +var p14523Var = "object " +var p14523 = &p14523Var +var p14526Var = "object " +var p14526 = &p14526Var +var p14529Var = "object " +var p14529 = &p14529Var +var p14532Var = "object " +var p14532 = &p14532Var +var p14537Var = "thunk from >" +var p14537 = &p14537Var +var p14539Var = "thunk from >" +var p14539 = &p14539Var +var p14545Var = "function " +var p14545 = &p14545Var +var p14574Var = "thunk from >" +var p14574 = &p14574Var +var p14595Var = "thunk from >" +var p14595 = &p14595Var +var p14599Var = "function " +var p14599 = &p14599Var +var p14614Var = "thunk from >" +var p14614 = &p14614Var +var p14622Var = "thunk from >" +var p14622 = &p14622Var +var p14626Var = "thunk from from >>" +var p14626 = &p14626Var +var p14661Var = "thunk from >" +var p14661 = &p14661Var +var p14686Var = "thunk from from >>" +var p14686 = &p14686Var +var p14727Var = "thunk from >" +var p14727 = &p14727Var +var p14752Var = "thunk from from >>" +var p14752 = &p14752Var +var p14792Var = "thunk from >" +var p14792 = &p14792Var +var p14819Var = "thunk from >" +var p14819 = &p14819Var +var p14827Var = "object " +var p14827 = &p14827Var +var p14829Var = "object " +var p14829 = &p14829Var +var p14853Var = "object " +var p14853 = &p14853Var +var p14857Var = "object " +var p14857 = &p14857Var +var p14860Var = "object " +var p14860 = &p14860Var +var p14863Var = "object " +var p14863 = &p14863Var +var p14866Var = "object " +var p14866 = &p14866Var +var p14869Var = "object " +var p14869 = &p14869Var +var p14872Var = "object " +var p14872 = &p14872Var +var p14875Var = "object " +var p14875 = &p14875Var +var p14880Var = "thunk from >" +var p14880 = &p14880Var +var p14882Var = "thunk from >" +var p14882 = &p14882Var +var p14888Var = "function " +var p14888 = &p14888Var +var p14892Var = "thunk from >" +var p14892 = &p14892Var +var p14901Var = "thunk from from >>" +var p14901 = &p14901Var +var p14912Var = "thunk from >" +var p14912 = &p14912Var +var p14922Var = "thunk from >>" +var p14922 = &p14922Var +var p14926Var = "function " +var p14926 = &p14926Var +var p14935Var = "thunk from >" +var p14935 = &p14935Var +var p14943Var = "object " +var p14943 = &p14943Var +var p14945Var = "object " +var p14945 = &p14945Var +var p14969Var = "object " +var p14969 = &p14969Var +var p14973Var = "object " +var p14973 = &p14973Var +var p14976Var = "object " +var p14976 = &p14976Var +var p14979Var = "object " +var p14979 = &p14979Var +var p14982Var = "object " +var p14982 = &p14982Var +var p14985Var = "object " +var p14985 = &p14985Var +var p14988Var = "object " +var p14988 = &p14988Var +var p14991Var = "object " +var p14991 = &p14991Var +var p14996Var = "thunk from >" +var p14996 = &p14996Var +var p14998Var = "thunk from >" +var p14998 = &p14998Var +var p15004Var = "function " +var p15004 = &p15004Var +var p15008Var = "thunk from >" +var p15008 = &p15008Var +var p15017Var = "thunk from from >>" +var p15017 = &p15017Var +var p15038Var = "thunk from >" +var p15038 = &p15038Var +var p15046Var = "thunk from >" +var p15046 = &p15046Var +var p15055Var = "thunk from >" +var p15055 = &p15055Var +var p15064Var = "thunk from from >>" +var p15064 = &p15064Var +var p15073Var = "function " +var p15073 = &p15073Var +var p15086Var = "thunk from >" +var p15086 = &p15086Var +var p15095Var = "thunk from from >>" +var p15095 = &p15095Var +var p15099Var = "function " +var p15099 = &p15099Var +var p15111Var = "thunk from >" +var p15111 = &p15111Var +var p15120Var = "thunk from from >>" +var p15120 = &p15120Var +var p15124Var = "function " +var p15124 = &p15124Var +var p15145Var = "thunk from >" +var p15145 = &p15145Var +var p15151Var = "thunk from >" +var p15151 = &p15151Var +var p15162Var = "thunk from >" +var p15162 = &p15162Var +var p15168Var = "object " +var p15168 = &p15168Var +var p15170Var = "object " +var p15170 = &p15170Var +var p15194Var = "object " +var p15194 = &p15194Var +var p15198Var = "object " +var p15198 = &p15198Var +var p15201Var = "object " +var p15201 = &p15201Var +var p15204Var = "object " +var p15204 = &p15204Var +var p15207Var = "object " +var p15207 = &p15207Var +var p15210Var = "object " +var p15210 = &p15210Var +var p15213Var = "object " +var p15213 = &p15213Var +var p15216Var = "object " +var p15216 = &p15216Var +var p15221Var = "thunk from >" +var p15221 = &p15221Var +var p15223Var = "thunk from >" +var p15223 = &p15223Var +var p15229Var = "function " +var p15229 = &p15229Var +var p15233Var = "thunk from >" +var p15233 = &p15233Var +var p15237Var = "function " +var p15237 = &p15237Var +var p15256Var = "thunk from >" +var p15256 = &p15256Var +var p15263Var = "thunk from >" +var p15263 = &p15263Var +var p15290Var = "thunk from >" +var p15290 = &p15290Var +var p15305Var = "thunk from >" +var p15305 = &p15305Var +var p15316Var = "thunk from >" +var p15316 = &p15316Var +var p15325Var = "object " +var p15325 = &p15325Var +var p15327Var = "object " +var p15327 = &p15327Var +var p15351Var = "object " +var p15351 = &p15351Var +var p15355Var = "object " +var p15355 = &p15355Var +var p15358Var = "object " +var p15358 = &p15358Var +var p15361Var = "object " +var p15361 = &p15361Var +var p15364Var = "object " +var p15364 = &p15364Var +var p15367Var = "object " +var p15367 = &p15367Var +var p15370Var = "object " +var p15370 = &p15370Var +var p15373Var = "object " +var p15373 = &p15373Var +var p15378Var = "thunk from >" +var p15378 = &p15378Var +var p15380Var = "thunk from >" +var p15380 = &p15380Var +var p15386Var = "function " +var p15386 = &p15386Var +var p15395Var = "thunk from >" +var p15395 = &p15395Var +var p15404Var = "thunk from >>" +var p15404 = &p15404Var +var p15410Var = "object " +var p15410 = &p15410Var +var p15412Var = "object " +var p15412 = &p15412Var +var p15436Var = "object " +var p15436 = &p15436Var +var p15440Var = "object " +var p15440 = &p15440Var +var p15443Var = "object " +var p15443 = &p15443Var +var p15446Var = "object " +var p15446 = &p15446Var +var p15449Var = "object " +var p15449 = &p15449Var +var p15452Var = "object " +var p15452 = &p15452Var +var p15455Var = "object " +var p15455 = &p15455Var +var p15458Var = "object " +var p15458 = &p15458Var +var p15463Var = "thunk from >" +var p15463 = &p15463Var +var p15465Var = "thunk from >" +var p15465 = &p15465Var +var p15471Var = "function " +var p15471 = &p15471Var +var p15482Var = "thunk from >" +var p15482 = &p15482Var +var p15491Var = "thunk from >>" +var p15491 = &p15491Var +var p15495Var = "thunk from >>>" +var p15495 = &p15495Var +var p15504Var = "object " +var p15504 = &p15504Var +var p15506Var = "object " +var p15506 = &p15506Var +var p15530Var = "object " +var p15530 = &p15530Var +var p15534Var = "object " +var p15534 = &p15534Var +var p15537Var = "object " +var p15537 = &p15537Var +var p15540Var = "object " +var p15540 = &p15540Var +var p15543Var = "object " +var p15543 = &p15543Var +var p15546Var = "object " +var p15546 = &p15546Var +var p15549Var = "object " +var p15549 = &p15549Var +var p15552Var = "object " +var p15552 = &p15552Var +var p15557Var = "thunk from >" +var p15557 = &p15557Var +var p15559Var = "thunk from >" +var p15559 = &p15559Var +var p15565Var = "function " +var p15565 = &p15565Var +var p15574Var = "thunk from >" +var p15574 = &p15574Var +var p15584Var = "object " +var p15584 = &p15584Var +var p15586Var = "object " +var p15586 = &p15586Var +var p15610Var = "object " +var p15610 = &p15610Var +var p15614Var = "object " +var p15614 = &p15614Var +var p15617Var = "object " +var p15617 = &p15617Var +var p15620Var = "object " +var p15620 = &p15620Var +var p15623Var = "object " +var p15623 = &p15623Var +var p15626Var = "object " +var p15626 = &p15626Var +var p15629Var = "object " +var p15629 = &p15629Var +var p15632Var = "object " +var p15632 = &p15632Var +var p15637Var = "thunk from >" +var p15637 = &p15637Var +var p15639Var = "thunk from >" +var p15639 = &p15639Var +var p15645Var = "function " +var p15645 = &p15645Var +var p15649Var = "thunk from >" +var p15649 = &p15649Var +var p15653Var = "function " +var p15653 = &p15653Var +var p15670Var = "thunk from >" +var p15670 = &p15670Var +var p15685Var = "thunk from >" +var p15685 = &p15685Var +var p15717Var = "thunk from >" +var p15717 = &p15717Var +var p15739Var = "thunk from >>" +var p15739 = &p15739Var +var p15767Var = "thunk from >" +var p15767 = &p15767Var +var p15786Var = "thunk from >" +var p15786 = &p15786Var +var p15805Var = "thunk from >" +var p15805 = &p15805Var +var p15816Var = "object " +var p15816 = &p15816Var +var p15818Var = "object " +var p15818 = &p15818Var +var p15842Var = "object " +var p15842 = &p15842Var +var p15846Var = "object " +var p15846 = &p15846Var +var p15849Var = "object " +var p15849 = &p15849Var +var p15852Var = "object " +var p15852 = &p15852Var +var p15855Var = "object " +var p15855 = &p15855Var +var p15858Var = "object " +var p15858 = &p15858Var +var p15861Var = "object " +var p15861 = &p15861Var +var p15864Var = "object " +var p15864 = &p15864Var +var p15869Var = "thunk from >" +var p15869 = &p15869Var +var p15871Var = "thunk from >" +var p15871 = &p15871Var +var p15877Var = "function " +var p15877 = &p15877Var +var p15881Var = "thunk from >" +var p15881 = &p15881Var +var p15885Var = "function " +var p15885 = &p15885Var +var p15900Var = "thunk from >" +var p15900 = &p15900Var +var p15919Var = "thunk from >" +var p15919 = &p15919Var +var p15927Var = "thunk from >" +var p15927 = &p15927Var +var p15946Var = "thunk from >>" +var p15946 = &p15946Var +var p15980Var = "thunk from >" +var p15980 = &p15980Var +var p16018Var = "thunk from >" +var p16018 = &p16018Var +var p16037Var = "thunk from >>" +var p16037 = &p16037Var +var p16049Var = "thunk from >" +var p16049 = &p16049Var +var p16068Var = "thunk from >" +var p16068 = &p16068Var +var p16079Var = "object " +var p16079 = &p16079Var +var p16081Var = "object " +var p16081 = &p16081Var +var p16105Var = "object " +var p16105 = &p16105Var +var p16109Var = "object " +var p16109 = &p16109Var +var p16112Var = "object " +var p16112 = &p16112Var +var p16115Var = "object " +var p16115 = &p16115Var +var p16118Var = "object " +var p16118 = &p16118Var +var p16121Var = "object " +var p16121 = &p16121Var +var p16124Var = "object " +var p16124 = &p16124Var +var p16127Var = "object " +var p16127 = &p16127Var +var p16132Var = "thunk from >" +var p16132 = &p16132Var +var p16134Var = "thunk from >" +var p16134 = &p16134Var +var p16140Var = "function " +var p16140 = &p16140Var +var p16159Var = "thunk from >" +var p16159 = &p16159Var +var p16166Var = "thunk from >" +var p16166 = &p16166Var +var p16185Var = "thunk from from >>" +var p16185 = &p16185Var +var p16195Var = "thunk from >" +var p16195 = &p16195Var +var p16214Var = "thunk from from >>" +var p16214 = &p16214Var +var p16226Var = "thunk from from >>" +var p16226 = &p16226Var +var p16254Var = "thunk from >" +var p16254 = &p16254Var +var p16265Var = "thunk from from >>" +var p16265 = &p16265Var +var p16277Var = "thunk from from >>" +var p16277 = &p16277Var +var p16283Var = "thunk from >" +var p16283 = &p16283Var +var p16292Var = "thunk from from >>" +var p16292 = &p16292Var +var p16303Var = "thunk from from >>>" +var p16303 = &p16303Var +var p16333Var = "object " +var p16333 = &p16333Var +var p16346Var = "thunk from >" +var p16346 = &p16346Var +var p16369Var = "thunk from >" +var p16369 = &p16369Var +var p16382Var = "thunk from >" +var p16382 = &p16382Var +var p16398Var = "thunk from >" +var p16398 = &p16398Var +var p16419Var = "thunk from >" +var p16419 = &p16419Var +var p16429Var = "object " +var p16429 = &p16429Var +var p16431Var = "object " +var p16431 = &p16431Var +var p16455Var = "object " +var p16455 = &p16455Var +var p16459Var = "object " +var p16459 = &p16459Var +var p16462Var = "object " +var p16462 = &p16462Var +var p16465Var = "object " +var p16465 = &p16465Var +var p16468Var = "object " +var p16468 = &p16468Var +var p16471Var = "object " +var p16471 = &p16471Var +var p16474Var = "object " +var p16474 = &p16474Var +var p16477Var = "object " +var p16477 = &p16477Var +var p16482Var = "thunk from >" +var p16482 = &p16482Var +var p16484Var = "thunk from >" +var p16484 = &p16484Var +var p16490Var = "function " +var p16490 = &p16490Var +var p16499Var = "thunk from >" +var p16499 = &p16499Var +var p16506Var = "object " +var p16506 = &p16506Var +var p16508Var = "object " +var p16508 = &p16508Var +var p16532Var = "object " +var p16532 = &p16532Var +var p16536Var = "object " +var p16536 = &p16536Var +var p16539Var = "object " +var p16539 = &p16539Var +var p16542Var = "object " +var p16542 = &p16542Var +var p16545Var = "object " +var p16545 = &p16545Var +var p16548Var = "object " +var p16548 = &p16548Var +var p16551Var = "object " +var p16551 = &p16551Var +var p16554Var = "object " +var p16554 = &p16554Var +var p16559Var = "thunk from >" +var p16559 = &p16559Var +var p16561Var = "thunk from >" +var p16561 = &p16561Var +var p16567Var = "function " +var p16567 = &p16567Var +var p16576Var = "thunk from >" +var p16576 = &p16576Var +var p16583Var = "object " +var p16583 = &p16583Var +var p16585Var = "object " +var p16585 = &p16585Var +var p16609Var = "object " +var p16609 = &p16609Var +var p16613Var = "object " +var p16613 = &p16613Var +var p16616Var = "object " +var p16616 = &p16616Var +var p16619Var = "object " +var p16619 = &p16619Var +var p16622Var = "object " +var p16622 = &p16622Var +var p16625Var = "object " +var p16625 = &p16625Var +var p16628Var = "object " +var p16628 = &p16628Var +var p16631Var = "object " +var p16631 = &p16631Var +var p16636Var = "thunk from >" +var p16636 = &p16636Var +var p16638Var = "thunk from >" +var p16638 = &p16638Var +var p16644Var = "function " +var p16644 = &p16644Var +var p16653Var = "thunk from >" +var p16653 = &p16653Var +var p16662Var = "object " +var p16662 = &p16662Var +var p16664Var = "object " +var p16664 = &p16664Var +var p16688Var = "object " +var p16688 = &p16688Var +var p16692Var = "object " +var p16692 = &p16692Var +var p16695Var = "object " +var p16695 = &p16695Var +var p16698Var = "object " +var p16698 = &p16698Var +var p16701Var = "object " +var p16701 = &p16701Var +var p16704Var = "object " +var p16704 = &p16704Var +var p16707Var = "object " +var p16707 = &p16707Var +var p16710Var = "object " +var p16710 = &p16710Var +var p16715Var = "thunk from >" +var p16715 = &p16715Var +var p16717Var = "thunk from >" +var p16717 = &p16717Var +var p16723Var = "function " +var p16723 = &p16723Var +var p16732Var = "thunk from >" +var p16732 = &p16732Var +var p16741Var = "object " +var p16741 = &p16741Var +var p16743Var = "object " +var p16743 = &p16743Var +var p16767Var = "object " +var p16767 = &p16767Var +var p16771Var = "object " +var p16771 = &p16771Var +var p16774Var = "object " +var p16774 = &p16774Var +var p16777Var = "object " +var p16777 = &p16777Var +var p16780Var = "object " +var p16780 = &p16780Var +var p16783Var = "object " +var p16783 = &p16783Var +var p16786Var = "object " +var p16786 = &p16786Var +var p16789Var = "object " +var p16789 = &p16789Var +var p16794Var = "thunk from >" +var p16794 = &p16794Var +var p16796Var = "thunk from >" +var p16796 = &p16796Var +var p16802Var = "function " +var p16802 = &p16802Var +var p16806Var = "thunk from >" +var p16806 = &p16806Var +var p16815Var = "thunk from from >>" +var p16815 = &p16815Var +var p16821Var = "thunk from >" +var p16821 = &p16821Var +var p16830Var = "thunk from from >>" +var p16830 = &p16830Var +var p16845Var = "thunk from >" +var p16845 = &p16845Var +var p16861Var = "thunk from >" +var p16861 = &p16861Var +var p16868Var = "thunk from >" +var p16868 = &p16868Var +var p16877Var = "thunk from from >>" +var p16877 = &p16877Var +var p16892Var = "thunk from >" +var p16892 = &p16892Var +var p16903Var = "thunk from >>" +var p16903 = &p16903Var +var p16910Var = "thunk from >" +var p16910 = &p16910Var +var p16914Var = "function " +var p16914 = &p16914Var +var p16954Var = "thunk from >" +var p16954 = &p16954Var +var p16969Var = "thunk from >" +var p16969 = &p16969Var +var p16985Var = "thunk from >" +var p16985 = &p16985Var +var p16992Var = "thunk from >" +var p16992 = &p16992Var +var p17001Var = "thunk from from >>" +var p17001 = &p17001Var +var p17007Var = "thunk from >" +var p17007 = &p17007Var +var p17016Var = "thunk from from >>" +var p17016 = &p17016Var +var p17041Var = "thunk from >" +var p17041 = &p17041Var +var p17048Var = "thunk from >" +var p17048 = &p17048Var +var p17052Var = "function " +var p17052 = &p17052Var +var p17067Var = "thunk from >" +var p17067 = &p17067Var +var p17102Var = "thunk from >" +var p17102 = &p17102Var +var p17117Var = "thunk from >" +var p17117 = &p17117Var +var p17131Var = "thunk from >" +var p17131 = &p17131Var +var p17139Var = "object " +var p17139 = &p17139Var +var p17141Var = "object " +var p17141 = &p17141Var +var p17165Var = "object " +var p17165 = &p17165Var +var p17169Var = "object " +var p17169 = &p17169Var +var p17172Var = "object " +var p17172 = &p17172Var +var p17175Var = "object " +var p17175 = &p17175Var +var p17178Var = "object " +var p17178 = &p17178Var +var p17181Var = "object " +var p17181 = &p17181Var +var p17184Var = "object " +var p17184 = &p17184Var +var p17187Var = "object " +var p17187 = &p17187Var +var p17192Var = "thunk from >" +var p17192 = &p17192Var +var p17194Var = "thunk from >" +var p17194 = &p17194Var +var p17200Var = "function " +var p17200 = &p17200Var +var p17204Var = "thunk from >" +var p17204 = &p17204Var +var p17213Var = "thunk from from >>" +var p17213 = &p17213Var +var p17225Var = "thunk from >" +var p17225 = &p17225Var +var p17237Var = "thunk from >>" +var p17237 = &p17237Var +var p17248Var = "thunk from >>>" +var p17248 = &p17248Var +var p17255Var = "function " +var p17255 = &p17255Var +var p17265Var = "thunk from >>" +var p17265 = &p17265Var +var p17271Var = "object " +var p17271 = &p17271Var +var p17273Var = "object " +var p17273 = &p17273Var +var p17297Var = "object " +var p17297 = &p17297Var +var p17301Var = "object " +var p17301 = &p17301Var +var p17304Var = "object " +var p17304 = &p17304Var +var p17307Var = "object " +var p17307 = &p17307Var +var p17310Var = "object " +var p17310 = &p17310Var +var p17313Var = "object " +var p17313 = &p17313Var +var p17316Var = "object " +var p17316 = &p17316Var +var p17319Var = "object " +var p17319 = &p17319Var +var p17324Var = "thunk from >" +var p17324 = &p17324Var +var p17326Var = "thunk from >" +var p17326 = &p17326Var +var p17332Var = "function " +var p17332 = &p17332Var +var p17336Var = "thunk from >" +var p17336 = &p17336Var +var p17340Var = "function " +var p17340 = &p17340Var +var p17344Var = "thunk from >" +var p17344 = &p17344Var +var p17353Var = "thunk from from >>" +var p17353 = &p17353Var +var p17393Var = "thunk from >" +var p17393 = &p17393Var +var p17420Var = "thunk from >" +var p17420 = &p17420Var +var p17428Var = "thunk from >" +var p17428 = &p17428Var +var p17437Var = "thunk from from >>" +var p17437 = &p17437Var +var p17471Var = "thunk from >" +var p17471 = &p17471Var +var p17480Var = "thunk from >>" +var p17480 = &p17480Var +var p17486Var = "thunk from >" +var p17486 = &p17486Var +var p17495Var = "thunk from >>" +var p17495 = &p17495Var +var p17540Var = "thunk from >" +var p17540 = &p17540Var +var p17549Var = "thunk from >>" +var p17549 = &p17549Var +var p17564Var = "object " +var p17564 = &p17564Var +var p17573Var = "thunk from >" +var p17573 = &p17573Var +var p17589Var = "thunk from >" +var p17589 = &p17589Var var p1 = &Source{ lines: []string{ "/*\n", @@ -2743,7 +4347,7 @@ var p1 = &Source{ " aux(value, [], ''),\n", "\n", " manifestYamlDoc(value)::\n", - " local aux(v, in_array, in_object, path, cindent) =\n", + " local aux(v, in_object, path, cindent) =\n", " if v == true then\n", " 'true'\n", " else if v == false then\n", @@ -2768,21 +4372,21 @@ var p1 = &Source{ " '[]'\n", " else\n", " local range = std.range(0, std.length(v) - 1);\n", - " local new_indent = cindent + ' ';\n", - " local parts = [aux(v[i], true, false, path + [i], new_indent) for i in range];\n", - " (if in_object then '\\n' + cindent else '') + '- ' + std.join('\\n' + cindent + '- ', parts)\n", + " local actual_indent = if in_object then cindent[2:] else cindent;\n", + " local parts = [aux(v[i], false, path + [i], cindent) for i in range];\n", + " (if in_object then '\\n' + actual_indent else '')\n", + " + '- ' + std.join('\\n' + actual_indent + '- ', parts)\n", " else if std.type(v) == 'object' then\n", " if std.length(v) == 0 then\n", " '{}'\n", " else\n", " local new_indent = cindent + ' ';\n", " local lines = [\n", - " cindent + std.escapeStringJson(k) + ': ' + aux(v[k], false, true, path + [k], new_indent)\n", + " std.escapeStringJson(k) + ': ' + aux(v[k], true, path + [k], new_indent)\n", " for k in std.objectFields(v)\n", " ];\n", - " (if in_array || in_object then '\\n' else '')\n", - " + std.join('\\n', lines);\n", - " aux(value, false, false, [], ''),\n", + " (if in_object then '\\n' + cindent else '') + std.join('\\n' + cindent, lines);\n", + " aux(value, false, [], ''),\n", "\n", " manifestYamlStream(value)::\n", " if std.type(value) != 'array' then\n", @@ -3171,7 +4775,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -3413,7 +5017,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p35, freeVariables: Identifiers{ "base64_table", "i", @@ -3437,7 +5041,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p39, freeVariables: Identifiers{ "base64_table", "i", @@ -3457,7 +5061,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p42, freeVariables: Identifiers{ "base64_table", }, @@ -3478,7 +5082,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p45, freeVariables: Identifiers{ "i", }, @@ -3501,7 +5105,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p48, freeVariables: Identifiers{ "i", }, @@ -3530,7 +5134,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p51, freeVariables: Identifiers{ "std", }, @@ -3549,7 +5153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p54, freeVariables: Identifiers{ "std", }, @@ -3568,7 +5172,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p57, freeVariables: Identifiers{ "std", }, @@ -3614,7 +5218,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p62, freeVariables: nil, }, Value: float64(0), @@ -3634,14 +5238,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p64, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -3697,7 +5301,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -3808,7 +5412,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p69, + context: p80, freeVariables: Identifiers{ "std", "v", @@ -3828,7 +5432,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p69, + context: p80, freeVariables: Identifiers{ "std", }, @@ -3847,7 +5451,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p69, + context: p80, freeVariables: Identifiers{ "std", }, @@ -3893,7 +5497,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p78, + context: p89, freeVariables: Identifiers{ "v", }, @@ -3920,7 +5524,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p69, + context: p80, freeVariables: nil, }, Value: "string", @@ -3994,7 +5598,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p96, freeVariables: nil, }, }, @@ -4016,7 +5620,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p98, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -4258,7 +5862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p122, freeVariables: Identifiers{ "base64_table", "i", @@ -4282,7 +5886,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p126, freeVariables: Identifiers{ "base64_table", "i", @@ -4302,7 +5906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p129, freeVariables: Identifiers{ "base64_table", }, @@ -4323,7 +5927,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p132, freeVariables: Identifiers{ "i", }, @@ -4346,7 +5950,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p135, freeVariables: Identifiers{ "i", }, @@ -4375,7 +5979,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p138, freeVariables: Identifiers{ "std", }, @@ -4394,7 +5998,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p141, freeVariables: Identifiers{ "std", }, @@ -4413,7 +6017,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p144, freeVariables: Identifiers{ "std", }, @@ -4459,7 +6063,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p149, freeVariables: nil, }, Value: float64(0), @@ -4479,14 +6083,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p151, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -4542,7 +6146,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -4653,7 +6257,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p95, + context: p165, freeVariables: Identifiers{ "std", "v", @@ -4673,7 +6277,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p95, + context: p165, freeVariables: Identifiers{ "std", }, @@ -4692,7 +6296,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p95, + context: p165, freeVariables: Identifiers{ "std", }, @@ -4738,7 +6342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p104, + context: p174, freeVariables: Identifiers{ "v", }, @@ -4765,7 +6369,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p95, + context: p165, freeVariables: nil, }, Value: "number", @@ -4839,7 +6443,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p181, freeVariables: nil, }, }, @@ -4861,7 +6465,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p183, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -5103,7 +6707,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p207, freeVariables: Identifiers{ "base64_table", "i", @@ -5127,7 +6731,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p211, freeVariables: Identifiers{ "base64_table", "i", @@ -5147,7 +6751,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p214, freeVariables: Identifiers{ "base64_table", }, @@ -5168,7 +6772,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p217, freeVariables: Identifiers{ "i", }, @@ -5191,7 +6795,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p220, freeVariables: Identifiers{ "i", }, @@ -5220,7 +6824,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p223, freeVariables: Identifiers{ "std", }, @@ -5239,7 +6843,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p226, freeVariables: Identifiers{ "std", }, @@ -5258,7 +6862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p229, freeVariables: Identifiers{ "std", }, @@ -5304,7 +6908,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p234, freeVariables: nil, }, Value: float64(0), @@ -5324,14 +6928,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p236, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -5387,7 +6991,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -5498,7 +7102,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p121, + context: p250, freeVariables: Identifiers{ "std", "v", @@ -5518,7 +7122,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p121, + context: p250, freeVariables: Identifiers{ "std", }, @@ -5537,7 +7141,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p121, + context: p250, freeVariables: Identifiers{ "std", }, @@ -5583,7 +7187,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p130, + context: p259, freeVariables: Identifiers{ "v", }, @@ -5610,7 +7214,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p121, + context: p250, freeVariables: nil, }, Value: "boolean", @@ -5684,7 +7288,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p266, freeVariables: nil, }, }, @@ -5706,7 +7310,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p268, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -5948,7 +7552,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p292, freeVariables: Identifiers{ "base64_table", "i", @@ -5972,7 +7576,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p296, freeVariables: Identifiers{ "base64_table", "i", @@ -5992,7 +7596,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p299, freeVariables: Identifiers{ "base64_table", }, @@ -6013,7 +7617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p302, freeVariables: Identifiers{ "i", }, @@ -6036,7 +7640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p305, freeVariables: Identifiers{ "i", }, @@ -6065,7 +7669,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p308, freeVariables: Identifiers{ "std", }, @@ -6084,7 +7688,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p311, freeVariables: Identifiers{ "std", }, @@ -6103,7 +7707,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p314, freeVariables: Identifiers{ "std", }, @@ -6149,7 +7753,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p319, freeVariables: nil, }, Value: float64(0), @@ -6169,14 +7773,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p321, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -6232,7 +7836,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -6343,7 +7947,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p147, + context: p335, freeVariables: Identifiers{ "std", "v", @@ -6363,7 +7967,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p147, + context: p335, freeVariables: Identifiers{ "std", }, @@ -6382,7 +7986,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p147, + context: p335, freeVariables: Identifiers{ "std", }, @@ -6428,7 +8032,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p156, + context: p344, freeVariables: Identifiers{ "v", }, @@ -6455,7 +8059,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p147, + context: p335, freeVariables: nil, }, Value: "object", @@ -6529,7 +8133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p351, freeVariables: nil, }, }, @@ -6551,7 +8155,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p353, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -6793,7 +8397,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p377, freeVariables: Identifiers{ "base64_table", "i", @@ -6817,7 +8421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p381, freeVariables: Identifiers{ "base64_table", "i", @@ -6837,7 +8441,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p384, freeVariables: Identifiers{ "base64_table", }, @@ -6858,7 +8462,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p387, freeVariables: Identifiers{ "i", }, @@ -6881,7 +8485,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p390, freeVariables: Identifiers{ "i", }, @@ -6910,7 +8514,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p393, freeVariables: Identifiers{ "std", }, @@ -6929,7 +8533,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p396, freeVariables: Identifiers{ "std", }, @@ -6948,7 +8552,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p399, freeVariables: Identifiers{ "std", }, @@ -6994,7 +8598,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p404, freeVariables: nil, }, Value: float64(0), @@ -7014,14 +8618,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p406, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -7077,7 +8681,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -7188,7 +8792,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p173, + context: p420, freeVariables: Identifiers{ "std", "v", @@ -7208,7 +8812,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p173, + context: p420, freeVariables: Identifiers{ "std", }, @@ -7227,7 +8831,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p173, + context: p420, freeVariables: Identifiers{ "std", }, @@ -7273,7 +8877,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p182, + context: p429, freeVariables: Identifiers{ "v", }, @@ -7300,7 +8904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p173, + context: p420, freeVariables: nil, }, Value: "array", @@ -7374,7 +8978,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p436, freeVariables: nil, }, }, @@ -7396,7 +9000,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p438, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -7638,7 +9242,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p462, freeVariables: Identifiers{ "base64_table", "i", @@ -7662,7 +9266,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p466, freeVariables: Identifiers{ "base64_table", "i", @@ -7682,7 +9286,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p469, freeVariables: Identifiers{ "base64_table", }, @@ -7703,7 +9307,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p472, freeVariables: Identifiers{ "i", }, @@ -7726,7 +9330,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p475, freeVariables: Identifiers{ "i", }, @@ -7755,7 +9359,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p478, freeVariables: Identifiers{ "std", }, @@ -7774,7 +9378,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p481, freeVariables: Identifiers{ "std", }, @@ -7793,7 +9397,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p484, freeVariables: Identifiers{ "std", }, @@ -7839,7 +9443,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p489, freeVariables: nil, }, Value: float64(0), @@ -7859,14 +9463,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p491, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -7922,7 +9526,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -8033,7 +9637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p199, + context: p505, freeVariables: Identifiers{ "std", "v", @@ -8053,7 +9657,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p199, + context: p505, freeVariables: Identifiers{ "std", }, @@ -8072,7 +9676,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p199, + context: p505, freeVariables: Identifiers{ "std", }, @@ -8118,7 +9722,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p208, + context: p514, freeVariables: Identifiers{ "v", }, @@ -8145,7 +9749,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p199, + context: p505, freeVariables: nil, }, Value: "function", @@ -8219,7 +9823,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p521, freeVariables: nil, }, }, @@ -8241,7 +9845,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p523, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -8483,7 +10087,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p547, freeVariables: Identifiers{ "base64_table", "i", @@ -8507,7 +10111,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p551, freeVariables: Identifiers{ "base64_table", "i", @@ -8527,7 +10131,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p554, freeVariables: Identifiers{ "base64_table", }, @@ -8548,7 +10152,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p557, freeVariables: Identifiers{ "i", }, @@ -8571,7 +10175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p560, freeVariables: Identifiers{ "i", }, @@ -8600,7 +10204,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p563, freeVariables: Identifiers{ "std", }, @@ -8619,7 +10223,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p566, freeVariables: Identifiers{ "std", }, @@ -8638,7 +10242,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p569, freeVariables: Identifiers{ "std", }, @@ -8684,7 +10288,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p574, freeVariables: nil, }, Value: float64(0), @@ -8704,14 +10308,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p576, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -8767,7 +10371,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -8793,7 +10397,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p217, + context: p582, freeVariables: Identifiers{ "a", "std", @@ -8898,7 +10502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p217, + context: p582, freeVariables: Identifiers{ "a", "std", @@ -8918,7 +10522,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p217, + context: p582, freeVariables: Identifiers{ "std", }, @@ -8937,7 +10541,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p217, + context: p582, freeVariables: Identifiers{ "std", }, @@ -8983,7 +10587,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p236, + context: p601, freeVariables: Identifiers{ "a", }, @@ -9010,7 +10614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p217, + context: p582, freeVariables: nil, }, Value: "string", @@ -9037,7 +10641,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p217, + context: p582, freeVariables: Identifiers{ "a", }, @@ -9058,7 +10662,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p217, + context: p582, freeVariables: Identifiers{ "a", }, @@ -9077,7 +10681,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p217, + context: p582, freeVariables: nil, }, Value: "", @@ -9099,7 +10703,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p217, + context: p582, freeVariables: Identifiers{ "a", }, @@ -9169,7 +10773,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p615, freeVariables: nil, }, }, @@ -9191,7 +10795,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p617, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -9433,7 +11037,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p641, freeVariables: Identifiers{ "base64_table", "i", @@ -9457,7 +11061,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p645, freeVariables: Identifiers{ "base64_table", "i", @@ -9477,7 +11081,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p648, freeVariables: Identifiers{ "base64_table", }, @@ -9498,7 +11102,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p651, freeVariables: Identifiers{ "i", }, @@ -9521,7 +11125,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p654, freeVariables: Identifiers{ "i", }, @@ -9550,7 +11154,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p657, freeVariables: Identifiers{ "std", }, @@ -9569,7 +11173,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p660, freeVariables: Identifiers{ "std", }, @@ -9588,7 +11192,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p663, freeVariables: Identifiers{ "std", }, @@ -9634,7 +11238,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p668, freeVariables: nil, }, Value: float64(0), @@ -9654,14 +11258,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p670, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -9717,7 +11321,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -9745,7 +11349,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "from", "len", @@ -9873,7 +11477,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", "str", @@ -9893,7 +11497,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -9912,7 +11516,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -9958,7 +11562,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p273, + context: p697, freeVariables: Identifiers{ "str", }, @@ -9985,7 +11589,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: nil, }, Value: "string", @@ -10013,7 +11617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", "str", @@ -10033,7 +11637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", "str", @@ -10053,7 +11657,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: nil, }, Value: "substr first parameter should be a string, got ", @@ -10075,7 +11679,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", "str", @@ -10095,7 +11699,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -10114,7 +11718,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -10160,7 +11764,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p290, + context: p714, freeVariables: Identifiers{ "str", }, @@ -10189,7 +11793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "from", "len", @@ -10317,7 +11921,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "from", "std", @@ -10337,7 +11941,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -10356,7 +11960,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -10402,7 +12006,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p313, + context: p737, freeVariables: Identifiers{ "from", }, @@ -10429,7 +12033,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: nil, }, Value: "number", @@ -10457,7 +12061,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "from", "std", @@ -10477,7 +12081,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "from", "std", @@ -10497,7 +12101,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: nil, }, Value: "substr second parameter should be a number, got ", @@ -10519,7 +12123,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "from", "std", @@ -10539,7 +12143,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -10558,7 +12162,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -10604,7 +12208,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p330, + context: p754, freeVariables: Identifiers{ "from", }, @@ -10633,7 +12237,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "from", "len", @@ -10761,7 +12365,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "len", "std", @@ -10781,7 +12385,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -10800,7 +12404,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -10846,7 +12450,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p353, + context: p777, freeVariables: Identifiers{ "len", }, @@ -10873,7 +12477,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: nil, }, Value: "number", @@ -10901,7 +12505,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "len", "std", @@ -10921,7 +12525,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "len", "std", @@ -10941,7 +12545,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: nil, }, Value: "substr third parameter should be a number, got ", @@ -10963,7 +12567,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "len", "std", @@ -10983,7 +12587,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -11002,7 +12606,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -11048,7 +12652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p370, + context: p794, freeVariables: Identifiers{ "len", }, @@ -11077,7 +12681,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "from", "len", @@ -11099,7 +12703,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "len", }, @@ -11118,7 +12722,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "len", }, @@ -11140,7 +12744,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: nil, }, Value: float64(0), @@ -11161,7 +12765,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "len", }, @@ -11180,7 +12784,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "len", }, @@ -11199,7 +12803,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: nil, }, Value: "substr third parameter should be greater than zero, got ", @@ -11221,7 +12825,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "len", }, @@ -11244,7 +12848,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "from", "len", @@ -11266,7 +12870,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -11285,7 +12889,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p252, + context: p676, freeVariables: Identifiers{ "std", }, @@ -11331,7 +12935,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p395, + context: p819, freeVariables: nil, }, Value: "", @@ -11352,7 +12956,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p395, + context: p819, freeVariables: Identifiers{ "from", "len", @@ -11374,7 +12978,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p395, + context: p819, freeVariables: Identifiers{ "std", }, @@ -11393,7 +12997,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p395, + context: p819, freeVariables: Identifiers{ "std", }, @@ -11439,7 +13043,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p405, + context: p829, freeVariables: Identifiers{ "len", }, @@ -11460,7 +13064,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p405, + context: p829, freeVariables: Identifiers{ "from", "str", @@ -11487,7 +13091,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p411, + context: p835, freeVariables: Identifiers{ "from", "i", @@ -11508,7 +13112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p411, + context: p835, freeVariables: Identifiers{ "str", }, @@ -11529,7 +13133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p411, + context: p835, freeVariables: Identifiers{ "from", "i", @@ -11549,7 +13153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p411, + context: p835, freeVariables: Identifiers{ "i", }, @@ -11571,7 +13175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p411, + context: p835, freeVariables: Identifiers{ "from", }, @@ -11659,7 +13263,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p849, freeVariables: nil, }, }, @@ -11681,7 +13285,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p851, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -11923,7 +13527,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p875, freeVariables: Identifiers{ "base64_table", "i", @@ -11947,7 +13551,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p879, freeVariables: Identifiers{ "base64_table", "i", @@ -11967,7 +13571,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p882, freeVariables: Identifiers{ "base64_table", }, @@ -11988,7 +13592,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p885, freeVariables: Identifiers{ "i", }, @@ -12011,7 +13615,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p888, freeVariables: Identifiers{ "i", }, @@ -12040,7 +13644,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p891, freeVariables: Identifiers{ "std", }, @@ -12059,7 +13663,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p894, freeVariables: Identifiers{ "std", }, @@ -12078,7 +13682,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p897, freeVariables: Identifiers{ "std", }, @@ -12124,7 +13728,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p902, freeVariables: nil, }, Value: float64(0), @@ -12144,14 +13748,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p904, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -12207,7 +13811,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -12234,7 +13838,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "a", "b", @@ -12255,7 +13859,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "a", "b", @@ -12276,7 +13880,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "a", "std", @@ -12296,7 +13900,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "std", }, @@ -12315,7 +13919,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "std", }, @@ -12361,7 +13965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p440, + context: p923, freeVariables: Identifiers{ "a", }, @@ -12389,7 +13993,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "b", "std", @@ -12409,7 +14013,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "std", }, @@ -12428,7 +14032,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "std", }, @@ -12474,7 +14078,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p451, + context: p934, freeVariables: Identifiers{ "b", }, @@ -12502,7 +14106,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: nil, }, Value: false, @@ -12607,7 +14211,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "a", "b", @@ -12628,7 +14232,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "std", }, @@ -12647,7 +14251,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "std", }, @@ -12693,7 +14297,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p471, + context: p954, freeVariables: Identifiers{ "a", }, @@ -12714,7 +14318,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p471, + context: p954, freeVariables: nil, }, Value: float64(0), @@ -12734,7 +14338,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p471, + context: p954, freeVariables: Identifiers{ "b", "std", @@ -12754,7 +14358,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p471, + context: p954, freeVariables: Identifiers{ "std", }, @@ -12773,7 +14377,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p471, + context: p954, freeVariables: Identifiers{ "std", }, @@ -12819,7 +14423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p483, + context: p966, freeVariables: Identifiers{ "b", }, @@ -12852,7 +14456,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p427, + context: p910, freeVariables: Identifiers{ "b", }, @@ -12927,7 +14531,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p974, freeVariables: nil, }, }, @@ -12949,7 +14553,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p976, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -13191,7 +14795,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1000, freeVariables: Identifiers{ "base64_table", "i", @@ -13215,7 +14819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1004, freeVariables: Identifiers{ "base64_table", "i", @@ -13235,7 +14839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1007, freeVariables: Identifiers{ "base64_table", }, @@ -13256,7 +14860,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1010, freeVariables: Identifiers{ "i", }, @@ -13279,7 +14883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p1013, freeVariables: Identifiers{ "i", }, @@ -13308,7 +14912,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1016, freeVariables: Identifiers{ "std", }, @@ -13327,7 +14931,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1019, freeVariables: Identifiers{ "std", }, @@ -13346,7 +14950,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1022, freeVariables: Identifiers{ "std", }, @@ -13392,7 +14996,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1027, freeVariables: nil, }, Value: float64(0), @@ -13412,14 +15016,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1029, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -13475,7 +15079,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -13502,7 +15106,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "a", "b", @@ -13523,7 +15127,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "a", "b", @@ -13544,7 +15148,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "a", "std", @@ -13564,7 +15168,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "std", }, @@ -13583,7 +15187,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "std", }, @@ -13629,7 +15233,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p506, + context: p1048, freeVariables: Identifiers{ "a", }, @@ -13657,7 +15261,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "b", "std", @@ -13677,7 +15281,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "std", }, @@ -13696,7 +15300,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "std", }, @@ -13742,7 +15346,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p517, + context: p1059, freeVariables: Identifiers{ "b", }, @@ -13770,7 +15374,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: nil, }, Value: false, @@ -13875,7 +15479,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "a", "b", @@ -13896,7 +15500,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "std", }, @@ -13915,7 +15519,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "std", }, @@ -13961,7 +15565,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "a", }, @@ -13982,7 +15586,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "a", "b", @@ -14003,7 +15607,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "a", "std", @@ -14023,7 +15627,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "std", }, @@ -14042,7 +15646,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "std", }, @@ -14088,7 +15692,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p550, + context: p1092, freeVariables: Identifiers{ "a", }, @@ -14116,7 +15720,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "b", "std", @@ -14136,7 +15740,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "std", }, @@ -14155,7 +15759,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "std", }, @@ -14201,7 +15805,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p561, + context: p1103, freeVariables: Identifiers{ "b", }, @@ -14229,7 +15833,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "b", "std", @@ -14249,7 +15853,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "std", }, @@ -14268,7 +15872,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p537, + context: p1079, freeVariables: Identifiers{ "std", }, @@ -14314,7 +15918,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p572, + context: p1114, freeVariables: Identifiers{ "b", }, @@ -14347,7 +15951,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p493, + context: p1035, freeVariables: Identifiers{ "b", }, @@ -14422,7 +16026,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1122, freeVariables: nil, }, }, @@ -14444,7 +16048,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1124, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -14686,7 +16290,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1148, freeVariables: Identifiers{ "base64_table", "i", @@ -14710,7 +16314,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1152, freeVariables: Identifiers{ "base64_table", "i", @@ -14730,7 +16334,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1155, freeVariables: Identifiers{ "base64_table", }, @@ -14751,7 +16355,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1158, freeVariables: Identifiers{ "i", }, @@ -14774,7 +16378,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p1161, freeVariables: Identifiers{ "i", }, @@ -14803,7 +16407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1164, freeVariables: Identifiers{ "std", }, @@ -14822,7 +16426,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1167, freeVariables: Identifiers{ "std", }, @@ -14841,7 +16445,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1170, freeVariables: Identifiers{ "std", }, @@ -14887,7 +16491,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1175, freeVariables: nil, }, Value: float64(0), @@ -14907,14 +16511,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1177, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -14970,7 +16574,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -14996,7 +16600,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p582, + context: p1183, freeVariables: Identifiers{ "std", "str", @@ -15016,7 +16620,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p582, + context: p1183, freeVariables: Identifiers{ "std", }, @@ -15035,7 +16639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p582, + context: p1183, freeVariables: Identifiers{ "std", }, @@ -15081,7 +16685,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p591, + context: p1192, freeVariables: Identifiers{ "std", "str", @@ -15101,7 +16705,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p591, + context: p1192, freeVariables: Identifiers{ "std", }, @@ -15120,7 +16724,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p591, + context: p1192, freeVariables: Identifiers{ "std", }, @@ -15166,7 +16770,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p600, + context: p1201, freeVariables: Identifiers{ "str", }, @@ -15193,7 +16797,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p591, + context: p1192, freeVariables: Identifiers{ "str", }, @@ -15219,7 +16823,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p606, + context: p1207, freeVariables: Identifiers{ "i", "str", @@ -15239,7 +16843,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p606, + context: p1207, freeVariables: Identifiers{ "str", }, @@ -15260,7 +16864,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p606, + context: p1207, freeVariables: Identifiers{ "i", }, @@ -15337,7 +16941,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1217, freeVariables: nil, }, }, @@ -15359,7 +16963,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1219, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -15601,7 +17205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1243, freeVariables: Identifiers{ "base64_table", "i", @@ -15625,7 +17229,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1247, freeVariables: Identifiers{ "base64_table", "i", @@ -15645,7 +17249,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1250, freeVariables: Identifiers{ "base64_table", }, @@ -15666,7 +17270,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1253, freeVariables: Identifiers{ "i", }, @@ -15689,7 +17293,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p1256, freeVariables: Identifiers{ "i", }, @@ -15718,7 +17322,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1259, freeVariables: Identifiers{ "std", }, @@ -15737,7 +17341,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1262, freeVariables: Identifiers{ "std", }, @@ -15756,7 +17360,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1265, freeVariables: Identifiers{ "std", }, @@ -15802,7 +17406,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1270, freeVariables: nil, }, Value: float64(0), @@ -15822,14 +17426,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1272, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -15885,7 +17489,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -15911,7 +17515,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "std", "str", @@ -15934,7 +17538,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p622, + context: p1282, freeVariables: nil, }, Parameters: Parameters{ @@ -15959,7 +17563,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "aggregate", "digit", @@ -15979,7 +17583,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "digit", }, @@ -15998,7 +17602,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "digit", }, @@ -16017,7 +17621,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "digit", }, @@ -16039,7 +17643,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: nil, }, Value: float64(0), @@ -16061,7 +17665,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "digit", }, @@ -16080,7 +17684,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "digit", }, @@ -16102,7 +17706,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: nil, }, Value: float64(9), @@ -16124,7 +17728,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: nil, }, Expr: &LiteralString{ @@ -16141,7 +17745,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: nil, }, Value: "parseInt got string which does not match regex [0-9]+", @@ -16163,7 +17767,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "aggregate", "digit", @@ -16183,7 +17787,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "aggregate", }, @@ -16202,7 +17806,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: nil, }, Value: float64(10), @@ -16223,7 +17827,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "aggregate", }, @@ -16246,7 +17850,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p625, + context: p1285, freeVariables: Identifiers{ "digit", }, @@ -16273,7 +17877,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "addDigit", "std", @@ -16297,7 +17901,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p654, + context: p1314, freeVariables: Identifiers{ "std", }, @@ -16455,7 +18059,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p672, + context: p1332, freeVariables: Identifiers{ "char", "std", @@ -16475,7 +18079,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p672, + context: p1332, freeVariables: Identifiers{ "char", "std", @@ -16495,7 +18099,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p672, + context: p1332, freeVariables: Identifiers{ "std", }, @@ -16514,7 +18118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p672, + context: p1332, freeVariables: Identifiers{ "std", }, @@ -16560,7 +18164,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p683, + context: p1343, freeVariables: Identifiers{ "char", }, @@ -16588,7 +18192,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p672, + context: p1332, freeVariables: Identifiers{ "std", }, @@ -16607,7 +18211,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p672, + context: p1332, freeVariables: Identifiers{ "std", }, @@ -16626,7 +18230,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p672, + context: p1332, freeVariables: Identifiers{ "std", }, @@ -16672,7 +18276,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p694, + context: p1354, freeVariables: nil, }, Value: "0", @@ -16704,7 +18308,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p696, + context: p1356, freeVariables: Identifiers{ "std", "str", @@ -16724,7 +18328,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p696, + context: p1356, freeVariables: Identifiers{ "std", }, @@ -16743,7 +18347,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p696, + context: p1356, freeVariables: Identifiers{ "std", }, @@ -16789,7 +18393,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p705, + context: p1365, freeVariables: Identifiers{ "str", }, @@ -16826,7 +18430,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "addDigit", "std", @@ -16933,7 +18537,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "str", }, @@ -16952,7 +18556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "str", }, @@ -16973,7 +18577,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: nil, }, Value: float64(0), @@ -16995,7 +18599,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: nil, }, Value: "-", @@ -17022,7 +18626,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "addDigit", "std", @@ -17045,7 +18649,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "addDigit", "std", @@ -17067,7 +18671,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "std", }, @@ -17086,7 +18690,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "std", }, @@ -17132,7 +18736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p734, + context: p1394, freeVariables: Identifiers{ "addDigit", }, @@ -17153,7 +18757,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p734, + context: p1394, freeVariables: Identifiers{ "std", "str", @@ -17174,7 +18778,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p734, + context: p1394, freeVariables: Identifiers{ "toDigits", }, @@ -17282,7 +18886,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p750, + context: p1410, freeVariables: Identifiers{ "str", }, @@ -17303,7 +18907,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p750, + context: p1410, freeVariables: nil, }, Value: float64(1), @@ -17371,7 +18975,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p734, + context: p1394, freeVariables: nil, }, Value: float64(0), @@ -17398,7 +19002,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "addDigit", "std", @@ -17420,7 +19024,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "std", }, @@ -17439,7 +19043,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p618, + context: p1278, freeVariables: Identifiers{ "std", }, @@ -17485,7 +19089,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p765, + context: p1425, freeVariables: Identifiers{ "addDigit", }, @@ -17506,7 +19110,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p765, + context: p1425, freeVariables: Identifiers{ "str", "toDigits", @@ -17526,7 +19130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p765, + context: p1425, freeVariables: Identifiers{ "toDigits", }, @@ -17549,7 +19153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p773, + context: p1433, freeVariables: Identifiers{ "str", }, @@ -17576,7 +19180,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p765, + context: p1425, freeVariables: nil, }, Value: float64(0), @@ -17652,7 +19256,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1440, freeVariables: nil, }, }, @@ -17674,7 +19278,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1442, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -17916,7 +19520,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1466, freeVariables: Identifiers{ "base64_table", "i", @@ -17940,7 +19544,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1470, freeVariables: Identifiers{ "base64_table", "i", @@ -17960,7 +19564,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1473, freeVariables: Identifiers{ "base64_table", }, @@ -17981,7 +19585,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1476, freeVariables: Identifiers{ "i", }, @@ -18004,7 +19608,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p1479, freeVariables: Identifiers{ "i", }, @@ -18033,7 +19637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1482, freeVariables: Identifiers{ "std", }, @@ -18052,7 +19656,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1485, freeVariables: Identifiers{ "std", }, @@ -18071,7 +19675,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1488, freeVariables: Identifiers{ "std", }, @@ -18117,7 +19721,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1493, freeVariables: nil, }, Value: float64(0), @@ -18137,14 +19741,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1495, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -18200,7 +19804,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -18227,7 +19831,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -18354,7 +19958,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", "str", @@ -18374,7 +19978,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -18393,7 +19997,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -18439,7 +20043,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p803, + context: p1522, freeVariables: Identifiers{ "str", }, @@ -18466,7 +20070,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: nil, }, Value: "string", @@ -18494,7 +20098,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", "str", @@ -18514,7 +20118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", "str", @@ -18534,7 +20138,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: nil, }, Value: "std.split first parameter should be a string, got ", @@ -18556,7 +20160,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", "str", @@ -18576,7 +20180,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -18595,7 +20199,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -18641,7 +20245,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p820, + context: p1539, freeVariables: Identifiers{ "str", }, @@ -18670,7 +20274,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -18797,7 +20401,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -18817,7 +20421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -18836,7 +20440,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -18882,7 +20486,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p843, + context: p1562, freeVariables: Identifiers{ "c", }, @@ -18909,7 +20513,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: nil, }, Value: "string", @@ -18937,7 +20541,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -18957,7 +20561,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -18977,7 +20581,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: nil, }, Value: "std.split second parameter should be a string, got ", @@ -18999,7 +20603,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -19019,7 +20623,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -19038,7 +20642,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -19084,7 +20688,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p860, + context: p1579, freeVariables: Identifiers{ "c", }, @@ -19113,7 +20717,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -19240,7 +20844,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -19260,7 +20864,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -19279,7 +20883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -19325,7 +20929,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p883, + context: p1602, freeVariables: Identifiers{ "c", }, @@ -19352,7 +20956,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: nil, }, Value: float64(1), @@ -19379,7 +20983,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -19399,7 +21003,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -19419,7 +21023,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: nil, }, Value: "std.split second parameter should have length 1, got ", @@ -19441,7 +21045,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -19461,7 +21065,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -19480,7 +21084,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -19526,7 +21130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p900, + context: p1619, freeVariables: Identifiers{ "c", }, @@ -19555,7 +21159,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "c", "std", @@ -19576,7 +21180,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -19595,7 +21199,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p782, + context: p1501, freeVariables: Identifiers{ "std", }, @@ -19641,7 +21245,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p911, + context: p1630, freeVariables: Identifiers{ "str", }, @@ -19662,7 +21266,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p911, + context: p1630, freeVariables: Identifiers{ "c", }, @@ -19683,7 +21287,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p911, + context: p1630, freeVariables: nil, }, Op: UnaryOp(3), @@ -19701,7 +21305,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p911, + context: p1630, freeVariables: nil, }, Value: float64(1), @@ -19778,7 +21382,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1640, freeVariables: nil, }, }, @@ -19800,7 +21404,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1642, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -20042,7 +21646,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1666, freeVariables: Identifiers{ "base64_table", "i", @@ -20066,7 +21670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1670, freeVariables: Identifiers{ "base64_table", "i", @@ -20086,7 +21690,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1673, freeVariables: Identifiers{ "base64_table", }, @@ -20107,7 +21711,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1676, freeVariables: Identifiers{ "i", }, @@ -20130,7 +21734,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p1679, freeVariables: Identifiers{ "i", }, @@ -20159,7 +21763,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1682, freeVariables: Identifiers{ "std", }, @@ -20178,7 +21782,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1685, freeVariables: Identifiers{ "std", }, @@ -20197,7 +21801,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p1688, freeVariables: Identifiers{ "std", }, @@ -20243,7 +21847,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1693, freeVariables: nil, }, Value: float64(0), @@ -20263,14 +21867,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p1695, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -20326,7 +21930,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -20354,7 +21958,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "maxsplits", @@ -20482,7 +22086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", "str", @@ -20502,7 +22106,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -20521,7 +22125,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -20567,7 +22171,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p944, + context: p1722, freeVariables: Identifiers{ "str", }, @@ -20594,7 +22198,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: nil, }, Value: "string", @@ -20622,7 +22226,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", "str", @@ -20642,7 +22246,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", "str", @@ -20662,7 +22266,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: nil, }, Value: "std.splitLimit first parameter should be a string, got ", @@ -20684,7 +22288,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", "str", @@ -20704,7 +22308,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -20723,7 +22327,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -20769,7 +22373,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p961, + context: p1739, freeVariables: Identifiers{ "str", }, @@ -20798,7 +22402,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "maxsplits", @@ -20926,7 +22530,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "std", @@ -20946,7 +22550,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -20965,7 +22569,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -21011,7 +22615,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p984, + context: p1762, freeVariables: Identifiers{ "c", }, @@ -21038,7 +22642,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: nil, }, Value: "string", @@ -21066,7 +22670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "std", @@ -21086,7 +22690,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "std", @@ -21106,7 +22710,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: nil, }, Value: "std.splitLimit second parameter should be a string, got ", @@ -21128,7 +22732,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "std", @@ -21148,7 +22752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -21167,7 +22771,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -21213,7 +22817,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1001, + context: p1779, freeVariables: Identifiers{ "c", }, @@ -21242,7 +22846,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "maxsplits", @@ -21370,7 +22974,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "std", @@ -21390,7 +22994,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -21409,7 +23013,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -21455,7 +23059,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1024, + context: p1802, freeVariables: Identifiers{ "c", }, @@ -21482,7 +23086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: nil, }, Value: float64(1), @@ -21509,7 +23113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "std", @@ -21529,7 +23133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "std", @@ -21549,7 +23153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: nil, }, Value: "std.splitLimit second parameter should have length 1, got ", @@ -21571,7 +23175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "std", @@ -21591,7 +23195,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -21610,7 +23214,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -21656,7 +23260,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1041, + context: p1819, freeVariables: Identifiers{ "c", }, @@ -21685,7 +23289,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "maxsplits", @@ -21813,7 +23417,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "maxsplits", "std", @@ -21833,7 +23437,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -21852,7 +23456,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -21898,7 +23502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1064, + context: p1842, freeVariables: Identifiers{ "maxsplits", }, @@ -21925,7 +23529,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: nil, }, Value: "number", @@ -21953,7 +23557,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "maxsplits", "std", @@ -21973,7 +23577,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "maxsplits", "std", @@ -21993,7 +23597,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: nil, }, Value: "std.splitLimit third parameter should be a number, got ", @@ -22015,7 +23619,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "maxsplits", "std", @@ -22035,7 +23639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -22054,7 +23658,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "std", }, @@ -22100,7 +23704,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1081, + context: p1859, freeVariables: Identifiers{ "maxsplits", }, @@ -22129,7 +23733,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "c", "maxsplits", @@ -22154,7 +23758,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1087, + context: p1865, freeVariables: Identifiers{ "aux", "maxsplits", @@ -22186,7 +23790,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "aux", @@ -22215,7 +23819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1095, + context: p1873, freeVariables: Identifiers{ "i", "str", @@ -22235,7 +23839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1095, + context: p1873, freeVariables: Identifiers{ "str", }, @@ -22256,7 +23860,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1095, + context: p1873, freeVariables: Identifiers{ "i", }, @@ -22282,7 +23886,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "aux", @@ -22312,7 +23916,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1105, + context: p1883, freeVariables: Identifiers{ "i", }, @@ -22331,7 +23935,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1105, + context: p1883, freeVariables: Identifiers{ "i", }, @@ -22353,7 +23957,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1105, + context: p1883, freeVariables: nil, }, Value: float64(1), @@ -22377,7 +23981,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "aux", @@ -22405,7 +24009,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "i", "std", @@ -22426,7 +24030,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "i", }, @@ -22448,7 +24052,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "std", "str", @@ -22468,7 +24072,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "std", }, @@ -22487,7 +24091,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "std", }, @@ -22533,7 +24137,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1125, + context: p1903, freeVariables: Identifiers{ "str", }, @@ -22561,7 +24165,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "v", @@ -22581,7 +24185,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", }, @@ -22603,7 +24207,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "v", }, @@ -22623,7 +24227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1135, + context: p1913, freeVariables: Identifiers{ "v", }, @@ -22648,7 +24252,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "aux", @@ -22675,7 +24279,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "c", @@ -22784,7 +24388,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "c", }, @@ -22805,7 +24409,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "delim", }, @@ -22833,7 +24437,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "maxsplits", @@ -22939,7 +24543,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "maxsplits", }, @@ -22960,7 +24564,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: nil, }, Op: UnaryOp(3), @@ -22978,7 +24582,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: nil, }, Value: float64(1), @@ -23006,7 +24610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "maxsplits", @@ -23027,7 +24631,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "std", @@ -23047,7 +24651,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "std", }, @@ -23066,7 +24670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "std", }, @@ -23112,7 +24716,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1178, + context: p1956, freeVariables: Identifiers{ "arr", }, @@ -23140,7 +24744,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "maxsplits", }, @@ -23164,7 +24768,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "aux", @@ -23188,7 +24792,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "aux", }, @@ -23211,7 +24815,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1188, + context: p1966, freeVariables: Identifiers{ "str", }, @@ -23232,7 +24836,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1188, + context: p1966, freeVariables: Identifiers{ "delim", }, @@ -23253,7 +24857,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1188, + context: p1966, freeVariables: Identifiers{ "i2", }, @@ -23274,7 +24878,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1188, + context: p1966, freeVariables: Identifiers{ "arr", "v", @@ -23294,7 +24898,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1188, + context: p1966, freeVariables: Identifiers{ "arr", }, @@ -23316,7 +24920,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1188, + context: p1966, freeVariables: Identifiers{ "v", }, @@ -23336,7 +24940,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1202, + context: p1980, freeVariables: Identifiers{ "v", }, @@ -23361,7 +24965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1188, + context: p1966, freeVariables: nil, }, Value: "", @@ -23388,7 +24992,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "arr", "aux", @@ -23413,7 +25017,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1091, + context: p1869, freeVariables: Identifiers{ "aux", }, @@ -23436,7 +25040,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1211, + context: p1989, freeVariables: Identifiers{ "str", }, @@ -23457,7 +25061,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1211, + context: p1989, freeVariables: Identifiers{ "delim", }, @@ -23478,7 +25082,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1211, + context: p1989, freeVariables: Identifiers{ "i2", }, @@ -23499,7 +25103,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1211, + context: p1989, freeVariables: Identifiers{ "arr", }, @@ -23520,7 +25124,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1211, + context: p1989, freeVariables: Identifiers{ "c", "v", @@ -23540,7 +25144,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1211, + context: p1989, freeVariables: Identifiers{ "v", }, @@ -23562,7 +25166,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1211, + context: p1989, freeVariables: Identifiers{ "c", }, @@ -23598,7 +25202,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "aux", "c", @@ -23619,7 +25223,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p923, + context: p1701, freeVariables: Identifiers{ "aux", }, @@ -23642,7 +25246,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1231, + context: p2009, freeVariables: Identifiers{ "str", }, @@ -23663,7 +25267,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1231, + context: p2009, freeVariables: Identifiers{ "c", }, @@ -23684,7 +25288,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1231, + context: p2009, freeVariables: nil, }, Value: float64(0), @@ -23704,7 +25308,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1231, + context: p2009, freeVariables: nil, }, Elements: nil, @@ -23724,7 +25328,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1231, + context: p2009, freeVariables: nil, }, Value: "", @@ -23803,7 +25407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2020, freeVariables: nil, }, }, @@ -23825,7 +25429,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2022, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -24067,7 +25671,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2046, freeVariables: Identifiers{ "base64_table", "i", @@ -24091,7 +25695,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2050, freeVariables: Identifiers{ "base64_table", "i", @@ -24111,7 +25715,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2053, freeVariables: Identifiers{ "base64_table", }, @@ -24132,7 +25736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2056, freeVariables: Identifiers{ "i", }, @@ -24155,7 +25759,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p2059, freeVariables: Identifiers{ "i", }, @@ -24184,7 +25788,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2062, freeVariables: Identifiers{ "std", }, @@ -24203,7 +25807,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2065, freeVariables: Identifiers{ "std", }, @@ -24222,7 +25826,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2068, freeVariables: Identifiers{ "std", }, @@ -24268,7 +25872,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2073, freeVariables: nil, }, Value: float64(0), @@ -24288,14 +25892,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2075, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -24351,7 +25955,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -24486,7 +26090,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", "str", @@ -24506,7 +26110,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", }, @@ -24525,7 +26129,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", }, @@ -24571,7 +26175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1263, + context: p2100, freeVariables: Identifiers{ "str", }, @@ -24598,7 +26202,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: nil, }, Value: "string", @@ -24732,7 +26336,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "from", "std", @@ -24752,7 +26356,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", }, @@ -24771,7 +26375,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", }, @@ -24817,7 +26421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1285, + context: p2122, freeVariables: Identifiers{ "from", }, @@ -24844,7 +26448,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: nil, }, Value: "string", @@ -24978,7 +26582,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", "to", @@ -24998,7 +26602,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", }, @@ -25017,7 +26621,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", }, @@ -25063,7 +26667,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1307, + context: p2144, freeVariables: Identifiers{ "to", }, @@ -25090,7 +26694,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: nil, }, Value: "string", @@ -25245,7 +26849,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "from", }, @@ -25266,7 +26870,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: nil, }, Value: "", @@ -25294,7 +26898,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "from", "std", @@ -25319,7 +26923,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1329, + context: p2166, freeVariables: Identifiers{ "std", "str", @@ -25339,7 +26943,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1329, + context: p2166, freeVariables: Identifiers{ "std", }, @@ -25358,7 +26962,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1329, + context: p2166, freeVariables: Identifiers{ "std", }, @@ -25404,7 +27008,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1338, + context: p2175, freeVariables: Identifiers{ "str", }, @@ -25434,7 +27038,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "from", "std", @@ -25460,7 +27064,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1344, + context: p2181, freeVariables: Identifiers{ "from", "std", @@ -25480,7 +27084,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1344, + context: p2181, freeVariables: Identifiers{ "std", }, @@ -25499,7 +27103,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1344, + context: p2181, freeVariables: Identifiers{ "std", }, @@ -25545,7 +27149,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1353, + context: p2190, freeVariables: Identifiers{ "from", }, @@ -25575,7 +27179,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "from", "from_len", @@ -25602,7 +27206,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1359, + context: p2196, freeVariables: Identifiers{ "from", "from_len", @@ -25806,7 +27410,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1379, + context: p2216, freeVariables: Identifiers{ "str", }, @@ -25827,7 +27431,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1379, + context: p2216, freeVariables: Identifiers{ "i", }, @@ -25848,7 +27452,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1379, + context: p2216, freeVariables: Identifiers{ "from_len", "i", @@ -25868,7 +27472,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1379, + context: p2216, freeVariables: Identifiers{ "i", }, @@ -25890,7 +27494,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1379, + context: p2216, freeVariables: Identifiers{ "from_len", }, @@ -25936,7 +27540,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1379, + context: p2216, freeVariables: Identifiers{ "from", }, @@ -25967,7 +27571,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "found_at", "from", @@ -25995,7 +27599,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1396, + context: p2233, freeVariables: Identifiers{ "found_at", "from", @@ -26029,7 +27633,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "acc", "curr_index", @@ -26057,7 +27661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "curr_index", "str_len", @@ -26077,7 +27681,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "curr_index", }, @@ -26099,7 +27703,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "str_len", }, @@ -26121,7 +27725,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "acc", "curr_index", @@ -26144,7 +27748,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "acc", }, @@ -26253,7 +27857,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "str", }, @@ -26274,7 +27878,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "start_index", }, @@ -26295,7 +27899,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "curr_index", }, @@ -26341,7 +27945,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "acc", "curr_index", @@ -26368,7 +27972,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "curr_index", "found_at", @@ -26388,7 +27992,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "found_at", }, @@ -26411,7 +28015,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1435, + context: p2272, freeVariables: Identifiers{ "curr_index", }, @@ -26438,7 +28042,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "acc", "curr_index", @@ -26467,7 +28071,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1441, + context: p2278, freeVariables: Identifiers{ "curr_index", "from", @@ -26488,7 +28092,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1441, + context: p2278, freeVariables: Identifiers{ "curr_index", }, @@ -26510,7 +28114,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1441, + context: p2278, freeVariables: Identifiers{ "from", "std", @@ -26530,7 +28134,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1441, + context: p2278, freeVariables: Identifiers{ "std", }, @@ -26549,7 +28153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1441, + context: p2278, freeVariables: Identifiers{ "std", }, @@ -26595,7 +28199,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1454, + context: p2291, freeVariables: Identifiers{ "from", }, @@ -26626,7 +28230,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "acc", "curr_index", @@ -26652,7 +28256,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "replace_after", }, @@ -26675,7 +28279,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1462, + context: p2299, freeVariables: Identifiers{ "new_index", }, @@ -26696,7 +28300,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1462, + context: p2299, freeVariables: Identifiers{ "new_index", }, @@ -26717,7 +28321,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1462, + context: p2299, freeVariables: Identifiers{ "acc", "curr_index", @@ -26741,7 +28345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1462, + context: p2299, freeVariables: Identifiers{ "acc", "curr_index", @@ -26764,7 +28368,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1462, + context: p2299, freeVariables: Identifiers{ "acc", }, @@ -26873,7 +28477,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1462, + context: p2299, freeVariables: Identifiers{ "str", }, @@ -26894,7 +28498,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1462, + context: p2299, freeVariables: Identifiers{ "start_index", }, @@ -26915,7 +28519,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1462, + context: p2299, freeVariables: Identifiers{ "curr_index", }, @@ -26962,7 +28566,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1462, + context: p2299, freeVariables: Identifiers{ "to", }, @@ -26991,7 +28595,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "acc", "curr_index", @@ -27013,7 +28617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1400, + context: p2237, freeVariables: Identifiers{ "replace_after", }, @@ -27036,7 +28640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1495, + context: p2332, freeVariables: Identifiers{ "start_index", }, @@ -27057,7 +28661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1495, + context: p2332, freeVariables: Identifiers{ "curr_index", }, @@ -27076,7 +28680,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1495, + context: p2332, freeVariables: Identifiers{ "curr_index", }, @@ -27098,7 +28702,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1495, + context: p2332, freeVariables: nil, }, Value: float64(1), @@ -27119,7 +28723,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1495, + context: p2332, freeVariables: Identifiers{ "acc", }, @@ -27152,7 +28756,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "from", "from_len", @@ -27261,7 +28865,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "from_len", }, @@ -27282,7 +28886,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: nil, }, Value: float64(1), @@ -27308,7 +28912,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "from", "std", @@ -27330,7 +28934,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", }, @@ -27349,7 +28953,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "std", }, @@ -27395,7 +28999,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1526, + context: p2363, freeVariables: Identifiers{ "to", }, @@ -27416,7 +29020,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1526, + context: p2363, freeVariables: Identifiers{ "from", "std", @@ -27437,7 +29041,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1526, + context: p2363, freeVariables: Identifiers{ "std", }, @@ -27456,7 +29060,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1526, + context: p2363, freeVariables: Identifiers{ "std", }, @@ -27502,7 +29106,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1537, + context: p2374, freeVariables: Identifiers{ "str", }, @@ -27523,7 +29127,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1537, + context: p2374, freeVariables: Identifiers{ "from", }, @@ -27556,7 +29160,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "replace_after", }, @@ -27575,7 +29179,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: Identifiers{ "replace_after", }, @@ -27598,7 +29202,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1547, + context: p2384, freeVariables: nil, }, Value: float64(0), @@ -27618,7 +29222,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1547, + context: p2384, freeVariables: nil, }, Value: float64(0), @@ -27638,7 +29242,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1547, + context: p2384, freeVariables: nil, }, Value: "", @@ -27687,7 +29291,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1254, + context: p2091, freeVariables: nil, }, Value: "'from' string must not be zero length.", @@ -27877,7 +29481,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2399, freeVariables: nil, }, }, @@ -27899,7 +29503,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2401, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -28141,7 +29745,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2425, freeVariables: Identifiers{ "base64_table", "i", @@ -28165,7 +29769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2429, freeVariables: Identifiers{ "base64_table", "i", @@ -28185,7 +29789,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2432, freeVariables: Identifiers{ "base64_table", }, @@ -28206,7 +29810,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2435, freeVariables: Identifiers{ "i", }, @@ -28229,7 +29833,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p2438, freeVariables: Identifiers{ "i", }, @@ -28258,7 +29862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2441, freeVariables: Identifiers{ "std", }, @@ -28277,7 +29881,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2444, freeVariables: Identifiers{ "std", }, @@ -28296,7 +29900,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2447, freeVariables: Identifiers{ "std", }, @@ -28342,7 +29946,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2452, freeVariables: nil, }, Value: float64(0), @@ -28362,14 +29966,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2454, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -28425,7 +30029,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -28451,7 +30055,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1564, + context: p2460, freeVariables: Identifiers{ "std", "x", @@ -28474,7 +30078,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1568, + context: p2464, freeVariables: Identifiers{ "std", }, @@ -28493,7 +30097,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1568, + context: p2464, freeVariables: Identifiers{ "std", }, @@ -28540,7 +30144,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1564, + context: p2460, freeVariables: Identifiers{ "cp", "std", @@ -28564,7 +30168,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1577, + context: p2473, freeVariables: Identifiers{ "cp", "std", @@ -28591,7 +30195,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "c", "cp", @@ -28612,7 +30216,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "c", "cp", @@ -28632,7 +30236,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "c", "cp", @@ -28652,7 +30256,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "c", "cp", @@ -28672,7 +30276,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "cp", }, @@ -28695,7 +30299,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1593, + context: p2489, freeVariables: Identifiers{ "c", }, @@ -28723,7 +30327,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: nil, }, Value: float64(97), @@ -28745,7 +30349,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "c", "cp", @@ -28765,7 +30369,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "c", "cp", @@ -28785,7 +30389,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "cp", }, @@ -28808,7 +30412,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1604, + context: p2500, freeVariables: Identifiers{ "c", }, @@ -28836,7 +30440,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: nil, }, Value: float64(123), @@ -28858,7 +30462,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "c", "cp", @@ -28879,7 +30483,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "std", }, @@ -28898,7 +30502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "std", }, @@ -28944,7 +30548,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1616, + context: p2512, freeVariables: Identifiers{ "c", "cp", @@ -28964,7 +30568,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1616, + context: p2512, freeVariables: Identifiers{ "c", "cp", @@ -28984,7 +30588,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1616, + context: p2512, freeVariables: Identifiers{ "cp", }, @@ -29007,7 +30611,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1624, + context: p2520, freeVariables: Identifiers{ "c", }, @@ -29035,7 +30639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1616, + context: p2512, freeVariables: nil, }, Value: float64(32), @@ -29062,7 +30666,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1581, + context: p2477, freeVariables: Identifiers{ "c", }, @@ -29088,7 +30692,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1564, + context: p2460, freeVariables: Identifiers{ "std", "up_letter", @@ -29109,7 +30713,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1564, + context: p2460, freeVariables: Identifiers{ "std", }, @@ -29128,7 +30732,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1564, + context: p2460, freeVariables: Identifiers{ "std", }, @@ -29174,7 +30778,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1638, + context: p2534, freeVariables: nil, }, Value: "", @@ -29195,7 +30799,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1638, + context: p2534, freeVariables: Identifiers{ "std", "up_letter", @@ -29216,7 +30820,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1638, + context: p2534, freeVariables: Identifiers{ "std", }, @@ -29235,7 +30839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1638, + context: p2534, freeVariables: Identifiers{ "std", }, @@ -29281,7 +30885,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1648, + context: p2544, freeVariables: Identifiers{ "up_letter", }, @@ -29302,7 +30906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1648, + context: p2544, freeVariables: Identifiers{ "std", "x", @@ -29322,7 +30926,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1648, + context: p2544, freeVariables: Identifiers{ "std", }, @@ -29341,7 +30945,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1648, + context: p2544, freeVariables: Identifiers{ "std", }, @@ -29387,7 +30991,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1659, + context: p2555, freeVariables: Identifiers{ "x", }, @@ -29475,7 +31079,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2561, freeVariables: nil, }, }, @@ -29497,7 +31101,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2563, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -29739,7 +31343,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2587, freeVariables: Identifiers{ "base64_table", "i", @@ -29763,7 +31367,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2591, freeVariables: Identifiers{ "base64_table", "i", @@ -29783,7 +31387,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2594, freeVariables: Identifiers{ "base64_table", }, @@ -29804,7 +31408,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2597, freeVariables: Identifiers{ "i", }, @@ -29827,7 +31431,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p2600, freeVariables: Identifiers{ "i", }, @@ -29856,7 +31460,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2603, freeVariables: Identifiers{ "std", }, @@ -29875,7 +31479,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2606, freeVariables: Identifiers{ "std", }, @@ -29894,7 +31498,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2609, freeVariables: Identifiers{ "std", }, @@ -29940,7 +31544,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2614, freeVariables: nil, }, Value: float64(0), @@ -29960,14 +31564,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2616, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -30023,7 +31627,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -30049,7 +31653,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1667, + context: p2622, freeVariables: Identifiers{ "std", "x", @@ -30072,7 +31676,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1671, + context: p2626, freeVariables: Identifiers{ "std", }, @@ -30091,7 +31695,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1671, + context: p2626, freeVariables: Identifiers{ "std", }, @@ -30138,7 +31742,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1667, + context: p2622, freeVariables: Identifiers{ "cp", "std", @@ -30162,7 +31766,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1680, + context: p2635, freeVariables: Identifiers{ "cp", "std", @@ -30189,7 +31793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "c", "cp", @@ -30210,7 +31814,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "c", "cp", @@ -30230,7 +31834,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "c", "cp", @@ -30250,7 +31854,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "c", "cp", @@ -30270,7 +31874,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "cp", }, @@ -30293,7 +31897,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1696, + context: p2651, freeVariables: Identifiers{ "c", }, @@ -30321,7 +31925,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: nil, }, Value: float64(65), @@ -30343,7 +31947,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "c", "cp", @@ -30363,7 +31967,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "c", "cp", @@ -30383,7 +31987,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "cp", }, @@ -30406,7 +32010,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1707, + context: p2662, freeVariables: Identifiers{ "c", }, @@ -30434,7 +32038,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: nil, }, Value: float64(91), @@ -30456,7 +32060,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "c", "cp", @@ -30477,7 +32081,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "std", }, @@ -30496,7 +32100,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "std", }, @@ -30542,7 +32146,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1719, + context: p2674, freeVariables: Identifiers{ "c", "cp", @@ -30562,7 +32166,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1719, + context: p2674, freeVariables: Identifiers{ "c", "cp", @@ -30582,7 +32186,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1719, + context: p2674, freeVariables: Identifiers{ "cp", }, @@ -30605,7 +32209,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1727, + context: p2682, freeVariables: Identifiers{ "c", }, @@ -30633,7 +32237,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1719, + context: p2674, freeVariables: nil, }, Value: float64(32), @@ -30660,7 +32264,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1684, + context: p2639, freeVariables: Identifiers{ "c", }, @@ -30686,7 +32290,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1667, + context: p2622, freeVariables: Identifiers{ "down_letter", "std", @@ -30707,7 +32311,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1667, + context: p2622, freeVariables: Identifiers{ "std", }, @@ -30726,7 +32330,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1667, + context: p2622, freeVariables: Identifiers{ "std", }, @@ -30772,7 +32376,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1741, + context: p2696, freeVariables: nil, }, Value: "", @@ -30793,7 +32397,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1741, + context: p2696, freeVariables: Identifiers{ "down_letter", "std", @@ -30814,7 +32418,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1741, + context: p2696, freeVariables: Identifiers{ "std", }, @@ -30833,7 +32437,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1741, + context: p2696, freeVariables: Identifiers{ "std", }, @@ -30879,7 +32483,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1751, + context: p2706, freeVariables: Identifiers{ "down_letter", }, @@ -30900,7 +32504,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1751, + context: p2706, freeVariables: Identifiers{ "std", "x", @@ -30920,7 +32524,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1751, + context: p2706, freeVariables: Identifiers{ "std", }, @@ -30939,7 +32543,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1751, + context: p2706, freeVariables: Identifiers{ "std", }, @@ -30985,7 +32589,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1762, + context: p2717, freeVariables: Identifiers{ "x", }, @@ -31073,7 +32677,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2723, freeVariables: nil, }, }, @@ -31095,7 +32699,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2725, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -31337,7 +32941,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2749, freeVariables: Identifiers{ "base64_table", "i", @@ -31361,7 +32965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2753, freeVariables: Identifiers{ "base64_table", "i", @@ -31381,7 +32985,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2756, freeVariables: Identifiers{ "base64_table", }, @@ -31402,7 +33006,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2759, freeVariables: Identifiers{ "i", }, @@ -31425,7 +33029,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p2762, freeVariables: Identifiers{ "i", }, @@ -31454,7 +33058,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2765, freeVariables: Identifiers{ "std", }, @@ -31473,7 +33077,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2768, freeVariables: Identifiers{ "std", }, @@ -31492,7 +33096,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2771, freeVariables: Identifiers{ "std", }, @@ -31538,7 +33142,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2776, freeVariables: nil, }, Value: float64(0), @@ -31558,14 +33162,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2778, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -31621,7 +33225,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -31648,7 +33252,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1770, + context: p2784, freeVariables: Identifiers{ "from", "std", @@ -31669,7 +33273,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1770, + context: p2784, freeVariables: Identifiers{ "std", }, @@ -31688,7 +33292,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1770, + context: p2784, freeVariables: Identifiers{ "std", }, @@ -31734,7 +33338,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1779, + context: p2793, freeVariables: Identifiers{ "from", "to", @@ -31754,7 +33358,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1779, + context: p2793, freeVariables: Identifiers{ "from", "to", @@ -31774,7 +33378,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1779, + context: p2793, freeVariables: Identifiers{ "to", }, @@ -31796,7 +33400,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1779, + context: p2793, freeVariables: Identifiers{ "from", }, @@ -31819,7 +33423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1779, + context: p2793, freeVariables: nil, }, Value: float64(1), @@ -31840,7 +33444,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1779, + context: p2793, freeVariables: Identifiers{ "from", }, @@ -31866,7 +33470,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1792, + context: p2806, freeVariables: Identifiers{ "from", "i", @@ -31886,7 +33490,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1792, + context: p2806, freeVariables: Identifiers{ "i", }, @@ -31908,7 +33512,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1792, + context: p2806, freeVariables: Identifiers{ "from", }, @@ -31984,7 +33588,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2816, freeVariables: nil, }, }, @@ -32006,7 +33610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2818, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -32248,7 +33852,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2842, freeVariables: Identifiers{ "base64_table", "i", @@ -32272,7 +33876,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2846, freeVariables: Identifiers{ "base64_table", "i", @@ -32292,7 +33896,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2849, freeVariables: Identifiers{ "base64_table", }, @@ -32313,7 +33917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2852, freeVariables: Identifiers{ "i", }, @@ -32336,7 +33940,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p2855, freeVariables: Identifiers{ "i", }, @@ -32365,7 +33969,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2858, freeVariables: Identifiers{ "std", }, @@ -32384,7 +33988,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2861, freeVariables: Identifiers{ "std", }, @@ -32403,7 +34007,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p2864, freeVariables: Identifiers{ "std", }, @@ -32449,7 +34053,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2869, freeVariables: nil, }, Value: float64(0), @@ -32469,14 +34073,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p2871, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -32532,7 +34136,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -32561,7 +34165,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "end", "index", @@ -32587,7 +34191,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1808, + context: p2881, freeVariables: Identifiers{ "end", "index", @@ -32635,7 +34239,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "indexable", }, @@ -32681,7 +34285,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "index", "std", @@ -32786,7 +34390,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "index", }, @@ -32807,7 +34411,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: nil, }, }, @@ -32831,7 +34435,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: nil, }, Value: float64(0), @@ -32851,7 +34455,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "index", }, @@ -32898,7 +34502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "end", "indexable", @@ -33004,7 +34608,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "end", }, @@ -33025,7 +34629,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: nil, }, }, @@ -33049,7 +34653,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "indexable", "std", @@ -33069,7 +34673,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "std", }, @@ -33088,7 +34692,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "std", }, @@ -33134,7 +34738,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1855, + context: p2928, freeVariables: Identifiers{ "indexable", }, @@ -33161,7 +34765,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "end", }, @@ -33208,7 +34812,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "std", "step", @@ -33313,7 +34917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "step", }, @@ -33334,7 +34938,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: nil, }, }, @@ -33358,7 +34962,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: nil, }, Value: float64(1), @@ -33378,7 +34982,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "step", }, @@ -33425,7 +35029,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "indexable", "std", @@ -33445,7 +35049,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "std", }, @@ -33464,7 +35068,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "std", }, @@ -33510,7 +35114,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1886, + context: p2959, freeVariables: Identifiers{ "indexable", }, @@ -33562,7 +35166,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "indexable", "std", @@ -33582,7 +35186,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "std", }, @@ -33601,7 +35205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1813, + context: p2886, freeVariables: Identifiers{ "std", }, @@ -33647,7 +35251,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1898, + context: p2971, freeVariables: Identifiers{ "indexable", }, @@ -33681,7 +35285,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "indexable", "invar", @@ -33703,7 +35307,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33722,7 +35326,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33741,7 +35345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33760,7 +35364,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33779,7 +35383,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33824,7 +35428,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: nil, }, Value: float64(0), @@ -33846,7 +35450,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33865,7 +35469,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33884,7 +35488,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33929,7 +35533,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: nil, }, Value: float64(0), @@ -33952,7 +35556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33971,7 +35575,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -33990,7 +35594,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -34035,7 +35639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: nil, }, Value: float64(0), @@ -34057,7 +35661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", "std", @@ -34162,7 +35766,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: nil, }, Value: "got [%s:%s:%s] but negative index, end, and steps are not supported", @@ -34183,7 +35787,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", }, @@ -34203,7 +35807,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1945, + context: p3018, freeVariables: Identifiers{ "invar", }, @@ -34222,7 +35826,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1945, + context: p3018, freeVariables: Identifiers{ "invar", }, @@ -34266,7 +35870,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1945, + context: p3018, freeVariables: Identifiers{ "invar", }, @@ -34285,7 +35889,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1945, + context: p3018, freeVariables: Identifiers{ "invar", }, @@ -34329,7 +35933,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1945, + context: p3018, freeVariables: Identifiers{ "invar", }, @@ -34348,7 +35952,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1945, + context: p3018, freeVariables: Identifiers{ "invar", }, @@ -34402,7 +36006,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "indexable", "invar", @@ -34509,7 +36113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "step", }, @@ -34530,7 +36134,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: nil, }, Value: float64(0), @@ -34556,7 +36160,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "std", "step", @@ -34661,7 +36265,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: nil, }, Value: "got %s but step must be greater than 0", @@ -34682,7 +36286,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "step", }, @@ -34710,7 +36314,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "indexable", "invar", @@ -34731,7 +36335,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "indexable", "std", @@ -34857,7 +36461,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "indexable", "std", @@ -34877,7 +36481,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "std", }, @@ -34896,7 +36500,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "std", }, @@ -34942,7 +36546,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2009, + context: p3082, freeVariables: Identifiers{ "indexable", }, @@ -34969,7 +36573,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: nil, }, Value: "string", @@ -35104,7 +36708,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "indexable", "std", @@ -35124,7 +36728,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "std", }, @@ -35143,7 +36747,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "std", }, @@ -35189,7 +36793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2031, + context: p3104, freeVariables: Identifiers{ "indexable", }, @@ -35216,7 +36820,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: nil, }, Value: "array", @@ -35245,7 +36849,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "indexable", "std", @@ -35350,7 +36954,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: nil, }, Value: "std.slice accepts a string or an array, but got: %s", @@ -35371,7 +36975,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "indexable", "std", @@ -35391,7 +36995,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "std", }, @@ -35410,7 +37014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "std", }, @@ -35456,7 +37060,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2054, + context: p3127, freeVariables: Identifiers{ "indexable", }, @@ -35490,7 +37094,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "invar", "std", @@ -35513,7 +37117,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2060, + context: p3133, freeVariables: Identifiers{ "build", "invar", @@ -35542,7 +37146,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "build", "cur", @@ -35565,7 +37169,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "cur", "invar", @@ -35585,7 +37189,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "cur", "invar", @@ -35605,7 +37209,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "cur", }, @@ -35627,7 +37231,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "invar", }, @@ -35646,7 +37250,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "invar", }, @@ -35692,7 +37296,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "cur", "invar", @@ -35712,7 +37316,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "cur", }, @@ -35734,7 +37338,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "invar", }, @@ -35753,7 +37357,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "invar", }, @@ -35799,7 +37403,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "slice", }, @@ -35820,7 +37424,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "build", "cur", @@ -35843,7 +37447,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2064, + context: p3137, freeVariables: Identifiers{ "build", }, @@ -35866,7 +37470,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "cur", "invar", @@ -35973,7 +37577,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "invar", }, @@ -35992,7 +37596,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "invar", }, @@ -36036,7 +37640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: nil, }, Value: "string", @@ -36063,7 +37667,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "cur", "invar", @@ -36084,7 +37688,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "slice", }, @@ -36106,7 +37710,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "cur", "invar", @@ -36126,7 +37730,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "invar", }, @@ -36145,7 +37749,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "invar", }, @@ -36189,7 +37793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "cur", }, @@ -36213,7 +37817,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "cur", "invar", @@ -36234,7 +37838,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "slice", }, @@ -36256,7 +37860,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "cur", "invar", @@ -36277,7 +37881,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2131, + context: p3204, freeVariables: Identifiers{ "cur", "invar", @@ -36297,7 +37901,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2131, + context: p3204, freeVariables: Identifiers{ "invar", }, @@ -36316,7 +37920,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2131, + context: p3204, freeVariables: Identifiers{ "invar", }, @@ -36360,7 +37964,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2131, + context: p3204, freeVariables: Identifiers{ "cur", }, @@ -36388,7 +37992,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "cur", "invar", @@ -36408,7 +38012,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "cur", }, @@ -36430,7 +38034,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "invar", }, @@ -36449,7 +38053,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2094, + context: p3167, freeVariables: Identifiers{ "invar", }, @@ -36505,7 +38109,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "build", "invar", @@ -36526,7 +38130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p1804, + context: p2877, freeVariables: Identifiers{ "build", }, @@ -36549,7 +38153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2155, + context: p3228, freeVariables: Identifiers{ "invar", "std", @@ -36654,7 +38258,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2155, + context: p3228, freeVariables: Identifiers{ "invar", }, @@ -36673,7 +38277,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2155, + context: p3228, freeVariables: Identifiers{ "invar", }, @@ -36717,7 +38321,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2155, + context: p3228, freeVariables: nil, }, Value: "string", @@ -36744,7 +38348,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2155, + context: p3228, freeVariables: nil, }, Value: "", @@ -36765,7 +38369,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2155, + context: p3228, freeVariables: nil, }, Elements: nil, @@ -36786,7 +38390,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2155, + context: p3228, freeVariables: Identifiers{ "invar", }, @@ -36805,7 +38409,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2155, + context: p3228, freeVariables: Identifiers{ "invar", }, @@ -36907,7 +38511,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3255, freeVariables: nil, }, }, @@ -36929,7 +38533,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3257, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -37171,7 +38775,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3281, freeVariables: Identifiers{ "base64_table", "i", @@ -37195,7 +38799,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3285, freeVariables: Identifiers{ "base64_table", "i", @@ -37215,7 +38819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3288, freeVariables: Identifiers{ "base64_table", }, @@ -37236,7 +38840,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3291, freeVariables: Identifiers{ "i", }, @@ -37259,7 +38863,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p3294, freeVariables: Identifiers{ "i", }, @@ -37288,7 +38892,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3297, freeVariables: Identifiers{ "std", }, @@ -37307,7 +38911,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3300, freeVariables: Identifiers{ "std", }, @@ -37326,7 +38930,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3303, freeVariables: Identifiers{ "std", }, @@ -37372,7 +38976,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p3308, freeVariables: nil, }, Value: float64(0), @@ -37392,14 +38996,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p3310, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -37455,7 +39059,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -37482,7 +39086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2184, + context: p3316, freeVariables: Identifiers{ "arr", "std", @@ -37503,7 +39107,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2184, + context: p3316, freeVariables: Identifiers{ "std", }, @@ -37522,7 +39126,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2184, + context: p3316, freeVariables: Identifiers{ "std", }, @@ -37568,7 +39172,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2193, + context: p3325, freeVariables: Identifiers{ "arr", "std", @@ -37589,7 +39193,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2193, + context: p3325, freeVariables: Identifiers{ "std", }, @@ -37608,7 +39212,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2193, + context: p3325, freeVariables: Identifiers{ "std", }, @@ -37654,7 +39258,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2202, + context: p3334, freeVariables: Identifiers{ "std", "x", @@ -37767,7 +39371,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2214, + context: p3346, freeVariables: Identifiers{ "v", }, @@ -37788,7 +39392,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2214, + context: p3346, freeVariables: Identifiers{ "x", }, @@ -37816,7 +39420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2202, + context: p3334, freeVariables: Identifiers{ "arr", }, @@ -37896,7 +39500,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3356, freeVariables: nil, }, }, @@ -37918,7 +39522,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3358, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -38160,7 +39764,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3382, freeVariables: Identifiers{ "base64_table", "i", @@ -38184,7 +39788,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3386, freeVariables: Identifiers{ "base64_table", "i", @@ -38204,7 +39808,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3389, freeVariables: Identifiers{ "base64_table", }, @@ -38225,7 +39829,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3392, freeVariables: Identifiers{ "i", }, @@ -38248,7 +39852,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p3395, freeVariables: Identifiers{ "i", }, @@ -38277,7 +39881,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3398, freeVariables: Identifiers{ "std", }, @@ -38296,7 +39900,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3401, freeVariables: Identifiers{ "std", }, @@ -38315,7 +39919,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3404, freeVariables: Identifiers{ "std", }, @@ -38361,7 +39965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p3409, freeVariables: nil, }, Value: float64(0), @@ -38381,14 +39985,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p3411, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -38444,7 +40048,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -38471,7 +40075,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "b", @@ -38492,7 +40096,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "b", @@ -38598,7 +40202,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "std", @@ -38618,7 +40222,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -38637,7 +40241,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -38683,7 +40287,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2247, + context: p3438, freeVariables: Identifiers{ "a", }, @@ -38710,7 +40314,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: nil, }, Value: "number", @@ -38823,7 +40427,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "b", "std", @@ -38843,7 +40447,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -38862,7 +40466,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -38908,7 +40512,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2267, + context: p3458, freeVariables: Identifiers{ "b", }, @@ -38935,7 +40539,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: nil, }, Value: "number", @@ -38963,7 +40567,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "b", @@ -38984,7 +40588,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39003,7 +40607,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39049,7 +40653,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2279, + context: p3470, freeVariables: Identifiers{ "a", }, @@ -39070,7 +40674,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2279, + context: p3470, freeVariables: Identifiers{ "b", }, @@ -39097,7 +40701,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "b", @@ -39203,7 +40807,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "std", @@ -39223,7 +40827,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39242,7 +40846,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39288,7 +40892,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2302, + context: p3493, freeVariables: Identifiers{ "a", }, @@ -39315,7 +40919,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: nil, }, Value: "string", @@ -39342,7 +40946,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "b", @@ -39363,7 +40967,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39382,7 +40986,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39428,7 +41032,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2314, + context: p3505, freeVariables: Identifiers{ "a", }, @@ -39449,7 +41053,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2314, + context: p3505, freeVariables: Identifiers{ "b", }, @@ -39476,7 +41080,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "b", @@ -39497,7 +41101,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "b", @@ -39518,7 +41122,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "b", @@ -39539,7 +41143,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "std", @@ -39559,7 +41163,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "std", @@ -39579,7 +41183,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: nil, }, Value: "Operator % cannot be used on types ", @@ -39601,7 +41205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "a", "std", @@ -39621,7 +41225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39640,7 +41244,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39686,7 +41290,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2338, + context: p3529, freeVariables: Identifiers{ "a", }, @@ -39715,7 +41319,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: nil, }, Value: " and ", @@ -39738,7 +41342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "b", "std", @@ -39758,7 +41362,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39777,7 +41381,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: Identifiers{ "std", }, @@ -39823,7 +41427,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2350, + context: p3541, freeVariables: Identifiers{ "b", }, @@ -39852,7 +41456,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2226, + context: p3417, freeVariables: nil, }, Value: ".", @@ -39924,7 +41528,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3548, freeVariables: nil, }, }, @@ -39946,7 +41550,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3550, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -40188,7 +41792,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3574, freeVariables: Identifiers{ "base64_table", "i", @@ -40212,7 +41816,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3578, freeVariables: Identifiers{ "base64_table", "i", @@ -40232,7 +41836,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3581, freeVariables: Identifiers{ "base64_table", }, @@ -40253,7 +41857,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3584, freeVariables: Identifiers{ "i", }, @@ -40276,7 +41880,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p3587, freeVariables: Identifiers{ "i", }, @@ -40305,7 +41909,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3590, freeVariables: Identifiers{ "std", }, @@ -40324,7 +41928,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3593, freeVariables: Identifiers{ "std", }, @@ -40343,7 +41947,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3596, freeVariables: Identifiers{ "std", }, @@ -40389,7 +41993,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p3601, freeVariables: nil, }, Value: float64(0), @@ -40409,14 +42013,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p3603, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -40472,7 +42076,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -40499,7 +42103,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "arr", "func", @@ -40626,7 +42230,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "func", "std", @@ -40646,7 +42250,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -40665,7 +42269,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -40711,7 +42315,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2380, + context: p3630, freeVariables: Identifiers{ "func", }, @@ -40738,7 +42342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: nil, }, Value: "function", @@ -40766,7 +42370,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "func", "std", @@ -40786,7 +42390,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "func", "std", @@ -40806,7 +42410,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: nil, }, Value: "std.map first param must be function, got ", @@ -40828,7 +42432,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "func", "std", @@ -40848,7 +42452,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -40867,7 +42471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -40913,7 +42517,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2397, + context: p3647, freeVariables: Identifiers{ "func", }, @@ -40942,7 +42546,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "arr", "func", @@ -40963,7 +42567,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "arr", "std", @@ -41089,7 +42693,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "arr", "std", @@ -41109,7 +42713,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -41128,7 +42732,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -41174,7 +42778,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2422, + context: p3672, freeVariables: Identifiers{ "arr", }, @@ -41201,7 +42805,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: nil, }, Value: "array", @@ -41336,7 +42940,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "arr", "std", @@ -41356,7 +42960,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -41375,7 +42979,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -41421,7 +43025,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2444, + context: p3694, freeVariables: Identifiers{ "arr", }, @@ -41448,7 +43052,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: nil, }, Value: "string", @@ -41477,7 +43081,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "arr", "std", @@ -41497,7 +43101,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "arr", "std", @@ -41517,7 +43121,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: nil, }, Value: "std.map second param must be array / string, got ", @@ -41539,7 +43143,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "arr", "std", @@ -41559,7 +43163,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -41578,7 +43182,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -41624,7 +43228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2461, + context: p3711, freeVariables: Identifiers{ "arr", }, @@ -41653,7 +43257,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "arr", "func", @@ -41674,7 +43278,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -41693,7 +43297,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2359, + context: p3609, freeVariables: Identifiers{ "std", }, @@ -41739,7 +43343,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2472, + context: p3722, freeVariables: Identifiers{ "arr", "std", @@ -41759,7 +43363,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2472, + context: p3722, freeVariables: Identifiers{ "std", }, @@ -41778,7 +43382,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2472, + context: p3722, freeVariables: Identifiers{ "std", }, @@ -41824,7 +43428,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2481, + context: p3731, freeVariables: Identifiers{ "arr", }, @@ -41851,7 +43455,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2472, + context: p3722, freeVariables: Identifiers{ "arr", "func", @@ -41878,7 +43482,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2487, + context: p3737, freeVariables: Identifiers{ "arr", "func", @@ -41899,7 +43503,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2487, + context: p3737, freeVariables: Identifiers{ "func", }, @@ -41922,7 +43526,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2493, + context: p3743, freeVariables: Identifiers{ "arr", "i", @@ -41942,7 +43546,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2493, + context: p3743, freeVariables: Identifiers{ "arr", }, @@ -41963,7 +43567,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2493, + context: p3743, freeVariables: Identifiers{ "i", }, @@ -42048,7 +43652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3753, freeVariables: nil, }, }, @@ -42070,7 +43674,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3755, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -42312,7 +43916,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3779, freeVariables: Identifiers{ "base64_table", "i", @@ -42336,7 +43940,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3783, freeVariables: Identifiers{ "base64_table", "i", @@ -42356,7 +43960,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3786, freeVariables: Identifiers{ "base64_table", }, @@ -42377,7 +43981,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3789, freeVariables: Identifiers{ "i", }, @@ -42400,7 +44004,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p3792, freeVariables: Identifiers{ "i", }, @@ -42429,7 +44033,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3795, freeVariables: Identifiers{ "std", }, @@ -42448,7 +44052,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3798, freeVariables: Identifiers{ "std", }, @@ -42467,7 +44071,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3801, freeVariables: Identifiers{ "std", }, @@ -42513,7 +44117,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p3806, freeVariables: nil, }, Value: float64(0), @@ -42533,14 +44137,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p3808, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -42596,7 +44200,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -42623,7 +44227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "arr", "func", @@ -42750,7 +44354,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "func", "std", @@ -42770,7 +44374,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -42789,7 +44393,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -42835,7 +44439,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2526, + context: p3835, freeVariables: Identifiers{ "func", }, @@ -42862,7 +44466,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: nil, }, Value: "function", @@ -42890,7 +44494,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "func", "std", @@ -42910,7 +44514,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "func", "std", @@ -42930,7 +44534,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: nil, }, Value: "std.mapWithIndex first param must be function, got ", @@ -42952,7 +44556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "func", "std", @@ -42972,7 +44576,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -42991,7 +44595,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -43037,7 +44641,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2543, + context: p3852, freeVariables: Identifiers{ "func", }, @@ -43066,7 +44670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "arr", "func", @@ -43087,7 +44691,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "arr", "std", @@ -43213,7 +44817,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "arr", "std", @@ -43233,7 +44837,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -43252,7 +44856,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -43298,7 +44902,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2568, + context: p3877, freeVariables: Identifiers{ "arr", }, @@ -43325,7 +44929,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: nil, }, Value: "array", @@ -43460,7 +45064,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "arr", "std", @@ -43480,7 +45084,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -43499,7 +45103,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -43545,7 +45149,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2590, + context: p3899, freeVariables: Identifiers{ "arr", }, @@ -43572,7 +45176,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: nil, }, Value: "string", @@ -43601,7 +45205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "arr", "std", @@ -43621,7 +45225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "arr", "std", @@ -43641,7 +45245,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: nil, }, Value: "std.mapWithIndex second param must be array, got ", @@ -43663,7 +45267,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "arr", "std", @@ -43683,7 +45287,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -43702,7 +45306,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -43748,7 +45352,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2607, + context: p3916, freeVariables: Identifiers{ "arr", }, @@ -43777,7 +45381,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "arr", "func", @@ -43798,7 +45402,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -43817,7 +45421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2505, + context: p3814, freeVariables: Identifiers{ "std", }, @@ -43863,7 +45467,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2618, + context: p3927, freeVariables: Identifiers{ "arr", "std", @@ -43883,7 +45487,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2618, + context: p3927, freeVariables: Identifiers{ "std", }, @@ -43902,7 +45506,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2618, + context: p3927, freeVariables: Identifiers{ "std", }, @@ -43948,7 +45552,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2627, + context: p3936, freeVariables: Identifiers{ "arr", }, @@ -43975,7 +45579,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2618, + context: p3927, freeVariables: Identifiers{ "arr", "func", @@ -44002,7 +45606,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2633, + context: p3942, freeVariables: Identifiers{ "arr", "func", @@ -44023,7 +45627,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2633, + context: p3942, freeVariables: Identifiers{ "func", }, @@ -44046,7 +45650,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2639, + context: p3948, freeVariables: Identifiers{ "i", }, @@ -44067,7 +45671,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2639, + context: p3948, freeVariables: Identifiers{ "arr", "i", @@ -44087,7 +45691,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2639, + context: p3948, freeVariables: Identifiers{ "arr", }, @@ -44108,7 +45712,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2639, + context: p3948, freeVariables: Identifiers{ "i", }, @@ -44193,7 +45797,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3960, freeVariables: nil, }, }, @@ -44215,7 +45819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3962, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -44457,7 +46061,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3986, freeVariables: Identifiers{ "base64_table", "i", @@ -44481,7 +46085,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3990, freeVariables: Identifiers{ "base64_table", "i", @@ -44501,7 +46105,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3993, freeVariables: Identifiers{ "base64_table", }, @@ -44522,7 +46126,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p3996, freeVariables: Identifiers{ "i", }, @@ -44545,7 +46149,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p3999, freeVariables: Identifiers{ "i", }, @@ -44574,7 +46178,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4002, freeVariables: Identifiers{ "std", }, @@ -44593,7 +46197,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4005, freeVariables: Identifiers{ "std", }, @@ -44612,7 +46216,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4008, freeVariables: Identifiers{ "std", }, @@ -44658,7 +46262,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4013, freeVariables: nil, }, Value: float64(0), @@ -44678,14 +46282,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4015, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -44741,7 +46345,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -44768,7 +46372,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "func", "obj", @@ -44895,7 +46499,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "func", "std", @@ -44915,7 +46519,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -44934,7 +46538,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -44980,7 +46584,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2674, + context: p4042, freeVariables: Identifiers{ "func", }, @@ -45007,7 +46611,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: nil, }, Value: "function", @@ -45035,7 +46639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "func", "std", @@ -45055,7 +46659,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "func", "std", @@ -45075,7 +46679,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: nil, }, Value: "std.mapWithKey first param must be function, got ", @@ -45097,7 +46701,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "func", "std", @@ -45117,7 +46721,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -45136,7 +46740,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -45182,7 +46786,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2691, + context: p4059, freeVariables: Identifiers{ "func", }, @@ -45211,7 +46815,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "func", "obj", @@ -45338,7 +46942,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "obj", "std", @@ -45358,7 +46962,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -45377,7 +46981,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -45423,7 +47027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2714, + context: p4082, freeVariables: Identifiers{ "obj", }, @@ -45450,7 +47054,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: nil, }, Value: "object", @@ -45478,7 +47082,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "obj", "std", @@ -45498,7 +47102,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "obj", "std", @@ -45518,7 +47122,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: nil, }, Value: "std.mapWithKey second param must be object, got ", @@ -45540,7 +47144,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "obj", "std", @@ -45560,7 +47164,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -45579,7 +47183,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -45625,7 +47229,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2731, + context: p4099, freeVariables: Identifiers{ "obj", }, @@ -45875,7 +47479,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "func", "k", @@ -45900,7 +47504,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "k", }, @@ -45921,7 +47525,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2761, + context: p4129, freeVariables: Identifiers{ "func", "k", @@ -45942,7 +47546,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2761, + context: p4129, freeVariables: Identifiers{ "func", }, @@ -45965,7 +47569,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2767, + context: p4135, freeVariables: Identifiers{ "k", }, @@ -45986,7 +47590,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2767, + context: p4135, freeVariables: Identifiers{ "k", "obj", @@ -46006,7 +47610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2767, + context: p4135, freeVariables: Identifiers{ "obj", }, @@ -46027,7 +47631,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2767, + context: p4135, freeVariables: Identifiers{ "k", }, @@ -46064,7 +47668,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "obj", "std", @@ -46084,7 +47688,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -46103,7 +47707,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2653, + context: p4021, freeVariables: Identifiers{ "std", }, @@ -46149,7 +47753,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2784, + context: p4152, freeVariables: Identifiers{ "obj", }, @@ -46237,7 +47841,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4158, freeVariables: nil, }, }, @@ -46259,7 +47863,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4160, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -46501,7 +48105,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4184, freeVariables: Identifiers{ "base64_table", "i", @@ -46525,7 +48129,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4188, freeVariables: Identifiers{ "base64_table", "i", @@ -46545,7 +48149,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4191, freeVariables: Identifiers{ "base64_table", }, @@ -46566,7 +48170,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4194, freeVariables: Identifiers{ "i", }, @@ -46589,7 +48193,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p4197, freeVariables: Identifiers{ "i", }, @@ -46618,7 +48222,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4200, freeVariables: Identifiers{ "std", }, @@ -46637,7 +48241,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4203, freeVariables: Identifiers{ "std", }, @@ -46656,7 +48260,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4206, freeVariables: Identifiers{ "std", }, @@ -46702,7 +48306,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4211, freeVariables: nil, }, Value: float64(0), @@ -46722,14 +48326,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4213, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -46785,7 +48389,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -46812,7 +48416,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "sep", @@ -46836,7 +48440,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2796, + context: p4223, freeVariables: Identifiers{ "aux", "sep", @@ -46867,7 +48471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "aux", @@ -46892,7 +48496,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "i", @@ -46913,7 +48517,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "i", }, @@ -46935,7 +48539,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "std", @@ -46955,7 +48559,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "std", }, @@ -46974,7 +48578,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "std", }, @@ -47020,7 +48624,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2815, + context: p4242, freeVariables: Identifiers{ "arr", }, @@ -47048,7 +48652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "running", }, @@ -47069,7 +48673,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "aux", @@ -47180,7 +48784,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "i", @@ -47200,7 +48804,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", }, @@ -47221,7 +48825,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "i", }, @@ -47244,7 +48848,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: nil, }, }, @@ -47268,7 +48872,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "aux", @@ -47291,7 +48895,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "aux", }, @@ -47314,7 +48918,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2842, + context: p4269, freeVariables: Identifiers{ "arr", }, @@ -47335,7 +48939,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2842, + context: p4269, freeVariables: Identifiers{ "i", }, @@ -47354,7 +48958,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2842, + context: p4269, freeVariables: Identifiers{ "i", }, @@ -47376,7 +48980,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2842, + context: p4269, freeVariables: nil, }, Value: float64(1), @@ -47397,7 +49001,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2842, + context: p4269, freeVariables: Identifiers{ "first", }, @@ -47418,7 +49022,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2842, + context: p4269, freeVariables: Identifiers{ "running", }, @@ -47445,7 +49049,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "aux", @@ -47580,7 +49184,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "i", @@ -47601,7 +49205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "std", }, @@ -47620,7 +49224,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "std", }, @@ -47666,7 +49270,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2874, + context: p4301, freeVariables: Identifiers{ "arr", "i", @@ -47686,7 +49290,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2874, + context: p4301, freeVariables: Identifiers{ "arr", }, @@ -47707,7 +49311,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2874, + context: p4301, freeVariables: Identifiers{ "i", }, @@ -47736,7 +49340,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "sep", "std", @@ -47756,7 +49360,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "std", }, @@ -47775,7 +49379,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "std", }, @@ -47821,7 +49425,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2889, + context: p4316, freeVariables: Identifiers{ "sep", }, @@ -47855,7 +49459,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "i", @@ -47964,7 +49568,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: nil, }, Value: "expected %s but arr[%d] was %s ", @@ -47985,7 +49589,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "i", @@ -48008,7 +49612,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2906, + context: p4333, freeVariables: Identifiers{ "sep", "std", @@ -48028,7 +49632,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2906, + context: p4333, freeVariables: Identifiers{ "std", }, @@ -48047,7 +49651,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2906, + context: p4333, freeVariables: Identifiers{ "std", }, @@ -48093,7 +49697,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2915, + context: p4342, freeVariables: Identifiers{ "sep", }, @@ -48120,7 +49724,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2906, + context: p4333, freeVariables: Identifiers{ "i", }, @@ -48141,7 +49745,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2906, + context: p4333, freeVariables: Identifiers{ "arr", "i", @@ -48162,7 +49766,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2906, + context: p4333, freeVariables: Identifiers{ "std", }, @@ -48181,7 +49785,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2906, + context: p4333, freeVariables: Identifiers{ "std", }, @@ -48227,7 +49831,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2928, + context: p4355, freeVariables: Identifiers{ "arr", "i", @@ -48247,7 +49851,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2928, + context: p4355, freeVariables: Identifiers{ "arr", }, @@ -48268,7 +49872,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2928, + context: p4355, freeVariables: Identifiers{ "i", }, @@ -48307,7 +49911,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "aux", @@ -48331,7 +49935,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "first", }, @@ -48352,7 +49956,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "aux", @@ -48374,7 +49978,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "aux", }, @@ -48397,7 +50001,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: Identifiers{ "arr", }, @@ -48418,7 +50022,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: Identifiers{ "i", }, @@ -48437,7 +50041,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: Identifiers{ "i", }, @@ -48459,7 +50063,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: nil, }, Value: float64(1), @@ -48480,7 +50084,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: nil, }, Value: false, @@ -48499,7 +50103,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: Identifiers{ "arr", "i", @@ -48520,7 +50124,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: Identifiers{ "running", }, @@ -48542,7 +50146,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: Identifiers{ "arr", "i", @@ -48562,7 +50166,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: Identifiers{ "arr", }, @@ -48583,7 +50187,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2944, + context: p4371, freeVariables: Identifiers{ "i", }, @@ -48613,7 +50217,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "arr", "aux", @@ -48636,7 +50240,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2800, + context: p4227, freeVariables: Identifiers{ "aux", }, @@ -48659,7 +50263,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "arr", }, @@ -48680,7 +50284,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "i", }, @@ -48699,7 +50303,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "i", }, @@ -48721,7 +50325,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: nil, }, Value: float64(1), @@ -48742,7 +50346,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: nil, }, Value: false, @@ -48761,7 +50365,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "arr", "i", @@ -48783,7 +50387,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "running", "sep", @@ -48803,7 +50407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "running", }, @@ -48825,7 +50429,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "sep", }, @@ -48848,7 +50452,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "arr", "i", @@ -48868,7 +50472,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "arr", }, @@ -48889,7 +50493,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2968, + context: p4395, freeVariables: Identifiers{ "i", }, @@ -48927,7 +50531,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "aux", @@ -49055,7 +50659,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "std", @@ -49075,7 +50679,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -49094,7 +50698,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -49140,7 +50744,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3011, + context: p4438, freeVariables: Identifiers{ "arr", }, @@ -49167,7 +50771,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: nil, }, Value: "array", @@ -49195,7 +50799,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "std", @@ -49215,7 +50819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "std", @@ -49235,7 +50839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: nil, }, Value: "join second parameter should be array, got ", @@ -49257,7 +50861,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "std", @@ -49277,7 +50881,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -49296,7 +50900,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -49342,7 +50946,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3028, + context: p4455, freeVariables: Identifiers{ "arr", }, @@ -49371,7 +50975,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "aux", @@ -49478,7 +51082,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "sep", "std", @@ -49498,7 +51102,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -49517,7 +51121,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -49563,7 +51167,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3049, + context: p4476, freeVariables: Identifiers{ "sep", }, @@ -49590,7 +51194,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: nil, }, Value: "string", @@ -49617,7 +51221,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "aux", @@ -49637,7 +51241,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "aux", }, @@ -49660,7 +51264,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3058, + context: p4485, freeVariables: Identifiers{ "arr", }, @@ -49681,7 +51285,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3058, + context: p4485, freeVariables: nil, }, Value: float64(0), @@ -49701,7 +51305,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3058, + context: p4485, freeVariables: nil, }, Value: true, @@ -49720,7 +51324,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3058, + context: p4485, freeVariables: nil, }, Value: "", @@ -49747,7 +51351,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "aux", @@ -49854,7 +51458,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "sep", "std", @@ -49874,7 +51478,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -49893,7 +51497,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -49939,7 +51543,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3082, + context: p4509, freeVariables: Identifiers{ "sep", }, @@ -49966,7 +51570,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: nil, }, Value: "array", @@ -49993,7 +51597,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "arr", "aux", @@ -50013,7 +51617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "aux", }, @@ -50036,7 +51640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3091, + context: p4518, freeVariables: Identifiers{ "arr", }, @@ -50057,7 +51661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3091, + context: p4518, freeVariables: nil, }, Value: float64(0), @@ -50077,7 +51681,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3091, + context: p4518, freeVariables: nil, }, Value: true, @@ -50096,7 +51700,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3091, + context: p4518, freeVariables: nil, }, Elements: nil, @@ -50122,7 +51726,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "sep", "std", @@ -50142,7 +51746,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "sep", "std", @@ -50162,7 +51766,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: nil, }, Value: "join first parameter should be string or array, got ", @@ -50184,7 +51788,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "sep", "std", @@ -50204,7 +51808,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -50223,7 +51827,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p2792, + context: p4219, freeVariables: Identifiers{ "std", }, @@ -50269,7 +51873,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3110, + context: p4537, freeVariables: Identifiers{ "sep", }, @@ -50349,7 +51953,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4543, freeVariables: nil, }, }, @@ -50371,7 +51975,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4545, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -50613,7 +52217,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4569, freeVariables: Identifiers{ "base64_table", "i", @@ -50637,7 +52241,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4573, freeVariables: Identifiers{ "base64_table", "i", @@ -50657,7 +52261,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4576, freeVariables: Identifiers{ "base64_table", }, @@ -50678,7 +52282,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4579, freeVariables: Identifiers{ "i", }, @@ -50701,7 +52305,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p4582, freeVariables: Identifiers{ "i", }, @@ -50730,7 +52334,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4585, freeVariables: Identifiers{ "std", }, @@ -50749,7 +52353,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4588, freeVariables: Identifiers{ "std", }, @@ -50768,7 +52372,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4591, freeVariables: Identifiers{ "std", }, @@ -50814,7 +52418,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4596, freeVariables: nil, }, Value: float64(0), @@ -50834,14 +52438,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4598, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -50897,7 +52501,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -50923,7 +52527,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3118, + context: p4604, freeVariables: Identifiers{ "arr", "std", @@ -50943,7 +52547,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3118, + context: p4604, freeVariables: Identifiers{ "std", }, @@ -50962,7 +52566,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3118, + context: p4604, freeVariables: Identifiers{ "std", }, @@ -51008,7 +52612,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3127, + context: p4613, freeVariables: nil, }, Value: "\n", @@ -51029,7 +52633,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3127, + context: p4613, freeVariables: Identifiers{ "arr", }, @@ -51048,7 +52652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3127, + context: p4613, freeVariables: Identifiers{ "arr", }, @@ -51070,7 +52674,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3127, + context: p4613, freeVariables: nil, }, Elements: Nodes{ @@ -51088,7 +52692,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3135, + context: p4621, freeVariables: nil, }, Value: "", @@ -51166,7 +52770,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4626, freeVariables: nil, }, }, @@ -51188,7 +52792,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4628, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -51430,7 +53034,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4652, freeVariables: Identifiers{ "base64_table", "i", @@ -51454,7 +53058,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4656, freeVariables: Identifiers{ "base64_table", "i", @@ -51474,7 +53078,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4659, freeVariables: Identifiers{ "base64_table", }, @@ -51495,7 +53099,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4662, freeVariables: Identifiers{ "i", }, @@ -51518,7 +53122,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p4665, freeVariables: Identifiers{ "i", }, @@ -51547,7 +53151,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4668, freeVariables: Identifiers{ "std", }, @@ -51566,7 +53170,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4671, freeVariables: Identifiers{ "std", }, @@ -51585,7 +53189,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4674, freeVariables: Identifiers{ "std", }, @@ -51631,7 +53235,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4679, freeVariables: nil, }, Value: float64(0), @@ -51651,14 +53255,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4681, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -51714,7 +53318,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -51740,7 +53344,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "arr", "std", @@ -51760,7 +53364,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "arr", "std", @@ -51780,7 +53384,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "std", }, @@ -51799,7 +53403,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "std", }, @@ -51845,7 +53449,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3153, + context: p4698, freeVariables: Identifiers{ "arr", }, @@ -51872,7 +53476,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "arr", }, @@ -51893,7 +53497,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "arr", "std", @@ -51913,7 +53517,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "arr", "std", @@ -51933,7 +53537,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "std", }, @@ -51952,7 +53556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "std", }, @@ -51998,7 +53602,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3168, + context: p4713, freeVariables: Identifiers{ "arr", }, @@ -52025,7 +53629,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "arr", "std", @@ -52045,7 +53649,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "std", }, @@ -52064,7 +53668,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "std", }, @@ -52110,7 +53714,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3179, + context: p4724, freeVariables: nil, }, Value: "", @@ -52263,7 +53867,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3195, + context: p4740, freeVariables: Identifiers{ "std", "x", @@ -52283,7 +53887,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3195, + context: p4740, freeVariables: Identifiers{ "std", }, @@ -52302,7 +53906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3195, + context: p4740, freeVariables: Identifiers{ "std", }, @@ -52348,7 +53952,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3204, + context: p4749, freeVariables: Identifiers{ "x", }, @@ -52379,7 +53983,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3179, + context: p4724, freeVariables: Identifiers{ "arr", }, @@ -52412,7 +54016,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "arr", "std", @@ -52517,7 +54121,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: nil, }, Value: "Expected string or array, got %s", @@ -52538,7 +54142,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "arr", "std", @@ -52558,7 +54162,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "std", }, @@ -52577,7 +54181,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3142, + context: p4687, freeVariables: Identifiers{ "std", }, @@ -52623,7 +54227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3228, + context: p4773, freeVariables: Identifiers{ "arr", }, @@ -52706,7 +54310,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4779, freeVariables: nil, }, }, @@ -52728,7 +54332,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4781, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -52970,7 +54574,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4805, freeVariables: Identifiers{ "base64_table", "i", @@ -52994,7 +54598,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4809, freeVariables: Identifiers{ "base64_table", "i", @@ -53014,7 +54618,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4812, freeVariables: Identifiers{ "base64_table", }, @@ -53035,7 +54639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4815, freeVariables: Identifiers{ "i", }, @@ -53058,7 +54662,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p4818, freeVariables: Identifiers{ "i", }, @@ -53087,7 +54691,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4821, freeVariables: Identifiers{ "std", }, @@ -53106,7 +54710,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4824, freeVariables: Identifiers{ "std", }, @@ -53125,7 +54729,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p4827, freeVariables: Identifiers{ "std", }, @@ -53171,7 +54775,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4832, freeVariables: nil, }, Value: float64(0), @@ -53191,14 +54795,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p4834, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -53254,7 +54858,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -53281,7 +54885,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", "str", @@ -53305,7 +54909,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3240, + context: p4844, freeVariables: Identifiers{ "std", }, @@ -53332,7 +54936,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "i", "std", @@ -53353,7 +54957,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "i", "std", @@ -53374,7 +54978,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "i", }, @@ -53396,7 +55000,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "std", "str", @@ -53416,7 +55020,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "std", }, @@ -53435,7 +55039,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "std", }, @@ -53481,7 +55085,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3259, + context: p4863, freeVariables: Identifiers{ "str", }, @@ -53509,7 +55113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: nil, }, Expr: &LiteralString{ @@ -53526,7 +55130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: nil, }, Value: "Truncated format code.", @@ -53548,7 +55152,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "i", "std", @@ -53572,7 +55176,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3267, + context: p4871, freeVariables: Identifiers{ "i", "str", @@ -53592,7 +55196,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3267, + context: p4871, freeVariables: Identifiers{ "str", }, @@ -53613,7 +55217,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3267, + context: p4871, freeVariables: Identifiers{ "i", }, @@ -53639,7 +55243,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "c", "i", @@ -53746,7 +55350,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "c", }, @@ -53767,7 +55371,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: nil, }, Value: "(", @@ -53794,7 +55398,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "i", "std", @@ -53818,7 +55422,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3290, + context: p4894, freeVariables: Identifiers{ "consume", "std", @@ -53847,7 +55451,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "consume", "j", @@ -53870,7 +55474,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "j", "std", @@ -53891,7 +55495,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "j", }, @@ -53913,7 +55517,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "std", "str", @@ -53933,7 +55537,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "std", }, @@ -53952,7 +55556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "std", }, @@ -53998,7 +55602,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3309, + context: p4913, freeVariables: Identifiers{ "str", }, @@ -54026,7 +55630,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: nil, }, Expr: &LiteralString{ @@ -54043,7 +55647,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: nil, }, Value: "Truncated format code.", @@ -54065,7 +55669,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "consume", "j", @@ -54091,7 +55695,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3317, + context: p4921, freeVariables: Identifiers{ "j", "str", @@ -54111,7 +55715,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3317, + context: p4921, freeVariables: Identifiers{ "str", }, @@ -54132,7 +55736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3317, + context: p4921, freeVariables: Identifiers{ "j", }, @@ -54158,7 +55762,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "c", "consume", @@ -54288,7 +55892,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "c", }, @@ -54309,7 +55913,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: nil, }, Value: ")", @@ -54337,7 +55941,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "c", "consume", @@ -54360,7 +55964,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "consume", }, @@ -54383,7 +55987,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3344, + context: p4948, freeVariables: Identifiers{ "str", }, @@ -54404,7 +56008,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3344, + context: p4948, freeVariables: Identifiers{ "j", }, @@ -54423,7 +56027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3344, + context: p4948, freeVariables: Identifiers{ "j", }, @@ -54445,7 +56049,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3344, + context: p4948, freeVariables: nil, }, Value: float64(1), @@ -54466,7 +56070,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3344, + context: p4948, freeVariables: Identifiers{ "c", "v", @@ -54486,7 +56090,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3344, + context: p4948, freeVariables: Identifiers{ "v", }, @@ -54508,7 +56112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3344, + context: p4948, freeVariables: Identifiers{ "c", }, @@ -54536,7 +56140,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3294, + context: p4898, freeVariables: Identifiers{ "j", "v", @@ -54581,7 +56185,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3362, + context: p4966, freeVariables: Identifiers{ "j", }, @@ -54600,7 +56204,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3362, + context: p4966, freeVariables: Identifiers{ "j", }, @@ -54622,7 +56226,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3362, + context: p4966, freeVariables: nil, }, Value: float64(1), @@ -54668,7 +56272,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3362, + context: p4966, freeVariables: Identifiers{ "v", }, @@ -54700,7 +56304,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "consume", "i", @@ -54721,7 +56325,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "consume", }, @@ -54744,7 +56348,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3376, + context: p4980, freeVariables: Identifiers{ "str", }, @@ -54765,7 +56369,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3376, + context: p4980, freeVariables: Identifiers{ "i", }, @@ -54784,7 +56388,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3376, + context: p4980, freeVariables: Identifiers{ "i", }, @@ -54806,7 +56410,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3376, + context: p4980, freeVariables: nil, }, Value: float64(1), @@ -54827,7 +56431,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3376, + context: p4980, freeVariables: nil, }, Value: "", @@ -54855,7 +56459,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3244, + context: p4848, freeVariables: Identifiers{ "i", }, @@ -54899,7 +56503,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3389, + context: p4993, freeVariables: Identifiers{ "i", }, @@ -54945,7 +56549,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3389, + context: p4993, freeVariables: nil, }, }, @@ -54974,7 +56578,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", "str", @@ -54999,7 +56603,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3397, + context: p5001, freeVariables: Identifiers{ "std", }, @@ -55026,7 +56630,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3401, + context: p5005, freeVariables: Identifiers{ "i", "std", @@ -55050,7 +56654,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3405, + context: p5009, freeVariables: Identifiers{ "consume", "std", @@ -55079,7 +56683,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", "j", @@ -55102,7 +56706,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "j", "std", @@ -55123,7 +56727,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "j", }, @@ -55145,7 +56749,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "std", "str", @@ -55165,7 +56769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "std", }, @@ -55184,7 +56788,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "std", }, @@ -55230,7 +56834,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3424, + context: p5028, freeVariables: Identifiers{ "str", }, @@ -55258,7 +56862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: nil, }, Expr: &LiteralString{ @@ -55275,7 +56879,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: nil, }, Value: "Truncated format code.", @@ -55297,7 +56901,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", "j", @@ -55323,7 +56927,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3432, + context: p5036, freeVariables: Identifiers{ "j", "str", @@ -55343,7 +56947,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3432, + context: p5036, freeVariables: Identifiers{ "str", }, @@ -55364,7 +56968,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3432, + context: p5036, freeVariables: Identifiers{ "j", }, @@ -55390,7 +56994,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", "consume", @@ -55499,7 +57103,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", }, @@ -55520,7 +57124,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: nil, }, Value: "#", @@ -55547,7 +57151,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", "j", @@ -55569,7 +57173,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", }, @@ -55592,7 +57196,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3457, + context: p5061, freeVariables: Identifiers{ "str", }, @@ -55613,7 +57217,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3457, + context: p5061, freeVariables: Identifiers{ "j", }, @@ -55632,7 +57236,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3457, + context: p5061, freeVariables: Identifiers{ "j", }, @@ -55654,7 +57258,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3457, + context: p5061, freeVariables: nil, }, Value: float64(1), @@ -55675,7 +57279,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3457, + context: p5061, freeVariables: Identifiers{ "v", }, @@ -55694,7 +57298,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3457, + context: p5061, freeVariables: Identifiers{ "v", }, @@ -55716,7 +57320,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3457, + context: p5061, freeVariables: nil, }, Asserts: nil, @@ -55758,7 +57362,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3472, + context: p5076, freeVariables: nil, }, Value: true, @@ -55788,7 +57392,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", "consume", @@ -55897,7 +57501,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", }, @@ -55918,7 +57522,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: nil, }, Value: "0", @@ -55945,7 +57549,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", "j", @@ -55967,7 +57571,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", }, @@ -55990,7 +57594,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3492, + context: p5096, freeVariables: Identifiers{ "str", }, @@ -56011,7 +57615,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3492, + context: p5096, freeVariables: Identifiers{ "j", }, @@ -56030,7 +57634,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3492, + context: p5096, freeVariables: Identifiers{ "j", }, @@ -56052,7 +57656,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3492, + context: p5096, freeVariables: nil, }, Value: float64(1), @@ -56073,7 +57677,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3492, + context: p5096, freeVariables: Identifiers{ "v", }, @@ -56092,7 +57696,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3492, + context: p5096, freeVariables: Identifiers{ "v", }, @@ -56114,7 +57718,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3492, + context: p5096, freeVariables: nil, }, Asserts: nil, @@ -56156,7 +57760,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3507, + context: p5111, freeVariables: nil, }, Value: true, @@ -56186,7 +57790,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", "consume", @@ -56295,7 +57899,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", }, @@ -56316,7 +57920,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: nil, }, Value: "-", @@ -56343,7 +57947,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", "j", @@ -56365,7 +57969,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", }, @@ -56388,7 +57992,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3527, + context: p5131, freeVariables: Identifiers{ "str", }, @@ -56409,7 +58013,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3527, + context: p5131, freeVariables: Identifiers{ "j", }, @@ -56428,7 +58032,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3527, + context: p5131, freeVariables: Identifiers{ "j", }, @@ -56450,7 +58054,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3527, + context: p5131, freeVariables: nil, }, Value: float64(1), @@ -56471,7 +58075,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3527, + context: p5131, freeVariables: Identifiers{ "v", }, @@ -56490,7 +58094,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3527, + context: p5131, freeVariables: Identifiers{ "v", }, @@ -56512,7 +58116,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3527, + context: p5131, freeVariables: nil, }, Asserts: nil, @@ -56554,7 +58158,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3542, + context: p5146, freeVariables: nil, }, Value: true, @@ -56584,7 +58188,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", "consume", @@ -56693,7 +58297,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", }, @@ -56714,7 +58318,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: nil, }, Value: " ", @@ -56741,7 +58345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", "j", @@ -56763,7 +58367,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", }, @@ -56786,7 +58390,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3562, + context: p5166, freeVariables: Identifiers{ "str", }, @@ -56807,7 +58411,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3562, + context: p5166, freeVariables: Identifiers{ "j", }, @@ -56826,7 +58430,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3562, + context: p5166, freeVariables: Identifiers{ "j", }, @@ -56848,7 +58452,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3562, + context: p5166, freeVariables: nil, }, Value: float64(1), @@ -56869,7 +58473,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3562, + context: p5166, freeVariables: Identifiers{ "v", }, @@ -56888,7 +58492,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3562, + context: p5166, freeVariables: Identifiers{ "v", }, @@ -56910,7 +58514,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3562, + context: p5166, freeVariables: nil, }, Asserts: nil, @@ -56952,7 +58556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3577, + context: p5181, freeVariables: nil, }, Value: true, @@ -56982,7 +58586,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", "consume", @@ -57091,7 +58695,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "c", }, @@ -57112,7 +58716,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: nil, }, Value: "+", @@ -57139,7 +58743,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", "j", @@ -57161,7 +58765,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "consume", }, @@ -57184,7 +58788,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3597, + context: p5201, freeVariables: Identifiers{ "str", }, @@ -57205,7 +58809,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3597, + context: p5201, freeVariables: Identifiers{ "j", }, @@ -57224,7 +58828,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3597, + context: p5201, freeVariables: Identifiers{ "j", }, @@ -57246,7 +58850,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3597, + context: p5201, freeVariables: nil, }, Value: float64(1), @@ -57267,7 +58871,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3597, + context: p5201, freeVariables: Identifiers{ "v", }, @@ -57286,7 +58890,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3597, + context: p5201, freeVariables: Identifiers{ "v", }, @@ -57308,7 +58912,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3597, + context: p5201, freeVariables: nil, }, Asserts: nil, @@ -57350,7 +58954,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3612, + context: p5216, freeVariables: nil, }, Value: true, @@ -57380,7 +58984,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3409, + context: p5013, freeVariables: Identifiers{ "j", "v", @@ -57425,7 +59029,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3618, + context: p5222, freeVariables: Identifiers{ "j", }, @@ -57471,7 +59075,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3618, + context: p5222, freeVariables: Identifiers{ "v", }, @@ -57507,7 +59111,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3401, + context: p5005, freeVariables: Identifiers{ "consume", "i", @@ -57528,7 +59132,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3401, + context: p5005, freeVariables: Identifiers{ "consume", }, @@ -57551,7 +59155,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3629, + context: p5233, freeVariables: Identifiers{ "str", }, @@ -57572,7 +59176,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3629, + context: p5233, freeVariables: Identifiers{ "i", }, @@ -57593,7 +59197,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3629, + context: p5233, freeVariables: nil, }, Asserts: nil, @@ -57635,7 +59239,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3637, + context: p5241, freeVariables: nil, }, Value: false, @@ -57679,7 +59283,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3637, + context: p5241, freeVariables: nil, }, Value: false, @@ -57723,7 +59327,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3637, + context: p5241, freeVariables: nil, }, Value: false, @@ -57767,7 +59371,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3637, + context: p5241, freeVariables: nil, }, Value: false, @@ -57811,7 +59415,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3637, + context: p5241, freeVariables: nil, }, Value: false, @@ -57845,7 +59449,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", "str", @@ -57871,7 +59475,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3650, + context: p5254, freeVariables: Identifiers{ "std", }, @@ -57898,7 +59502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "i", "std", @@ -57919,7 +59523,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "i", "std", @@ -57940,7 +59544,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "i", "std", @@ -57961,7 +59565,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "i", }, @@ -57983,7 +59587,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "std", "str", @@ -58003,7 +59607,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "std", }, @@ -58022,7 +59626,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "std", }, @@ -58068,7 +59672,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3671, + context: p5275, freeVariables: Identifiers{ "str", }, @@ -58183,7 +59787,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "i", "str", @@ -58203,7 +59807,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "str", }, @@ -58224,7 +59828,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "i", }, @@ -58247,7 +59851,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: nil, }, Value: "*", @@ -58275,7 +59879,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "i", }, @@ -58319,7 +59923,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3693, + context: p5297, freeVariables: Identifiers{ "i", }, @@ -58338,7 +59942,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3693, + context: p5297, freeVariables: Identifiers{ "i", }, @@ -58360,7 +59964,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3693, + context: p5297, freeVariables: nil, }, Value: float64(1), @@ -58406,7 +60010,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3693, + context: p5297, freeVariables: nil, }, Value: "*", @@ -58431,7 +60035,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "i", "std", @@ -58455,7 +60059,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3704, + context: p5308, freeVariables: Identifiers{ "consume", "std", @@ -58484,7 +60088,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -58507,7 +60111,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "j", "std", @@ -58528,7 +60132,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "j", }, @@ -58550,7 +60154,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "std", "str", @@ -58570,7 +60174,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "std", }, @@ -58589,7 +60193,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "std", }, @@ -58635,7 +60239,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3723, + context: p5327, freeVariables: Identifiers{ "str", }, @@ -58663,7 +60267,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Expr: &LiteralString{ @@ -58680,7 +60284,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "Truncated format code.", @@ -58702,7 +60306,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -58728,7 +60332,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3731, + context: p5335, freeVariables: Identifiers{ "j", "str", @@ -58748,7 +60352,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3731, + context: p5335, freeVariables: Identifiers{ "str", }, @@ -58769,7 +60373,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3731, + context: p5335, freeVariables: Identifiers{ "j", }, @@ -58795,7 +60399,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -58904,7 +60508,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -58925,7 +60529,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "0", @@ -58952,7 +60556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -58974,7 +60578,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -58997,7 +60601,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3756, + context: p5360, freeVariables: Identifiers{ "str", }, @@ -59018,7 +60622,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3756, + context: p5360, freeVariables: Identifiers{ "j", }, @@ -59037,7 +60641,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3756, + context: p5360, freeVariables: Identifiers{ "j", }, @@ -59059,7 +60663,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3756, + context: p5360, freeVariables: nil, }, Value: float64(1), @@ -59080,7 +60684,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3756, + context: p5360, freeVariables: Identifiers{ "v", }, @@ -59099,7 +60703,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3756, + context: p5360, freeVariables: Identifiers{ "v", }, @@ -59118,7 +60722,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3756, + context: p5360, freeVariables: Identifiers{ "v", }, @@ -59140,7 +60744,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3756, + context: p5360, freeVariables: nil, }, Value: float64(10), @@ -59162,7 +60766,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3756, + context: p5360, freeVariables: nil, }, Value: float64(0), @@ -59189,7 +60793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -59298,7 +60902,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -59319,7 +60923,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "1", @@ -59346,7 +60950,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -59368,7 +60972,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -59391,7 +60995,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3790, + context: p5394, freeVariables: Identifiers{ "str", }, @@ -59412,7 +61016,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3790, + context: p5394, freeVariables: Identifiers{ "j", }, @@ -59431,7 +61035,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3790, + context: p5394, freeVariables: Identifiers{ "j", }, @@ -59453,7 +61057,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3790, + context: p5394, freeVariables: nil, }, Value: float64(1), @@ -59474,7 +61078,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3790, + context: p5394, freeVariables: Identifiers{ "v", }, @@ -59493,7 +61097,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3790, + context: p5394, freeVariables: Identifiers{ "v", }, @@ -59512,7 +61116,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3790, + context: p5394, freeVariables: Identifiers{ "v", }, @@ -59534,7 +61138,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3790, + context: p5394, freeVariables: nil, }, Value: float64(10), @@ -59556,7 +61160,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3790, + context: p5394, freeVariables: nil, }, Value: float64(1), @@ -59583,7 +61187,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -59692,7 +61296,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -59713,7 +61317,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "2", @@ -59740,7 +61344,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -59762,7 +61366,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -59785,7 +61389,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3824, + context: p5428, freeVariables: Identifiers{ "str", }, @@ -59806,7 +61410,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3824, + context: p5428, freeVariables: Identifiers{ "j", }, @@ -59825,7 +61429,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3824, + context: p5428, freeVariables: Identifiers{ "j", }, @@ -59847,7 +61451,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3824, + context: p5428, freeVariables: nil, }, Value: float64(1), @@ -59868,7 +61472,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3824, + context: p5428, freeVariables: Identifiers{ "v", }, @@ -59887,7 +61491,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3824, + context: p5428, freeVariables: Identifiers{ "v", }, @@ -59906,7 +61510,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3824, + context: p5428, freeVariables: Identifiers{ "v", }, @@ -59928,7 +61532,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3824, + context: p5428, freeVariables: nil, }, Value: float64(10), @@ -59950,7 +61554,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3824, + context: p5428, freeVariables: nil, }, Value: float64(2), @@ -59977,7 +61581,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -60086,7 +61690,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -60107,7 +61711,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "3", @@ -60134,7 +61738,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -60156,7 +61760,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -60179,7 +61783,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3858, + context: p5462, freeVariables: Identifiers{ "str", }, @@ -60200,7 +61804,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3858, + context: p5462, freeVariables: Identifiers{ "j", }, @@ -60219,7 +61823,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3858, + context: p5462, freeVariables: Identifiers{ "j", }, @@ -60241,7 +61845,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3858, + context: p5462, freeVariables: nil, }, Value: float64(1), @@ -60262,7 +61866,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3858, + context: p5462, freeVariables: Identifiers{ "v", }, @@ -60281,7 +61885,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3858, + context: p5462, freeVariables: Identifiers{ "v", }, @@ -60300,7 +61904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3858, + context: p5462, freeVariables: Identifiers{ "v", }, @@ -60322,7 +61926,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3858, + context: p5462, freeVariables: nil, }, Value: float64(10), @@ -60344,7 +61948,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3858, + context: p5462, freeVariables: nil, }, Value: float64(3), @@ -60371,7 +61975,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -60480,7 +62084,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -60501,7 +62105,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "4", @@ -60528,7 +62132,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -60550,7 +62154,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -60573,7 +62177,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3892, + context: p5496, freeVariables: Identifiers{ "str", }, @@ -60594,7 +62198,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3892, + context: p5496, freeVariables: Identifiers{ "j", }, @@ -60613,7 +62217,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3892, + context: p5496, freeVariables: Identifiers{ "j", }, @@ -60635,7 +62239,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3892, + context: p5496, freeVariables: nil, }, Value: float64(1), @@ -60656,7 +62260,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3892, + context: p5496, freeVariables: Identifiers{ "v", }, @@ -60675,7 +62279,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3892, + context: p5496, freeVariables: Identifiers{ "v", }, @@ -60694,7 +62298,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3892, + context: p5496, freeVariables: Identifiers{ "v", }, @@ -60716,7 +62320,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3892, + context: p5496, freeVariables: nil, }, Value: float64(10), @@ -60738,7 +62342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3892, + context: p5496, freeVariables: nil, }, Value: float64(4), @@ -60765,7 +62369,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -60874,7 +62478,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -60895,7 +62499,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "5", @@ -60922,7 +62526,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -60944,7 +62548,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -60967,7 +62571,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3926, + context: p5530, freeVariables: Identifiers{ "str", }, @@ -60988,7 +62592,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3926, + context: p5530, freeVariables: Identifiers{ "j", }, @@ -61007,7 +62611,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3926, + context: p5530, freeVariables: Identifiers{ "j", }, @@ -61029,7 +62633,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3926, + context: p5530, freeVariables: nil, }, Value: float64(1), @@ -61050,7 +62654,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3926, + context: p5530, freeVariables: Identifiers{ "v", }, @@ -61069,7 +62673,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3926, + context: p5530, freeVariables: Identifiers{ "v", }, @@ -61088,7 +62692,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3926, + context: p5530, freeVariables: Identifiers{ "v", }, @@ -61110,7 +62714,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3926, + context: p5530, freeVariables: nil, }, Value: float64(10), @@ -61132,7 +62736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3926, + context: p5530, freeVariables: nil, }, Value: float64(5), @@ -61159,7 +62763,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -61268,7 +62872,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -61289,7 +62893,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "6", @@ -61316,7 +62920,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -61338,7 +62942,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -61361,7 +62965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3960, + context: p5564, freeVariables: Identifiers{ "str", }, @@ -61382,7 +62986,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3960, + context: p5564, freeVariables: Identifiers{ "j", }, @@ -61401,7 +63005,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3960, + context: p5564, freeVariables: Identifiers{ "j", }, @@ -61423,7 +63027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3960, + context: p5564, freeVariables: nil, }, Value: float64(1), @@ -61444,7 +63048,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3960, + context: p5564, freeVariables: Identifiers{ "v", }, @@ -61463,7 +63067,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3960, + context: p5564, freeVariables: Identifiers{ "v", }, @@ -61482,7 +63086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3960, + context: p5564, freeVariables: Identifiers{ "v", }, @@ -61504,7 +63108,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3960, + context: p5564, freeVariables: nil, }, Value: float64(10), @@ -61526,7 +63130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3960, + context: p5564, freeVariables: nil, }, Value: float64(6), @@ -61553,7 +63157,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -61662,7 +63266,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -61683,7 +63287,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "7", @@ -61710,7 +63314,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -61732,7 +63336,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -61755,7 +63359,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3994, + context: p5598, freeVariables: Identifiers{ "str", }, @@ -61776,7 +63380,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3994, + context: p5598, freeVariables: Identifiers{ "j", }, @@ -61795,7 +63399,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3994, + context: p5598, freeVariables: Identifiers{ "j", }, @@ -61817,7 +63421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3994, + context: p5598, freeVariables: nil, }, Value: float64(1), @@ -61838,7 +63442,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3994, + context: p5598, freeVariables: Identifiers{ "v", }, @@ -61857,7 +63461,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3994, + context: p5598, freeVariables: Identifiers{ "v", }, @@ -61876,7 +63480,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3994, + context: p5598, freeVariables: Identifiers{ "v", }, @@ -61898,7 +63502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3994, + context: p5598, freeVariables: nil, }, Value: float64(10), @@ -61920,7 +63524,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3994, + context: p5598, freeVariables: nil, }, Value: float64(7), @@ -61947,7 +63551,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -62056,7 +63660,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -62077,7 +63681,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "8", @@ -62104,7 +63708,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -62126,7 +63730,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -62149,7 +63753,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4028, + context: p5632, freeVariables: Identifiers{ "str", }, @@ -62170,7 +63774,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4028, + context: p5632, freeVariables: Identifiers{ "j", }, @@ -62189,7 +63793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4028, + context: p5632, freeVariables: Identifiers{ "j", }, @@ -62211,7 +63815,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4028, + context: p5632, freeVariables: nil, }, Value: float64(1), @@ -62232,7 +63836,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4028, + context: p5632, freeVariables: Identifiers{ "v", }, @@ -62251,7 +63855,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4028, + context: p5632, freeVariables: Identifiers{ "v", }, @@ -62270,7 +63874,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4028, + context: p5632, freeVariables: Identifiers{ "v", }, @@ -62292,7 +63896,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4028, + context: p5632, freeVariables: nil, }, Value: float64(10), @@ -62314,7 +63918,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4028, + context: p5632, freeVariables: nil, }, Value: float64(8), @@ -62341,7 +63945,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", "consume", @@ -62450,7 +64054,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "c", }, @@ -62471,7 +64075,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: nil, }, Value: "9", @@ -62498,7 +64102,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", "j", @@ -62520,7 +64124,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "consume", }, @@ -62543,7 +64147,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4062, + context: p5666, freeVariables: Identifiers{ "str", }, @@ -62564,7 +64168,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4062, + context: p5666, freeVariables: Identifiers{ "j", }, @@ -62583,7 +64187,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4062, + context: p5666, freeVariables: Identifiers{ "j", }, @@ -62605,7 +64209,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4062, + context: p5666, freeVariables: nil, }, Value: float64(1), @@ -62626,7 +64230,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4062, + context: p5666, freeVariables: Identifiers{ "v", }, @@ -62645,7 +64249,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4062, + context: p5666, freeVariables: Identifiers{ "v", }, @@ -62664,7 +64268,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4062, + context: p5666, freeVariables: Identifiers{ "v", }, @@ -62686,7 +64290,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4062, + context: p5666, freeVariables: nil, }, Value: float64(10), @@ -62708,7 +64312,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4062, + context: p5666, freeVariables: nil, }, Value: float64(9), @@ -62735,7 +64339,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3708, + context: p5312, freeVariables: Identifiers{ "j", "v", @@ -62780,7 +64384,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4082, + context: p5686, freeVariables: Identifiers{ "j", }, @@ -62826,7 +64430,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4082, + context: p5686, freeVariables: Identifiers{ "v", }, @@ -62867,7 +64471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "consume", "i", @@ -62888,7 +64492,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3654, + context: p5258, freeVariables: Identifiers{ "consume", }, @@ -62911,7 +64515,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4093, + context: p5697, freeVariables: Identifiers{ "str", }, @@ -62932,7 +64536,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4093, + context: p5697, freeVariables: Identifiers{ "i", }, @@ -62953,7 +64557,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4093, + context: p5697, freeVariables: nil, }, Value: float64(0), @@ -62985,7 +64589,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", "str", @@ -63012,7 +64616,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4102, + context: p5706, freeVariables: Identifiers{ "std", "try_parse_field_width", @@ -63040,7 +64644,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "i", "std", @@ -63062,7 +64666,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "i", "std", @@ -63083,7 +64687,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "i", }, @@ -63105,7 +64709,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "std", "str", @@ -63125,7 +64729,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "std", }, @@ -63144,7 +64748,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "std", }, @@ -63190,7 +64794,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4121, + context: p5725, freeVariables: Identifiers{ "str", }, @@ -63218,7 +64822,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: nil, }, Expr: &LiteralString{ @@ -63235,7 +64839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: nil, }, Value: "Truncated format code.", @@ -63257,7 +64861,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "i", "std", @@ -63282,7 +64886,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4129, + context: p5733, freeVariables: Identifiers{ "i", "str", @@ -63302,7 +64906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4129, + context: p5733, freeVariables: Identifiers{ "str", }, @@ -63323,7 +64927,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4129, + context: p5733, freeVariables: Identifiers{ "i", }, @@ -63349,7 +64953,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "c", "i", @@ -63457,7 +65061,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "c", }, @@ -63478,7 +65082,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: nil, }, Value: ".", @@ -63505,7 +65109,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "i", "str", @@ -63526,7 +65130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "try_parse_field_width", }, @@ -63549,7 +65153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4154, + context: p5758, freeVariables: Identifiers{ "str", }, @@ -63570,7 +65174,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4154, + context: p5758, freeVariables: Identifiers{ "i", }, @@ -63589,7 +65193,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4154, + context: p5758, freeVariables: Identifiers{ "i", }, @@ -63611,7 +65215,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4154, + context: p5758, freeVariables: nil, }, Value: float64(1), @@ -63638,7 +65242,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4106, + context: p5710, freeVariables: Identifiers{ "i", }, @@ -63682,7 +65286,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4166, + context: p5770, freeVariables: Identifiers{ "i", }, @@ -63728,7 +65332,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4166, + context: p5770, freeVariables: nil, }, }, @@ -63757,7 +65361,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", "str", @@ -63785,7 +65389,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4174, + context: p5778, freeVariables: Identifiers{ "std", }, @@ -63812,7 +65416,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "i", "std", @@ -63833,7 +65437,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "i", "std", @@ -63854,7 +65458,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "i", }, @@ -63876,7 +65480,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "std", "str", @@ -63896,7 +65500,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "std", }, @@ -63915,7 +65519,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "std", }, @@ -63961,7 +65565,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4193, + context: p5797, freeVariables: Identifiers{ "str", }, @@ -63989,7 +65593,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: nil, }, Expr: &LiteralString{ @@ -64006,7 +65610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: nil, }, Value: "Truncated format code.", @@ -64028,7 +65632,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "i", "std", @@ -64052,7 +65656,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4201, + context: p5805, freeVariables: Identifiers{ "i", "str", @@ -64072,7 +65676,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4201, + context: p5805, freeVariables: Identifiers{ "str", }, @@ -64093,7 +65697,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4201, + context: p5805, freeVariables: Identifiers{ "i", }, @@ -64119,7 +65723,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "c", "i", @@ -64140,7 +65744,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "c", "std", @@ -64160,7 +65764,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "c", "std", @@ -64265,7 +65869,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "c", }, @@ -64286,7 +65890,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: nil, }, Value: "h", @@ -64399,7 +66003,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "c", }, @@ -64420,7 +66024,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: nil, }, Value: "l", @@ -64534,7 +66138,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "c", }, @@ -64555,7 +66159,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: nil, }, Value: "L", @@ -64583,7 +66187,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "i", }, @@ -64602,7 +66206,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "i", }, @@ -64624,7 +66228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: nil, }, Value: float64(1), @@ -64645,7 +66249,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4178, + context: p5782, freeVariables: Identifiers{ "i", }, @@ -64673,7 +66277,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", "str", @@ -64702,7 +66306,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4257, + context: p5861, freeVariables: Identifiers{ "std", }, @@ -64729,7 +66333,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", "std", @@ -64750,7 +66354,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", "std", @@ -64771,7 +66375,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -64793,7 +66397,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "std", "str", @@ -64813,7 +66417,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "std", }, @@ -64832,7 +66436,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "std", }, @@ -64878,7 +66482,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4276, + context: p5880, freeVariables: Identifiers{ "str", }, @@ -64906,7 +66510,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Expr: &LiteralString{ @@ -64923,7 +66527,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "Truncated format code.", @@ -64945,7 +66549,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", "std", @@ -64969,7 +66573,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4284, + context: p5888, freeVariables: Identifiers{ "i", "str", @@ -64989,7 +66593,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4284, + context: p5888, freeVariables: Identifiers{ "str", }, @@ -65010,7 +66614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4284, + context: p5888, freeVariables: Identifiers{ "i", }, @@ -65036,7 +66640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -65057,7 +66661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "std", @@ -65077,7 +66681,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "std", @@ -65182,7 +66786,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -65203,7 +66807,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "d", @@ -65316,7 +66920,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -65337,7 +66941,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "i", @@ -65451,7 +67055,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -65472,7 +67076,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "u", @@ -65500,7 +67104,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -65544,7 +67148,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4334, + context: p5938, freeVariables: Identifiers{ "i", }, @@ -65563,7 +67167,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4334, + context: p5938, freeVariables: Identifiers{ "i", }, @@ -65585,7 +67189,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4334, + context: p5938, freeVariables: nil, }, Value: float64(1), @@ -65631,7 +67235,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4334, + context: p5938, freeVariables: nil, }, Value: "d", @@ -65677,7 +67281,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4334, + context: p5938, freeVariables: nil, }, Value: false, @@ -65700,7 +67304,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -65806,7 +67410,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -65827,7 +67431,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "o", @@ -65854,7 +67458,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -65898,7 +67502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4361, + context: p5965, freeVariables: Identifiers{ "i", }, @@ -65917,7 +67521,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4361, + context: p5965, freeVariables: Identifiers{ "i", }, @@ -65939,7 +67543,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4361, + context: p5965, freeVariables: nil, }, Value: float64(1), @@ -65985,7 +67589,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4361, + context: p5965, freeVariables: nil, }, Value: "o", @@ -66031,7 +67635,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4361, + context: p5965, freeVariables: nil, }, Value: false, @@ -66054,7 +67658,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -66160,7 +67764,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -66181,7 +67785,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "x", @@ -66208,7 +67812,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -66252,7 +67856,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4388, + context: p5992, freeVariables: Identifiers{ "i", }, @@ -66271,7 +67875,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4388, + context: p5992, freeVariables: Identifiers{ "i", }, @@ -66293,7 +67897,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4388, + context: p5992, freeVariables: nil, }, Value: float64(1), @@ -66339,7 +67943,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4388, + context: p5992, freeVariables: nil, }, Value: "x", @@ -66385,7 +67989,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4388, + context: p5992, freeVariables: nil, }, Value: false, @@ -66408,7 +68012,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -66514,7 +68118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -66535,7 +68139,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "X", @@ -66562,7 +68166,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -66606,7 +68210,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4415, + context: p6019, freeVariables: Identifiers{ "i", }, @@ -66625,7 +68229,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4415, + context: p6019, freeVariables: Identifiers{ "i", }, @@ -66647,7 +68251,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4415, + context: p6019, freeVariables: nil, }, Value: float64(1), @@ -66693,7 +68297,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4415, + context: p6019, freeVariables: nil, }, Value: "x", @@ -66739,7 +68343,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4415, + context: p6019, freeVariables: nil, }, Value: true, @@ -66762,7 +68366,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -66868,7 +68472,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -66889,7 +68493,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "e", @@ -66916,7 +68520,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -66960,7 +68564,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4442, + context: p6046, freeVariables: Identifiers{ "i", }, @@ -66979,7 +68583,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4442, + context: p6046, freeVariables: Identifiers{ "i", }, @@ -67001,7 +68605,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4442, + context: p6046, freeVariables: nil, }, Value: float64(1), @@ -67047,7 +68651,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4442, + context: p6046, freeVariables: nil, }, Value: "e", @@ -67093,7 +68697,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4442, + context: p6046, freeVariables: nil, }, Value: false, @@ -67116,7 +68720,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -67222,7 +68826,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -67243,7 +68847,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "E", @@ -67270,7 +68874,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -67314,7 +68918,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4469, + context: p6073, freeVariables: Identifiers{ "i", }, @@ -67333,7 +68937,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4469, + context: p6073, freeVariables: Identifiers{ "i", }, @@ -67355,7 +68959,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4469, + context: p6073, freeVariables: nil, }, Value: float64(1), @@ -67401,7 +69005,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4469, + context: p6073, freeVariables: nil, }, Value: "e", @@ -67447,7 +69051,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4469, + context: p6073, freeVariables: nil, }, Value: true, @@ -67470,7 +69074,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -67576,7 +69180,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -67597,7 +69201,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "f", @@ -67624,7 +69228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -67668,7 +69272,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4496, + context: p6100, freeVariables: Identifiers{ "i", }, @@ -67687,7 +69291,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4496, + context: p6100, freeVariables: Identifiers{ "i", }, @@ -67709,7 +69313,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4496, + context: p6100, freeVariables: nil, }, Value: float64(1), @@ -67755,7 +69359,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4496, + context: p6100, freeVariables: nil, }, Value: "f", @@ -67801,7 +69405,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4496, + context: p6100, freeVariables: nil, }, Value: false, @@ -67824,7 +69428,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -67930,7 +69534,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -67951,7 +69555,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "F", @@ -67978,7 +69582,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -68022,7 +69626,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4523, + context: p6127, freeVariables: Identifiers{ "i", }, @@ -68041,7 +69645,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4523, + context: p6127, freeVariables: Identifiers{ "i", }, @@ -68063,7 +69667,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4523, + context: p6127, freeVariables: nil, }, Value: float64(1), @@ -68109,7 +69713,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4523, + context: p6127, freeVariables: nil, }, Value: "f", @@ -68155,7 +69759,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4523, + context: p6127, freeVariables: nil, }, Value: true, @@ -68178,7 +69782,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -68284,7 +69888,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -68305,7 +69909,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "g", @@ -68332,7 +69936,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -68376,7 +69980,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4550, + context: p6154, freeVariables: Identifiers{ "i", }, @@ -68395,7 +69999,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4550, + context: p6154, freeVariables: Identifiers{ "i", }, @@ -68417,7 +70021,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4550, + context: p6154, freeVariables: nil, }, Value: float64(1), @@ -68463,7 +70067,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4550, + context: p6154, freeVariables: nil, }, Value: "g", @@ -68509,7 +70113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4550, + context: p6154, freeVariables: nil, }, Value: false, @@ -68532,7 +70136,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -68638,7 +70242,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -68659,7 +70263,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "G", @@ -68686,7 +70290,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -68730,7 +70334,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4577, + context: p6181, freeVariables: Identifiers{ "i", }, @@ -68749,7 +70353,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4577, + context: p6181, freeVariables: Identifiers{ "i", }, @@ -68771,7 +70375,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4577, + context: p6181, freeVariables: nil, }, Value: float64(1), @@ -68817,7 +70421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4577, + context: p6181, freeVariables: nil, }, Value: "g", @@ -68863,7 +70467,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4577, + context: p6181, freeVariables: nil, }, Value: true, @@ -68886,7 +70490,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -68992,7 +70596,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -69013,7 +70617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "c", @@ -69040,7 +70644,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -69084,7 +70688,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4604, + context: p6208, freeVariables: Identifiers{ "i", }, @@ -69103,7 +70707,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4604, + context: p6208, freeVariables: Identifiers{ "i", }, @@ -69125,7 +70729,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4604, + context: p6208, freeVariables: nil, }, Value: float64(1), @@ -69171,7 +70775,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4604, + context: p6208, freeVariables: nil, }, Value: "c", @@ -69217,7 +70821,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4604, + context: p6208, freeVariables: nil, }, Value: false, @@ -69240,7 +70844,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -69346,7 +70950,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -69367,7 +70971,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "s", @@ -69394,7 +70998,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -69438,7 +71042,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4631, + context: p6235, freeVariables: Identifiers{ "i", }, @@ -69457,7 +71061,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4631, + context: p6235, freeVariables: Identifiers{ "i", }, @@ -69479,7 +71083,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4631, + context: p6235, freeVariables: nil, }, Value: float64(1), @@ -69525,7 +71129,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4631, + context: p6235, freeVariables: nil, }, Value: "s", @@ -69571,7 +71175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4631, + context: p6235, freeVariables: nil, }, Value: false, @@ -69594,7 +71198,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", "i", @@ -69700,7 +71304,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -69721,7 +71325,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "%", @@ -69748,7 +71352,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "i", }, @@ -69792,7 +71396,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4658, + context: p6262, freeVariables: Identifiers{ "i", }, @@ -69811,7 +71415,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4658, + context: p6262, freeVariables: Identifiers{ "i", }, @@ -69833,7 +71437,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4658, + context: p6262, freeVariables: nil, }, Value: float64(1), @@ -69879,7 +71483,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4658, + context: p6262, freeVariables: nil, }, Value: "%", @@ -69925,7 +71529,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4658, + context: p6262, freeVariables: nil, }, Value: false, @@ -69948,7 +71552,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -69967,7 +71571,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -69986,7 +71590,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: nil, }, Value: "Unrecognised conversion type: ", @@ -70008,7 +71612,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4261, + context: p5865, freeVariables: Identifiers{ "c", }, @@ -70050,7 +71654,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "parse_conv_type", "std", @@ -70080,7 +71684,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4678, + context: p6282, freeVariables: Identifiers{ "parse_conv_type", "std", @@ -70113,7 +71717,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "i", "parse_conv_type", @@ -70140,7 +71744,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "i", "std", @@ -70161,7 +71765,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "i", }, @@ -70183,7 +71787,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "std", "str", @@ -70203,7 +71807,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "std", }, @@ -70222,7 +71826,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "std", }, @@ -70268,7 +71872,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4697, + context: p6301, freeVariables: Identifiers{ "str", }, @@ -70296,7 +71900,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: nil, }, Expr: &LiteralString{ @@ -70313,7 +71917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: nil, }, Value: "Truncated format code.", @@ -70335,7 +71939,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "i", "parse_conv_type", @@ -70364,7 +71968,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4705, + context: p6309, freeVariables: Identifiers{ "i", "str", @@ -70385,7 +71989,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4705, + context: p6309, freeVariables: Identifiers{ "try_parse_mapping_key", }, @@ -70408,7 +72012,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4711, + context: p6315, freeVariables: Identifiers{ "str", }, @@ -70429,7 +72033,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4711, + context: p6315, freeVariables: Identifiers{ "i", }, @@ -70459,7 +72063,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "mkey", "parse_conv_type", @@ -70487,7 +72091,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4719, + context: p6323, freeVariables: Identifiers{ "mkey", "str", @@ -70508,7 +72112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4719, + context: p6323, freeVariables: Identifiers{ "try_parse_cflags", }, @@ -70531,7 +72135,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4725, + context: p6329, freeVariables: Identifiers{ "str", }, @@ -70552,7 +72156,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4725, + context: p6329, freeVariables: Identifiers{ "mkey", }, @@ -70571,7 +72175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4725, + context: p6329, freeVariables: Identifiers{ "mkey", }, @@ -70624,7 +72228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "cflags", "mkey", @@ -70652,7 +72256,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4736, + context: p6340, freeVariables: Identifiers{ "cflags", "str", @@ -70673,7 +72277,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4736, + context: p6340, freeVariables: Identifiers{ "try_parse_field_width", }, @@ -70696,7 +72300,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4742, + context: p6346, freeVariables: Identifiers{ "str", }, @@ -70717,7 +72321,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4742, + context: p6346, freeVariables: Identifiers{ "cflags", }, @@ -70736,7 +72340,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4742, + context: p6346, freeVariables: Identifiers{ "cflags", }, @@ -70789,7 +72393,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "cflags", "fw", @@ -70817,7 +72421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4753, + context: p6357, freeVariables: Identifiers{ "fw", "str", @@ -70838,7 +72442,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4753, + context: p6357, freeVariables: Identifiers{ "try_parse_precision", }, @@ -70861,7 +72465,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4759, + context: p6363, freeVariables: Identifiers{ "str", }, @@ -70882,7 +72486,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4759, + context: p6363, freeVariables: Identifiers{ "fw", }, @@ -70901,7 +72505,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4759, + context: p6363, freeVariables: Identifiers{ "fw", }, @@ -70954,7 +72558,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "cflags", "fw", @@ -70982,7 +72586,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4770, + context: p6374, freeVariables: Identifiers{ "prec", "str", @@ -71003,7 +72607,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4770, + context: p6374, freeVariables: Identifiers{ "try_parse_length_modifier", }, @@ -71026,7 +72630,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4776, + context: p6380, freeVariables: Identifiers{ "str", }, @@ -71047,7 +72651,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4776, + context: p6380, freeVariables: Identifiers{ "prec", }, @@ -71066,7 +72670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4776, + context: p6380, freeVariables: Identifiers{ "prec", }, @@ -71119,7 +72723,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "cflags", "fw", @@ -71147,7 +72751,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4787, + context: p6391, freeVariables: Identifiers{ "len_mod", "parse_conv_type", @@ -71168,7 +72772,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4787, + context: p6391, freeVariables: Identifiers{ "parse_conv_type", }, @@ -71191,7 +72795,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4793, + context: p6397, freeVariables: Identifiers{ "str", }, @@ -71212,7 +72816,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4793, + context: p6397, freeVariables: Identifiers{ "len_mod", }, @@ -71242,7 +72846,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4682, + context: p6286, freeVariables: Identifiers{ "cflags", "ctype", @@ -71290,7 +72894,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4802, + context: p6406, freeVariables: Identifiers{ "ctype", }, @@ -71309,7 +72913,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4802, + context: p6406, freeVariables: Identifiers{ "ctype", }, @@ -71378,7 +72982,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4802, + context: p6406, freeVariables: Identifiers{ "cflags", "ctype", @@ -71426,7 +73030,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "mkey", }, @@ -71445,7 +73049,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "mkey", }, @@ -71514,7 +73118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "cflags", }, @@ -71533,7 +73137,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "cflags", }, @@ -71602,7 +73206,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "fw", }, @@ -71621,7 +73225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "fw", }, @@ -71690,7 +73294,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "prec", }, @@ -71709,7 +73313,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "prec", }, @@ -71778,7 +73382,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "ctype", }, @@ -71797,7 +73401,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "ctype", }, @@ -71866,7 +73470,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "ctype", }, @@ -71885,7 +73489,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4813, + context: p6417, freeVariables: Identifiers{ "ctype", }, @@ -71948,7 +73552,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "parse_code", "std", @@ -71973,7 +73577,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4852, + context: p6456, freeVariables: Identifiers{ "parse_code", "parse_codes", @@ -72004,7 +73608,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "cur", "i", @@ -72029,7 +73633,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "i", "std", @@ -72050,7 +73654,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "i", }, @@ -72072,7 +73676,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "std", "str", @@ -72092,7 +73696,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "std", }, @@ -72111,7 +73715,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "std", }, @@ -72157,7 +73761,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4871, + context: p6475, freeVariables: Identifiers{ "str", }, @@ -72185,7 +73789,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "cur", "out", @@ -72205,7 +73809,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "out", }, @@ -72227,7 +73831,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "cur", }, @@ -72247,7 +73851,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4881, + context: p6485, freeVariables: Identifiers{ "cur", }, @@ -72272,7 +73876,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "cur", "i", @@ -72300,7 +73904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4887, + context: p6491, freeVariables: Identifiers{ "i", "str", @@ -72320,7 +73924,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4887, + context: p6491, freeVariables: Identifiers{ "str", }, @@ -72341,7 +73945,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4887, + context: p6491, freeVariables: Identifiers{ "i", }, @@ -72367,7 +73971,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "c", "cur", @@ -72478,7 +74082,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "c", }, @@ -72499,7 +74103,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: nil, }, Value: "%", @@ -72526,7 +74130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "cur", "i", @@ -72553,7 +74157,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4910, + context: p6514, freeVariables: Identifiers{ "i", "parse_code", @@ -72574,7 +74178,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4910, + context: p6514, freeVariables: Identifiers{ "parse_code", }, @@ -72597,7 +74201,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4916, + context: p6520, freeVariables: Identifiers{ "str", }, @@ -72618,7 +74222,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4916, + context: p6520, freeVariables: Identifiers{ "i", }, @@ -72637,7 +74241,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4916, + context: p6520, freeVariables: Identifiers{ "i", }, @@ -72659,7 +74263,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4916, + context: p6520, freeVariables: nil, }, Value: float64(1), @@ -72689,7 +74293,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "cur", "out", @@ -72712,7 +74316,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "parse_codes", }, @@ -72735,7 +74339,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4929, + context: p6533, freeVariables: Identifiers{ "str", }, @@ -72756,7 +74360,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4929, + context: p6533, freeVariables: Identifiers{ "r", }, @@ -72775,7 +74379,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4929, + context: p6533, freeVariables: Identifiers{ "r", }, @@ -72819,7 +74423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4929, + context: p6533, freeVariables: Identifiers{ "cur", "out", @@ -72840,7 +74444,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4929, + context: p6533, freeVariables: Identifiers{ "out", }, @@ -72862,7 +74466,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4929, + context: p6533, freeVariables: Identifiers{ "cur", "r", @@ -72883,7 +74487,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4944, + context: p6548, freeVariables: Identifiers{ "cur", }, @@ -72904,7 +74508,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4944, + context: p6548, freeVariables: Identifiers{ "r", }, @@ -72923,7 +74527,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4944, + context: p6548, freeVariables: Identifiers{ "r", }, @@ -72971,7 +74575,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4929, + context: p6533, freeVariables: nil, }, Value: "", @@ -72999,7 +74603,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "c", "cur", @@ -73023,7 +74627,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4856, + context: p6460, freeVariables: Identifiers{ "parse_codes", }, @@ -73046,7 +74650,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4958, + context: p6562, freeVariables: Identifiers{ "str", }, @@ -73067,7 +74671,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4958, + context: p6562, freeVariables: Identifiers{ "i", }, @@ -73086,7 +74690,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4958, + context: p6562, freeVariables: Identifiers{ "i", }, @@ -73108,7 +74712,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4958, + context: p6562, freeVariables: nil, }, Value: float64(1), @@ -73129,7 +74733,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4958, + context: p6562, freeVariables: Identifiers{ "out", }, @@ -73150,7 +74754,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4958, + context: p6562, freeVariables: Identifiers{ "c", "cur", @@ -73170,7 +74774,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4958, + context: p6562, freeVariables: Identifiers{ "cur", }, @@ -73192,7 +74796,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4958, + context: p6562, freeVariables: Identifiers{ "c", }, @@ -73227,7 +74831,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "parse_codes", "std", @@ -73252,7 +74856,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4977, + context: p6581, freeVariables: Identifiers{ "parse_codes", "str", @@ -73272,7 +74876,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4977, + context: p6581, freeVariables: Identifiers{ "parse_codes", }, @@ -73295,7 +74899,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4983, + context: p6587, freeVariables: Identifiers{ "str", }, @@ -73316,7 +74920,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4983, + context: p6587, freeVariables: nil, }, Value: float64(0), @@ -73336,7 +74940,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4983, + context: p6587, freeVariables: nil, }, Elements: nil, @@ -73356,7 +74960,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4983, + context: p6587, freeVariables: nil, }, Value: "", @@ -73386,7 +74990,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "std", @@ -73410,7 +75014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4992, + context: p6596, freeVariables: nil, }, Parameters: Parameters{ @@ -73435,7 +75039,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4995, + context: p6599, freeVariables: Identifiers{ "s", "w", @@ -73458,7 +75062,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4999, + context: p6603, freeVariables: Identifiers{ "aux", "s", @@ -73486,7 +75090,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5003, + context: p6607, freeVariables: Identifiers{ "aux", "s", @@ -73508,7 +75112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5003, + context: p6607, freeVariables: Identifiers{ "w", }, @@ -73527,7 +75131,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5003, + context: p6607, freeVariables: Identifiers{ "w", }, @@ -73549,7 +75153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5003, + context: p6607, freeVariables: nil, }, Value: float64(0), @@ -73570,7 +75174,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5003, + context: p6607, freeVariables: Identifiers{ "v", }, @@ -73591,7 +75195,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5003, + context: p6607, freeVariables: Identifiers{ "aux", "s", @@ -73613,7 +75217,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5003, + context: p6607, freeVariables: Identifiers{ "aux", }, @@ -73636,7 +75240,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5018, + context: p6622, freeVariables: Identifiers{ "w", }, @@ -73655,7 +75259,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5018, + context: p6622, freeVariables: Identifiers{ "w", }, @@ -73677,7 +75281,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5018, + context: p6622, freeVariables: nil, }, Value: float64(1), @@ -73698,7 +75302,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5018, + context: p6622, freeVariables: Identifiers{ "s", "v", @@ -73718,7 +75322,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5018, + context: p6622, freeVariables: Identifiers{ "v", }, @@ -73740,7 +75344,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5018, + context: p6622, freeVariables: Identifiers{ "s", }, @@ -73773,7 +75377,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4995, + context: p6599, freeVariables: Identifiers{ "aux", "w", @@ -73793,7 +75397,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p4995, + context: p6599, freeVariables: Identifiers{ "aux", }, @@ -73816,7 +75420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5035, + context: p6639, freeVariables: Identifiers{ "w", }, @@ -73837,7 +75441,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5035, + context: p6639, freeVariables: nil, }, Value: "", @@ -73869,7 +75473,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "padding", @@ -73894,7 +75498,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5042, + context: p6646, freeVariables: Identifiers{ "padding", "std", @@ -73923,7 +75527,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5046, + context: p6650, freeVariables: Identifiers{ "padding", "s", @@ -73946,7 +75550,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5046, + context: p6650, freeVariables: Identifiers{ "padding", "s", @@ -73969,7 +75573,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5046, + context: p6650, freeVariables: Identifiers{ "padding", }, @@ -73992,7 +75596,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5054, + context: p6658, freeVariables: Identifiers{ "std", "str", @@ -74013,7 +75617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5054, + context: p6658, freeVariables: Identifiers{ "w", }, @@ -74035,7 +75639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5054, + context: p6658, freeVariables: Identifiers{ "std", "str", @@ -74055,7 +75659,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5054, + context: p6658, freeVariables: Identifiers{ "std", }, @@ -74074,7 +75678,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5054, + context: p6658, freeVariables: Identifiers{ "std", }, @@ -74120,7 +75724,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5067, + context: p6671, freeVariables: Identifiers{ "str", }, @@ -74148,7 +75752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5054, + context: p6658, freeVariables: Identifiers{ "s", }, @@ -74176,7 +75780,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5046, + context: p6650, freeVariables: Identifiers{ "str", }, @@ -74202,7 +75806,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "pad_left", @@ -74228,7 +75832,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5077, + context: p6681, freeVariables: Identifiers{ "padding", "std", @@ -74257,7 +75861,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5081, + context: p6685, freeVariables: Identifiers{ "padding", "s", @@ -74280,7 +75884,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5081, + context: p6685, freeVariables: Identifiers{ "str", }, @@ -74302,7 +75906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5081, + context: p6685, freeVariables: Identifiers{ "padding", "s", @@ -74325,7 +75929,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5081, + context: p6685, freeVariables: Identifiers{ "padding", }, @@ -74348,7 +75952,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5091, + context: p6695, freeVariables: Identifiers{ "std", "str", @@ -74369,7 +75973,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5091, + context: p6695, freeVariables: Identifiers{ "w", }, @@ -74391,7 +75995,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5091, + context: p6695, freeVariables: Identifiers{ "std", "str", @@ -74411,7 +76015,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5091, + context: p6695, freeVariables: Identifiers{ "std", }, @@ -74430,7 +76034,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5091, + context: p6695, freeVariables: Identifiers{ "std", }, @@ -74476,7 +76080,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5104, + context: p6708, freeVariables: Identifiers{ "str", }, @@ -74504,7 +76108,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5091, + context: p6695, freeVariables: Identifiers{ "s", }, @@ -74536,7 +76140,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "pad_left", @@ -74562,7 +76166,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5112, + context: p6716, freeVariables: Identifiers{ "pad_left", "std", @@ -74595,7 +76199,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", "min_chars", @@ -74625,7 +76229,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5120, + context: p6724, freeVariables: Identifiers{ "n__", "std", @@ -74645,7 +76249,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5120, + context: p6724, freeVariables: Identifiers{ "std", }, @@ -74664,7 +76268,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5120, + context: p6724, freeVariables: Identifiers{ "std", }, @@ -74710,7 +76314,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5129, + context: p6733, freeVariables: Identifiers{ "n__", }, @@ -74740,7 +76344,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", "min_chars", @@ -74771,7 +76375,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5135, + context: p6739, freeVariables: Identifiers{ "aux", "radix", @@ -74800,7 +76404,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5139, + context: p6743, freeVariables: Identifiers{ "aux", "n", @@ -74908,7 +76512,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5139, + context: p6743, freeVariables: Identifiers{ "n", }, @@ -74929,7 +76533,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5139, + context: p6743, freeVariables: nil, }, Value: float64(0), @@ -74955,7 +76559,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5139, + context: p6743, freeVariables: Identifiers{ "zero_prefix", }, @@ -74976,7 +76580,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5139, + context: p6743, freeVariables: Identifiers{ "aux", "n", @@ -74998,7 +76602,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5139, + context: p6743, freeVariables: Identifiers{ "aux", "n", @@ -75020,7 +76624,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5139, + context: p6743, freeVariables: Identifiers{ "aux", }, @@ -75043,7 +76647,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5162, + context: p6766, freeVariables: Identifiers{ "n", "radix", @@ -75064,7 +76668,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5162, + context: p6766, freeVariables: Identifiers{ "std", }, @@ -75083,7 +76687,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5162, + context: p6766, freeVariables: Identifiers{ "std", }, @@ -75129,7 +76733,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5171, + context: p6775, freeVariables: Identifiers{ "n", "radix", @@ -75149,7 +76753,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5171, + context: p6775, freeVariables: Identifiers{ "n", }, @@ -75171,7 +76775,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5171, + context: p6775, freeVariables: Identifiers{ "radix", }, @@ -75292,7 +76896,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5139, + context: p6743, freeVariables: Identifiers{ "n", }, @@ -75313,7 +76917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5139, + context: p6743, freeVariables: Identifiers{ "radix", }, @@ -75346,7 +76950,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "aux", "blank", @@ -75376,7 +76980,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5193, + context: p6797, freeVariables: Identifiers{ "aux", "n_", @@ -75482,7 +77086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5193, + context: p6797, freeVariables: Identifiers{ "n_", "std", @@ -75502,7 +77106,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5193, + context: p6797, freeVariables: Identifiers{ "std", }, @@ -75521,7 +77125,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5193, + context: p6797, freeVariables: Identifiers{ "std", }, @@ -75567,7 +77171,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5212, + context: p6816, freeVariables: Identifiers{ "n_", }, @@ -75594,7 +77198,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5193, + context: p6797, freeVariables: nil, }, Value: float64(0), @@ -75620,7 +77224,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5193, + context: p6797, freeVariables: nil, }, Value: "0", @@ -75641,7 +77245,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5193, + context: p6797, freeVariables: Identifiers{ "aux", "n_", @@ -75662,7 +77266,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5193, + context: p6797, freeVariables: Identifiers{ "aux", }, @@ -75685,7 +77289,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5222, + context: p6826, freeVariables: Identifiers{ "n_", "std", @@ -75705,7 +77309,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5222, + context: p6826, freeVariables: Identifiers{ "std", }, @@ -75724,7 +77328,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5222, + context: p6826, freeVariables: Identifiers{ "std", }, @@ -75770,7 +77374,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5231, + context: p6835, freeVariables: Identifiers{ "n_", }, @@ -75807,7 +77411,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", "dec", @@ -75836,7 +77440,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5237, + context: p6841, freeVariables: Identifiers{ "n__", }, @@ -75855,7 +77459,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5237, + context: p6841, freeVariables: Identifiers{ "n__", }, @@ -75877,7 +77481,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5237, + context: p6841, freeVariables: nil, }, Value: float64(0), @@ -75901,7 +77505,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", "dec", @@ -75930,7 +77534,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: Identifiers{ "blank", "min_chars", @@ -75952,7 +77556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: Identifiers{ "min_chars", }, @@ -75974,7 +77578,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: Identifiers{ "blank", "neg", @@ -75995,7 +77599,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: Identifiers{ "blank", "neg", @@ -76016,7 +77620,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: Identifiers{ "blank", "neg", @@ -76036,7 +77640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: Identifiers{ "neg", }, @@ -76058,7 +77662,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: Identifiers{ "blank", }, @@ -76081,7 +77685,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: Identifiers{ "sign", }, @@ -76103,7 +77707,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: nil, }, Value: float64(1), @@ -76123,7 +77727,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5246, + context: p6850, freeVariables: nil, }, Value: float64(0), @@ -76148,7 +77752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", "dec", @@ -76177,7 +77781,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5268, + context: p6872, freeVariables: Identifiers{ "min_digits", "std", @@ -76198,7 +77802,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5268, + context: p6872, freeVariables: Identifiers{ "std", }, @@ -76217,7 +77821,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5268, + context: p6872, freeVariables: Identifiers{ "std", }, @@ -76263,7 +77867,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5277, + context: p6881, freeVariables: Identifiers{ "zp", }, @@ -76284,7 +77888,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5277, + context: p6881, freeVariables: Identifiers{ "min_digits", }, @@ -76314,7 +77918,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", "dec", @@ -76341,7 +77945,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5285, + context: p6889, freeVariables: Identifiers{ "dec", "pad_left", @@ -76362,7 +77966,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5285, + context: p6889, freeVariables: Identifiers{ "pad_left", }, @@ -76385,7 +77989,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5291, + context: p6895, freeVariables: Identifiers{ "dec", }, @@ -76406,7 +78010,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5291, + context: p6895, freeVariables: Identifiers{ "zp2", }, @@ -76427,7 +78031,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5291, + context: p6895, freeVariables: nil, }, Value: "0", @@ -76457,7 +78061,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", "dec2", @@ -76479,7 +78083,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", "neg", @@ -76500,7 +78104,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "neg", }, @@ -76521,7 +78125,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: nil, }, Value: "-", @@ -76542,7 +78146,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", "sign", @@ -76562,7 +78166,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "sign", }, @@ -76583,7 +78187,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: nil, }, Value: "+", @@ -76604,7 +78208,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", }, @@ -76623,7 +78227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "blank", }, @@ -76644,7 +78248,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: nil, }, Value: " ", @@ -76665,7 +78269,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: nil, }, Value: "", @@ -76690,7 +78294,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5116, + context: p6720, freeVariables: Identifiers{ "dec2", }, @@ -76723,7 +78327,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "pad_left", @@ -76750,7 +78354,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5320, + context: p6924, freeVariables: Identifiers{ "pad_left", "std", @@ -76783,7 +78387,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "add_zerox", "blank", @@ -76813,7 +78417,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5328, + context: p6932, freeVariables: Identifiers{ "capitals", }, @@ -76832,7 +78436,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5328, + context: p6932, freeVariables: nil, }, Elements: Nodes{ @@ -76850,7 +78454,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(0), @@ -76870,7 +78474,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(1), @@ -76890,7 +78494,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(2), @@ -76910,7 +78514,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(3), @@ -76930,7 +78534,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(4), @@ -76950,7 +78554,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(5), @@ -76970,7 +78574,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(6), @@ -76990,7 +78594,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(7), @@ -77010,7 +78614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(8), @@ -77030,7 +78634,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5333, + context: p6937, freeVariables: nil, }, Value: float64(9), @@ -77054,7 +78658,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5328, + context: p6932, freeVariables: Identifiers{ "capitals", }, @@ -77073,7 +78677,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5328, + context: p6932, freeVariables: Identifiers{ "capitals", }, @@ -77094,7 +78698,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5328, + context: p6932, freeVariables: nil, }, Elements: Nodes{ @@ -77112,7 +78716,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5350, + context: p6954, freeVariables: nil, }, Value: "A", @@ -77133,7 +78737,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5350, + context: p6954, freeVariables: nil, }, Value: "B", @@ -77154,7 +78758,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5350, + context: p6954, freeVariables: nil, }, Value: "C", @@ -77175,7 +78779,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5350, + context: p6954, freeVariables: nil, }, Value: "D", @@ -77196,7 +78800,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5350, + context: p6954, freeVariables: nil, }, Value: "E", @@ -77217,7 +78821,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5350, + context: p6954, freeVariables: nil, }, Value: "F", @@ -77241,7 +78845,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5328, + context: p6932, freeVariables: nil, }, Elements: Nodes{ @@ -77259,7 +78863,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5359, + context: p6963, freeVariables: nil, }, Value: "a", @@ -77280,7 +78884,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5359, + context: p6963, freeVariables: nil, }, Value: "b", @@ -77301,7 +78905,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5359, + context: p6963, freeVariables: nil, }, Value: "c", @@ -77322,7 +78926,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5359, + context: p6963, freeVariables: nil, }, Value: "d", @@ -77343,7 +78947,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5359, + context: p6963, freeVariables: nil, }, Value: "e", @@ -77364,7 +78968,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5359, + context: p6963, freeVariables: nil, }, Value: "f", @@ -77393,7 +78997,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "add_zerox", "blank", @@ -77424,7 +79028,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5369, + context: p6973, freeVariables: Identifiers{ "n__", "std", @@ -77444,7 +79048,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5369, + context: p6973, freeVariables: Identifiers{ "std", }, @@ -77463,7 +79067,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5369, + context: p6973, freeVariables: Identifiers{ "std", }, @@ -77509,7 +79113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5378, + context: p6982, freeVariables: Identifiers{ "n__", }, @@ -77539,7 +79143,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "add_zerox", "blank", @@ -77571,7 +79175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5384, + context: p6988, freeVariables: Identifiers{ "aux", "numerals", @@ -77599,7 +79203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: Identifiers{ "aux", "n", @@ -77706,7 +79310,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: Identifiers{ "n", }, @@ -77727,7 +79331,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: nil, }, Value: float64(0), @@ -77753,7 +79357,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: nil, }, Value: "", @@ -77774,7 +79378,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: Identifiers{ "aux", "n", @@ -77796,7 +79400,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: Identifiers{ "aux", "n", @@ -77817,7 +79421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: Identifiers{ "aux", }, @@ -77840,7 +79444,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5410, + context: p7014, freeVariables: Identifiers{ "n", "std", @@ -77860,7 +79464,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5410, + context: p7014, freeVariables: Identifiers{ "std", }, @@ -77879,7 +79483,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5410, + context: p7014, freeVariables: Identifiers{ "std", }, @@ -77925,7 +79529,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5419, + context: p7023, freeVariables: Identifiers{ "n", }, @@ -77944,7 +79548,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5419, + context: p7023, freeVariables: Identifiers{ "n", }, @@ -77966,7 +79570,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5419, + context: p7023, freeVariables: nil, }, Value: float64(16), @@ -78000,7 +79604,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: Identifiers{ "n", "numerals", @@ -78021,7 +79625,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: Identifiers{ "numerals", }, @@ -78127,7 +79731,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: Identifiers{ "n", }, @@ -78148,7 +79752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5388, + context: p6992, freeVariables: nil, }, Value: float64(16), @@ -78182,7 +79786,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "add_zerox", "aux", @@ -78214,7 +79818,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5443, + context: p7047, freeVariables: Identifiers{ "aux", "n_", @@ -78320,7 +79924,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5443, + context: p7047, freeVariables: Identifiers{ "n_", "std", @@ -78340,7 +79944,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5443, + context: p7047, freeVariables: Identifiers{ "std", }, @@ -78359,7 +79963,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5443, + context: p7047, freeVariables: Identifiers{ "std", }, @@ -78405,7 +80009,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5462, + context: p7066, freeVariables: Identifiers{ "n_", }, @@ -78432,7 +80036,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5443, + context: p7047, freeVariables: nil, }, Value: float64(0), @@ -78458,7 +80062,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5443, + context: p7047, freeVariables: nil, }, Value: "0", @@ -78479,7 +80083,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5443, + context: p7047, freeVariables: Identifiers{ "aux", "n_", @@ -78500,7 +80104,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5443, + context: p7047, freeVariables: Identifiers{ "aux", }, @@ -78523,7 +80127,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5472, + context: p7076, freeVariables: Identifiers{ "n_", "std", @@ -78543,7 +80147,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5472, + context: p7076, freeVariables: Identifiers{ "std", }, @@ -78562,7 +80166,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5472, + context: p7076, freeVariables: Identifiers{ "std", }, @@ -78608,7 +80212,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5481, + context: p7085, freeVariables: Identifiers{ "n_", }, @@ -78645,7 +80249,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "add_zerox", "blank", @@ -78676,7 +80280,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5487, + context: p7091, freeVariables: Identifiers{ "n__", }, @@ -78695,7 +80299,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5487, + context: p7091, freeVariables: Identifiers{ "n__", }, @@ -78717,7 +80321,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5487, + context: p7091, freeVariables: nil, }, Value: float64(0), @@ -78741,7 +80345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "add_zerox", "blank", @@ -78772,7 +80376,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "add_zerox", "blank", @@ -78795,7 +80399,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "blank", "min_chars", @@ -78817,7 +80421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "min_chars", }, @@ -78839,7 +80443,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "blank", "neg", @@ -78860,7 +80464,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "blank", "neg", @@ -78881,7 +80485,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "blank", "neg", @@ -78901,7 +80505,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "neg", }, @@ -78923,7 +80527,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "blank", }, @@ -78946,7 +80550,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "sign", }, @@ -78968,7 +80572,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: nil, }, Value: float64(1), @@ -78988,7 +80592,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: nil, }, Value: float64(0), @@ -79011,7 +80615,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "add_zerox", }, @@ -79030,7 +80634,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: Identifiers{ "add_zerox", }, @@ -79051,7 +80655,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: nil, }, Value: float64(2), @@ -79071,7 +80675,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5496, + context: p7100, freeVariables: nil, }, Value: float64(0), @@ -79096,7 +80700,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "add_zerox", "blank", @@ -79127,7 +80731,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5526, + context: p7130, freeVariables: Identifiers{ "min_digits", "std", @@ -79148,7 +80752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5526, + context: p7130, freeVariables: Identifiers{ "std", }, @@ -79167,7 +80771,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5526, + context: p7130, freeVariables: Identifiers{ "std", }, @@ -79213,7 +80817,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5535, + context: p7139, freeVariables: Identifiers{ "zp", }, @@ -79234,7 +80838,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5535, + context: p7139, freeVariables: Identifiers{ "min_digits", }, @@ -79264,7 +80868,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "add_zerox", "blank", @@ -79293,7 +80897,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: Identifiers{ "add_zerox", "capitals", @@ -79316,7 +80920,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: Identifiers{ "add_zerox", "capitals", @@ -79336,7 +80940,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: Identifiers{ "add_zerox", }, @@ -79357,7 +80961,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: Identifiers{ "capitals", }, @@ -79376,7 +80980,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: Identifiers{ "capitals", }, @@ -79397,7 +81001,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: nil, }, Value: "0X", @@ -79418,7 +81022,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: nil, }, Value: "0x", @@ -79440,7 +81044,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: nil, }, Value: "", @@ -79463,7 +81067,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: Identifiers{ "hex", "pad_left", @@ -79484,7 +81088,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5543, + context: p7147, freeVariables: Identifiers{ "pad_left", }, @@ -79507,7 +81111,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5562, + context: p7166, freeVariables: Identifiers{ "hex", }, @@ -79528,7 +81132,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5562, + context: p7166, freeVariables: Identifiers{ "zp2", }, @@ -79549,7 +81153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5562, + context: p7166, freeVariables: nil, }, Value: "0", @@ -79580,7 +81184,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "blank", "hex2", @@ -79602,7 +81206,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "blank", "neg", @@ -79623,7 +81227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "neg", }, @@ -79644,7 +81248,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: nil, }, Value: "-", @@ -79665,7 +81269,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "blank", "sign", @@ -79685,7 +81289,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "sign", }, @@ -79706,7 +81310,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: nil, }, Value: "+", @@ -79727,7 +81331,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "blank", }, @@ -79746,7 +81350,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "blank", }, @@ -79767,7 +81371,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: nil, }, Value: " ", @@ -79788,7 +81392,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: nil, }, Value: "", @@ -79813,7 +81417,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5324, + context: p6928, freeVariables: Identifiers{ "hex2", }, @@ -79847,7 +81451,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "pad_left", @@ -79875,7 +81479,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5591, + context: p7195, freeVariables: Identifiers{ "std", }, @@ -79901,7 +81505,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5595, + context: p7199, freeVariables: Identifiers{ "std", "str", @@ -79924,7 +81528,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5599, + context: p7203, freeVariables: Identifiers{ "aux", "std", @@ -79952,7 +81556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "aux", "i", @@ -79974,7 +81578,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "i", }, @@ -79993,7 +81597,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "i", }, @@ -80015,7 +81619,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: nil, }, Value: float64(0), @@ -80036,7 +81640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: nil, }, Value: "", @@ -80057,7 +81661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "aux", "i", @@ -80165,7 +81769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "i", "str", @@ -80185,7 +81789,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "str", }, @@ -80206,7 +81810,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "i", }, @@ -80229,7 +81833,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: nil, }, Value: "0", @@ -80256,7 +81860,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "aux", "i", @@ -80277,7 +81881,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "aux", }, @@ -80300,7 +81904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5634, + context: p7238, freeVariables: Identifiers{ "str", }, @@ -80321,7 +81925,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5634, + context: p7238, freeVariables: Identifiers{ "i", }, @@ -80340,7 +81944,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5634, + context: p7238, freeVariables: Identifiers{ "i", }, @@ -80362,7 +81966,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5634, + context: p7238, freeVariables: nil, }, Value: float64(1), @@ -80389,7 +81993,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "i", "std", @@ -80410,7 +82014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "std", }, @@ -80429,7 +82033,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5603, + context: p7207, freeVariables: Identifiers{ "std", }, @@ -80475,7 +82079,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5650, + context: p7254, freeVariables: Identifiers{ "str", }, @@ -80496,7 +82100,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5650, + context: p7254, freeVariables: nil, }, Value: float64(0), @@ -80516,7 +82120,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5650, + context: p7254, freeVariables: Identifiers{ "i", }, @@ -80535,7 +82139,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5650, + context: p7254, freeVariables: Identifiers{ "i", }, @@ -80557,7 +82161,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5650, + context: p7254, freeVariables: nil, }, Value: float64(1), @@ -80590,7 +82194,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5595, + context: p7199, freeVariables: Identifiers{ "aux", "std", @@ -80611,7 +82215,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5595, + context: p7199, freeVariables: Identifiers{ "aux", }, @@ -80634,7 +82238,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5664, + context: p7268, freeVariables: Identifiers{ "str", }, @@ -80655,7 +82259,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5664, + context: p7268, freeVariables: Identifiers{ "std", "str", @@ -80675,7 +82279,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5664, + context: p7268, freeVariables: Identifiers{ "std", "str", @@ -80695,7 +82299,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5664, + context: p7268, freeVariables: Identifiers{ "std", }, @@ -80714,7 +82318,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5664, + context: p7268, freeVariables: Identifiers{ "std", }, @@ -80760,7 +82364,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5677, + context: p7281, freeVariables: Identifiers{ "str", }, @@ -80788,7 +82392,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5664, + context: p7268, freeVariables: nil, }, Value: float64(1), @@ -80820,7 +82424,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "pad_left", @@ -80849,7 +82453,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5684, + context: p7288, freeVariables: Identifiers{ "render_int", "std", @@ -80883,7 +82487,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "blank", "ensure_pt", @@ -80914,7 +82518,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5692, + context: p7296, freeVariables: Identifiers{ "n__", "std", @@ -80934,7 +82538,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5692, + context: p7296, freeVariables: Identifiers{ "std", }, @@ -80953,7 +82557,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5692, + context: p7296, freeVariables: Identifiers{ "std", }, @@ -80999,7 +82603,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5701, + context: p7305, freeVariables: Identifiers{ "n__", }, @@ -81029,7 +82633,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "blank", "ensure_pt", @@ -81061,7 +82665,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5707, + context: p7311, freeVariables: Identifiers{ "n_", "std", @@ -81081,7 +82685,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5707, + context: p7311, freeVariables: Identifiers{ "std", }, @@ -81100,7 +82704,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5707, + context: p7311, freeVariables: Identifiers{ "std", }, @@ -81146,7 +82750,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5716, + context: p7320, freeVariables: Identifiers{ "n_", }, @@ -81176,7 +82780,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "blank", "ensure_pt", @@ -81209,7 +82813,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5722, + context: p7326, freeVariables: Identifiers{ "ensure_pt", "prec", @@ -81230,7 +82834,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5722, + context: p7326, freeVariables: Identifiers{ "ensure_pt", "prec", @@ -81336,7 +82940,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5722, + context: p7326, freeVariables: Identifiers{ "prec", }, @@ -81357,7 +82961,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5722, + context: p7326, freeVariables: nil, }, Value: float64(0), @@ -81384,7 +82988,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5722, + context: p7326, freeVariables: Identifiers{ "ensure_pt", }, @@ -81404,7 +83008,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5722, + context: p7326, freeVariables: Identifiers{ "ensure_pt", }, @@ -81427,7 +83031,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5722, + context: p7326, freeVariables: nil, }, Value: float64(0), @@ -81447,7 +83051,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5722, + context: p7326, freeVariables: nil, }, Value: float64(1), @@ -81471,7 +83075,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "blank", "dot_size", @@ -81505,7 +83109,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5747, + context: p7351, freeVariables: Identifiers{ "dot_size", "prec", @@ -81526,7 +83130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5747, + context: p7351, freeVariables: Identifiers{ "prec", "zero_pad", @@ -81546,7 +83150,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5747, + context: p7351, freeVariables: Identifiers{ "zero_pad", }, @@ -81568,7 +83172,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5747, + context: p7351, freeVariables: Identifiers{ "prec", }, @@ -81591,7 +83195,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5747, + context: p7351, freeVariables: Identifiers{ "dot_size", }, @@ -81616,7 +83220,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "blank", "ensure_pt", @@ -81649,7 +83253,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5761, + context: p7365, freeVariables: Identifiers{ "blank", "n__", @@ -81674,7 +83278,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5761, + context: p7365, freeVariables: Identifiers{ "render_int", }, @@ -81697,7 +83301,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: Identifiers{ "n__", "std", @@ -81718,7 +83322,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: Identifiers{ "n__", "std", @@ -81738,7 +83342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: Identifiers{ "std", }, @@ -81757,7 +83361,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: Identifiers{ "std", }, @@ -81803,7 +83407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5778, + context: p7382, freeVariables: Identifiers{ "n__", }, @@ -81831,7 +83435,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: Identifiers{ "whole", }, @@ -81853,7 +83457,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: Identifiers{ "zp", }, @@ -81874,7 +83478,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: nil, }, Value: float64(0), @@ -81894,7 +83498,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: Identifiers{ "blank", }, @@ -81915,7 +83519,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: Identifiers{ "sign", }, @@ -81936,7 +83540,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: nil, }, Value: float64(10), @@ -81956,7 +83560,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5767, + context: p7371, freeVariables: nil, }, Value: "", @@ -81986,7 +83590,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "ensure_pt", "n_", @@ -82098,7 +83702,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "prec", }, @@ -82119,7 +83723,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: nil, }, Value: float64(0), @@ -82145,7 +83749,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "ensure_pt", "str", @@ -82165,7 +83769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "str", }, @@ -82187,7 +83791,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "ensure_pt", }, @@ -82206,7 +83810,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "ensure_pt", }, @@ -82227,7 +83831,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: nil, }, Value: ".", @@ -82248,7 +83852,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: nil, }, Value: "", @@ -82271,7 +83875,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "n_", "prec", @@ -82300,7 +83904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5818, + context: p7422, freeVariables: Identifiers{ "n_", "prec", @@ -82322,7 +83926,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5818, + context: p7422, freeVariables: Identifiers{ "std", }, @@ -82341,7 +83945,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5818, + context: p7422, freeVariables: Identifiers{ "std", }, @@ -82387,7 +83991,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5827, + context: p7431, freeVariables: Identifiers{ "n_", "prec", @@ -82409,7 +84013,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5827, + context: p7431, freeVariables: Identifiers{ "n_", "prec", @@ -82431,7 +84035,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5827, + context: p7431, freeVariables: Identifiers{ "n_", "whole", @@ -82451,7 +84055,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5827, + context: p7431, freeVariables: Identifiers{ "n_", }, @@ -82473,7 +84077,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5827, + context: p7431, freeVariables: Identifiers{ "whole", }, @@ -82496,7 +84100,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5827, + context: p7431, freeVariables: Identifiers{ "prec", "std", @@ -82516,7 +84120,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5827, + context: p7431, freeVariables: Identifiers{ "std", }, @@ -82535,7 +84139,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5827, + context: p7431, freeVariables: Identifiers{ "std", }, @@ -82581,7 +84185,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5846, + context: p7450, freeVariables: nil, }, Value: float64(10), @@ -82601,7 +84205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5846, + context: p7450, freeVariables: Identifiers{ "prec", }, @@ -82630,7 +84234,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5827, + context: p7431, freeVariables: nil, }, Value: float64(0.5), @@ -82660,7 +84264,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "frac", "prec", @@ -82684,7 +84288,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "frac", "trailing", @@ -82704,7 +84308,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "trailing", }, @@ -82726,7 +84330,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "frac", }, @@ -82745,7 +84349,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "frac", }, @@ -82767,7 +84371,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: nil, }, Value: float64(0), @@ -82789,7 +84393,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "frac", "prec", @@ -82816,7 +84420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5865, + context: p7469, freeVariables: Identifiers{ "frac", "prec", @@ -82837,7 +84441,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5865, + context: p7469, freeVariables: Identifiers{ "render_int", }, @@ -82860,7 +84464,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5871, + context: p7475, freeVariables: Identifiers{ "frac", }, @@ -82881,7 +84485,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5871, + context: p7475, freeVariables: Identifiers{ "prec", }, @@ -82902,7 +84506,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5871, + context: p7475, freeVariables: nil, }, Value: float64(0), @@ -82922,7 +84526,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5871, + context: p7475, freeVariables: nil, }, Value: false, @@ -82941,7 +84545,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5871, + context: p7475, freeVariables: nil, }, Value: false, @@ -82960,7 +84564,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5871, + context: p7475, freeVariables: nil, }, Value: float64(10), @@ -82980,7 +84584,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5871, + context: p7475, freeVariables: nil, }, Value: "", @@ -83010,7 +84614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "frac_str", "str", @@ -83032,7 +84636,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "str", }, @@ -83051,7 +84655,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "str", }, @@ -83073,7 +84677,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: nil, }, Value: ".", @@ -83096,7 +84700,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "frac_str", "strip_trailing_zero", @@ -83117,7 +84721,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "trailing", }, @@ -83137,7 +84741,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "trailing", }, @@ -83159,7 +84763,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "frac_str", "strip_trailing_zero", @@ -83179,7 +84783,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "strip_trailing_zero", }, @@ -83202,7 +84806,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5899, + context: p7503, freeVariables: Identifiers{ "frac_str", }, @@ -83229,7 +84833,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "frac_str", }, @@ -83253,7 +84857,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5688, + context: p7292, freeVariables: Identifiers{ "str", }, @@ -83286,7 +84890,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "pad_left", @@ -83315,7 +84919,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5909, + context: p7513, freeVariables: Identifiers{ "render_float_dec", "render_int", @@ -83350,7 +84954,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5913, + context: p7517, freeVariables: Identifiers{ "blank", "caps", @@ -83382,7 +84986,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5917, + context: p7521, freeVariables: Identifiers{ "n__", "std", @@ -83402,7 +85006,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5917, + context: p7521, freeVariables: Identifiers{ "std", }, @@ -83421,7 +85025,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5917, + context: p7521, freeVariables: Identifiers{ "std", }, @@ -83467,7 +85071,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5926, + context: p7530, freeVariables: Identifiers{ "n__", "std", @@ -83487,7 +85091,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5926, + context: p7530, freeVariables: Identifiers{ "n__", "std", @@ -83507,7 +85111,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5926, + context: p7530, freeVariables: Identifiers{ "std", }, @@ -83526,7 +85130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5926, + context: p7530, freeVariables: Identifiers{ "std", }, @@ -83572,7 +85176,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5937, + context: p7541, freeVariables: Identifiers{ "n__", "std", @@ -83592,7 +85196,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5937, + context: p7541, freeVariables: Identifiers{ "std", }, @@ -83611,7 +85215,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5937, + context: p7541, freeVariables: Identifiers{ "std", }, @@ -83657,7 +85261,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5946, + context: p7550, freeVariables: Identifiers{ "n__", }, @@ -83691,7 +85295,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5926, + context: p7530, freeVariables: Identifiers{ "std", }, @@ -83710,7 +85314,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5926, + context: p7530, freeVariables: Identifiers{ "std", }, @@ -83729,7 +85333,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5926, + context: p7530, freeVariables: Identifiers{ "std", }, @@ -83775,7 +85379,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5957, + context: p7561, freeVariables: nil, }, Value: float64(10), @@ -83811,7 +85415,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5913, + context: p7517, freeVariables: Identifiers{ "blank", "caps", @@ -83844,7 +85448,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5962, + context: p7566, freeVariables: Identifiers{ "caps", "exponent", @@ -83865,7 +85469,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5962, + context: p7566, freeVariables: Identifiers{ "caps", }, @@ -83884,7 +85488,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5962, + context: p7566, freeVariables: Identifiers{ "caps", }, @@ -83905,7 +85509,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5962, + context: p7566, freeVariables: nil, }, Value: "E", @@ -83926,7 +85530,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5962, + context: p7566, freeVariables: nil, }, Value: "e", @@ -83949,7 +85553,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5962, + context: p7566, freeVariables: Identifiers{ "exponent", "render_int", @@ -83969,7 +85573,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5962, + context: p7566, freeVariables: Identifiers{ "render_int", }, @@ -83992,7 +85596,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5976, + context: p7580, freeVariables: Identifiers{ "exponent", }, @@ -84013,7 +85617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5976, + context: p7580, freeVariables: nil, }, Value: float64(3), @@ -84033,7 +85637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5976, + context: p7580, freeVariables: nil, }, Value: float64(0), @@ -84053,7 +85657,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5976, + context: p7580, freeVariables: nil, }, Value: false, @@ -84072,7 +85676,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5976, + context: p7580, freeVariables: nil, }, Value: true, @@ -84091,7 +85695,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5976, + context: p7580, freeVariables: nil, }, Value: float64(10), @@ -84111,7 +85715,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5976, + context: p7580, freeVariables: nil, }, Value: "", @@ -84142,7 +85746,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5913, + context: p7517, freeVariables: Identifiers{ "blank", "ensure_pt", @@ -84174,7 +85778,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5988, + context: p7592, freeVariables: Identifiers{ "exponent", "n__", @@ -84195,7 +85799,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5988, + context: p7592, freeVariables: Identifiers{ "n__", }, @@ -84217,7 +85821,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5988, + context: p7592, freeVariables: Identifiers{ "exponent", "std", @@ -84237,7 +85841,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5988, + context: p7592, freeVariables: Identifiers{ "std", }, @@ -84256,7 +85860,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5988, + context: p7592, freeVariables: Identifiers{ "std", }, @@ -84302,7 +85906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6001, + context: p7605, freeVariables: nil, }, Value: float64(10), @@ -84322,7 +85926,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6001, + context: p7605, freeVariables: Identifiers{ "exponent", }, @@ -84353,7 +85957,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5913, + context: p7517, freeVariables: Identifiers{ "blank", "ensure_pt", @@ -84384,7 +85988,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6008, + context: p7612, freeVariables: Identifiers{ "std", "suff", @@ -84405,7 +86009,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6008, + context: p7612, freeVariables: Identifiers{ "zero_pad", }, @@ -84427,7 +86031,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6008, + context: p7612, freeVariables: Identifiers{ "std", "suff", @@ -84447,7 +86051,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6008, + context: p7612, freeVariables: Identifiers{ "std", }, @@ -84466,7 +86070,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6008, + context: p7612, freeVariables: Identifiers{ "std", }, @@ -84512,7 +86116,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6021, + context: p7625, freeVariables: Identifiers{ "suff", }, @@ -84543,7 +86147,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5913, + context: p7517, freeVariables: Identifiers{ "blank", "ensure_pt", @@ -84570,7 +86174,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5913, + context: p7517, freeVariables: Identifiers{ "blank", "ensure_pt", @@ -84596,7 +86200,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5913, + context: p7517, freeVariables: Identifiers{ "render_float_dec", }, @@ -84619,7 +86223,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6031, + context: p7635, freeVariables: Identifiers{ "mantissa", }, @@ -84640,7 +86244,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6031, + context: p7635, freeVariables: Identifiers{ "zp2", }, @@ -84661,7 +86265,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6031, + context: p7635, freeVariables: Identifiers{ "blank", }, @@ -84682,7 +86286,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6031, + context: p7635, freeVariables: Identifiers{ "sign", }, @@ -84703,7 +86307,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6031, + context: p7635, freeVariables: Identifiers{ "ensure_pt", }, @@ -84724,7 +86328,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6031, + context: p7635, freeVariables: Identifiers{ "trailing", }, @@ -84745,7 +86349,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6031, + context: p7635, freeVariables: Identifiers{ "prec", }, @@ -84773,7 +86377,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p5913, + context: p7517, freeVariables: Identifiers{ "suff", }, @@ -84803,7 +86407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "pad_left", @@ -84833,7 +86437,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6051, + context: p7655, freeVariables: Identifiers{ "render_float_dec", "render_float_sci", @@ -84867,7 +86471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", "fw", @@ -84898,7 +86502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6059, + context: p7663, freeVariables: Identifiers{ "code", }, @@ -84917,7 +86521,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6059, + context: p7663, freeVariables: Identifiers{ "code", }, @@ -84964,7 +86568,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -84996,7 +86600,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6068, + context: p7672, freeVariables: Identifiers{ "prec_or_null", "std", @@ -85122,7 +86726,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6068, + context: p7672, freeVariables: Identifiers{ "prec_or_null", }, @@ -85143,7 +86747,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6068, + context: p7672, freeVariables: nil, }, }, @@ -85168,7 +86772,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6068, + context: p7672, freeVariables: Identifiers{ "prec_or_null", }, @@ -85189,7 +86793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6068, + context: p7672, freeVariables: nil, }, Value: float64(6), @@ -85213,7 +86817,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -85246,7 +86850,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6090, + context: p7694, freeVariables: Identifiers{ "prec_or_null", "std", @@ -85372,7 +86976,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6090, + context: p7694, freeVariables: Identifiers{ "prec_or_null", }, @@ -85393,7 +86997,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6090, + context: p7694, freeVariables: nil, }, }, @@ -85418,7 +87022,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6090, + context: p7694, freeVariables: Identifiers{ "prec_or_null", }, @@ -85439,7 +87043,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6090, + context: p7694, freeVariables: nil, }, Value: float64(0), @@ -85463,7 +87067,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -85496,7 +87100,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6112, + context: p7716, freeVariables: Identifiers{ "cflags", "fw", @@ -85516,7 +87120,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6112, + context: p7716, freeVariables: Identifiers{ "cflags", }, @@ -85535,7 +87139,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6112, + context: p7716, freeVariables: Identifiers{ "cflags", }, @@ -85554,7 +87158,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6112, + context: p7716, freeVariables: Identifiers{ "cflags", }, @@ -85599,7 +87203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6112, + context: p7716, freeVariables: Identifiers{ "cflags", }, @@ -85619,7 +87223,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6112, + context: p7716, freeVariables: Identifiers{ "cflags", }, @@ -85638,7 +87242,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6112, + context: p7716, freeVariables: Identifiers{ "cflags", }, @@ -85684,7 +87288,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6112, + context: p7716, freeVariables: Identifiers{ "fw", }, @@ -85705,7 +87309,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6112, + context: p7716, freeVariables: nil, }, Value: float64(0), @@ -85729,7 +87333,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -85844,7 +87448,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -85863,7 +87467,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -85907,7 +87511,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "s", @@ -85934,7 +87538,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -85954,7 +87558,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -85973,7 +87577,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -86019,7 +87623,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6156, + context: p7760, freeVariables: Identifiers{ "val", }, @@ -86046,7 +87650,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -86161,7 +87765,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -86180,7 +87784,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -86224,7 +87828,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "d", @@ -86251,7 +87855,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "i", @@ -86382,7 +87986,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -86402,7 +88006,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -86421,7 +88025,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -86467,7 +88071,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6195, + context: p7799, freeVariables: Identifiers{ "val", }, @@ -86494,7 +88098,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "number", @@ -86522,7 +88126,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -86543,7 +88147,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -86564,7 +88168,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -86583,7 +88187,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -86602,7 +88206,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "Format required number at ", @@ -86624,7 +88228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -86647,7 +88251,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: ", got ", @@ -86670,7 +88274,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -86690,7 +88294,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -86709,7 +88313,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -86755,7 +88359,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6219, + context: p7823, freeVariables: Identifiers{ "val", }, @@ -86784,7 +88388,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "iprec", @@ -86807,7 +88411,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "render_int", }, @@ -86830,7 +88434,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6227, + context: p7831, freeVariables: Identifiers{ "val", }, @@ -86851,7 +88455,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6227, + context: p7831, freeVariables: Identifiers{ "zp", }, @@ -86872,7 +88476,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6227, + context: p7831, freeVariables: Identifiers{ "iprec", }, @@ -86893,7 +88497,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6227, + context: p7831, freeVariables: Identifiers{ "cflags", }, @@ -86912,7 +88516,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6227, + context: p7831, freeVariables: Identifiers{ "cflags", }, @@ -86956,7 +88560,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6227, + context: p7831, freeVariables: Identifiers{ "cflags", }, @@ -86975,7 +88579,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6227, + context: p7831, freeVariables: Identifiers{ "cflags", }, @@ -87019,7 +88623,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6227, + context: p7831, freeVariables: nil, }, Value: float64(10), @@ -87039,7 +88643,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6227, + context: p7831, freeVariables: nil, }, Value: "", @@ -87067,7 +88671,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -87182,7 +88786,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -87201,7 +88805,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -87245,7 +88849,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "o", @@ -87272,7 +88876,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "i", @@ -87403,7 +89007,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -87423,7 +89027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -87442,7 +89046,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -87488,7 +89092,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6282, + context: p7886, freeVariables: Identifiers{ "val", }, @@ -87515,7 +89119,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "number", @@ -87543,7 +89147,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -87564,7 +89168,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -87585,7 +89189,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -87604,7 +89208,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -87623,7 +89227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "Format required number at ", @@ -87645,7 +89249,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -87668,7 +89272,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: ", got ", @@ -87691,7 +89295,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -87711,7 +89315,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -87730,7 +89334,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -87776,7 +89380,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6306, + context: p7910, freeVariables: Identifiers{ "val", }, @@ -87805,7 +89409,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "iprec", @@ -87831,7 +89435,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6312, + context: p7916, freeVariables: Identifiers{ "cflags", }, @@ -87850,7 +89454,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6312, + context: p7916, freeVariables: Identifiers{ "cflags", }, @@ -87869,7 +89473,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6312, + context: p7916, freeVariables: Identifiers{ "cflags", }, @@ -87913,7 +89517,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6312, + context: p7916, freeVariables: nil, }, Value: "0", @@ -87934,7 +89538,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6312, + context: p7916, freeVariables: nil, }, Value: "", @@ -87959,7 +89563,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "iprec", @@ -87983,7 +89587,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "render_int", }, @@ -88006,7 +89610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6327, + context: p7931, freeVariables: Identifiers{ "val", }, @@ -88027,7 +89631,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6327, + context: p7931, freeVariables: Identifiers{ "zp", }, @@ -88048,7 +89652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6327, + context: p7931, freeVariables: Identifiers{ "iprec", }, @@ -88069,7 +89673,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6327, + context: p7931, freeVariables: Identifiers{ "cflags", }, @@ -88088,7 +89692,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6327, + context: p7931, freeVariables: Identifiers{ "cflags", }, @@ -88132,7 +89736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6327, + context: p7931, freeVariables: Identifiers{ "cflags", }, @@ -88151,7 +89755,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6327, + context: p7931, freeVariables: Identifiers{ "cflags", }, @@ -88195,7 +89799,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6327, + context: p7931, freeVariables: nil, }, Value: float64(8), @@ -88215,7 +89819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6327, + context: p7931, freeVariables: Identifiers{ "zero_prefix", }, @@ -88244,7 +89848,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -88358,7 +89962,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -88377,7 +89981,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -88421,7 +90025,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "x", @@ -88448,7 +90052,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -88580,7 +90184,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -88600,7 +90204,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -88619,7 +90223,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -88665,7 +90269,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6383, + context: p7987, freeVariables: Identifiers{ "val", }, @@ -88692,7 +90296,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "number", @@ -88720,7 +90324,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -88741,7 +90345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -88762,7 +90366,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -88781,7 +90385,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -88800,7 +90404,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "Format required number at ", @@ -88822,7 +90426,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -88845,7 +90449,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: ", got ", @@ -88868,7 +90472,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -88888,7 +90492,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -88907,7 +90511,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -88953,7 +90557,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6407, + context: p8011, freeVariables: Identifiers{ "val", }, @@ -88982,7 +90586,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -89006,7 +90610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "render_hex", }, @@ -89029,7 +90633,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "val", }, @@ -89050,7 +90654,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "zp", }, @@ -89071,7 +90675,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "iprec", }, @@ -89092,7 +90696,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "cflags", }, @@ -89111,7 +90715,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "cflags", }, @@ -89155,7 +90759,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "cflags", }, @@ -89174,7 +90778,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "cflags", }, @@ -89218,7 +90822,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "cflags", }, @@ -89237,7 +90841,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "cflags", }, @@ -89281,7 +90885,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "code", }, @@ -89300,7 +90904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6415, + context: p8019, freeVariables: Identifiers{ "code", }, @@ -89351,7 +90955,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -89463,7 +91067,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -89482,7 +91086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -89526,7 +91130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "f", @@ -89553,7 +91157,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "fpprec", @@ -89684,7 +91288,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -89704,7 +91308,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -89723,7 +91327,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -89769,7 +91373,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6478, + context: p8082, freeVariables: Identifiers{ "val", }, @@ -89796,7 +91400,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "number", @@ -89824,7 +91428,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -89845,7 +91449,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -89866,7 +91470,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -89885,7 +91489,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -89904,7 +91508,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "Format required number at ", @@ -89926,7 +91530,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -89949,7 +91553,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: ", got ", @@ -89972,7 +91576,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -89992,7 +91596,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -90011,7 +91615,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -90057,7 +91661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6502, + context: p8106, freeVariables: Identifiers{ "val", }, @@ -90086,7 +91690,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "fpprec", @@ -90109,7 +91713,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "render_float_dec", }, @@ -90132,7 +91736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: Identifiers{ "val", }, @@ -90153,7 +91757,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: Identifiers{ "zp", }, @@ -90174,7 +91778,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: Identifiers{ "cflags", }, @@ -90193,7 +91797,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: Identifiers{ "cflags", }, @@ -90237,7 +91841,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: Identifiers{ "cflags", }, @@ -90256,7 +91860,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: Identifiers{ "cflags", }, @@ -90300,7 +91904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: Identifiers{ "cflags", }, @@ -90319,7 +91923,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: Identifiers{ "cflags", }, @@ -90363,7 +91967,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: nil, }, Value: true, @@ -90382,7 +91986,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6510, + context: p8114, freeVariables: Identifiers{ "fpprec", }, @@ -90410,7 +92014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -90522,7 +92126,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -90541,7 +92145,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -90585,7 +92189,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "e", @@ -90612,7 +92216,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -90744,7 +92348,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -90764,7 +92368,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -90783,7 +92387,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -90829,7 +92433,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6569, + context: p8173, freeVariables: Identifiers{ "val", }, @@ -90856,7 +92460,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "number", @@ -90884,7 +92488,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -90905,7 +92509,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -90926,7 +92530,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -90945,7 +92549,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -90964,7 +92568,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "Format required number at ", @@ -90986,7 +92590,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -91009,7 +92613,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: ", got ", @@ -91032,7 +92636,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -91052,7 +92656,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -91071,7 +92675,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -91117,7 +92721,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6593, + context: p8197, freeVariables: Identifiers{ "val", }, @@ -91146,7 +92750,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -91170,7 +92774,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "render_float_sci", }, @@ -91193,7 +92797,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "val", }, @@ -91214,7 +92818,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "zp", }, @@ -91235,7 +92839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "cflags", }, @@ -91254,7 +92858,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "cflags", }, @@ -91298,7 +92902,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "cflags", }, @@ -91317,7 +92921,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "cflags", }, @@ -91361,7 +92965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "cflags", }, @@ -91380,7 +92984,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "cflags", }, @@ -91424,7 +93028,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: nil, }, Value: true, @@ -91443,7 +93047,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "code", }, @@ -91462,7 +93066,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "code", }, @@ -91506,7 +93110,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6601, + context: p8205, freeVariables: Identifiers{ "fpprec", }, @@ -91534,7 +93138,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -91646,7 +93250,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -91665,7 +93269,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -91709,7 +93313,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "g", @@ -91736,7 +93340,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -91869,7 +93473,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -91889,7 +93493,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -91908,7 +93512,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -91954,7 +93558,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6665, + context: p8269, freeVariables: Identifiers{ "val", }, @@ -91981,7 +93585,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "number", @@ -92009,7 +93613,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -92030,7 +93634,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", "std", @@ -92051,7 +93655,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -92070,7 +93674,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -92089,7 +93693,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "Format required number at ", @@ -92111,7 +93715,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "i", }, @@ -92134,7 +93738,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: ", got ", @@ -92157,7 +93761,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -92177,7 +93781,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -92196,7 +93800,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -92242,7 +93846,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6689, + context: p8293, freeVariables: Identifiers{ "val", }, @@ -92271,7 +93875,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -92300,7 +93904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6695, + context: p8299, freeVariables: Identifiers{ "std", "val", @@ -92320,7 +93924,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6695, + context: p8299, freeVariables: Identifiers{ "std", }, @@ -92339,7 +93943,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6695, + context: p8299, freeVariables: Identifiers{ "std", }, @@ -92385,7 +93989,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6704, + context: p8308, freeVariables: Identifiers{ "std", "val", @@ -92405,7 +94009,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6704, + context: p8308, freeVariables: Identifiers{ "std", "val", @@ -92425,7 +94029,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6704, + context: p8308, freeVariables: Identifiers{ "std", }, @@ -92444,7 +94048,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6704, + context: p8308, freeVariables: Identifiers{ "std", }, @@ -92490,7 +94094,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6715, + context: p8319, freeVariables: Identifiers{ "std", "val", @@ -92510,7 +94114,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6715, + context: p8319, freeVariables: Identifiers{ "std", }, @@ -92529,7 +94133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6715, + context: p8319, freeVariables: Identifiers{ "std", }, @@ -92575,7 +94179,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6724, + context: p8328, freeVariables: Identifiers{ "val", }, @@ -92609,7 +94213,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6704, + context: p8308, freeVariables: Identifiers{ "std", }, @@ -92628,7 +94232,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6704, + context: p8308, freeVariables: Identifiers{ "std", }, @@ -92647,7 +94251,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6704, + context: p8308, freeVariables: Identifiers{ "std", }, @@ -92693,7 +94297,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6735, + context: p8339, freeVariables: nil, }, Value: float64(10), @@ -92729,7 +94333,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -92756,7 +94360,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "exponent", "fpprec", @@ -92776,7 +94380,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "exponent", }, @@ -92795,7 +94399,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "exponent", }, @@ -92817,7 +94421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Op: UnaryOp(3), @@ -92835,7 +94439,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: float64(4), @@ -92858,7 +94462,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "exponent", "fpprec", @@ -92878,7 +94482,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "exponent", }, @@ -92900,7 +94504,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "fpprec", }, @@ -92923,7 +94527,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "code", @@ -92947,7 +94551,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "render_float_sci", }, @@ -92970,7 +94574,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "val", }, @@ -92991,7 +94595,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "zp", }, @@ -93012,7 +94616,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "cflags", }, @@ -93031,7 +94635,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "cflags", }, @@ -93075,7 +94679,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "cflags", }, @@ -93094,7 +94698,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "cflags", }, @@ -93138,7 +94742,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "cflags", }, @@ -93157,7 +94761,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "cflags", }, @@ -93201,7 +94805,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "cflags", }, @@ -93220,7 +94824,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "cflags", }, @@ -93264,7 +94868,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "code", }, @@ -93283,7 +94887,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "code", }, @@ -93327,7 +94931,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "fpprec", }, @@ -93346,7 +94950,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: Identifiers{ "fpprec", }, @@ -93368,7 +94972,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6758, + context: p8362, freeVariables: nil, }, Value: float64(1), @@ -93395,7 +94999,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "exponent", @@ -93423,7 +95027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6796, + context: p8400, freeVariables: Identifiers{ "exponent", "std", @@ -93443,7 +95047,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6796, + context: p8400, freeVariables: Identifiers{ "std", }, @@ -93462,7 +95066,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6796, + context: p8400, freeVariables: Identifiers{ "std", }, @@ -93508,7 +95112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6805, + context: p8409, freeVariables: nil, }, Value: float64(1), @@ -93528,7 +95132,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6805, + context: p8409, freeVariables: Identifiers{ "exponent", }, @@ -93547,7 +95151,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6805, + context: p8409, freeVariables: Identifiers{ "exponent", }, @@ -93569,7 +95173,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6805, + context: p8409, freeVariables: nil, }, Value: float64(1), @@ -93599,7 +95203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "cflags", "digits_before_pt", @@ -93623,7 +95227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "render_float_dec", }, @@ -93646,7 +95250,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "val", }, @@ -93667,7 +95271,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "zp", }, @@ -93688,7 +95292,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "cflags", }, @@ -93707,7 +95311,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "cflags", }, @@ -93751,7 +95355,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "cflags", }, @@ -93770,7 +95374,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "cflags", }, @@ -93814,7 +95418,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "cflags", }, @@ -93833,7 +95437,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "cflags", }, @@ -93877,7 +95481,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "cflags", }, @@ -93896,7 +95500,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "cflags", }, @@ -93940,7 +95544,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "digits_before_pt", "fpprec", @@ -93960,7 +95564,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "fpprec", }, @@ -93982,7 +95586,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6817, + context: p8421, freeVariables: Identifiers{ "digits_before_pt", }, @@ -94014,7 +95618,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", "std", @@ -94120,7 +95724,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -94139,7 +95743,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -94183,7 +95787,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "c", @@ -94210,7 +95814,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -94315,7 +95919,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -94335,7 +95939,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -94354,7 +95958,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -94400,7 +96004,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6882, + context: p8486, freeVariables: Identifiers{ "val", }, @@ -94427,7 +96031,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "number", @@ -94454,7 +96058,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -94474,7 +96078,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -94493,7 +96097,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -94539,7 +96143,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6894, + context: p8498, freeVariables: Identifiers{ "val", }, @@ -94566,7 +96170,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -94671,7 +96275,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -94691,7 +96295,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -94710,7 +96314,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -94756,7 +96360,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6915, + context: p8519, freeVariables: Identifiers{ "val", }, @@ -94783,7 +96387,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "string", @@ -94810,7 +96414,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -94915,7 +96519,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -94935,7 +96539,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -94954,7 +96558,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -95000,7 +96604,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6937, + context: p8541, freeVariables: Identifiers{ "val", }, @@ -95027,7 +96631,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: float64(1), @@ -95053,7 +96657,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "val", }, @@ -95074,7 +96678,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -95094,7 +96698,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -95114,7 +96718,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "%c expected 1-sized string got: ", @@ -95136,7 +96740,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -95156,7 +96760,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -95175,7 +96779,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -95221,7 +96825,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6956, + context: p8560, freeVariables: Identifiers{ "val", }, @@ -95251,7 +96855,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -95271,7 +96875,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -95291,7 +96895,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "%c expected number / string, got: ", @@ -95313,7 +96917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", "val", @@ -95333,7 +96937,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -95352,7 +96956,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "std", }, @@ -95398,7 +97002,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6972, + context: p8576, freeVariables: Identifiers{ "val", }, @@ -95429,7 +97033,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -95448,7 +97052,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -95467,7 +97071,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: nil, }, Value: "Unknown code: ", @@ -95489,7 +97093,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -95508,7 +97112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6055, + context: p7659, freeVariables: Identifiers{ "code", }, @@ -95570,7 +97174,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "format_code", @@ -95597,7 +97201,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6988, + context: p8592, freeVariables: Identifiers{ "format_code", "format_codes_arr", @@ -95631,7 +97235,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "codes", @@ -95659,7 +97263,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "codes", "i", @@ -95680,7 +97284,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "i", }, @@ -95702,7 +97306,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "codes", "std", @@ -95722,7 +97326,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "std", }, @@ -95741,7 +97345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "std", }, @@ -95787,7 +97391,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7007, + context: p8611, freeVariables: Identifiers{ "codes", }, @@ -95815,7 +97419,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "j", @@ -95837,7 +97441,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "j", @@ -95858,7 +97462,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "j", }, @@ -95880,7 +97484,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "std", @@ -95900,7 +97504,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "std", }, @@ -95919,7 +97523,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "std", }, @@ -95965,7 +97569,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7024, + context: p8628, freeVariables: Identifiers{ "arr", }, @@ -95993,7 +97597,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "j", @@ -96014,7 +97618,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "j", @@ -96035,7 +97639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "std", @@ -96055,7 +97659,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "std", @@ -96075,7 +97679,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: nil, }, Value: "Too many values to format: ", @@ -96097,7 +97701,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "std", @@ -96117,7 +97721,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "std", }, @@ -96136,7 +97740,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "std", }, @@ -96182,7 +97786,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7044, + context: p8648, freeVariables: Identifiers{ "arr", }, @@ -96211,7 +97815,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: nil, }, Value: ", expected ", @@ -96234,7 +97838,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "j", }, @@ -96257,7 +97861,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "v", }, @@ -96279,7 +97883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "codes", @@ -96310,7 +97914,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7055, + context: p8659, freeVariables: Identifiers{ "codes", "i", @@ -96330,7 +97934,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7055, + context: p8659, freeVariables: Identifiers{ "codes", }, @@ -96351,7 +97955,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7055, + context: p8659, freeVariables: Identifiers{ "i", }, @@ -96377,7 +97981,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "code", @@ -96491,7 +98095,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "code", "std", @@ -96511,7 +98115,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "std", }, @@ -96530,7 +98134,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "std", }, @@ -96576,7 +98180,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7080, + context: p8684, freeVariables: Identifiers{ "code", }, @@ -96603,7 +98207,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: nil, }, Value: "string", @@ -96630,7 +98234,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "code", @@ -96655,7 +98259,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "format_codes_arr", }, @@ -96678,7 +98282,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7089, + context: p8693, freeVariables: Identifiers{ "codes", }, @@ -96699,7 +98303,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7089, + context: p8693, freeVariables: Identifiers{ "arr", }, @@ -96720,7 +98324,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7089, + context: p8693, freeVariables: Identifiers{ "i", }, @@ -96739,7 +98343,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7089, + context: p8693, freeVariables: Identifiers{ "i", }, @@ -96761,7 +98365,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7089, + context: p8693, freeVariables: nil, }, Value: float64(1), @@ -96782,7 +98386,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7089, + context: p8693, freeVariables: Identifiers{ "j", }, @@ -96803,7 +98407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7089, + context: p8693, freeVariables: Identifiers{ "code", "v", @@ -96823,7 +98427,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7089, + context: p8693, freeVariables: Identifiers{ "v", }, @@ -96845,7 +98449,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7089, + context: p8693, freeVariables: Identifiers{ "code", }, @@ -96873,7 +98477,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "code", @@ -96905,7 +98509,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7110, + context: p8714, freeVariables: Identifiers{ "arr", "code", @@ -97012,7 +98616,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7110, + context: p8714, freeVariables: Identifiers{ "code", }, @@ -97031,7 +98635,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7110, + context: p8714, freeVariables: Identifiers{ "code", }, @@ -97075,7 +98679,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7110, + context: p8714, freeVariables: nil, }, Value: "*", @@ -97102,7 +98706,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7110, + context: p8714, freeVariables: Identifiers{ "arr", "j", @@ -97148,7 +98752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "j", }, @@ -97167,7 +98771,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "j", }, @@ -97189,7 +98793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: nil, }, Value: float64(1), @@ -97235,7 +98839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "arr", "j", @@ -97256,7 +98860,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "arr", "j", @@ -97277,7 +98881,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "j", }, @@ -97299,7 +98903,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "arr", "std", @@ -97319,7 +98923,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "std", }, @@ -97338,7 +98942,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "std", }, @@ -97384,7 +98988,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7152, + context: p8756, freeVariables: Identifiers{ "arr", }, @@ -97412,7 +99016,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "arr", "std", @@ -97432,7 +99036,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "arr", "std", @@ -97452,7 +99056,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: nil, }, Value: "Not enough values to format: ", @@ -97474,7 +99078,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "arr", "std", @@ -97494,7 +99098,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "std", }, @@ -97513,7 +99117,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "std", }, @@ -97559,7 +99163,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7168, + context: p8772, freeVariables: Identifiers{ "arr", }, @@ -97588,7 +99192,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "arr", "j", @@ -97608,7 +99212,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "arr", }, @@ -97629,7 +99233,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7131, + context: p8735, freeVariables: Identifiers{ "j", }, @@ -97657,7 +99261,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7110, + context: p8714, freeVariables: Identifiers{ "code", "j", @@ -97702,7 +99306,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7181, + context: p8785, freeVariables: Identifiers{ "j", }, @@ -97748,7 +99352,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7181, + context: p8785, freeVariables: Identifiers{ "code", }, @@ -97767,7 +99371,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7181, + context: p8785, freeVariables: Identifiers{ "code", }, @@ -97819,7 +99423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "code", @@ -97851,7 +99455,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7193, + context: p8797, freeVariables: Identifiers{ "arr", "code", @@ -97958,7 +99562,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7193, + context: p8797, freeVariables: Identifiers{ "code", }, @@ -97977,7 +99581,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7193, + context: p8797, freeVariables: Identifiers{ "code", }, @@ -98021,7 +99625,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7193, + context: p8797, freeVariables: nil, }, Value: "*", @@ -98048,7 +99652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7193, + context: p8797, freeVariables: Identifiers{ "arr", "std", @@ -98094,7 +99698,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "tmp", }, @@ -98113,7 +99717,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "tmp", }, @@ -98132,7 +99736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "tmp", }, @@ -98177,7 +99781,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: nil, }, Value: float64(1), @@ -98223,7 +99827,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "arr", "std", @@ -98244,7 +99848,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "arr", "std", @@ -98265,7 +99869,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "tmp", }, @@ -98284,7 +99888,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "tmp", }, @@ -98329,7 +99933,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "arr", "std", @@ -98349,7 +99953,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "std", }, @@ -98368,7 +99972,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "std", }, @@ -98414,7 +100018,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7241, + context: p8845, freeVariables: Identifiers{ "arr", }, @@ -98442,7 +100046,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "arr", "std", @@ -98462,7 +100066,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "arr", "std", @@ -98482,7 +100086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: nil, }, Value: "Not enough values to format: ", @@ -98504,7 +100108,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "arr", "std", @@ -98524,7 +100128,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "std", }, @@ -98543,7 +100147,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "std", }, @@ -98589,7 +100193,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7257, + context: p8861, freeVariables: Identifiers{ "arr", }, @@ -98618,7 +100222,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "arr", "tmp", @@ -98638,7 +100242,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "arr", }, @@ -98659,7 +100263,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "tmp", }, @@ -98678,7 +100282,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7214, + context: p8818, freeVariables: Identifiers{ "tmp", }, @@ -98729,7 +100333,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7193, + context: p8797, freeVariables: Identifiers{ "code", "tmp", @@ -98774,7 +100378,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7273, + context: p8877, freeVariables: Identifiers{ "tmp", }, @@ -98793,7 +100397,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7273, + context: p8877, freeVariables: Identifiers{ "tmp", }, @@ -98862,7 +100466,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7273, + context: p8877, freeVariables: Identifiers{ "code", }, @@ -98881,7 +100485,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7273, + context: p8877, freeVariables: Identifiers{ "code", }, @@ -98933,7 +100537,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "code", @@ -98966,7 +100570,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7288, + context: p8892, freeVariables: Identifiers{ "tmp2", }, @@ -98985,7 +100589,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7288, + context: p8892, freeVariables: Identifiers{ "tmp2", }, @@ -99032,7 +100636,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "code", @@ -99066,7 +100670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "arr", "j2", @@ -99087,7 +100691,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "arr", "j2", @@ -99108,7 +100712,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "j2", }, @@ -99130,7 +100734,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "arr", "std", @@ -99150,7 +100754,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "std", }, @@ -99169,7 +100773,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "std", }, @@ -99215,7 +100819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7312, + context: p8916, freeVariables: Identifiers{ "arr", }, @@ -99243,7 +100847,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "arr", "j2", @@ -99263,7 +100867,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "arr", }, @@ -99284,7 +100888,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "j2", }, @@ -99307,7 +100911,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "arr", "std", @@ -99327,7 +100931,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "arr", "std", @@ -99347,7 +100951,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: nil, }, Value: "Not enough values to format, got ", @@ -99369,7 +100973,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "arr", "std", @@ -99389,7 +100993,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "std", }, @@ -99408,7 +101012,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7297, + context: p8901, freeVariables: Identifiers{ "std", }, @@ -99454,7 +101058,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7334, + context: p8938, freeVariables: Identifiers{ "arr", }, @@ -99487,7 +101091,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "code", @@ -99522,7 +101126,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7340, + context: p8944, freeVariables: Identifiers{ "code", "format_code", @@ -99632,7 +101236,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7340, + context: p8944, freeVariables: Identifiers{ "code", }, @@ -99651,7 +101255,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7340, + context: p8944, freeVariables: Identifiers{ "code", }, @@ -99695,7 +101299,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7340, + context: p8944, freeVariables: nil, }, Value: "%", @@ -99722,7 +101326,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7340, + context: p8944, freeVariables: nil, }, Value: "%", @@ -99743,7 +101347,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7340, + context: p8944, freeVariables: Identifiers{ "code", "format_code", @@ -99767,7 +101371,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7340, + context: p8944, freeVariables: Identifiers{ "format_code", }, @@ -99790,7 +101394,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7363, + context: p8967, freeVariables: Identifiers{ "val", }, @@ -99811,7 +101415,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7363, + context: p8967, freeVariables: Identifiers{ "code", }, @@ -99832,7 +101436,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7363, + context: p8967, freeVariables: Identifiers{ "tmp", }, @@ -99851,7 +101455,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7363, + context: p8967, freeVariables: Identifiers{ "tmp", }, @@ -99895,7 +101499,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7363, + context: p8967, freeVariables: Identifiers{ "tmp2", }, @@ -99914,7 +101518,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7363, + context: p8967, freeVariables: Identifiers{ "tmp2", }, @@ -99958,7 +101562,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7363, + context: p8967, freeVariables: Identifiers{ "j2", }, @@ -99989,7 +101593,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "code", @@ -100022,7 +101626,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7383, + context: p8987, freeVariables: Identifiers{ "code", "pad_left", @@ -100045,7 +101649,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7383, + context: p8987, freeVariables: Identifiers{ "code", }, @@ -100064,7 +101668,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7383, + context: p8987, freeVariables: Identifiers{ "code", }, @@ -100083,7 +101687,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7383, + context: p8987, freeVariables: Identifiers{ "code", }, @@ -100150,7 +101754,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7383, + context: p8987, freeVariables: Identifiers{ "pad_right", "s", @@ -100171,7 +101775,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7383, + context: p8987, freeVariables: Identifiers{ "pad_right", }, @@ -100194,7 +101798,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7399, + context: p9003, freeVariables: Identifiers{ "s", }, @@ -100215,7 +101819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7399, + context: p9003, freeVariables: Identifiers{ "tmp", }, @@ -100234,7 +101838,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7399, + context: p9003, freeVariables: Identifiers{ "tmp", }, @@ -100278,7 +101882,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7399, + context: p9003, freeVariables: nil, }, Value: " ", @@ -100305,7 +101909,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7383, + context: p8987, freeVariables: Identifiers{ "pad_left", "s", @@ -100326,7 +101930,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7383, + context: p8987, freeVariables: Identifiers{ "pad_left", }, @@ -100349,7 +101953,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7413, + context: p9017, freeVariables: Identifiers{ "s", }, @@ -100370,7 +101974,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7413, + context: p9017, freeVariables: Identifiers{ "tmp", }, @@ -100389,7 +101993,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7413, + context: p9017, freeVariables: Identifiers{ "tmp", }, @@ -100433,7 +102037,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7413, + context: p9017, freeVariables: nil, }, Value: " ", @@ -100464,7 +102068,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "code", @@ -100494,7 +102098,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7425, + context: p9029, freeVariables: Identifiers{ "code", "j2", @@ -100600,7 +102204,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7425, + context: p9029, freeVariables: Identifiers{ "code", }, @@ -100619,7 +102223,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7425, + context: p9029, freeVariables: Identifiers{ "code", }, @@ -100663,7 +102267,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7425, + context: p9029, freeVariables: nil, }, Value: "%", @@ -100690,7 +102294,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7425, + context: p9029, freeVariables: Identifiers{ "j2", }, @@ -100711,7 +102315,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7425, + context: p9029, freeVariables: Identifiers{ "j2", }, @@ -100730,7 +102334,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7425, + context: p9029, freeVariables: Identifiers{ "j2", }, @@ -100752,7 +102356,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7425, + context: p9029, freeVariables: nil, }, Value: float64(1), @@ -100777,7 +102381,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "arr", "codes", @@ -100802,7 +102406,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p6992, + context: p8596, freeVariables: Identifiers{ "format_codes_arr", }, @@ -100825,7 +102429,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7454, + context: p9058, freeVariables: Identifiers{ "codes", }, @@ -100846,7 +102450,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7454, + context: p9058, freeVariables: Identifiers{ "arr", }, @@ -100867,7 +102471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7454, + context: p9058, freeVariables: Identifiers{ "i", }, @@ -100886,7 +102490,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7454, + context: p9058, freeVariables: Identifiers{ "i", }, @@ -100908,7 +102512,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7454, + context: p9058, freeVariables: nil, }, Value: float64(1), @@ -100929,7 +102533,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7454, + context: p9058, freeVariables: Identifiers{ "j3", }, @@ -100950,7 +102554,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7454, + context: p9058, freeVariables: Identifiers{ "s_padded", "v", @@ -100970,7 +102574,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7454, + context: p9058, freeVariables: Identifiers{ "v", }, @@ -100992,7 +102596,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7454, + context: p9058, freeVariables: Identifiers{ "s_padded", }, @@ -101034,7 +102638,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "format_code", @@ -101062,7 +102666,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7475, + context: p9079, freeVariables: Identifiers{ "format_code", "format_codes_obj", @@ -101095,7 +102699,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "codes", "format_code", @@ -101122,7 +102726,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "codes", "i", @@ -101143,7 +102747,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "i", }, @@ -101165,7 +102769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "codes", "std", @@ -101185,7 +102789,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "std", }, @@ -101204,7 +102808,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "std", }, @@ -101250,7 +102854,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7494, + context: p9098, freeVariables: Identifiers{ "codes", }, @@ -101278,7 +102882,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "v", }, @@ -101299,7 +102903,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "codes", "format_code", @@ -101329,7 +102933,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7502, + context: p9106, freeVariables: Identifiers{ "codes", "i", @@ -101349,7 +102953,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7502, + context: p9106, freeVariables: Identifiers{ "codes", }, @@ -101370,7 +102974,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7502, + context: p9106, freeVariables: Identifiers{ "i", }, @@ -101396,7 +103000,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "code", "codes", @@ -101509,7 +103113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "code", "std", @@ -101529,7 +103133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "std", }, @@ -101548,7 +103152,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "std", }, @@ -101594,7 +103198,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7527, + context: p9131, freeVariables: Identifiers{ "code", }, @@ -101621,7 +103225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: nil, }, Value: "string", @@ -101648,7 +103252,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "code", "codes", @@ -101672,7 +103276,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "format_codes_obj", }, @@ -101695,7 +103299,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7536, + context: p9140, freeVariables: Identifiers{ "codes", }, @@ -101716,7 +103320,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7536, + context: p9140, freeVariables: Identifiers{ "obj", }, @@ -101737,7 +103341,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7536, + context: p9140, freeVariables: Identifiers{ "i", }, @@ -101756,7 +103360,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7536, + context: p9140, freeVariables: Identifiers{ "i", }, @@ -101778,7 +103382,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7536, + context: p9140, freeVariables: nil, }, Value: float64(1), @@ -101799,7 +103403,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7536, + context: p9140, freeVariables: Identifiers{ "code", "v", @@ -101819,7 +103423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7536, + context: p9140, freeVariables: Identifiers{ "v", }, @@ -101841,7 +103445,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7536, + context: p9140, freeVariables: Identifiers{ "code", }, @@ -101869,7 +103473,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "code", "codes", @@ -101900,7 +103504,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7555, + context: p9159, freeVariables: Identifiers{ "code", "std", @@ -102005,7 +103609,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7555, + context: p9159, freeVariables: Identifiers{ "code", }, @@ -102024,7 +103628,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7555, + context: p9159, freeVariables: Identifiers{ "code", }, @@ -102068,7 +103672,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7555, + context: p9159, freeVariables: nil, }, }, @@ -102092,7 +103696,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7555, + context: p9159, freeVariables: nil, }, Expr: &LiteralString{ @@ -102109,7 +103713,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7555, + context: p9159, freeVariables: nil, }, Value: "Mapping keys required.", @@ -102131,7 +103735,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7555, + context: p9159, freeVariables: Identifiers{ "code", }, @@ -102150,7 +103754,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7555, + context: p9159, freeVariables: Identifiers{ "code", }, @@ -102198,7 +103802,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "code", "codes", @@ -102230,7 +103834,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7582, + context: p9186, freeVariables: Identifiers{ "code", "std", @@ -102335,7 +103939,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7582, + context: p9186, freeVariables: Identifiers{ "code", }, @@ -102354,7 +103958,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7582, + context: p9186, freeVariables: Identifiers{ "code", }, @@ -102398,7 +104002,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7582, + context: p9186, freeVariables: nil, }, Value: "*", @@ -102425,7 +104029,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7582, + context: p9186, freeVariables: nil, }, Expr: &LiteralString{ @@ -102442,7 +104046,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7582, + context: p9186, freeVariables: nil, }, Value: "Cannot use * field width with object.", @@ -102464,7 +104068,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7582, + context: p9186, freeVariables: Identifiers{ "code", }, @@ -102483,7 +104087,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7582, + context: p9186, freeVariables: Identifiers{ "code", }, @@ -102531,7 +104135,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "code", "codes", @@ -102564,7 +104168,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7609, + context: p9213, freeVariables: Identifiers{ "code", "std", @@ -102669,7 +104273,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7609, + context: p9213, freeVariables: Identifiers{ "code", }, @@ -102688,7 +104292,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7609, + context: p9213, freeVariables: Identifiers{ "code", }, @@ -102732,7 +104336,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7609, + context: p9213, freeVariables: nil, }, Value: "*", @@ -102759,7 +104363,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7609, + context: p9213, freeVariables: nil, }, Expr: &LiteralString{ @@ -102776,7 +104380,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7609, + context: p9213, freeVariables: nil, }, Value: "Cannot use * precision with object.", @@ -102798,7 +104402,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7609, + context: p9213, freeVariables: Identifiers{ "code", }, @@ -102817,7 +104421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7609, + context: p9213, freeVariables: Identifiers{ "code", }, @@ -102865,7 +104469,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "code", "codes", @@ -102899,7 +104503,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "f", "obj", @@ -102920,7 +104524,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "f", "obj", @@ -102941,7 +104545,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "std", }, @@ -102960,7 +104564,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "std", }, @@ -103006,7 +104610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7647, + context: p9251, freeVariables: Identifiers{ "obj", }, @@ -103027,7 +104631,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7647, + context: p9251, freeVariables: Identifiers{ "f", }, @@ -103054,7 +104658,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "f", "obj", @@ -103074,7 +104678,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "obj", }, @@ -103095,7 +104699,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "f", }, @@ -103118,7 +104722,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "f", }, @@ -103137,7 +104741,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "f", }, @@ -103156,7 +104760,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: nil, }, Value: "No such field: ", @@ -103178,7 +104782,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7636, + context: p9240, freeVariables: Identifiers{ "f", }, @@ -103205,7 +104809,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "code", "codes", @@ -103240,7 +104844,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7668, + context: p9272, freeVariables: Identifiers{ "code", "f", @@ -103350,7 +104954,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7668, + context: p9272, freeVariables: Identifiers{ "code", }, @@ -103369,7 +104973,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7668, + context: p9272, freeVariables: Identifiers{ "code", }, @@ -103413,7 +105017,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7668, + context: p9272, freeVariables: nil, }, Value: "%", @@ -103440,7 +105044,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7668, + context: p9272, freeVariables: nil, }, Value: "%", @@ -103461,7 +105065,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7668, + context: p9272, freeVariables: Identifiers{ "code", "f", @@ -103485,7 +105089,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7668, + context: p9272, freeVariables: Identifiers{ "format_code", }, @@ -103508,7 +105112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7691, + context: p9295, freeVariables: Identifiers{ "val", }, @@ -103529,7 +105133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7691, + context: p9295, freeVariables: Identifiers{ "code", }, @@ -103550,7 +105154,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7691, + context: p9295, freeVariables: Identifiers{ "fw", }, @@ -103571,7 +105175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7691, + context: p9295, freeVariables: Identifiers{ "prec", }, @@ -103592,7 +105196,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7691, + context: p9295, freeVariables: Identifiers{ "f", }, @@ -103623,7 +105227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "code", "codes", @@ -103654,7 +105258,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7705, + context: p9309, freeVariables: Identifiers{ "code", "fw", @@ -103677,7 +105281,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7705, + context: p9309, freeVariables: Identifiers{ "code", }, @@ -103696,7 +105300,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7705, + context: p9309, freeVariables: Identifiers{ "code", }, @@ -103715,7 +105319,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7705, + context: p9309, freeVariables: Identifiers{ "code", }, @@ -103782,7 +105386,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7705, + context: p9309, freeVariables: Identifiers{ "fw", "pad_right", @@ -103803,7 +105407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7705, + context: p9309, freeVariables: Identifiers{ "pad_right", }, @@ -103826,7 +105430,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7721, + context: p9325, freeVariables: Identifiers{ "s", }, @@ -103847,7 +105451,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7721, + context: p9325, freeVariables: Identifiers{ "fw", }, @@ -103868,7 +105472,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7721, + context: p9325, freeVariables: nil, }, Value: " ", @@ -103895,7 +105499,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7705, + context: p9309, freeVariables: Identifiers{ "fw", "pad_left", @@ -103916,7 +105520,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7705, + context: p9309, freeVariables: Identifiers{ "pad_left", }, @@ -103939,7 +105543,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7732, + context: p9336, freeVariables: Identifiers{ "s", }, @@ -103960,7 +105564,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7732, + context: p9336, freeVariables: Identifiers{ "fw", }, @@ -103981,7 +105585,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7732, + context: p9336, freeVariables: nil, }, Value: " ", @@ -104012,7 +105616,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "codes", "format_codes_obj", @@ -104036,7 +105640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7479, + context: p9083, freeVariables: Identifiers{ "format_codes_obj", }, @@ -104059,7 +105663,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7743, + context: p9347, freeVariables: Identifiers{ "codes", }, @@ -104080,7 +105684,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7743, + context: p9347, freeVariables: Identifiers{ "obj", }, @@ -104101,7 +105705,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7743, + context: p9347, freeVariables: Identifiers{ "i", }, @@ -104120,7 +105724,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7743, + context: p9347, freeVariables: Identifiers{ "i", }, @@ -104142,7 +105746,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7743, + context: p9347, freeVariables: nil, }, Value: float64(1), @@ -104163,7 +105767,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7743, + context: p9347, freeVariables: Identifiers{ "s_padded", "v", @@ -104183,7 +105787,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7743, + context: p9347, freeVariables: Identifiers{ "v", }, @@ -104205,7 +105809,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7743, + context: p9347, freeVariables: Identifiers{ "s_padded", }, @@ -104246,7 +105850,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "format_codes_arr", @@ -104354,7 +105958,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", "vals", @@ -104374,7 +105978,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", }, @@ -104393,7 +105997,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", }, @@ -104439,7 +106043,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7777, + context: p9381, freeVariables: Identifiers{ "vals", }, @@ -104466,7 +106070,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: nil, }, Value: "array", @@ -104493,7 +106097,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "format_codes_arr", @@ -104514,7 +106118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "format_codes_arr", }, @@ -104537,7 +106141,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7786, + context: p9390, freeVariables: Identifiers{ "codes", }, @@ -104558,7 +106162,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7786, + context: p9390, freeVariables: Identifiers{ "vals", }, @@ -104579,7 +106183,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7786, + context: p9390, freeVariables: nil, }, Value: float64(0), @@ -104599,7 +106203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7786, + context: p9390, freeVariables: nil, }, Value: float64(0), @@ -104619,7 +106223,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7786, + context: p9390, freeVariables: nil, }, Value: "", @@ -104646,7 +106250,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "format_codes_arr", @@ -104754,7 +106358,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", "vals", @@ -104774,7 +106378,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", }, @@ -104793,7 +106397,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "std", }, @@ -104839,7 +106443,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7812, + context: p9416, freeVariables: Identifiers{ "vals", }, @@ -104866,7 +106470,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: nil, }, Value: "object", @@ -104893,7 +106497,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "format_codes_obj", @@ -104914,7 +106518,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "format_codes_obj", }, @@ -104937,7 +106541,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7821, + context: p9425, freeVariables: Identifiers{ "codes", }, @@ -104958,7 +106562,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7821, + context: p9425, freeVariables: Identifiers{ "vals", }, @@ -104979,7 +106583,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7821, + context: p9425, freeVariables: nil, }, Value: float64(0), @@ -104999,7 +106603,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7821, + context: p9425, freeVariables: nil, }, Value: "", @@ -105026,7 +106630,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "codes", "format_codes_arr", @@ -105047,7 +106651,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p3236, + context: p4840, freeVariables: Identifiers{ "format_codes_arr", }, @@ -105070,7 +106674,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7833, + context: p9437, freeVariables: Identifiers{ "codes", }, @@ -105091,7 +106695,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7833, + context: p9437, freeVariables: Identifiers{ "vals", }, @@ -105111,7 +106715,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7839, + context: p9443, freeVariables: Identifiers{ "vals", }, @@ -105135,7 +106739,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7833, + context: p9437, freeVariables: nil, }, Value: float64(0), @@ -105155,7 +106759,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7833, + context: p9437, freeVariables: nil, }, Value: float64(0), @@ -105175,7 +106779,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7833, + context: p9437, freeVariables: nil, }, Value: "", @@ -105271,7 +106875,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9452, freeVariables: nil, }, }, @@ -105293,7 +106897,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9454, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -105535,7 +107139,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9478, freeVariables: Identifiers{ "base64_table", "i", @@ -105559,7 +107163,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9482, freeVariables: Identifiers{ "base64_table", "i", @@ -105579,7 +107183,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9485, freeVariables: Identifiers{ "base64_table", }, @@ -105600,7 +107204,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9488, freeVariables: Identifiers{ "i", }, @@ -105623,7 +107227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p9491, freeVariables: Identifiers{ "i", }, @@ -105652,7 +107256,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9494, freeVariables: Identifiers{ "std", }, @@ -105671,7 +107275,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9497, freeVariables: Identifiers{ "std", }, @@ -105690,7 +107294,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9500, freeVariables: Identifiers{ "std", }, @@ -105736,7 +107340,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p9505, freeVariables: nil, }, Value: float64(0), @@ -105756,14 +107360,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p9507, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -105819,7 +107423,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -105847,7 +107451,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7850, + context: p9513, freeVariables: Identifiers{ "arr", "func", @@ -105872,7 +107476,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7854, + context: p9517, freeVariables: Identifiers{ "aux", }, @@ -105901,7 +107505,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7858, + context: p9521, freeVariables: Identifiers{ "arr", "aux", @@ -105924,7 +107528,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7858, + context: p9521, freeVariables: Identifiers{ "idx", }, @@ -105943,7 +107547,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7858, + context: p9521, freeVariables: Identifiers{ "idx", }, @@ -105965,7 +107569,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7858, + context: p9521, freeVariables: nil, }, Value: float64(0), @@ -105986,7 +107590,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7858, + context: p9521, freeVariables: Identifiers{ "running", }, @@ -106007,7 +107611,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7858, + context: p9521, freeVariables: Identifiers{ "arr", "aux", @@ -106030,7 +107634,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7858, + context: p9521, freeVariables: Identifiers{ "aux", }, @@ -106053,7 +107657,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7873, + context: p9536, freeVariables: Identifiers{ "func", }, @@ -106074,7 +107678,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7873, + context: p9536, freeVariables: Identifiers{ "arr", }, @@ -106095,7 +107699,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7873, + context: p9536, freeVariables: Identifiers{ "arr", "func", @@ -106117,7 +107721,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7873, + context: p9536, freeVariables: Identifiers{ "func", }, @@ -106140,7 +107744,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7883, + context: p9546, freeVariables: Identifiers{ "arr", "idx", @@ -106160,7 +107764,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7883, + context: p9546, freeVariables: Identifiers{ "arr", }, @@ -106181,7 +107785,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7883, + context: p9546, freeVariables: Identifiers{ "idx", }, @@ -106204,7 +107808,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7883, + context: p9546, freeVariables: Identifiers{ "running", }, @@ -106231,7 +107835,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7873, + context: p9536, freeVariables: Identifiers{ "idx", }, @@ -106250,7 +107854,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7873, + context: p9536, freeVariables: Identifiers{ "idx", }, @@ -106272,7 +107876,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7873, + context: p9536, freeVariables: nil, }, Value: float64(1), @@ -106304,7 +107908,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7850, + context: p9513, freeVariables: Identifiers{ "arr", "aux", @@ -106327,7 +107931,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7850, + context: p9513, freeVariables: Identifiers{ "aux", }, @@ -106350,7 +107954,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7902, + context: p9565, freeVariables: Identifiers{ "func", }, @@ -106371,7 +107975,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7902, + context: p9565, freeVariables: Identifiers{ "arr", }, @@ -106392,7 +107996,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7902, + context: p9565, freeVariables: Identifiers{ "init", }, @@ -106413,7 +108017,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7902, + context: p9565, freeVariables: Identifiers{ "arr", "std", @@ -106433,7 +108037,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7902, + context: p9565, freeVariables: Identifiers{ "arr", "std", @@ -106453,7 +108057,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7902, + context: p9565, freeVariables: Identifiers{ "std", }, @@ -106472,7 +108076,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7902, + context: p9565, freeVariables: Identifiers{ "std", }, @@ -106518,7 +108122,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7919, + context: p9582, freeVariables: Identifiers{ "arr", }, @@ -106546,7 +108150,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7902, + context: p9565, freeVariables: nil, }, Value: float64(1), @@ -106621,7 +108225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9589, freeVariables: nil, }, }, @@ -106643,7 +108247,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9591, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -106885,7 +108489,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9615, freeVariables: Identifiers{ "base64_table", "i", @@ -106909,7 +108513,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9619, freeVariables: Identifiers{ "base64_table", "i", @@ -106929,7 +108533,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9622, freeVariables: Identifiers{ "base64_table", }, @@ -106950,7 +108554,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9625, freeVariables: Identifiers{ "i", }, @@ -106973,7 +108577,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p9628, freeVariables: Identifiers{ "i", }, @@ -107002,7 +108606,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9631, freeVariables: Identifiers{ "std", }, @@ -107021,7 +108625,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9634, freeVariables: Identifiers{ "std", }, @@ -107040,7 +108644,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9637, freeVariables: Identifiers{ "std", }, @@ -107086,7 +108690,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p9642, freeVariables: nil, }, Value: float64(0), @@ -107106,14 +108710,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p9644, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -107169,7 +108773,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -107197,7 +108801,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7928, + context: p9650, freeVariables: Identifiers{ "arr", "func", @@ -107222,7 +108826,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7932, + context: p9654, freeVariables: Identifiers{ "aux", "std", @@ -107252,7 +108856,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7936, + context: p9658, freeVariables: Identifiers{ "arr", "aux", @@ -107276,7 +108880,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7936, + context: p9658, freeVariables: Identifiers{ "arr", "idx", @@ -107297,7 +108901,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7936, + context: p9658, freeVariables: Identifiers{ "idx", }, @@ -107319,7 +108923,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7936, + context: p9658, freeVariables: Identifiers{ "arr", "std", @@ -107339,7 +108943,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7936, + context: p9658, freeVariables: Identifiers{ "std", }, @@ -107358,7 +108962,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7936, + context: p9658, freeVariables: Identifiers{ "std", }, @@ -107404,7 +109008,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7951, + context: p9673, freeVariables: Identifiers{ "arr", }, @@ -107432,7 +109036,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7936, + context: p9658, freeVariables: Identifiers{ "running", }, @@ -107453,7 +109057,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7936, + context: p9658, freeVariables: Identifiers{ "arr", "aux", @@ -107476,7 +109080,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7936, + context: p9658, freeVariables: Identifiers{ "aux", }, @@ -107499,7 +109103,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7961, + context: p9683, freeVariables: Identifiers{ "func", }, @@ -107520,7 +109124,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7961, + context: p9683, freeVariables: Identifiers{ "arr", }, @@ -107541,7 +109145,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7961, + context: p9683, freeVariables: Identifiers{ "arr", "func", @@ -107563,7 +109167,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7961, + context: p9683, freeVariables: Identifiers{ "func", }, @@ -107586,7 +109190,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7971, + context: p9693, freeVariables: Identifiers{ "running", }, @@ -107607,7 +109211,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7971, + context: p9693, freeVariables: Identifiers{ "arr", "idx", @@ -107627,7 +109231,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7971, + context: p9693, freeVariables: Identifiers{ "arr", }, @@ -107648,7 +109252,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7971, + context: p9693, freeVariables: Identifiers{ "idx", }, @@ -107677,7 +109281,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7961, + context: p9683, freeVariables: Identifiers{ "idx", }, @@ -107696,7 +109300,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7961, + context: p9683, freeVariables: Identifiers{ "idx", }, @@ -107718,7 +109322,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7961, + context: p9683, freeVariables: nil, }, Value: float64(1), @@ -107750,7 +109354,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7928, + context: p9650, freeVariables: Identifiers{ "arr", "aux", @@ -107772,7 +109376,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7928, + context: p9650, freeVariables: Identifiers{ "aux", }, @@ -107795,7 +109399,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7990, + context: p9712, freeVariables: Identifiers{ "func", }, @@ -107816,7 +109420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7990, + context: p9712, freeVariables: Identifiers{ "arr", }, @@ -107837,7 +109441,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7990, + context: p9712, freeVariables: Identifiers{ "init", }, @@ -107858,7 +109462,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p7990, + context: p9712, freeVariables: nil, }, Value: float64(0), @@ -107932,7 +109536,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9723, freeVariables: nil, }, }, @@ -107954,7 +109558,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9725, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -108196,7 +109800,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9749, freeVariables: Identifiers{ "base64_table", "i", @@ -108220,7 +109824,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9753, freeVariables: Identifiers{ "base64_table", "i", @@ -108240,7 +109844,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9756, freeVariables: Identifiers{ "base64_table", }, @@ -108261,7 +109865,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9759, freeVariables: Identifiers{ "i", }, @@ -108284,7 +109888,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p9762, freeVariables: Identifiers{ "i", }, @@ -108313,7 +109917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9765, freeVariables: Identifiers{ "std", }, @@ -108332,7 +109936,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9768, freeVariables: Identifiers{ "std", }, @@ -108351,7 +109955,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9771, freeVariables: Identifiers{ "std", }, @@ -108397,7 +110001,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p9776, freeVariables: nil, }, Value: float64(0), @@ -108417,14 +110021,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p9778, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -108480,7 +110084,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -108508,7 +110112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "arr", "filter_func", @@ -108636,7 +110240,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "filter_func", "std", @@ -108656,7 +110260,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -108675,7 +110279,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -108721,7 +110325,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8024, + context: p9805, freeVariables: Identifiers{ "filter_func", }, @@ -108748,7 +110352,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: nil, }, Value: "function", @@ -108776,7 +110380,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "filter_func", "std", @@ -108796,7 +110400,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "filter_func", "std", @@ -108816,7 +110420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: nil, }, Value: "std.filterMap first param must be function, got ", @@ -108838,7 +110442,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "filter_func", "std", @@ -108858,7 +110462,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -108877,7 +110481,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -108923,7 +110527,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8041, + context: p9822, freeVariables: Identifiers{ "filter_func", }, @@ -108952,7 +110556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "arr", "filter_func", @@ -109080,7 +110684,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "map_func", "std", @@ -109100,7 +110704,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109119,7 +110723,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109165,7 +110769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8064, + context: p9845, freeVariables: Identifiers{ "map_func", }, @@ -109192,7 +110796,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: nil, }, Value: "function", @@ -109220,7 +110824,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "map_func", "std", @@ -109240,7 +110844,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "map_func", "std", @@ -109260,7 +110864,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: nil, }, Value: "std.filterMap second param must be function, got ", @@ -109282,7 +110886,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "map_func", "std", @@ -109302,7 +110906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109321,7 +110925,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109367,7 +110971,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8081, + context: p9862, freeVariables: Identifiers{ "map_func", }, @@ -109396,7 +111000,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "arr", "filter_func", @@ -109524,7 +111128,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "arr", "std", @@ -109544,7 +111148,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109563,7 +111167,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109609,7 +111213,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8104, + context: p9885, freeVariables: Identifiers{ "arr", }, @@ -109636,7 +111240,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: nil, }, Value: "array", @@ -109664,7 +111268,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "arr", "std", @@ -109684,7 +111288,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "arr", "std", @@ -109704,7 +111308,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: nil, }, Value: "std.filterMap third param must be array, got ", @@ -109726,7 +111330,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "arr", "std", @@ -109746,7 +111350,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109765,7 +111369,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109811,7 +111415,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8121, + context: p9902, freeVariables: Identifiers{ "arr", }, @@ -109840,7 +111444,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "arr", "filter_func", @@ -109862,7 +111466,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109881,7 +111485,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8003, + context: p9784, freeVariables: Identifiers{ "std", }, @@ -109927,7 +111531,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8132, + context: p9913, freeVariables: Identifiers{ "map_func", }, @@ -109948,7 +111552,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8132, + context: p9913, freeVariables: Identifiers{ "arr", "filter_func", @@ -109969,7 +111573,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8132, + context: p9913, freeVariables: Identifiers{ "std", }, @@ -109988,7 +111592,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8132, + context: p9913, freeVariables: Identifiers{ "std", }, @@ -110034,7 +111638,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8143, + context: p9924, freeVariables: Identifiers{ "filter_func", }, @@ -110055,7 +111659,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8143, + context: p9924, freeVariables: Identifiers{ "arr", }, @@ -110138,7 +111742,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9932, freeVariables: nil, }, }, @@ -110160,7 +111764,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9934, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -110402,7 +112006,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9958, freeVariables: Identifiers{ "base64_table", "i", @@ -110426,7 +112030,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9962, freeVariables: Identifiers{ "base64_table", "i", @@ -110446,7 +112050,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9965, freeVariables: Identifiers{ "base64_table", }, @@ -110467,7 +112071,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9968, freeVariables: Identifiers{ "i", }, @@ -110490,7 +112094,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p9971, freeVariables: Identifiers{ "i", }, @@ -110519,7 +112123,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9974, freeVariables: Identifiers{ "std", }, @@ -110538,7 +112142,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9977, freeVariables: Identifiers{ "std", }, @@ -110557,7 +112161,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p9980, freeVariables: Identifiers{ "std", }, @@ -110603,7 +112207,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p9985, freeVariables: nil, }, Value: float64(0), @@ -110623,14 +112227,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p9987, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -110686,7 +112290,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -110713,7 +112317,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: Identifiers{ "a", "b", @@ -110820,7 +112424,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: Identifiers{ "a", }, @@ -110841,7 +112445,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: Identifiers{ "b", }, @@ -110868,7 +112472,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: nil, }, Value: true, @@ -110887,7 +112491,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: Identifiers{ "a", "b", @@ -110907,7 +112511,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: Identifiers{ "a", "b", @@ -110927,7 +112531,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: Identifiers{ "a", }, @@ -110946,7 +112550,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: Identifiers{ "a", }, @@ -110965,7 +112569,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: nil, }, Value: "Assertion failed. ", @@ -110987,7 +112591,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: Identifiers{ "a", }, @@ -111010,7 +112614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: nil, }, Value: " != ", @@ -111033,7 +112637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8153, + context: p9993, freeVariables: Identifiers{ "b", }, @@ -111104,7 +112708,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10026, freeVariables: nil, }, }, @@ -111126,7 +112730,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10028, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -111368,7 +112972,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10052, freeVariables: Identifiers{ "base64_table", "i", @@ -111392,7 +112996,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10056, freeVariables: Identifiers{ "base64_table", "i", @@ -111412,7 +113016,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10059, freeVariables: Identifiers{ "base64_table", }, @@ -111433,7 +113037,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10062, freeVariables: Identifiers{ "i", }, @@ -111456,7 +113060,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p10065, freeVariables: Identifiers{ "i", }, @@ -111485,7 +113089,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10068, freeVariables: Identifiers{ "std", }, @@ -111504,7 +113108,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10071, freeVariables: Identifiers{ "std", }, @@ -111523,7 +113127,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10074, freeVariables: Identifiers{ "std", }, @@ -111569,7 +113173,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10079, freeVariables: nil, }, Value: float64(0), @@ -111589,14 +113193,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10081, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -111652,7 +113256,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -111678,7 +113282,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", "std", @@ -111804,7 +113408,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", "std", @@ -111824,7 +113428,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "std", }, @@ -111843,7 +113447,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "std", }, @@ -111889,7 +113493,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8209, + context: p10108, freeVariables: Identifiers{ "n", }, @@ -111916,7 +113520,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: nil, }, Value: "number", @@ -111944,7 +113548,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", "std", @@ -111964,7 +113568,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", "std", @@ -111984,7 +113588,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: nil, }, Value: "std.abs expected number, got ", @@ -112006,7 +113610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", "std", @@ -112026,7 +113630,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "std", }, @@ -112045,7 +113649,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "std", }, @@ -112091,7 +113695,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8226, + context: p10125, freeVariables: Identifiers{ "n", }, @@ -112120,7 +113724,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", }, @@ -112139,7 +113743,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", }, @@ -112158,7 +113762,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", }, @@ -112180,7 +113784,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: nil, }, Value: float64(0), @@ -112201,7 +113805,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", }, @@ -112222,7 +113826,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", }, @@ -112242,7 +113846,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8188, + context: p10087, freeVariables: Identifiers{ "n", }, @@ -112313,7 +113917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10144, freeVariables: nil, }, }, @@ -112335,7 +113939,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10146, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -112577,7 +114181,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10170, freeVariables: Identifiers{ "base64_table", "i", @@ -112601,7 +114205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10174, freeVariables: Identifiers{ "base64_table", "i", @@ -112621,7 +114225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10177, freeVariables: Identifiers{ "base64_table", }, @@ -112642,7 +114246,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10180, freeVariables: Identifiers{ "i", }, @@ -112665,7 +114269,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p10183, freeVariables: Identifiers{ "i", }, @@ -112694,7 +114298,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10186, freeVariables: Identifiers{ "std", }, @@ -112713,7 +114317,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10189, freeVariables: Identifiers{ "std", }, @@ -112732,7 +114336,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10192, freeVariables: Identifiers{ "std", }, @@ -112778,7 +114382,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10197, freeVariables: nil, }, Value: float64(0), @@ -112798,14 +114402,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10199, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -112861,7 +114465,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -112887,7 +114491,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", "std", @@ -113013,7 +114617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", "std", @@ -113033,7 +114637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "std", }, @@ -113052,7 +114656,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "std", }, @@ -113098,7 +114702,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8268, + context: p10226, freeVariables: Identifiers{ "n", }, @@ -113125,7 +114729,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: nil, }, Value: "number", @@ -113153,7 +114757,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", "std", @@ -113173,7 +114777,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", "std", @@ -113193,7 +114797,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: nil, }, Value: "std.sign expected number, got ", @@ -113215,7 +114819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", "std", @@ -113235,7 +114839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "std", }, @@ -113254,7 +114858,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "std", }, @@ -113300,7 +114904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8285, + context: p10243, freeVariables: Identifiers{ "n", }, @@ -113329,7 +114933,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", }, @@ -113348,7 +114952,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", }, @@ -113367,7 +114971,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", }, @@ -113389,7 +114993,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: nil, }, Value: float64(0), @@ -113410,7 +115014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: nil, }, Value: float64(1), @@ -113430,7 +115034,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", }, @@ -113449,7 +115053,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", }, @@ -113468,7 +115072,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: Identifiers{ "n", }, @@ -113490,7 +115094,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: nil, }, Value: float64(0), @@ -113511,7 +115115,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: nil, }, Op: UnaryOp(3), @@ -113529,7 +115133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: nil, }, Value: float64(1), @@ -113550,7 +115154,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8247, + context: p10205, freeVariables: nil, }, Value: float64(0), @@ -113620,7 +115224,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10267, freeVariables: nil, }, }, @@ -113642,7 +115246,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10269, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -113884,7 +115488,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10293, freeVariables: Identifiers{ "base64_table", "i", @@ -113908,7 +115512,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10297, freeVariables: Identifiers{ "base64_table", "i", @@ -113928,7 +115532,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10300, freeVariables: Identifiers{ "base64_table", }, @@ -113949,7 +115553,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10303, freeVariables: Identifiers{ "i", }, @@ -113972,7 +115576,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p10306, freeVariables: Identifiers{ "i", }, @@ -114001,7 +115605,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10309, freeVariables: Identifiers{ "std", }, @@ -114020,7 +115624,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10312, freeVariables: Identifiers{ "std", }, @@ -114039,7 +115643,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10315, freeVariables: Identifiers{ "std", }, @@ -114085,7 +115689,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10320, freeVariables: nil, }, Value: float64(0), @@ -114105,14 +115709,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10322, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -114168,7 +115772,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -114195,7 +115799,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", "b", @@ -114322,7 +115926,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", "std", @@ -114342,7 +115946,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "std", }, @@ -114361,7 +115965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "std", }, @@ -114407,7 +116011,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8332, + context: p10349, freeVariables: Identifiers{ "a", }, @@ -114434,7 +116038,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: nil, }, Value: "number", @@ -114462,7 +116066,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", "std", @@ -114482,7 +116086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", "std", @@ -114502,7 +116106,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: nil, }, Value: "std.max first param expected number, got ", @@ -114524,7 +116128,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", "std", @@ -114544,7 +116148,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "std", }, @@ -114563,7 +116167,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "std", }, @@ -114609,7 +116213,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8349, + context: p10366, freeVariables: Identifiers{ "a", }, @@ -114638,7 +116242,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", "b", @@ -114765,7 +116369,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "b", "std", @@ -114785,7 +116389,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "std", }, @@ -114804,7 +116408,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "std", }, @@ -114850,7 +116454,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8372, + context: p10389, freeVariables: Identifiers{ "b", }, @@ -114877,7 +116481,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: nil, }, Value: "number", @@ -114905,7 +116509,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "b", "std", @@ -114925,7 +116529,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "b", "std", @@ -114945,7 +116549,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: nil, }, Value: "std.max second param expected number, got ", @@ -114967,7 +116571,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "b", "std", @@ -114987,7 +116591,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "std", }, @@ -115006,7 +116610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "std", }, @@ -115052,7 +116656,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8389, + context: p10406, freeVariables: Identifiers{ "b", }, @@ -115081,7 +116685,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", "b", @@ -115101,7 +116705,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", "b", @@ -115121,7 +116725,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", }, @@ -115143,7 +116747,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "b", }, @@ -115165,7 +116769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "a", }, @@ -115186,7 +116790,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8311, + context: p10328, freeVariables: Identifiers{ "b", }, @@ -115257,7 +116861,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10424, freeVariables: nil, }, }, @@ -115279,7 +116883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10426, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -115521,7 +117125,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10450, freeVariables: Identifiers{ "base64_table", "i", @@ -115545,7 +117149,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10454, freeVariables: Identifiers{ "base64_table", "i", @@ -115565,7 +117169,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10457, freeVariables: Identifiers{ "base64_table", }, @@ -115586,7 +117190,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10460, freeVariables: Identifiers{ "i", }, @@ -115609,7 +117213,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p10463, freeVariables: Identifiers{ "i", }, @@ -115638,7 +117242,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10466, freeVariables: Identifiers{ "std", }, @@ -115657,7 +117261,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10469, freeVariables: Identifiers{ "std", }, @@ -115676,7 +117280,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10472, freeVariables: Identifiers{ "std", }, @@ -115722,7 +117326,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10477, freeVariables: nil, }, Value: float64(0), @@ -115742,14 +117346,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10479, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -115805,7 +117409,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -115832,7 +117436,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", "b", @@ -115959,7 +117563,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", "std", @@ -115979,7 +117583,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "std", }, @@ -115998,7 +117602,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "std", }, @@ -116044,7 +117648,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8430, + context: p10506, freeVariables: Identifiers{ "a", }, @@ -116071,7 +117675,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: nil, }, Value: "number", @@ -116099,7 +117703,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", "std", @@ -116119,7 +117723,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", "std", @@ -116139,7 +117743,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: nil, }, Value: "std.max first param expected number, got ", @@ -116161,7 +117765,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", "std", @@ -116181,7 +117785,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "std", }, @@ -116200,7 +117804,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "std", }, @@ -116246,7 +117850,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8447, + context: p10523, freeVariables: Identifiers{ "a", }, @@ -116275,7 +117879,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", "b", @@ -116402,7 +118006,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "b", "std", @@ -116422,7 +118026,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "std", }, @@ -116441,7 +118045,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "std", }, @@ -116487,7 +118091,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8470, + context: p10546, freeVariables: Identifiers{ "b", }, @@ -116514,7 +118118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: nil, }, Value: "number", @@ -116542,7 +118146,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "b", "std", @@ -116562,7 +118166,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "b", "std", @@ -116582,7 +118186,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: nil, }, Value: "std.max second param expected number, got ", @@ -116604,7 +118208,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "b", "std", @@ -116624,7 +118228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "std", }, @@ -116643,7 +118247,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "std", }, @@ -116689,7 +118293,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8487, + context: p10563, freeVariables: Identifiers{ "b", }, @@ -116718,7 +118322,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", "b", @@ -116738,7 +118342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", "b", @@ -116758,7 +118362,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", }, @@ -116780,7 +118384,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "b", }, @@ -116802,7 +118406,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "a", }, @@ -116823,7 +118427,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8409, + context: p10485, freeVariables: Identifiers{ "b", }, @@ -116894,7 +118498,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10581, freeVariables: nil, }, }, @@ -116916,7 +118520,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10583, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -117158,7 +118762,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10607, freeVariables: Identifiers{ "base64_table", "i", @@ -117182,7 +118786,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10611, freeVariables: Identifiers{ "base64_table", "i", @@ -117202,7 +118806,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10614, freeVariables: Identifiers{ "base64_table", }, @@ -117223,7 +118827,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10617, freeVariables: Identifiers{ "i", }, @@ -117246,7 +118850,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p10620, freeVariables: Identifiers{ "i", }, @@ -117275,7 +118879,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10623, freeVariables: Identifiers{ "std", }, @@ -117294,7 +118898,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10626, freeVariables: Identifiers{ "std", }, @@ -117313,7 +118917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10629, freeVariables: Identifiers{ "std", }, @@ -117359,7 +118963,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10634, freeVariables: nil, }, Value: float64(0), @@ -117379,14 +118983,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10636, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -117442,7 +119046,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -117468,7 +119072,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8507, + context: p10642, freeVariables: Identifiers{ "arrs", "std", @@ -117488,7 +119092,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8507, + context: p10642, freeVariables: Identifiers{ "std", }, @@ -117507,7 +119111,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8507, + context: p10642, freeVariables: Identifiers{ "std", }, @@ -117553,7 +119157,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8516, + context: p10651, freeVariables: nil, }, Parameters: Parameters{ @@ -117578,7 +119182,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8519, + context: p10654, freeVariables: Identifiers{ "a", "b", @@ -117598,7 +119202,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8519, + context: p10654, freeVariables: Identifiers{ "a", }, @@ -117620,7 +119224,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8519, + context: p10654, freeVariables: Identifiers{ "b", }, @@ -117643,7 +119247,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8516, + context: p10651, freeVariables: Identifiers{ "arrs", }, @@ -117664,7 +119268,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8516, + context: p10651, freeVariables: nil, }, Elements: nil, @@ -117737,7 +119341,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10667, freeVariables: nil, }, }, @@ -117759,7 +119363,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10669, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -118001,7 +119605,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10693, freeVariables: Identifiers{ "base64_table", "i", @@ -118025,7 +119629,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10697, freeVariables: Identifiers{ "base64_table", "i", @@ -118045,7 +119649,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10700, freeVariables: Identifiers{ "base64_table", }, @@ -118066,7 +119670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10703, freeVariables: Identifiers{ "i", }, @@ -118089,7 +119693,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p10706, freeVariables: Identifiers{ "i", }, @@ -118118,7 +119722,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10709, freeVariables: Identifiers{ "std", }, @@ -118137,7 +119741,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10712, freeVariables: Identifiers{ "std", }, @@ -118156,7 +119760,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p10715, freeVariables: Identifiers{ "std", }, @@ -118202,7 +119806,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10720, freeVariables: nil, }, Value: float64(0), @@ -118222,14 +119826,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p10722, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -118285,7 +119889,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -118311,7 +119915,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8534, + context: p10728, freeVariables: Identifiers{ "ini", "std", @@ -118334,7 +119938,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8538, + context: p10732, freeVariables: Identifiers{ "std", }, @@ -118360,7 +119964,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8542, + context: p10736, freeVariables: Identifiers{ "body", "std", @@ -118380,7 +119984,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8542, + context: p10736, freeVariables: Identifiers{ "std", }, @@ -118399,7 +120003,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8542, + context: p10736, freeVariables: Identifiers{ "std", }, @@ -118445,7 +120049,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8551, + context: p10745, freeVariables: nil, }, Elements: nil, @@ -118599,7 +120203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8567, + context: p10761, freeVariables: Identifiers{ "body", "k", @@ -118623,7 +120227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8571, + context: p10765, freeVariables: Identifiers{ "body", "k", @@ -118643,7 +120247,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8571, + context: p10765, freeVariables: Identifiers{ "body", }, @@ -118664,7 +120268,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8571, + context: p10765, freeVariables: Identifiers{ "k", }, @@ -118690,7 +120294,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8567, + context: p10761, freeVariables: Identifiers{ "k", "std", @@ -118796,7 +120400,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8567, + context: p10761, freeVariables: Identifiers{ "std", "value_or_values", @@ -118816,7 +120420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8567, + context: p10761, freeVariables: Identifiers{ "std", }, @@ -118835,7 +120439,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8567, + context: p10761, freeVariables: Identifiers{ "std", }, @@ -118881,7 +120485,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8596, + context: p10790, freeVariables: Identifiers{ "value_or_values", }, @@ -118908,7 +120512,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8567, + context: p10761, freeVariables: nil, }, Value: "array", @@ -119156,7 +120760,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8622, + context: p10816, freeVariables: nil, }, Value: "%s = %s", @@ -119177,7 +120781,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8622, + context: p10816, freeVariables: Identifiers{ "k", "value", @@ -119198,7 +120802,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8627, + context: p10821, freeVariables: Identifiers{ "k", }, @@ -119219,7 +120823,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8627, + context: p10821, freeVariables: Identifiers{ "value", }, @@ -119253,7 +120857,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8567, + context: p10761, freeVariables: Identifiers{ "value_or_values", }, @@ -119280,7 +120884,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8567, + context: p10761, freeVariables: Identifiers{ "k", "std", @@ -119388,7 +120992,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8645, + context: p10839, freeVariables: nil, }, Value: "%s = %s", @@ -119409,7 +121013,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8645, + context: p10839, freeVariables: Identifiers{ "k", "value_or_values", @@ -119430,7 +121034,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8650, + context: p10844, freeVariables: Identifiers{ "k", }, @@ -119451,7 +121055,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8650, + context: p10844, freeVariables: Identifiers{ "value_or_values", }, @@ -119490,7 +121094,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8551, + context: p10745, freeVariables: Identifiers{ "body", "std", @@ -119510,7 +121114,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8551, + context: p10745, freeVariables: Identifiers{ "std", }, @@ -119529,7 +121133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8551, + context: p10745, freeVariables: Identifiers{ "std", }, @@ -119575,7 +121179,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8663, + context: p10857, freeVariables: Identifiers{ "body", }, @@ -119618,7 +121222,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8534, + context: p10728, freeVariables: Identifiers{ "body_lines", "ini", @@ -119642,7 +121246,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8669, + context: p10863, freeVariables: Identifiers{ "body_lines", "std", @@ -119670,7 +121274,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8673, + context: p10867, freeVariables: Identifiers{ "body_lines", "sbody", @@ -119692,7 +121296,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8673, + context: p10867, freeVariables: Identifiers{ "sname", "std", @@ -119798,7 +121402,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8687, + context: p10881, freeVariables: nil, }, Value: "[%s]", @@ -119819,7 +121423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8687, + context: p10881, freeVariables: Identifiers{ "sname", }, @@ -119839,7 +121443,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8692, + context: p10886, freeVariables: Identifiers{ "sname", }, @@ -119873,7 +121477,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8673, + context: p10867, freeVariables: Identifiers{ "body_lines", "sbody", @@ -119893,7 +121497,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8673, + context: p10867, freeVariables: Identifiers{ "body_lines", }, @@ -119916,7 +121520,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8700, + context: p10894, freeVariables: Identifiers{ "sbody", }, @@ -119949,7 +121553,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8703, + context: p10897, freeVariables: Identifiers{ "body_lines", "ini", @@ -119970,7 +121574,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8703, + context: p10897, freeVariables: Identifiers{ "ini", "std", @@ -119990,7 +121594,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8703, + context: p10897, freeVariables: Identifiers{ "std", }, @@ -120009,7 +121613,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8703, + context: p10897, freeVariables: Identifiers{ "std", }, @@ -120055,7 +121659,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8714, + context: p10908, freeVariables: Identifiers{ "ini", }, @@ -120076,7 +121680,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8714, + context: p10908, freeVariables: nil, }, Value: "main", @@ -120103,7 +121707,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8703, + context: p10897, freeVariables: Identifiers{ "body_lines", "ini", @@ -120123,7 +121727,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8703, + context: p10897, freeVariables: Identifiers{ "body_lines", }, @@ -120146,7 +121750,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8723, + context: p10917, freeVariables: Identifiers{ "ini", }, @@ -120165,7 +121769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8723, + context: p10917, freeVariables: Identifiers{ "ini", }, @@ -120215,7 +121819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8703, + context: p10897, freeVariables: nil, }, Elements: nil, @@ -120375,7 +121979,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8744, + context: p10938, freeVariables: Identifiers{ "ini", "k", @@ -120396,7 +122000,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8744, + context: p10938, freeVariables: Identifiers{ "section_lines", }, @@ -120419,7 +122023,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8750, + context: p10944, freeVariables: Identifiers{ "k", }, @@ -120440,7 +122044,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8750, + context: p10944, freeVariables: Identifiers{ "ini", "k", @@ -120460,7 +122064,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8750, + context: p10944, freeVariables: Identifiers{ "ini", }, @@ -120479,7 +122083,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8750, + context: p10944, freeVariables: Identifiers{ "ini", }, @@ -120523,7 +122127,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8750, + context: p10944, freeVariables: Identifiers{ "k", }, @@ -120556,7 +122160,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8762, + context: p10956, freeVariables: Identifiers{ "ini", "std", @@ -120576,7 +122180,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8762, + context: p10956, freeVariables: Identifiers{ "std", }, @@ -120595,7 +122199,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8762, + context: p10956, freeVariables: Identifiers{ "std", }, @@ -120641,7 +122245,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8771, + context: p10965, freeVariables: Identifiers{ "ini", }, @@ -120660,7 +122264,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8771, + context: p10965, freeVariables: Identifiers{ "ini", }, @@ -120719,7 +122323,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8534, + context: p10728, freeVariables: Identifiers{ "all_sections", "main_body", @@ -120740,7 +122344,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8534, + context: p10728, freeVariables: Identifiers{ "std", }, @@ -120759,7 +122363,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8534, + context: p10728, freeVariables: Identifiers{ "std", }, @@ -120805,7 +122409,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8785, + context: p10979, freeVariables: nil, }, Value: "\n", @@ -120826,7 +122430,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8785, + context: p10979, freeVariables: Identifiers{ "all_sections", "main_body", @@ -120847,7 +122451,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8785, + context: p10979, freeVariables: Identifiers{ "all_sections", "main_body", @@ -120868,7 +122472,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8785, + context: p10979, freeVariables: Identifiers{ "main_body", }, @@ -120890,7 +122494,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8785, + context: p10979, freeVariables: Identifiers{ "all_sections", "std", @@ -120910,7 +122514,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8785, + context: p10979, freeVariables: Identifiers{ "std", }, @@ -120929,7 +122533,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8785, + context: p10979, freeVariables: Identifiers{ "std", }, @@ -120975,7 +122579,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8801, + context: p10995, freeVariables: Identifiers{ "all_sections", }, @@ -121004,7 +122608,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8785, + context: p10979, freeVariables: nil, }, Elements: Nodes{ @@ -121022,7 +122626,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8806, + context: p11000, freeVariables: nil, }, Value: "", @@ -121102,7 +122706,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11005, freeVariables: nil, }, }, @@ -121124,7 +122728,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11007, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -121366,7 +122970,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11031, freeVariables: Identifiers{ "base64_table", "i", @@ -121390,7 +122994,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11035, freeVariables: Identifiers{ "base64_table", "i", @@ -121410,7 +123014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11038, freeVariables: Identifiers{ "base64_table", }, @@ -121431,7 +123035,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11041, freeVariables: Identifiers{ "i", }, @@ -121454,7 +123058,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p11044, freeVariables: Identifiers{ "i", }, @@ -121483,7 +123087,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11047, freeVariables: Identifiers{ "std", }, @@ -121502,7 +123106,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11050, freeVariables: Identifiers{ "std", }, @@ -121521,7 +123125,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11053, freeVariables: Identifiers{ "std", }, @@ -121567,7 +123171,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11058, freeVariables: nil, }, Value: float64(0), @@ -121587,14 +123191,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11060, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -121650,7 +123254,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -121676,7 +123280,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8813, + context: p11066, freeVariables: Identifiers{ "std", "str_", @@ -121699,7 +123303,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8817, + context: p11070, freeVariables: Identifiers{ "std", "str_", @@ -121719,7 +123323,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8817, + context: p11070, freeVariables: Identifiers{ "std", }, @@ -121738,7 +123342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8817, + context: p11070, freeVariables: Identifiers{ "std", }, @@ -121784,7 +123388,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8826, + context: p11079, freeVariables: Identifiers{ "str_", }, @@ -121814,7 +123418,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8813, + context: p11066, freeVariables: Identifiers{ "std", "str", @@ -121837,7 +123441,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8832, + context: p11085, freeVariables: Identifiers{ "std", }, @@ -121863,7 +123467,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", "std", @@ -121968,7 +123572,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", }, @@ -121989,7 +123593,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\"", @@ -122016,7 +123620,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\\\"", @@ -122037,7 +123641,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", "std", @@ -122142,7 +123746,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", }, @@ -122163,7 +123767,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\\", @@ -122190,7 +123794,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\\\\", @@ -122211,7 +123815,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", "std", @@ -122316,7 +123920,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", }, @@ -122337,7 +123941,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\b", @@ -122364,7 +123968,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\\b", @@ -122385,7 +123989,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", "std", @@ -122490,7 +124094,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", }, @@ -122511,7 +124115,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\f", @@ -122538,7 +124142,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\\f", @@ -122559,7 +124163,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", "std", @@ -122664,7 +124268,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", }, @@ -122685,7 +124289,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\n", @@ -122712,7 +124316,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\\n", @@ -122733,7 +124337,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", "std", @@ -122838,7 +124442,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", }, @@ -122859,7 +124463,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\r", @@ -122886,7 +124490,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\\r", @@ -122907,7 +124511,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", "std", @@ -123012,7 +124616,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", }, @@ -123033,7 +124637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\t", @@ -123060,7 +124664,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\\t", @@ -123081,7 +124685,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", "std", @@ -123104,7 +124708,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8938, + context: p11191, freeVariables: Identifiers{ "ch", "std", @@ -123124,7 +124728,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8938, + context: p11191, freeVariables: Identifiers{ "std", }, @@ -123143,7 +124747,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8938, + context: p11191, freeVariables: Identifiers{ "std", }, @@ -123189,7 +124793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8947, + context: p11200, freeVariables: Identifiers{ "ch", }, @@ -123219,7 +124823,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", "cp", @@ -123240,7 +124844,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "cp", }, @@ -123259,7 +124863,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "cp", }, @@ -123278,7 +124882,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "cp", }, @@ -123300,7 +124904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: float64(32), @@ -123322,7 +124926,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "cp", }, @@ -123341,7 +124945,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "cp", }, @@ -123360,7 +124964,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "cp", }, @@ -123382,7 +124986,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: float64(126), @@ -123404,7 +125008,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "cp", }, @@ -123423,7 +125027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "cp", }, @@ -123445,7 +125049,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: float64(159), @@ -123553,7 +125157,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: nil, }, Value: "\\u%04x", @@ -123574,7 +125178,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "cp", }, @@ -123594,7 +125198,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8983, + context: p11236, freeVariables: Identifiers{ "cp", }, @@ -123624,7 +125228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8836, + context: p11089, freeVariables: Identifiers{ "ch", }, @@ -123744,7 +125348,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8813, + context: p11066, freeVariables: nil, }, Value: "\"%s\"", @@ -123765,7 +125369,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8813, + context: p11066, freeVariables: Identifiers{ "std", "str", @@ -123786,7 +125390,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8813, + context: p11066, freeVariables: Identifiers{ "std", }, @@ -123805,7 +125409,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p8813, + context: p11066, freeVariables: Identifiers{ "std", }, @@ -123851,7 +125455,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9005, + context: p11258, freeVariables: nil, }, Value: "", @@ -124005,7 +125609,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9021, + context: p11274, freeVariables: Identifiers{ "ch", "trans", @@ -124025,7 +125629,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9021, + context: p11274, freeVariables: Identifiers{ "trans", }, @@ -124048,7 +125652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9027, + context: p11280, freeVariables: Identifiers{ "ch", }, @@ -124079,7 +125683,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9005, + context: p11258, freeVariables: Identifiers{ "std", "str", @@ -124099,7 +125703,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9005, + context: p11258, freeVariables: Identifiers{ "std", }, @@ -124118,7 +125722,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9005, + context: p11258, freeVariables: Identifiers{ "std", }, @@ -124164,7 +125768,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9038, + context: p11291, freeVariables: Identifiers{ "str", }, @@ -124258,7 +125862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11297, freeVariables: nil, }, }, @@ -124280,7 +125884,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11299, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -124522,7 +126126,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11323, freeVariables: Identifiers{ "base64_table", "i", @@ -124546,7 +126150,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11327, freeVariables: Identifiers{ "base64_table", "i", @@ -124566,7 +126170,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11330, freeVariables: Identifiers{ "base64_table", }, @@ -124587,7 +126191,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11333, freeVariables: Identifiers{ "i", }, @@ -124610,7 +126214,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p11336, freeVariables: Identifiers{ "i", }, @@ -124639,7 +126243,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11339, freeVariables: Identifiers{ "std", }, @@ -124658,7 +126262,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11342, freeVariables: Identifiers{ "std", }, @@ -124677,7 +126281,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11345, freeVariables: Identifiers{ "std", }, @@ -124723,7 +126327,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11350, freeVariables: nil, }, Value: float64(0), @@ -124743,14 +126347,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11352, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -124806,7 +126410,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -124832,7 +126436,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9046, + context: p11358, freeVariables: Identifiers{ "std", "str", @@ -124852,7 +126456,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9046, + context: p11358, freeVariables: Identifiers{ "std", }, @@ -124871,7 +126475,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9046, + context: p11358, freeVariables: Identifiers{ "std", }, @@ -124917,7 +126521,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9055, + context: p11367, freeVariables: Identifiers{ "str", }, @@ -124991,7 +126595,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11373, freeVariables: nil, }, }, @@ -125013,7 +126617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11375, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -125255,7 +126859,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11399, freeVariables: Identifiers{ "base64_table", "i", @@ -125279,7 +126883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11403, freeVariables: Identifiers{ "base64_table", "i", @@ -125299,7 +126903,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11406, freeVariables: Identifiers{ "base64_table", }, @@ -125320,7 +126924,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11409, freeVariables: Identifiers{ "i", }, @@ -125343,7 +126947,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p11412, freeVariables: Identifiers{ "i", }, @@ -125372,7 +126976,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11415, freeVariables: Identifiers{ "std", }, @@ -125391,7 +126995,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11418, freeVariables: Identifiers{ "std", }, @@ -125410,7 +127014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11421, freeVariables: Identifiers{ "std", }, @@ -125456,7 +127060,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11426, freeVariables: nil, }, Value: float64(0), @@ -125476,14 +127080,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11428, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -125539,7 +127143,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -125565,7 +127169,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9063, + context: p11434, freeVariables: Identifiers{ "std", "str_", @@ -125588,7 +127192,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9067, + context: p11438, freeVariables: Identifiers{ "std", "str_", @@ -125608,7 +127212,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9067, + context: p11438, freeVariables: Identifiers{ "std", }, @@ -125627,7 +127231,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9067, + context: p11438, freeVariables: Identifiers{ "std", }, @@ -125673,7 +127277,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9076, + context: p11447, freeVariables: Identifiers{ "str_", }, @@ -125703,7 +127307,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9063, + context: p11434, freeVariables: Identifiers{ "std", "str", @@ -125726,7 +127330,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9082, + context: p11453, freeVariables: Identifiers{ "std", }, @@ -125752,7 +127356,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9086, + context: p11457, freeVariables: Identifiers{ "ch", "std", @@ -125857,7 +127461,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9086, + context: p11457, freeVariables: Identifiers{ "ch", }, @@ -125878,7 +127482,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9086, + context: p11457, freeVariables: nil, }, Value: "'", @@ -125905,7 +127509,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9086, + context: p11457, freeVariables: nil, }, Value: "'\"'\"'", @@ -125926,7 +127530,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9086, + context: p11457, freeVariables: Identifiers{ "ch", }, @@ -126038,7 +127642,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9063, + context: p11434, freeVariables: nil, }, Value: "'%s'", @@ -126059,7 +127663,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9063, + context: p11434, freeVariables: Identifiers{ "std", "str", @@ -126080,7 +127684,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9063, + context: p11434, freeVariables: Identifiers{ "std", }, @@ -126099,7 +127703,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9063, + context: p11434, freeVariables: Identifiers{ "std", }, @@ -126145,7 +127749,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9120, + context: p11491, freeVariables: nil, }, Value: "", @@ -126299,7 +127903,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9136, + context: p11507, freeVariables: Identifiers{ "ch", "trans", @@ -126319,7 +127923,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9136, + context: p11507, freeVariables: Identifiers{ "trans", }, @@ -126342,7 +127946,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9142, + context: p11513, freeVariables: Identifiers{ "ch", }, @@ -126373,7 +127977,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9120, + context: p11491, freeVariables: Identifiers{ "std", "str", @@ -126393,7 +127997,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9120, + context: p11491, freeVariables: Identifiers{ "std", }, @@ -126412,7 +128016,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9120, + context: p11491, freeVariables: Identifiers{ "std", }, @@ -126458,7 +128062,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9153, + context: p11524, freeVariables: Identifiers{ "str", }, @@ -126552,7 +128156,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11530, freeVariables: nil, }, }, @@ -126574,7 +128178,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11532, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -126816,7 +128420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11556, freeVariables: Identifiers{ "base64_table", "i", @@ -126840,7 +128444,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11560, freeVariables: Identifiers{ "base64_table", "i", @@ -126860,7 +128464,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11563, freeVariables: Identifiers{ "base64_table", }, @@ -126881,7 +128485,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11566, freeVariables: Identifiers{ "i", }, @@ -126904,7 +128508,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p11569, freeVariables: Identifiers{ "i", }, @@ -126933,7 +128537,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11572, freeVariables: Identifiers{ "std", }, @@ -126952,7 +128556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11575, freeVariables: Identifiers{ "std", }, @@ -126971,7 +128575,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11578, freeVariables: Identifiers{ "std", }, @@ -127017,7 +128621,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11583, freeVariables: nil, }, Value: float64(0), @@ -127037,14 +128641,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11585, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -127100,7 +128704,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -127126,7 +128730,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9161, + context: p11591, freeVariables: Identifiers{ "std", "str_", @@ -127149,7 +128753,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9165, + context: p11595, freeVariables: Identifiers{ "std", "str_", @@ -127169,7 +128773,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9165, + context: p11595, freeVariables: Identifiers{ "std", }, @@ -127188,7 +128792,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9165, + context: p11595, freeVariables: Identifiers{ "std", }, @@ -127234,7 +128838,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9174, + context: p11604, freeVariables: Identifiers{ "str_", }, @@ -127264,7 +128868,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9161, + context: p11591, freeVariables: Identifiers{ "std", "str", @@ -127287,7 +128891,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9180, + context: p11610, freeVariables: Identifiers{ "std", }, @@ -127313,7 +128917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9184, + context: p11614, freeVariables: Identifiers{ "ch", "std", @@ -127418,7 +129022,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9184, + context: p11614, freeVariables: Identifiers{ "ch", }, @@ -127439,7 +129043,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9184, + context: p11614, freeVariables: nil, }, Value: "$", @@ -127466,7 +129070,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9184, + context: p11614, freeVariables: nil, }, Value: "$$", @@ -127487,7 +129091,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9184, + context: p11614, freeVariables: Identifiers{ "ch", }, @@ -127513,7 +129117,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9161, + context: p11591, freeVariables: Identifiers{ "std", "str", @@ -127534,7 +129138,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9161, + context: p11591, freeVariables: Identifiers{ "std", }, @@ -127553,7 +129157,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9161, + context: p11591, freeVariables: Identifiers{ "std", }, @@ -127599,7 +129203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9209, + context: p11639, freeVariables: Identifiers{ "trans", }, @@ -127626,7 +129230,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9213, + context: p11643, freeVariables: Identifiers{ "a", "b", @@ -127647,7 +129251,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9213, + context: p11643, freeVariables: Identifiers{ "a", }, @@ -127669,7 +129273,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9213, + context: p11643, freeVariables: Identifiers{ "b", "trans", @@ -127689,7 +129293,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9213, + context: p11643, freeVariables: Identifiers{ "trans", }, @@ -127712,7 +129316,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9223, + context: p11653, freeVariables: Identifiers{ "b", }, @@ -127741,7 +129345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9209, + context: p11639, freeVariables: Identifiers{ "std", "str", @@ -127761,7 +129365,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9209, + context: p11639, freeVariables: Identifiers{ "std", }, @@ -127780,7 +129384,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9209, + context: p11639, freeVariables: Identifiers{ "std", }, @@ -127826,7 +129430,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9234, + context: p11664, freeVariables: Identifiers{ "str", }, @@ -127853,7 +129457,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9209, + context: p11639, freeVariables: nil, }, Value: "", @@ -127929,7 +129533,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11671, freeVariables: nil, }, }, @@ -127951,7 +129555,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11673, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -128193,7 +129797,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11697, freeVariables: Identifiers{ "base64_table", "i", @@ -128217,7 +129821,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11701, freeVariables: Identifiers{ "base64_table", "i", @@ -128237,7 +129841,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11704, freeVariables: Identifiers{ "base64_table", }, @@ -128258,7 +129862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11707, freeVariables: Identifiers{ "i", }, @@ -128281,7 +129885,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p11710, freeVariables: Identifiers{ "i", }, @@ -128310,7 +129914,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11713, freeVariables: Identifiers{ "std", }, @@ -128329,7 +129933,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11716, freeVariables: Identifiers{ "std", }, @@ -128348,7 +129952,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11719, freeVariables: Identifiers{ "std", }, @@ -128394,7 +129998,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11724, freeVariables: nil, }, Value: float64(0), @@ -128414,14 +130018,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11726, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -128477,7 +130081,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -128503,7 +130107,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9243, + context: p11732, freeVariables: Identifiers{ "std", "value", @@ -128523,7 +130127,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9243, + context: p11732, freeVariables: Identifiers{ "std", }, @@ -128542,7 +130146,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9243, + context: p11732, freeVariables: Identifiers{ "std", }, @@ -128588,7 +130192,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9252, + context: p11741, freeVariables: Identifiers{ "value", }, @@ -128609,7 +130213,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9252, + context: p11741, freeVariables: nil, }, Value: " ", @@ -128683,7 +130287,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11748, freeVariables: nil, }, }, @@ -128705,7 +130309,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11750, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -128947,7 +130551,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11774, freeVariables: Identifiers{ "base64_table", "i", @@ -128971,7 +130575,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11778, freeVariables: Identifiers{ "base64_table", "i", @@ -128991,7 +130595,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11781, freeVariables: Identifiers{ "base64_table", }, @@ -129012,7 +130616,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11784, freeVariables: Identifiers{ "i", }, @@ -129035,7 +130639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p11787, freeVariables: Identifiers{ "i", }, @@ -129064,7 +130668,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11790, freeVariables: Identifiers{ "std", }, @@ -129083,7 +130687,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11793, freeVariables: Identifiers{ "std", }, @@ -129102,7 +130706,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p11796, freeVariables: Identifiers{ "std", }, @@ -129148,7 +130752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11801, freeVariables: nil, }, Value: float64(0), @@ -129168,14 +130772,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p11803, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -129231,7 +130835,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -129258,7 +130862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9261, + context: p11809, freeVariables: Identifiers{ "indent", "std", @@ -129282,7 +130886,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9265, + context: p11813, freeVariables: Identifiers{ "aux", "indent", @@ -129312,7 +130916,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -129421,7 +131025,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "v", }, @@ -129442,7 +131046,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: true, @@ -129467,7 +131071,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "true", @@ -129488,7 +131092,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -129597,7 +131201,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "v", }, @@ -129618,7 +131222,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: false, @@ -129643,7 +131247,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "false", @@ -129664,7 +131268,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -129773,7 +131377,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "v", }, @@ -129794,7 +131398,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, }, @@ -129818,7 +131422,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "null", @@ -129839,7 +131443,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -129948,7 +131552,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", "v", @@ -129968,7 +131572,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -129987,7 +131591,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -130033,7 +131637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9330, + context: p11878, freeVariables: Identifiers{ "v", }, @@ -130060,7 +131664,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "number", @@ -130087,7 +131691,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "v", }, @@ -130106,7 +131710,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "", @@ -130128,7 +131732,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "v", }, @@ -130150,7 +131754,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -130259,7 +131863,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", "v", @@ -130279,7 +131883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -130298,7 +131902,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -130344,7 +131948,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9357, + context: p11905, freeVariables: Identifiers{ "v", }, @@ -130371,7 +131975,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "string", @@ -130398,7 +132002,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", "v", @@ -130418,7 +132022,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -130437,7 +132041,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -130483,7 +132087,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9369, + context: p11917, freeVariables: Identifiers{ "v", }, @@ -130510,7 +132114,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -130619,7 +132223,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", "v", @@ -130639,7 +132243,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -130658,7 +132262,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -130704,7 +132308,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9390, + context: p11938, freeVariables: Identifiers{ "v", }, @@ -130731,7 +132335,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "function", @@ -130758,7 +132362,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "path", }, @@ -130777,7 +132381,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "path", }, @@ -130796,7 +132400,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "Tried to manifest function at ", @@ -130818,7 +132422,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "path", }, @@ -130841,7 +132445,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -130950,7 +132554,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", "v", @@ -130970,7 +132574,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -130989,7 +132593,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -131035,7 +132639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9419, + context: p11967, freeVariables: Identifiers{ "v", }, @@ -131062,7 +132666,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "array", @@ -131089,7 +132693,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -131116,7 +132720,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9426, + context: p11974, freeVariables: Identifiers{ "std", "v", @@ -131136,7 +132740,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9426, + context: p11974, freeVariables: Identifiers{ "std", }, @@ -131155,7 +132759,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9426, + context: p11974, freeVariables: Identifiers{ "std", }, @@ -131201,7 +132805,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9435, + context: p11983, freeVariables: nil, }, Value: float64(0), @@ -131221,7 +132825,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9435, + context: p11983, freeVariables: Identifiers{ "std", "v", @@ -131241,7 +132845,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9435, + context: p11983, freeVariables: Identifiers{ "std", "v", @@ -131261,7 +132865,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9435, + context: p11983, freeVariables: Identifiers{ "std", }, @@ -131280,7 +132884,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9435, + context: p11983, freeVariables: Identifiers{ "std", }, @@ -131326,7 +132930,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9447, + context: p11995, freeVariables: Identifiers{ "v", }, @@ -131354,7 +132958,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9435, + context: p11983, freeVariables: nil, }, Value: float64(1), @@ -131384,7 +132988,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -131412,7 +133016,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9454, + context: p12002, freeVariables: Identifiers{ "cindent", "indent", @@ -131432,7 +133036,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9454, + context: p12002, freeVariables: Identifiers{ "cindent", }, @@ -131454,7 +133058,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9454, + context: p12002, freeVariables: Identifiers{ "indent", }, @@ -131479,7 +133083,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -131507,7 +133111,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9464, + context: p12012, freeVariables: Identifiers{ "aux", "cindent", @@ -131532,7 +133136,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9464, + context: p12012, freeVariables: Identifiers{ "aux", "new_indent", @@ -131556,7 +133160,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9464, + context: p12012, freeVariables: nil, }, Elements: Nodes{ @@ -131574,7 +133178,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9471, + context: p12019, freeVariables: nil, }, Value: "[\n", @@ -131599,7 +133203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9464, + context: p12012, freeVariables: Identifiers{ "aux", "new_indent", @@ -131623,7 +133227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9464, + context: p12012, freeVariables: Identifiers{ "std", }, @@ -131642,7 +133246,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9464, + context: p12012, freeVariables: Identifiers{ "std", }, @@ -131688,7 +133292,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9481, + context: p12029, freeVariables: nil, }, Elements: Nodes{ @@ -131706,7 +133310,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9484, + context: p12032, freeVariables: nil, }, Value: ",\n", @@ -131872,7 +133476,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9500, + context: p12048, freeVariables: Identifiers{ "aux", "i", @@ -131896,7 +133500,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9504, + context: p12052, freeVariables: Identifiers{ "aux", "i", @@ -131919,7 +133523,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9504, + context: p12052, freeVariables: Identifiers{ "new_indent", }, @@ -131941,7 +133545,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9504, + context: p12052, freeVariables: Identifiers{ "aux", "i", @@ -131964,7 +133568,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9504, + context: p12052, freeVariables: Identifiers{ "aux", }, @@ -131987,7 +133591,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9514, + context: p12062, freeVariables: Identifiers{ "i", "v", @@ -132007,7 +133611,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9514, + context: p12062, freeVariables: Identifiers{ "v", }, @@ -132028,7 +133632,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9514, + context: p12062, freeVariables: Identifiers{ "i", }, @@ -132051,7 +133655,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9514, + context: p12062, freeVariables: Identifiers{ "i", "path", @@ -132071,7 +133675,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9514, + context: p12062, freeVariables: Identifiers{ "path", }, @@ -132093,7 +133697,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9514, + context: p12062, freeVariables: Identifiers{ "i", }, @@ -132113,7 +133717,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9528, + context: p12076, freeVariables: Identifiers{ "i", }, @@ -132138,7 +133742,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9514, + context: p12062, freeVariables: Identifiers{ "new_indent", }, @@ -132173,7 +133777,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9481, + context: p12029, freeVariables: Identifiers{ "range", }, @@ -132208,7 +133812,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9464, + context: p12012, freeVariables: Identifiers{ "cindent", }, @@ -132228,7 +133832,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9538, + context: p12086, freeVariables: Identifiers{ "cindent", }, @@ -132247,7 +133851,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9538, + context: p12086, freeVariables: Identifiers{ "cindent", }, @@ -132266,7 +133870,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9538, + context: p12086, freeVariables: nil, }, Value: "\n", @@ -132288,7 +133892,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9538, + context: p12086, freeVariables: Identifiers{ "cindent", }, @@ -132311,7 +133915,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9538, + context: p12086, freeVariables: nil, }, Value: "]", @@ -132340,7 +133944,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "lines", "std", @@ -132360,7 +133964,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -132379,7 +133983,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -132425,7 +134029,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9555, + context: p12103, freeVariables: nil, }, Value: "", @@ -132446,7 +134050,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9555, + context: p12103, freeVariables: Identifiers{ "lines", }, @@ -132476,7 +134080,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -132585,7 +134189,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", "v", @@ -132605,7 +134209,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -132624,7 +134228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -132670,7 +134274,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9577, + context: p12125, freeVariables: Identifiers{ "v", }, @@ -132697,7 +134301,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: nil, }, Value: "object", @@ -132724,7 +134328,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "aux", "cindent", @@ -132751,7 +134355,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9584, + context: p12132, freeVariables: Identifiers{ "aux", "cindent", @@ -132775,7 +134379,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9584, + context: p12132, freeVariables: Identifiers{ "aux", "cindent", @@ -132799,7 +134403,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9584, + context: p12132, freeVariables: nil, }, Elements: Nodes{ @@ -132817,7 +134421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9591, + context: p12139, freeVariables: nil, }, Value: "{\n", @@ -132842,7 +134446,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9584, + context: p12132, freeVariables: Identifiers{ "aux", "cindent", @@ -132866,7 +134470,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9584, + context: p12132, freeVariables: Identifiers{ "std", }, @@ -132885,7 +134489,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9584, + context: p12132, freeVariables: Identifiers{ "std", }, @@ -132931,7 +134535,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9601, + context: p12149, freeVariables: nil, }, Elements: Nodes{ @@ -132949,7 +134553,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9604, + context: p12152, freeVariables: nil, }, Value: ",\n", @@ -133119,7 +134723,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9620, + context: p12168, freeVariables: Identifiers{ "aux", "cindent", @@ -133145,7 +134749,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "aux", "cindent", @@ -133170,7 +134774,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "cindent", "indent", @@ -133192,7 +134796,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "cindent", "indent", @@ -133214,7 +134818,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "cindent", "indent", @@ -133234,7 +134838,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "cindent", }, @@ -133256,7 +134860,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "indent", }, @@ -133279,7 +134883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "k", "std", @@ -133299,7 +134903,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "std", }, @@ -133318,7 +134922,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "std", }, @@ -133364,7 +134968,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9645, + context: p12193, freeVariables: Identifiers{ "k", }, @@ -133393,7 +134997,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: nil, }, Value: ": ", @@ -133416,7 +135020,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "aux", "cindent", @@ -133440,7 +135044,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9624, + context: p12172, freeVariables: Identifiers{ "aux", }, @@ -133463,7 +135067,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9654, + context: p12202, freeVariables: Identifiers{ "k", "v", @@ -133483,7 +135087,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9654, + context: p12202, freeVariables: Identifiers{ "v", }, @@ -133504,7 +135108,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9654, + context: p12202, freeVariables: Identifiers{ "k", }, @@ -133527,7 +135131,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9654, + context: p12202, freeVariables: Identifiers{ "k", "path", @@ -133547,7 +135151,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9654, + context: p12202, freeVariables: Identifiers{ "path", }, @@ -133569,7 +135173,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9654, + context: p12202, freeVariables: Identifiers{ "k", }, @@ -133589,7 +135193,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9668, + context: p12216, freeVariables: Identifiers{ "k", }, @@ -133614,7 +135218,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9654, + context: p12202, freeVariables: Identifiers{ "cindent", "indent", @@ -133634,7 +135238,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9654, + context: p12202, freeVariables: Identifiers{ "cindent", }, @@ -133656,7 +135260,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9654, + context: p12202, freeVariables: Identifiers{ "indent", }, @@ -133692,7 +135296,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9601, + context: p12149, freeVariables: Identifiers{ "std", "v", @@ -133712,7 +135316,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9601, + context: p12149, freeVariables: Identifiers{ "std", }, @@ -133731,7 +135335,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9601, + context: p12149, freeVariables: Identifiers{ "std", }, @@ -133777,7 +135381,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9685, + context: p12233, freeVariables: Identifiers{ "v", }, @@ -133818,7 +135422,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9584, + context: p12132, freeVariables: Identifiers{ "cindent", }, @@ -133838,7 +135442,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9691, + context: p12239, freeVariables: Identifiers{ "cindent", }, @@ -133857,7 +135461,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9691, + context: p12239, freeVariables: Identifiers{ "cindent", }, @@ -133876,7 +135480,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9691, + context: p12239, freeVariables: nil, }, Value: "\n", @@ -133898,7 +135502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9691, + context: p12239, freeVariables: Identifiers{ "cindent", }, @@ -133921,7 +135525,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9691, + context: p12239, freeVariables: nil, }, Value: "}", @@ -133950,7 +135554,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "lines", "std", @@ -133970,7 +135574,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -133989,7 +135593,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9269, + context: p11817, freeVariables: Identifiers{ "std", }, @@ -134035,7 +135639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9708, + context: p12256, freeVariables: nil, }, Value: "", @@ -134056,7 +135660,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9708, + context: p12256, freeVariables: Identifiers{ "lines", }, @@ -134114,7 +135718,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9261, + context: p11809, freeVariables: Identifiers{ "aux", "value", @@ -134134,7 +135738,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9261, + context: p11809, freeVariables: Identifiers{ "aux", }, @@ -134157,7 +135761,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9718, + context: p12266, freeVariables: Identifiers{ "value", }, @@ -134178,7 +135782,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9718, + context: p12266, freeVariables: nil, }, Elements: nil, @@ -134198,7 +135802,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9718, + context: p12266, freeVariables: nil, }, Value: "", @@ -134273,7 +135877,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12274, freeVariables: nil, }, }, @@ -134295,7 +135899,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12276, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -134537,7 +136141,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12300, freeVariables: Identifiers{ "base64_table", "i", @@ -134561,7 +136165,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12304, freeVariables: Identifiers{ "base64_table", "i", @@ -134581,7 +136185,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12307, freeVariables: Identifiers{ "base64_table", }, @@ -134602,7 +136206,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12310, freeVariables: Identifiers{ "i", }, @@ -134625,7 +136229,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p12313, freeVariables: Identifiers{ "i", }, @@ -134654,7 +136258,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12316, freeVariables: Identifiers{ "std", }, @@ -134673,7 +136277,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12319, freeVariables: Identifiers{ "std", }, @@ -134692,7 +136296,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12322, freeVariables: Identifiers{ "std", }, @@ -134738,7 +136342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p12327, freeVariables: nil, }, Value: float64(0), @@ -134758,14 +136362,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p12329, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -134821,7 +136425,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -134843,11 +136447,11 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(940), - Column: int(37), + Column: int(30), }, file: p1, }, - context: p9728, + context: p12335, freeVariables: Identifiers{ "std", "value", @@ -134866,11 +136470,11 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9732, + context: p12339, freeVariables: Identifiers{ "aux", "std", @@ -134879,7 +136483,6 @@ var StdAst = &DesugaredObject{ Parameters: Parameters{ Required: Identifiers{ "v", - "in_array", "in_object", "path", "cindent", @@ -134897,15 +136500,14 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -135011,7 +136613,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "v", }, @@ -135032,7 +136634,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: true, @@ -135057,7 +136659,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "true", @@ -135074,15 +136676,14 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -135188,7 +136789,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "v", }, @@ -135209,7 +136810,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: false, @@ -135234,7 +136835,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "false", @@ -135251,15 +136852,14 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -135365,7 +136965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "v", }, @@ -135386,7 +136986,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, }, @@ -135410,7 +137010,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "null", @@ -135427,15 +137027,14 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -135541,7 +137140,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", "v", @@ -135561,7 +137160,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -135580,7 +137179,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -135626,7 +137225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9797, + context: p12404, freeVariables: Identifiers{ "v", }, @@ -135653,7 +137252,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "number", @@ -135680,7 +137279,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "v", }, @@ -135699,7 +137298,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "", @@ -135721,7 +137320,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "v", }, @@ -135739,15 +137338,14 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -135853,7 +137451,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", "v", @@ -135873,7 +137471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -135892,7 +137490,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -135938,7 +137536,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9824, + context: p12431, freeVariables: Identifiers{ "v", }, @@ -135965,7 +137563,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "string", @@ -135992,7 +137590,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "cindent", "std", @@ -136016,7 +137614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9831, + context: p12438, freeVariables: Identifiers{ "std", "v", @@ -136036,7 +137634,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9831, + context: p12438, freeVariables: Identifiers{ "std", }, @@ -136055,7 +137653,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9831, + context: p12438, freeVariables: Identifiers{ "std", }, @@ -136101,7 +137699,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9840, + context: p12447, freeVariables: Identifiers{ "v", }, @@ -136131,7 +137729,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "cindent", "len", @@ -136238,7 +137836,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "len", }, @@ -136259,7 +137857,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: float64(0), @@ -136285,7 +137883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "\"\"", @@ -136306,7 +137904,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "cindent", "len", @@ -136414,7 +138012,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "len", "v", @@ -136434,7 +138032,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "v", }, @@ -136455,7 +138053,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "len", }, @@ -136474,7 +138072,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "len", }, @@ -136496,7 +138094,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: float64(1), @@ -136519,7 +138117,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "\n", @@ -136546,7 +138144,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "cindent", "std", @@ -136570,7 +138168,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9880, + context: p12487, freeVariables: Identifiers{ "std", "v", @@ -136590,7 +138188,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9880, + context: p12487, freeVariables: Identifiers{ "std", }, @@ -136609,7 +138207,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9880, + context: p12487, freeVariables: Identifiers{ "std", }, @@ -136655,7 +138253,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9889, + context: p12496, freeVariables: Identifiers{ "v", }, @@ -136676,7 +138274,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9889, + context: p12496, freeVariables: nil, }, Value: "\n", @@ -136706,7 +138304,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "cindent", "split", @@ -136727,7 +138325,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -136746,7 +138344,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -136792,7 +138390,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: Identifiers{ "cindent", }, @@ -136811,7 +138409,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: nil, }, Value: "\n", @@ -136833,7 +138431,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: Identifiers{ "cindent", }, @@ -136855,7 +138453,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: Identifiers{ "split", "std", @@ -136875,7 +138473,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: nil, }, Elements: Nodes{ @@ -136893,7 +138491,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9911, + context: p12518, freeVariables: nil, }, Value: "|", @@ -137003,7 +138601,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: Identifiers{ "split", }, @@ -137024,7 +138622,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: nil, }, Value: float64(0), @@ -137044,7 +138642,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: Identifiers{ "split", "std", @@ -137064,7 +138662,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: Identifiers{ "split", "std", @@ -137084,7 +138682,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: Identifiers{ "std", }, @@ -137103,7 +138701,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: Identifiers{ "std", }, @@ -137149,7 +138747,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9934, + context: p12541, freeVariables: Identifiers{ "split", }, @@ -137177,7 +138775,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9901, + context: p12508, freeVariables: nil, }, Value: float64(1), @@ -137230,7 +138828,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", "v", @@ -137250,7 +138848,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -137269,7 +138867,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -137315,7 +138913,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9947, + context: p12554, freeVariables: Identifiers{ "v", }, @@ -137341,15 +138939,14 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -137455,7 +139052,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", "v", @@ -137475,7 +139072,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -137494,7 +139091,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -137540,7 +139137,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9968, + context: p12575, freeVariables: Identifiers{ "v", }, @@ -137567,7 +139164,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "function", @@ -137594,7 +139191,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "path", }, @@ -137613,7 +139210,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "path", }, @@ -137632,7 +139229,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "Tried to manifest function at ", @@ -137654,7 +139251,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "path", }, @@ -137673,15 +139270,14 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -137787,7 +139383,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", "v", @@ -137807,7 +139403,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -137826,7 +139422,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -137872,7 +139468,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9997, + context: p12604, freeVariables: Identifiers{ "v", }, @@ -137899,7 +139495,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "array", @@ -137921,12 +139517,12 @@ var StdAst = &DesugaredObject{ Column: int(9), }, End: Location{ - Line: int(928), - Column: int(101), + Line: int(929), + Column: int(64), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", @@ -138035,7 +139631,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", "v", @@ -138055,7 +139651,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -138074,7 +139670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -138120,7 +139716,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10019, + context: p12626, freeVariables: Identifiers{ "v", }, @@ -138147,7 +139743,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: float64(0), @@ -138173,7 +139769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "[]", @@ -138189,12 +139785,12 @@ var StdAst = &DesugaredObject{ Column: int(11), }, End: Location{ - Line: int(928), - Column: int(101), + Line: int(929), + Column: int(64), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", @@ -138221,7 +139817,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10027, + context: p12634, freeVariables: Identifiers{ "std", "v", @@ -138241,7 +139837,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10027, + context: p12634, freeVariables: Identifiers{ "std", }, @@ -138260,7 +139856,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10027, + context: p12634, freeVariables: Identifiers{ "std", }, @@ -138306,7 +139902,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10036, + context: p12643, freeVariables: nil, }, Value: float64(0), @@ -138326,7 +139922,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10036, + context: p12643, freeVariables: Identifiers{ "std", "v", @@ -138346,7 +139942,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10036, + context: p12643, freeVariables: Identifiers{ "std", "v", @@ -138366,7 +139962,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10036, + context: p12643, freeVariables: Identifiers{ "std", }, @@ -138385,7 +139981,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10036, + context: p12643, freeVariables: Identifiers{ "std", }, @@ -138431,7 +140027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10048, + context: p12655, freeVariables: Identifiers{ "v", }, @@ -138459,7 +140055,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10036, + context: p12643, freeVariables: nil, }, Value: float64(1), @@ -138484,12 +140080,12 @@ var StdAst = &DesugaredObject{ Column: int(11), }, End: Location{ - Line: int(928), - Column: int(101), + Line: int(929), + Column: int(64), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", @@ -138502,103 +140098,50 @@ var StdAst = &DesugaredObject{ }, Binds: LocalBinds{ LocalBind{ - Variable: "new_indent", - Body: &Binary{ + Variable: "actual_indent", + Body: &Conditional{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ Line: int(926), - Column: int(30), + Column: int(33), }, End: Location{ Line: int(926), - Column: int(44), + Column: int(75), }, file: p1, }, - context: p10055, + context: p12662, freeVariables: Identifiers{ "cindent", + "in_object", + "std", }, }, - Left: &Var{ + Cond: &Var{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ Line: int(926), - Column: int(30), + Column: int(36), }, End: Location{ Line: int(926), - Column: int(37), + Column: int(45), }, file: p1, }, - context: p10055, + context: p12662, freeVariables: Identifiers{ - "cindent", - }, - }, - Id: "cindent", - }, - Op: BinaryOp(3), - Right: &LiteralString{ - NodeBase: NodeBase{ - loc: LocationRange{ - FileName: "", - Begin: Location{ - Line: int(926), - Column: int(40), - }, - End: Location{ - Line: int(926), - Column: int(44), - }, - file: p1, + "in_object", }, - context: p10055, - freeVariables: nil, }, - Value: " ", - Kind: LiteralStringKind(1), - BlockIndent: "", + Id: "in_object", }, - }, - Fun: nil, - }, - }, - Body: &Local{ - NodeBase: NodeBase{ - loc: LocationRange{ - FileName: "", - Begin: Location{ - Line: int(927), - Column: int(11), - }, - End: Location{ - Line: int(928), - Column: int(101), - }, - file: p1, - }, - context: p9736, - freeVariables: Identifiers{ - "aux", - "cindent", - "in_object", - "new_indent", - "path", - "range", - "std", - "v", - }, - }, - Binds: LocalBinds{ - LocalBind{ - Variable: "parts", - Body: &Apply{ + BranchTrue: &Apply{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", @@ -138614,12 +140157,234 @@ var StdAst = &DesugaredObject{ }, context: nil, freeVariables: Identifiers{ - "aux", - "new_indent", - "path", - "range", + "cindent", "std", - "v", + }, + }, + Target: &Index{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(0), + Column: int(0), + }, + End: Location{ + Line: int(0), + Column: int(0), + }, + file: nil, + }, + context: nil, + freeVariables: Identifiers{ + "std", + }, + }, + Target: &Var{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(0), + Column: int(0), + }, + End: Location{ + Line: int(0), + Column: int(0), + }, + file: nil, + }, + context: nil, + freeVariables: Identifiers{ + "std", + }, + }, + Id: "std", + }, + Index: &LiteralString{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(0), + Column: int(0), + }, + End: Location{ + Line: int(0), + Column: int(0), + }, + file: nil, + }, + context: nil, + freeVariables: nil, + }, + Value: "slice", + Kind: LiteralStringKind(1), + BlockIndent: "", + }, + Id: nil, + }, + Arguments: Arguments{ + Positional: Nodes{ + &Var{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(926), + Column: int(51), + }, + End: Location{ + Line: int(926), + Column: int(58), + }, + file: p1, + }, + context: p12662, + freeVariables: Identifiers{ + "cindent", + }, + }, + Id: "cindent", + }, + &LiteralNumber{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(926), + Column: int(59), + }, + End: Location{ + Line: int(926), + Column: int(60), + }, + file: p1, + }, + context: p12662, + freeVariables: nil, + }, + Value: float64(2), + OriginalString: "2", + }, + &LiteralNull{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(0), + Column: int(0), + }, + End: Location{ + Line: int(0), + Column: int(0), + }, + file: nil, + }, + context: nil, + freeVariables: nil, + }, + }, + &LiteralNull{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(0), + Column: int(0), + }, + End: Location{ + Line: int(0), + Column: int(0), + }, + file: nil, + }, + context: nil, + freeVariables: nil, + }, + }, + }, + Named: nil, + }, + TrailingComma: false, + TailStrict: false, + }, + BranchFalse: &Var{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(926), + Column: int(68), + }, + End: Location{ + Line: int(926), + Column: int(75), + }, + file: p1, + }, + context: p12662, + freeVariables: Identifiers{ + "cindent", + }, + }, + Id: "cindent", + }, + }, + Fun: nil, + }, + }, + Body: &Local{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(927), + Column: int(11), + }, + End: Location{ + Line: int(929), + Column: int(64), + }, + file: p1, + }, + context: p12343, + freeVariables: Identifiers{ + "actual_indent", + "aux", + "cindent", + "in_object", + "path", + "range", + "std", + "v", + }, + }, + Binds: LocalBinds{ + LocalBind{ + Variable: "parts", + Body: &Apply{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(0), + Column: int(0), + }, + End: Location{ + Line: int(0), + Column: int(0), + }, + file: nil, + }, + context: nil, + freeVariables: Identifiers{ + "aux", + "cindent", + "path", + "range", + "std", + "v", }, }, Target: &Index{ @@ -138704,7 +140469,7 @@ var StdAst = &DesugaredObject{ context: nil, freeVariables: Identifiers{ "aux", - "new_indent", + "cindent", "path", "v", }, @@ -138733,8 +140498,8 @@ var StdAst = &DesugaredObject{ context: nil, freeVariables: Identifiers{ "aux", + "cindent", "i", - "new_indent", "path", "v", }, @@ -138750,15 +140515,15 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(927), - Column: int(72), + Column: int(63), }, file: p1, }, - context: p10078, + context: p12699, freeVariables: Identifiers{ "aux", + "cindent", "i", - "new_indent", "path", "v", }, @@ -138777,7 +140542,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10078, + context: p12699, freeVariables: Identifiers{ "aux", }, @@ -138800,7 +140565,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10084, + context: p12705, freeVariables: Identifiers{ "i", "v", @@ -138820,7 +140585,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10084, + context: p12705, freeVariables: Identifiers{ "v", }, @@ -138841,7 +140606,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10084, + context: p12705, freeVariables: Identifiers{ "i", }, @@ -138860,30 +140625,11 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(927), - Column: int(40), - }, - file: p1, - }, - context: p10084, - freeVariables: nil, - }, - Value: true, - }, - &LiteralBoolean{ - NodeBase: NodeBase{ - loc: LocationRange{ - FileName: "", - Begin: Location{ - Line: int(927), - Column: int(42), - }, - End: Location{ - Line: int(927), - Column: int(47), + Column: int(41), }, file: p1, }, - context: p10084, + context: p12705, freeVariables: nil, }, Value: false, @@ -138894,15 +140640,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(927), - Column: int(49), + Column: int(43), }, End: Location{ Line: int(927), - Column: int(59), + Column: int(53), }, file: p1, }, - context: p10084, + context: p12705, freeVariables: Identifiers{ "i", "path", @@ -138914,15 +140660,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(927), - Column: int(49), + Column: int(43), }, End: Location{ Line: int(927), - Column: int(53), + Column: int(47), }, file: p1, }, - context: p10084, + context: p12705, freeVariables: Identifiers{ "path", }, @@ -138936,15 +140682,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(927), - Column: int(56), + Column: int(50), }, End: Location{ Line: int(927), - Column: int(59), + Column: int(53), }, file: p1, }, - context: p10084, + context: p12705, freeVariables: Identifiers{ "i", }, @@ -138956,15 +140702,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(927), - Column: int(57), + Column: int(51), }, End: Location{ Line: int(927), - Column: int(58), + Column: int(52), }, file: p1, }, - context: p10100, + context: p12720, freeVariables: Identifiers{ "i", }, @@ -138981,20 +140727,20 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(927), - Column: int(61), + Column: int(55), }, End: Location{ Line: int(927), - Column: int(71), + Column: int(62), }, file: p1, }, - context: p10084, + context: p12705, freeVariables: Identifiers{ - "new_indent", + "cindent", }, }, - Id: "new_indent", + Id: "cindent", }, }, Named: nil, @@ -139012,15 +140758,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(927), - Column: int(82), + Column: int(73), }, End: Location{ Line: int(927), - Column: int(87), + Column: int(78), }, file: p1, }, - context: p10105, + context: p12725, freeVariables: Identifiers{ "range", }, @@ -139045,14 +140791,14 @@ var StdAst = &DesugaredObject{ Column: int(11), }, End: Location{ - Line: int(928), - Column: int(101), + Line: int(929), + Column: int(64), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "cindent", + "actual_indent", "in_object", "parts", "std", @@ -139067,14 +140813,14 @@ var StdAst = &DesugaredObject{ Column: int(11), }, End: Location{ - Line: int(928), - Column: int(60), + Line: int(929), + Column: int(17), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "cindent", + "actual_indent", "in_object", }, }, @@ -139088,13 +140834,13 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(928), - Column: int(52), + Column: int(58), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "cindent", + "actual_indent", "in_object", }, }, @@ -139112,7 +140858,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "in_object", }, @@ -139129,13 +140875,13 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(928), - Column: int(44), + Column: int(50), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "cindent", + "actual_indent", }, }, Left: &LiteralString{ @@ -139152,7 +140898,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "\n", @@ -139170,16 +140916,16 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(928), - Column: int(44), + Column: int(50), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "cindent", + "actual_indent", }, }, - Id: "cindent", + Id: "actual_indent", }, }, BranchFalse: &LiteralString{ @@ -139188,15 +140934,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(928), - Column: int(50), + Column: int(56), }, End: Location{ Line: int(928), - Column: int(52), + Column: int(58), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "", @@ -139210,16 +140956,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(56), + Line: int(929), + Column: int(13), }, End: Location{ - Line: int(928), - Column: int(60), + Line: int(929), + Column: int(17), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "- ", @@ -139233,18 +140979,18 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(63), + Line: int(929), + Column: int(20), }, End: Location{ - Line: int(928), - Column: int(101), + Line: int(929), + Column: int(64), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "cindent", + "actual_indent", "parts", "std", }, @@ -139254,16 +141000,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(63), + Line: int(929), + Column: int(20), }, End: Location{ - Line: int(928), - Column: int(71), + Line: int(929), + Column: int(28), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -139273,16 +141019,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(63), + Line: int(929), + Column: int(20), }, End: Location{ - Line: int(928), - Column: int(66), + Line: int(929), + Column: int(23), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -139319,18 +141065,18 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(72), + Line: int(929), + Column: int(29), }, End: Location{ - Line: int(928), - Column: int(93), + Line: int(929), + Column: int(56), }, file: p1, }, - context: p10131, + context: p12751, freeVariables: Identifiers{ - "cindent", + "actual_indent", }, }, Left: &Binary{ @@ -139338,18 +141084,18 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(72), + Line: int(929), + Column: int(29), }, End: Location{ - Line: int(928), - Column: int(86), + Line: int(929), + Column: int(49), }, file: p1, }, - context: p10131, + context: p12751, freeVariables: Identifiers{ - "cindent", + "actual_indent", }, }, Left: &LiteralString{ @@ -139357,16 +141103,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(72), + Line: int(929), + Column: int(29), }, End: Location{ - Line: int(928), - Column: int(76), + Line: int(929), + Column: int(33), }, file: p1, }, - context: p10131, + context: p12751, freeVariables: nil, }, Value: "\n", @@ -139379,21 +141125,21 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(79), + Line: int(929), + Column: int(36), }, End: Location{ - Line: int(928), - Column: int(86), + Line: int(929), + Column: int(49), }, file: p1, }, - context: p10131, + context: p12751, freeVariables: Identifiers{ - "cindent", + "actual_indent", }, }, - Id: "cindent", + Id: "actual_indent", }, }, Op: BinaryOp(3), @@ -139402,16 +141148,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(89), + Line: int(929), + Column: int(52), }, End: Location{ - Line: int(928), - Column: int(93), + Line: int(929), + Column: int(56), }, file: p1, }, - context: p10131, + context: p12751, freeVariables: nil, }, Value: "- ", @@ -139424,16 +141170,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(928), - Column: int(95), + Line: int(929), + Column: int(58), }, End: Location{ - Line: int(928), - Column: int(100), + Line: int(929), + Column: int(63), }, file: p1, }, - context: p10131, + context: p12751, freeVariables: Identifiers{ "parts", }, @@ -139456,20 +141202,19 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(929), + Line: int(930), Column: int(12), }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -139566,16 +141311,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(929), + Line: int(930), Column: int(15), }, End: Location{ - Line: int(929), + Line: int(930), Column: int(26), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", "v", @@ -139586,16 +141331,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(929), + Line: int(930), Column: int(15), }, End: Location{ - Line: int(929), + Line: int(930), Column: int(23), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -139605,16 +141350,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(929), + Line: int(930), Column: int(15), }, End: Location{ - Line: int(929), + Line: int(930), Column: int(18), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -139651,16 +141396,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(929), + Line: int(930), Column: int(24), }, End: Location{ - Line: int(929), + Line: int(930), Column: int(25), }, file: p1, }, - context: p10160, + context: p12780, freeVariables: Identifiers{ "v", }, @@ -139678,16 +141423,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(929), + Line: int(930), Column: int(30), }, End: Location{ - Line: int(929), + Line: int(930), Column: int(38), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "object", @@ -139705,20 +141450,19 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(930), + Line: int(931), Column: int(9), }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -139815,16 +141559,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(930), + Line: int(931), Column: int(12), }, End: Location{ - Line: int(930), + Line: int(931), Column: int(25), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", "v", @@ -139835,16 +141579,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(930), + Line: int(931), Column: int(12), }, End: Location{ - Line: int(930), + Line: int(931), Column: int(22), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -139854,16 +141598,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(930), + Line: int(931), Column: int(12), }, End: Location{ - Line: int(930), + Line: int(931), Column: int(15), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -139900,16 +141644,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(930), + Line: int(931), Column: int(23), }, End: Location{ - Line: int(930), + Line: int(931), Column: int(24), }, file: p1, }, - context: p10182, + context: p12802, freeVariables: Identifiers{ "v", }, @@ -139927,16 +141671,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(930), + Line: int(931), Column: int(29), }, End: Location{ - Line: int(930), + Line: int(931), Column: int(30), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: float64(0), @@ -139953,16 +141697,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(931), + Line: int(932), Column: int(11), }, End: Location{ - Line: int(931), + Line: int(932), Column: int(15), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "{}", @@ -139974,20 +141718,19 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(933), + Line: int(934), Column: int(11), }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "path", "std", @@ -140002,16 +141745,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(933), + Line: int(934), Column: int(30), }, End: Location{ - Line: int(933), + Line: int(934), Column: int(44), }, file: p1, }, - context: p10190, + context: p12810, freeVariables: Identifiers{ "cindent", }, @@ -140021,16 +141764,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(933), + Line: int(934), Column: int(30), }, End: Location{ - Line: int(933), + Line: int(934), Column: int(37), }, file: p1, }, - context: p10190, + context: p12810, freeVariables: Identifiers{ "cindent", }, @@ -140043,16 +141786,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(933), + Line: int(934), Column: int(40), }, End: Location{ - Line: int(933), + Line: int(934), Column: int(44), }, file: p1, }, - context: p10190, + context: p12810, freeVariables: nil, }, Value: " ", @@ -140068,20 +141811,19 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(934), + Line: int(935), Column: int(11), }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "aux", "cindent", - "in_array", "in_object", "new_indent", "path", @@ -140109,7 +141851,6 @@ var StdAst = &DesugaredObject{ context: nil, freeVariables: Identifiers{ "aux", - "cindent", "new_indent", "path", "std", @@ -140198,7 +141939,6 @@ var StdAst = &DesugaredObject{ context: nil, freeVariables: Identifiers{ "aux", - "cindent", "new_indent", "path", "std", @@ -140229,7 +141969,6 @@ var StdAst = &DesugaredObject{ context: nil, freeVariables: Identifiers{ "aux", - "cindent", "k", "new_indent", "path", @@ -140243,19 +141982,18 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), + Line: int(936), Column: int(13), }, End: Location{ - Line: int(935), - Column: int(102), + Line: int(936), + Column: int(85), }, file: p1, }, - context: p10213, + context: p12833, freeVariables: Identifiers{ "aux", - "cindent", "k", "new_indent", "path", @@ -140268,177 +142006,132 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), + Line: int(936), Column: int(13), }, End: Location{ - Line: int(935), - Column: int(53), + Line: int(936), + Column: int(43), }, file: p1, }, - context: p10213, + context: p12833, freeVariables: Identifiers{ - "cindent", "k", "std", }, }, - Left: &Binary{ + Left: &Apply{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), + Line: int(936), Column: int(13), }, End: Location{ - Line: int(935), - Column: int(46), + Line: int(936), + Column: int(36), }, file: p1, }, - context: p10213, + context: p12833, freeVariables: Identifiers{ - "cindent", "k", "std", }, }, - Left: &Var{ + Target: &Index{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), + Line: int(936), Column: int(13), }, End: Location{ - Line: int(935), - Column: int(20), - }, - file: p1, - }, - context: p10213, - freeVariables: Identifiers{ - "cindent", - }, - }, - Id: "cindent", - }, - Op: BinaryOp(3), - Right: &Apply{ - NodeBase: NodeBase{ - loc: LocationRange{ - FileName: "", - Begin: Location{ - Line: int(935), - Column: int(23), - }, - End: Location{ - Line: int(935), - Column: int(46), + Line: int(936), + Column: int(33), }, file: p1, }, - context: p10213, + context: p12833, freeVariables: Identifiers{ - "k", "std", }, }, - Target: &Index{ + Target: &Var{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(23), + Line: int(936), + Column: int(13), }, End: Location{ - Line: int(935), - Column: int(43), + Line: int(936), + Column: int(16), }, file: p1, }, - context: p10213, + context: p12833, freeVariables: Identifiers{ "std", }, }, - Target: &Var{ - NodeBase: NodeBase{ - loc: LocationRange{ - FileName: "", - Begin: Location{ - Line: int(935), - Column: int(23), - }, - End: Location{ - Line: int(935), - Column: int(26), - }, - file: p1, + Id: "std", + }, + Index: &LiteralString{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(0), + Column: int(0), }, - context: p10213, - freeVariables: Identifiers{ - "std", + End: Location{ + Line: int(0), + Column: int(0), }, + file: nil, }, - Id: "std", + context: nil, + freeVariables: nil, }, - Index: &LiteralString{ + Value: "escapeStringJson", + Kind: LiteralStringKind(1), + BlockIndent: "", + }, + Id: nil, + }, + Arguments: Arguments{ + Positional: Nodes{ + &Var{ NodeBase: NodeBase{ loc: LocationRange{ - FileName: "", + FileName: "", Begin: Location{ - Line: int(0), - Column: int(0), + Line: int(936), + Column: int(34), }, End: Location{ - Line: int(0), - Column: int(0), + Line: int(936), + Column: int(35), }, - file: nil, + file: p1, }, - context: nil, - freeVariables: nil, - }, - Value: "escapeStringJson", - Kind: LiteralStringKind(1), - BlockIndent: "", - }, - Id: nil, - }, - Arguments: Arguments{ - Positional: Nodes{ - &Var{ - NodeBase: NodeBase{ - loc: LocationRange{ - FileName: "", - Begin: Location{ - Line: int(935), - Column: int(44), - }, - End: Location{ - Line: int(935), - Column: int(45), - }, - file: p1, - }, - context: p10230, - freeVariables: Identifiers{ - "k", - }, + context: p12846, + freeVariables: Identifiers{ + "k", }, - Id: "k", }, + Id: "k", }, - Named: nil, }, - TrailingComma: false, - TailStrict: false, + Named: nil, }, + TrailingComma: false, + TailStrict: false, }, Op: BinaryOp(3), Right: &LiteralString{ @@ -140446,16 +142139,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(49), + Line: int(936), + Column: int(39), }, End: Location{ - Line: int(935), - Column: int(53), + Line: int(936), + Column: int(43), }, file: p1, }, - context: p10213, + context: p12833, freeVariables: nil, }, Value: ": ", @@ -140469,16 +142162,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(56), + Line: int(936), + Column: int(46), }, End: Location{ - Line: int(935), - Column: int(102), + Line: int(936), + Column: int(85), }, file: p1, }, - context: p10213, + context: p12833, freeVariables: Identifiers{ "aux", "k", @@ -140492,16 +142185,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(56), + Line: int(936), + Column: int(46), }, End: Location{ - Line: int(935), - Column: int(59), + Line: int(936), + Column: int(49), }, file: p1, }, - context: p10213, + context: p12833, freeVariables: Identifiers{ "aux", }, @@ -140515,16 +142208,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(60), + Line: int(936), + Column: int(50), }, End: Location{ - Line: int(935), - Column: int(64), + Line: int(936), + Column: int(54), }, file: p1, }, - context: p10239, + context: p12855, freeVariables: Identifiers{ "k", "v", @@ -140535,16 +142228,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(60), + Line: int(936), + Column: int(50), }, End: Location{ - Line: int(935), - Column: int(61), + Line: int(936), + Column: int(51), }, file: p1, }, - context: p10239, + context: p12855, freeVariables: Identifiers{ "v", }, @@ -140556,16 +142249,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(62), + Line: int(936), + Column: int(52), }, End: Location{ - Line: int(935), - Column: int(63), + Line: int(936), + Column: int(53), }, file: p1, }, - context: p10239, + context: p12855, freeVariables: Identifiers{ "k", }, @@ -140579,35 +142272,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(66), - }, - End: Location{ - Line: int(935), - Column: int(71), - }, - file: p1, - }, - context: p10239, - freeVariables: nil, - }, - Value: false, - }, - &LiteralBoolean{ - NodeBase: NodeBase{ - loc: LocationRange{ - FileName: "", - Begin: Location{ - Line: int(935), - Column: int(73), + Line: int(936), + Column: int(56), }, End: Location{ - Line: int(935), - Column: int(77), + Line: int(936), + Column: int(60), }, file: p1, }, - context: p10239, + context: p12855, freeVariables: nil, }, Value: true, @@ -140617,16 +142291,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(79), + Line: int(936), + Column: int(62), }, End: Location{ - Line: int(935), - Column: int(89), + Line: int(936), + Column: int(72), }, file: p1, }, - context: p10239, + context: p12855, freeVariables: Identifiers{ "k", "path", @@ -140637,16 +142311,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(79), + Line: int(936), + Column: int(62), }, End: Location{ - Line: int(935), - Column: int(83), + Line: int(936), + Column: int(66), }, file: p1, }, - context: p10239, + context: p12855, freeVariables: Identifiers{ "path", }, @@ -140659,16 +142333,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(86), + Line: int(936), + Column: int(69), }, End: Location{ - Line: int(935), - Column: int(89), + Line: int(936), + Column: int(72), }, file: p1, }, - context: p10239, + context: p12855, freeVariables: Identifiers{ "k", }, @@ -140679,16 +142353,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(87), + Line: int(936), + Column: int(70), }, End: Location{ - Line: int(935), - Column: int(88), + Line: int(936), + Column: int(71), }, file: p1, }, - context: p10255, + context: p12870, freeVariables: Identifiers{ "k", }, @@ -140704,16 +142378,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(935), - Column: int(91), + Line: int(936), + Column: int(74), }, End: Location{ - Line: int(935), - Column: int(101), + Line: int(936), + Column: int(84), }, file: p1, }, - context: p10239, + context: p12855, freeVariables: Identifiers{ "new_indent", }, @@ -140736,16 +142410,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(936), + Line: int(937), Column: int(22), }, End: Location{ - Line: int(936), + Line: int(937), Column: int(41), }, file: p1, }, - context: p10260, + context: p12875, freeVariables: Identifiers{ "std", "v", @@ -140756,16 +142430,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(936), + Line: int(937), Column: int(22), }, End: Location{ - Line: int(936), + Line: int(937), Column: int(38), }, file: p1, }, - context: p10260, + context: p12875, freeVariables: Identifiers{ "std", }, @@ -140775,16 +142449,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(936), + Line: int(937), Column: int(22), }, End: Location{ - Line: int(936), + Line: int(937), Column: int(25), }, file: p1, }, - context: p10260, + context: p12875, freeVariables: Identifiers{ "std", }, @@ -140821,16 +142495,16 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(936), + Line: int(937), Column: int(39), }, End: Location{ - Line: int(936), + Line: int(937), Column: int(40), }, file: p1, }, - context: p10269, + context: p12884, freeVariables: Identifiers{ "v", }, @@ -140857,18 +142531,18 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(938), + Line: int(939), Column: int(11), }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "in_array", + "cindent", "in_object", "lines", "std", @@ -140879,121 +142553,120 @@ var StdAst = &DesugaredObject{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(938), + Line: int(939), Column: int(12), }, End: Location{ - Line: int(938), - Column: int(54), + Line: int(939), + Column: int(52), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "in_array", + "cindent", "in_object", }, }, - Cond: &Binary{ + Cond: &Var{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(938), + Line: int(939), Column: int(15), }, End: Location{ - Line: int(938), - Column: int(36), + Line: int(939), + Column: int(24), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "in_array", "in_object", }, }, - Left: &Var{ + Id: "in_object", + }, + BranchTrue: &Binary{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(939), + Column: int(30), + }, + End: Location{ + Line: int(939), + Column: int(44), + }, + file: p1, + }, + context: p12343, + freeVariables: Identifiers{ + "cindent", + }, + }, + Left: &LiteralString{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(938), - Column: int(15), + Line: int(939), + Column: int(30), }, End: Location{ - Line: int(938), - Column: int(23), + Line: int(939), + Column: int(34), }, file: p1, }, - context: p9736, - freeVariables: Identifiers{ - "in_array", - }, + context: p12343, + freeVariables: nil, }, - Id: "in_array", + Value: "\n", + Kind: LiteralStringKind(1), + BlockIndent: "", }, - Op: BinaryOp(18), + Op: BinaryOp(3), Right: &Var{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(938), - Column: int(27), + Line: int(939), + Column: int(37), }, End: Location{ - Line: int(938), - Column: int(36), + Line: int(939), + Column: int(44), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ - "in_object", - }, - }, - Id: "in_object", - }, - }, - BranchTrue: &LiteralString{ - NodeBase: NodeBase{ - loc: LocationRange{ - FileName: "", - Begin: Location{ - Line: int(938), - Column: int(42), - }, - End: Location{ - Line: int(938), - Column: int(46), + "cindent", }, - file: p1, }, - context: p9736, - freeVariables: nil, + Id: "cindent", }, - Value: "\n", - Kind: LiteralStringKind(1), - BlockIndent: "", }, BranchFalse: &LiteralString{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ - Line: int(938), - Column: int(52), + Line: int(939), + Column: int(50), }, End: Location{ - Line: int(938), - Column: int(54), + Line: int(939), + Column: int(52), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: nil, }, Value: "", @@ -141008,16 +142681,17 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(939), - Column: int(13), + Column: int(56), }, End: Location{ Line: int(939), - Column: int(34), + Column: int(87), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ + "cindent", "lines", "std", }, @@ -141028,15 +142702,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(939), - Column: int(13), + Column: int(56), }, End: Location{ Line: int(939), - Column: int(21), + Column: int(64), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -141047,15 +142721,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(939), - Column: int(13), + Column: int(56), }, End: Location{ Line: int(939), - Column: int(16), + Column: int(59), }, file: p1, }, - context: p9736, + context: p12343, freeVariables: Identifiers{ "std", }, @@ -141087,26 +142761,68 @@ var StdAst = &DesugaredObject{ }, Arguments: Arguments{ Positional: Nodes{ - &LiteralString{ + &Binary{ NodeBase: NodeBase{ loc: LocationRange{ FileName: "", Begin: Location{ Line: int(939), - Column: int(22), + Column: int(65), }, End: Location{ Line: int(939), - Column: int(26), + Column: int(79), }, file: p1, }, - context: p10292, - freeVariables: nil, + context: p12907, + freeVariables: Identifiers{ + "cindent", + }, + }, + Left: &LiteralString{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(939), + Column: int(65), + }, + End: Location{ + Line: int(939), + Column: int(69), + }, + file: p1, + }, + context: p12907, + freeVariables: nil, + }, + Value: "\n", + Kind: LiteralStringKind(1), + BlockIndent: "", + }, + Op: BinaryOp(3), + Right: &Var{ + NodeBase: NodeBase{ + loc: LocationRange{ + FileName: "", + Begin: Location{ + Line: int(939), + Column: int(72), + }, + End: Location{ + Line: int(939), + Column: int(79), + }, + file: p1, + }, + context: p12907, + freeVariables: Identifiers{ + "cindent", + }, + }, + Id: "cindent", }, - Value: "\n", - Kind: LiteralStringKind(1), - BlockIndent: "", }, &Var{ NodeBase: NodeBase{ @@ -141114,15 +142830,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(939), - Column: int(28), + Column: int(81), }, End: Location{ Line: int(939), - Column: int(33), + Column: int(86), }, file: p1, }, - context: p10292, + context: p12907, freeVariables: Identifiers{ "lines", }, @@ -141179,11 +142895,11 @@ var StdAst = &DesugaredObject{ }, End: Location{ Line: int(940), - Column: int(37), + Column: int(30), }, file: p1, }, - context: p9728, + context: p12335, freeVariables: Identifiers{ "aux", "value", @@ -141203,7 +142919,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9728, + context: p12335, freeVariables: Identifiers{ "aux", }, @@ -141226,7 +142942,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10302, + context: p12921, freeVariables: Identifiers{ "value", }, @@ -141247,26 +142963,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10302, - freeVariables: nil, - }, - Value: false, - }, - &LiteralBoolean{ - NodeBase: NodeBase{ - loc: LocationRange{ - FileName: "", - Begin: Location{ - Line: int(940), - Column: int(23), - }, - End: Location{ - Line: int(940), - Column: int(28), - }, - file: p1, - }, - context: p10302, + context: p12921, freeVariables: nil, }, Value: false, @@ -141277,15 +142974,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(940), - Column: int(30), + Column: int(23), }, End: Location{ Line: int(940), - Column: int(32), + Column: int(25), }, file: p1, }, - context: p10302, + context: p12921, freeVariables: nil, }, Elements: nil, @@ -141297,15 +142994,15 @@ var StdAst = &DesugaredObject{ FileName: "", Begin: Location{ Line: int(940), - Column: int(34), + Column: int(27), }, End: Location{ Line: int(940), - Column: int(36), + Column: int(29), }, file: p1, }, - context: p10302, + context: p12921, freeVariables: nil, }, Value: "", @@ -141380,7 +143077,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12930, freeVariables: nil, }, }, @@ -141402,7 +143099,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12932, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -141644,7 +143341,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12956, freeVariables: Identifiers{ "base64_table", "i", @@ -141668,7 +143365,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12960, freeVariables: Identifiers{ "base64_table", "i", @@ -141688,7 +143385,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12963, freeVariables: Identifiers{ "base64_table", }, @@ -141709,7 +143406,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12966, freeVariables: Identifiers{ "i", }, @@ -141732,7 +143429,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p12969, freeVariables: Identifiers{ "i", }, @@ -141761,7 +143458,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12972, freeVariables: Identifiers{ "std", }, @@ -141780,7 +143477,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12975, freeVariables: Identifiers{ "std", }, @@ -141799,7 +143496,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p12978, freeVariables: Identifiers{ "std", }, @@ -141845,7 +143542,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p12983, freeVariables: nil, }, Value: float64(0), @@ -141865,14 +143562,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p12985, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -141928,7 +143625,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -141954,7 +143651,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", "value", @@ -142080,7 +143777,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", "value", @@ -142100,7 +143797,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", }, @@ -142119,7 +143816,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", }, @@ -142165,7 +143862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10335, + context: p13012, freeVariables: Identifiers{ "value", }, @@ -142192,7 +143889,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: nil, }, Value: "array", @@ -142220,7 +143917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", "value", @@ -142240,7 +143937,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", "value", @@ -142260,7 +143957,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: nil, }, Value: "manifestYamlStream only takes arrays, got ", @@ -142282,7 +143979,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", "value", @@ -142302,7 +143999,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", }, @@ -142321,7 +144018,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", }, @@ -142367,7 +144064,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10352, + context: p13029, freeVariables: Identifiers{ "value", }, @@ -142396,7 +144093,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", "value", @@ -142416,7 +144113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", "value", @@ -142436,7 +144133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: nil, }, Value: "---\n", @@ -142458,7 +144155,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", "value", @@ -142478,7 +144175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", }, @@ -142497,7 +144194,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: Identifiers{ "std", }, @@ -142543,7 +144240,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10368, + context: p13045, freeVariables: nil, }, Value: "\n---\n", @@ -142696,7 +144393,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10384, + context: p13061, freeVariables: Identifiers{ "e", "std", @@ -142716,7 +144413,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10384, + context: p13061, freeVariables: Identifiers{ "std", }, @@ -142735,7 +144432,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10384, + context: p13061, freeVariables: Identifiers{ "std", }, @@ -142781,7 +144478,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10393, + context: p13070, freeVariables: Identifiers{ "e", }, @@ -142812,7 +144509,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10368, + context: p13045, freeVariables: Identifiers{ "value", }, @@ -142847,7 +144544,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10314, + context: p12991, freeVariables: nil, }, Value: "\n...\n", @@ -142917,7 +144614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13079, freeVariables: nil, }, }, @@ -142939,7 +144636,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13081, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -143181,7 +144878,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13105, freeVariables: Identifiers{ "base64_table", "i", @@ -143205,7 +144902,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13109, freeVariables: Identifiers{ "base64_table", "i", @@ -143225,7 +144922,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13112, freeVariables: Identifiers{ "base64_table", }, @@ -143246,7 +144943,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13115, freeVariables: Identifiers{ "i", }, @@ -143269,7 +144966,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p13118, freeVariables: Identifiers{ "i", }, @@ -143298,7 +144995,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13121, freeVariables: Identifiers{ "std", }, @@ -143317,7 +145014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13124, freeVariables: Identifiers{ "std", }, @@ -143336,7 +145033,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13127, freeVariables: Identifiers{ "std", }, @@ -143382,7 +145079,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p13132, freeVariables: nil, }, Value: float64(0), @@ -143402,14 +145099,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p13134, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -143465,7 +145162,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -143491,7 +145188,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -143596,7 +145293,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -143616,7 +145313,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -143635,7 +145332,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -143681,7 +145378,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10423, + context: p13159, freeVariables: Identifiers{ "o", }, @@ -143708,7 +145405,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "object", @@ -143735,7 +145432,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -143978,7 +145675,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10452, + context: p13188, freeVariables: nil, }, Value: "%s: %s", @@ -143999,7 +145696,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10452, + context: p13188, freeVariables: Identifiers{ "k", "o", @@ -144021,7 +145718,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10457, + context: p13193, freeVariables: Identifiers{ "k", "std", @@ -144041,7 +145738,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10457, + context: p13193, freeVariables: Identifiers{ "std", }, @@ -144060,7 +145757,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10457, + context: p13193, freeVariables: Identifiers{ "std", }, @@ -144106,7 +145803,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10466, + context: p13202, freeVariables: Identifiers{ "k", }, @@ -144133,7 +145830,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10457, + context: p13193, freeVariables: Identifiers{ "k", "o", @@ -144154,7 +145851,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10457, + context: p13193, freeVariables: Identifiers{ "std", }, @@ -144173,7 +145870,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10457, + context: p13193, freeVariables: Identifiers{ "std", }, @@ -144219,7 +145916,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10477, + context: p13213, freeVariables: Identifiers{ "k", "o", @@ -144239,7 +145936,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10477, + context: p13213, freeVariables: Identifiers{ "o", }, @@ -144260,7 +145957,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10477, + context: p13213, freeVariables: Identifiers{ "k", }, @@ -144302,7 +145999,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10484, + context: p13220, freeVariables: Identifiers{ "o", "std", @@ -144322,7 +146019,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10484, + context: p13220, freeVariables: Identifiers{ "std", }, @@ -144341,7 +146038,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10484, + context: p13220, freeVariables: Identifiers{ "std", }, @@ -144387,7 +146084,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10493, + context: p13229, freeVariables: Identifiers{ "o", }, @@ -144508,7 +146205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "{%s}", @@ -144529,7 +146226,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "fields", "std", @@ -144550,7 +146247,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10508, + context: p13244, freeVariables: Identifiers{ "fields", "std", @@ -144570,7 +146267,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10508, + context: p13244, freeVariables: Identifiers{ "std", }, @@ -144589,7 +146286,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10508, + context: p13244, freeVariables: Identifiers{ "std", }, @@ -144635,7 +146332,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10517, + context: p13253, freeVariables: nil, }, Value: ", ", @@ -144656,7 +146353,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10517, + context: p13253, freeVariables: Identifiers{ "fields", }, @@ -144693,7 +146390,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -144798,7 +146495,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -144818,7 +146515,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -144837,7 +146534,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -144883,7 +146580,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10539, + context: p13275, freeVariables: Identifiers{ "o", }, @@ -144910,7 +146607,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "array", @@ -145022,7 +146719,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "[%s]", @@ -145043,7 +146740,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -145064,7 +146761,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10555, + context: p13291, freeVariables: Identifiers{ "o", "std", @@ -145084,7 +146781,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10555, + context: p13291, freeVariables: Identifiers{ "std", }, @@ -145103,7 +146800,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10555, + context: p13291, freeVariables: Identifiers{ "std", }, @@ -145149,7 +146846,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10564, + context: p13300, freeVariables: nil, }, Value: ", ", @@ -145302,7 +146999,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10580, + context: p13316, freeVariables: Identifiers{ "o2", "std", @@ -145322,7 +147019,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10580, + context: p13316, freeVariables: Identifiers{ "std", }, @@ -145341,7 +147038,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10580, + context: p13316, freeVariables: Identifiers{ "std", }, @@ -145387,7 +147084,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10589, + context: p13325, freeVariables: Identifiers{ "o2", }, @@ -145418,7 +147115,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10564, + context: p13300, freeVariables: Identifiers{ "o", }, @@ -145460,7 +147157,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -145565,7 +147262,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -145585,7 +147282,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -145604,7 +147301,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -145650,7 +147347,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10612, + context: p13348, freeVariables: Identifiers{ "o", }, @@ -145677,7 +147374,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "string", @@ -145789,7 +147486,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "%s", @@ -145810,7 +147507,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -145831,7 +147528,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10628, + context: p13364, freeVariables: Identifiers{ "o", "std", @@ -145851,7 +147548,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10628, + context: p13364, freeVariables: Identifiers{ "std", }, @@ -145870,7 +147567,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10628, + context: p13364, freeVariables: Identifiers{ "std", }, @@ -145916,7 +147613,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10637, + context: p13373, freeVariables: Identifiers{ "o", }, @@ -145952,7 +147649,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -146057,7 +147754,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -146077,7 +147774,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -146096,7 +147793,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -146142,7 +147839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10658, + context: p13394, freeVariables: Identifiers{ "o", }, @@ -146169,7 +147866,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "function", @@ -146196,7 +147893,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Expr: &LiteralString{ @@ -146213,7 +147910,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "cannot manifest function", @@ -146235,7 +147932,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -146340,7 +148037,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -146360,7 +148057,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -146379,7 +148076,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -146425,7 +148122,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10682, + context: p13418, freeVariables: Identifiers{ "o", }, @@ -146452,7 +148149,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "number", @@ -146479,7 +148176,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -146499,7 +148196,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -146518,7 +148215,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "std", }, @@ -146564,7 +148261,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10694, + context: p13430, freeVariables: Identifiers{ "o", }, @@ -146591,7 +148288,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -146696,7 +148393,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", }, @@ -146717,7 +148414,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: true, @@ -146742,7 +148439,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "True", @@ -146763,7 +148460,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -146868,7 +148565,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", }, @@ -146889,7 +148586,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: false, @@ -146914,7 +148611,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "False", @@ -146935,7 +148632,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", "std", @@ -147040,7 +148737,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: Identifiers{ "o", }, @@ -147061,7 +148758,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, }, @@ -147085,7 +148782,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10404, + context: p13140, freeVariables: nil, }, Value: "None", @@ -147179,7 +148876,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13479, freeVariables: nil, }, }, @@ -147201,7 +148898,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13481, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -147443,7 +149140,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13505, freeVariables: Identifiers{ "base64_table", "i", @@ -147467,7 +149164,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13509, freeVariables: Identifiers{ "base64_table", "i", @@ -147487,7 +149184,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13512, freeVariables: Identifiers{ "base64_table", }, @@ -147508,7 +149205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13515, freeVariables: Identifiers{ "i", }, @@ -147531,7 +149228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p13518, freeVariables: Identifiers{ "i", }, @@ -147560,7 +149257,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13521, freeVariables: Identifiers{ "std", }, @@ -147579,7 +149276,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13524, freeVariables: Identifiers{ "std", }, @@ -147598,7 +149295,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13527, freeVariables: Identifiers{ "std", }, @@ -147644,7 +149341,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p13532, freeVariables: nil, }, Value: float64(0), @@ -147664,14 +149361,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p13534, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -147727,7 +149424,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -147753,7 +149450,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10745, + context: p13540, freeVariables: Identifiers{ "conf", "std", @@ -147996,7 +149693,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10771, + context: p13566, freeVariables: nil, }, Value: "%s = %s", @@ -148017,7 +149714,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10771, + context: p13566, freeVariables: Identifiers{ "conf", "k", @@ -148039,7 +149736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10776, + context: p13571, freeVariables: Identifiers{ "k", }, @@ -148060,7 +149757,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10776, + context: p13571, freeVariables: Identifiers{ "conf", "k", @@ -148081,7 +149778,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10776, + context: p13571, freeVariables: Identifiers{ "std", }, @@ -148100,7 +149797,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10776, + context: p13571, freeVariables: Identifiers{ "std", }, @@ -148146,7 +149843,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10787, + context: p13582, freeVariables: Identifiers{ "conf", "k", @@ -148166,7 +149863,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10787, + context: p13582, freeVariables: Identifiers{ "conf", }, @@ -148187,7 +149884,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10787, + context: p13582, freeVariables: Identifiers{ "k", }, @@ -148229,7 +149926,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10794, + context: p13589, freeVariables: Identifiers{ "conf", "std", @@ -148249,7 +149946,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10794, + context: p13589, freeVariables: Identifiers{ "std", }, @@ -148268,7 +149965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10794, + context: p13589, freeVariables: Identifiers{ "std", }, @@ -148314,7 +150011,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10803, + context: p13598, freeVariables: Identifiers{ "conf", }, @@ -148350,7 +150047,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10745, + context: p13540, freeVariables: Identifiers{ "std", "vars", @@ -148370,7 +150067,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10745, + context: p13540, freeVariables: Identifiers{ "std", }, @@ -148389,7 +150086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10745, + context: p13540, freeVariables: Identifiers{ "std", }, @@ -148435,7 +150132,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10814, + context: p13609, freeVariables: nil, }, Value: "\n", @@ -148456,7 +150153,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10814, + context: p13609, freeVariables: Identifiers{ "vars", }, @@ -148475,7 +150172,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10814, + context: p13609, freeVariables: Identifiers{ "vars", }, @@ -148497,7 +150194,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10814, + context: p13609, freeVariables: nil, }, Elements: Nodes{ @@ -148515,7 +150212,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10822, + context: p13617, freeVariables: nil, }, Value: "", @@ -148594,7 +150291,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13622, freeVariables: nil, }, }, @@ -148616,7 +150313,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13624, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -148858,7 +150555,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13648, freeVariables: Identifiers{ "base64_table", "i", @@ -148882,7 +150579,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13652, freeVariables: Identifiers{ "base64_table", "i", @@ -148902,7 +150599,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13655, freeVariables: Identifiers{ "base64_table", }, @@ -148923,7 +150620,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13658, freeVariables: Identifiers{ "i", }, @@ -148946,7 +150643,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p13661, freeVariables: Identifiers{ "i", }, @@ -148975,7 +150672,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13664, freeVariables: Identifiers{ "std", }, @@ -148994,7 +150691,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13667, freeVariables: Identifiers{ "std", }, @@ -149013,7 +150710,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13670, freeVariables: Identifiers{ "std", }, @@ -149059,7 +150756,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p13675, freeVariables: nil, }, Value: float64(0), @@ -149079,14 +150776,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p13677, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -149142,7 +150839,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -149168,7 +150865,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", "value", @@ -149188,7 +150885,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", "value", @@ -149209,7 +150906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", "value", @@ -149229,7 +150926,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", }, @@ -149248,7 +150945,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", }, @@ -149294,7 +150991,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10842, + context: p13696, freeVariables: Identifiers{ "value", }, @@ -149322,7 +151019,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", "value", @@ -149427,7 +151124,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: nil, }, Value: "Expected a JSONML value (an array), got %s", @@ -149448,7 +151145,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", "value", @@ -149468,7 +151165,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", }, @@ -149487,7 +151184,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", }, @@ -149533,7 +151230,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10864, + context: p13718, freeVariables: Identifiers{ "value", }, @@ -149567,7 +151264,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "std", "value", @@ -149590,7 +151287,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10870, + context: p13724, freeVariables: Identifiers{ "aux", "std", @@ -149617,7 +151314,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "aux", "std", @@ -149638,7 +151335,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "std", "v", @@ -149658,7 +151355,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "std", }, @@ -149677,7 +151374,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "std", }, @@ -149723,7 +151420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10885, + context: p13739, freeVariables: Identifiers{ "v", }, @@ -149750,7 +151447,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "v", }, @@ -149771,7 +151468,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "aux", "std", @@ -149795,7 +151492,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10893, + context: p13747, freeVariables: Identifiers{ "v", }, @@ -149814,7 +151511,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10893, + context: p13747, freeVariables: Identifiers{ "v", }, @@ -149835,7 +151532,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10893, + context: p13747, freeVariables: nil, }, Value: float64(0), @@ -149860,7 +151557,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "aux", "std", @@ -149885,7 +151582,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: Identifiers{ "std", "v", @@ -149905,7 +151602,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: Identifiers{ "std", "v", @@ -149925,7 +151622,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: Identifiers{ "std", "v", @@ -149945,7 +151642,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: Identifiers{ "std", }, @@ -149964,7 +151661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: Identifiers{ "std", }, @@ -150010,7 +151707,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10915, + context: p13769, freeVariables: Identifiers{ "v", }, @@ -150038,7 +151735,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: nil, }, Value: float64(1), @@ -150145,7 +151842,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: Identifiers{ "std", "v", @@ -150165,7 +151862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: Identifiers{ "std", }, @@ -150184,7 +151881,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: Identifiers{ "std", }, @@ -150230,7 +151927,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10935, + context: p13789, freeVariables: Identifiers{ "v", }, @@ -150249,7 +151946,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10935, + context: p13789, freeVariables: Identifiers{ "v", }, @@ -150270,7 +151967,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10935, + context: p13789, freeVariables: nil, }, Value: float64(1), @@ -150298,7 +151995,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10902, + context: p13756, freeVariables: nil, }, Value: "object", @@ -150329,7 +152026,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "aux", "has_attrs", @@ -150355,7 +152052,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10945, + context: p13799, freeVariables: Identifiers{ "has_attrs", "v", @@ -150375,7 +152072,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10945, + context: p13799, freeVariables: Identifiers{ "has_attrs", }, @@ -150396,7 +152093,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10945, + context: p13799, freeVariables: Identifiers{ "v", }, @@ -150415,7 +152112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10945, + context: p13799, freeVariables: Identifiers{ "v", }, @@ -150436,7 +152133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10945, + context: p13799, freeVariables: nil, }, Value: float64(1), @@ -150458,7 +152155,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10945, + context: p13799, freeVariables: nil, }, Asserts: nil, @@ -150482,7 +152179,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "attrs", "aux", @@ -150509,7 +152206,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10959, + context: p13813, freeVariables: Identifiers{ "has_attrs", "std", @@ -150530,7 +152227,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10959, + context: p13813, freeVariables: Identifiers{ "has_attrs", }, @@ -150636,7 +152333,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10959, + context: p13813, freeVariables: Identifiers{ "v", }, @@ -150657,7 +152354,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10959, + context: p13813, freeVariables: nil, }, Value: float64(2), @@ -150804,7 +152501,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10959, + context: p13813, freeVariables: Identifiers{ "v", }, @@ -150825,7 +152522,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10959, + context: p13813, freeVariables: nil, }, Value: float64(1), @@ -150891,7 +152588,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "attrs", "aux", @@ -150917,7 +152614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10993, + context: p13847, freeVariables: Identifiers{ "attrs", "std", @@ -150937,7 +152634,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10993, + context: p13847, freeVariables: Identifiers{ "std", }, @@ -150956,7 +152653,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10993, + context: p13847, freeVariables: Identifiers{ "std", }, @@ -151002,7 +152699,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11002, + context: p13856, freeVariables: nil, }, Value: "", @@ -151243,7 +152940,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11026, + context: p13880, freeVariables: nil, }, Value: " %s=\"%s\"", @@ -151264,7 +152961,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11026, + context: p13880, freeVariables: Identifiers{ "attrs", "k", @@ -151285,7 +152982,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11031, + context: p13885, freeVariables: Identifiers{ "k", }, @@ -151306,7 +153003,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11031, + context: p13885, freeVariables: Identifiers{ "attrs", "k", @@ -151326,7 +153023,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11031, + context: p13885, freeVariables: Identifiers{ "attrs", }, @@ -151347,7 +153044,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11031, + context: p13885, freeVariables: Identifiers{ "k", }, @@ -151383,7 +153080,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11002, + context: p13856, freeVariables: Identifiers{ "attrs", "std", @@ -151403,7 +153100,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11002, + context: p13856, freeVariables: Identifiers{ "std", }, @@ -151422,7 +153119,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11002, + context: p13856, freeVariables: Identifiers{ "std", }, @@ -151468,7 +153165,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11048, + context: p13902, freeVariables: Identifiers{ "attrs", }, @@ -151510,7 +153207,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "attrs_str", "aux", @@ -151533,7 +153230,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "std", }, @@ -151552,7 +153249,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10874, + context: p13728, freeVariables: Identifiers{ "std", }, @@ -151598,7 +153295,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11059, + context: p13913, freeVariables: Identifiers{ "attrs_str", "aux", @@ -151622,7 +153319,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11063, + context: p13917, freeVariables: nil, }, Value: "<", @@ -151643,7 +153340,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11063, + context: p13917, freeVariables: Identifiers{ "tag", }, @@ -151664,7 +153361,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11063, + context: p13917, freeVariables: Identifiers{ "attrs_str", }, @@ -151685,7 +153382,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11063, + context: p13917, freeVariables: nil, }, Value: ">", @@ -151839,7 +153536,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11084, + context: p13938, freeVariables: Identifiers{ "aux", "x", @@ -151859,7 +153556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11084, + context: p13938, freeVariables: Identifiers{ "aux", }, @@ -151882,7 +153579,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11090, + context: p13944, freeVariables: Identifiers{ "x", }, @@ -151913,7 +153610,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11063, + context: p13917, freeVariables: Identifiers{ "children", }, @@ -151940,7 +153637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11063, + context: p13917, freeVariables: nil, }, Value: "", @@ -152022,7 +153719,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "aux", "value", @@ -152042,7 +153739,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p10829, + context: p13683, freeVariables: Identifiers{ "aux", }, @@ -152065,7 +153762,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11104, + context: p13958, freeVariables: Identifiers{ "value", }, @@ -152141,7 +153838,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13964, freeVariables: nil, }, }, @@ -152163,7 +153860,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13966, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -152405,7 +154102,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13990, freeVariables: Identifiers{ "base64_table", "i", @@ -152429,7 +154126,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13994, freeVariables: Identifiers{ "base64_table", "i", @@ -152449,7 +154146,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p13997, freeVariables: Identifiers{ "base64_table", }, @@ -152470,7 +154167,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14000, freeVariables: Identifiers{ "i", }, @@ -152493,7 +154190,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p14003, freeVariables: Identifiers{ "i", }, @@ -152522,7 +154219,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14006, freeVariables: Identifiers{ "std", }, @@ -152541,7 +154238,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14009, freeVariables: Identifiers{ "std", }, @@ -152560,7 +154257,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14012, freeVariables: Identifiers{ "std", }, @@ -152606,7 +154303,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p14017, freeVariables: nil, }, Value: float64(0), @@ -152626,14 +154323,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p14019, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -152689,7 +154386,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "base64_table", "std", @@ -152716,7 +154413,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: Identifiers{ "base64_table", "input", @@ -152740,7 +154437,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11116, + context: p14029, freeVariables: Identifiers{ "input", "std", @@ -152845,7 +154542,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11116, + context: p14029, freeVariables: Identifiers{ "input", "std", @@ -152865,7 +154562,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11116, + context: p14029, freeVariables: Identifiers{ "std", }, @@ -152884,7 +154581,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11116, + context: p14029, freeVariables: Identifiers{ "std", }, @@ -152930,7 +154627,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11135, + context: p14048, freeVariables: Identifiers{ "input", }, @@ -152957,7 +154654,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11116, + context: p14029, freeVariables: nil, }, Value: "string", @@ -152984,7 +154681,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11116, + context: p14029, freeVariables: Identifiers{ "input", "std", @@ -153004,7 +154701,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11116, + context: p14029, freeVariables: Identifiers{ "std", }, @@ -153023,7 +154720,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11116, + context: p14029, freeVariables: Identifiers{ "std", }, @@ -153069,7 +154766,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11147, + context: p14060, freeVariables: Identifiers{ "std", }, @@ -153095,7 +154792,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11151, + context: p14064, freeVariables: Identifiers{ "c", "std", @@ -153115,7 +154812,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11151, + context: p14064, freeVariables: Identifiers{ "std", }, @@ -153134,7 +154831,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11151, + context: p14064, freeVariables: Identifiers{ "std", }, @@ -153180,7 +154877,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11160, + context: p14073, freeVariables: Identifiers{ "c", }, @@ -153208,7 +154905,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11147, + context: p14060, freeVariables: Identifiers{ "input", }, @@ -153235,7 +154932,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11116, + context: p14029, freeVariables: Identifiers{ "input", }, @@ -153260,7 +154957,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: Identifiers{ "base64_table", "bytes", @@ -153284,7 +154981,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11170, + context: p14083, freeVariables: Identifiers{ "aux", "base64_table", @@ -153314,7 +155011,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "aux", @@ -153338,7 +155035,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "i", @@ -153359,7 +155056,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "i", }, @@ -153381,7 +155078,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "std", @@ -153401,7 +155098,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "std", }, @@ -153420,7 +155117,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "std", }, @@ -153466,7 +155163,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11189, + context: p14102, freeVariables: Identifiers{ "arr", }, @@ -153494,7 +155191,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "r", }, @@ -153515,7 +155212,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "aux", @@ -153539,7 +155236,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "i", @@ -153560,7 +155257,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "i", }, @@ -153579,7 +155276,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "i", }, @@ -153601,7 +155298,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: nil, }, Value: float64(1), @@ -153623,7 +155320,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "std", @@ -153643,7 +155340,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "std", }, @@ -153662,7 +155359,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "std", }, @@ -153708,7 +155405,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11211, + context: p14124, freeVariables: Identifiers{ "arr", }, @@ -153736,7 +155433,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "aux", @@ -153762,7 +155459,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "base64_table", @@ -153783,7 +155480,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "base64_table", @@ -153804,7 +155501,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "base64_table", @@ -153825,7 +155522,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "base64_table", }, @@ -153846,7 +155543,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "i", @@ -153866,7 +155563,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "i", @@ -153886,7 +155583,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "i", @@ -153906,7 +155603,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", }, @@ -153927,7 +155624,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "i", }, @@ -153951,7 +155648,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: nil, }, Value: float64(252), @@ -153973,7 +155670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: nil, }, Value: float64(2), @@ -153997,7 +155694,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "base64_table", @@ -154018,7 +155715,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "base64_table", }, @@ -154039,7 +155736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "i", @@ -154059,7 +155756,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "i", @@ -154079,7 +155776,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", "i", @@ -154099,7 +155796,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "arr", }, @@ -154120,7 +155817,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: Identifiers{ "i", }, @@ -154144,7 +155841,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: nil, }, Value: float64(3), @@ -154166,7 +155863,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: nil, }, Value: float64(4), @@ -154191,7 +155888,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11217, + context: p14130, freeVariables: nil, }, Value: "==", @@ -154216,7 +155913,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "aux", @@ -154239,7 +155936,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "aux", }, @@ -154262,7 +155959,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11260, + context: p14173, freeVariables: Identifiers{ "arr", }, @@ -154283,7 +155980,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11260, + context: p14173, freeVariables: Identifiers{ "i", }, @@ -154302,7 +155999,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11260, + context: p14173, freeVariables: Identifiers{ "i", }, @@ -154324,7 +156021,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11260, + context: p14173, freeVariables: nil, }, Value: float64(3), @@ -154345,7 +156042,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11260, + context: p14173, freeVariables: Identifiers{ "r", "str", @@ -154365,7 +156062,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11260, + context: p14173, freeVariables: Identifiers{ "r", }, @@ -154387,7 +156084,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11260, + context: p14173, freeVariables: Identifiers{ "str", }, @@ -154416,7 +156113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "aux", @@ -154440,7 +156137,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "i", @@ -154461,7 +156158,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "i", }, @@ -154480,7 +156177,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "i", }, @@ -154502,7 +156199,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: nil, }, Value: float64(2), @@ -154524,7 +156221,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "std", @@ -154544,7 +156241,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "std", }, @@ -154563,7 +156260,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "std", }, @@ -154609,7 +156306,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11291, + context: p14204, freeVariables: Identifiers{ "arr", }, @@ -154637,7 +156334,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "aux", @@ -154663,7 +156360,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "base64_table", @@ -154684,7 +156381,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "base64_table", @@ -154705,7 +156402,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "base64_table", @@ -154726,7 +156423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "base64_table", @@ -154747,7 +156444,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "base64_table", }, @@ -154768,7 +156465,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -154788,7 +156485,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -154808,7 +156505,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -154828,7 +156525,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", }, @@ -154849,7 +156546,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "i", }, @@ -154873,7 +156570,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(252), @@ -154895,7 +156592,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(2), @@ -154919,7 +156616,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "base64_table", @@ -154940,7 +156637,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "base64_table", }, @@ -154961,7 +156658,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -154981,7 +156678,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -155001,7 +156698,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -155021,7 +156718,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -155041,7 +156738,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", }, @@ -155062,7 +156759,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "i", }, @@ -155086,7 +156783,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(3), @@ -155108,7 +156805,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(4), @@ -155130,7 +156827,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -155150,7 +156847,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -155170,7 +156867,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -155190,7 +156887,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", }, @@ -155211,7 +156908,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "i", }, @@ -155230,7 +156927,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "i", }, @@ -155252,7 +156949,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(1), @@ -155276,7 +156973,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(240), @@ -155298,7 +156995,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(4), @@ -155324,7 +157021,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "base64_table", @@ -155345,7 +157042,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "base64_table", }, @@ -155366,7 +157063,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -155386,7 +157083,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -155406,7 +157103,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", "i", @@ -155426,7 +157123,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "arr", }, @@ -155447,7 +157144,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "i", }, @@ -155466,7 +157163,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: Identifiers{ "i", }, @@ -155488,7 +157185,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(1), @@ -155512,7 +157209,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(15), @@ -155534,7 +157231,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: float64(2), @@ -155559,7 +157256,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11297, + context: p14210, freeVariables: nil, }, Value: "=", @@ -155584,7 +157281,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "aux", @@ -155607,7 +157304,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "aux", }, @@ -155630,7 +157327,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11378, + context: p14291, freeVariables: Identifiers{ "arr", }, @@ -155651,7 +157348,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11378, + context: p14291, freeVariables: Identifiers{ "i", }, @@ -155670,7 +157367,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11378, + context: p14291, freeVariables: Identifiers{ "i", }, @@ -155692,7 +157389,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11378, + context: p14291, freeVariables: nil, }, Value: float64(3), @@ -155713,7 +157410,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11378, + context: p14291, freeVariables: Identifiers{ "r", "str", @@ -155733,7 +157430,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11378, + context: p14291, freeVariables: Identifiers{ "r", }, @@ -155755,7 +157452,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11378, + context: p14291, freeVariables: Identifiers{ "str", }, @@ -155784,7 +157481,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "aux", @@ -155810,7 +157507,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "base64_table", @@ -155831,7 +157528,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "base64_table", @@ -155852,7 +157549,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "base64_table", @@ -155873,7 +157570,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "base64_table", @@ -155894,7 +157591,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "base64_table", }, @@ -155915,7 +157612,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -155935,7 +157632,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -155955,7 +157652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -155975,7 +157672,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", }, @@ -155996,7 +157693,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -156020,7 +157717,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(252), @@ -156042,7 +157739,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(2), @@ -156066,7 +157763,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "base64_table", @@ -156087,7 +157784,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "base64_table", }, @@ -156108,7 +157805,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156128,7 +157825,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156148,7 +157845,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156168,7 +157865,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156188,7 +157885,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", }, @@ -156209,7 +157906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -156233,7 +157930,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(3), @@ -156255,7 +157952,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(4), @@ -156277,7 +157974,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156297,7 +157994,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156317,7 +158014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156337,7 +158034,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", }, @@ -156358,7 +158055,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -156377,7 +158074,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -156399,7 +158096,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(1), @@ -156423,7 +158120,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(240), @@ -156445,7 +158142,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(4), @@ -156471,7 +158168,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "base64_table", @@ -156492,7 +158189,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "base64_table", }, @@ -156513,7 +158210,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156533,7 +158230,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156553,7 +158250,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156573,7 +158270,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156593,7 +158290,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", }, @@ -156614,7 +158311,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -156633,7 +158330,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -156655,7 +158352,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(1), @@ -156679,7 +158376,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(15), @@ -156701,7 +158398,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(2), @@ -156723,7 +158420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156743,7 +158440,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156763,7 +158460,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156783,7 +158480,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", }, @@ -156804,7 +158501,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -156823,7 +158520,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -156845,7 +158542,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(2), @@ -156869,7 +158566,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(192), @@ -156891,7 +158588,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(6), @@ -156917,7 +158614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "base64_table", @@ -156938,7 +158635,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "base64_table", }, @@ -156959,7 +158656,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156979,7 +158676,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", "i", @@ -156999,7 +158696,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "arr", }, @@ -157020,7 +158717,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -157039,7 +158736,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: Identifiers{ "i", }, @@ -157061,7 +158758,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(2), @@ -157085,7 +158782,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11395, + context: p14308, freeVariables: nil, }, Value: float64(63), @@ -157112,7 +158809,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "arr", "aux", @@ -157135,7 +158832,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11174, + context: p14087, freeVariables: Identifiers{ "aux", }, @@ -157158,7 +158855,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11508, + context: p14421, freeVariables: Identifiers{ "arr", }, @@ -157179,7 +158876,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11508, + context: p14421, freeVariables: Identifiers{ "i", }, @@ -157198,7 +158895,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11508, + context: p14421, freeVariables: Identifiers{ "i", }, @@ -157220,7 +158917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11508, + context: p14421, freeVariables: nil, }, Value: float64(3), @@ -157241,7 +158938,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11508, + context: p14421, freeVariables: Identifiers{ "r", "str", @@ -157261,7 +158958,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11508, + context: p14421, freeVariables: Identifiers{ "r", }, @@ -157283,7 +158980,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11508, + context: p14421, freeVariables: Identifiers{ "str", }, @@ -157319,7 +159016,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: Identifiers{ "aux", "bytes", @@ -157343,7 +159040,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11525, + context: p14438, freeVariables: Identifiers{ "bytes", "std", @@ -157363,7 +159060,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11525, + context: p14438, freeVariables: Identifiers{ "std", }, @@ -157382,7 +159079,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11525, + context: p14438, freeVariables: Identifiers{ "std", }, @@ -157428,7 +159125,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11534, + context: p14447, freeVariables: nil, }, Parameters: Parameters{ @@ -157453,7 +159150,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11537, + context: p14450, freeVariables: Identifiers{ "a", "r", @@ -157473,7 +159170,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11537, + context: p14450, freeVariables: Identifiers{ "r", }, @@ -157495,7 +159192,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11537, + context: p14450, freeVariables: Identifiers{ "a", }, @@ -157514,7 +159211,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11537, + context: p14450, freeVariables: Identifiers{ "a", }, @@ -157536,7 +159233,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11537, + context: p14450, freeVariables: nil, }, Value: float64(256), @@ -157559,7 +159256,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11534, + context: p14447, freeVariables: Identifiers{ "bytes", }, @@ -157580,7 +159277,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11534, + context: p14447, freeVariables: nil, }, Value: true, @@ -157608,7 +159305,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: Identifiers{ "aux", "bytes", @@ -157629,7 +159326,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: Identifiers{ "sanity", }, @@ -157649,7 +159346,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: Identifiers{ "sanity", }, @@ -157671,7 +159368,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: nil, }, Expr: &LiteralString{ @@ -157688,7 +159385,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: nil, }, Value: "Can only base64 encode strings / arrays of single bytes.", @@ -157710,7 +159407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: Identifiers{ "aux", "bytes", @@ -157730,7 +159427,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11112, + context: p14025, freeVariables: Identifiers{ "aux", }, @@ -157753,7 +159450,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11563, + context: p14476, freeVariables: Identifiers{ "bytes", }, @@ -157774,7 +159471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11563, + context: p14476, freeVariables: nil, }, Value: float64(0), @@ -157794,7 +159491,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11563, + context: p14476, freeVariables: nil, }, Value: "", @@ -157872,7 +159569,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14484, freeVariables: nil, }, }, @@ -157894,7 +159591,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14486, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -158136,7 +159833,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14510, freeVariables: Identifiers{ "base64_table", "i", @@ -158160,7 +159857,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14514, freeVariables: Identifiers{ "base64_table", "i", @@ -158180,7 +159877,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14517, freeVariables: Identifiers{ "base64_table", }, @@ -158201,7 +159898,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14520, freeVariables: Identifiers{ "i", }, @@ -158224,7 +159921,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p14523, freeVariables: Identifiers{ "i", }, @@ -158253,7 +159950,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14526, freeVariables: Identifiers{ "std", }, @@ -158272,7 +159969,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14529, freeVariables: Identifiers{ "std", }, @@ -158291,7 +159988,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14532, freeVariables: Identifiers{ "std", }, @@ -158337,7 +160034,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p14537, freeVariables: nil, }, Value: float64(0), @@ -158357,14 +160054,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p14539, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -158420,7 +160117,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "base64_inv", "std", @@ -158447,7 +160144,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: Identifiers{ "base64_inv", "std", @@ -158659,7 +160356,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: Identifiers{ "std", "str", @@ -158679,7 +160376,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: Identifiers{ "std", }, @@ -158698,7 +160395,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: Identifiers{ "std", }, @@ -158744,7 +160441,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11602, + context: p14574, freeVariables: Identifiers{ "str", }, @@ -158771,7 +160468,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: nil, }, Value: float64(4), @@ -158797,7 +160494,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: nil, }, Value: float64(0), @@ -158824,7 +160521,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: Identifiers{ "std", "str", @@ -158929,7 +160626,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: nil, }, Value: "Not a base64 encoded string \"%s\"", @@ -158950,7 +160647,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: Identifiers{ "str", }, @@ -158978,7 +160675,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: Identifiers{ "base64_inv", "std", @@ -159002,7 +160699,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11623, + context: p14595, freeVariables: Identifiers{ "aux", "base64_inv", @@ -159032,7 +160729,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "aux", "base64_inv", @@ -159056,7 +160753,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "i", "std", @@ -159077,7 +160774,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "i", }, @@ -159099,7 +160796,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "std", "str", @@ -159119,7 +160816,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "std", }, @@ -159138,7 +160835,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "std", }, @@ -159184,7 +160881,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11642, + context: p14614, freeVariables: Identifiers{ "str", }, @@ -159212,7 +160909,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "r", }, @@ -159233,7 +160930,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "aux", "base64_inv", @@ -159260,7 +160957,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11650, + context: p14622, freeVariables: Identifiers{ "base64_inv", "i", @@ -159282,7 +160979,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "base64_inv", "i", @@ -159303,7 +161000,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "base64_inv", "i", @@ -159324,7 +161021,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "base64_inv", "i", @@ -159345,7 +161042,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "base64_inv", }, @@ -159366,7 +161063,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "i", "str", @@ -159386,7 +161083,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "str", }, @@ -159407,7 +161104,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "i", }, @@ -159433,7 +161130,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: nil, }, Value: float64(2), @@ -159455,7 +161152,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "base64_inv", "i", @@ -159476,7 +161173,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "base64_inv", "i", @@ -159497,7 +161194,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "base64_inv", }, @@ -159518,7 +161215,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "i", "str", @@ -159538,7 +161235,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "str", }, @@ -159559,7 +161256,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "i", }, @@ -159578,7 +161275,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: Identifiers{ "i", }, @@ -159600,7 +161297,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: nil, }, Value: float64(1), @@ -159626,7 +161323,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11654, + context: p14626, freeVariables: nil, }, Value: float64(4), @@ -159654,7 +161351,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "aux", "base64_inv", @@ -159682,7 +161379,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11689, + context: p14661, freeVariables: Identifiers{ "base64_inv", "i", @@ -159790,7 +161487,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11689, + context: p14661, freeVariables: Identifiers{ "i", "str", @@ -159810,7 +161507,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11689, + context: p14661, freeVariables: Identifiers{ "str", }, @@ -159831,7 +161528,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11689, + context: p14661, freeVariables: Identifiers{ "i", }, @@ -159850,7 +161547,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11689, + context: p14661, freeVariables: Identifiers{ "i", }, @@ -159872,7 +161569,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11689, + context: p14661, freeVariables: nil, }, Value: float64(2), @@ -159895,7 +161592,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11689, + context: p14661, freeVariables: nil, }, Value: "=", @@ -159922,7 +161619,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11689, + context: p14661, freeVariables: nil, }, Elements: nil, @@ -159942,7 +161639,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11689, + context: p14661, freeVariables: Identifiers{ "base64_inv", "i", @@ -159964,7 +161661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "base64_inv", "i", @@ -159985,7 +161682,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "base64_inv", "i", @@ -160006,7 +161703,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "base64_inv", "i", @@ -160027,7 +161724,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "base64_inv", "i", @@ -160048,7 +161745,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "base64_inv", }, @@ -160069,7 +161766,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "i", "str", @@ -160089,7 +161786,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "str", }, @@ -160110,7 +161807,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "i", }, @@ -160129,7 +161826,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "i", }, @@ -160151,7 +161848,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: nil, }, Value: float64(1), @@ -160177,7 +161874,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: nil, }, Value: float64(15), @@ -160199,7 +161896,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: nil, }, Value: float64(4), @@ -160221,7 +161918,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "base64_inv", "i", @@ -160242,7 +161939,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "base64_inv", "i", @@ -160263,7 +161960,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "base64_inv", }, @@ -160284,7 +161981,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "i", "str", @@ -160304,7 +162001,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "str", }, @@ -160325,7 +162022,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "i", }, @@ -160344,7 +162041,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: Identifiers{ "i", }, @@ -160366,7 +162063,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: nil, }, Value: float64(2), @@ -160392,7 +162089,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11714, + context: p14686, freeVariables: nil, }, Value: float64(2), @@ -160421,7 +162118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "aux", "base64_inv", @@ -160450,7 +162147,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11755, + context: p14727, freeVariables: Identifiers{ "base64_inv", "i", @@ -160558,7 +162255,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11755, + context: p14727, freeVariables: Identifiers{ "i", "str", @@ -160578,7 +162275,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11755, + context: p14727, freeVariables: Identifiers{ "str", }, @@ -160599,7 +162296,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11755, + context: p14727, freeVariables: Identifiers{ "i", }, @@ -160618,7 +162315,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11755, + context: p14727, freeVariables: Identifiers{ "i", }, @@ -160640,7 +162337,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11755, + context: p14727, freeVariables: nil, }, Value: float64(3), @@ -160663,7 +162360,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11755, + context: p14727, freeVariables: nil, }, Value: "=", @@ -160690,7 +162387,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11755, + context: p14727, freeVariables: nil, }, Elements: nil, @@ -160710,7 +162407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11755, + context: p14727, freeVariables: Identifiers{ "base64_inv", "i", @@ -160732,7 +162429,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "base64_inv", "i", @@ -160753,7 +162450,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "base64_inv", "i", @@ -160774,7 +162471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "base64_inv", "i", @@ -160795,7 +162492,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "base64_inv", "i", @@ -160816,7 +162513,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "base64_inv", }, @@ -160837,7 +162534,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "i", "str", @@ -160857,7 +162554,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "str", }, @@ -160878,7 +162575,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "i", }, @@ -160897,7 +162594,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "i", }, @@ -160919,7 +162616,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: nil, }, Value: float64(2), @@ -160945,7 +162642,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: nil, }, Value: float64(3), @@ -160967,7 +162664,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: nil, }, Value: float64(6), @@ -160989,7 +162686,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "base64_inv", "i", @@ -161010,7 +162707,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "base64_inv", }, @@ -161031,7 +162728,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "i", "str", @@ -161051,7 +162748,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "str", }, @@ -161072,7 +162769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "i", }, @@ -161091,7 +162788,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: Identifiers{ "i", }, @@ -161113,7 +162810,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11780, + context: p14752, freeVariables: nil, }, Value: float64(3), @@ -161146,7 +162843,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "aux", "i", @@ -161171,7 +162868,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11627, + context: p14599, freeVariables: Identifiers{ "aux", }, @@ -161194,7 +162891,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "str", }, @@ -161215,7 +162912,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "i", }, @@ -161234,7 +162931,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "i", }, @@ -161256,7 +162953,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: nil, }, Value: float64(4), @@ -161277,7 +162974,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "n1", "n2", @@ -161299,7 +162996,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "n1", "n2", @@ -161320,7 +163017,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "n1", "r", @@ -161340,7 +163037,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "r", }, @@ -161362,7 +163059,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "n1", }, @@ -161385,7 +163082,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "n2", }, @@ -161408,7 +163105,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11820, + context: p14792, freeVariables: Identifiers{ "n3", }, @@ -161444,7 +163141,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: Identifiers{ "aux", "str", @@ -161464,7 +163161,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11573, + context: p14545, freeVariables: Identifiers{ "aux", }, @@ -161487,7 +163184,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11847, + context: p14819, freeVariables: Identifiers{ "str", }, @@ -161508,7 +163205,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11847, + context: p14819, freeVariables: nil, }, Value: float64(0), @@ -161528,7 +163225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11847, + context: p14819, freeVariables: nil, }, Elements: nil, @@ -161603,7 +163300,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14827, freeVariables: nil, }, }, @@ -161625,7 +163322,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14829, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -161867,7 +163564,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14853, freeVariables: Identifiers{ "base64_table", "i", @@ -161891,7 +163588,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14857, freeVariables: Identifiers{ "base64_table", "i", @@ -161911,7 +163608,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14860, freeVariables: Identifiers{ "base64_table", }, @@ -161932,7 +163629,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14863, freeVariables: Identifiers{ "i", }, @@ -161955,7 +163652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p14866, freeVariables: Identifiers{ "i", }, @@ -161984,7 +163681,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14869, freeVariables: Identifiers{ "std", }, @@ -162003,7 +163700,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14872, freeVariables: Identifiers{ "std", }, @@ -162022,7 +163719,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14875, freeVariables: Identifiers{ "std", }, @@ -162068,7 +163765,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p14880, freeVariables: nil, }, Value: float64(0), @@ -162088,14 +163785,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p14882, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -162151,7 +163848,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -162177,7 +163874,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11857, + context: p14888, freeVariables: Identifiers{ "std", "str", @@ -162200,7 +163897,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11861, + context: p14892, freeVariables: Identifiers{ "std", "str", @@ -162220,7 +163917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11861, + context: p14892, freeVariables: Identifiers{ "std", }, @@ -162239,7 +163936,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11861, + context: p14892, freeVariables: Identifiers{ "std", }, @@ -162285,7 +163982,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11870, + context: p14901, freeVariables: Identifiers{ "str", }, @@ -162315,7 +164012,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11857, + context: p14888, freeVariables: Identifiers{ "bytes", "std", @@ -162335,7 +164032,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11857, + context: p14888, freeVariables: Identifiers{ "std", }, @@ -162354,7 +164051,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11857, + context: p14888, freeVariables: Identifiers{ "std", }, @@ -162400,7 +164097,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11881, + context: p14912, freeVariables: nil, }, Value: "", @@ -162421,7 +164118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11881, + context: p14912, freeVariables: Identifiers{ "bytes", "std", @@ -162441,7 +164138,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11881, + context: p14912, freeVariables: Identifiers{ "std", }, @@ -162460,7 +164157,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11881, + context: p14912, freeVariables: Identifiers{ "std", }, @@ -162506,7 +164203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11891, + context: p14922, freeVariables: Identifiers{ "std", }, @@ -162532,7 +164229,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11895, + context: p14926, freeVariables: Identifiers{ "b", "std", @@ -162552,7 +164249,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11895, + context: p14926, freeVariables: Identifiers{ "std", }, @@ -162571,7 +164268,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11895, + context: p14926, freeVariables: Identifiers{ "std", }, @@ -162617,7 +164314,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11904, + context: p14935, freeVariables: Identifiers{ "b", }, @@ -162645,7 +164342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11891, + context: p14922, freeVariables: Identifiers{ "bytes", }, @@ -162726,7 +164423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14943, freeVariables: nil, }, }, @@ -162748,7 +164445,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14945, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -162990,7 +164687,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14969, freeVariables: Identifiers{ "base64_table", "i", @@ -163014,7 +164711,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14973, freeVariables: Identifiers{ "base64_table", "i", @@ -163034,7 +164731,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14976, freeVariables: Identifiers{ "base64_table", }, @@ -163055,7 +164752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14979, freeVariables: Identifiers{ "i", }, @@ -163078,7 +164775,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p14982, freeVariables: Identifiers{ "i", }, @@ -163107,7 +164804,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14985, freeVariables: Identifiers{ "std", }, @@ -163126,7 +164823,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14988, freeVariables: Identifiers{ "std", }, @@ -163145,7 +164842,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p14991, freeVariables: Identifiers{ "std", }, @@ -163191,7 +164888,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p14996, freeVariables: nil, }, Value: float64(0), @@ -163211,14 +164908,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p14998, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -163274,7 +164971,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -163300,7 +164997,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "arr", "std", @@ -163323,7 +165020,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11918, + context: p15008, freeVariables: Identifiers{ "arr", "std", @@ -163343,7 +165040,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11918, + context: p15008, freeVariables: Identifiers{ "std", }, @@ -163362,7 +165059,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11918, + context: p15008, freeVariables: Identifiers{ "std", }, @@ -163408,7 +165105,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11927, + context: p15017, freeVariables: Identifiers{ "arr", }, @@ -163438,7 +165135,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "arr", "l", @@ -163544,7 +165241,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "arr", "std", @@ -163564,7 +165261,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "std", }, @@ -163583,7 +165280,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "std", }, @@ -163629,7 +165326,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11948, + context: p15038, freeVariables: Identifiers{ "arr", }, @@ -163656,7 +165353,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: nil, }, Value: float64(0), @@ -163682,7 +165379,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: nil, }, Elements: nil, @@ -163702,7 +165399,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "arr", "l", @@ -163726,7 +165423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11956, + context: p15046, freeVariables: Identifiers{ "arr", }, @@ -163745,7 +165442,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11956, + context: p15046, freeVariables: Identifiers{ "arr", }, @@ -163766,7 +165463,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11956, + context: p15046, freeVariables: nil, }, Value: float64(0), @@ -163791,7 +165488,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "arr", "l", @@ -163816,7 +165513,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11965, + context: p15055, freeVariables: Identifiers{ "arr", "l", @@ -163837,7 +165534,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11965, + context: p15055, freeVariables: Identifiers{ "std", }, @@ -163856,7 +165553,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11965, + context: p15055, freeVariables: Identifiers{ "std", }, @@ -163902,7 +165599,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11974, + context: p15064, freeVariables: Identifiers{ "l", }, @@ -163921,7 +165618,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11974, + context: p15064, freeVariables: Identifiers{ "l", }, @@ -163943,7 +165640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11974, + context: p15064, freeVariables: nil, }, Value: float64(1), @@ -163964,7 +165661,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11974, + context: p15064, freeVariables: Identifiers{ "arr", }, @@ -163990,7 +165687,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11983, + context: p15073, freeVariables: Identifiers{ "arr", "i", @@ -164010,7 +165707,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11983, + context: p15073, freeVariables: Identifiers{ "arr", }, @@ -164031,7 +165728,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11983, + context: p15073, freeVariables: Identifiers{ "i", }, @@ -164050,7 +165747,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11983, + context: p15073, freeVariables: Identifiers{ "i", }, @@ -164072,7 +165769,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11983, + context: p15073, freeVariables: nil, }, Value: float64(1), @@ -164105,7 +165802,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "pivot", "rest", @@ -164129,7 +165826,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11996, + context: p15086, freeVariables: Identifiers{ "pivot", "rest", @@ -164150,7 +165847,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11996, + context: p15086, freeVariables: Identifiers{ "std", }, @@ -164169,7 +165866,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11996, + context: p15086, freeVariables: Identifiers{ "std", }, @@ -164215,7 +165912,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12005, + context: p15095, freeVariables: Identifiers{ "pivot", }, @@ -164241,7 +165938,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12009, + context: p15099, freeVariables: Identifiers{ "pivot", "x", @@ -164261,7 +165958,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12009, + context: p15099, freeVariables: Identifiers{ "x", }, @@ -164283,7 +165980,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12009, + context: p15099, freeVariables: Identifiers{ "pivot", }, @@ -164306,7 +166003,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12005, + context: p15095, freeVariables: Identifiers{ "rest", }, @@ -164336,7 +166033,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "left", "pivot", @@ -164361,7 +166058,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12021, + context: p15111, freeVariables: Identifiers{ "pivot", "rest", @@ -164382,7 +166079,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12021, + context: p15111, freeVariables: Identifiers{ "std", }, @@ -164401,7 +166098,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12021, + context: p15111, freeVariables: Identifiers{ "std", }, @@ -164447,7 +166144,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12030, + context: p15120, freeVariables: Identifiers{ "pivot", }, @@ -164473,7 +166170,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12034, + context: p15124, freeVariables: Identifiers{ "pivot", "x", @@ -164493,7 +166190,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12034, + context: p15124, freeVariables: Identifiers{ "x", }, @@ -164515,7 +166212,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12034, + context: p15124, freeVariables: Identifiers{ "pivot", }, @@ -164538,7 +166235,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12030, + context: p15120, freeVariables: Identifiers{ "rest", }, @@ -164568,7 +166265,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "left", "pivot", @@ -164590,7 +166287,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "left", "pivot", @@ -164611,7 +166308,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "left", "std", @@ -164631,7 +166328,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "std", }, @@ -164650,7 +166347,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "std", }, @@ -164696,7 +166393,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12055, + context: p15145, freeVariables: Identifiers{ "left", }, @@ -164724,7 +166421,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "pivot", }, @@ -164744,7 +166441,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12061, + context: p15151, freeVariables: Identifiers{ "pivot", }, @@ -164770,7 +166467,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "right", "std", @@ -164790,7 +166487,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "std", }, @@ -164809,7 +166506,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p11914, + context: p15004, freeVariables: Identifiers{ "std", }, @@ -164855,7 +166552,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12072, + context: p15162, freeVariables: Identifiers{ "right", }, @@ -164936,7 +166633,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15168, freeVariables: nil, }, }, @@ -164958,7 +166655,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15170, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -165200,7 +166897,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15194, freeVariables: Identifiers{ "base64_table", "i", @@ -165224,7 +166921,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15198, freeVariables: Identifiers{ "base64_table", "i", @@ -165244,7 +166941,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15201, freeVariables: Identifiers{ "base64_table", }, @@ -165265,7 +166962,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15204, freeVariables: Identifiers{ "i", }, @@ -165288,7 +166985,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p15207, freeVariables: Identifiers{ "i", }, @@ -165317,7 +167014,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15210, freeVariables: Identifiers{ "std", }, @@ -165336,7 +167033,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15213, freeVariables: Identifiers{ "std", }, @@ -165355,7 +167052,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15216, freeVariables: Identifiers{ "std", }, @@ -165401,7 +167098,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15221, freeVariables: nil, }, Value: float64(0), @@ -165421,14 +167118,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15223, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -165484,7 +167181,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -165510,7 +167207,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12080, + context: p15229, freeVariables: Identifiers{ "arr", "std", @@ -165533,7 +167230,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12084, + context: p15233, freeVariables: Identifiers{ "std", }, @@ -165560,7 +167257,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", "b", @@ -165666,7 +167363,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", "std", @@ -165686,7 +167383,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "std", }, @@ -165705,7 +167402,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "std", }, @@ -165751,7 +167448,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12107, + context: p15256, freeVariables: Identifiers{ "a", }, @@ -165778,7 +167475,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: nil, }, Value: float64(0), @@ -165804,7 +167501,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "b", }, @@ -165824,7 +167521,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12114, + context: p15263, freeVariables: Identifiers{ "b", }, @@ -165848,7 +167545,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", "b", @@ -165955,7 +167652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", "std", @@ -165975,7 +167672,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", }, @@ -165996,7 +167693,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", "std", @@ -166016,7 +167713,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", "std", @@ -166036,7 +167733,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "std", }, @@ -166055,7 +167752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "std", }, @@ -166101,7 +167798,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12141, + context: p15290, freeVariables: Identifiers{ "a", }, @@ -166129,7 +167826,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: nil, }, Value: float64(1), @@ -166152,7 +167849,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "b", }, @@ -166179,7 +167876,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", }, @@ -166200,7 +167897,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", "b", @@ -166220,7 +167917,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "a", }, @@ -166242,7 +167939,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12088, + context: p15237, freeVariables: Identifiers{ "b", }, @@ -166262,7 +167959,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12156, + context: p15305, freeVariables: Identifiers{ "b", }, @@ -166293,7 +167990,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12080, + context: p15229, freeVariables: Identifiers{ "arr", "f", @@ -166314,7 +168011,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12080, + context: p15229, freeVariables: Identifiers{ "std", }, @@ -166333,7 +168030,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12080, + context: p15229, freeVariables: Identifiers{ "std", }, @@ -166379,7 +168076,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12167, + context: p15316, freeVariables: Identifiers{ "f", }, @@ -166400,7 +168097,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12167, + context: p15316, freeVariables: Identifiers{ "arr", }, @@ -166421,7 +168118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12167, + context: p15316, freeVariables: nil, }, Elements: nil, @@ -166495,7 +168192,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15325, freeVariables: nil, }, }, @@ -166517,7 +168214,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15327, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -166759,7 +168456,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15351, freeVariables: Identifiers{ "base64_table", "i", @@ -166783,7 +168480,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15355, freeVariables: Identifiers{ "base64_table", "i", @@ -166803,7 +168500,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15358, freeVariables: Identifiers{ "base64_table", }, @@ -166824,7 +168521,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15361, freeVariables: Identifiers{ "i", }, @@ -166847,7 +168544,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p15364, freeVariables: Identifiers{ "i", }, @@ -166876,7 +168573,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15367, freeVariables: Identifiers{ "std", }, @@ -166895,7 +168592,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15370, freeVariables: Identifiers{ "std", }, @@ -166914,7 +168611,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15373, freeVariables: Identifiers{ "std", }, @@ -166960,7 +168657,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15378, freeVariables: nil, }, Value: float64(0), @@ -166980,14 +168677,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15380, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -167043,7 +168740,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -167069,7 +168766,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12178, + context: p15386, freeVariables: Identifiers{ "arr", "std", @@ -167089,7 +168786,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12178, + context: p15386, freeVariables: Identifiers{ "std", }, @@ -167108,7 +168805,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12178, + context: p15386, freeVariables: Identifiers{ "std", }, @@ -167154,7 +168851,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12187, + context: p15395, freeVariables: Identifiers{ "arr", "std", @@ -167174,7 +168871,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12187, + context: p15395, freeVariables: Identifiers{ "std", }, @@ -167193,7 +168890,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12187, + context: p15395, freeVariables: Identifiers{ "std", }, @@ -167239,7 +168936,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12196, + context: p15404, freeVariables: Identifiers{ "arr", }, @@ -167319,7 +169016,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15410, freeVariables: nil, }, }, @@ -167341,7 +169038,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15412, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -167583,7 +169280,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15436, freeVariables: Identifiers{ "base64_table", "i", @@ -167607,7 +169304,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15440, freeVariables: Identifiers{ "base64_table", "i", @@ -167627,7 +169324,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15443, freeVariables: Identifiers{ "base64_table", }, @@ -167648,7 +169345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15446, freeVariables: Identifiers{ "i", }, @@ -167671,7 +169368,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p15449, freeVariables: Identifiers{ "i", }, @@ -167700,7 +169397,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15452, freeVariables: Identifiers{ "std", }, @@ -167719,7 +169416,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15455, freeVariables: Identifiers{ "std", }, @@ -167738,7 +169435,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15458, freeVariables: Identifiers{ "std", }, @@ -167784,7 +169481,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15463, freeVariables: nil, }, Value: float64(0), @@ -167804,14 +169501,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15465, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -167867,7 +169564,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -167894,7 +169591,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12204, + context: p15471, freeVariables: Identifiers{ "arr", "std", @@ -167915,7 +169612,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12204, + context: p15471, freeVariables: Identifiers{ "arr", "std", @@ -167936,7 +169633,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12204, + context: p15471, freeVariables: Identifiers{ "std", }, @@ -167955,7 +169652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12204, + context: p15471, freeVariables: Identifiers{ "std", }, @@ -168001,7 +169698,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12215, + context: p15482, freeVariables: Identifiers{ "arr", "std", @@ -168022,7 +169719,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12215, + context: p15482, freeVariables: Identifiers{ "std", }, @@ -168041,7 +169738,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12215, + context: p15482, freeVariables: Identifiers{ "std", }, @@ -168087,7 +169784,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12224, + context: p15491, freeVariables: Identifiers{ "x", }, @@ -168107,7 +169804,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12228, + context: p15495, freeVariables: Identifiers{ "x", }, @@ -168131,7 +169828,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12224, + context: p15491, freeVariables: Identifiers{ "arr", }, @@ -168165,7 +169862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12204, + context: p15471, freeVariables: nil, }, Value: float64(0), @@ -168233,7 +169930,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15504, freeVariables: nil, }, }, @@ -168255,7 +169952,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15506, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -168497,7 +170194,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15530, freeVariables: Identifiers{ "base64_table", "i", @@ -168521,7 +170218,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15534, freeVariables: Identifiers{ "base64_table", "i", @@ -168541,7 +170238,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15537, freeVariables: Identifiers{ "base64_table", }, @@ -168562,7 +170259,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15540, freeVariables: Identifiers{ "i", }, @@ -168585,7 +170282,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p15543, freeVariables: Identifiers{ "i", }, @@ -168614,7 +170311,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15546, freeVariables: Identifiers{ "std", }, @@ -168633,7 +170330,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15549, freeVariables: Identifiers{ "std", }, @@ -168652,7 +170349,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15552, freeVariables: Identifiers{ "std", }, @@ -168698,7 +170395,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15557, freeVariables: nil, }, Value: float64(0), @@ -168718,14 +170415,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15559, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -168781,7 +170478,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -168808,7 +170505,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12239, + context: p15565, freeVariables: Identifiers{ "a", "b", @@ -168829,7 +170526,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12239, + context: p15565, freeVariables: Identifiers{ "std", }, @@ -168848,7 +170545,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12239, + context: p15565, freeVariables: Identifiers{ "std", }, @@ -168894,7 +170591,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12248, + context: p15574, freeVariables: Identifiers{ "a", "b", @@ -168914,7 +170611,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12248, + context: p15574, freeVariables: Identifiers{ "a", }, @@ -168936,7 +170633,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12248, + context: p15574, freeVariables: Identifiers{ "b", }, @@ -169011,7 +170708,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15584, freeVariables: nil, }, }, @@ -169033,7 +170730,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15586, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -169275,7 +170972,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15610, freeVariables: Identifiers{ "base64_table", "i", @@ -169299,7 +170996,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15614, freeVariables: Identifiers{ "base64_table", "i", @@ -169319,7 +171016,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15617, freeVariables: Identifiers{ "base64_table", }, @@ -169340,7 +171037,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15620, freeVariables: Identifiers{ "i", }, @@ -169363,7 +171060,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p15623, freeVariables: Identifiers{ "i", }, @@ -169392,7 +171089,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15626, freeVariables: Identifiers{ "std", }, @@ -169411,7 +171108,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15629, freeVariables: Identifiers{ "std", }, @@ -169430,7 +171127,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15632, freeVariables: Identifiers{ "std", }, @@ -169476,7 +171173,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15637, freeVariables: nil, }, Value: float64(0), @@ -169496,14 +171193,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15639, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -169559,7 +171256,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -169586,7 +171283,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12260, + context: p15645, freeVariables: Identifiers{ "a", "b", @@ -169610,7 +171307,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12264, + context: p15649, freeVariables: Identifiers{ "aux", "std", @@ -169641,7 +171338,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "acc", @@ -169666,7 +171363,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "b", @@ -169689,7 +171386,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "i", @@ -169710,7 +171407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "i", }, @@ -169732,7 +171429,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "std", @@ -169752,7 +171449,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "std", }, @@ -169771,7 +171468,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "std", }, @@ -169817,7 +171514,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12285, + context: p15670, freeVariables: Identifiers{ "a", }, @@ -169846,7 +171543,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "b", "j", @@ -169867,7 +171564,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "j", }, @@ -169889,7 +171586,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "b", "std", @@ -169909,7 +171606,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "std", }, @@ -169928,7 +171625,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "std", }, @@ -169974,7 +171671,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12300, + context: p15685, freeVariables: Identifiers{ "b", }, @@ -170003,7 +171700,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "acc", }, @@ -170024,7 +171721,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "acc", @@ -170137,7 +171834,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "i", @@ -170157,7 +171854,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", }, @@ -170178,7 +171875,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "i", }, @@ -170201,7 +171898,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "b", "j", @@ -170221,7 +171918,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "b", }, @@ -170242,7 +171939,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "j", }, @@ -170271,7 +171968,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "acc", @@ -170295,7 +171992,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "aux", }, @@ -170318,7 +172015,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: Identifiers{ "a", }, @@ -170339,7 +172036,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: Identifiers{ "b", }, @@ -170360,7 +172057,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: Identifiers{ "i", }, @@ -170379,7 +172076,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: Identifiers{ "i", }, @@ -170401,7 +172098,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: nil, }, Value: float64(1), @@ -170422,7 +172119,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: Identifiers{ "j", }, @@ -170441,7 +172138,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: Identifiers{ "j", }, @@ -170463,7 +172160,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: nil, }, Value: float64(1), @@ -170484,7 +172181,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: Identifiers{ "a", "acc", @@ -170505,7 +172202,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: Identifiers{ "acc", }, @@ -170527,7 +172224,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12332, + context: p15717, freeVariables: Identifiers{ "a", "i", @@ -170548,7 +172245,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12354, + context: p15739, freeVariables: Identifiers{ "a", "i", @@ -170568,7 +172265,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12354, + context: p15739, freeVariables: Identifiers{ "a", }, @@ -170589,7 +172286,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12354, + context: p15739, freeVariables: Identifiers{ "i", }, @@ -170622,7 +172319,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "acc", @@ -170646,7 +172343,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "b", @@ -170668,7 +172365,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "i", @@ -170688,7 +172385,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", }, @@ -170709,7 +172406,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "i", }, @@ -170733,7 +172430,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "b", "j", @@ -170753,7 +172450,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "b", }, @@ -170774,7 +172471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "j", }, @@ -170798,7 +172495,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "acc", @@ -170822,7 +172519,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "aux", }, @@ -170845,7 +172542,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12382, + context: p15767, freeVariables: Identifiers{ "a", }, @@ -170866,7 +172563,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12382, + context: p15767, freeVariables: Identifiers{ "b", }, @@ -170887,7 +172584,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12382, + context: p15767, freeVariables: Identifiers{ "i", }, @@ -170906,7 +172603,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12382, + context: p15767, freeVariables: Identifiers{ "i", }, @@ -170928,7 +172625,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12382, + context: p15767, freeVariables: nil, }, Value: float64(1), @@ -170949,7 +172646,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12382, + context: p15767, freeVariables: Identifiers{ "j", }, @@ -170970,7 +172667,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12382, + context: p15767, freeVariables: Identifiers{ "acc", }, @@ -170997,7 +172694,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "a", "acc", @@ -171021,7 +172718,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12268, + context: p15653, freeVariables: Identifiers{ "aux", }, @@ -171044,7 +172741,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12401, + context: p15786, freeVariables: Identifiers{ "a", }, @@ -171065,7 +172762,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12401, + context: p15786, freeVariables: Identifiers{ "b", }, @@ -171086,7 +172783,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12401, + context: p15786, freeVariables: Identifiers{ "i", }, @@ -171107,7 +172804,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12401, + context: p15786, freeVariables: Identifiers{ "j", }, @@ -171126,7 +172823,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12401, + context: p15786, freeVariables: Identifiers{ "j", }, @@ -171148,7 +172845,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12401, + context: p15786, freeVariables: nil, }, Value: float64(1), @@ -171169,7 +172866,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12401, + context: p15786, freeVariables: Identifiers{ "acc", }, @@ -171203,7 +172900,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12260, + context: p15645, freeVariables: Identifiers{ "a", "aux", @@ -171224,7 +172921,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12260, + context: p15645, freeVariables: Identifiers{ "aux", }, @@ -171247,7 +172944,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12420, + context: p15805, freeVariables: Identifiers{ "a", }, @@ -171268,7 +172965,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12420, + context: p15805, freeVariables: Identifiers{ "b", }, @@ -171289,7 +172986,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12420, + context: p15805, freeVariables: nil, }, Value: float64(0), @@ -171309,7 +173006,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12420, + context: p15805, freeVariables: nil, }, Value: float64(0), @@ -171329,7 +173026,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12420, + context: p15805, freeVariables: nil, }, Elements: nil, @@ -171403,7 +173100,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15816, freeVariables: nil, }, }, @@ -171425,7 +173122,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15818, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -171667,7 +173364,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15842, freeVariables: Identifiers{ "base64_table", "i", @@ -171691,7 +173388,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15846, freeVariables: Identifiers{ "base64_table", "i", @@ -171711,7 +173408,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15849, freeVariables: Identifiers{ "base64_table", }, @@ -171732,7 +173429,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15852, freeVariables: Identifiers{ "i", }, @@ -171755,7 +173452,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p15855, freeVariables: Identifiers{ "i", }, @@ -171784,7 +173481,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15858, freeVariables: Identifiers{ "std", }, @@ -171803,7 +173500,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15861, freeVariables: Identifiers{ "std", }, @@ -171822,7 +173519,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p15864, freeVariables: Identifiers{ "std", }, @@ -171868,7 +173565,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15869, freeVariables: nil, }, Value: float64(0), @@ -171888,14 +173585,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p15871, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -171951,7 +173648,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -171978,7 +173675,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12433, + context: p15877, freeVariables: Identifiers{ "a", "b", @@ -172002,7 +173699,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12437, + context: p15881, freeVariables: Identifiers{ "aux", "std", @@ -172033,7 +173730,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "acc", @@ -172058,7 +173755,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "i", @@ -172079,7 +173776,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "i", }, @@ -172101,7 +173798,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "std", @@ -172121,7 +173818,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "std", }, @@ -172140,7 +173837,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "std", }, @@ -172186,7 +173883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12456, + context: p15900, freeVariables: Identifiers{ "a", }, @@ -172214,7 +173911,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "acc", }, @@ -172235,7 +173932,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "acc", @@ -172260,7 +173957,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "b", "j", @@ -172281,7 +173978,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "j", }, @@ -172303,7 +174000,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "b", "std", @@ -172323,7 +174020,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "std", }, @@ -172342,7 +174039,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "std", }, @@ -172388,7 +174085,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12475, + context: p15919, freeVariables: Identifiers{ "b", }, @@ -172416,7 +174113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "acc", @@ -172440,7 +174137,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "aux", }, @@ -172463,7 +174160,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12483, + context: p15927, freeVariables: Identifiers{ "a", }, @@ -172484,7 +174181,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12483, + context: p15927, freeVariables: Identifiers{ "b", }, @@ -172505,7 +174202,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12483, + context: p15927, freeVariables: Identifiers{ "i", }, @@ -172524,7 +174221,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12483, + context: p15927, freeVariables: Identifiers{ "i", }, @@ -172546,7 +174243,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12483, + context: p15927, freeVariables: nil, }, Value: float64(1), @@ -172567,7 +174264,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12483, + context: p15927, freeVariables: Identifiers{ "j", }, @@ -172588,7 +174285,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12483, + context: p15927, freeVariables: Identifiers{ "a", "acc", @@ -172609,7 +174306,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12483, + context: p15927, freeVariables: Identifiers{ "acc", }, @@ -172631,7 +174328,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12483, + context: p15927, freeVariables: Identifiers{ "a", "i", @@ -172652,7 +174349,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12502, + context: p15946, freeVariables: Identifiers{ "a", "i", @@ -172672,7 +174369,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12502, + context: p15946, freeVariables: Identifiers{ "a", }, @@ -172693,7 +174390,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12502, + context: p15946, freeVariables: Identifiers{ "i", }, @@ -172726,7 +174423,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "acc", @@ -172839,7 +174536,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "i", @@ -172859,7 +174556,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", }, @@ -172880,7 +174577,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "i", }, @@ -172903,7 +174600,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "b", "j", @@ -172923,7 +174620,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "b", }, @@ -172944,7 +174641,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "j", }, @@ -172973,7 +174670,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "acc", @@ -172997,7 +174694,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "aux", }, @@ -173020,7 +174717,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12536, + context: p15980, freeVariables: Identifiers{ "a", }, @@ -173041,7 +174738,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12536, + context: p15980, freeVariables: Identifiers{ "b", }, @@ -173062,7 +174759,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12536, + context: p15980, freeVariables: Identifiers{ "i", }, @@ -173081,7 +174778,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12536, + context: p15980, freeVariables: Identifiers{ "i", }, @@ -173103,7 +174800,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12536, + context: p15980, freeVariables: nil, }, Value: float64(1), @@ -173124,7 +174821,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12536, + context: p15980, freeVariables: Identifiers{ "j", }, @@ -173143,7 +174840,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12536, + context: p15980, freeVariables: Identifiers{ "j", }, @@ -173165,7 +174862,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12536, + context: p15980, freeVariables: nil, }, Value: float64(1), @@ -173186,7 +174883,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12536, + context: p15980, freeVariables: Identifiers{ "acc", }, @@ -173213,7 +174910,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "acc", @@ -173237,7 +174934,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "b", @@ -173259,7 +174956,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "i", @@ -173279,7 +174976,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", }, @@ -173300,7 +174997,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "i", }, @@ -173324,7 +175021,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "b", "j", @@ -173344,7 +175041,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "b", }, @@ -173365,7 +175062,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "j", }, @@ -173389,7 +175086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "acc", @@ -173413,7 +175110,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "aux", }, @@ -173436,7 +175133,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12574, + context: p16018, freeVariables: Identifiers{ "a", }, @@ -173457,7 +175154,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12574, + context: p16018, freeVariables: Identifiers{ "b", }, @@ -173478,7 +175175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12574, + context: p16018, freeVariables: Identifiers{ "i", }, @@ -173497,7 +175194,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12574, + context: p16018, freeVariables: Identifiers{ "i", }, @@ -173519,7 +175216,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12574, + context: p16018, freeVariables: nil, }, Value: float64(1), @@ -173540,7 +175237,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12574, + context: p16018, freeVariables: Identifiers{ "j", }, @@ -173561,7 +175258,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12574, + context: p16018, freeVariables: Identifiers{ "a", "acc", @@ -173582,7 +175279,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12574, + context: p16018, freeVariables: Identifiers{ "acc", }, @@ -173604,7 +175301,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12574, + context: p16018, freeVariables: Identifiers{ "a", "i", @@ -173625,7 +175322,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12593, + context: p16037, freeVariables: Identifiers{ "a", "i", @@ -173645,7 +175342,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12593, + context: p16037, freeVariables: Identifiers{ "a", }, @@ -173666,7 +175363,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12593, + context: p16037, freeVariables: Identifiers{ "i", }, @@ -173699,7 +175396,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "a", "acc", @@ -173723,7 +175420,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12441, + context: p15885, freeVariables: Identifiers{ "aux", }, @@ -173746,7 +175443,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12605, + context: p16049, freeVariables: Identifiers{ "a", }, @@ -173767,7 +175464,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12605, + context: p16049, freeVariables: Identifiers{ "b", }, @@ -173788,7 +175485,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12605, + context: p16049, freeVariables: Identifiers{ "i", }, @@ -173809,7 +175506,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12605, + context: p16049, freeVariables: Identifiers{ "j", }, @@ -173828,7 +175525,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12605, + context: p16049, freeVariables: Identifiers{ "j", }, @@ -173850,7 +175547,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12605, + context: p16049, freeVariables: nil, }, Value: float64(1), @@ -173871,7 +175568,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12605, + context: p16049, freeVariables: Identifiers{ "acc", }, @@ -173906,7 +175603,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12433, + context: p15877, freeVariables: Identifiers{ "a", "aux", @@ -173927,7 +175624,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12433, + context: p15877, freeVariables: Identifiers{ "aux", }, @@ -173950,7 +175647,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12624, + context: p16068, freeVariables: Identifiers{ "a", }, @@ -173971,7 +175668,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12624, + context: p16068, freeVariables: Identifiers{ "b", }, @@ -173992,7 +175689,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12624, + context: p16068, freeVariables: nil, }, Value: float64(0), @@ -174012,7 +175709,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12624, + context: p16068, freeVariables: nil, }, Value: float64(0), @@ -174032,7 +175729,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12624, + context: p16068, freeVariables: nil, }, Elements: nil, @@ -174106,7 +175803,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16079, freeVariables: nil, }, }, @@ -174128,7 +175825,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16081, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -174370,7 +176067,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16105, freeVariables: Identifiers{ "base64_table", "i", @@ -174394,7 +176091,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16109, freeVariables: Identifiers{ "base64_table", "i", @@ -174414,7 +176111,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16112, freeVariables: Identifiers{ "base64_table", }, @@ -174435,7 +176132,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16115, freeVariables: Identifiers{ "i", }, @@ -174458,7 +176155,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p16118, freeVariables: Identifiers{ "i", }, @@ -174487,7 +176184,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16121, freeVariables: Identifiers{ "std", }, @@ -174506,7 +176203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16124, freeVariables: Identifiers{ "std", }, @@ -174525,7 +176222,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16127, freeVariables: Identifiers{ "std", }, @@ -174571,7 +176268,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16132, freeVariables: nil, }, Value: float64(0), @@ -174591,14 +176288,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16134, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -174654,7 +176351,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -174681,7 +176378,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "patch", "std", @@ -174787,7 +176484,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "patch", "std", @@ -174807,7 +176504,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "std", }, @@ -174826,7 +176523,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "std", }, @@ -174872,7 +176569,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12656, + context: p16159, freeVariables: Identifiers{ "patch", }, @@ -174899,7 +176596,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: nil, }, Value: "object", @@ -174926,7 +176623,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "patch", "std", @@ -174950,7 +176647,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12663, + context: p16166, freeVariables: Identifiers{ "std", "target", @@ -175055,7 +176752,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12663, + context: p16166, freeVariables: Identifiers{ "std", "target", @@ -175075,7 +176772,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12663, + context: p16166, freeVariables: Identifiers{ "std", }, @@ -175094,7 +176791,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12663, + context: p16166, freeVariables: Identifiers{ "std", }, @@ -175140,7 +176837,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12682, + context: p16185, freeVariables: Identifiers{ "target", }, @@ -175167,7 +176864,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12663, + context: p16166, freeVariables: nil, }, Value: "object", @@ -175194,7 +176891,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12663, + context: p16166, freeVariables: Identifiers{ "target", }, @@ -175215,7 +176912,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12663, + context: p16166, freeVariables: nil, }, Asserts: nil, @@ -175239,7 +176936,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "patch", "std", @@ -175263,7 +176960,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12692, + context: p16195, freeVariables: Identifiers{ "std", "target_object", @@ -175368,7 +177065,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12692, + context: p16195, freeVariables: Identifiers{ "std", "target_object", @@ -175388,7 +177085,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12692, + context: p16195, freeVariables: Identifiers{ "std", }, @@ -175407,7 +177104,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12692, + context: p16195, freeVariables: Identifiers{ "std", }, @@ -175453,7 +177150,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12711, + context: p16214, freeVariables: Identifiers{ "target_object", }, @@ -175480,7 +177177,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12692, + context: p16195, freeVariables: nil, }, Value: "object", @@ -175507,7 +177204,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12692, + context: p16195, freeVariables: Identifiers{ "std", "target_object", @@ -175527,7 +177224,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12692, + context: p16195, freeVariables: Identifiers{ "std", }, @@ -175546,7 +177243,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12692, + context: p16195, freeVariables: Identifiers{ "std", }, @@ -175592,7 +177289,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12723, + context: p16226, freeVariables: Identifiers{ "target_object", }, @@ -175619,7 +177316,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12692, + context: p16195, freeVariables: nil, }, Elements: nil, @@ -175643,7 +177340,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "patch", "std", @@ -175887,7 +177584,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12751, + context: p16254, freeVariables: Identifiers{ "k", "patch", @@ -175907,7 +177604,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12751, + context: p16254, freeVariables: Identifiers{ "patch", }, @@ -175928,7 +177625,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12751, + context: p16254, freeVariables: Identifiers{ "k", }, @@ -175951,7 +177648,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12751, + context: p16254, freeVariables: nil, }, }, @@ -175995,7 +177692,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12762, + context: p16265, freeVariables: Identifiers{ "k", }, @@ -176041,7 +177738,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12751, + context: p16254, freeVariables: Identifiers{ "patch", "std", @@ -176061,7 +177758,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12751, + context: p16254, freeVariables: Identifiers{ "std", }, @@ -176080,7 +177777,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12751, + context: p16254, freeVariables: Identifiers{ "std", }, @@ -176126,7 +177823,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12774, + context: p16277, freeVariables: Identifiers{ "patch", }, @@ -176162,7 +177859,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "null_fields", "patch", @@ -176188,7 +177885,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12780, + context: p16283, freeVariables: Identifiers{ "patch", "std", @@ -176209,7 +177906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12780, + context: p16283, freeVariables: Identifiers{ "std", }, @@ -176228,7 +177925,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12780, + context: p16283, freeVariables: Identifiers{ "std", }, @@ -176274,7 +177971,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12789, + context: p16292, freeVariables: Identifiers{ "target_fields", }, @@ -176295,7 +177992,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12789, + context: p16292, freeVariables: Identifiers{ "patch", "std", @@ -176315,7 +178012,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12789, + context: p16292, freeVariables: Identifiers{ "std", }, @@ -176334,7 +178031,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12789, + context: p16292, freeVariables: Identifiers{ "std", }, @@ -176380,7 +178077,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12800, + context: p16303, freeVariables: Identifiers{ "patch", }, @@ -176643,7 +178340,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "k", "patch", @@ -176669,7 +178366,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "k", }, @@ -176690,7 +178387,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", "patch", @@ -176712,7 +178409,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", "patch", @@ -176734,7 +178431,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", "patch", @@ -176755,7 +178452,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "std", }, @@ -176774,7 +178471,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "std", }, @@ -176820,7 +178517,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12843, + context: p16346, freeVariables: Identifiers{ "patch", }, @@ -176841,7 +178538,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12843, + context: p16346, freeVariables: Identifiers{ "k", }, @@ -176869,7 +178566,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", "target_object", @@ -176889,7 +178586,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "target_object", }, @@ -176910,7 +178607,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", }, @@ -176933,7 +178630,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", "patch", @@ -176955,7 +178652,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", "std", @@ -176977,7 +178674,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", "std", @@ -176998,7 +178695,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "std", }, @@ -177017,7 +178714,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "std", }, @@ -177063,7 +178760,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12866, + context: p16369, freeVariables: Identifiers{ "target_object", }, @@ -177084,7 +178781,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12866, + context: p16369, freeVariables: Identifiers{ "k", }, @@ -177112,7 +178809,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", "patch", @@ -177133,7 +178830,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "std", }, @@ -177152,7 +178849,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "std", }, @@ -177198,7 +178895,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12879, + context: p16382, freeVariables: nil, }, }, @@ -177216,7 +178913,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12879, + context: p16382, freeVariables: Identifiers{ "k", "patch", @@ -177236,7 +178933,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12879, + context: p16382, freeVariables: Identifiers{ "patch", }, @@ -177257,7 +178954,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12879, + context: p16382, freeVariables: Identifiers{ "k", }, @@ -177286,7 +178983,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "k", "patch", @@ -177308,7 +179005,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "std", }, @@ -177327,7 +179024,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12830, + context: p16333, freeVariables: Identifiers{ "std", }, @@ -177373,7 +179070,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12895, + context: p16398, freeVariables: Identifiers{ "k", "target_object", @@ -177393,7 +179090,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12895, + context: p16398, freeVariables: Identifiers{ "target_object", }, @@ -177414,7 +179111,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12895, + context: p16398, freeVariables: Identifiers{ "k", }, @@ -177437,7 +179134,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12895, + context: p16398, freeVariables: Identifiers{ "k", "patch", @@ -177457,7 +179154,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12895, + context: p16398, freeVariables: Identifiers{ "patch", }, @@ -177478,7 +179175,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12895, + context: p16398, freeVariables: Identifiers{ "k", }, @@ -177517,7 +179214,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "both_fields", "null_fields", @@ -177538,7 +179235,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "std", }, @@ -177557,7 +179254,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "std", }, @@ -177603,7 +179300,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12916, + context: p16419, freeVariables: Identifiers{ "both_fields", }, @@ -177624,7 +179321,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12916, + context: p16419, freeVariables: Identifiers{ "null_fields", }, @@ -177667,7 +179364,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12637, + context: p16140, freeVariables: Identifiers{ "patch", }, @@ -177736,7 +179433,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16429, freeVariables: nil, }, }, @@ -177758,7 +179455,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16431, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -178000,7 +179697,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16455, freeVariables: Identifiers{ "base64_table", "i", @@ -178024,7 +179721,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16459, freeVariables: Identifiers{ "base64_table", "i", @@ -178044,7 +179741,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16462, freeVariables: Identifiers{ "base64_table", }, @@ -178065,7 +179762,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16465, freeVariables: Identifiers{ "i", }, @@ -178088,7 +179785,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p16468, freeVariables: Identifiers{ "i", }, @@ -178117,7 +179814,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16471, freeVariables: Identifiers{ "std", }, @@ -178136,7 +179833,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16474, freeVariables: Identifiers{ "std", }, @@ -178155,7 +179852,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16477, freeVariables: Identifiers{ "std", }, @@ -178201,7 +179898,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16482, freeVariables: nil, }, Value: float64(0), @@ -178221,14 +179918,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16484, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -178284,7 +179981,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -178310,7 +180007,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12928, + context: p16490, freeVariables: Identifiers{ "o", "std", @@ -178330,7 +180027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12928, + context: p16490, freeVariables: Identifiers{ "std", }, @@ -178349,7 +180046,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12928, + context: p16490, freeVariables: Identifiers{ "std", }, @@ -178395,7 +180092,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12937, + context: p16499, freeVariables: Identifiers{ "o", }, @@ -178416,7 +180113,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12937, + context: p16499, freeVariables: nil, }, Value: false, @@ -178488,7 +180185,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16506, freeVariables: nil, }, }, @@ -178510,7 +180207,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16508, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -178752,7 +180449,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16532, freeVariables: Identifiers{ "base64_table", "i", @@ -178776,7 +180473,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16536, freeVariables: Identifiers{ "base64_table", "i", @@ -178796,7 +180493,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16539, freeVariables: Identifiers{ "base64_table", }, @@ -178817,7 +180514,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16542, freeVariables: Identifiers{ "i", }, @@ -178840,7 +180537,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p16545, freeVariables: Identifiers{ "i", }, @@ -178869,7 +180566,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16548, freeVariables: Identifiers{ "std", }, @@ -178888,7 +180585,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16551, freeVariables: Identifiers{ "std", }, @@ -178907,7 +180604,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16554, freeVariables: Identifiers{ "std", }, @@ -178953,7 +180650,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16559, freeVariables: nil, }, Value: float64(0), @@ -178973,14 +180670,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16561, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -179036,7 +180733,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -179062,7 +180759,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12946, + context: p16567, freeVariables: Identifiers{ "o", "std", @@ -179082,7 +180779,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12946, + context: p16567, freeVariables: Identifiers{ "std", }, @@ -179101,7 +180798,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12946, + context: p16567, freeVariables: Identifiers{ "std", }, @@ -179147,7 +180844,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12955, + context: p16576, freeVariables: Identifiers{ "o", }, @@ -179168,7 +180865,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12955, + context: p16576, freeVariables: nil, }, Value: true, @@ -179240,7 +180937,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16583, freeVariables: nil, }, }, @@ -179262,7 +180959,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16585, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -179504,7 +181201,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16609, freeVariables: Identifiers{ "base64_table", "i", @@ -179528,7 +181225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16613, freeVariables: Identifiers{ "base64_table", "i", @@ -179548,7 +181245,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16616, freeVariables: Identifiers{ "base64_table", }, @@ -179569,7 +181266,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16619, freeVariables: Identifiers{ "i", }, @@ -179592,7 +181289,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p16622, freeVariables: Identifiers{ "i", }, @@ -179621,7 +181318,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16625, freeVariables: Identifiers{ "std", }, @@ -179640,7 +181337,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16628, freeVariables: Identifiers{ "std", }, @@ -179659,7 +181356,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16631, freeVariables: Identifiers{ "std", }, @@ -179705,7 +181402,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16636, freeVariables: nil, }, Value: float64(0), @@ -179725,14 +181422,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16638, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -179788,7 +181485,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -179815,7 +181512,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12964, + context: p16644, freeVariables: Identifiers{ "f", "o", @@ -179836,7 +181533,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12964, + context: p16644, freeVariables: Identifiers{ "std", }, @@ -179855,7 +181552,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12964, + context: p16644, freeVariables: Identifiers{ "std", }, @@ -179901,7 +181598,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12973, + context: p16653, freeVariables: Identifiers{ "o", }, @@ -179922,7 +181619,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12973, + context: p16653, freeVariables: Identifiers{ "f", }, @@ -179943,7 +181640,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12973, + context: p16653, freeVariables: nil, }, Value: false, @@ -180015,7 +181712,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16662, freeVariables: nil, }, }, @@ -180037,7 +181734,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16664, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -180279,7 +181976,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16688, freeVariables: Identifiers{ "base64_table", "i", @@ -180303,7 +182000,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16692, freeVariables: Identifiers{ "base64_table", "i", @@ -180323,7 +182020,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16695, freeVariables: Identifiers{ "base64_table", }, @@ -180344,7 +182041,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16698, freeVariables: Identifiers{ "i", }, @@ -180367,7 +182064,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p16701, freeVariables: Identifiers{ "i", }, @@ -180396,7 +182093,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16704, freeVariables: Identifiers{ "std", }, @@ -180415,7 +182112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16707, freeVariables: Identifiers{ "std", }, @@ -180434,7 +182131,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16710, freeVariables: Identifiers{ "std", }, @@ -180480,7 +182177,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16715, freeVariables: nil, }, Value: float64(0), @@ -180500,14 +182197,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16717, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -180563,7 +182260,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -180590,7 +182287,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12984, + context: p16723, freeVariables: Identifiers{ "f", "o", @@ -180611,7 +182308,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12984, + context: p16723, freeVariables: Identifiers{ "std", }, @@ -180630,7 +182327,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12984, + context: p16723, freeVariables: Identifiers{ "std", }, @@ -180676,7 +182373,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12993, + context: p16732, freeVariables: Identifiers{ "o", }, @@ -180697,7 +182394,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12993, + context: p16732, freeVariables: Identifiers{ "f", }, @@ -180718,7 +182415,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p12993, + context: p16732, freeVariables: nil, }, Value: true, @@ -180790,7 +182487,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16741, freeVariables: nil, }, }, @@ -180812,7 +182509,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16743, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -181054,7 +182751,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16767, freeVariables: Identifiers{ "base64_table", "i", @@ -181078,7 +182775,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16771, freeVariables: Identifiers{ "base64_table", "i", @@ -181098,7 +182795,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16774, freeVariables: Identifiers{ "base64_table", }, @@ -181119,7 +182816,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16777, freeVariables: Identifiers{ "i", }, @@ -181142,7 +182839,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p16780, freeVariables: Identifiers{ "i", }, @@ -181171,7 +182868,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16783, freeVariables: Identifiers{ "std", }, @@ -181190,7 +182887,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16786, freeVariables: Identifiers{ "std", }, @@ -181209,7 +182906,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p16789, freeVariables: Identifiers{ "std", }, @@ -181255,7 +182952,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16794, freeVariables: nil, }, Value: float64(0), @@ -181275,14 +182972,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p16796, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -181338,7 +183035,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -181365,7 +183062,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -181389,7 +183086,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13008, + context: p16806, freeVariables: Identifiers{ "a", "std", @@ -181409,7 +183106,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13008, + context: p16806, freeVariables: Identifiers{ "std", }, @@ -181428,7 +183125,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13008, + context: p16806, freeVariables: Identifiers{ "std", }, @@ -181474,7 +183171,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13017, + context: p16815, freeVariables: Identifiers{ "a", }, @@ -181504,7 +183201,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -181529,7 +183226,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13023, + context: p16821, freeVariables: Identifiers{ "b", "std", @@ -181549,7 +183246,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13023, + context: p16821, freeVariables: Identifiers{ "std", }, @@ -181568,7 +183265,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13023, + context: p16821, freeVariables: Identifiers{ "std", }, @@ -181614,7 +183311,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13032, + context: p16830, freeVariables: Identifiers{ "b", }, @@ -181644,7 +183341,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -181667,7 +183364,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", "ta", @@ -181689,7 +183386,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", "ta", @@ -181710,7 +183407,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -181729,7 +183426,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -181775,7 +183472,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13047, + context: p16845, freeVariables: Identifiers{ "ta", }, @@ -181796,7 +183493,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13047, + context: p16845, freeVariables: Identifiers{ "tb", }, @@ -181824,7 +183521,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: nil, }, Value: false, @@ -181843,7 +183540,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -181865,7 +183562,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", "ta", @@ -181885,7 +183582,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -181904,7 +183601,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -181950,7 +183647,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13063, + context: p16861, freeVariables: Identifiers{ "ta", }, @@ -181971,7 +183668,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13063, + context: p16861, freeVariables: nil, }, Value: "array", @@ -181998,7 +183695,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -182022,7 +183719,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13070, + context: p16868, freeVariables: Identifiers{ "a", "std", @@ -182042,7 +183739,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13070, + context: p16868, freeVariables: Identifiers{ "std", }, @@ -182061,7 +183758,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13070, + context: p16868, freeVariables: Identifiers{ "std", }, @@ -182107,7 +183804,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13079, + context: p16877, freeVariables: Identifiers{ "a", }, @@ -182137,7 +183834,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -182159,7 +183856,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "b", "la", @@ -182181,7 +183878,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "b", "la", @@ -182202,7 +183899,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -182221,7 +183918,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -182267,7 +183964,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13094, + context: p16892, freeVariables: Identifiers{ "la", }, @@ -182288,7 +183985,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13094, + context: p16892, freeVariables: Identifiers{ "b", "std", @@ -182308,7 +184005,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13094, + context: p16892, freeVariables: Identifiers{ "std", }, @@ -182327,7 +184024,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13094, + context: p16892, freeVariables: Identifiers{ "std", }, @@ -182373,7 +184070,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13105, + context: p16903, freeVariables: Identifiers{ "b", }, @@ -182407,7 +184104,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: nil, }, Value: false, @@ -182426,7 +184123,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -182451,7 +184148,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13112, + context: p16910, freeVariables: Identifiers{ "aux", "la", @@ -182481,7 +184178,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "a", "aux", @@ -182505,7 +184202,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "i", "la", @@ -182525,7 +184222,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "i", }, @@ -182547,7 +184244,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "la", }, @@ -182569,7 +184266,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: nil, }, Value: true, @@ -182588,7 +184285,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "a", "aux", @@ -182721,7 +184418,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "a", "i", @@ -182741,7 +184438,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "a", }, @@ -182762,7 +184459,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "i", }, @@ -182785,7 +184482,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "b", "i", @@ -182805,7 +184502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "b", }, @@ -182826,7 +184523,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "i", }, @@ -182856,7 +184553,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: nil, }, Value: false, @@ -182875,7 +184572,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "a", "aux", @@ -182897,7 +184594,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13116, + context: p16914, freeVariables: Identifiers{ "aux", }, @@ -182920,7 +184617,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13156, + context: p16954, freeVariables: Identifiers{ "a", }, @@ -182941,7 +184638,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13156, + context: p16954, freeVariables: Identifiers{ "b", }, @@ -182962,7 +184659,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13156, + context: p16954, freeVariables: Identifiers{ "i", }, @@ -182981,7 +184678,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13156, + context: p16954, freeVariables: Identifiers{ "i", }, @@ -183003,7 +184700,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13156, + context: p16954, freeVariables: nil, }, Value: float64(1), @@ -183036,7 +184733,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "aux", @@ -183057,7 +184754,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "aux", }, @@ -183080,7 +184777,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13171, + context: p16969, freeVariables: Identifiers{ "a", }, @@ -183101,7 +184798,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13171, + context: p16969, freeVariables: Identifiers{ "b", }, @@ -183122,7 +184819,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13171, + context: p16969, freeVariables: nil, }, Value: float64(0), @@ -183151,7 +184848,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -183173,7 +184870,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", "ta", @@ -183193,7 +184890,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -183212,7 +184909,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -183258,7 +184955,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13187, + context: p16985, freeVariables: Identifiers{ "ta", }, @@ -183279,7 +184976,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13187, + context: p16985, freeVariables: nil, }, Value: "object", @@ -183306,7 +185003,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -183330,7 +185027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13194, + context: p16992, freeVariables: Identifiers{ "a", "std", @@ -183350,7 +185047,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13194, + context: p16992, freeVariables: Identifiers{ "std", }, @@ -183369,7 +185066,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13194, + context: p16992, freeVariables: Identifiers{ "std", }, @@ -183415,7 +185112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13203, + context: p17001, freeVariables: Identifiers{ "a", }, @@ -183445,7 +185142,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -183470,7 +185167,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13209, + context: p17007, freeVariables: Identifiers{ "fields", "std", @@ -183490,7 +185187,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13209, + context: p17007, freeVariables: Identifiers{ "std", }, @@ -183509,7 +185206,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13209, + context: p17007, freeVariables: Identifiers{ "std", }, @@ -183555,7 +185252,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13218, + context: p17016, freeVariables: Identifiers{ "fields", }, @@ -183585,7 +185282,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -183716,7 +185413,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "fields", }, @@ -183737,7 +185434,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "b", "std", @@ -183757,7 +185454,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -183776,7 +185473,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -183822,7 +185519,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13243, + context: p17041, freeVariables: Identifiers{ "b", }, @@ -183856,7 +185553,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: nil, }, Value: false, @@ -183875,7 +185572,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -183901,7 +185598,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13250, + context: p17048, freeVariables: Identifiers{ "aux", "fields", @@ -183932,7 +185629,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "a", "aux", @@ -183957,7 +185654,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "i", "lfields", @@ -183977,7 +185674,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "i", }, @@ -183999,7 +185696,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "lfields", }, @@ -184021,7 +185718,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: nil, }, Value: true, @@ -184040,7 +185737,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "a", "aux", @@ -184064,7 +185761,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "a", "b", @@ -184090,7 +185787,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13269, + context: p17067, freeVariables: Identifiers{ "fields", "i", @@ -184110,7 +185807,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13269, + context: p17067, freeVariables: Identifiers{ "fields", }, @@ -184131,7 +185828,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13269, + context: p17067, freeVariables: Identifiers{ "i", }, @@ -184267,7 +185964,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "a", "f", @@ -184287,7 +185984,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "a", }, @@ -184308,7 +186005,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "f", }, @@ -184331,7 +186028,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "b", "f", @@ -184351,7 +186048,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "b", }, @@ -184372,7 +186069,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "f", }, @@ -184403,7 +186100,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: nil, }, Value: false, @@ -184422,7 +186119,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "a", "aux", @@ -184444,7 +186141,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13254, + context: p17052, freeVariables: Identifiers{ "aux", }, @@ -184467,7 +186164,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13304, + context: p17102, freeVariables: Identifiers{ "a", }, @@ -184488,7 +186185,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13304, + context: p17102, freeVariables: Identifiers{ "b", }, @@ -184509,7 +186206,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13304, + context: p17102, freeVariables: Identifiers{ "i", }, @@ -184528,7 +186225,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13304, + context: p17102, freeVariables: Identifiers{ "i", }, @@ -184550,7 +186247,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13304, + context: p17102, freeVariables: nil, }, Value: float64(1), @@ -184583,7 +186280,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "aux", @@ -184604,7 +186301,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "aux", }, @@ -184627,7 +186324,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13319, + context: p17117, freeVariables: Identifiers{ "a", }, @@ -184648,7 +186345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13319, + context: p17117, freeVariables: Identifiers{ "b", }, @@ -184669,7 +186366,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13319, + context: p17117, freeVariables: nil, }, Value: float64(0), @@ -184699,7 +186396,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "a", "b", @@ -184720,7 +186417,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -184739,7 +186436,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13004, + context: p16802, freeVariables: Identifiers{ "std", }, @@ -184785,7 +186482,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13333, + context: p17131, freeVariables: Identifiers{ "a", }, @@ -184806,7 +186503,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13333, + context: p17131, freeVariables: Identifiers{ "b", }, @@ -184885,7 +186582,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17139, freeVariables: nil, }, }, @@ -184907,7 +186604,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17141, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -185149,7 +186846,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17165, freeVariables: Identifiers{ "base64_table", "i", @@ -185173,7 +186870,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17169, freeVariables: Identifiers{ "base64_table", "i", @@ -185193,7 +186890,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17172, freeVariables: Identifiers{ "base64_table", }, @@ -185214,7 +186911,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17175, freeVariables: Identifiers{ "i", }, @@ -185237,7 +186934,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p17178, freeVariables: Identifiers{ "i", }, @@ -185266,7 +186963,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17181, freeVariables: Identifiers{ "std", }, @@ -185285,7 +186982,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17184, freeVariables: Identifiers{ "std", }, @@ -185304,7 +187001,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17187, freeVariables: Identifiers{ "std", }, @@ -185350,7 +187047,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p17192, freeVariables: nil, }, Value: float64(0), @@ -185370,14 +187067,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p17194, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -185433,7 +187130,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "std", }, @@ -185460,7 +187157,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13343, + context: p17200, freeVariables: Identifiers{ "f", "r", @@ -185484,7 +187181,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13347, + context: p17204, freeVariables: Identifiers{ "f", "std", @@ -185504,7 +187201,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13347, + context: p17204, freeVariables: Identifiers{ "std", }, @@ -185523,7 +187220,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13347, + context: p17204, freeVariables: Identifiers{ "std", }, @@ -185569,7 +187266,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13356, + context: p17213, freeVariables: Identifiers{ "f", }, @@ -185590,7 +187287,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13356, + context: p17213, freeVariables: nil, }, Value: "/", @@ -185620,7 +187317,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13343, + context: p17200, freeVariables: Identifiers{ "arr", "r", @@ -185641,7 +187338,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13343, + context: p17200, freeVariables: Identifiers{ "std", }, @@ -185660,7 +187357,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13343, + context: p17200, freeVariables: Identifiers{ "std", }, @@ -185706,7 +187403,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13368, + context: p17225, freeVariables: nil, }, Value: "/", @@ -185727,7 +187424,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13368, + context: p17225, freeVariables: Identifiers{ "arr", "r", @@ -185748,7 +187445,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13368, + context: p17225, freeVariables: Identifiers{ "arr", "std", @@ -185768,7 +187465,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13368, + context: p17225, freeVariables: Identifiers{ "std", }, @@ -185787,7 +187484,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13368, + context: p17225, freeVariables: Identifiers{ "std", }, @@ -185833,7 +187530,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13380, + context: p17237, freeVariables: Identifiers{ "arr", "std", @@ -185853,7 +187550,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13380, + context: p17237, freeVariables: Identifiers{ "arr", "std", @@ -185873,7 +187570,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13380, + context: p17237, freeVariables: Identifiers{ "std", }, @@ -185892,7 +187589,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13380, + context: p17237, freeVariables: Identifiers{ "std", }, @@ -185938,7 +187635,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13391, + context: p17248, freeVariables: Identifiers{ "arr", }, @@ -185966,7 +187663,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13380, + context: p17237, freeVariables: nil, }, Value: float64(1), @@ -185987,7 +187684,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13380, + context: p17237, freeVariables: Identifiers{ "arr", }, @@ -186013,7 +187710,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13398, + context: p17255, freeVariables: Identifiers{ "arr", "i", @@ -186033,7 +187730,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13398, + context: p17255, freeVariables: Identifiers{ "arr", }, @@ -186054,7 +187751,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13398, + context: p17255, freeVariables: Identifiers{ "i", }, @@ -186085,7 +187782,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13368, + context: p17225, freeVariables: Identifiers{ "r", }, @@ -186105,7 +187802,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13408, + context: p17265, freeVariables: Identifiers{ "r", }, @@ -186184,7 +187881,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17271, freeVariables: nil, }, }, @@ -186206,7 +187903,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17273, freeVariables: nil, }, Value: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", @@ -186448,7 +188145,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17297, freeVariables: Identifiers{ "base64_table", "i", @@ -186472,7 +188169,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17301, freeVariables: Identifiers{ "base64_table", "i", @@ -186492,7 +188189,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17304, freeVariables: Identifiers{ "base64_table", }, @@ -186513,7 +188210,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17307, freeVariables: Identifiers{ "i", }, @@ -186536,7 +188233,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p43, + context: p17310, freeVariables: Identifiers{ "i", }, @@ -186565,7 +188262,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17313, freeVariables: Identifiers{ "std", }, @@ -186584,7 +188281,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17316, freeVariables: Identifiers{ "std", }, @@ -186603,7 +188300,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p9, + context: p17319, freeVariables: Identifiers{ "std", }, @@ -186649,7 +188346,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p17324, freeVariables: nil, }, Value: float64(0), @@ -186669,14 +188366,14 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p54, + context: p17326, freeVariables: nil, }, Value: float64(63), OriginalString: "63", }, }, - Named: nil, + Named: []NamedArgument{}, }, TrailingComma: false, TailStrict: false, @@ -186732,7 +188429,7 @@ var StdAst = &DesugaredObject{ }, file: nil, }, - context: p9, + context: p68, freeVariables: Identifiers{ "$", "std", @@ -186759,7 +188456,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "$", "a", @@ -186783,7 +188480,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13420, + context: p17336, freeVariables: Identifiers{ "std", }, @@ -186809,7 +188506,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "b", "std", @@ -186832,7 +188529,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13428, + context: p17344, freeVariables: Identifiers{ "b", "std", @@ -186852,7 +188549,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13428, + context: p17344, freeVariables: Identifiers{ "std", }, @@ -186871,7 +188568,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13428, + context: p17344, freeVariables: Identifiers{ "std", }, @@ -186917,7 +188614,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13437, + context: p17353, freeVariables: Identifiers{ "b", }, @@ -186947,7 +188644,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "b", "std", @@ -187053,7 +188750,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "b", }, @@ -187074,7 +188771,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: nil, }, }, @@ -187098,7 +188795,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: nil, }, Value: false, @@ -187117,7 +188814,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "b", "std", @@ -187223,7 +188920,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "t", }, @@ -187244,7 +188941,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: nil, }, Value: "array", @@ -187271,7 +188968,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "b", "std", @@ -187291,7 +188988,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "b", "std", @@ -187311,7 +189008,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "std", }, @@ -187330,7 +189027,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "std", }, @@ -187376,7 +189073,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13477, + context: p17393, freeVariables: Identifiers{ "b", }, @@ -187404,7 +189101,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: nil, }, Value: float64(0), @@ -187425,7 +189122,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "b", "std", @@ -187531,7 +189228,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "t", }, @@ -187552,7 +189249,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: nil, }, Value: "object", @@ -187579,7 +189276,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "b", "std", @@ -187599,7 +189296,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "b", "std", @@ -187619,7 +189316,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "std", }, @@ -187638,7 +189335,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: Identifiers{ "std", }, @@ -187684,7 +189381,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13504, + context: p17420, freeVariables: Identifiers{ "b", }, @@ -187712,7 +189409,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: nil, }, Value: float64(0), @@ -187733,7 +189430,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13424, + context: p17340, freeVariables: nil, }, Value: true, @@ -187760,7 +189457,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "$", "a", @@ -187785,7 +189482,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13512, + context: p17428, freeVariables: Identifiers{ "a", "std", @@ -187805,7 +189502,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13512, + context: p17428, freeVariables: Identifiers{ "std", }, @@ -187824,7 +189521,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13512, + context: p17428, freeVariables: Identifiers{ "std", }, @@ -187870,7 +189567,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13521, + context: p17437, freeVariables: Identifiers{ "a", }, @@ -187900,7 +189597,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "$", "a", @@ -188008,7 +189705,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "t", }, @@ -188029,7 +189726,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: nil, }, Value: "array", @@ -188193,7 +189890,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "$", "isContent", @@ -188214,7 +189911,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "isContent", }, @@ -188237,7 +189934,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13555, + context: p17471, freeVariables: Identifiers{ "$", "x", @@ -188257,7 +189954,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13555, + context: p17471, freeVariables: Identifiers{ "$", }, @@ -188276,7 +189973,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13555, + context: p17471, freeVariables: Identifiers{ "$", }, @@ -188322,7 +190019,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13564, + context: p17480, freeVariables: Identifiers{ "x", }, @@ -188376,7 +190073,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13570, + context: p17486, freeVariables: Identifiers{ "std", "x", @@ -188396,7 +190093,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13570, + context: p17486, freeVariables: Identifiers{ "std", }, @@ -188415,7 +190112,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13570, + context: p17486, freeVariables: Identifiers{ "std", }, @@ -188461,7 +190158,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13579, + context: p17495, freeVariables: Identifiers{ "x", }, @@ -188513,7 +190210,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "a", }, @@ -188540,7 +190237,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "$", "a", @@ -188648,7 +190345,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "t", }, @@ -188669,7 +190366,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: nil, }, Value: "object", @@ -188922,7 +190619,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "a", "isContent", @@ -188944,7 +190641,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "isContent", }, @@ -188967,7 +190664,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13624, + context: p17540, freeVariables: Identifiers{ "a", "std", @@ -188988,7 +190685,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13624, + context: p17540, freeVariables: Identifiers{ "std", }, @@ -189007,7 +190704,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13624, + context: p17540, freeVariables: Identifiers{ "std", }, @@ -189053,7 +190750,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13633, + context: p17549, freeVariables: Identifiers{ "a", "x", @@ -189073,7 +190770,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13633, + context: p17549, freeVariables: Identifiers{ "a", }, @@ -189094,7 +190791,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13633, + context: p17549, freeVariables: Identifiers{ "x", }, @@ -189151,7 +190848,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "$", "a", @@ -189176,7 +190873,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "x", }, @@ -189197,7 +190894,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13648, + context: p17564, freeVariables: Identifiers{ "$", "a", @@ -189218,7 +190915,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13648, + context: p17564, freeVariables: Identifiers{ "$", }, @@ -189237,7 +190934,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13648, + context: p17564, freeVariables: Identifiers{ "$", }, @@ -189283,7 +190980,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13657, + context: p17573, freeVariables: Identifiers{ "a", "x", @@ -189303,7 +191000,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13657, + context: p17573, freeVariables: Identifiers{ "a", }, @@ -189324,7 +191021,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13657, + context: p17573, freeVariables: Identifiers{ "x", }, @@ -189382,7 +191079,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "a", "std", @@ -189402,7 +191099,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "std", }, @@ -189421,7 +191118,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "std", }, @@ -189467,7 +191164,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13673, + context: p17589, freeVariables: Identifiers{ "a", }, @@ -189506,7 +191203,7 @@ var StdAst = &DesugaredObject{ }, file: p1, }, - context: p13416, + context: p17332, freeVariables: Identifiers{ "a", }, diff --git a/vendor/github.com/google/go-jsonnet/vm.go b/vendor/github.com/google/go-jsonnet/vm.go index 2bfe0df4c2f..4a254fb3e31 100644 --- a/vendor/github.com/google/go-jsonnet/vm.go +++ b/vendor/github.com/google/go-jsonnet/vm.go @@ -191,5 +191,5 @@ func SnippetToAST(filename string, snippet string) (ast.Node, error) { // Version returns the Jsonnet version number. func Version() string { - return "v0.9.5" + return "v0.10.0" } diff --git a/vendor/github.com/googleapis/gnostic/OpenAPIv2/OpenAPIv2.go b/vendor/github.com/googleapis/gnostic/OpenAPIv2/OpenAPIv2.go index 0e32451a320..5351f36f36c 100644 --- a/vendor/github.com/googleapis/gnostic/OpenAPIv2/OpenAPIv2.go +++ b/vendor/github.com/googleapis/gnostic/OpenAPIv2/OpenAPIv2.go @@ -7106,20 +7106,20 @@ func (m *Any) ToRawInfo() interface{} { func (m *ApiKeySecurity) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.In != "" { - info = append(info, yaml.MapItem{"in", m.In}) + info = append(info, yaml.MapItem{Key: "in", Value: m.In}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7130,14 +7130,14 @@ func (m *ApiKeySecurity) ToRawInfo() interface{} { func (m *BasicAuthenticationSecurity) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7148,24 +7148,24 @@ func (m *BasicAuthenticationSecurity) ToRawInfo() interface{} { func (m *BodyParameter) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.In != "" { - info = append(info, yaml.MapItem{"in", m.In}) + info = append(info, yaml.MapItem{Key: "in", Value: m.In}) } if m.Required != false { - info = append(info, yaml.MapItem{"required", m.Required}) + info = append(info, yaml.MapItem{Key: "required", Value: m.Required}) } if m.Schema != nil { - info = append(info, yaml.MapItem{"schema", m.Schema.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "schema", Value: m.Schema.ToRawInfo()}) } // &{Name:schema Type:Schema StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7176,17 +7176,17 @@ func (m *BodyParameter) ToRawInfo() interface{} { func (m *Contact) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.Url != "" { - info = append(info, yaml.MapItem{"url", m.Url}) + info = append(info, yaml.MapItem{Key: "url", Value: m.Url}) } if m.Email != "" { - info = append(info, yaml.MapItem{"email", m.Email}) + info = append(info, yaml.MapItem{Key: "email", Value: m.Email}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7198,7 +7198,7 @@ func (m *Default) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern: Implicit:false Description:} @@ -7210,7 +7210,7 @@ func (m *Definitions) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedSchema StringEnumValues:[] MapType:Schema Repeated:true Pattern: Implicit:true Description:} @@ -7221,41 +7221,41 @@ func (m *Definitions) ToRawInfo() interface{} { func (m *Document) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Swagger != "" { - info = append(info, yaml.MapItem{"swagger", m.Swagger}) + info = append(info, yaml.MapItem{Key: "swagger", Value: m.Swagger}) } if m.Info != nil { - info = append(info, yaml.MapItem{"info", m.Info.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "info", Value: m.Info.ToRawInfo()}) } // &{Name:info Type:Info StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Host != "" { - info = append(info, yaml.MapItem{"host", m.Host}) + info = append(info, yaml.MapItem{Key: "host", Value: m.Host}) } if m.BasePath != "" { - info = append(info, yaml.MapItem{"basePath", m.BasePath}) + info = append(info, yaml.MapItem{Key: "basePath", Value: m.BasePath}) } if len(m.Schemes) != 0 { - info = append(info, yaml.MapItem{"schemes", m.Schemes}) + info = append(info, yaml.MapItem{Key: "schemes", Value: m.Schemes}) } if len(m.Consumes) != 0 { - info = append(info, yaml.MapItem{"consumes", m.Consumes}) + info = append(info, yaml.MapItem{Key: "consumes", Value: m.Consumes}) } if len(m.Produces) != 0 { - info = append(info, yaml.MapItem{"produces", m.Produces}) + info = append(info, yaml.MapItem{Key: "produces", Value: m.Produces}) } if m.Paths != nil { - info = append(info, yaml.MapItem{"paths", m.Paths.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "paths", Value: m.Paths.ToRawInfo()}) } // &{Name:paths Type:Paths StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Definitions != nil { - info = append(info, yaml.MapItem{"definitions", m.Definitions.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "definitions", Value: m.Definitions.ToRawInfo()}) } // &{Name:definitions Type:Definitions StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Parameters != nil { - info = append(info, yaml.MapItem{"parameters", m.Parameters.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "parameters", Value: m.Parameters.ToRawInfo()}) } // &{Name:parameters Type:ParameterDefinitions StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Responses != nil { - info = append(info, yaml.MapItem{"responses", m.Responses.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "responses", Value: m.Responses.ToRawInfo()}) } // &{Name:responses Type:ResponseDefinitions StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if len(m.Security) != 0 { @@ -7263,11 +7263,11 @@ func (m *Document) ToRawInfo() interface{} { for _, item := range m.Security { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"security", items}) + info = append(info, yaml.MapItem{Key: "security", Value: items}) } // &{Name:security Type:SecurityRequirement StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.SecurityDefinitions != nil { - info = append(info, yaml.MapItem{"securityDefinitions", m.SecurityDefinitions.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "securityDefinitions", Value: m.SecurityDefinitions.ToRawInfo()}) } // &{Name:securityDefinitions Type:SecurityDefinitions StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if len(m.Tags) != 0 { @@ -7275,16 +7275,16 @@ func (m *Document) ToRawInfo() interface{} { for _, item := range m.Tags { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"tags", items}) + info = append(info, yaml.MapItem{Key: "tags", Value: items}) } // &{Name:tags Type:Tag StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.ExternalDocs != nil { - info = append(info, yaml.MapItem{"externalDocs", m.ExternalDocs.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "externalDocs", Value: m.ExternalDocs.ToRawInfo()}) } // &{Name:externalDocs Type:ExternalDocs StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7296,7 +7296,7 @@ func (m *Examples) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern: Implicit:true Description:} @@ -7307,14 +7307,14 @@ func (m *Examples) ToRawInfo() interface{} { func (m *ExternalDocs) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.Url != "" { - info = append(info, yaml.MapItem{"url", m.Url}) + info = append(info, yaml.MapItem{Key: "url", Value: m.Url}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7325,38 +7325,38 @@ func (m *ExternalDocs) ToRawInfo() interface{} { func (m *FileSchema) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Format != "" { - info = append(info, yaml.MapItem{"format", m.Format}) + info = append(info, yaml.MapItem{Key: "format", Value: m.Format}) } if m.Title != "" { - info = append(info, yaml.MapItem{"title", m.Title}) + info = append(info, yaml.MapItem{Key: "title", Value: m.Title}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.Default != nil { - info = append(info, yaml.MapItem{"default", m.Default.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "default", Value: m.Default.ToRawInfo()}) } // &{Name:default Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if len(m.Required) != 0 { - info = append(info, yaml.MapItem{"required", m.Required}) + info = append(info, yaml.MapItem{Key: "required", Value: m.Required}) } if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.ReadOnly != false { - info = append(info, yaml.MapItem{"readOnly", m.ReadOnly}) + info = append(info, yaml.MapItem{Key: "readOnly", Value: m.ReadOnly}) } if m.ExternalDocs != nil { - info = append(info, yaml.MapItem{"externalDocs", m.ExternalDocs.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "externalDocs", Value: m.ExternalDocs.ToRawInfo()}) } // &{Name:externalDocs Type:ExternalDocs StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Example != nil { - info = append(info, yaml.MapItem{"example", m.Example.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "example", Value: m.Example.ToRawInfo()}) } // &{Name:example Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7367,81 +7367,81 @@ func (m *FileSchema) ToRawInfo() interface{} { func (m *FormDataParameterSubSchema) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Required != false { - info = append(info, yaml.MapItem{"required", m.Required}) + info = append(info, yaml.MapItem{Key: "required", Value: m.Required}) } if m.In != "" { - info = append(info, yaml.MapItem{"in", m.In}) + info = append(info, yaml.MapItem{Key: "in", Value: m.In}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.AllowEmptyValue != false { - info = append(info, yaml.MapItem{"allowEmptyValue", m.AllowEmptyValue}) + info = append(info, yaml.MapItem{Key: "allowEmptyValue", Value: m.AllowEmptyValue}) } if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Format != "" { - info = append(info, yaml.MapItem{"format", m.Format}) + info = append(info, yaml.MapItem{Key: "format", Value: m.Format}) } if m.Items != nil { - info = append(info, yaml.MapItem{"items", m.Items.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "items", Value: m.Items.ToRawInfo()}) } // &{Name:items Type:PrimitivesItems StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.CollectionFormat != "" { - info = append(info, yaml.MapItem{"collectionFormat", m.CollectionFormat}) + info = append(info, yaml.MapItem{Key: "collectionFormat", Value: m.CollectionFormat}) } if m.Default != nil { - info = append(info, yaml.MapItem{"default", m.Default.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "default", Value: m.Default.ToRawInfo()}) } // &{Name:default Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Maximum != 0.0 { - info = append(info, yaml.MapItem{"maximum", m.Maximum}) + info = append(info, yaml.MapItem{Key: "maximum", Value: m.Maximum}) } if m.ExclusiveMaximum != false { - info = append(info, yaml.MapItem{"exclusiveMaximum", m.ExclusiveMaximum}) + info = append(info, yaml.MapItem{Key: "exclusiveMaximum", Value: m.ExclusiveMaximum}) } if m.Minimum != 0.0 { - info = append(info, yaml.MapItem{"minimum", m.Minimum}) + info = append(info, yaml.MapItem{Key: "minimum", Value: m.Minimum}) } if m.ExclusiveMinimum != false { - info = append(info, yaml.MapItem{"exclusiveMinimum", m.ExclusiveMinimum}) + info = append(info, yaml.MapItem{Key: "exclusiveMinimum", Value: m.ExclusiveMinimum}) } if m.MaxLength != 0 { - info = append(info, yaml.MapItem{"maxLength", m.MaxLength}) + info = append(info, yaml.MapItem{Key: "maxLength", Value: m.MaxLength}) } if m.MinLength != 0 { - info = append(info, yaml.MapItem{"minLength", m.MinLength}) + info = append(info, yaml.MapItem{Key: "minLength", Value: m.MinLength}) } if m.Pattern != "" { - info = append(info, yaml.MapItem{"pattern", m.Pattern}) + info = append(info, yaml.MapItem{Key: "pattern", Value: m.Pattern}) } if m.MaxItems != 0 { - info = append(info, yaml.MapItem{"maxItems", m.MaxItems}) + info = append(info, yaml.MapItem{Key: "maxItems", Value: m.MaxItems}) } if m.MinItems != 0 { - info = append(info, yaml.MapItem{"minItems", m.MinItems}) + info = append(info, yaml.MapItem{Key: "minItems", Value: m.MinItems}) } if m.UniqueItems != false { - info = append(info, yaml.MapItem{"uniqueItems", m.UniqueItems}) + info = append(info, yaml.MapItem{Key: "uniqueItems", Value: m.UniqueItems}) } if len(m.Enum) != 0 { items := make([]interface{}, 0) for _, item := range m.Enum { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"enum", items}) + info = append(info, yaml.MapItem{Key: "enum", Value: items}) } // &{Name:enum Type:Any StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.MultipleOf != 0.0 { - info = append(info, yaml.MapItem{"multipleOf", m.MultipleOf}) + info = append(info, yaml.MapItem{Key: "multipleOf", Value: m.MultipleOf}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7452,69 +7452,69 @@ func (m *FormDataParameterSubSchema) ToRawInfo() interface{} { func (m *Header) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Format != "" { - info = append(info, yaml.MapItem{"format", m.Format}) + info = append(info, yaml.MapItem{Key: "format", Value: m.Format}) } if m.Items != nil { - info = append(info, yaml.MapItem{"items", m.Items.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "items", Value: m.Items.ToRawInfo()}) } // &{Name:items Type:PrimitivesItems StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.CollectionFormat != "" { - info = append(info, yaml.MapItem{"collectionFormat", m.CollectionFormat}) + info = append(info, yaml.MapItem{Key: "collectionFormat", Value: m.CollectionFormat}) } if m.Default != nil { - info = append(info, yaml.MapItem{"default", m.Default.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "default", Value: m.Default.ToRawInfo()}) } // &{Name:default Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Maximum != 0.0 { - info = append(info, yaml.MapItem{"maximum", m.Maximum}) + info = append(info, yaml.MapItem{Key: "maximum", Value: m.Maximum}) } if m.ExclusiveMaximum != false { - info = append(info, yaml.MapItem{"exclusiveMaximum", m.ExclusiveMaximum}) + info = append(info, yaml.MapItem{Key: "exclusiveMaximum", Value: m.ExclusiveMaximum}) } if m.Minimum != 0.0 { - info = append(info, yaml.MapItem{"minimum", m.Minimum}) + info = append(info, yaml.MapItem{Key: "minimum", Value: m.Minimum}) } if m.ExclusiveMinimum != false { - info = append(info, yaml.MapItem{"exclusiveMinimum", m.ExclusiveMinimum}) + info = append(info, yaml.MapItem{Key: "exclusiveMinimum", Value: m.ExclusiveMinimum}) } if m.MaxLength != 0 { - info = append(info, yaml.MapItem{"maxLength", m.MaxLength}) + info = append(info, yaml.MapItem{Key: "maxLength", Value: m.MaxLength}) } if m.MinLength != 0 { - info = append(info, yaml.MapItem{"minLength", m.MinLength}) + info = append(info, yaml.MapItem{Key: "minLength", Value: m.MinLength}) } if m.Pattern != "" { - info = append(info, yaml.MapItem{"pattern", m.Pattern}) + info = append(info, yaml.MapItem{Key: "pattern", Value: m.Pattern}) } if m.MaxItems != 0 { - info = append(info, yaml.MapItem{"maxItems", m.MaxItems}) + info = append(info, yaml.MapItem{Key: "maxItems", Value: m.MaxItems}) } if m.MinItems != 0 { - info = append(info, yaml.MapItem{"minItems", m.MinItems}) + info = append(info, yaml.MapItem{Key: "minItems", Value: m.MinItems}) } if m.UniqueItems != false { - info = append(info, yaml.MapItem{"uniqueItems", m.UniqueItems}) + info = append(info, yaml.MapItem{Key: "uniqueItems", Value: m.UniqueItems}) } if len(m.Enum) != 0 { items := make([]interface{}, 0) for _, item := range m.Enum { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"enum", items}) + info = append(info, yaml.MapItem{Key: "enum", Value: items}) } // &{Name:enum Type:Any StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.MultipleOf != 0.0 { - info = append(info, yaml.MapItem{"multipleOf", m.MultipleOf}) + info = append(info, yaml.MapItem{Key: "multipleOf", Value: m.MultipleOf}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7525,78 +7525,78 @@ func (m *Header) ToRawInfo() interface{} { func (m *HeaderParameterSubSchema) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Required != false { - info = append(info, yaml.MapItem{"required", m.Required}) + info = append(info, yaml.MapItem{Key: "required", Value: m.Required}) } if m.In != "" { - info = append(info, yaml.MapItem{"in", m.In}) + info = append(info, yaml.MapItem{Key: "in", Value: m.In}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Format != "" { - info = append(info, yaml.MapItem{"format", m.Format}) + info = append(info, yaml.MapItem{Key: "format", Value: m.Format}) } if m.Items != nil { - info = append(info, yaml.MapItem{"items", m.Items.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "items", Value: m.Items.ToRawInfo()}) } // &{Name:items Type:PrimitivesItems StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.CollectionFormat != "" { - info = append(info, yaml.MapItem{"collectionFormat", m.CollectionFormat}) + info = append(info, yaml.MapItem{Key: "collectionFormat", Value: m.CollectionFormat}) } if m.Default != nil { - info = append(info, yaml.MapItem{"default", m.Default.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "default", Value: m.Default.ToRawInfo()}) } // &{Name:default Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Maximum != 0.0 { - info = append(info, yaml.MapItem{"maximum", m.Maximum}) + info = append(info, yaml.MapItem{Key: "maximum", Value: m.Maximum}) } if m.ExclusiveMaximum != false { - info = append(info, yaml.MapItem{"exclusiveMaximum", m.ExclusiveMaximum}) + info = append(info, yaml.MapItem{Key: "exclusiveMaximum", Value: m.ExclusiveMaximum}) } if m.Minimum != 0.0 { - info = append(info, yaml.MapItem{"minimum", m.Minimum}) + info = append(info, yaml.MapItem{Key: "minimum", Value: m.Minimum}) } if m.ExclusiveMinimum != false { - info = append(info, yaml.MapItem{"exclusiveMinimum", m.ExclusiveMinimum}) + info = append(info, yaml.MapItem{Key: "exclusiveMinimum", Value: m.ExclusiveMinimum}) } if m.MaxLength != 0 { - info = append(info, yaml.MapItem{"maxLength", m.MaxLength}) + info = append(info, yaml.MapItem{Key: "maxLength", Value: m.MaxLength}) } if m.MinLength != 0 { - info = append(info, yaml.MapItem{"minLength", m.MinLength}) + info = append(info, yaml.MapItem{Key: "minLength", Value: m.MinLength}) } if m.Pattern != "" { - info = append(info, yaml.MapItem{"pattern", m.Pattern}) + info = append(info, yaml.MapItem{Key: "pattern", Value: m.Pattern}) } if m.MaxItems != 0 { - info = append(info, yaml.MapItem{"maxItems", m.MaxItems}) + info = append(info, yaml.MapItem{Key: "maxItems", Value: m.MaxItems}) } if m.MinItems != 0 { - info = append(info, yaml.MapItem{"minItems", m.MinItems}) + info = append(info, yaml.MapItem{Key: "minItems", Value: m.MinItems}) } if m.UniqueItems != false { - info = append(info, yaml.MapItem{"uniqueItems", m.UniqueItems}) + info = append(info, yaml.MapItem{Key: "uniqueItems", Value: m.UniqueItems}) } if len(m.Enum) != 0 { items := make([]interface{}, 0) for _, item := range m.Enum { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"enum", items}) + info = append(info, yaml.MapItem{Key: "enum", Value: items}) } // &{Name:enum Type:Any StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.MultipleOf != 0.0 { - info = append(info, yaml.MapItem{"multipleOf", m.MultipleOf}) + info = append(info, yaml.MapItem{Key: "multipleOf", Value: m.MultipleOf}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7608,7 +7608,7 @@ func (m *Headers) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedHeader StringEnumValues:[] MapType:Header Repeated:true Pattern: Implicit:true Description:} @@ -7619,28 +7619,28 @@ func (m *Headers) ToRawInfo() interface{} { func (m *Info) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Title != "" { - info = append(info, yaml.MapItem{"title", m.Title}) + info = append(info, yaml.MapItem{Key: "title", Value: m.Title}) } if m.Version != "" { - info = append(info, yaml.MapItem{"version", m.Version}) + info = append(info, yaml.MapItem{Key: "version", Value: m.Version}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.TermsOfService != "" { - info = append(info, yaml.MapItem{"termsOfService", m.TermsOfService}) + info = append(info, yaml.MapItem{Key: "termsOfService", Value: m.TermsOfService}) } if m.Contact != nil { - info = append(info, yaml.MapItem{"contact", m.Contact.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "contact", Value: m.Contact.ToRawInfo()}) } // &{Name:contact Type:Contact StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.License != nil { - info = append(info, yaml.MapItem{"license", m.License.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "license", Value: m.License.ToRawInfo()}) } // &{Name:license Type:License StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7655,7 +7655,7 @@ func (m *ItemsItem) ToRawInfo() interface{} { for _, item := range m.Schema { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"schema", items}) + info = append(info, yaml.MapItem{Key: "schema", Value: items}) } // &{Name:schema Type:Schema StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} return info @@ -7665,10 +7665,10 @@ func (m *ItemsItem) ToRawInfo() interface{} { func (m *JsonReference) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.XRef != "" { - info = append(info, yaml.MapItem{"$ref", m.XRef}) + info = append(info, yaml.MapItem{Key: "$ref", Value: m.XRef}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } return info } @@ -7677,14 +7677,14 @@ func (m *JsonReference) ToRawInfo() interface{} { func (m *License) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.Url != "" { - info = append(info, yaml.MapItem{"url", m.Url}) + info = append(info, yaml.MapItem{Key: "url", Value: m.Url}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7695,7 +7695,7 @@ func (m *License) ToRawInfo() interface{} { func (m *NamedAny) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } // &{Name:value Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:Mapped value} return info @@ -7705,7 +7705,7 @@ func (m *NamedAny) ToRawInfo() interface{} { func (m *NamedHeader) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } // &{Name:value Type:Header StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:Mapped value} return info @@ -7715,7 +7715,7 @@ func (m *NamedHeader) ToRawInfo() interface{} { func (m *NamedParameter) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } // &{Name:value Type:Parameter StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:Mapped value} return info @@ -7725,7 +7725,7 @@ func (m *NamedParameter) ToRawInfo() interface{} { func (m *NamedPathItem) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } // &{Name:value Type:PathItem StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:Mapped value} return info @@ -7735,7 +7735,7 @@ func (m *NamedPathItem) ToRawInfo() interface{} { func (m *NamedResponse) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } // &{Name:value Type:Response StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:Mapped value} return info @@ -7745,7 +7745,7 @@ func (m *NamedResponse) ToRawInfo() interface{} { func (m *NamedResponseValue) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } // &{Name:value Type:ResponseValue StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:Mapped value} return info @@ -7755,7 +7755,7 @@ func (m *NamedResponseValue) ToRawInfo() interface{} { func (m *NamedSchema) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } // &{Name:value Type:Schema StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:Mapped value} return info @@ -7765,7 +7765,7 @@ func (m *NamedSchema) ToRawInfo() interface{} { func (m *NamedSecurityDefinitionsItem) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } // &{Name:value Type:SecurityDefinitionsItem StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:Mapped value} return info @@ -7775,10 +7775,10 @@ func (m *NamedSecurityDefinitionsItem) ToRawInfo() interface{} { func (m *NamedString) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.Value != "" { - info = append(info, yaml.MapItem{"value", m.Value}) + info = append(info, yaml.MapItem{Key: "value", Value: m.Value}) } return info } @@ -7787,7 +7787,7 @@ func (m *NamedString) ToRawInfo() interface{} { func (m *NamedStringArray) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } // &{Name:value Type:StringArray StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:Mapped value} return info @@ -7824,27 +7824,27 @@ func (m *NonBodyParameter) ToRawInfo() interface{} { func (m *Oauth2AccessCodeSecurity) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Flow != "" { - info = append(info, yaml.MapItem{"flow", m.Flow}) + info = append(info, yaml.MapItem{Key: "flow", Value: m.Flow}) } if m.Scopes != nil { - info = append(info, yaml.MapItem{"scopes", m.Scopes.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "scopes", Value: m.Scopes.ToRawInfo()}) } // &{Name:scopes Type:Oauth2Scopes StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.AuthorizationUrl != "" { - info = append(info, yaml.MapItem{"authorizationUrl", m.AuthorizationUrl}) + info = append(info, yaml.MapItem{Key: "authorizationUrl", Value: m.AuthorizationUrl}) } if m.TokenUrl != "" { - info = append(info, yaml.MapItem{"tokenUrl", m.TokenUrl}) + info = append(info, yaml.MapItem{Key: "tokenUrl", Value: m.TokenUrl}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7855,24 +7855,24 @@ func (m *Oauth2AccessCodeSecurity) ToRawInfo() interface{} { func (m *Oauth2ApplicationSecurity) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Flow != "" { - info = append(info, yaml.MapItem{"flow", m.Flow}) + info = append(info, yaml.MapItem{Key: "flow", Value: m.Flow}) } if m.Scopes != nil { - info = append(info, yaml.MapItem{"scopes", m.Scopes.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "scopes", Value: m.Scopes.ToRawInfo()}) } // &{Name:scopes Type:Oauth2Scopes StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.TokenUrl != "" { - info = append(info, yaml.MapItem{"tokenUrl", m.TokenUrl}) + info = append(info, yaml.MapItem{Key: "tokenUrl", Value: m.TokenUrl}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7883,24 +7883,24 @@ func (m *Oauth2ApplicationSecurity) ToRawInfo() interface{} { func (m *Oauth2ImplicitSecurity) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Flow != "" { - info = append(info, yaml.MapItem{"flow", m.Flow}) + info = append(info, yaml.MapItem{Key: "flow", Value: m.Flow}) } if m.Scopes != nil { - info = append(info, yaml.MapItem{"scopes", m.Scopes.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "scopes", Value: m.Scopes.ToRawInfo()}) } // &{Name:scopes Type:Oauth2Scopes StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.AuthorizationUrl != "" { - info = append(info, yaml.MapItem{"authorizationUrl", m.AuthorizationUrl}) + info = append(info, yaml.MapItem{Key: "authorizationUrl", Value: m.AuthorizationUrl}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7911,24 +7911,24 @@ func (m *Oauth2ImplicitSecurity) ToRawInfo() interface{} { func (m *Oauth2PasswordSecurity) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Flow != "" { - info = append(info, yaml.MapItem{"flow", m.Flow}) + info = append(info, yaml.MapItem{Key: "flow", Value: m.Flow}) } if m.Scopes != nil { - info = append(info, yaml.MapItem{"scopes", m.Scopes.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "scopes", Value: m.Scopes.ToRawInfo()}) } // &{Name:scopes Type:Oauth2Scopes StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.TokenUrl != "" { - info = append(info, yaml.MapItem{"tokenUrl", m.TokenUrl}) + info = append(info, yaml.MapItem{Key: "tokenUrl", Value: m.TokenUrl}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -7946,56 +7946,56 @@ func (m *Oauth2Scopes) ToRawInfo() interface{} { func (m *Operation) ToRawInfo() interface{} { info := yaml.MapSlice{} if len(m.Tags) != 0 { - info = append(info, yaml.MapItem{"tags", m.Tags}) + info = append(info, yaml.MapItem{Key: "tags", Value: m.Tags}) } if m.Summary != "" { - info = append(info, yaml.MapItem{"summary", m.Summary}) + info = append(info, yaml.MapItem{Key: "summary", Value: m.Summary}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.ExternalDocs != nil { - info = append(info, yaml.MapItem{"externalDocs", m.ExternalDocs.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "externalDocs", Value: m.ExternalDocs.ToRawInfo()}) } // &{Name:externalDocs Type:ExternalDocs StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.OperationId != "" { - info = append(info, yaml.MapItem{"operationId", m.OperationId}) + info = append(info, yaml.MapItem{Key: "operationId", Value: m.OperationId}) } if len(m.Produces) != 0 { - info = append(info, yaml.MapItem{"produces", m.Produces}) + info = append(info, yaml.MapItem{Key: "produces", Value: m.Produces}) } if len(m.Consumes) != 0 { - info = append(info, yaml.MapItem{"consumes", m.Consumes}) + info = append(info, yaml.MapItem{Key: "consumes", Value: m.Consumes}) } if len(m.Parameters) != 0 { items := make([]interface{}, 0) for _, item := range m.Parameters { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"parameters", items}) + info = append(info, yaml.MapItem{Key: "parameters", Value: items}) } // &{Name:parameters Type:ParametersItem StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:The parameters needed to send a valid API call.} if m.Responses != nil { - info = append(info, yaml.MapItem{"responses", m.Responses.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "responses", Value: m.Responses.ToRawInfo()}) } // &{Name:responses Type:Responses StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if len(m.Schemes) != 0 { - info = append(info, yaml.MapItem{"schemes", m.Schemes}) + info = append(info, yaml.MapItem{Key: "schemes", Value: m.Schemes}) } if m.Deprecated != false { - info = append(info, yaml.MapItem{"deprecated", m.Deprecated}) + info = append(info, yaml.MapItem{Key: "deprecated", Value: m.Deprecated}) } if len(m.Security) != 0 { items := make([]interface{}, 0) for _, item := range m.Security { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"security", items}) + info = append(info, yaml.MapItem{Key: "security", Value: items}) } // &{Name:security Type:SecurityRequirement StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -8024,7 +8024,7 @@ func (m *ParameterDefinitions) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedParameter StringEnumValues:[] MapType:Parameter Repeated:true Pattern: Implicit:true Description:} @@ -8052,34 +8052,34 @@ func (m *ParametersItem) ToRawInfo() interface{} { func (m *PathItem) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.XRef != "" { - info = append(info, yaml.MapItem{"$ref", m.XRef}) + info = append(info, yaml.MapItem{Key: "$ref", Value: m.XRef}) } if m.Get != nil { - info = append(info, yaml.MapItem{"get", m.Get.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "get", Value: m.Get.ToRawInfo()}) } // &{Name:get Type:Operation StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Put != nil { - info = append(info, yaml.MapItem{"put", m.Put.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "put", Value: m.Put.ToRawInfo()}) } // &{Name:put Type:Operation StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Post != nil { - info = append(info, yaml.MapItem{"post", m.Post.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "post", Value: m.Post.ToRawInfo()}) } // &{Name:post Type:Operation StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Delete != nil { - info = append(info, yaml.MapItem{"delete", m.Delete.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "delete", Value: m.Delete.ToRawInfo()}) } // &{Name:delete Type:Operation StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Options != nil { - info = append(info, yaml.MapItem{"options", m.Options.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "options", Value: m.Options.ToRawInfo()}) } // &{Name:options Type:Operation StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Head != nil { - info = append(info, yaml.MapItem{"head", m.Head.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "head", Value: m.Head.ToRawInfo()}) } // &{Name:head Type:Operation StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Patch != nil { - info = append(info, yaml.MapItem{"patch", m.Patch.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "patch", Value: m.Patch.ToRawInfo()}) } // &{Name:patch Type:Operation StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if len(m.Parameters) != 0 { @@ -8087,12 +8087,12 @@ func (m *PathItem) ToRawInfo() interface{} { for _, item := range m.Parameters { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"parameters", items}) + info = append(info, yaml.MapItem{Key: "parameters", Value: items}) } // &{Name:parameters Type:ParametersItem StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:The parameters needed to send a valid API call.} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -8103,78 +8103,78 @@ func (m *PathItem) ToRawInfo() interface{} { func (m *PathParameterSubSchema) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Required != false { - info = append(info, yaml.MapItem{"required", m.Required}) + info = append(info, yaml.MapItem{Key: "required", Value: m.Required}) } if m.In != "" { - info = append(info, yaml.MapItem{"in", m.In}) + info = append(info, yaml.MapItem{Key: "in", Value: m.In}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Format != "" { - info = append(info, yaml.MapItem{"format", m.Format}) + info = append(info, yaml.MapItem{Key: "format", Value: m.Format}) } if m.Items != nil { - info = append(info, yaml.MapItem{"items", m.Items.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "items", Value: m.Items.ToRawInfo()}) } // &{Name:items Type:PrimitivesItems StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.CollectionFormat != "" { - info = append(info, yaml.MapItem{"collectionFormat", m.CollectionFormat}) + info = append(info, yaml.MapItem{Key: "collectionFormat", Value: m.CollectionFormat}) } if m.Default != nil { - info = append(info, yaml.MapItem{"default", m.Default.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "default", Value: m.Default.ToRawInfo()}) } // &{Name:default Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Maximum != 0.0 { - info = append(info, yaml.MapItem{"maximum", m.Maximum}) + info = append(info, yaml.MapItem{Key: "maximum", Value: m.Maximum}) } if m.ExclusiveMaximum != false { - info = append(info, yaml.MapItem{"exclusiveMaximum", m.ExclusiveMaximum}) + info = append(info, yaml.MapItem{Key: "exclusiveMaximum", Value: m.ExclusiveMaximum}) } if m.Minimum != 0.0 { - info = append(info, yaml.MapItem{"minimum", m.Minimum}) + info = append(info, yaml.MapItem{Key: "minimum", Value: m.Minimum}) } if m.ExclusiveMinimum != false { - info = append(info, yaml.MapItem{"exclusiveMinimum", m.ExclusiveMinimum}) + info = append(info, yaml.MapItem{Key: "exclusiveMinimum", Value: m.ExclusiveMinimum}) } if m.MaxLength != 0 { - info = append(info, yaml.MapItem{"maxLength", m.MaxLength}) + info = append(info, yaml.MapItem{Key: "maxLength", Value: m.MaxLength}) } if m.MinLength != 0 { - info = append(info, yaml.MapItem{"minLength", m.MinLength}) + info = append(info, yaml.MapItem{Key: "minLength", Value: m.MinLength}) } if m.Pattern != "" { - info = append(info, yaml.MapItem{"pattern", m.Pattern}) + info = append(info, yaml.MapItem{Key: "pattern", Value: m.Pattern}) } if m.MaxItems != 0 { - info = append(info, yaml.MapItem{"maxItems", m.MaxItems}) + info = append(info, yaml.MapItem{Key: "maxItems", Value: m.MaxItems}) } if m.MinItems != 0 { - info = append(info, yaml.MapItem{"minItems", m.MinItems}) + info = append(info, yaml.MapItem{Key: "minItems", Value: m.MinItems}) } if m.UniqueItems != false { - info = append(info, yaml.MapItem{"uniqueItems", m.UniqueItems}) + info = append(info, yaml.MapItem{Key: "uniqueItems", Value: m.UniqueItems}) } if len(m.Enum) != 0 { items := make([]interface{}, 0) for _, item := range m.Enum { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"enum", items}) + info = append(info, yaml.MapItem{Key: "enum", Value: items}) } // &{Name:enum Type:Any StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.MultipleOf != 0.0 { - info = append(info, yaml.MapItem{"multipleOf", m.MultipleOf}) + info = append(info, yaml.MapItem{Key: "multipleOf", Value: m.MultipleOf}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -8186,13 +8186,13 @@ func (m *Paths) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} if m.Path != nil { for _, item := range m.Path { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:Path Type:NamedPathItem StringEnumValues:[] MapType:PathItem Repeated:true Pattern:^/ Implicit:true Description:} @@ -8203,66 +8203,66 @@ func (m *Paths) ToRawInfo() interface{} { func (m *PrimitivesItems) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Format != "" { - info = append(info, yaml.MapItem{"format", m.Format}) + info = append(info, yaml.MapItem{Key: "format", Value: m.Format}) } if m.Items != nil { - info = append(info, yaml.MapItem{"items", m.Items.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "items", Value: m.Items.ToRawInfo()}) } // &{Name:items Type:PrimitivesItems StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.CollectionFormat != "" { - info = append(info, yaml.MapItem{"collectionFormat", m.CollectionFormat}) + info = append(info, yaml.MapItem{Key: "collectionFormat", Value: m.CollectionFormat}) } if m.Default != nil { - info = append(info, yaml.MapItem{"default", m.Default.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "default", Value: m.Default.ToRawInfo()}) } // &{Name:default Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Maximum != 0.0 { - info = append(info, yaml.MapItem{"maximum", m.Maximum}) + info = append(info, yaml.MapItem{Key: "maximum", Value: m.Maximum}) } if m.ExclusiveMaximum != false { - info = append(info, yaml.MapItem{"exclusiveMaximum", m.ExclusiveMaximum}) + info = append(info, yaml.MapItem{Key: "exclusiveMaximum", Value: m.ExclusiveMaximum}) } if m.Minimum != 0.0 { - info = append(info, yaml.MapItem{"minimum", m.Minimum}) + info = append(info, yaml.MapItem{Key: "minimum", Value: m.Minimum}) } if m.ExclusiveMinimum != false { - info = append(info, yaml.MapItem{"exclusiveMinimum", m.ExclusiveMinimum}) + info = append(info, yaml.MapItem{Key: "exclusiveMinimum", Value: m.ExclusiveMinimum}) } if m.MaxLength != 0 { - info = append(info, yaml.MapItem{"maxLength", m.MaxLength}) + info = append(info, yaml.MapItem{Key: "maxLength", Value: m.MaxLength}) } if m.MinLength != 0 { - info = append(info, yaml.MapItem{"minLength", m.MinLength}) + info = append(info, yaml.MapItem{Key: "minLength", Value: m.MinLength}) } if m.Pattern != "" { - info = append(info, yaml.MapItem{"pattern", m.Pattern}) + info = append(info, yaml.MapItem{Key: "pattern", Value: m.Pattern}) } if m.MaxItems != 0 { - info = append(info, yaml.MapItem{"maxItems", m.MaxItems}) + info = append(info, yaml.MapItem{Key: "maxItems", Value: m.MaxItems}) } if m.MinItems != 0 { - info = append(info, yaml.MapItem{"minItems", m.MinItems}) + info = append(info, yaml.MapItem{Key: "minItems", Value: m.MinItems}) } if m.UniqueItems != false { - info = append(info, yaml.MapItem{"uniqueItems", m.UniqueItems}) + info = append(info, yaml.MapItem{Key: "uniqueItems", Value: m.UniqueItems}) } if len(m.Enum) != 0 { items := make([]interface{}, 0) for _, item := range m.Enum { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"enum", items}) + info = append(info, yaml.MapItem{Key: "enum", Value: items}) } // &{Name:enum Type:Any StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.MultipleOf != 0.0 { - info = append(info, yaml.MapItem{"multipleOf", m.MultipleOf}) + info = append(info, yaml.MapItem{Key: "multipleOf", Value: m.MultipleOf}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -8274,7 +8274,7 @@ func (m *Properties) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedSchema StringEnumValues:[] MapType:Schema Repeated:true Pattern: Implicit:true Description:} @@ -8285,81 +8285,81 @@ func (m *Properties) ToRawInfo() interface{} { func (m *QueryParameterSubSchema) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Required != false { - info = append(info, yaml.MapItem{"required", m.Required}) + info = append(info, yaml.MapItem{Key: "required", Value: m.Required}) } if m.In != "" { - info = append(info, yaml.MapItem{"in", m.In}) + info = append(info, yaml.MapItem{Key: "in", Value: m.In}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.AllowEmptyValue != false { - info = append(info, yaml.MapItem{"allowEmptyValue", m.AllowEmptyValue}) + info = append(info, yaml.MapItem{Key: "allowEmptyValue", Value: m.AllowEmptyValue}) } if m.Type != "" { - info = append(info, yaml.MapItem{"type", m.Type}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type}) } if m.Format != "" { - info = append(info, yaml.MapItem{"format", m.Format}) + info = append(info, yaml.MapItem{Key: "format", Value: m.Format}) } if m.Items != nil { - info = append(info, yaml.MapItem{"items", m.Items.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "items", Value: m.Items.ToRawInfo()}) } // &{Name:items Type:PrimitivesItems StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.CollectionFormat != "" { - info = append(info, yaml.MapItem{"collectionFormat", m.CollectionFormat}) + info = append(info, yaml.MapItem{Key: "collectionFormat", Value: m.CollectionFormat}) } if m.Default != nil { - info = append(info, yaml.MapItem{"default", m.Default.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "default", Value: m.Default.ToRawInfo()}) } // &{Name:default Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Maximum != 0.0 { - info = append(info, yaml.MapItem{"maximum", m.Maximum}) + info = append(info, yaml.MapItem{Key: "maximum", Value: m.Maximum}) } if m.ExclusiveMaximum != false { - info = append(info, yaml.MapItem{"exclusiveMaximum", m.ExclusiveMaximum}) + info = append(info, yaml.MapItem{Key: "exclusiveMaximum", Value: m.ExclusiveMaximum}) } if m.Minimum != 0.0 { - info = append(info, yaml.MapItem{"minimum", m.Minimum}) + info = append(info, yaml.MapItem{Key: "minimum", Value: m.Minimum}) } if m.ExclusiveMinimum != false { - info = append(info, yaml.MapItem{"exclusiveMinimum", m.ExclusiveMinimum}) + info = append(info, yaml.MapItem{Key: "exclusiveMinimum", Value: m.ExclusiveMinimum}) } if m.MaxLength != 0 { - info = append(info, yaml.MapItem{"maxLength", m.MaxLength}) + info = append(info, yaml.MapItem{Key: "maxLength", Value: m.MaxLength}) } if m.MinLength != 0 { - info = append(info, yaml.MapItem{"minLength", m.MinLength}) + info = append(info, yaml.MapItem{Key: "minLength", Value: m.MinLength}) } if m.Pattern != "" { - info = append(info, yaml.MapItem{"pattern", m.Pattern}) + info = append(info, yaml.MapItem{Key: "pattern", Value: m.Pattern}) } if m.MaxItems != 0 { - info = append(info, yaml.MapItem{"maxItems", m.MaxItems}) + info = append(info, yaml.MapItem{Key: "maxItems", Value: m.MaxItems}) } if m.MinItems != 0 { - info = append(info, yaml.MapItem{"minItems", m.MinItems}) + info = append(info, yaml.MapItem{Key: "minItems", Value: m.MinItems}) } if m.UniqueItems != false { - info = append(info, yaml.MapItem{"uniqueItems", m.UniqueItems}) + info = append(info, yaml.MapItem{Key: "uniqueItems", Value: m.UniqueItems}) } if len(m.Enum) != 0 { items := make([]interface{}, 0) for _, item := range m.Enum { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"enum", items}) + info = append(info, yaml.MapItem{Key: "enum", Value: items}) } // &{Name:enum Type:Any StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.MultipleOf != 0.0 { - info = append(info, yaml.MapItem{"multipleOf", m.MultipleOf}) + info = append(info, yaml.MapItem{Key: "multipleOf", Value: m.MultipleOf}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -8370,23 +8370,23 @@ func (m *QueryParameterSubSchema) ToRawInfo() interface{} { func (m *Response) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.Schema != nil { - info = append(info, yaml.MapItem{"schema", m.Schema.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "schema", Value: m.Schema.ToRawInfo()}) } // &{Name:schema Type:SchemaItem StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Headers != nil { - info = append(info, yaml.MapItem{"headers", m.Headers.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "headers", Value: m.Headers.ToRawInfo()}) } // &{Name:headers Type:Headers StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Examples != nil { - info = append(info, yaml.MapItem{"examples", m.Examples.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "examples", Value: m.Examples.ToRawInfo()}) } // &{Name:examples Type:Examples StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -8398,7 +8398,7 @@ func (m *ResponseDefinitions) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedResponse StringEnumValues:[] MapType:Response Repeated:true Pattern: Implicit:true Description:} @@ -8427,13 +8427,13 @@ func (m *Responses) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.ResponseCode != nil { for _, item := range m.ResponseCode { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:ResponseCode Type:NamedResponseValue StringEnumValues:[] MapType:ResponseValue Repeated:true Pattern:^([0-9]{3})$|^(default)$ Implicit:true Description:} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -8444,80 +8444,80 @@ func (m *Responses) ToRawInfo() interface{} { func (m *Schema) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.XRef != "" { - info = append(info, yaml.MapItem{"$ref", m.XRef}) + info = append(info, yaml.MapItem{Key: "$ref", Value: m.XRef}) } if m.Format != "" { - info = append(info, yaml.MapItem{"format", m.Format}) + info = append(info, yaml.MapItem{Key: "format", Value: m.Format}) } if m.Title != "" { - info = append(info, yaml.MapItem{"title", m.Title}) + info = append(info, yaml.MapItem{Key: "title", Value: m.Title}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.Default != nil { - info = append(info, yaml.MapItem{"default", m.Default.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "default", Value: m.Default.ToRawInfo()}) } // &{Name:default Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.MultipleOf != 0.0 { - info = append(info, yaml.MapItem{"multipleOf", m.MultipleOf}) + info = append(info, yaml.MapItem{Key: "multipleOf", Value: m.MultipleOf}) } if m.Maximum != 0.0 { - info = append(info, yaml.MapItem{"maximum", m.Maximum}) + info = append(info, yaml.MapItem{Key: "maximum", Value: m.Maximum}) } if m.ExclusiveMaximum != false { - info = append(info, yaml.MapItem{"exclusiveMaximum", m.ExclusiveMaximum}) + info = append(info, yaml.MapItem{Key: "exclusiveMaximum", Value: m.ExclusiveMaximum}) } if m.Minimum != 0.0 { - info = append(info, yaml.MapItem{"minimum", m.Minimum}) + info = append(info, yaml.MapItem{Key: "minimum", Value: m.Minimum}) } if m.ExclusiveMinimum != false { - info = append(info, yaml.MapItem{"exclusiveMinimum", m.ExclusiveMinimum}) + info = append(info, yaml.MapItem{Key: "exclusiveMinimum", Value: m.ExclusiveMinimum}) } if m.MaxLength != 0 { - info = append(info, yaml.MapItem{"maxLength", m.MaxLength}) + info = append(info, yaml.MapItem{Key: "maxLength", Value: m.MaxLength}) } if m.MinLength != 0 { - info = append(info, yaml.MapItem{"minLength", m.MinLength}) + info = append(info, yaml.MapItem{Key: "minLength", Value: m.MinLength}) } if m.Pattern != "" { - info = append(info, yaml.MapItem{"pattern", m.Pattern}) + info = append(info, yaml.MapItem{Key: "pattern", Value: m.Pattern}) } if m.MaxItems != 0 { - info = append(info, yaml.MapItem{"maxItems", m.MaxItems}) + info = append(info, yaml.MapItem{Key: "maxItems", Value: m.MaxItems}) } if m.MinItems != 0 { - info = append(info, yaml.MapItem{"minItems", m.MinItems}) + info = append(info, yaml.MapItem{Key: "minItems", Value: m.MinItems}) } if m.UniqueItems != false { - info = append(info, yaml.MapItem{"uniqueItems", m.UniqueItems}) + info = append(info, yaml.MapItem{Key: "uniqueItems", Value: m.UniqueItems}) } if m.MaxProperties != 0 { - info = append(info, yaml.MapItem{"maxProperties", m.MaxProperties}) + info = append(info, yaml.MapItem{Key: "maxProperties", Value: m.MaxProperties}) } if m.MinProperties != 0 { - info = append(info, yaml.MapItem{"minProperties", m.MinProperties}) + info = append(info, yaml.MapItem{Key: "minProperties", Value: m.MinProperties}) } if len(m.Required) != 0 { - info = append(info, yaml.MapItem{"required", m.Required}) + info = append(info, yaml.MapItem{Key: "required", Value: m.Required}) } if len(m.Enum) != 0 { items := make([]interface{}, 0) for _, item := range m.Enum { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"enum", items}) + info = append(info, yaml.MapItem{Key: "enum", Value: items}) } // &{Name:enum Type:Any StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.AdditionalProperties != nil { - info = append(info, yaml.MapItem{"additionalProperties", m.AdditionalProperties.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "additionalProperties", Value: m.AdditionalProperties.ToRawInfo()}) } // &{Name:additionalProperties Type:AdditionalPropertiesItem StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Type != nil { if len(m.Type.Value) == 1 { - info = append(info, yaml.MapItem{"type", m.Type.Value[0]}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type.Value[0]}) } else { - info = append(info, yaml.MapItem{"type", m.Type.Value}) + info = append(info, yaml.MapItem{Key: "type", Value: m.Type.Value}) } } // &{Name:type Type:TypeItem StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} @@ -8526,7 +8526,7 @@ func (m *Schema) ToRawInfo() interface{} { for _, item := range m.Items.Schema { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"items", items[0]}) + info = append(info, yaml.MapItem{Key: "items", Value: items[0]}) } // &{Name:items Type:ItemsItem StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if len(m.AllOf) != 0 { @@ -8534,34 +8534,34 @@ func (m *Schema) ToRawInfo() interface{} { for _, item := range m.AllOf { items = append(items, item.ToRawInfo()) } - info = append(info, yaml.MapItem{"allOf", items}) + info = append(info, yaml.MapItem{Key: "allOf", Value: items}) } // &{Name:allOf Type:Schema StringEnumValues:[] MapType: Repeated:true Pattern: Implicit:false Description:} if m.Properties != nil { - info = append(info, yaml.MapItem{"properties", m.Properties.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "properties", Value: m.Properties.ToRawInfo()}) } // &{Name:properties Type:Properties StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Discriminator != "" { - info = append(info, yaml.MapItem{"discriminator", m.Discriminator}) + info = append(info, yaml.MapItem{Key: "discriminator", Value: m.Discriminator}) } if m.ReadOnly != false { - info = append(info, yaml.MapItem{"readOnly", m.ReadOnly}) + info = append(info, yaml.MapItem{Key: "readOnly", Value: m.ReadOnly}) } if m.Xml != nil { - info = append(info, yaml.MapItem{"xml", m.Xml.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "xml", Value: m.Xml.ToRawInfo()}) } // &{Name:xml Type:Xml StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.ExternalDocs != nil { - info = append(info, yaml.MapItem{"externalDocs", m.ExternalDocs.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "externalDocs", Value: m.ExternalDocs.ToRawInfo()}) } // &{Name:externalDocs Type:ExternalDocs StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.Example != nil { - info = append(info, yaml.MapItem{"example", m.Example.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "example", Value: m.Example.ToRawInfo()}) } // &{Name:example Type:Any StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -8590,7 +8590,7 @@ func (m *SecurityDefinitions) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedSecurityDefinitionsItem StringEnumValues:[] MapType:SecurityDefinitionsItem Repeated:true Pattern: Implicit:true Description:} @@ -8639,7 +8639,7 @@ func (m *SecurityRequirement) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedStringArray StringEnumValues:[] MapType:StringArray Repeated:true Pattern: Implicit:true Description:} @@ -8655,18 +8655,18 @@ func (m *StringArray) ToRawInfo() interface{} { func (m *Tag) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.Description != "" { - info = append(info, yaml.MapItem{"description", m.Description}) + info = append(info, yaml.MapItem{Key: "description", Value: m.Description}) } if m.ExternalDocs != nil { - info = append(info, yaml.MapItem{"externalDocs", m.ExternalDocs.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: "externalDocs", Value: m.ExternalDocs.ToRawInfo()}) } // &{Name:externalDocs Type:ExternalDocs StringEnumValues:[] MapType: Repeated:false Pattern: Implicit:false Description:} if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} @@ -8677,7 +8677,7 @@ func (m *Tag) ToRawInfo() interface{} { func (m *TypeItem) ToRawInfo() interface{} { info := yaml.MapSlice{} if len(m.Value) != 0 { - info = append(info, yaml.MapItem{"value", m.Value}) + info = append(info, yaml.MapItem{Key: "value", Value: m.Value}) } return info } @@ -8687,7 +8687,7 @@ func (m *VendorExtension) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.AdditionalProperties != nil { for _, item := range m.AdditionalProperties { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:additionalProperties Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern: Implicit:true Description:} @@ -8698,23 +8698,23 @@ func (m *VendorExtension) ToRawInfo() interface{} { func (m *Xml) ToRawInfo() interface{} { info := yaml.MapSlice{} if m.Name != "" { - info = append(info, yaml.MapItem{"name", m.Name}) + info = append(info, yaml.MapItem{Key: "name", Value: m.Name}) } if m.Namespace != "" { - info = append(info, yaml.MapItem{"namespace", m.Namespace}) + info = append(info, yaml.MapItem{Key: "namespace", Value: m.Namespace}) } if m.Prefix != "" { - info = append(info, yaml.MapItem{"prefix", m.Prefix}) + info = append(info, yaml.MapItem{Key: "prefix", Value: m.Prefix}) } if m.Attribute != false { - info = append(info, yaml.MapItem{"attribute", m.Attribute}) + info = append(info, yaml.MapItem{Key: "attribute", Value: m.Attribute}) } if m.Wrapped != false { - info = append(info, yaml.MapItem{"wrapped", m.Wrapped}) + info = append(info, yaml.MapItem{Key: "wrapped", Value: m.Wrapped}) } if m.VendorExtension != nil { for _, item := range m.VendorExtension { - info = append(info, yaml.MapItem{item.Name, item.Value.ToRawInfo()}) + info = append(info, yaml.MapItem{Key: item.Name, Value: item.Value.ToRawInfo()}) } } // &{Name:VendorExtension Type:NamedAny StringEnumValues:[] MapType:Any Repeated:true Pattern:^x- Implicit:true Description:} diff --git a/vendor/github.com/googleapis/gnostic/OpenAPIv2/OpenAPIv2.pb.go b/vendor/github.com/googleapis/gnostic/OpenAPIv2/OpenAPIv2.pb.go index 37da7df256f..a030fa67653 100644 --- a/vendor/github.com/googleapis/gnostic/OpenAPIv2/OpenAPIv2.pb.go +++ b/vendor/github.com/googleapis/gnostic/OpenAPIv2/OpenAPIv2.pb.go @@ -1,6 +1,5 @@ -// Code generated by protoc-gen-go. +// Code generated by protoc-gen-go. DO NOT EDIT. // source: OpenAPIv2/OpenAPIv2.proto -// DO NOT EDIT! /* Package openapi_v2 is a generated protocol buffer package. @@ -4257,7 +4256,7 @@ func init() { proto.RegisterFile("OpenAPIv2/OpenAPIv2.proto", fileDescriptor0) } var fileDescriptor0 = []byte{ // 3129 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xec, 0x3b, 0x4b, 0x73, 0x1c, 0x57, + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x3b, 0x4b, 0x73, 0x1c, 0x57, 0xd5, 0xf3, 0x7e, 0x1c, 0x69, 0x46, 0xa3, 0x96, 0x2c, 0xb7, 0x24, 0xc7, 0x71, 0xe4, 0x3c, 0x6c, 0xe7, 0xb3, 0x9c, 0x4f, 0x29, 0x48, 0x05, 0x2a, 0x05, 0xf2, 0xab, 0xc6, 0xc4, 0x44, 0x4a, 0xcb, 0x0e, 0x09, 0x04, 0xba, 0xae, 0x66, 0xee, 0x48, 0x9d, 0x74, 0xf7, 0x6d, 0x77, 0xf7, 0xc8, 0x1a, diff --git a/vendor/github.com/googleapis/gnostic/compiler/reader.go b/vendor/github.com/googleapis/gnostic/compiler/reader.go index 2d4b3303db4..c954a2d9b24 100644 --- a/vendor/github.com/googleapis/gnostic/compiler/reader.go +++ b/vendor/github.com/googleapis/gnostic/compiler/reader.go @@ -110,7 +110,9 @@ func ReadInfoFromBytes(filename string, bytes []byte) (interface{}, error) { if err != nil { return nil, err } - infoCache[filename] = info + if len(filename) > 0 { + infoCache[filename] = info + } return info, nil } diff --git a/vendor/github.com/googleapis/gnostic/extensions/extension.pb.go b/vendor/github.com/googleapis/gnostic/extensions/extension.pb.go index 7c6b9149673..749ff784166 100644 --- a/vendor/github.com/googleapis/gnostic/extensions/extension.pb.go +++ b/vendor/github.com/googleapis/gnostic/extensions/extension.pb.go @@ -1,6 +1,5 @@ -// Code generated by protoc-gen-go. +// Code generated by protoc-gen-go. DO NOT EDIT. // source: extension.proto -// DO NOT EDIT! /* Package openapiextension_v1 is a generated protocol buffer package. @@ -78,7 +77,7 @@ func (m *Version) GetSuffix() string { // An encoded Request is written to the ExtensionHandler's stdin. type ExtensionHandlerRequest struct { // The OpenAPI descriptions that were explicitly listed on the command line. - // The specifications will appear in the order they are specified to openapic. + // The specifications will appear in the order they are specified to gnostic. Wrapper *Wrapper `protobuf:"bytes,1,opt,name=wrapper" json:"wrapper,omitempty"` // The version number of openapi compiler. CompilerVersion *Version `protobuf:"bytes,3,opt,name=compiler_version,json=compilerVersion" json:"compiler_version,omitempty"` @@ -192,28 +191,28 @@ func init() { func init() { proto.RegisterFile("extension.proto", fileDescriptor0) } var fileDescriptor0 = []byte{ - // 355 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x74, 0x91, 0x4d, 0x4b, 0xf3, 0x40, - 0x1c, 0xc4, 0x49, 0xdf, 0xf2, 0x64, 0x1f, 0xb4, 0xb2, 0x16, 0x8d, 0xe2, 0xa1, 0x04, 0x84, 0x22, - 0xb8, 0xa5, 0x0a, 0xde, 0x5b, 0x28, 0xea, 0xc5, 0x96, 0x3d, 0xd4, 0x9b, 0x65, 0x9b, 0xfe, 0xdb, - 0x46, 0x92, 0xdd, 0x75, 0xf3, 0x62, 0xfb, 0x55, 0x3c, 0xfa, 0x49, 0x25, 0xbb, 0xd9, 0x7a, 0x50, - 0x6f, 0x99, 0x1f, 0x93, 0xfc, 0x67, 0x26, 0xa8, 0x0d, 0xdb, 0x0c, 0x78, 0x1a, 0x09, 0x4e, 0xa4, - 0x12, 0x99, 0xc0, 0xc7, 0x42, 0x02, 0x67, 0x32, 0xfa, 0xe6, 0xc5, 0xe0, 0xfc, 0x6c, 0x2d, 0xc4, - 0x3a, 0x86, 0xbe, 0xb6, 0x2c, 0xf2, 0x55, 0x9f, 0xf1, 0x9d, 0xf1, 0x07, 0x21, 0x72, 0x67, 0xa0, - 0x4a, 0x23, 0xee, 0xa0, 0x66, 0xc2, 0x5e, 0x85, 0xf2, 0x9d, 0xae, 0xd3, 0x6b, 0x52, 0x23, 0x34, - 0x8d, 0xb8, 0x50, 0x7e, 0xad, 0xa2, 0xa5, 0x28, 0xa9, 0x64, 0x59, 0xb8, 0xf1, 0xeb, 0x86, 0x6a, - 0x81, 0x4f, 0x50, 0x2b, 0xcd, 0x57, 0xab, 0x68, 0xeb, 0x37, 0xba, 0x4e, 0xcf, 0xa3, 0x95, 0x0a, - 0x3e, 0x1c, 0x74, 0x3a, 0xb6, 0x81, 0x1e, 0x18, 0x5f, 0xc6, 0xa0, 0x28, 0xbc, 0xe5, 0x90, 0x66, - 0xf8, 0x0e, 0xb9, 0xef, 0x8a, 0x49, 0x09, 0xe6, 0xee, 0xff, 0x9b, 0x0b, 0xf2, 0x4b, 0x05, 0xf2, - 0x6c, 0x3c, 0xd4, 0x9a, 0xf1, 0x3d, 0x3a, 0x0a, 0x45, 0x22, 0xa3, 0x18, 0xd4, 0xbc, 0x30, 0x0d, - 0x74, 0x98, 0xbf, 0x3e, 0x50, 0xb5, 0xa4, 0x6d, 0xfb, 0x56, 0x05, 0x82, 0x02, 0xf9, 0x3f, 0xb3, - 0xa5, 0x52, 0xf0, 0x14, 0xb0, 0x8f, 0xdc, 0x8d, 0x46, 0x4b, 0x1d, 0xee, 0x1f, 0xb5, 0xb2, 0x1c, - 0x00, 0x94, 0xd2, 0xb3, 0xd4, 0x7b, 0x1e, 0x35, 0x02, 0x5f, 0xa1, 0x66, 0xc1, 0xe2, 0x1c, 0xaa, - 0x24, 0x1d, 0x62, 0x86, 0x27, 0x76, 0x78, 0x32, 0xe4, 0x3b, 0x6a, 0x2c, 0xc1, 0x0b, 0x72, 0xab, - 0x52, 0xe5, 0x19, 0x5b, 0xc1, 0xd1, 0xc3, 0x59, 0x89, 0x2f, 0xd1, 0xe1, 0xbe, 0xc5, 0x9c, 0xb3, - 0x04, 0xf4, 0x6f, 0xf0, 0xe8, 0xc1, 0x9e, 0x3e, 0xb1, 0x04, 0x30, 0x46, 0x8d, 0x1d, 0x4b, 0x62, - 0x7d, 0xd6, 0xa3, 0xfa, 0x79, 0x74, 0x8d, 0xda, 0x42, 0xad, 0xed, 0x16, 0x21, 0x29, 0x06, 0x23, - 0x3c, 0x91, 0xc0, 0x87, 0xd3, 0xc7, 0x7d, 0xdf, 0xd9, 0x60, 0xea, 0x7c, 0xd6, 0xea, 0x93, 0xe1, - 0x78, 0xd1, 0xd2, 0x19, 0x6f, 0xbf, 0x02, 0x00, 0x00, 0xff, 0xff, 0xfc, 0x56, 0x40, 0x4d, 0x52, - 0x02, 0x00, 0x00, + // 357 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x74, 0x91, 0x4d, 0x4b, 0xc3, 0x40, + 0x18, 0x84, 0x49, 0xbf, 0x62, 0x56, 0x6c, 0x65, 0x2d, 0x1a, 0xc5, 0x43, 0x09, 0x08, 0x45, 0x64, + 0x4b, 0x15, 0xbc, 0xb7, 0x50, 0xd4, 0x8b, 0x2d, 0x7b, 0xa8, 0x37, 0xcb, 0x36, 0x7d, 0x9b, 0x46, + 0x92, 0xdd, 0x75, 0xf3, 0x61, 0xfb, 0x57, 0x3c, 0xfa, 0x4b, 0x25, 0xbb, 0x49, 0x3d, 0xa8, 0xb7, + 0xcc, 0xc3, 0x24, 0xef, 0xcc, 0x04, 0x75, 0x60, 0x9b, 0x02, 0x4f, 0x42, 0xc1, 0x89, 0x54, 0x22, + 0x15, 0xf8, 0x44, 0x48, 0xe0, 0x4c, 0x86, 0x3f, 0x3c, 0x1f, 0x5e, 0x9c, 0x07, 0x42, 0x04, 0x11, + 0x0c, 0xb4, 0x65, 0x99, 0xad, 0x07, 0x8c, 0xef, 0x8c, 0xdf, 0xf3, 0x91, 0x3d, 0x07, 0x55, 0x18, + 0x71, 0x17, 0x35, 0x63, 0xf6, 0x26, 0x94, 0x6b, 0xf5, 0xac, 0x7e, 0x93, 0x1a, 0xa1, 0x69, 0xc8, + 0x85, 0x72, 0x6b, 0x25, 0x2d, 0x44, 0x41, 0x25, 0x4b, 0xfd, 0x8d, 0x5b, 0x37, 0x54, 0x0b, 0x7c, + 0x8a, 0x5a, 0x49, 0xb6, 0x5e, 0x87, 0x5b, 0xb7, 0xd1, 0xb3, 0xfa, 0x0e, 0x2d, 0x95, 0xf7, 0x69, + 0xa1, 0xb3, 0x49, 0x15, 0xe8, 0x91, 0xf1, 0x55, 0x04, 0x8a, 0xc2, 0x7b, 0x06, 0x49, 0x8a, 0xef, + 0x91, 0xfd, 0xa1, 0x98, 0x94, 0x60, 0xee, 0x1e, 0xde, 0x5e, 0x92, 0x3f, 0x2a, 0x90, 0x17, 0xe3, + 0xa1, 0x95, 0x19, 0x3f, 0xa0, 0x63, 0x5f, 0xc4, 0x32, 0x8c, 0x40, 0x2d, 0x72, 0xd3, 0x40, 0x87, + 0xf9, 0xef, 0x03, 0x65, 0x4b, 0xda, 0xa9, 0xde, 0x2a, 0x81, 0x97, 0x23, 0xf7, 0x77, 0xb6, 0x44, + 0x0a, 0x9e, 0x00, 0x76, 0x91, 0xbd, 0xd1, 0x68, 0xa5, 0xc3, 0x1d, 0xd0, 0x4a, 0x16, 0x03, 0x80, + 0x52, 0x7a, 0x96, 0x7a, 0xdf, 0xa1, 0x46, 0xe0, 0x6b, 0xd4, 0xcc, 0x59, 0x94, 0x41, 0x99, 0xa4, + 0x4b, 0xcc, 0xf0, 0xa4, 0x1a, 0x9e, 0x8c, 0xf8, 0x8e, 0x1a, 0x8b, 0xf7, 0x8a, 0xec, 0xb2, 0x54, + 0x71, 0xa6, 0xaa, 0x60, 0xe9, 0xe1, 0x2a, 0x89, 0xaf, 0x50, 0x7b, 0xdf, 0x62, 0xc1, 0x59, 0x0c, + 0xfa, 0x37, 0x38, 0xf4, 0x68, 0x4f, 0x9f, 0x59, 0x0c, 0x18, 0xa3, 0xc6, 0x8e, 0xc5, 0x91, 0x3e, + 0xeb, 0x50, 0xfd, 0x3c, 0xbe, 0x41, 0x6d, 0xa1, 0x02, 0x12, 0x70, 0x91, 0xa4, 0xa1, 0x4f, 0xf2, + 0xe1, 0x18, 0x4f, 0x25, 0xf0, 0xd1, 0xec, 0x69, 0x5f, 0x77, 0x3e, 0x9c, 0x59, 0x5f, 0xb5, 0xfa, + 0x74, 0x34, 0x59, 0xb6, 0x74, 0xc4, 0xbb, 0xef, 0x00, 0x00, 0x00, 0xff, 0xff, 0x84, 0x5c, 0x6b, + 0x80, 0x51, 0x02, 0x00, 0x00, } diff --git a/vendor/github.com/googleapis/gnostic/extensions/extension.proto b/vendor/github.com/googleapis/gnostic/extensions/extension.proto index 806760a1329..04856f913b1 100644 --- a/vendor/github.com/googleapis/gnostic/extensions/extension.proto +++ b/vendor/github.com/googleapis/gnostic/extensions/extension.proto @@ -29,7 +29,7 @@ option java_multiple_files = true; option java_outer_classname = "OpenAPIExtensionV1"; // The Java package name must be proto package name with proper prefix. -option java_package = "org.openapic.v1"; +option java_package = "org.gnostic.v1"; // A reasonable prefix for the Objective-C symbols generated from the package. // It should at a minimum be 3 characters long, all uppercase, and convention @@ -53,7 +53,7 @@ message Version { message ExtensionHandlerRequest { // The OpenAPI descriptions that were explicitly listed on the command line. - // The specifications will appear in the order they are specified to openapic. + // The specifications will appear in the order they are specified to gnostic. Wrapper wrapper = 1; // The version number of openapi compiler. diff --git a/vendor/github.com/gophercloud/gophercloud/.gitignore b/vendor/github.com/gophercloud/gophercloud/.gitignore index df9048a010a..dd91ed20559 100644 --- a/vendor/github.com/gophercloud/gophercloud/.gitignore +++ b/vendor/github.com/gophercloud/gophercloud/.gitignore @@ -1,2 +1,3 @@ **/*.swp .idea +.vscode diff --git a/vendor/github.com/gophercloud/gophercloud/.travis.yml b/vendor/github.com/gophercloud/gophercloud/.travis.yml index 59c41949527..02728f49682 100644 --- a/vendor/github.com/gophercloud/gophercloud/.travis.yml +++ b/vendor/github.com/gophercloud/gophercloud/.travis.yml @@ -7,8 +7,8 @@ install: - go get github.com/mattn/goveralls - go get golang.org/x/tools/cmd/goimports go: -- 1.8 -- tip +- "1.10" +- "tip" env: global: - secure: "xSQsAG5wlL9emjbCdxzz/hYQsSpJ/bABO1kkbwMSISVcJ3Nk0u4ywF+LS4bgeOnwPfmFvNTOqVDu3RwEvMeWXSI76t1piCPcObutb2faKLVD/hLoAS76gYX+Z8yGWGHrSB7Do5vTPj1ERe2UljdrnsSeOXzoDwFxYRaZLX4bBOB4AyoGvRniil5QXPATiA1tsWX1VMicj8a4F8X+xeESzjt1Q5Iy31e7vkptu71bhvXCaoo5QhYwT+pLR9dN0S1b7Ro0KVvkRefmr1lUOSYd2e74h6Lc34tC1h3uYZCS4h47t7v5cOXvMNxinEj2C51RvbjvZI1RLVdkuAEJD1Iz4+Ote46nXbZ//6XRZMZz/YxQ13l7ux1PFjgEB6HAapmF5Xd8PRsgeTU9LRJxpiTJ3P5QJ3leS1va8qnziM5kYipj/Rn+V8g2ad/rgkRox9LSiR9VYZD2Pe45YCb1mTKSl2aIJnV7nkOqsShY5LNB4JZSg7xIffA+9YVDktw8dJlATjZqt7WvJJ49g6A61mIUV4C15q2JPGKTkZzDiG81NtmS7hFa7k0yaE2ELgYocbcuyUcAahhxntYTC0i23nJmEHVNiZmBO3u7EgpWe4KGVfumU+lt12tIn5b3dZRBBUk3QakKKozSK1QPHGpk/AZGrhu7H6l8to6IICKWtDcyMPQ=" diff --git a/vendor/github.com/gophercloud/gophercloud/.zuul.yaml b/vendor/github.com/gophercloud/gophercloud/.zuul.yaml index c259d03e184..3d4798fe6f8 100644 --- a/vendor/github.com/gophercloud/gophercloud/.zuul.yaml +++ b/vendor/github.com/gophercloud/gophercloud/.zuul.yaml @@ -1,3 +1,58 @@ +- job: + name: gophercloud-unittest + parent: golang-test + description: | + Run gophercloud unit test + run: .zuul/playbooks/gophercloud-unittest/run.yaml + nodeset: ubuntu-xenial-ut + +- job: + name: gophercloud-acceptance-test + parent: golang-test + description: | + Run gophercloud acceptance test on master branch + run: .zuul/playbooks/gophercloud-acceptance-test/run.yaml + +- job: + name: gophercloud-acceptance-test-queens + parent: gophercloud-acceptance-test + description: | + Run gophercloud acceptance test on queens branch + vars: + os_branch: 'stable/queens' + +- job: + name: gophercloud-acceptance-test-pike + parent: gophercloud-acceptance-test + description: | + Run gophercloud acceptance test on pike branch + vars: + os_branch: 'stable/pike' +- job: + name: gophercloud-acceptance-test-ocata + parent: gophercloud-acceptance-test + description: | + Run gophercloud acceptance test on ocata branch + vars: + os_branch: 'stable/ocata' + +- job: + name: gophercloud-acceptance-test-newton + parent: gophercloud-acceptance-test + description: | + Run gophercloud acceptance test on newton branch + vars: + os_branch: 'stable/newton' + +- job: + name: gophercloud-acceptance-test-mitaka + parent: gophercloud-acceptance-test + description: | + Run gophercloud acceptance test on mitaka branch + vars: + os_branch: 'stable/mitaka' + nodeset: ubuntu-trusty + - project: name: gophercloud/gophercloud check: @@ -7,6 +62,15 @@ recheck-mitaka: jobs: - gophercloud-acceptance-test-mitaka + recheck-newton: + jobs: + - gophercloud-acceptance-test-newton + recheck-ocata: + jobs: + - gophercloud-acceptance-test-ocata recheck-pike: jobs: - gophercloud-acceptance-test-pike + recheck-queens: + jobs: + - gophercloud-acceptance-test-queens diff --git a/vendor/github.com/gophercloud/gophercloud/FAQ.md b/vendor/github.com/gophercloud/gophercloud/FAQ.md deleted file mode 100644 index 88a366a288b..00000000000 --- a/vendor/github.com/gophercloud/gophercloud/FAQ.md +++ /dev/null @@ -1,148 +0,0 @@ -# Tips - -## Implementing default logging and re-authentication attempts - -You can implement custom logging and/or limit re-auth attempts by creating a custom HTTP client -like the following and setting it as the provider client's HTTP Client (via the -`gophercloud.ProviderClient.HTTPClient` field): - -```go -//... - -// LogRoundTripper satisfies the http.RoundTripper interface and is used to -// customize the default Gophercloud RoundTripper to allow for logging. -type LogRoundTripper struct { - rt http.RoundTripper - numReauthAttempts int -} - -// newHTTPClient return a custom HTTP client that allows for logging relevant -// information before and after the HTTP request. -func newHTTPClient() http.Client { - return http.Client{ - Transport: &LogRoundTripper{ - rt: http.DefaultTransport, - }, - } -} - -// RoundTrip performs a round-trip HTTP request and logs relevant information about it. -func (lrt *LogRoundTripper) RoundTrip(request *http.Request) (*http.Response, error) { - glog.Infof("Request URL: %s\n", request.URL) - - response, err := lrt.rt.RoundTrip(request) - if response == nil { - return nil, err - } - - if response.StatusCode == http.StatusUnauthorized { - if lrt.numReauthAttempts == 3 { - return response, fmt.Errorf("Tried to re-authenticate 3 times with no success.") - } - lrt.numReauthAttempts++ - } - - glog.Debugf("Response Status: %s\n", response.Status) - - return response, nil -} - -endpoint := "https://127.0.0.1/auth" -pc := openstack.NewClient(endpoint) -pc.HTTPClient = newHTTPClient() - -//... -``` - - -## Implementing custom objects - -OpenStack request/response objects may differ among variable names or types. - -### Custom request objects - -To pass custom options to a request, implement the desired `OptsBuilder` interface. For -example, to pass in - -```go -type MyCreateServerOpts struct { - Name string - Size int -} -``` - -to `servers.Create`, simply implement the `servers.CreateOptsBuilder` interface: - -```go -func (o MyCreateServeropts) ToServerCreateMap() (map[string]interface{}, error) { - return map[string]interface{}{ - "name": o.Name, - "size": o.Size, - }, nil -} -``` - -create an instance of your custom options object, and pass it to `servers.Create`: - -```go -// ... -myOpts := MyCreateServerOpts{ - Name: "s1", - Size: "100", -} -server, err := servers.Create(computeClient, myOpts).Extract() -// ... -``` - -### Custom response objects - -Some OpenStack services have extensions. Extensions that are supported in Gophercloud can be -combined to create a custom object: - -```go -// ... -type MyVolume struct { - volumes.Volume - tenantattr.VolumeExt -} - -var v struct { - MyVolume `json:"volume"` -} - -err := volumes.Get(client, volID).ExtractInto(&v) -// ... -``` - -## Overriding default `UnmarshalJSON` method - -For some response objects, a field may be a custom type or may be allowed to take on -different types. In these cases, overriding the default `UnmarshalJSON` method may be -necessary. To do this, declare the JSON `struct` field tag as "-" and create an `UnmarshalJSON` -method on the type: - -```go -// ... -type MyVolume struct { - ID string `json: "id"` - TimeCreated time.Time `json: "-"` -} - -func (r *MyVolume) UnmarshalJSON(b []byte) error { - type tmp MyVolume - var s struct { - tmp - TimeCreated gophercloud.JSONRFC3339MilliNoZ `json:"created_at"` - } - err := json.Unmarshal(b, &s) - if err != nil { - return err - } - *r = Volume(s.tmp) - - r.TimeCreated = time.Time(s.CreatedAt) - - return err -} -// ... -``` diff --git a/vendor/github.com/gophercloud/gophercloud/MIGRATING.md b/vendor/github.com/gophercloud/gophercloud/MIGRATING.md deleted file mode 100644 index aa383c9cc9e..00000000000 --- a/vendor/github.com/gophercloud/gophercloud/MIGRATING.md +++ /dev/null @@ -1,32 +0,0 @@ -# Compute - -## Floating IPs - -* `github.com/gophercloud/gophercloud/openstack/compute/v2/extensions/floatingip` is now `github.com/gophercloud/gophercloud/openstack/compute/v2/extensions/floatingips` -* `floatingips.Associate` and `floatingips.Disassociate` have been removed. -* `floatingips.DisassociateOpts` is now required to disassociate a Floating IP. - -## Security Groups - -* `secgroups.AddServerToGroup` is now `secgroups.AddServer`. -* `secgroups.RemoveServerFromGroup` is now `secgroups.RemoveServer`. - -## Servers - -* `servers.Reboot` now requires a `servers.RebootOpts` struct: - - ```golang - rebootOpts := &servers.RebootOpts{ - Type: servers.SoftReboot, - } - res := servers.Reboot(client, server.ID, rebootOpts) - ``` - -# Identity - -## V3 - -### Tokens - -* `Token.ExpiresAt` is now of type `gophercloud.JSONRFC3339Milli` instead of - `time.Time` diff --git a/vendor/github.com/gophercloud/gophercloud/README.md b/vendor/github.com/gophercloud/gophercloud/README.md index bb218c3fe9e..8c5bfce796b 100644 --- a/vendor/github.com/gophercloud/gophercloud/README.md +++ b/vendor/github.com/gophercloud/gophercloud/README.md @@ -127,7 +127,7 @@ new resource in the `server` variable (a ## Advanced Usage -Have a look at the [FAQ](./FAQ.md) for some tips on customizing the way Gophercloud works. +Have a look at the [FAQ](./docs/FAQ.md) for some tips on customizing the way Gophercloud works. ## Backwards-Compatibility Guarantees @@ -148,12 +148,12 @@ We'd like to extend special thanks and appreciation to the following: ### OpenLab - + OpenLab is providing a full CI environment to test each PR and merge for a variety of OpenStack releases. ### VEXXHOST - + VEXXHOST is providing their services to assist with the development and testing of Gophercloud. diff --git a/vendor/github.com/gophercloud/gophercloud/STYLEGUIDE.md b/vendor/github.com/gophercloud/gophercloud/STYLEGUIDE.md deleted file mode 100644 index 22a29009412..00000000000 --- a/vendor/github.com/gophercloud/gophercloud/STYLEGUIDE.md +++ /dev/null @@ -1,79 +0,0 @@ - -## On Pull Requests - -- Please make sure to read our [contributing guide](/.github/CONTRIBUTING.md). - -- Before you start a PR there needs to be a Github issue and a discussion about it - on that issue with a core contributor, even if it's just a 'SGTM'. - -- A PR's description must reference the issue it closes with a `For ` (e.g. For #293). - -- A PR's description must contain link(s) to the line(s) in the OpenStack - source code (on Github) that prove(s) the PR code to be valid. Links to documentation - are not good enough. The link(s) should be to a non-`master` branch. For example, - a pull request implementing the creation of a Neutron v2 subnet might put the - following link in the description: - - https://github.com/openstack/neutron/blob/stable/mitaka/neutron/api/v2/attributes.py#L749 - - From that link, a reviewer (or user) can verify the fields in the request/response - objects in the PR. - -- A PR that is in-progress should have `[wip]` in front of the PR's title. When - ready for review, remove the `[wip]` and ping a core contributor with an `@`. - -- Forcing PRs to be small can have the effect of users submitting PRs in a hierarchical chain, with - one depending on the next. If a PR depends on another one, it should have a [Pending #PRNUM] - prefix in the PR title. In addition, it will be the PR submitter's responsibility to remove the - [Pending #PRNUM] tag once the PR has been updated with the merged, dependent PR. That will - let reviewers know it is ready to review. - -- A PR should be small. Even if you intend on implementing an entire - service, a PR should only be one route of that service - (e.g. create server or get server, but not both). - -- Unless explicitly asked, do not squash commits in the middle of a review; only - append. It makes it difficult for the reviewer to see what's changed from one - review to the next. - -- See [#583](https://github.com/gophercloud/gophercloud/issues/583) as an example of a - well-formatted issue which contains all relevant information we need to review and approve. - -## On Code - -- In re design: follow as closely as is reasonable the code already in the library. - Most operations (e.g. create, delete) admit the same design. - -- Unit tests and acceptance (integration) tests must be written to cover each PR. - Tests for operations with several options (e.g. list, create) should include all - the options in the tests. This will allow users to verify an operation on their - own infrastructure and see an example of usage. - -- If in doubt, ask in-line on the PR. - -### File Structure - -- The following should be used in most cases: - - - `requests.go`: contains all the functions that make HTTP requests and the - types associated with the HTTP request (parameters for URL, body, etc) - - `results.go`: contains all the response objects and their methods - - `urls.go`: contains the endpoints to which the requests are made - -### Naming - -- For methods on a type in `results.go`, the receiver should be named `r` and the - variable into which it will be unmarshalled `s`. - -- Functions in `requests.go`, with the exception of functions that return a - `pagination.Pager`, should be named returns of the name `r`. - -- Functions in `requests.go` that accept request bodies should accept as their - last parameter an `interface` named `OptsBuilder` (eg `CreateOptsBuilder`). - This `interface` should have at the least a method named `ToMap` - (eg `ToPortCreateMap`). - -- Functions in `requests.go` that accept query strings should accept as their - last parameter an `interface` named `OptsBuilder` (eg `ListOptsBuilder`). - This `interface` should have at the least a method named `ToQuery` - (eg `ToServerListQuery`). diff --git a/vendor/github.com/gophercloud/gophercloud/auth_options.go b/vendor/github.com/gophercloud/gophercloud/auth_options.go index 4211470020a..5e693585c2d 100644 --- a/vendor/github.com/gophercloud/gophercloud/auth_options.go +++ b/vendor/github.com/gophercloud/gophercloud/auth_options.go @@ -81,6 +81,17 @@ type AuthOptions struct { // TokenID allows users to authenticate (possibly as another user) with an // authentication token ID. TokenID string `json:"-"` + + // Scope determines the scoping of the authentication request. + Scope *AuthScope `json:"-"` +} + +// AuthScope allows a created token to be limited to a specific domain or project. +type AuthScope struct { + ProjectID string + ProjectName string + DomainID string + DomainName string } // ToTokenV2CreateMap allows AuthOptions to satisfy the AuthOptionsBuilder @@ -263,85 +274,83 @@ func (opts *AuthOptions) ToTokenV3CreateMap(scope map[string]interface{}) (map[s } func (opts *AuthOptions) ToTokenV3ScopeMap() (map[string]interface{}, error) { - - var scope struct { - ProjectID string - ProjectName string - DomainID string - DomainName string - } - - if opts.TenantID != "" { - scope.ProjectID = opts.TenantID - } else { - if opts.TenantName != "" { - scope.ProjectName = opts.TenantName - scope.DomainID = opts.DomainID - scope.DomainName = opts.DomainName + // For backwards compatibility. + // If AuthOptions.Scope was not set, try to determine it. + // This works well for common scenarios. + if opts.Scope == nil { + opts.Scope = new(AuthScope) + if opts.TenantID != "" { + opts.Scope.ProjectID = opts.TenantID + } else { + if opts.TenantName != "" { + opts.Scope.ProjectName = opts.TenantName + opts.Scope.DomainID = opts.DomainID + opts.Scope.DomainName = opts.DomainName + } } } - if scope.ProjectName != "" { + if opts.Scope.ProjectName != "" { // ProjectName provided: either DomainID or DomainName must also be supplied. // ProjectID may not be supplied. - if scope.DomainID == "" && scope.DomainName == "" { + if opts.Scope.DomainID == "" && opts.Scope.DomainName == "" { return nil, ErrScopeDomainIDOrDomainName{} } - if scope.ProjectID != "" { + if opts.Scope.ProjectID != "" { return nil, ErrScopeProjectIDOrProjectName{} } - if scope.DomainID != "" { + if opts.Scope.DomainID != "" { // ProjectName + DomainID return map[string]interface{}{ "project": map[string]interface{}{ - "name": &scope.ProjectName, - "domain": map[string]interface{}{"id": &scope.DomainID}, + "name": &opts.Scope.ProjectName, + "domain": map[string]interface{}{"id": &opts.Scope.DomainID}, }, }, nil } - if scope.DomainName != "" { + if opts.Scope.DomainName != "" { // ProjectName + DomainName return map[string]interface{}{ "project": map[string]interface{}{ - "name": &scope.ProjectName, - "domain": map[string]interface{}{"name": &scope.DomainName}, + "name": &opts.Scope.ProjectName, + "domain": map[string]interface{}{"name": &opts.Scope.DomainName}, }, }, nil } - } else if scope.ProjectID != "" { + } else if opts.Scope.ProjectID != "" { // ProjectID provided. ProjectName, DomainID, and DomainName may not be provided. - if scope.DomainID != "" { + if opts.Scope.DomainID != "" { return nil, ErrScopeProjectIDAlone{} } - if scope.DomainName != "" { + if opts.Scope.DomainName != "" { return nil, ErrScopeProjectIDAlone{} } // ProjectID return map[string]interface{}{ "project": map[string]interface{}{ - "id": &scope.ProjectID, + "id": &opts.Scope.ProjectID, }, }, nil - } else if scope.DomainID != "" { + } else if opts.Scope.DomainID != "" { // DomainID provided. ProjectID, ProjectName, and DomainName may not be provided. - if scope.DomainName != "" { + if opts.Scope.DomainName != "" { return nil, ErrScopeDomainIDOrDomainName{} } // DomainID return map[string]interface{}{ "domain": map[string]interface{}{ - "id": &scope.DomainID, + "id": &opts.Scope.DomainID, }, }, nil - } else if scope.DomainName != "" { + } else if opts.Scope.DomainName != "" { // DomainName return map[string]interface{}{ "domain": map[string]interface{}{ - "name": &scope.DomainName, + "name": &opts.Scope.DomainName, }, }, nil } diff --git a/vendor/github.com/gophercloud/gophercloud/errors.go b/vendor/github.com/gophercloud/gophercloud/errors.go index 2466932efe4..a5fa68d6d55 100644 --- a/vendor/github.com/gophercloud/gophercloud/errors.go +++ b/vendor/github.com/gophercloud/gophercloud/errors.go @@ -1,6 +1,9 @@ package gophercloud -import "fmt" +import ( + "fmt" + "strings" +) // BaseError is an error type that all other error types embed. type BaseError struct { @@ -43,6 +46,33 @@ func (e ErrInvalidInput) Error() string { return e.choseErrString() } +// ErrMissingEnvironmentVariable is the error when environment variable is required +// in a particular situation but not provided by the user +type ErrMissingEnvironmentVariable struct { + BaseError + EnvironmentVariable string +} + +func (e ErrMissingEnvironmentVariable) Error() string { + e.DefaultErrString = fmt.Sprintf("Missing environment variable [%s]", e.EnvironmentVariable) + return e.choseErrString() +} + +// ErrMissingAnyoneOfEnvironmentVariables is the error when anyone of the environment variables +// is required in a particular situation but not provided by the user +type ErrMissingAnyoneOfEnvironmentVariables struct { + BaseError + EnvironmentVariables []string +} + +func (e ErrMissingAnyoneOfEnvironmentVariables) Error() string { + e.DefaultErrString = fmt.Sprintf( + "Missing one of the following environment variables [%s]", + strings.Join(e.EnvironmentVariables, ", "), + ) + return e.choseErrString() +} + // ErrUnexpectedResponseCode is returned by the Request method when a response code other than // those listed in OkCodes is encountered. type ErrUnexpectedResponseCode struct { @@ -108,7 +138,11 @@ type ErrDefault503 struct { } func (e ErrDefault400) Error() string { - return "Invalid request due to incorrect syntax or missing required parameters." + e.DefaultErrString = fmt.Sprintf( + "Bad request with: [%s %s], error message: %s", + e.Method, e.URL, e.Body, + ) + return e.choseErrString() } func (e ErrDefault401) Error() string { return "Authentication failed" diff --git a/vendor/github.com/gophercloud/gophercloud/openstack/auth_env.go b/vendor/github.com/gophercloud/gophercloud/openstack/auth_env.go index b5482ba8c9f..994b5550c91 100644 --- a/vendor/github.com/gophercloud/gophercloud/openstack/auth_env.go +++ b/vendor/github.com/gophercloud/gophercloud/openstack/auth_env.go @@ -50,17 +50,23 @@ func AuthOptionsFromEnv() (gophercloud.AuthOptions, error) { } if authURL == "" { - err := gophercloud.ErrMissingInput{Argument: "authURL"} + err := gophercloud.ErrMissingEnvironmentVariable{ + EnvironmentVariable: "OS_AUTH_URL", + } return nilOptions, err } if username == "" && userID == "" { - err := gophercloud.ErrMissingInput{Argument: "username"} + err := gophercloud.ErrMissingAnyoneOfEnvironmentVariables{ + EnvironmentVariables: []string{"OS_USERNAME", "OS_USERID"}, + } return nilOptions, err } if password == "" { - err := gophercloud.ErrMissingInput{Argument: "password"} + err := gophercloud.ErrMissingEnvironmentVariable{ + EnvironmentVariable: "OS_PASSWORD", + } return nilOptions, err } diff --git a/vendor/github.com/gophercloud/gophercloud/openstack/client.go b/vendor/github.com/gophercloud/gophercloud/openstack/client.go index 5a52e579148..e554b7bc370 100644 --- a/vendor/github.com/gophercloud/gophercloud/openstack/client.go +++ b/vendor/github.com/gophercloud/gophercloud/openstack/client.go @@ -2,10 +2,7 @@ package openstack import ( "fmt" - "net/url" "reflect" - "regexp" - "strings" "github.com/gophercloud/gophercloud" tokens2 "github.com/gophercloud/gophercloud/openstack/identity/v2/tokens" @@ -38,21 +35,11 @@ A basic example of using this would be: client, err := openstack.NewIdentityV3(provider, gophercloud.EndpointOpts{}) */ func NewClient(endpoint string) (*gophercloud.ProviderClient, error) { - u, err := url.Parse(endpoint) + base, err := utils.BaseEndpoint(endpoint) if err != nil { return nil, err } - u.RawQuery, u.Fragment = "", "" - - var base string - versionRe := regexp.MustCompile("v[0-9.]+/?") - if version := versionRe.FindString(u.Path); version != "" { - base = strings.Replace(u.String(), version, "", -1) - } else { - base = u.String() - } - endpoint = gophercloud.NormalizeURL(endpoint) base = gophercloud.NormalizeURL(base) @@ -287,11 +274,17 @@ func NewIdentityV3(client *gophercloud.ProviderClient, eo gophercloud.EndpointOp // Ensure endpoint still has a suffix of v3. // This is because EndpointLocator might have found a versionless - // endpoint and requests will fail unless targeted at /v3. - if !strings.HasSuffix(endpoint, "v3/") { - endpoint = endpoint + "v3/" + // endpoint or the published endpoint is still /v2.0. In both + // cases, we need to fix the endpoint to point to /v3. + base, err := utils.BaseEndpoint(endpoint) + if err != nil { + return nil, err } + base = gophercloud.NormalizeURL(base) + + endpoint = base + "v3/" + return &gophercloud.ServiceClient{ ProviderClient: client, Endpoint: endpoint, @@ -394,3 +387,22 @@ func NewLoadBalancerV2(client *gophercloud.ProviderClient, eo gophercloud.Endpoi sc.ResourceBase = sc.Endpoint + "v2.0/" return sc, err } + +// NewClusteringV1 creates a ServiceClient that may be used with the v1 clustering +// package. +func NewClusteringV1(client *gophercloud.ProviderClient, eo gophercloud.EndpointOpts) (*gophercloud.ServiceClient, error) { + return initClientOpts(client, eo, "clustering") +} + +// NewMessagingV2 creates a ServiceClient that may be used with the v2 messaging +// service. +func NewMessagingV2(client *gophercloud.ProviderClient, clientID string, eo gophercloud.EndpointOpts) (*gophercloud.ServiceClient, error) { + sc, err := initClientOpts(client, eo, "messaging") + sc.MoreHeaders = map[string]string{"Client-ID": clientID} + return sc, err +} + +// NewContainerV1 creates a ServiceClient that may be used with v1 container package +func NewContainerV1(client *gophercloud.ProviderClient, eo gophercloud.EndpointOpts) (*gophercloud.ServiceClient, error) { + return initClientOpts(client, eo, "container") +} diff --git a/vendor/github.com/gophercloud/gophercloud/openstack/identity/v3/tokens/requests.go b/vendor/github.com/gophercloud/gophercloud/openstack/identity/v3/tokens/requests.go index ca35851e4a4..6e99a793c53 100644 --- a/vendor/github.com/gophercloud/gophercloud/openstack/identity/v3/tokens/requests.go +++ b/vendor/github.com/gophercloud/gophercloud/openstack/identity/v3/tokens/requests.go @@ -72,72 +72,15 @@ func (opts *AuthOptions) ToTokenV3CreateMap(scope map[string]interface{}) (map[s // ToTokenV3CreateMap builds a scope request body from AuthOptions. func (opts *AuthOptions) ToTokenV3ScopeMap() (map[string]interface{}, error) { - if opts.Scope.ProjectName != "" { - // ProjectName provided: either DomainID or DomainName must also be supplied. - // ProjectID may not be supplied. - if opts.Scope.DomainID == "" && opts.Scope.DomainName == "" { - return nil, gophercloud.ErrScopeDomainIDOrDomainName{} - } - if opts.Scope.ProjectID != "" { - return nil, gophercloud.ErrScopeProjectIDOrProjectName{} - } - - if opts.Scope.DomainID != "" { - // ProjectName + DomainID - return map[string]interface{}{ - "project": map[string]interface{}{ - "name": &opts.Scope.ProjectName, - "domain": map[string]interface{}{"id": &opts.Scope.DomainID}, - }, - }, nil - } - - if opts.Scope.DomainName != "" { - // ProjectName + DomainName - return map[string]interface{}{ - "project": map[string]interface{}{ - "name": &opts.Scope.ProjectName, - "domain": map[string]interface{}{"name": &opts.Scope.DomainName}, - }, - }, nil - } - } else if opts.Scope.ProjectID != "" { - // ProjectID provided. ProjectName, DomainID, and DomainName may not be provided. - if opts.Scope.DomainID != "" { - return nil, gophercloud.ErrScopeProjectIDAlone{} - } - if opts.Scope.DomainName != "" { - return nil, gophercloud.ErrScopeProjectIDAlone{} - } - - // ProjectID - return map[string]interface{}{ - "project": map[string]interface{}{ - "id": &opts.Scope.ProjectID, - }, - }, nil - } else if opts.Scope.DomainID != "" { - // DomainID provided. ProjectID, ProjectName, and DomainName may not be provided. - if opts.Scope.DomainName != "" { - return nil, gophercloud.ErrScopeDomainIDOrDomainName{} - } - - // DomainID - return map[string]interface{}{ - "domain": map[string]interface{}{ - "id": &opts.Scope.DomainID, - }, - }, nil - } else if opts.Scope.DomainName != "" { - // DomainName - return map[string]interface{}{ - "domain": map[string]interface{}{ - "name": &opts.Scope.DomainName, - }, - }, nil + scope := gophercloud.AuthScope(opts.Scope) + + gophercloudAuthOpts := gophercloud.AuthOptions{ + Scope: &scope, + DomainID: opts.DomainID, + DomainName: opts.DomainName, } - return nil, nil + return gophercloudAuthOpts.ToTokenV3ScopeMap() } func (opts *AuthOptions) CanReauth() bool { @@ -190,7 +133,7 @@ func Get(c *gophercloud.ServiceClient, token string) (r GetResult) { // Validate determines if a specified token is valid or not. func Validate(c *gophercloud.ServiceClient, token string) (bool, error) { - resp, err := c.Request("HEAD", tokenURL(c), &gophercloud.RequestOpts{ + resp, err := c.Head(tokenURL(c), &gophercloud.RequestOpts{ MoreHeaders: subjectTokenHeaders(c, token), OkCodes: []int{200, 204, 404}, }) diff --git a/vendor/github.com/gophercloud/gophercloud/openstack/utils/base_endpoint.go b/vendor/github.com/gophercloud/gophercloud/openstack/utils/base_endpoint.go new file mode 100644 index 00000000000..d6f9e34eaa1 --- /dev/null +++ b/vendor/github.com/gophercloud/gophercloud/openstack/utils/base_endpoint.go @@ -0,0 +1,29 @@ +package utils + +import ( + "net/url" + "regexp" + "strings" +) + +// BaseEndpoint will return a URL without the /vX.Y +// portion of the URL. +func BaseEndpoint(endpoint string) (string, error) { + var base string + + u, err := url.Parse(endpoint) + if err != nil { + return base, err + } + + u.RawQuery, u.Fragment = "", "" + + versionRe := regexp.MustCompile("v[0-9.]+/?") + if version := versionRe.FindString(u.Path); version != "" { + base = strings.Replace(u.String(), version, "", -1) + } else { + base = u.String() + } + + return base, nil +} diff --git a/vendor/github.com/gophercloud/gophercloud/params.go b/vendor/github.com/gophercloud/gophercloud/params.go index 28ad9068565..19b8cf7bf84 100644 --- a/vendor/github.com/gophercloud/gophercloud/params.go +++ b/vendor/github.com/gophercloud/gophercloud/params.go @@ -363,9 +363,8 @@ func BuildQueryString(opts interface{}) (*url.URL, error) { } } } else { - // Otherwise, the field is not set. - if len(tags) == 2 && tags[1] == "required" { - // And the field is required. Return an error. + // if the field has a 'required' tag, it can't have a zero-value + if requiredTag := f.Tag.Get("required"); requiredTag == "true" { return &url.URL{}, fmt.Errorf("Required query parameter [%s] not set.", f.Name) } } @@ -439,10 +438,9 @@ func BuildHeaders(opts interface{}) (map[string]string, error) { optsMap[tags[0]] = strconv.FormatBool(v.Bool()) } } else { - // Otherwise, the field is not set. - if len(tags) == 2 && tags[1] == "required" { - // And the field is required. Return an error. - return optsMap, fmt.Errorf("Required header not set.") + // if the field has a 'required' tag, it can't have a zero-value + if requiredTag := f.Tag.Get("required"); requiredTag == "true" { + return optsMap, fmt.Errorf("Required header [%s] not set.", f.Name) } } } diff --git a/vendor/github.com/gophercloud/gophercloud/provider_client.go b/vendor/github.com/gophercloud/gophercloud/provider_client.go index e93c236e179..17e45127435 100644 --- a/vendor/github.com/gophercloud/gophercloud/provider_client.go +++ b/vendor/github.com/gophercloud/gophercloud/provider_client.go @@ -126,6 +126,36 @@ func (client *ProviderClient) SetToken(t string) { client.TokenID = t } +//Reauthenticate calls client.ReauthFunc in a thread-safe way. If this is +//called because of a 401 response, the caller may pass the previous token. In +//this case, the reauthentication can be skipped if another thread has already +//reauthenticated in the meantime. If no previous token is known, an empty +//string should be passed instead to force unconditional reauthentication. +func (client *ProviderClient) Reauthenticate(previousToken string) (err error) { + if client.ReauthFunc == nil { + return nil + } + + if client.mut == nil { + return client.ReauthFunc() + } + client.mut.Lock() + defer client.mut.Unlock() + + client.reauthmut.Lock() + client.reauthmut.reauthing = true + client.reauthmut.Unlock() + + if previousToken == "" || client.TokenID == previousToken { + err = client.ReauthFunc() + } + + client.reauthmut.Lock() + client.reauthmut.reauthing = false + client.reauthmut.Unlock() + return +} + // RequestOpts customizes the behavior of the provider.Request() method. type RequestOpts struct { // JSONBody, if provided, will be encoded as JSON and used as the body of the HTTP request. The @@ -254,21 +284,7 @@ func (client *ProviderClient) Request(method, url string, options *RequestOpts) } case http.StatusUnauthorized: if client.ReauthFunc != nil { - if client.mut != nil { - client.mut.Lock() - client.reauthmut.Lock() - client.reauthmut.reauthing = true - client.reauthmut.Unlock() - if curtok := client.TokenID; curtok == prereqtok { - err = client.ReauthFunc() - } - client.reauthmut.Lock() - client.reauthmut.reauthing = false - client.reauthmut.Unlock() - client.mut.Unlock() - } else { - err = client.ReauthFunc() - } + err = client.Reauthenticate(prereqtok) if err != nil { e := &ErrUnableToReauthenticate{} e.ErrOriginal = respErr diff --git a/vendor/github.com/gophercloud/gophercloud/results.go b/vendor/github.com/gophercloud/gophercloud/results.go index e64feee19ed..fdd4830ec1f 100644 --- a/vendor/github.com/gophercloud/gophercloud/results.go +++ b/vendor/github.com/gophercloud/gophercloud/results.go @@ -345,6 +345,27 @@ func (jt *JSONRFC3339NoZ) UnmarshalJSON(data []byte) error { return nil } +// RFC3339ZNoT is the time format used in Zun (Containers Service). +const RFC3339ZNoT = "2006-01-02 15:04:05-07:00" + +type JSONRFC3339ZNoT time.Time + +func (jt *JSONRFC3339ZNoT) UnmarshalJSON(data []byte) error { + var s string + if err := json.Unmarshal(data, &s); err != nil { + return err + } + if s == "" { + return nil + } + t, err := time.Parse(RFC3339ZNoT, s) + if err != nil { + return err + } + *jt = JSONRFC3339ZNoT(t) + return nil +} + /* Link is an internal type to be used in packages of collection resources that are paginated in a certain way. diff --git a/vendor/github.com/gophercloud/gophercloud/service_client.go b/vendor/github.com/gophercloud/gophercloud/service_client.go index d1a48fea35b..2734510e1b4 100644 --- a/vendor/github.com/gophercloud/gophercloud/service_client.go +++ b/vendor/github.com/gophercloud/gophercloud/service_client.go @@ -28,6 +28,10 @@ type ServiceClient struct { // The microversion of the service to use. Set this to use a particular microversion. Microversion string + + // MoreHeaders allows users (or Gophercloud) to set service-wide headers on requests. Put another way, + // values set in this field will be set on all the HTTP requests the service client sends. + MoreHeaders map[string]string } // ResourceBaseURL returns the base URL of any resources used by this service. It MUST end with a /. @@ -108,6 +112,15 @@ func (client *ServiceClient) Delete(url string, opts *RequestOpts) (*http.Respon return client.Request("DELETE", url, opts) } +// Head calls `Request` with the "HEAD" HTTP verb. +func (client *ServiceClient) Head(url string, opts *RequestOpts) (*http.Response, error) { + if opts == nil { + opts = new(RequestOpts) + } + client.initReqOpts(url, nil, nil, opts) + return client.Request("HEAD", url, opts) +} + func (client *ServiceClient) setMicroversionHeader(opts *RequestOpts) { switch client.Type { case "compute": @@ -122,3 +135,16 @@ func (client *ServiceClient) setMicroversionHeader(opts *RequestOpts) { opts.MoreHeaders["OpenStack-API-Version"] = client.Type + " " + client.Microversion } } + +// Request carries out the HTTP operation for the service client +func (client *ServiceClient) Request(method, url string, options *RequestOpts) (*http.Response, error) { + if len(client.MoreHeaders) > 0 { + if options == nil { + options = new(RequestOpts) + } + for k, v := range client.MoreHeaders { + options.MoreHeaders[k] = v + } + } + return client.ProviderClient.Request(method, url, options) +} diff --git a/vendor/github.com/gorilla/context/.travis.yml b/vendor/github.com/gorilla/context/.travis.yml index faca4dad3dc..6f440f1e42d 100644 --- a/vendor/github.com/gorilla/context/.travis.yml +++ b/vendor/github.com/gorilla/context/.travis.yml @@ -7,13 +7,13 @@ matrix: - go: 1.4 - go: 1.5 - go: 1.6 + - go: 1.7 + - go: tip + allow_failures: - go: tip - -install: - - go get golang.org/x/tools/cmd/vet script: - go get -t -v ./... - diff -u <(echo -n) <(gofmt -d .) - - go tool vet . + - go vet $(go list ./... | grep -v /vendor/) - go test -v -race ./... diff --git a/vendor/github.com/gorilla/context/README.md b/vendor/github.com/gorilla/context/README.md index c60a31b053b..08f86693bcd 100644 --- a/vendor/github.com/gorilla/context/README.md +++ b/vendor/github.com/gorilla/context/README.md @@ -4,4 +4,7 @@ context gorilla/context is a general purpose registry for global request variables. +> Note: gorilla/context, having been born well before `context.Context` existed, does not play well +> with the shallow copying of the request that [`http.Request.WithContext`](https://golang.org/pkg/net/http/#Request.WithContext) (added to net/http Go 1.7 onwards) performs. You should either use *just* gorilla/context, or moving forward, the new `http.Request.Context()`. + Read the full documentation here: http://www.gorillatoolkit.org/pkg/context diff --git a/vendor/github.com/gorilla/context/doc.go b/vendor/github.com/gorilla/context/doc.go index 73c7400311e..448d1bfcac6 100644 --- a/vendor/github.com/gorilla/context/doc.go +++ b/vendor/github.com/gorilla/context/doc.go @@ -5,6 +5,12 @@ /* Package context stores values shared during a request lifetime. +Note: gorilla/context, having been born well before `context.Context` existed, +does not play well > with the shallow copying of the request that +[`http.Request.WithContext`](https://golang.org/pkg/net/http/#Request.WithContext) +(added to net/http Go 1.7 onwards) performs. You should either use *just* +gorilla/context, or moving forward, the new `http.Request.Context()`. + For example, a router can set variables extracted from the URL and later application handlers can access those values, or it can be used to store sessions values to be saved at the end of a request. There are several diff --git a/vendor/github.com/gorilla/mux/.travis.yml b/vendor/github.com/gorilla/mux/.travis.yml index 3302233f3c3..ad0935dbd37 100644 --- a/vendor/github.com/gorilla/mux/.travis.yml +++ b/vendor/github.com/gorilla/mux/.travis.yml @@ -3,11 +3,12 @@ sudo: false matrix: include: - - go: 1.5 - - go: 1.6 - - go: 1.7 - - go: 1.8 - - go: 1.9 + - go: 1.5.x + - go: 1.6.x + - go: 1.7.x + - go: 1.8.x + - go: 1.9.x + - go: 1.10.x - go: tip allow_failures: - go: tip diff --git a/vendor/github.com/gorilla/mux/README.md b/vendor/github.com/gorilla/mux/README.md index f9b3103f068..e424397ac4d 100644 --- a/vendor/github.com/gorilla/mux/README.md +++ b/vendor/github.com/gorilla/mux/README.md @@ -1,5 +1,5 @@ -gorilla/mux -=== +# gorilla/mux + [![GoDoc](https://godoc.org/github.com/gorilla/mux?status.svg)](https://godoc.org/github.com/gorilla/mux) [![Build Status](https://travis-ci.org/gorilla/mux.svg?branch=master)](https://travis-ci.org/gorilla/mux) [![Sourcegraph](https://sourcegraph.com/github.com/gorilla/mux/-/badge.svg)](https://sourcegraph.com/github.com/gorilla/mux?badge) @@ -29,6 +29,7 @@ The name mux stands for "HTTP request multiplexer". Like the standard `http.Serv * [Walking Routes](#walking-routes) * [Graceful Shutdown](#graceful-shutdown) * [Middleware](#middleware) +* [Testing Handlers](#testing-handlers) * [Full Example](#full-example) --- @@ -178,70 +179,13 @@ s.HandleFunc("/{key}/", ProductHandler) // "/products/{key}/details" s.HandleFunc("/{key}/details", ProductDetailsHandler) ``` -### Listing Routes - -Routes on a mux can be listed using the Router.Walk method—useful for generating documentation: - -```go -package main - -import ( - "fmt" - "net/http" - "strings" - - "github.com/gorilla/mux" -) - -func handler(w http.ResponseWriter, r *http.Request) { - return -} -func main() { - r := mux.NewRouter() - r.HandleFunc("/", handler) - r.HandleFunc("/products", handler).Methods("POST") - r.HandleFunc("/articles", handler).Methods("GET") - r.HandleFunc("/articles/{id}", handler).Methods("GET", "PUT") - r.HandleFunc("/authors", handler).Queries("surname", "{surname}") - r.Walk(func(route *mux.Route, router *mux.Router, ancestors []*mux.Route) error { - t, err := route.GetPathTemplate() - if err != nil { - return err - } - qt, err := route.GetQueriesTemplates() - if err != nil { - return err - } - // p will contain regular expression is compatible with regular expression in Perl, Python, and other languages. - // for instance the regular expression for path '/articles/{id}' will be '^/articles/(?P[^/]+)$' - p, err := route.GetPathRegexp() - if err != nil { - return err - } - // qr will contain a list of regular expressions with the same semantics as GetPathRegexp, - // just applied to the Queries pairs instead, e.g., 'Queries("surname", "{surname}") will return - // {"^surname=(?P.*)$}. Where each combined query pair will have an entry in the list. - qr, err := route.GetQueriesRegexp() - if err != nil { - return err - } - m, err := route.GetMethods() - if err != nil { - return err - } - fmt.Println(strings.Join(m, ","), strings.Join(qt, ","), strings.Join(qr, ","), t, p) - return nil - }) - http.Handle("/", r) -} -``` ### Static Files Note that the path provided to `PathPrefix()` represents a "wildcard": calling `PathPrefix("/static/").Handler(...)` means that the handler will be passed any -request that matches "/static/*". This makes it easy to serve static files with mux: +request that matches "/static/\*". This makes it easy to serve static files with mux: ```go func main() { @@ -348,41 +292,58 @@ The `Walk` function on `mux.Router` can be used to visit all of the routes that the following prints all of the registered routes: ```go -r := mux.NewRouter() -r.HandleFunc("/", handler) -r.HandleFunc("/products", handler).Methods("POST") -r.HandleFunc("/articles", handler).Methods("GET") -r.HandleFunc("/articles/{id}", handler).Methods("GET", "PUT") -r.HandleFunc("/authors", handler).Queries("surname", "{surname}") -r.Walk(func(route *mux.Route, router *mux.Router, ancestors []*mux.Route) error { - t, err := route.GetPathTemplate() - if err != nil { - return err - } - qt, err := route.GetQueriesTemplates() - if err != nil { - return err - } - // p will contain a regular expression that is compatible with regular expressions in Perl, Python, and other languages. - // For example, the regular expression for path '/articles/{id}' will be '^/articles/(?P[^/]+)$'. - p, err := route.GetPathRegexp() - if err != nil { - return err - } - // qr will contain a list of regular expressions with the same semantics as GetPathRegexp, - // just applied to the Queries pairs instead, e.g., 'Queries("surname", "{surname}") will return - // {"^surname=(?P.*)$}. Where each combined query pair will have an entry in the list. - qr, err := route.GetQueriesRegexp() - if err != nil { - return err - } - m, err := route.GetMethods() - if err != nil { - return err - } - fmt.Println(strings.Join(m, ","), strings.Join(qt, ","), strings.Join(qr, ","), t, p) - return nil -}) +package main + +import ( + "fmt" + "net/http" + "strings" + + "github.com/gorilla/mux" +) + +func handler(w http.ResponseWriter, r *http.Request) { + return +} + +func main() { + r := mux.NewRouter() + r.HandleFunc("/", handler) + r.HandleFunc("/products", handler).Methods("POST") + r.HandleFunc("/articles", handler).Methods("GET") + r.HandleFunc("/articles/{id}", handler).Methods("GET", "PUT") + r.HandleFunc("/authors", handler).Queries("surname", "{surname}") + err := r.Walk(func(route *mux.Route, router *mux.Router, ancestors []*mux.Route) error { + pathTemplate, err := route.GetPathTemplate() + if err == nil { + fmt.Println("ROUTE:", pathTemplate) + } + pathRegexp, err := route.GetPathRegexp() + if err == nil { + fmt.Println("Path regexp:", pathRegexp) + } + queriesTemplates, err := route.GetQueriesTemplates() + if err == nil { + fmt.Println("Queries templates:", strings.Join(queriesTemplates, ",")) + } + queriesRegexps, err := route.GetQueriesRegexp() + if err == nil { + fmt.Println("Queries regexps:", strings.Join(queriesRegexps, ",")) + } + methods, err := route.GetMethods() + if err == nil { + fmt.Println("Methods:", strings.Join(methods, ",")) + } + fmt.Println() + return nil + }) + + if err != nil { + fmt.Println(err) + } + + http.Handle("/", r) +} ``` ### Graceful Shutdown @@ -399,6 +360,7 @@ import ( "net/http" "os" "os/signal" + "time" "github.com/gorilla/mux" ) @@ -410,7 +372,7 @@ func main() { r := mux.NewRouter() // Add your routes as needed - + srv := &http.Server{ Addr: "0.0.0.0:8080", // Good practice to set timeouts to avoid Slowloris attacks. @@ -426,7 +388,7 @@ func main() { log.Println(err) } }() - + c := make(chan os.Signal, 1) // We'll accept graceful shutdowns when quit via SIGINT (Ctrl+C) // SIGKILL, SIGQUIT or SIGTERM (Ctrl+/) will not be caught. @@ -436,7 +398,8 @@ func main() { <-c // Create a deadline to wait for. - ctx, cancel := context.WithTimeout(ctx, wait) + ctx, cancel := context.WithTimeout(context.Background(), wait) + defer cancel() // Doesn't block if no connections, but will otherwise wait // until the timeout deadline. srv.Shutdown(ctx) @@ -464,7 +427,7 @@ Typically, the returned handler is a closure which does something with the http. A very basic middleware which logs the URI of the request being handled could be written as: ```go -func simpleMw(next http.Handler) http.Handler { +func loggingMiddleware(next http.Handler) http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { // Do stuff here log.Println(r.RequestURI) @@ -474,12 +437,12 @@ func simpleMw(next http.Handler) http.Handler { } ``` -Middlewares can be added to a router using `Router.AddMiddlewareFunc()`: +Middlewares can be added to a router using `Router.Use()`: ```go r := mux.NewRouter() r.HandleFunc("/", handler) -r.AddMiddleware(simpleMw) +r.Use(loggingMiddleware) ``` A more complex authentication middleware, which maps session token to users, could be written as: @@ -502,7 +465,7 @@ func (amw *authenticationMiddleware) Populate() { func (amw *authenticationMiddleware) Middleware(next http.Handler) http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { token := r.Header.Get("X-Session-Token") - + if user, found := amw.tokenUsers[token]; found { // We found the token in our map log.Printf("Authenticated user %s\n", user) @@ -510,7 +473,7 @@ func (amw *authenticationMiddleware) Middleware(next http.Handler) http.Handler next.ServeHTTP(w, r) } else { // Write an error and stop the handler chain - http.Error(w, "Forbidden", 403) + http.Error(w, "Forbidden", http.StatusForbidden) } }) } @@ -523,10 +486,136 @@ r.HandleFunc("/", handler) amw := authenticationMiddleware{} amw.Populate() -r.AddMiddlewareFunc(amw.Middleware) +r.Use(amw.Middleware) +``` + +Note: The handler chain will be stopped if your middleware doesn't call `next.ServeHTTP()` with the corresponding parameters. This can be used to abort a request if the middleware writer wants to. Middlewares _should_ write to `ResponseWriter` if they _are_ going to terminate the request, and they _should not_ write to `ResponseWriter` if they _are not_ going to terminate it. + +### Testing Handlers + +Testing handlers in a Go web application is straightforward, and _mux_ doesn't complicate this any further. Given two files: `endpoints.go` and `endpoints_test.go`, here's how we'd test an application using _mux_. + +First, our simple HTTP handler: + +```go +// endpoints.go +package main + +func HealthCheckHandler(w http.ResponseWriter, r *http.Request) { + // A very simple health check. + w.WriteHeader(http.StatusOK) + w.Header().Set("Content-Type", "application/json") + + // In the future we could report back on the status of our DB, or our cache + // (e.g. Redis) by performing a simple PING, and include them in the response. + io.WriteString(w, `{"alive": true}`) +} + +func main() { + r := mux.NewRouter() + r.HandleFunc("/health", HealthCheckHandler) + + log.Fatal(http.ListenAndServe("localhost:8080", r)) +} +``` + +Our test code: + +```go +// endpoints_test.go +package main + +import ( + "net/http" + "net/http/httptest" + "testing" +) + +func TestHealthCheckHandler(t *testing.T) { + // Create a request to pass to our handler. We don't have any query parameters for now, so we'll + // pass 'nil' as the third parameter. + req, err := http.NewRequest("GET", "/health", nil) + if err != nil { + t.Fatal(err) + } + + // We create a ResponseRecorder (which satisfies http.ResponseWriter) to record the response. + rr := httptest.NewRecorder() + handler := http.HandlerFunc(HealthCheckHandler) + + // Our handlers satisfy http.Handler, so we can call their ServeHTTP method + // directly and pass in our Request and ResponseRecorder. + handler.ServeHTTP(rr, req) + + // Check the status code is what we expect. + if status := rr.Code; status != http.StatusOK { + t.Errorf("handler returned wrong status code: got %v want %v", + status, http.StatusOK) + } + + // Check the response body is what we expect. + expected := `{"alive": true}` + if rr.Body.String() != expected { + t.Errorf("handler returned unexpected body: got %v want %v", + rr.Body.String(), expected) + } +} +``` + +In the case that our routes have [variables](#examples), we can pass those in the request. We could write +[table-driven tests](https://dave.cheney.net/2013/06/09/writing-table-driven-tests-in-go) to test multiple +possible route variables as needed. + +```go +// endpoints.go +func main() { + r := mux.NewRouter() + // A route with a route variable: + r.HandleFunc("/metrics/{type}", MetricsHandler) + + log.Fatal(http.ListenAndServe("localhost:8080", r)) +} ``` -Note: The handler chain will be stopped if your middleware doesn't call `next.ServeHTTP()` with the corresponding parameters. This can be used to abort a request if the middleware writer wants to. Middlewares *should* write to `ResponseWriter` if they *are* going to terminate the request, and they *should not* write to `ResponseWriter` if they *are not* going to terminate it. +Our test file, with a table-driven test of `routeVariables`: + +```go +// endpoints_test.go +func TestMetricsHandler(t *testing.T) { + tt := []struct{ + routeVariable string + shouldPass bool + }{ + {"goroutines", true}, + {"heap", true}, + {"counters", true}, + {"queries", true}, + {"adhadaeqm3k", false}, + } + + for _, tc := range tt { + path := fmt.Sprintf("/metrics/%s", tc.routeVariable) + req, err := http.NewRequest("GET", path, nil) + if err != nil { + t.Fatal(err) + } + + rr := httptest.NewRecorder() + + // Need to create a router that we can pass the request through so that the vars will be added to the context + router := mux.NewRouter() + router.HandleFunc("/metrics/{type}", MetricsHandler) + router.ServeHTTP(rr, req) + + // In this case, our MetricsHandler returns a non-200 response + // for a route variable it doesn't know about. + if rr.Code == http.StatusOK && !tc.shouldPass { + t.Errorf("handler should have failed on routeVariable %s: got %v want %v", + tc.routeVariable, rr.Code, http.StatusOK) + } + } +} +``` ## Full Example diff --git a/vendor/github.com/gorilla/mux/doc.go b/vendor/github.com/gorilla/mux/doc.go index 013f088985b..38957deead3 100644 --- a/vendor/github.com/gorilla/mux/doc.go +++ b/vendor/github.com/gorilla/mux/doc.go @@ -239,8 +239,7 @@ as well: "category", "technology", "id", "42") -Since **vX.Y.Z**, mux supports the addition of middlewares to a [Router](https://godoc.org/github.com/gorilla/mux#Router), which are executed if a -match is found (including subrouters). Middlewares are defined using the de facto standard type: +Mux supports the addition of middlewares to a Router, which are executed in the order they are added if a match is found, including its subrouters. Middlewares are (typically) small pieces of code which take one request, do something with it, and pass it down to another middleware or the final handler. Some common use cases for middleware are request logging, header manipulation, or ResponseWriter hijacking. type MiddlewareFunc func(http.Handler) http.Handler @@ -261,7 +260,7 @@ Middlewares can be added to a router using `Router.Use()`: r := mux.NewRouter() r.HandleFunc("/", handler) - r.AddMiddleware(simpleMw) + r.Use(simpleMw) A more complex authentication middleware, which maps session token to users, could be written as: @@ -288,7 +287,7 @@ A more complex authentication middleware, which maps session token to users, cou log.Printf("Authenticated user %s\n", user) next.ServeHTTP(w, r) } else { - http.Error(w, "Forbidden", 403) + http.Error(w, "Forbidden", http.StatusForbidden) } }) } diff --git a/vendor/github.com/gorilla/mux/middleware.go b/vendor/github.com/gorilla/mux/middleware.go index 8f898675ea7..ceb812cee28 100644 --- a/vendor/github.com/gorilla/mux/middleware.go +++ b/vendor/github.com/gorilla/mux/middleware.go @@ -1,6 +1,9 @@ package mux -import "net/http" +import ( + "net/http" + "strings" +) // MiddlewareFunc is a function which receives an http.Handler and returns another http.Handler. // Typically, the returned handler is a closure which does something with the http.ResponseWriter and http.Request passed @@ -12,17 +15,58 @@ type middleware interface { Middleware(handler http.Handler) http.Handler } -// MiddlewareFunc also implements the middleware interface. +// Middleware allows MiddlewareFunc to implement the middleware interface. func (mw MiddlewareFunc) Middleware(handler http.Handler) http.Handler { return mw(handler) } // Use appends a MiddlewareFunc to the chain. Middleware can be used to intercept or otherwise modify requests and/or responses, and are executed in the order that they are applied to the Router. -func (r *Router) Use(mwf MiddlewareFunc) { - r.middlewares = append(r.middlewares, mwf) +func (r *Router) Use(mwf ...MiddlewareFunc) { + for _, fn := range mwf { + r.middlewares = append(r.middlewares, fn) + } } // useInterface appends a middleware to the chain. Middleware can be used to intercept or otherwise modify requests and/or responses, and are executed in the order that they are applied to the Router. func (r *Router) useInterface(mw middleware) { r.middlewares = append(r.middlewares, mw) } + +// CORSMethodMiddleware sets the Access-Control-Allow-Methods response header +// on a request, by matching routes based only on paths. It also handles +// OPTIONS requests, by settings Access-Control-Allow-Methods, and then +// returning without calling the next http handler. +func CORSMethodMiddleware(r *Router) MiddlewareFunc { + return func(next http.Handler) http.Handler { + return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) { + var allMethods []string + + err := r.Walk(func(route *Route, _ *Router, _ []*Route) error { + for _, m := range route.matchers { + if _, ok := m.(*routeRegexp); ok { + if m.Match(req, &RouteMatch{}) { + methods, err := route.GetMethods() + if err != nil { + return err + } + + allMethods = append(allMethods, methods...) + } + break + } + } + return nil + }) + + if err == nil { + w.Header().Set("Access-Control-Allow-Methods", strings.Join(append(allMethods, "OPTIONS"), ",")) + + if req.Method == "OPTIONS" { + return + } + } + + next.ServeHTTP(w, req) + }) + } +} diff --git a/vendor/github.com/gorilla/mux/mux.go b/vendor/github.com/gorilla/mux/mux.go index efabd241751..4bbafa51da3 100644 --- a/vendor/github.com/gorilla/mux/mux.go +++ b/vendor/github.com/gorilla/mux/mux.go @@ -13,8 +13,11 @@ import ( ) var ( + // ErrMethodMismatch is returned when the method in the request does not match + // the method defined against the route. ErrMethodMismatch = errors.New("method is not allowed") - ErrNotFound = errors.New("no matching route was found") + // ErrNotFound is returned when no route match is found. + ErrNotFound = errors.New("no matching route was found") ) // NewRouter returns a new router instance. @@ -95,9 +98,9 @@ func (r *Router) Match(req *http.Request, match *RouteMatch) bool { if r.MethodNotAllowedHandler != nil { match.Handler = r.MethodNotAllowedHandler return true - } else { - return false } + + return false } // Closest match for a router (includes sub-routers) diff --git a/vendor/github.com/gorilla/mux/route.go b/vendor/github.com/gorilla/mux/route.go index 4ce098d4fbf..a591d735450 100644 --- a/vendor/github.com/gorilla/mux/route.go +++ b/vendor/github.com/gorilla/mux/route.go @@ -43,6 +43,8 @@ type Route struct { buildVarsFunc BuildVarsFunc } +// SkipClean reports whether path cleaning is enabled for this route via +// Router.SkipClean. func (r *Route) SkipClean() bool { return r.skipClean } @@ -622,7 +624,7 @@ func (r *Route) GetPathRegexp() (string, error) { // route queries. // This is useful for building simple REST API documentation and for instrumentation // against third-party services. -// An empty list will be returned if the route does not have queries. +// An error will be returned if the route does not have queries. func (r *Route) GetQueriesRegexp() ([]string, error) { if r.err != nil { return nil, r.err @@ -641,7 +643,7 @@ func (r *Route) GetQueriesRegexp() ([]string, error) { // query matching. // This is useful for building simple REST API documentation and for instrumentation // against third-party services. -// An empty list will be returned if the route does not define queries. +// An error will be returned if the route does not define queries. func (r *Route) GetQueriesTemplates() ([]string, error) { if r.err != nil { return nil, r.err @@ -659,7 +661,7 @@ func (r *Route) GetQueriesTemplates() ([]string, error) { // GetMethods returns the methods the route matches against // This is useful for building simple REST API documentation and for instrumentation // against third-party services. -// An empty list will be returned if route does not have methods. +// An error will be returned if route does not have methods. func (r *Route) GetMethods() ([]string, error) { if r.err != nil { return nil, r.err @@ -669,7 +671,7 @@ func (r *Route) GetMethods() ([]string, error) { return []string(methods), nil } } - return nil, nil + return nil, errors.New("mux: route doesn't have methods") } // GetHostTemplate returns the template used to build the diff --git a/vendor/github.com/gorilla/mux/test_helpers.go b/vendor/github.com/gorilla/mux/test_helpers.go index 8b2c4a4c580..32ecffde489 100644 --- a/vendor/github.com/gorilla/mux/test_helpers.go +++ b/vendor/github.com/gorilla/mux/test_helpers.go @@ -7,7 +7,8 @@ package mux import "net/http" // SetURLVars sets the URL variables for the given request, to be accessed via -// mux.Vars for testing route behaviour. +// mux.Vars for testing route behaviour. Arguments are not modified, a shallow +// copy is returned. // // This API should only be used for testing purposes; it provides a way to // inject variables into the request context. Alternatively, URL variables diff --git a/vendor/github.com/imdario/mergo/README.md b/vendor/github.com/imdario/mergo/README.md index 4a99d31722c..d1cefa87189 100644 --- a/vendor/github.com/imdario/mergo/README.md +++ b/vendor/github.com/imdario/mergo/README.md @@ -8,10 +8,11 @@ Also a lovely [comune](http://en.wikipedia.org/wiki/Mergo) (municipality) in the It is ready for production use. [It is used in several projects by Docker, Google, The Linux Foundation, VMWare, Shopify, etc](https://github.com/imdario/mergo#mergo-in-the-wild). -[![Build Status][1]][2] [![GoDoc][3]][4] [![GoCard][5]][6] +[![Build Status][1]][2] [![Coverage Status][7]][8] +[![Sourcegraph][9]][10] [1]: https://travis-ci.org/imdario/mergo.png [2]: https://travis-ci.org/imdario/mergo @@ -21,15 +22,28 @@ It is ready for production use. [It is used in several projects by Docker, Googl [6]: https://goreportcard.com/report/github.com/imdario/mergo [7]: https://coveralls.io/repos/github/imdario/mergo/badge.svg?branch=master [8]: https://coveralls.io/github/imdario/mergo?branch=master +[9]: https://sourcegraph.com/github.com/imdario/mergo/-/badge.svg +[10]: https://sourcegraph.com/github.com/imdario/mergo?badge ### Latest release -[Release 0.3.1](https://github.com/imdario/mergo/releases/tag/0.3.1) is an important release because it changes `Merge()`and `Map()` signatures to support [transformers](#transformers). An optional/variadic argument has been added, so it won't break existing code. +[Release v0.3.4](https://github.com/imdario/mergo/releases/tag/v0.3.4). ### Important note +Please keep in mind that in [0.3.2](//github.com/imdario/mergo/releases/tag/0.3.2) Mergo changed `Merge()`and `Map()` signatures to support [transformers](#transformers). An optional/variadic argument has been added, so it won't break existing code. + If you were using Mergo **before** April 6th 2015, please check your project works as intended after updating your local copy with ```go get -u github.com/imdario/mergo```. I apologize for any issue caused by its previous behavior and any future bug that Mergo could cause (I hope it won't!) in existing projects after the change (release 0.2.0). +### Donations + +If Mergo is useful to you, consider buying me a coffee, a beer or making a monthly donation so I can keep building great free software. :heart_eyes: + +Buy Me a Coffee at ko-fi.com +[![Beerpay](https://beerpay.io/imdario/mergo/badge.svg)](https://beerpay.io/imdario/mergo) +[![Beerpay](https://beerpay.io/imdario/mergo/make-wish.svg)](https://beerpay.io/imdario/mergo) +Donate using Liberapay + ### Mergo in the wild - [moby/moby](https://github.com/moby/moby) @@ -84,7 +98,7 @@ If you were using Mergo **before** April 6th 2015, please check your project wor ## Usage -You can only merge same-type structs with exported fields initialized as zero value of their type and same-types maps. Mergo won't merge unexported (private) fields but will do recursively any exported one. Also maps will be merged recursively except for structs inside maps (because they are not addressable using Go reflection). +You can only merge same-type structs with exported fields initialized as zero value of their type and same-types maps. Mergo won't merge unexported (private) fields but will do recursively any exported one. It won't merge empty structs value as [they are not considered zero values](https://golang.org/ref/spec#The_zero_value) either. Also maps will be merged recursively except for structs inside maps (because they are not addressable using Go reflection). ```go if err := mergo.Merge(&dst, src); err != nil { @@ -95,7 +109,7 @@ if err := mergo.Merge(&dst, src); err != nil { Also, you can merge overwriting values using the transformer `WithOverride`. ```go -if err := mergo.Merge(&dst, src, WithOverride); err != nil { +if err := mergo.Merge(&dst, src, mergo.WithOverride); err != nil { // ... } ``` @@ -155,6 +169,7 @@ package main import ( "fmt" + "github.com/imdario/mergo" "reflect" "time" ) @@ -186,7 +201,7 @@ type Snapshot struct { func main() { src := Snapshot{time.Now()} dest := Snapshot{} - mergo.Merge(&dest, src, WithTransformers(timeTransfomer{})) + mergo.Merge(&dest, src, mergo.WithTransformers(timeTransfomer{})) fmt.Println(dest) // Will print // { 2018-01-12 01:15:00 +0000 UTC m=+0.000000001 } diff --git a/vendor/github.com/imdario/mergo/map.go b/vendor/github.com/imdario/mergo/map.go index 20981432922..6ea38e636b6 100644 --- a/vendor/github.com/imdario/mergo/map.go +++ b/vendor/github.com/imdario/mergo/map.go @@ -31,8 +31,8 @@ func isExported(field reflect.StructField) bool { // Traverses recursively both values, assigning src's fields values to dst. // The map argument tracks comparisons that have already been seen, which allows // short circuiting on recursive types. -func deepMap(dst, src reflect.Value, visited map[uintptr]*visit, depth int, config *config) (err error) { - overwrite := config.overwrite +func deepMap(dst, src reflect.Value, visited map[uintptr]*visit, depth int, config *Config) (err error) { + overwrite := config.Overwrite if dst.CanAddr() { addr := dst.UnsafeAddr() h := 17 * addr @@ -128,23 +128,23 @@ func deepMap(dst, src reflect.Value, visited map[uintptr]*visit, depth int, conf // doesn't apply if dst is a map. // This is separated method from Merge because it is cleaner and it keeps sane // semantics: merging equal types, mapping different (restricted) types. -func Map(dst, src interface{}, opts ...func(*config)) error { +func Map(dst, src interface{}, opts ...func(*Config)) error { return _map(dst, src, opts...) } -// MapWithOverwrite will do the same as Map except that non-empty dst attributes will be overriden by +// MapWithOverwrite will do the same as Map except that non-empty dst attributes will be overridden by // non-empty src attribute values. // Deprecated: Use Map(…) with WithOverride -func MapWithOverwrite(dst, src interface{}, opts ...func(*config)) error { +func MapWithOverwrite(dst, src interface{}, opts ...func(*Config)) error { return _map(dst, src, append(opts, WithOverride)...) } -func _map(dst, src interface{}, opts ...func(*config)) error { +func _map(dst, src interface{}, opts ...func(*Config)) error { var ( vDst, vSrc reflect.Value err error ) - config := &config{} + config := &Config{} for _, opt := range opts { opt(config) diff --git a/vendor/github.com/imdario/mergo/merge.go b/vendor/github.com/imdario/mergo/merge.go index 8ca10c91088..f0e17924ac9 100644 --- a/vendor/github.com/imdario/mergo/merge.go +++ b/vendor/github.com/imdario/mergo/merge.go @@ -8,7 +8,9 @@ package mergo -import "reflect" +import ( + "reflect" +) func hasExportedField(dst reflect.Value) (exported bool) { for i, n := 0, dst.NumField(); i < n; i++ { @@ -22,20 +24,21 @@ func hasExportedField(dst reflect.Value) (exported bool) { return } -type config struct { - overwrite bool - transformers transformers +type Config struct { + Overwrite bool + AppendSlice bool + Transformers Transformers } -type transformers interface { +type Transformers interface { Transformer(reflect.Type) func(dst, src reflect.Value) error } // Traverses recursively both values, assigning src's fields values to dst. // The map argument tracks comparisons that have already been seen, which allows // short circuiting on recursive types. -func deepMerge(dst, src reflect.Value, visited map[uintptr]*visit, depth int, config *config) (err error) { - overwrite := config.overwrite +func deepMerge(dst, src reflect.Value, visited map[uintptr]*visit, depth int, config *Config) (err error) { + overwrite := config.Overwrite if !src.IsValid() { return @@ -54,8 +57,8 @@ func deepMerge(dst, src reflect.Value, visited map[uintptr]*visit, depth int, co visited[h] = &visit{addr, typ, seen} } - if config.transformers != nil && !isEmptyValue(dst) { - if fn := config.transformers.Transformer(dst.Type()); fn != nil { + if config.Transformers != nil && !isEmptyValue(dst) { + if fn := config.Transformers.Transformer(dst.Type()); fn != nil { err = fn(dst, src) return } @@ -75,9 +78,8 @@ func deepMerge(dst, src reflect.Value, visited map[uintptr]*visit, depth int, co } } case reflect.Map: - if len(src.MapKeys()) == 0 && !src.IsNil() && len(dst.MapKeys()) == 0 { + if dst.IsNil() && !src.IsNil() { dst.Set(reflect.MakeMap(dst.Type())) - return } for _, key := range src.MapKeys() { srcElement := src.MapIndex(key) @@ -86,7 +88,7 @@ func deepMerge(dst, src reflect.Value, visited map[uintptr]*visit, depth int, co } dstElement := dst.MapIndex(key) switch srcElement.Kind() { - case reflect.Chan, reflect.Func, reflect.Map, reflect.Ptr, reflect.Interface, reflect.Slice: + case reflect.Chan, reflect.Func, reflect.Map, reflect.Interface, reflect.Slice: if srcElement.IsNil() { continue } @@ -122,7 +124,7 @@ func deepMerge(dst, src reflect.Value, visited map[uintptr]*visit, depth int, co continue } - if !isEmptyValue(srcElement) && (overwrite || (!dstElement.IsValid() || isEmptyValue(dst))) { + if srcElement.IsValid() && (overwrite || (!dstElement.IsValid() || isEmptyValue(dst))) { if dst.IsNil() { dst.Set(reflect.MakeMap(dst.Type())) } @@ -130,7 +132,14 @@ func deepMerge(dst, src reflect.Value, visited map[uintptr]*visit, depth int, co } } case reflect.Slice: - dst.Set(reflect.AppendSlice(dst, src)) + if !dst.CanSet() { + break + } + if !isEmptyValue(src) && (overwrite || isEmptyValue(dst)) && !config.AppendSlice { + dst.Set(src) + } else { + dst.Set(reflect.AppendSlice(dst, src)) + } case reflect.Ptr: fallthrough case reflect.Interface: @@ -174,36 +183,41 @@ func deepMerge(dst, src reflect.Value, visited map[uintptr]*visit, depth int, co // src attributes if they themselves are not empty. dst and src must be valid same-type structs // and dst must be a pointer to struct. // It won't merge unexported (private) fields and will do recursively any exported field. -func Merge(dst, src interface{}, opts ...func(*config)) error { +func Merge(dst, src interface{}, opts ...func(*Config)) error { return merge(dst, src, opts...) } // MergeWithOverwrite will do the same as Merge except that non-empty dst attributes will be overriden by // non-empty src attribute values. // Deprecated: use Merge(…) with WithOverride -func MergeWithOverwrite(dst, src interface{}, opts ...func(*config)) error { +func MergeWithOverwrite(dst, src interface{}, opts ...func(*Config)) error { return merge(dst, src, append(opts, WithOverride)...) } // WithTransformers adds transformers to merge, allowing to customize the merging of some types. -func WithTransformers(transformers transformers) func(*config) { - return func(config *config) { - config.transformers = transformers +func WithTransformers(transformers Transformers) func(*Config) { + return func(config *Config) { + config.Transformers = transformers } } // WithOverride will make merge override non-empty dst attributes with non-empty src attributes values. -func WithOverride(config *config) { - config.overwrite = true +func WithOverride(config *Config) { + config.Overwrite = true +} + +// WithAppendSlice will make merge append slices instead of overwriting it +func WithAppendSlice(config *Config) { + config.AppendSlice = true } -func merge(dst, src interface{}, opts ...func(*config)) error { +func merge(dst, src interface{}, opts ...func(*Config)) error { var ( vDst, vSrc reflect.Value err error ) - config := &config{} + config := &Config{} for _, opt := range opts { opt(config) diff --git a/vendor/github.com/json-iterator/go/config.go b/vendor/github.com/json-iterator/go/config.go index b69cdbfc372..bd66947d7c8 100644 --- a/vendor/github.com/json-iterator/go/config.go +++ b/vendor/github.com/json-iterator/go/config.go @@ -2,11 +2,12 @@ package jsoniter import ( "encoding/json" + "github.com/modern-go/concurrent" "github.com/modern-go/reflect2" "io" + "reflect" "sync" "unsafe" - "github.com/modern-go/concurrent" ) // Config customize how the API should behave. @@ -39,6 +40,8 @@ type API interface { NewDecoder(reader io.Reader) *Decoder Valid(data []byte) bool RegisterExtension(extension Extension) + DecoderOf(typ reflect2.Type) ValDecoder + EncoderOf(typ reflect2.Type) ValEncoder } // ConfigDefault the default API @@ -60,7 +63,6 @@ var ConfigFastest = Config{ ObjectFieldMustBeSimpleString: true, // do not unescape object field }.Froze() - type frozenConfig struct { configBeforeFrozen Config sortMapKeys bool @@ -104,7 +106,7 @@ func (cfg *frozenConfig) getEncoderFromCache(cacheKey uintptr) ValEncoder { return nil } -var cfgCache = &sync.Map{} +var cfgCache = concurrent.NewMap() func getFrozenConfigFromCache(cfg Config) *frozenConfig { obj, found := cfgCache.Load(cfg) @@ -192,6 +194,11 @@ func (cfg *frozenConfig) validateJsonRawMessage(extension EncoderExtension) { func (cfg *frozenConfig) useNumber(extension DecoderExtension) { extension[reflect2.TypeOfPtr((*interface{})(nil)).Elem()] = &funcDecoder{func(ptr unsafe.Pointer, iter *Iterator) { + exitingValue := *((*interface{})(ptr)) + if exitingValue != nil && reflect.TypeOf(exitingValue).Kind() == reflect.Ptr { + iter.ReadVal(exitingValue) + return + } if iter.WhatIsNext() == NumberValue { *((*interface{})(ptr)) = json.Number(iter.readNumberAsString()) } else { diff --git a/vendor/github.com/json-iterator/go/reflect_map.go b/vendor/github.com/json-iterator/go/reflect_map.go index f34d519f9c7..8812f085016 100644 --- a/vendor/github.com/json-iterator/go/reflect_map.go +++ b/vendor/github.com/json-iterator/go/reflect_map.go @@ -3,6 +3,7 @@ package jsoniter import ( "fmt" "github.com/modern-go/reflect2" + "io" "reflect" "sort" "unsafe" @@ -107,6 +108,9 @@ func encoderOfMapKey(ctx *ctx, typ reflect2.Type) ValEncoder { stringEncoder: ctx.EncoderOf(reflect2.TypeOf("")), } } + if typ.Kind() == reflect.Interface { + return &dynamicMapKeyEncoder{ctx, typ} + } return &lazyErrorEncoder{err: fmt.Errorf("unsupported map key type: %v", typ)} } } @@ -203,6 +207,21 @@ func (encoder *numericMapKeyEncoder) IsEmpty(ptr unsafe.Pointer) bool { return false } +type dynamicMapKeyEncoder struct { + ctx *ctx + valType reflect2.Type +} + +func (encoder *dynamicMapKeyEncoder) Encode(ptr unsafe.Pointer, stream *Stream) { + obj := encoder.valType.UnsafeIndirect(ptr) + encoderOfMapKey(encoder.ctx, reflect2.TypeOf(obj)).Encode(reflect2.PtrOf(obj), stream) +} + +func (encoder *dynamicMapKeyEncoder) IsEmpty(ptr unsafe.Pointer) bool { + obj := encoder.valType.UnsafeIndirect(ptr) + return encoderOfMapKey(encoder.ctx, reflect2.TypeOf(obj)).IsEmpty(reflect2.PtrOf(obj)) +} + type mapEncoder struct { mapType *reflect2.UnsafeMapType keyEncoder ValEncoder @@ -253,6 +272,9 @@ func (encoder *sortKeysMapEncoder) Encode(ptr unsafe.Pointer, stream *Stream) { subStream.buf = make([]byte, 0, 64) key, elem := mapIter.UnsafeNext() encoder.keyEncoder.Encode(key, subStream) + if subStream.Error != nil && subStream.Error != io.EOF && stream.Error == nil { + stream.Error = subStream.Error + } encodedKey := subStream.Buffer() subIter.ResetBytes(encodedKey) decodedKey := subIter.ReadString() diff --git a/vendor/github.com/mailru/easyjson/jlexer/lexer.go b/vendor/github.com/mailru/easyjson/jlexer/lexer.go index e5558ae39c9..0fd9b122f09 100644 --- a/vendor/github.com/mailru/easyjson/jlexer/lexer.go +++ b/vendor/github.com/mailru/easyjson/jlexer/lexer.go @@ -997,6 +997,22 @@ func (r *Lexer) Float32() float32 { return float32(n) } +func (r *Lexer) Float32Str() float32 { + s, b := r.unsafeString() + if !r.Ok() { + return 0 + } + n, err := strconv.ParseFloat(s, 32) + if err != nil { + r.addNonfatalError(&LexerError{ + Offset: r.start, + Reason: err.Error(), + Data: string(b), + }) + } + return float32(n) +} + func (r *Lexer) Float64() float64 { s := r.number() if !r.Ok() { @@ -1014,6 +1030,22 @@ func (r *Lexer) Float64() float64 { return n } +func (r *Lexer) Float64Str() float64 { + s, b := r.unsafeString() + if !r.Ok() { + return 0 + } + n, err := strconv.ParseFloat(s, 64) + if err != nil { + r.addNonfatalError(&LexerError{ + Offset: r.start, + Reason: err.Error(), + Data: string(b), + }) + } + return n +} + func (r *Lexer) Error() error { return r.fatalError } @@ -1056,7 +1088,7 @@ func (r *Lexer) JsonNumber() json.Number { } if !r.Ok() { r.errInvalidToken("json.Number") - return json.Number("0") + return json.Number("") } switch r.token.kind { @@ -1064,9 +1096,12 @@ func (r *Lexer) JsonNumber() json.Number { return json.Number(r.String()) case tokenNumber: return json.Number(r.Raw()) + case tokenNull: + r.Null() + return json.Number("") default: r.errSyntax() - return json.Number("0") + return json.Number("") } } diff --git a/vendor/github.com/mailru/easyjson/jwriter/writer.go b/vendor/github.com/mailru/easyjson/jwriter/writer.go index e5a5ddfdbf1..b9ed7ccaa8b 100644 --- a/vendor/github.com/mailru/easyjson/jwriter/writer.go +++ b/vendor/github.com/mailru/easyjson/jwriter/writer.go @@ -240,11 +240,25 @@ func (w *Writer) Float32(n float32) { w.Buffer.Buf = strconv.AppendFloat(w.Buffer.Buf, float64(n), 'g', -1, 32) } +func (w *Writer) Float32Str(n float32) { + w.Buffer.EnsureSpace(20) + w.Buffer.Buf = append(w.Buffer.Buf, '"') + w.Buffer.Buf = strconv.AppendFloat(w.Buffer.Buf, float64(n), 'g', -1, 32) + w.Buffer.Buf = append(w.Buffer.Buf, '"') +} + 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) Float64Str(n float64) { + w.Buffer.EnsureSpace(20) + w.Buffer.Buf = append(w.Buffer.Buf, '"') + w.Buffer.Buf = strconv.AppendFloat(w.Buffer.Buf, float64(n), 'g', -1, 64) + w.Buffer.Buf = append(w.Buffer.Buf, '"') +} + func (w *Writer) Bool(v bool) { w.Buffer.EnsureSpace(5) if v { @@ -340,12 +354,11 @@ func (w *Writer) base64(in []byte) { return } - w.Buffer.EnsureSpace(((len(in) - 1) / 3 + 1) * 4) + w.Buffer.EnsureSpace(((len(in)-1)/3 + 1) * 4) si := 0 n := (len(in) / 3) * 3 - for si < n { // Convert 3x 8bit source bytes into 4 bytes val := uint(in[si+0])<<16 | uint(in[si+1])<<8 | uint(in[si+2]) diff --git a/vendor/github.com/matttproud/golang_protobuf_extensions/pbutil/.gitignore b/vendor/github.com/matttproud/golang_protobuf_extensions/pbutil/.gitignore new file mode 100644 index 00000000000..e16fb946bb9 --- /dev/null +++ b/vendor/github.com/matttproud/golang_protobuf_extensions/pbutil/.gitignore @@ -0,0 +1 @@ +cover.dat diff --git a/vendor/github.com/matttproud/golang_protobuf_extensions/pbutil/Makefile b/vendor/github.com/matttproud/golang_protobuf_extensions/pbutil/Makefile new file mode 100644 index 00000000000..81be214370d --- /dev/null +++ b/vendor/github.com/matttproud/golang_protobuf_extensions/pbutil/Makefile @@ -0,0 +1,7 @@ +all: + +cover: + go test -cover -v -coverprofile=cover.dat ./... + go tool cover -func cover.dat + +.PHONY: cover diff --git a/vendor/github.com/prometheus/common/expfmt/decode.go b/vendor/github.com/prometheus/common/expfmt/decode.go index a7a42d5ef41..c092723e84a 100644 --- a/vendor/github.com/prometheus/common/expfmt/decode.go +++ b/vendor/github.com/prometheus/common/expfmt/decode.go @@ -164,9 +164,9 @@ func (sd *SampleDecoder) Decode(s *model.Vector) error { } // ExtractSamples builds a slice of samples from the provided metric -// families. If an error occurs during sample extraction, it continues to +// families. If an error occurrs during sample extraction, it continues to // extract from the remaining metric families. The returned error is the last -// error that has occured. +// error that has occurred. func ExtractSamples(o *DecodeOptions, fams ...*dto.MetricFamily) (model.Vector, error) { var ( all model.Vector diff --git a/vendor/github.com/prometheus/common/expfmt/text_parse.go b/vendor/github.com/prometheus/common/expfmt/text_parse.go index 54bcfde2946..b86290afa39 100644 --- a/vendor/github.com/prometheus/common/expfmt/text_parse.go +++ b/vendor/github.com/prometheus/common/expfmt/text_parse.go @@ -556,8 +556,8 @@ func (p *TextParser) readTokenUntilWhitespace() { // byte considered is the byte already read (now in p.currentByte). The first // newline byte encountered is still copied into p.currentByte, but not into // p.currentToken. If recognizeEscapeSequence is true, two escape sequences are -// recognized: '\\' tranlates into '\', and '\n' into a line-feed character. All -// other escape sequences are invalid and cause an error. +// recognized: '\\' translates into '\', and '\n' into a line-feed character. +// All other escape sequences are invalid and cause an error. func (p *TextParser) readTokenUntilNewline(recognizeEscapeSequence bool) { p.currentToken.Reset() escaped := false diff --git a/vendor/github.com/prometheus/common/model/silence.go b/vendor/github.com/prometheus/common/model/silence.go index 7538e299774..bb99889d2cc 100644 --- a/vendor/github.com/prometheus/common/model/silence.go +++ b/vendor/github.com/prometheus/common/model/silence.go @@ -59,8 +59,8 @@ func (m *Matcher) Validate() error { return nil } -// Silence defines the representation of a silence definiton -// in the Prometheus eco-system. +// Silence defines the representation of a silence definition in the Prometheus +// eco-system. type Silence struct { ID uint64 `json:"id,omitempty"` diff --git a/vendor/github.com/prometheus/common/model/value.go b/vendor/github.com/prometheus/common/model/value.go index c9ed3ffd82a..c9d8fb1a283 100644 --- a/vendor/github.com/prometheus/common/model/value.go +++ b/vendor/github.com/prometheus/common/model/value.go @@ -100,7 +100,7 @@ func (s *SamplePair) UnmarshalJSON(b []byte) error { } // Equal returns true if this SamplePair and o have equal Values and equal -// Timestamps. The sematics of Value equality is defined by SampleValue.Equal. +// Timestamps. The semantics of Value equality is defined by SampleValue.Equal. func (s *SamplePair) Equal(o *SamplePair) bool { return s == o || (s.Value.Equal(o.Value) && s.Timestamp.Equal(o.Timestamp)) } @@ -117,7 +117,7 @@ type Sample struct { } // Equal compares first the metrics, then the timestamp, then the value. The -// sematics of value equality is defined by SampleValue.Equal. +// semantics of value equality is defined by SampleValue.Equal. func (s *Sample) Equal(o *Sample) bool { if s == o { return true diff --git a/vendor/github.com/prometheus/procfs/net_dev.go b/vendor/github.com/prometheus/procfs/net_dev.go index 6c17affe8ab..3f2523371ab 100644 --- a/vendor/github.com/prometheus/procfs/net_dev.go +++ b/vendor/github.com/prometheus/procfs/net_dev.go @@ -184,7 +184,7 @@ func (nd NetDev) parseLine(rawLine string) (*NetDevLine, error) { } // Total aggregates the values across interfaces and returns a new NetDevLine. -// The Name field will be a sorted comma seperated list of interface names. +// The Name field will be a sorted comma separated list of interface names. func (nd NetDev) Total() NetDevLine { total := NetDevLine{} diff --git a/vendor/github.com/prometheus/procfs/nfs/nfs.go b/vendor/github.com/prometheus/procfs/nfs/nfs.go index e2185b7827a..651bf681952 100644 --- a/vendor/github.com/prometheus/procfs/nfs/nfs.go +++ b/vendor/github.com/prometheus/procfs/nfs/nfs.go @@ -11,7 +11,7 @@ // See the License for the specific language governing permissions and // limitations under the License. -// Package nfsd implements parsing of /proc/net/rpc/nfsd. +// Package nfs implements parsing of /proc/net/rpc/nfsd. // Fields are documented in https://www.svennd.be/nfsd-stats-explained-procnetrpcnfsd/ package nfs @@ -136,8 +136,8 @@ type ClientV4Stats struct { Setattr uint64 FsInfo uint64 Renew uint64 - SetClientId uint64 - SetClientIdConfirm uint64 + SetClientID uint64 + SetClientIDConfirm uint64 Lock uint64 Lockt uint64 Locku uint64 @@ -156,13 +156,13 @@ type ClientV4Stats struct { ReadDir uint64 ServerCaps uint64 DelegReturn uint64 - GetAcl uint64 - SetAcl uint64 + GetACL uint64 + SetACL uint64 FsLocations uint64 ReleaseLockowner uint64 Secinfo uint64 FsidPresent uint64 - ExchangeId uint64 + ExchangeID uint64 CreateSession uint64 DestroySession uint64 Sequence uint64 @@ -173,11 +173,11 @@ type ClientV4Stats struct { LayoutCommit uint64 LayoutReturn uint64 SecinfoNoName uint64 - TestStateId uint64 - FreeStateId uint64 + TestStateID uint64 + FreeStateID uint64 GetDeviceList uint64 BindConnToSession uint64 - DestroyClientId uint64 + DestroyClientID uint64 Seek uint64 Allocate uint64 DeAllocate uint64 @@ -238,7 +238,7 @@ type V4Ops struct { RelLockOwner uint64 } -// RPCStats models all stats from /proc/net/rpc/nfs. +// ClientRPCStats models all stats from /proc/net/rpc/nfs. type ClientRPCStats struct { Network Network ClientRPC ClientRPC diff --git a/vendor/github.com/prometheus/procfs/nfs/parse.go b/vendor/github.com/prometheus/procfs/nfs/parse.go index 8f568f0116d..95a83cc5bc5 100644 --- a/vendor/github.com/prometheus/procfs/nfs/parse.go +++ b/vendor/github.com/prometheus/procfs/nfs/parse.go @@ -204,8 +204,8 @@ func parseClientV4Stats(v []uint64) (ClientV4Stats, error) { Setattr: v[10], FsInfo: v[11], Renew: v[12], - SetClientId: v[13], - SetClientIdConfirm: v[14], + SetClientID: v[13], + SetClientIDConfirm: v[14], Lock: v[15], Lockt: v[16], Locku: v[17], @@ -224,13 +224,13 @@ func parseClientV4Stats(v []uint64) (ClientV4Stats, error) { ReadDir: v[30], ServerCaps: v[31], DelegReturn: v[32], - GetAcl: v[33], - SetAcl: v[34], + GetACL: v[33], + SetACL: v[34], FsLocations: v[35], ReleaseLockowner: v[36], Secinfo: v[37], FsidPresent: v[38], - ExchangeId: v[39], + ExchangeID: v[39], CreateSession: v[40], DestroySession: v[41], Sequence: v[42], @@ -241,11 +241,11 @@ func parseClientV4Stats(v []uint64) (ClientV4Stats, error) { LayoutCommit: v[47], LayoutReturn: v[48], SecinfoNoName: v[49], - TestStateId: v[50], - FreeStateId: v[51], + TestStateID: v[50], + FreeStateID: v[51], GetDeviceList: v[52], BindConnToSession: v[53], - DestroyClientId: v[54], + DestroyClientID: v[54], Seek: v[55], Allocate: v[56], DeAllocate: v[57], diff --git a/vendor/github.com/prometheus/procfs/ttar b/vendor/github.com/prometheus/procfs/ttar index b514e731222..b0171a12b59 100755 --- a/vendor/github.com/prometheus/procfs/ttar +++ b/vendor/github.com/prometheus/procfs/ttar @@ -229,13 +229,13 @@ function extract { # The repeated pattern makes up for sed's lack of negative # lookbehind assertions (for consecutive null bytes). echo -n "$line" | \ - sed 's/^NULLBYTE/\x0/g' | \ - sed 's/\([^\\]\)NULLBYTE/\1\x0/g' | \ - sed 's/\([^\\]\)NULLBYTE/\1\x0/g' | \ - sed 's/\\NULLBYTE/NULLBYTE/g' | \ - sed 's/\([^\\]\)EOF/\1/g' | \ - sed 's/\\EOF/EOF/g' \ - >> "$path" + sed -e 's/^NULLBYTE/\x0/g; + s/\([^\\]\)NULLBYTE/\1\x0/g; + s/\([^\\]\)NULLBYTE/\1\x0/g; + s/\\NULLBYTE/NULLBYTE/g; + s/\([^\\]\)EOF/\1/g; + s/\\EOF/EOF/g; + ' >> "$path" fi if [[ "$eof_without_newline" -eq 0 ]]; then echo >> "$path" @@ -283,11 +283,14 @@ function get_mode { local mfile=$1 if [ -z "${STAT_OPTION:-}" ]; then if stat -c '%a' "$mfile" >/dev/null 2>&1; then + # GNU stat STAT_OPTION='-c' STAT_FORMAT='%a' else + # BSD stat STAT_OPTION='-f' - STAT_FORMAT='%A' + # Octal output, user/group/other (omit file type, sticky bit) + STAT_FORMAT='%OLp' fi fi stat "${STAT_OPTION}" "${STAT_FORMAT}" "$mfile" @@ -334,9 +337,10 @@ function _create { < "$file" python -c "$PYTHON_CREATE_FILTER" else < "$file" \ - sed 's/EOF/\\EOF/g' | \ - sed 's/NULLBYTE/\\NULLBYTE/g' | \ - sed 's/\x0/NULLBYTE/g' + sed 's/EOF/\\EOF/g; + s/NULLBYTE/\\NULLBYTE/g; + s/\x0/NULLBYTE/g; + ' fi if [[ "$eof_without_newline" -eq 1 ]]; then # Finish line with EOF to indicate that the original line did diff --git a/vendor/github.com/sirupsen/logrus/CHANGELOG.md b/vendor/github.com/sirupsen/logrus/CHANGELOG.md index cc58f6451fa..1bd1deb2947 100644 --- a/vendor/github.com/sirupsen/logrus/CHANGELOG.md +++ b/vendor/github.com/sirupsen/logrus/CHANGELOG.md @@ -1,3 +1,8 @@ +# 1.0.5 + +* Fix hooks race (#707) +* Fix panic deadlock (#695) + # 1.0.4 * Fix race when adding hooks (#612) diff --git a/vendor/github.com/sirupsen/logrus/README.md b/vendor/github.com/sirupsen/logrus/README.md index 08584b5fc24..f77819b1686 100644 --- a/vendor/github.com/sirupsen/logrus/README.md +++ b/vendor/github.com/sirupsen/logrus/README.md @@ -220,7 +220,7 @@ Logrus comes with [built-in hooks](hooks/). Add those, or your custom hook, in ```go import ( log "github.com/sirupsen/logrus" - "gopkg.in/gemnasium/logrus-airbrake-hook.v2" // the package is named "aibrake" + "gopkg.in/gemnasium/logrus-airbrake-hook.v2" // the package is named "airbrake" logrus_syslog "github.com/sirupsen/logrus/hooks/syslog" "log/syslog" ) @@ -247,6 +247,7 @@ Note: Syslog hook also support connecting to local syslog (Ex. "/dev/log" or "/v | [Airbrake](https://github.com/gemnasium/logrus-airbrake-hook) | Send errors to the Airbrake API V3. Uses the official [`gobrake`](https://github.com/airbrake/gobrake) behind the scenes. | | [Amazon Kinesis](https://github.com/evalphobia/logrus_kinesis) | Hook for logging to [Amazon Kinesis](https://aws.amazon.com/kinesis/) | | [Amqp-Hook](https://github.com/vladoatanasov/logrus_amqp) | Hook for logging to Amqp broker (Like RabbitMQ) | +| [Application Insights](https://github.com/jjcollinge/logrus-appinsights) | Hook for logging to [Application Insights](https://azure.microsoft.com/en-us/services/application-insights/) | [AzureTableHook](https://github.com/kpfaulkner/azuretablehook/) | Hook for logging to Azure Table Storage| | [Bugsnag](https://github.com/Shopify/logrus-bugsnag/blob/master/bugsnag.go) | Send errors to the Bugsnag exception tracking service. | | [DeferPanic](https://github.com/deferpanic/dp-logrus) | Hook for logging to DeferPanic | @@ -262,6 +263,7 @@ Note: Syslog hook also support connecting to local syslog (Ex. "/dev/log" or "/v | [Influxus](http://github.com/vlad-doru/influxus) | Hook for concurrently logging to [InfluxDB](http://influxdata.com/) | | [Journalhook](https://github.com/wercker/journalhook) | Hook for logging to `systemd-journald` | | [KafkaLogrus](https://github.com/tracer0tong/kafkalogrus) | Hook for logging to Kafka | +| [Kafka REST Proxy](https://github.com/Nordstrom/logrus-kafka-rest-proxy) | Hook for logging to [Kafka REST Proxy](https://docs.confluent.io/current/kafka-rest/docs) | | [LFShook](https://github.com/rifflock/lfshook) | Hook for logging to the local filesystem | | [Logbeat](https://github.com/macandmia/logbeat) | Hook for logging to [Opbeat](https://opbeat.com/) | | [Logentries](https://github.com/jcftang/logentriesrus) | Hook for logging to [Logentries](https://logentries.com/) | diff --git a/vendor/github.com/sirupsen/logrus/entry.go b/vendor/github.com/sirupsen/logrus/entry.go index 1fad45e0823..778f4c9f0d3 100644 --- a/vendor/github.com/sirupsen/logrus/entry.go +++ b/vendor/github.com/sirupsen/logrus/entry.go @@ -94,38 +94,47 @@ func (entry Entry) log(level Level, msg string) { entry.Level = level entry.Message = msg - entry.Logger.mu.Lock() - err := entry.Logger.Hooks.Fire(level, &entry) - entry.Logger.mu.Unlock() - if err != nil { - entry.Logger.mu.Lock() - fmt.Fprintf(os.Stderr, "Failed to fire hook: %v\n", err) - entry.Logger.mu.Unlock() - } + entry.fireHooks() + buffer = bufferPool.Get().(*bytes.Buffer) buffer.Reset() defer bufferPool.Put(buffer) entry.Buffer = buffer - serialized, err := entry.Logger.Formatter.Format(&entry) + + entry.write() + entry.Buffer = nil + + // To avoid Entry#log() returning a value that only would make sense for + // panic() to use in Entry#Panic(), we avoid the allocation by checking + // directly here. + if level <= PanicLevel { + panic(&entry) + } +} + +// This function is not declared with a pointer value because otherwise +// race conditions will occur when using multiple goroutines +func (entry Entry) fireHooks() { + entry.Logger.mu.Lock() + defer entry.Logger.mu.Unlock() + err := entry.Logger.Hooks.Fire(entry.Level, &entry) + if err != nil { + fmt.Fprintf(os.Stderr, "Failed to fire hook: %v\n", err) + } +} + +func (entry *Entry) write() { + serialized, err := entry.Logger.Formatter.Format(entry) + entry.Logger.mu.Lock() + defer entry.Logger.mu.Unlock() if err != nil { - entry.Logger.mu.Lock() fmt.Fprintf(os.Stderr, "Failed to obtain reader, %v\n", err) - entry.Logger.mu.Unlock() } else { - entry.Logger.mu.Lock() _, err = entry.Logger.Out.Write(serialized) if err != nil { fmt.Fprintf(os.Stderr, "Failed to write to log, %v\n", err) } - entry.Logger.mu.Unlock() - } - - // To avoid Entry#log() returning a value that only would make sense for - // panic() to use in Entry#Panic(), we avoid the allocation by checking - // directly here. - if level <= PanicLevel { - panic(&entry) } } diff --git a/vendor/github.com/sirupsen/logrus/terminal_bsd.go b/vendor/github.com/sirupsen/logrus/terminal_bsd.go index d7b3893f3fe..4880d13d26d 100644 --- a/vendor/github.com/sirupsen/logrus/terminal_bsd.go +++ b/vendor/github.com/sirupsen/logrus/terminal_bsd.go @@ -1,5 +1,5 @@ // +build darwin freebsd openbsd netbsd dragonfly -// +build !appengine +// +build !appengine,!gopherjs package logrus diff --git a/vendor/github.com/sirupsen/logrus/terminal_check_appengine.go b/vendor/github.com/sirupsen/logrus/terminal_check_appengine.go index 2403de98192..3de08e802fd 100644 --- a/vendor/github.com/sirupsen/logrus/terminal_check_appengine.go +++ b/vendor/github.com/sirupsen/logrus/terminal_check_appengine.go @@ -1,4 +1,4 @@ -// +build appengine +// +build appengine gopherjs package logrus diff --git a/vendor/github.com/sirupsen/logrus/terminal_check_notappengine.go b/vendor/github.com/sirupsen/logrus/terminal_check_notappengine.go index 116bcb4e339..067047a1233 100644 --- a/vendor/github.com/sirupsen/logrus/terminal_check_notappengine.go +++ b/vendor/github.com/sirupsen/logrus/terminal_check_notappengine.go @@ -1,4 +1,4 @@ -// +build !appengine +// +build !appengine,!gopherjs package logrus diff --git a/vendor/github.com/sirupsen/logrus/terminal_linux.go b/vendor/github.com/sirupsen/logrus/terminal_linux.go index 88d7298e24f..f29a0097c81 100644 --- a/vendor/github.com/sirupsen/logrus/terminal_linux.go +++ b/vendor/github.com/sirupsen/logrus/terminal_linux.go @@ -3,7 +3,7 @@ // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. -// +build !appengine +// +build !appengine,!gopherjs package logrus diff --git a/vendor/github.com/spf13/cobra/.travis.yml b/vendor/github.com/spf13/cobra/.travis.yml index 68efa136331..5afcb209619 100644 --- a/vendor/github.com/spf13/cobra/.travis.yml +++ b/vendor/github.com/spf13/cobra/.travis.yml @@ -2,8 +2,8 @@ language: go matrix: include: - - go: 1.7.6 - - go: 1.8.3 + - go: 1.9.4 + - go: 1.10.0 - go: tip allow_failures: - go: tip diff --git a/vendor/github.com/spf13/cobra/README.md b/vendor/github.com/spf13/cobra/README.md index 373a056ba19..851fcc087ca 100644 --- a/vendor/github.com/spf13/cobra/README.md +++ b/vendor/github.com/spf13/cobra/README.md @@ -20,6 +20,7 @@ Many of the most widely used Go projects are built using Cobra including: * [Nanobox](https://github.com/nanobox-io/nanobox)/[Nanopack](https://github.com/nanopack) * [rclone](http://rclone.org/) * [nehm](https://github.com/bogem/nehm) +* [Pouch](https://github.com/alibaba/pouch) [![Build Status](https://travis-ci.org/spf13/cobra.svg "Travis CI status")](https://travis-ci.org/spf13/cobra) [![CircleCI status](https://circleci.com/gh/spf13/cobra.png?circle-token=:circle-token "CircleCI status")](https://circleci.com/gh/spf13/cobra) @@ -158,10 +159,7 @@ import ( ) func main() { - if err := cmd.RootCmd.Execute(); err != nil { - fmt.Println(err) - os.Exit(1) - } + cmd.Execute() } ``` @@ -174,7 +172,7 @@ commands you want. It's the easiest way to incorporate Cobra into your applicati ## Using the Cobra Library -To manually implement Cobra you need to create a bare main.go file and a RootCmd file. +To manually implement Cobra you need to create a bare main.go file and a rootCmd file. You will optionally provide additional commands as you see fit. ### Create rootCmd @@ -184,7 +182,7 @@ Cobra doesn't require any special constructors. Simply create your commands. Ideally you place this in app/cmd/root.go: ```go -var RootCmd = &cobra.Command{ +var rootCmd = &cobra.Command{ Use: "hugo", Short: "Hugo is a very fast static site generator", Long: `A Fast and Flexible Static Site Generator built with @@ -194,6 +192,13 @@ var RootCmd = &cobra.Command{ // Do Stuff Here }, } + +func Execute() { + if err := rootCmd.Execute(); err != nil { + fmt.Println(err) + os.Exit(1) + } +} ``` You will additionally define flags and handle configuration in your init() function. @@ -212,22 +217,18 @@ import ( func init() { cobra.OnInitialize(initConfig) - RootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.cobra.yaml)") - RootCmd.PersistentFlags().StringVarP(&projectBase, "projectbase", "b", "", "base project directory eg. github.com/spf13/") - RootCmd.PersistentFlags().StringP("author", "a", "YOUR NAME", "Author name for copyright attribution") - RootCmd.PersistentFlags().StringVarP(&userLicense, "license", "l", "", "Name of license for the project (can provide `licensetext` in config)") - RootCmd.PersistentFlags().Bool("viper", true, "Use Viper for configuration") - viper.BindPFlag("author", RootCmd.PersistentFlags().Lookup("author")) - viper.BindPFlag("projectbase", RootCmd.PersistentFlags().Lookup("projectbase")) - viper.BindPFlag("useViper", RootCmd.PersistentFlags().Lookup("viper")) + rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.cobra.yaml)") + rootCmd.PersistentFlags().StringVarP(&projectBase, "projectbase", "b", "", "base project directory eg. github.com/spf13/") + rootCmd.PersistentFlags().StringP("author", "a", "YOUR NAME", "Author name for copyright attribution") + rootCmd.PersistentFlags().StringVarP(&userLicense, "license", "l", "", "Name of license for the project (can provide `licensetext` in config)") + rootCmd.PersistentFlags().Bool("viper", true, "Use Viper for configuration") + viper.BindPFlag("author", rootCmd.PersistentFlags().Lookup("author")) + viper.BindPFlag("projectbase", rootCmd.PersistentFlags().Lookup("projectbase")) + viper.BindPFlag("useViper", rootCmd.PersistentFlags().Lookup("viper")) viper.SetDefault("author", "NAME HERE ") viper.SetDefault("license", "apache") } -func Execute() { - RootCmd.Execute() -} - func initConfig() { // Don't forget to read config either from cfgFile or from home directory! if cfgFile != "" { @@ -271,10 +272,7 @@ import ( ) func main() { - if err := cmd.RootCmd.Execute(); err != nil { - fmt.Println(err) - os.Exit(1) - } + cmd.Execute() } ``` @@ -290,12 +288,13 @@ populate it with the following: package cmd import ( - "github.com/spf13/cobra" "fmt" + + "github.com/spf13/cobra" ) func init() { - RootCmd.AddCommand(versionCmd) + rootCmd.AddCommand(versionCmd) } var versionCmd = &cobra.Command{ @@ -332,7 +331,7 @@ command it's assigned to as well as every command under that command. For global flags, assign a flag as a persistent flag on the root. ```go -RootCmd.PersistentFlags().BoolVarP(&Verbose, "verbose", "v", false, "verbose output") +rootCmd.PersistentFlags().BoolVarP(&Verbose, "verbose", "v", false, "verbose output") ``` ### Local Flags @@ -340,13 +339,13 @@ RootCmd.PersistentFlags().BoolVarP(&Verbose, "verbose", "v", false, "verbose out A flag can also be assigned locally which will only apply to that specific command. ```go -RootCmd.Flags().StringVarP(&Source, "source", "s", "", "Source directory to read from") +rootCmd.Flags().StringVarP(&Source, "source", "s", "", "Source directory to read from") ``` ### Local Flag on Parent Commands -By default Cobra only parses local flags on the target command, any local flags on -parent commands are ignored. By enabling `Command.TraverseChildren` Cobra will +By default Cobra only parses local flags on the target command, any local flags on +parent commands are ignored. By enabling `Command.TraverseChildren` Cobra will parse local flags on each command before executing the target command. ```go @@ -363,8 +362,8 @@ You can also bind your flags with [viper](https://github.com/spf13/viper): var author string func init() { - RootCmd.PersistentFlags().StringVar(&author, "author", "YOUR NAME", "Author name for copyright attribution") - viper.BindPFlag("author", RootCmd.PersistentFlags().Lookup("author")) + rootCmd.PersistentFlags().StringVar(&author, "author", "YOUR NAME", "Author name for copyright attribution") + viper.BindPFlag("author", rootCmd.PersistentFlags().Lookup("author")) } ``` @@ -374,6 +373,15 @@ when the `--author` flag is not provided by user. More in [viper documentation](https://github.com/spf13/viper#working-with-flags). +### Required flags + +Flags are optional by default. If instead you wish your command to report an error +when a flag has not been set, mark it as required: +```go +rootCmd.Flags().StringVarP(&Region, "region", "r", "", "AWS region (required)") +rootCmd.MarkFlagRequired("region") +``` + ## Positional and Custom Arguments Validation of positional arguments can be specified using the `Args` field @@ -522,7 +530,7 @@ around it. In fact, you can provide your own if you want. ### Defining your own help You can provide your own Help command or your own template for the default command to use -with followind functions: +with following functions: ```go cmd.SetHelpCommand(cmd *Command) @@ -569,6 +577,13 @@ cmd.SetUsageFunc(f func(*Command) error) cmd.SetUsageTemplate(s string) ``` +## Version Flag + +Cobra adds a top-level '--version' flag if the Version field is set on the root command. +Running an application with the '--version' flag will print the version to stdout using +the version template. The template can be customized using the +`cmd.SetVersionTemplate(s string)` function. + ## PreRun and PostRun Hooks It is possible to run functions before or after the main `Run` function of your command. The `PersistentPreRun` and `PreRun` functions will be executed before `Run`. `PersistentPostRun` and `PostRun` will be executed after `Run`. The `Persistent*Run` functions will be inherited by children if they do not declare their own. These functions are run in the following order: diff --git a/vendor/github.com/spf13/cobra/args.go b/vendor/github.com/spf13/cobra/args.go index 94a6ca2737e..a5d8a9273ea 100644 --- a/vendor/github.com/spf13/cobra/args.go +++ b/vendor/github.com/spf13/cobra/args.go @@ -16,14 +16,14 @@ func legacyArgs(cmd *Command, args []string) error { return nil } - // root command with subcommands, do subcommand checking + // root command with subcommands, do subcommand checking. if !cmd.HasParent() && len(args) > 0 { return fmt.Errorf("unknown command %q for %q%s", args[0], cmd.CommandPath(), cmd.findSuggestions(args[0])) } return nil } -// NoArgs returns an error if any args are included +// NoArgs returns an error if any args are included. func NoArgs(cmd *Command, args []string) error { if len(args) > 0 { return fmt.Errorf("unknown command %q for %q", args[0], cmd.CommandPath()) @@ -31,7 +31,7 @@ func NoArgs(cmd *Command, args []string) error { return nil } -// OnlyValidArgs returns an error if any args are not in the list of ValidArgs +// OnlyValidArgs returns an error if any args are not in the list of ValidArgs. func OnlyValidArgs(cmd *Command, args []string) error { if len(cmd.ValidArgs) > 0 { for _, v := range args { @@ -43,21 +43,12 @@ func OnlyValidArgs(cmd *Command, args []string) error { return nil } -func stringInSlice(a string, list []string) bool { - for _, b := range list { - if b == a { - return true - } - } - return false -} - -// ArbitraryArgs never returns an error +// ArbitraryArgs never returns an error. func ArbitraryArgs(cmd *Command, args []string) error { return nil } -// MinimumNArgs returns an error if there is not at least N args +// MinimumNArgs returns an error if there is not at least N args. func MinimumNArgs(n int) PositionalArgs { return func(cmd *Command, args []string) error { if len(args) < n { @@ -67,7 +58,7 @@ func MinimumNArgs(n int) PositionalArgs { } } -// MaximumNArgs returns an error if there are more than N args +// MaximumNArgs returns an error if there are more than N args. func MaximumNArgs(n int) PositionalArgs { return func(cmd *Command, args []string) error { if len(args) > n { @@ -77,7 +68,7 @@ func MaximumNArgs(n int) PositionalArgs { } } -// ExactArgs returns an error if there are not exactly n args +// ExactArgs returns an error if there are not exactly n args. func ExactArgs(n int) PositionalArgs { return func(cmd *Command, args []string) error { if len(args) != n { @@ -87,7 +78,7 @@ func ExactArgs(n int) PositionalArgs { } } -// RangeArgs returns an error if the number of args is not within the expected range +// RangeArgs returns an error if the number of args is not within the expected range. func RangeArgs(min int, max int) PositionalArgs { return func(cmd *Command, args []string) error { if len(args) < min || len(args) > max { diff --git a/vendor/github.com/spf13/cobra/bash_completions.go b/vendor/github.com/spf13/cobra/bash_completions.go index c19fe7a068b..8fa8f486fac 100644 --- a/vendor/github.com/spf13/cobra/bash_completions.go +++ b/vendor/github.com/spf13/cobra/bash_completions.go @@ -21,8 +21,8 @@ const ( func writePreamble(buf *bytes.Buffer, name string) { buf.WriteString(fmt.Sprintf("# bash completion for %-36s -*- shell-script -*-\n", name)) - buf.WriteString(` -__debug() + buf.WriteString(fmt.Sprintf(` +__%[1]s_debug() { if [[ -n ${BASH_COMP_DEBUG_FILE} ]]; then echo "$*" >> "${BASH_COMP_DEBUG_FILE}" @@ -31,13 +31,13 @@ __debug() # Homebrew on Macs have version 1.3 of bash-completion which doesn't include # _init_completion. This is a very minimal version of that function. -__my_init_completion() +__%[1]s_init_completion() { COMPREPLY=() _get_comp_words_by_ref "$@" cur prev words cword } -__index_of_word() +__%[1]s_index_of_word() { local w word=$1 shift @@ -49,7 +49,7 @@ __index_of_word() index=-1 } -__contains_word() +__%[1]s_contains_word() { local w word=$1; shift for w in "$@"; do @@ -58,9 +58,9 @@ __contains_word() return 1 } -__handle_reply() +__%[1]s_handle_reply() { - __debug "${FUNCNAME[0]}" + __%[1]s_debug "${FUNCNAME[0]}" case $cur in -*) if [[ $(type -t compopt) = "builtin" ]]; then @@ -85,7 +85,7 @@ __handle_reply() local index flag flag="${cur%%=*}" - __index_of_word "${flag}" "${flags_with_completion[@]}" + __%[1]s_index_of_word "${flag}" "${flags_with_completion[@]}" COMPREPLY=() if [[ ${index} -ge 0 ]]; then PREFIX="" @@ -103,7 +103,7 @@ __handle_reply() # check if we are handling a flag with special work handling local index - __index_of_word "${prev}" "${flags_with_completion[@]}" + __%[1]s_index_of_word "${prev}" "${flags_with_completion[@]}" if [[ ${index} -ge 0 ]]; then ${flags_completion[${index}]} return @@ -136,24 +136,30 @@ __handle_reply() if declare -F __ltrim_colon_completions >/dev/null; then __ltrim_colon_completions "$cur" fi + + # If there is only 1 completion and it is a flag with an = it will be completed + # but we don't want a space after the = + if [[ "${#COMPREPLY[@]}" -eq "1" ]] && [[ $(type -t compopt) = "builtin" ]] && [[ "${COMPREPLY[0]}" == --*= ]]; then + compopt -o nospace + fi } # The arguments should be in the form "ext1|ext2|extn" -__handle_filename_extension_flag() +__%[1]s_handle_filename_extension_flag() { local ext="$1" _filedir "@(${ext})" } -__handle_subdirs_in_dir_flag() +__%[1]s_handle_subdirs_in_dir_flag() { local dir="$1" pushd "${dir}" >/dev/null 2>&1 && _filedir -d && popd >/dev/null 2>&1 } -__handle_flag() +__%[1]s_handle_flag() { - __debug "${FUNCNAME[0]}: c is $c words[c] is ${words[c]}" + __%[1]s_debug "${FUNCNAME[0]}: c is $c words[c] is ${words[c]}" # if a command required a flag, and we found it, unset must_have_one_flag() local flagname=${words[c]} @@ -164,27 +170,30 @@ __handle_flag() flagname=${flagname%%=*} # strip everything after the = flagname="${flagname}=" # but put the = back fi - __debug "${FUNCNAME[0]}: looking for ${flagname}" - if __contains_word "${flagname}" "${must_have_one_flag[@]}"; then + __%[1]s_debug "${FUNCNAME[0]}: looking for ${flagname}" + if __%[1]s_contains_word "${flagname}" "${must_have_one_flag[@]}"; then must_have_one_flag=() fi # if you set a flag which only applies to this command, don't show subcommands - if __contains_word "${flagname}" "${local_nonpersistent_flags[@]}"; then + if __%[1]s_contains_word "${flagname}" "${local_nonpersistent_flags[@]}"; then commands=() fi # keep flag value with flagname as flaghash - if [ -n "${flagvalue}" ] ; then - flaghash[${flagname}]=${flagvalue} - elif [ -n "${words[ $((c+1)) ]}" ] ; then - flaghash[${flagname}]=${words[ $((c+1)) ]} - else - flaghash[${flagname}]="true" # pad "true" for bool flag + # flaghash variable is an associative array which is only supported in bash > 3. + if [[ -z "${BASH_VERSION}" || "${BASH_VERSINFO[0]}" -gt 3 ]]; then + if [ -n "${flagvalue}" ] ; then + flaghash[${flagname}]=${flagvalue} + elif [ -n "${words[ $((c+1)) ]}" ] ; then + flaghash[${flagname}]=${words[ $((c+1)) ]} + else + flaghash[${flagname}]="true" # pad "true" for bool flag + fi fi # skip the argument to a two word flag - if __contains_word "${words[c]}" "${two_word_flags[@]}"; then + if __%[1]s_contains_word "${words[c]}" "${two_word_flags[@]}"; then c=$((c+1)) # if we are looking for a flags value, don't show commands if [[ $c -eq $cword ]]; then @@ -196,13 +205,13 @@ __handle_flag() } -__handle_noun() +__%[1]s_handle_noun() { - __debug "${FUNCNAME[0]}: c is $c words[c] is ${words[c]}" + __%[1]s_debug "${FUNCNAME[0]}: c is $c words[c] is ${words[c]}" - if __contains_word "${words[c]}" "${must_have_one_noun[@]}"; then + if __%[1]s_contains_word "${words[c]}" "${must_have_one_noun[@]}"; then must_have_one_noun=() - elif __contains_word "${words[c]}" "${noun_aliases[@]}"; then + elif __%[1]s_contains_word "${words[c]}" "${noun_aliases[@]}"; then must_have_one_noun=() fi @@ -210,45 +219,53 @@ __handle_noun() c=$((c+1)) } -__handle_command() +__%[1]s_handle_command() { - __debug "${FUNCNAME[0]}: c is $c words[c] is ${words[c]}" + __%[1]s_debug "${FUNCNAME[0]}: c is $c words[c] is ${words[c]}" local next_command if [[ -n ${last_command} ]]; then next_command="_${last_command}_${words[c]//:/__}" else if [[ $c -eq 0 ]]; then - next_command="_$(basename "${words[c]//:/__}")" + next_command="_%[1]s_root_command" else next_command="_${words[c]//:/__}" fi fi c=$((c+1)) - __debug "${FUNCNAME[0]}: looking for ${next_command}" + __%[1]s_debug "${FUNCNAME[0]}: looking for ${next_command}" declare -F "$next_command" >/dev/null && $next_command } -__handle_word() +__%[1]s_handle_word() { if [[ $c -ge $cword ]]; then - __handle_reply + __%[1]s_handle_reply return fi - __debug "${FUNCNAME[0]}: c is $c words[c] is ${words[c]}" + __%[1]s_debug "${FUNCNAME[0]}: c is $c words[c] is ${words[c]}" if [[ "${words[c]}" == -* ]]; then - __handle_flag - elif __contains_word "${words[c]}" "${commands[@]}"; then - __handle_command - elif [[ $c -eq 0 ]] && __contains_word "$(basename "${words[c]}")" "${commands[@]}"; then - __handle_command + __%[1]s_handle_flag + elif __%[1]s_contains_word "${words[c]}" "${commands[@]}"; then + __%[1]s_handle_command + elif [[ $c -eq 0 ]]; then + __%[1]s_handle_command + elif __%[1]s_contains_word "${words[c]}" "${command_aliases[@]}"; then + # aliashash variable is an associative array which is only supported in bash > 3. + if [[ -z "${BASH_VERSION}" || "${BASH_VERSINFO[0]}" -gt 3 ]]; then + words[c]=${aliashash[${words[c]}]} + __%[1]s_handle_command + else + __%[1]s_handle_noun + fi else - __handle_noun + __%[1]s_handle_noun fi - __handle_word + __%[1]s_handle_word } -`) +`, name)) } func writePostscript(buf *bytes.Buffer, name string) { @@ -257,10 +274,11 @@ func writePostscript(buf *bytes.Buffer, name string) { buf.WriteString(fmt.Sprintf(`{ local cur prev words cword declare -A flaghash 2>/dev/null || : + declare -A aliashash 2>/dev/null || : if declare -F _init_completion >/dev/null 2>&1; then _init_completion -s || return else - __my_init_completion -n "=" || return + __%[1]s_init_completion -n "=" || return fi local c=0 @@ -269,13 +287,13 @@ func writePostscript(buf *bytes.Buffer, name string) { local local_nonpersistent_flags=() local flags_with_completion=() local flags_completion=() - local commands=("%s") + local commands=("%[1]s") local must_have_one_flag=() local must_have_one_noun=() local last_command local nouns=() - __handle_word + __%[1]s_handle_word } `, name)) @@ -296,11 +314,12 @@ func writeCommands(buf *bytes.Buffer, cmd *Command) { continue } buf.WriteString(fmt.Sprintf(" commands+=(%q)\n", c.Name())) + writeCmdAliases(buf, c) } buf.WriteString("\n") } -func writeFlagHandler(buf *bytes.Buffer, name string, annotations map[string][]string) { +func writeFlagHandler(buf *bytes.Buffer, name string, annotations map[string][]string, cmd *Command) { for key, value := range annotations { switch key { case BashCompFilenameExt: @@ -308,7 +327,7 @@ func writeFlagHandler(buf *bytes.Buffer, name string, annotations map[string][]s var ext string if len(value) > 0 { - ext = "__handle_filename_extension_flag " + strings.Join(value, "|") + ext = fmt.Sprintf("__%s_handle_filename_extension_flag ", cmd.Root().Name()) + strings.Join(value, "|") } else { ext = "_filedir" } @@ -326,7 +345,7 @@ func writeFlagHandler(buf *bytes.Buffer, name string, annotations map[string][]s var ext string if len(value) == 1 { - ext = "__handle_subdirs_in_dir_flag " + value[0] + ext = fmt.Sprintf("__%s_handle_subdirs_in_dir_flag ", cmd.Root().Name()) + value[0] } else { ext = "_filedir -d" } @@ -335,7 +354,7 @@ func writeFlagHandler(buf *bytes.Buffer, name string, annotations map[string][]s } } -func writeShortFlag(buf *bytes.Buffer, flag *pflag.Flag) { +func writeShortFlag(buf *bytes.Buffer, flag *pflag.Flag, cmd *Command) { name := flag.Shorthand format := " " if len(flag.NoOptDefVal) == 0 { @@ -343,10 +362,10 @@ func writeShortFlag(buf *bytes.Buffer, flag *pflag.Flag) { } format += "flags+=(\"-%s\")\n" buf.WriteString(fmt.Sprintf(format, name)) - writeFlagHandler(buf, "-"+name, flag.Annotations) + writeFlagHandler(buf, "-"+name, flag.Annotations, cmd) } -func writeFlag(buf *bytes.Buffer, flag *pflag.Flag) { +func writeFlag(buf *bytes.Buffer, flag *pflag.Flag, cmd *Command) { name := flag.Name format := " flags+=(\"--%s" if len(flag.NoOptDefVal) == 0 { @@ -354,7 +373,7 @@ func writeFlag(buf *bytes.Buffer, flag *pflag.Flag) { } format += "\")\n" buf.WriteString(fmt.Sprintf(format, name)) - writeFlagHandler(buf, "--"+name, flag.Annotations) + writeFlagHandler(buf, "--"+name, flag.Annotations, cmd) } func writeLocalNonPersistentFlag(buf *bytes.Buffer, flag *pflag.Flag) { @@ -380,9 +399,9 @@ func writeFlags(buf *bytes.Buffer, cmd *Command) { if nonCompletableFlag(flag) { return } - writeFlag(buf, flag) + writeFlag(buf, flag, cmd) if len(flag.Shorthand) > 0 { - writeShortFlag(buf, flag) + writeShortFlag(buf, flag, cmd) } if localNonPersistentFlags.Lookup(flag.Name) != nil { writeLocalNonPersistentFlag(buf, flag) @@ -392,9 +411,9 @@ func writeFlags(buf *bytes.Buffer, cmd *Command) { if nonCompletableFlag(flag) { return } - writeFlag(buf, flag) + writeFlag(buf, flag, cmd) if len(flag.Shorthand) > 0 { - writeShortFlag(buf, flag) + writeShortFlag(buf, flag, cmd) } }) @@ -434,6 +453,21 @@ func writeRequiredNouns(buf *bytes.Buffer, cmd *Command) { } } +func writeCmdAliases(buf *bytes.Buffer, cmd *Command) { + if len(cmd.Aliases) == 0 { + return + } + + sort.Sort(sort.StringSlice(cmd.Aliases)) + + buf.WriteString(fmt.Sprint(` if [[ -z "${BASH_VERSION}" || "${BASH_VERSINFO[0]}" -gt 3 ]]; then`, "\n")) + for _, value := range cmd.Aliases { + buf.WriteString(fmt.Sprintf(" command_aliases+=(%q)\n", value)) + buf.WriteString(fmt.Sprintf(" aliashash[%q]=%q\n", value, cmd.Name())) + } + buf.WriteString(` fi`) + buf.WriteString("\n") +} func writeArgAliases(buf *bytes.Buffer, cmd *Command) { buf.WriteString(" noun_aliases=()\n") sort.Sort(sort.StringSlice(cmd.ArgAliases)) @@ -452,8 +486,18 @@ func gen(buf *bytes.Buffer, cmd *Command) { commandName := cmd.CommandPath() commandName = strings.Replace(commandName, " ", "_", -1) commandName = strings.Replace(commandName, ":", "__", -1) - buf.WriteString(fmt.Sprintf("_%s()\n{\n", commandName)) + + if cmd.Root() == cmd { + buf.WriteString(fmt.Sprintf("_%s_root_command()\n{\n", commandName)) + } else { + buf.WriteString(fmt.Sprintf("_%s()\n{\n", commandName)) + } + buf.WriteString(fmt.Sprintf(" last_command=%q\n", commandName)) + buf.WriteString("\n") + buf.WriteString(" command_aliases=()\n") + buf.WriteString("\n") + writeCommands(buf, cmd) writeFlags(buf, cmd) writeRequiredFlag(buf, cmd) @@ -491,17 +535,20 @@ func (c *Command) GenBashCompletionFile(filename string) error { return c.GenBashCompletion(outFile) } -// MarkFlagRequired adds the BashCompOneRequiredFlag annotation to the named flag, if it exists. +// MarkFlagRequired adds the BashCompOneRequiredFlag annotation to the named flag if it exists, +// and causes your command to report an error if invoked without the flag. func (c *Command) MarkFlagRequired(name string) error { return MarkFlagRequired(c.Flags(), name) } -// MarkPersistentFlagRequired adds the BashCompOneRequiredFlag annotation to the named persistent flag, if it exists. +// MarkPersistentFlagRequired adds the BashCompOneRequiredFlag annotation to the named persistent flag if it exists, +// and causes your command to report an error if invoked without the flag. func (c *Command) MarkPersistentFlagRequired(name string) error { return MarkFlagRequired(c.PersistentFlags(), name) } -// MarkFlagRequired adds the BashCompOneRequiredFlag annotation to the named flag in the flag set, if it exists. +// MarkFlagRequired adds the BashCompOneRequiredFlag annotation to the named flag if it exists, +// and causes your command to report an error if invoked without the flag. func MarkFlagRequired(flags *pflag.FlagSet, name string) error { return flags.SetAnnotation(name, BashCompOneRequiredFlag, []string{"true"}) } diff --git a/vendor/github.com/spf13/cobra/bash_completions.md b/vendor/github.com/spf13/cobra/bash_completions.md index 52bd39ddb1d..e79d4769d10 100644 --- a/vendor/github.com/spf13/cobra/bash_completions.md +++ b/vendor/github.com/spf13/cobra/bash_completions.md @@ -6,15 +6,16 @@ Generating bash completions from a cobra command is incredibly easy. An actual p package main import ( - "io/ioutil" - "os" + "io/ioutil" + "os" - "github.com/GoogleCloudPlatform/kubernetes/pkg/kubectl/cmd" + "k8s.io/kubernetes/pkg/kubectl/cmd" + "k8s.io/kubernetes/pkg/kubectl/cmd/util" ) func main() { - kubectl := cmd.NewFactory(nil).NewKubectlCommand(os.Stdin, ioutil.Discard, ioutil.Discard) - kubectl.GenBashCompletionFile("out.sh") + kubectl := cmd.NewKubectlCommand(util.NewFactory(nil), os.Stdin, ioutil.Discard, ioutil.Discard) + kubectl.GenBashCompletionFile("out.sh") } ``` @@ -173,14 +174,14 @@ hello.yml test.json So while there are many other files in the CWD it only shows me subdirs and those with valid extensions. -# Specifiy custom flag completion +# Specify custom flag completion -Similar to the filename completion and filtering using cobra.BashCompFilenameExt, you can specifiy +Similar to the filename completion and filtering using cobra.BashCompFilenameExt, you can specify a custom flag completion function with cobra.BashCompCustom: ```go annotation := make(map[string][]string) - annotation[cobra.BashCompFilenameExt] = []string{"__kubectl_get_namespaces"} + annotation[cobra.BashCompCustom] = []string{"__kubectl_get_namespaces"} flag := &pflag.Flag{ Name: "namespace", @@ -204,3 +205,17 @@ __kubectl_get_namespaces() fi } ``` +# Using bash aliases for commands + +You can also configure the `bash aliases` for the commands and they will also support completions. + +```bash +alias aliasname=origcommand +complete -o default -F __start_origcommand aliasname + +# and now when you run `aliasname` completion will make +# suggestions as it did for `origcommand`. + +$) aliasname +completion firstcommand secondcommand +``` diff --git a/vendor/github.com/spf13/cobra/cobra.go b/vendor/github.com/spf13/cobra/cobra.go index 8928cefc2fa..7010fd15b72 100644 --- a/vendor/github.com/spf13/cobra/cobra.go +++ b/vendor/github.com/spf13/cobra/cobra.go @@ -70,7 +70,8 @@ func AddTemplateFuncs(tmplFuncs template.FuncMap) { } } -// OnInitialize takes a series of func() arguments and appends them to a slice of func(). +// OnInitialize sets the passed functions to be run when each command's +// Execute method is called. func OnInitialize(y ...func()) { initializers = append(initializers, y...) } @@ -188,3 +189,12 @@ func ld(s, t string, ignoreCase bool) int { } return d[len(s)][len(t)] } + +func stringInSlice(a string, list []string) bool { + for _, b := range list { + if b == a { + return true + } + } + return false +} diff --git a/vendor/github.com/spf13/cobra/command.go b/vendor/github.com/spf13/cobra/command.go index 58e6ceb0778..34d1bf36712 100644 --- a/vendor/github.com/spf13/cobra/command.go +++ b/vendor/github.com/spf13/cobra/command.go @@ -27,6 +27,9 @@ import ( flag "github.com/spf13/pflag" ) +// FParseErrWhitelist configures Flag parse errors to be ignored +type FParseErrWhitelist flag.ParseErrorsWhitelist + // Command is just that, a command for your application. // E.g. 'go run ...' - 'run' is the command. Cobra requires // you to define the usage and description as part of your command @@ -75,6 +78,11 @@ type Command struct { // group commands. Annotations map[string]string + // Version defines the version for this command. If this value is non-empty and the command does not + // define a "version" flag, a "version" boolean flag will be added to the command and, if specified, + // will print content of the "Version" variable. + Version string + // The *Run functions are executed in the following order: // * PersistentPreRun() // * PreRun() @@ -118,6 +126,10 @@ type Command struct { // will be printed by generating docs for this command. DisableAutoGenTag bool + // DisableFlagsInUseLine will disable the addition of [flags] to the usage + // line of a command when printing help or generating docs + DisableFlagsInUseLine bool + // DisableSuggestions disables the suggestions based on Levenshtein distance // that go along with 'unknown command' messages. DisableSuggestions bool @@ -128,6 +140,9 @@ type Command struct { // TraverseChildren parses flags on all parents before executing child command. TraverseChildren bool + //FParseErrWhitelist flag parse errors to be ignored + FParseErrWhitelist FParseErrWhitelist + // commands is the list of commands supported by this program. commands []*Command // parent is a parent command for this command. @@ -138,6 +153,11 @@ type Command struct { commandsMaxNameLen int // commandsAreSorted defines, if command slice are sorted or not. commandsAreSorted bool + // commandCalledAs is the name or alias value used to call this command. + commandCalledAs struct { + name string + called bool + } // args is actual args parsed from flags. args []string @@ -173,6 +193,8 @@ type Command struct { // helpCommand is command with usage 'help'. If it's not defined by user, // cobra uses default help command. helpCommand *Command + // versionTemplate is the version template defined by user. + versionTemplate string } // SetArgs sets arguments for the command. It is set to os.Args[1:] by default, if desired, can be overridden @@ -218,6 +240,11 @@ func (c *Command) SetHelpTemplate(s string) { c.helpTemplate = s } +// SetVersionTemplate sets version template to be used. Application can use it to set custom template. +func (c *Command) SetVersionTemplate(s string) { + c.versionTemplate = s +} + // SetGlobalNormalizationFunc sets a normalization function to all flag sets and also to child commands. // The user should not have a cyclic dependency on commands. func (c *Command) SetGlobalNormalizationFunc(n func(f *flag.FlagSet, name string) flag.NormalizedName) { @@ -407,6 +434,19 @@ func (c *Command) HelpTemplate() string { {{end}}{{if or .Runnable .HasSubCommands}}{{.UsageString}}{{end}}` } +// VersionTemplate return version template for the command. +func (c *Command) VersionTemplate() string { + if c.versionTemplate != "" { + return c.versionTemplate + } + + if c.HasParent() { + return c.parent.VersionTemplate() + } + return `{{with .Name}}{{printf "%s " .}}{{end}}{{printf "version %s" .Version}} +` +} + func hasNoOptDefVal(name string, fs *flag.FlagSet) bool { flag := fs.Lookup(name) if flag == nil { @@ -441,6 +481,9 @@ Loop: s := args[0] args = args[1:] switch { + case s == "--": + // "--" terminates the flags + break Loop case strings.HasPrefix(s, "--") && !strings.Contains(s, "=") && !hasNoOptDefVal(s[2:], flags): // If '--flag arg' then // delete arg from args. @@ -528,6 +571,7 @@ func (c *Command) findNext(next string) *Command { matches := make([]*Command, 0) for _, cmd := range c.commands { if cmd.Name() == next || cmd.HasAlias(next) { + cmd.commandCalledAs.name = next return cmd } if EnablePrefixMatching && cmd.hasNameOrAliasPrefix(next) { @@ -538,6 +582,7 @@ func (c *Command) findNext(next string) *Command { if len(matches) == 1 { return matches[0] } + return nil } @@ -621,10 +666,8 @@ func (c *Command) Root() *Command { return c } -// 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. (Description from -// https://godoc.org/github.com/spf13/pflag#FlagSet.ArgsLenAtDash). +// ArgsLenAtDash will return the length of c.Flags().Args at the moment +// when a -- was found during args parsing. func (c *Command) ArgsLenAtDash() int { return c.Flags().ArgsLenAtDash() } @@ -638,9 +681,10 @@ func (c *Command) execute(a []string) (err error) { c.Printf("Command %q is deprecated, %s\n", c.Name(), c.Deprecated) } - // initialize help flag as the last point possible to allow for user + // initialize help and version flag at the last point possible to allow for user // overriding c.InitDefaultHelpFlag() + c.InitDefaultVersionFlag() err = c.ParseFlags(a) if err != nil { @@ -657,7 +701,27 @@ func (c *Command) execute(a []string) (err error) { return err } - if helpVal || !c.Runnable() { + if helpVal { + return flag.ErrHelp + } + + // for back-compat, only add version flag behavior if version is defined + if c.Version != "" { + versionVal, err := c.Flags().GetBool("version") + if err != nil { + c.Println("\"version\" flag declared as non-bool. Please correct your code") + return err + } + if versionVal { + err := tmpl(c.OutOrStdout(), c.VersionTemplate(), c) + if err != nil { + c.Println(err) + } + return err + } + } + + if !c.Runnable() { return flag.ErrHelp } @@ -780,6 +844,11 @@ func (c *Command) ExecuteC() (cmd *Command, err error) { return c, err } + cmd.commandCalledAs.called = true + if cmd.commandCalledAs.name == "" { + cmd.commandCalledAs.name = cmd.Name() + } + err = cmd.execute(flags) if err != nil { // Always show help if requested, even if SilenceErrors is in @@ -825,7 +894,7 @@ func (c *Command) validateRequiredFlags() error { }) if len(missingFlagNames) > 0 { - return fmt.Errorf(`Required flag(s) "%s" have/has not been set`, strings.Join(missingFlagNames, `", "`)) + return fmt.Errorf(`required flag(s) "%s" not set`, strings.Join(missingFlagNames, `", "`)) } return nil } @@ -846,6 +915,27 @@ func (c *Command) InitDefaultHelpFlag() { } } +// InitDefaultVersionFlag adds default version flag to c. +// It is called automatically by executing the c. +// If c already has a version flag, it will do nothing. +// If c.Version is empty, it will do nothing. +func (c *Command) InitDefaultVersionFlag() { + if c.Version == "" { + return + } + + c.mergePersistentFlags() + if c.Flags().Lookup("version") == nil { + usage := "version for " + if c.Name() == "" { + usage += "this command" + } else { + usage += c.Name() + } + c.Flags().Bool("version", false, usage) + } +} + // InitDefaultHelpCmd adds default help command to c. // It is called automatically by executing the c or by calling help and usage. // If c already has help command or c has no subcommands, it will do nothing. @@ -877,7 +967,7 @@ Simply type ` + c.Name() + ` help [path to command] for full details.`, c.AddCommand(c.helpCommand) } -// ResetCommands used for testing. +// ResetCommands delete parent, subcommand and help command from c. func (c *Command) ResetCommands() { c.parent = nil c.commands = nil @@ -996,6 +1086,9 @@ func (c *Command) UseLine() string { } else { useline = c.Use } + if c.DisableFlagsInUseLine { + return useline + } if c.HasAvailableFlags() && !strings.Contains(useline, "[flags]") { useline += " [flags]" } @@ -1063,14 +1156,25 @@ func (c *Command) HasAlias(s string) bool { return false } +// CalledAs returns the command name or alias that was used to invoke +// this command or an empty string if the command has not been called. +func (c *Command) CalledAs() string { + if c.commandCalledAs.called { + return c.commandCalledAs.name + } + return "" +} + // hasNameOrAliasPrefix returns true if the Name or any of aliases start // with prefix func (c *Command) hasNameOrAliasPrefix(prefix string) bool { if strings.HasPrefix(c.Name(), prefix) { + c.commandCalledAs.name = c.Name() return true } for _, alias := range c.Aliases { if strings.HasPrefix(alias, prefix) { + c.commandCalledAs.name = alias return true } } @@ -1163,7 +1267,7 @@ func (c *Command) HasAvailableSubCommands() bool { } } - // the command either has no sub comamnds, or no available (non deprecated/help/hidden) + // the command either has no sub commands, or no available (non deprecated/help/hidden) // sub commands return false } @@ -1173,7 +1277,7 @@ func (c *Command) HasParent() bool { return c.parent != nil } -// GlobalNormalizationFunc returns the global normalization function or nil if doesn't exists. +// GlobalNormalizationFunc returns the global normalization function or nil if it doesn't exist. func (c *Command) GlobalNormalizationFunc() func(f *flag.FlagSet, name string) flag.NormalizedName { return c.globNormFunc } @@ -1273,7 +1377,7 @@ func (c *Command) PersistentFlags() *flag.FlagSet { return c.pflags } -// ResetFlags is used in testing. +// ResetFlags deletes all flags from command. func (c *Command) ResetFlags() { c.flagErrorBuf = new(bytes.Buffer) c.flagErrorBuf.Reset() @@ -1365,6 +1469,10 @@ func (c *Command) ParseFlags(args []string) error { } beforeErrorBufLen := c.flagErrorBuf.Len() c.mergePersistentFlags() + + //do it here after merging all flags and just before parse + c.Flags().ParseErrorsWhitelist = flag.ParseErrorsWhitelist(c.FParseErrWhitelist) + err := c.Flags().Parse(args) // Print warnings if they occurred (e.g. deprecated flag messages). if c.flagErrorBuf.Len()-beforeErrorBufLen > 0 && err == nil { diff --git a/vendor/github.com/spf13/pflag/bytes.go b/vendor/github.com/spf13/pflag/bytes.go new file mode 100644 index 00000000000..12c58db9fe3 --- /dev/null +++ b/vendor/github.com/spf13/pflag/bytes.go @@ -0,0 +1,105 @@ +package pflag + +import ( + "encoding/hex" + "fmt" + "strings" +) + +// BytesHex adapts []byte for use as a flag. Value of flag is HEX encoded +type bytesHexValue []byte + +func (bytesHex bytesHexValue) String() string { + return fmt.Sprintf("%X", []byte(bytesHex)) +} + +func (bytesHex *bytesHexValue) Set(value string) error { + bin, err := hex.DecodeString(strings.TrimSpace(value)) + + if err != nil { + return err + } + + *bytesHex = bin + + return nil +} + +func (*bytesHexValue) Type() string { + return "bytesHex" +} + +func newBytesHexValue(val []byte, p *[]byte) *bytesHexValue { + *p = val + return (*bytesHexValue)(p) +} + +func bytesHexConv(sval string) (interface{}, error) { + + bin, err := hex.DecodeString(sval) + + if err == nil { + return bin, nil + } + + return nil, fmt.Errorf("invalid string being converted to Bytes: %s %s", sval, err) +} + +// GetBytesHex return the []byte value of a flag with the given name +func (f *FlagSet) GetBytesHex(name string) ([]byte, error) { + val, err := f.getFlagType(name, "bytesHex", bytesHexConv) + + if err != nil { + return []byte{}, err + } + + return val.([]byte), nil +} + +// BytesHexVar defines an []byte flag with specified name, default value, and usage string. +// The argument p points to an []byte variable in which to store the value of the flag. +func (f *FlagSet) BytesHexVar(p *[]byte, name string, value []byte, usage string) { + f.VarP(newBytesHexValue(value, p), name, "", usage) +} + +// BytesHexVarP is like BytesHexVar, but accepts a shorthand letter that can be used after a single dash. +func (f *FlagSet) BytesHexVarP(p *[]byte, name, shorthand string, value []byte, usage string) { + f.VarP(newBytesHexValue(value, p), name, shorthand, usage) +} + +// BytesHexVar defines an []byte flag with specified name, default value, and usage string. +// The argument p points to an []byte variable in which to store the value of the flag. +func BytesHexVar(p *[]byte, name string, value []byte, usage string) { + CommandLine.VarP(newBytesHexValue(value, p), name, "", usage) +} + +// BytesHexVarP is like BytesHexVar, but accepts a shorthand letter that can be used after a single dash. +func BytesHexVarP(p *[]byte, name, shorthand string, value []byte, usage string) { + CommandLine.VarP(newBytesHexValue(value, p), name, shorthand, usage) +} + +// BytesHex defines an []byte flag with specified name, default value, and usage string. +// The return value is the address of an []byte variable that stores the value of the flag. +func (f *FlagSet) BytesHex(name string, value []byte, usage string) *[]byte { + p := new([]byte) + f.BytesHexVarP(p, name, "", value, usage) + return p +} + +// BytesHexP is like BytesHex, but accepts a shorthand letter that can be used after a single dash. +func (f *FlagSet) BytesHexP(name, shorthand string, value []byte, usage string) *[]byte { + p := new([]byte) + f.BytesHexVarP(p, name, shorthand, value, usage) + return p +} + +// BytesHex defines an []byte flag with specified name, default value, and usage string. +// The return value is the address of an []byte variable that stores the value of the flag. +func BytesHex(name string, value []byte, usage string) *[]byte { + return CommandLine.BytesHexP(name, "", value, usage) +} + +// BytesHexP is like BytesHex, but accepts a shorthand letter that can be used after a single dash. +func BytesHexP(name, shorthand string, value []byte, usage string) *[]byte { + return CommandLine.BytesHexP(name, shorthand, value, usage) +} diff --git a/vendor/github.com/spf13/pflag/count.go b/vendor/github.com/spf13/pflag/count.go index 250a43814c9..aa126e44d1c 100644 --- a/vendor/github.com/spf13/pflag/count.go +++ b/vendor/github.com/spf13/pflag/count.go @@ -11,13 +11,13 @@ func newCountValue(val int, p *int) *countValue { } 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 { + // "+1" means that no specific value was passed, so increment + if s == "+1" { *i = countValue(*i + 1) - } else { - *i = countValue(v) + return nil } + v, err := strconv.ParseInt(s, 0, 0) + *i = countValue(v) return err } @@ -54,7 +54,7 @@ func (f *FlagSet) CountVar(p *int, name string, usage string) { // 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" + flag.NoOptDefVal = "+1" } // CountVar like CountVar only the flag is placed on the CommandLine instead of a given flag set diff --git a/vendor/github.com/spf13/pflag/duration_slice.go b/vendor/github.com/spf13/pflag/duration_slice.go new file mode 100644 index 00000000000..52c6b6dc104 --- /dev/null +++ b/vendor/github.com/spf13/pflag/duration_slice.go @@ -0,0 +1,128 @@ +package pflag + +import ( + "fmt" + "strings" + "time" +) + +// -- durationSlice Value +type durationSliceValue struct { + value *[]time.Duration + changed bool +} + +func newDurationSliceValue(val []time.Duration, p *[]time.Duration) *durationSliceValue { + dsv := new(durationSliceValue) + dsv.value = p + *dsv.value = val + return dsv +} + +func (s *durationSliceValue) Set(val string) error { + ss := strings.Split(val, ",") + out := make([]time.Duration, len(ss)) + for i, d := range ss { + var err error + out[i], err = time.ParseDuration(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 *durationSliceValue) Type() string { + return "durationSlice" +} + +func (s *durationSliceValue) String() string { + out := make([]string, len(*s.value)) + for i, d := range *s.value { + out[i] = fmt.Sprintf("%s", d) + } + return "[" + strings.Join(out, ",") + "]" +} + +func durationSliceConv(val string) (interface{}, error) { + val = strings.Trim(val, "[]") + // Empty string would cause a slice with one (empty) entry + if len(val) == 0 { + return []time.Duration{}, nil + } + ss := strings.Split(val, ",") + out := make([]time.Duration, len(ss)) + for i, d := range ss { + var err error + out[i], err = time.ParseDuration(d) + if err != nil { + return nil, err + } + + } + return out, nil +} + +// GetDurationSlice returns the []time.Duration value of a flag with the given name +func (f *FlagSet) GetDurationSlice(name string) ([]time.Duration, error) { + val, err := f.getFlagType(name, "durationSlice", durationSliceConv) + if err != nil { + return []time.Duration{}, err + } + return val.([]time.Duration), nil +} + +// DurationSliceVar defines a durationSlice 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) DurationSliceVar(p *[]time.Duration, name string, value []time.Duration, usage string) { + f.VarP(newDurationSliceValue(value, p), name, "", usage) +} + +// DurationSliceVarP is like DurationSliceVar, but accepts a shorthand letter that can be used after a single dash. +func (f *FlagSet) DurationSliceVarP(p *[]time.Duration, name, shorthand string, value []time.Duration, usage string) { + f.VarP(newDurationSliceValue(value, p), name, shorthand, usage) +} + +// DurationSliceVar defines a duration[] flag with specified name, default value, and usage string. +// The argument p points to a duration[] variable in which to store the value of the flag. +func DurationSliceVar(p *[]time.Duration, name string, value []time.Duration, usage string) { + CommandLine.VarP(newDurationSliceValue(value, p), name, "", usage) +} + +// DurationSliceVarP is like DurationSliceVar, but accepts a shorthand letter that can be used after a single dash. +func DurationSliceVarP(p *[]time.Duration, name, shorthand string, value []time.Duration, usage string) { + CommandLine.VarP(newDurationSliceValue(value, p), name, shorthand, usage) +} + +// DurationSlice 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) DurationSlice(name string, value []time.Duration, usage string) *[]time.Duration { + p := []time.Duration{} + f.DurationSliceVarP(&p, name, "", value, usage) + return &p +} + +// DurationSliceP is like DurationSlice, but accepts a shorthand letter that can be used after a single dash. +func (f *FlagSet) DurationSliceP(name, shorthand string, value []time.Duration, usage string) *[]time.Duration { + p := []time.Duration{} + f.DurationSliceVarP(&p, name, shorthand, value, usage) + return &p +} + +// DurationSlice 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 DurationSlice(name string, value []time.Duration, usage string) *[]time.Duration { + return CommandLine.DurationSliceP(name, "", value, usage) +} + +// DurationSliceP is like DurationSlice, but accepts a shorthand letter that can be used after a single dash. +func DurationSliceP(name, shorthand string, value []time.Duration, usage string) *[]time.Duration { + return CommandLine.DurationSliceP(name, shorthand, value, usage) +} diff --git a/vendor/github.com/spf13/pflag/flag.go b/vendor/github.com/spf13/pflag/flag.go index 6f1fc3007a8..5eadc84e3c4 100644 --- a/vendor/github.com/spf13/pflag/flag.go +++ b/vendor/github.com/spf13/pflag/flag.go @@ -101,6 +101,7 @@ package pflag import ( "bytes" "errors" + goflag "flag" "fmt" "io" "os" @@ -123,6 +124,12 @@ const ( PanicOnError ) +// ParseErrorsWhitelist defines the parsing errors that can be ignored +type ParseErrorsWhitelist struct { + // UnknownFlags will ignore unknown flags errors and continue parsing rest of the flags + UnknownFlags bool +} + // NormalizedName is a flag name that has been normalized according to rules // for the FlagSet (e.g. making '-' and '_' equivalent). type NormalizedName string @@ -138,6 +145,9 @@ type FlagSet struct { // help/usage messages. SortFlags bool + // ParseErrorsWhitelist is used to configure a whitelist of errors + ParseErrorsWhitelist ParseErrorsWhitelist + name string parsed bool actual map[NormalizedName]*Flag @@ -153,6 +163,8 @@ type FlagSet struct { output io.Writer // nil means stderr; use out() accessor interspersed bool // allow interspersed option/non-option args normalizeNameFunc func(f *FlagSet, name string) NormalizedName + + addedGoFlagSets []*goflag.FlagSet } // A Flag represents the state of a flag. @@ -202,12 +214,18 @@ func sortFlags(flags map[NormalizedName]*Flag) []*Flag { func (f *FlagSet) SetNormalizeFunc(n func(f *FlagSet, name string) NormalizedName) { f.normalizeNameFunc = n f.sortedFormal = f.sortedFormal[:0] - for k, v := range f.orderedFormal { - delete(f.formal, NormalizedName(v.Name)) - nname := f.normalizeFlagName(v.Name) - v.Name = string(nname) - f.formal[nname] = v - f.orderedFormal[k] = v + for fname, flag := range f.formal { + nname := f.normalizeFlagName(flag.Name) + if fname == nname { + continue + } + flag.Name = string(nname) + delete(f.formal, fname) + f.formal[nname] = flag + if _, set := f.actual[fname]; set { + delete(f.actual, fname) + f.actual[nname] = flag + } } } @@ -261,16 +279,16 @@ func (f *FlagSet) VisitAll(fn func(*Flag)) { } } -// HasFlags returns a bool to indicate if the FlagSet has any flags definied. +// HasFlags returns a bool to indicate if the FlagSet has any flags defined. 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. +// that are not hidden. func (f *FlagSet) HasAvailableFlags() bool { for _, flag := range f.formal { - if !flag.Hidden && len(flag.Deprecated) == 0 { + if !flag.Hidden { return true } } @@ -380,6 +398,7 @@ func (f *FlagSet) MarkDeprecated(name string, usageMessage string) error { return fmt.Errorf("deprecated message for flag %q must be set", name) } flag.Deprecated = usageMessage + flag.Hidden = true return nil } @@ -440,13 +459,15 @@ func (f *FlagSet) Set(name, value string) error { return fmt.Errorf("invalid argument %q for %q flag: %v", value, flagName, err) } - if f.actual == nil { - f.actual = make(map[NormalizedName]*Flag) - } - f.actual[normalName] = flag - f.orderedActual = append(f.orderedActual, flag) + if !flag.Changed { + if f.actual == nil { + f.actual = make(map[NormalizedName]*Flag) + } + f.actual[normalName] = flag + f.orderedActual = append(f.orderedActual, flag) - flag.Changed = true + flag.Changed = true + } if flag.Deprecated != "" { fmt.Fprintf(f.out(), "Flag --%s has been deprecated, %s\n", flag.Name, flag.Deprecated) @@ -556,6 +577,14 @@ func UnquoteUsage(flag *Flag) (name string, usage string) { name = "int" case "uint64": name = "uint" + case "stringSlice": + name = "strings" + case "intSlice": + name = "ints" + case "uintSlice": + name = "uints" + case "boolSlice": + name = "bools" } return @@ -570,11 +599,14 @@ func wrapN(i, slop int, s string) (string, string) { return s, "" } - w := strings.LastIndexAny(s[:i], " \t") + w := strings.LastIndexAny(s[:i], " \t\n") if w <= 0 { return s, "" } - + nlPos := strings.LastIndex(s[:i], "\n") + if nlPos > 0 && nlPos < w { + return s[:nlPos], s[nlPos+1:] + } return s[:w], s[w+1:] } @@ -583,7 +615,7 @@ func wrapN(i, slop int, s string) (string, string) { // caller). Pass `w` == 0 to do no wrapping func wrap(i, w int, s string) string { if w == 0 { - return s + return strings.Replace(s, "\n", "\n"+strings.Repeat(" ", i), -1) } // space between indent i and end of line width w into which @@ -601,7 +633,7 @@ func wrap(i, w int, s string) string { } // If still not enough space then don't even try to wrap. if wrap < 24 { - return s + return strings.Replace(s, "\n", r, -1) } // Try to avoid short orphan words on the final line, by @@ -613,14 +645,14 @@ func wrap(i, w int, s string) string { // Handle first line, which is indented by the caller (or the // special case above) l, s = wrapN(wrap, slop, s) - r = r + l + r = r + strings.Replace(l, "\n", "\n"+strings.Repeat(" ", i), -1) // Now wrap the rest for s != "" { var t string t, s = wrapN(wrap, slop, s) - r = r + "\n" + strings.Repeat(" ", i) + t + r = r + "\n" + strings.Repeat(" ", i) + strings.Replace(t, "\n", "\n"+strings.Repeat(" ", i), -1) } return r @@ -637,7 +669,7 @@ func (f *FlagSet) FlagUsagesWrapped(cols int) string { maxlen := 0 f.VisitAll(func(flag *Flag) { - if flag.Deprecated != "" || flag.Hidden { + if flag.Hidden { return } @@ -660,6 +692,10 @@ func (f *FlagSet) FlagUsagesWrapped(cols int) string { if flag.NoOptDefVal != "true" { line += fmt.Sprintf("[=%s]", flag.NoOptDefVal) } + case "count": + if flag.NoOptDefVal != "+1" { + line += fmt.Sprintf("[=%s]", flag.NoOptDefVal) + } default: line += fmt.Sprintf("[=%s]", flag.NoOptDefVal) } @@ -680,6 +716,9 @@ func (f *FlagSet) FlagUsagesWrapped(cols int) string { line += fmt.Sprintf(" (default %s)", flag.DefValue) } } + if len(flag.Deprecated) != 0 { + line += fmt.Sprintf(" (DEPRECATED: %s)", flag.Deprecated) + } lines = append(lines, line) }) @@ -857,8 +896,10 @@ func VarP(value Value, name, shorthand, usage string) { // returns the error. func (f *FlagSet) failf(format string, a ...interface{}) error { err := fmt.Errorf(format, a...) - fmt.Fprintln(f.out(), err) - f.usage() + if f.errorHandling != ContinueOnError { + fmt.Fprintln(f.out(), err) + f.usage() + } return err } @@ -874,6 +915,25 @@ func (f *FlagSet) usage() { } } +//--unknown (args will be empty) +//--unknown --next-flag ... (args will be --next-flag ...) +//--unknown arg ... (args will be arg ...) +func stripUnknownFlagValue(args []string) []string { + if len(args) == 0 { + //--unknown + return args + } + + first := args[0] + if first[0] == '-' { + //--unknown --next-flag ... + return args + } + + //--unknown arg ... (args will be arg ...) + return args[1:] +} + func (f *FlagSet) parseLongArg(s string, args []string, fn parseFunc) (a []string, err error) { a = args name := s[2:] @@ -885,13 +945,24 @@ func (f *FlagSet) parseLongArg(s string, args []string, fn parseFunc) (a []strin split := strings.SplitN(name, "=", 2) name = split[0] flag, exists := f.formal[f.normalizeFlagName(name)] + if !exists { - if name == "help" { // special case for nice help message. + switch { + case name == "help": f.usage() return a, ErrHelp + case f.ParseErrorsWhitelist.UnknownFlags: + // --unknown=unknownval arg ... + // we do not want to lose arg in this case + if len(split) >= 2 { + return a, nil + } + + return stripUnknownFlagValue(a), nil + default: + err = f.failf("unknown flag: --%s", name) + return } - err = f.failf("unknown flag: --%s", name) - return } var value string @@ -912,6 +983,9 @@ func (f *FlagSet) parseLongArg(s string, args []string, fn parseFunc) (a []strin } err = fn(flag, value) + if err != nil { + f.failf(err.Error()) + } return } @@ -926,13 +1000,25 @@ func (f *FlagSet) parseSingleShortArg(shorthands string, args []string, fn parse flag, exists := f.shorthands[c] if !exists { - if c == 'h' { // special case for nice help message. + switch { + case c == 'h': f.usage() err = ErrHelp return + case f.ParseErrorsWhitelist.UnknownFlags: + // '-f=arg arg ...' + // we do not want to lose arg in this case + if len(shorthands) > 2 && shorthands[1] == '=' { + outShorts = "" + return + } + + outArgs = stripUnknownFlagValue(outArgs) + return + default: + err = f.failf("unknown shorthand flag: %q in -%s", c, shorthands) + return } - err = f.failf("unknown shorthand flag: %q in -%s", c, shorthands) - return } var value string @@ -962,6 +1048,9 @@ func (f *FlagSet) parseSingleShortArg(shorthands string, args []string, fn parse } err = fn(flag, value) + if err != nil { + f.failf(err.Error()) + } return } @@ -1016,6 +1105,11 @@ func (f *FlagSet) parseArgs(args []string, fn parseFunc) (err error) { // 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 { + if f.addedGoFlagSets != nil { + for _, goFlagSet := range f.addedGoFlagSets { + goFlagSet.Parse(nil) + } + } f.parsed = true if len(arguments) < 0 { @@ -1034,6 +1128,7 @@ func (f *FlagSet) Parse(arguments []string) error { case ContinueOnError: return err case ExitOnError: + fmt.Println(err) os.Exit(2) case PanicOnError: panic(err) diff --git a/vendor/github.com/spf13/pflag/golangflag.go b/vendor/github.com/spf13/pflag/golangflag.go index c4f47ebe590..d3dd72b7fee 100644 --- a/vendor/github.com/spf13/pflag/golangflag.go +++ b/vendor/github.com/spf13/pflag/golangflag.go @@ -98,4 +98,8 @@ func (f *FlagSet) AddGoFlagSet(newSet *goflag.FlagSet) { newSet.VisitAll(func(goflag *goflag.Flag) { f.AddGoFlag(goflag) }) + if f.addedGoFlagSets == nil { + f.addedGoFlagSets = make([]*goflag.FlagSet, 0) + } + f.addedGoFlagSets = append(f.addedGoFlagSets, newSet) } diff --git a/vendor/github.com/spf13/pflag/int16.go b/vendor/github.com/spf13/pflag/int16.go new file mode 100644 index 00000000000..f1a01d05e69 --- /dev/null +++ b/vendor/github.com/spf13/pflag/int16.go @@ -0,0 +1,88 @@ +package pflag + +import "strconv" + +// -- int16 Value +type int16Value int16 + +func newInt16Value(val int16, p *int16) *int16Value { + *p = val + return (*int16Value)(p) +} + +func (i *int16Value) Set(s string) error { + v, err := strconv.ParseInt(s, 0, 16) + *i = int16Value(v) + return err +} + +func (i *int16Value) Type() string { + return "int16" +} + +func (i *int16Value) String() string { return strconv.FormatInt(int64(*i), 10) } + +func int16Conv(sval string) (interface{}, error) { + v, err := strconv.ParseInt(sval, 0, 16) + if err != nil { + return 0, err + } + return int16(v), nil +} + +// GetInt16 returns the int16 value of a flag with the given name +func (f *FlagSet) GetInt16(name string) (int16, error) { + val, err := f.getFlagType(name, "int16", int16Conv) + if err != nil { + return 0, err + } + return val.(int16), nil +} + +// Int16Var defines an int16 flag with specified name, default value, and usage string. +// The argument p points to an int16 variable in which to store the value of the flag. +func (f *FlagSet) Int16Var(p *int16, name string, value int16, usage string) { + f.VarP(newInt16Value(value, p), name, "", usage) +} + +// Int16VarP is like Int16Var, but accepts a shorthand letter that can be used after a single dash. +func (f *FlagSet) Int16VarP(p *int16, name, shorthand string, value int16, usage string) { + f.VarP(newInt16Value(value, p), name, shorthand, usage) +} + +// Int16Var defines an int16 flag with specified name, default value, and usage string. +// The argument p points to an int16 variable in which to store the value of the flag. +func Int16Var(p *int16, name string, value int16, usage string) { + CommandLine.VarP(newInt16Value(value, p), name, "", usage) +} + +// Int16VarP is like Int16Var, but accepts a shorthand letter that can be used after a single dash. +func Int16VarP(p *int16, name, shorthand string, value int16, usage string) { + CommandLine.VarP(newInt16Value(value, p), name, shorthand, usage) +} + +// Int16 defines an int16 flag with specified name, default value, and usage string. +// The return value is the address of an int16 variable that stores the value of the flag. +func (f *FlagSet) Int16(name string, value int16, usage string) *int16 { + p := new(int16) + f.Int16VarP(p, name, "", value, usage) + return p +} + +// Int16P is like Int16, but accepts a shorthand letter that can be used after a single dash. +func (f *FlagSet) Int16P(name, shorthand string, value int16, usage string) *int16 { + p := new(int16) + f.Int16VarP(p, name, shorthand, value, usage) + return p +} + +// Int16 defines an int16 flag with specified name, default value, and usage string. +// The return value is the address of an int16 variable that stores the value of the flag. +func Int16(name string, value int16, usage string) *int16 { + return CommandLine.Int16P(name, "", value, usage) +} + +// Int16P is like Int16, but accepts a shorthand letter that can be used after a single dash. +func Int16P(name, shorthand string, value int16, usage string) *int16 { + return CommandLine.Int16P(name, shorthand, value, usage) +} diff --git a/vendor/github.com/spf13/pflag/string_array.go b/vendor/github.com/spf13/pflag/string_array.go index 276b7ed49ed..fa7bc60187a 100644 --- a/vendor/github.com/spf13/pflag/string_array.go +++ b/vendor/github.com/spf13/pflag/string_array.go @@ -52,7 +52,7 @@ func (f *FlagSet) GetStringArray(name string) ([]string, error) { // 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 +// The value of each argument will not try to be separated by comma. Use a StringSlice for that. func (f *FlagSet) StringArrayVar(p *[]string, name string, value []string, usage string) { f.VarP(newStringArrayValue(value, p), name, "", usage) } @@ -64,7 +64,7 @@ func (f *FlagSet) StringArrayVarP(p *[]string, name, shorthand string, value []s // 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 +// The value of each argument will not try to be separated by comma. Use a StringSlice for that. func StringArrayVar(p *[]string, name string, value []string, usage string) { CommandLine.VarP(newStringArrayValue(value, p), name, "", usage) } @@ -76,7 +76,7 @@ func StringArrayVarP(p *[]string, name, shorthand string, value []string, 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 +// The value of each argument will not try to be separated by comma. Use a StringSlice for that. func (f *FlagSet) StringArray(name string, value []string, usage string) *[]string { p := []string{} f.StringArrayVarP(&p, name, "", value, usage) @@ -92,7 +92,7 @@ func (f *FlagSet) StringArrayP(name, shorthand string, value []string, usage str // 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 +// The value of each argument will not try to be separated by comma. Use a StringSlice for that. func StringArray(name string, value []string, usage string) *[]string { return CommandLine.StringArrayP(name, "", value, usage) } diff --git a/vendor/github.com/spf13/pflag/string_slice.go b/vendor/github.com/spf13/pflag/string_slice.go index 05eee75438d..0cd3ccc083e 100644 --- a/vendor/github.com/spf13/pflag/string_slice.go +++ b/vendor/github.com/spf13/pflag/string_slice.go @@ -82,6 +82,11 @@ func (f *FlagSet) GetStringSlice(name string) ([]string, error) { // 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. +// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly. +// For example: +// --ss="v1,v2" -ss="v3" +// will result in +// []string{"v1", "v2", "v3"} func (f *FlagSet) StringSliceVar(p *[]string, name string, value []string, usage string) { f.VarP(newStringSliceValue(value, p), name, "", usage) } @@ -93,6 +98,11 @@ func (f *FlagSet) StringSliceVarP(p *[]string, name, shorthand string, value []s // 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. +// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly. +// For example: +// --ss="v1,v2" -ss="v3" +// will result in +// []string{"v1", "v2", "v3"} func StringSliceVar(p *[]string, name string, value []string, usage string) { CommandLine.VarP(newStringSliceValue(value, p), name, "", usage) } @@ -104,6 +114,11 @@ func StringSliceVarP(p *[]string, name, shorthand string, value []string, 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. +// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly. +// For example: +// --ss="v1,v2" -ss="v3" +// will result in +// []string{"v1", "v2", "v3"} func (f *FlagSet) StringSlice(name string, value []string, usage string) *[]string { p := []string{} f.StringSliceVarP(&p, name, "", value, usage) @@ -119,6 +134,11 @@ func (f *FlagSet) StringSliceP(name, shorthand string, value []string, usage str // 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. +// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly. +// For example: +// --ss="v1,v2" -ss="v3" +// will result in +// []string{"v1", "v2", "v3"} func StringSlice(name string, value []string, usage string) *[]string { return CommandLine.StringSliceP(name, "", value, usage) } diff --git a/vendor/golang.org/x/crypto/openpgp/keys.go b/vendor/golang.org/x/crypto/openpgp/keys.go index fd582a89c0c..aceb1b79636 100644 --- a/vendor/golang.org/x/crypto/openpgp/keys.go +++ b/vendor/golang.org/x/crypto/openpgp/keys.go @@ -500,6 +500,10 @@ func NewEntity(name, comment, email string, config *packet.Config) (*Entity, err IssuerKeyId: &e.PrimaryKey.KeyId, }, } + err = e.Identities[uid.Id].SelfSignature.SignUserId(uid.Id, e.PrimaryKey, e.PrivateKey, config) + if err != nil { + return nil, err + } // If the user passes in a DefaultHash via packet.Config, // set the PreferredHash for the SelfSignature. @@ -529,14 +533,17 @@ func NewEntity(name, comment, email string, config *packet.Config) (*Entity, err } e.Subkeys[0].PublicKey.IsSubkey = true e.Subkeys[0].PrivateKey.IsSubkey = true - + err = e.Subkeys[0].Sig.SignKey(e.Subkeys[0].PublicKey, e.PrivateKey, config) + if err != nil { + return nil, err + } return e, nil } // SerializePrivate serializes an Entity, including private key material, to // the given Writer. For now, it must only be used on an Entity returned from // NewEntity. -// If config is nil, sensible defaults will be used. +// config is ignored func (e *Entity) SerializePrivate(w io.Writer, config *packet.Config) (err error) { err = e.PrivateKey.Serialize(w) if err != nil { @@ -547,10 +554,6 @@ func (e *Entity) SerializePrivate(w io.Writer, config *packet.Config) (err error if err != nil { return } - err = ident.SelfSignature.SignUserId(ident.UserId.Id, e.PrimaryKey, e.PrivateKey, config) - if err != nil { - return - } err = ident.SelfSignature.Serialize(w) if err != nil { return @@ -561,10 +564,6 @@ func (e *Entity) SerializePrivate(w io.Writer, config *packet.Config) (err error if err != nil { return } - err = subkey.Sig.SignKey(subkey.PublicKey, e.PrivateKey, config) - if err != nil { - return - } err = subkey.Sig.Serialize(w) if err != nil { return diff --git a/vendor/golang.org/x/crypto/openpgp/packet/encrypted_key.go b/vendor/golang.org/x/crypto/openpgp/packet/encrypted_key.go index 266840d05a3..02b372cf374 100644 --- a/vendor/golang.org/x/crypto/openpgp/packet/encrypted_key.go +++ b/vendor/golang.org/x/crypto/openpgp/packet/encrypted_key.go @@ -42,12 +42,18 @@ func (e *EncryptedKey) parse(r io.Reader) (err error) { switch e.Algo { case PubKeyAlgoRSA, PubKeyAlgoRSAEncryptOnly: e.encryptedMPI1.bytes, e.encryptedMPI1.bitLength, err = readMPI(r) + if err != nil { + return + } case PubKeyAlgoElGamal: e.encryptedMPI1.bytes, e.encryptedMPI1.bitLength, err = readMPI(r) if err != nil { return } e.encryptedMPI2.bytes, e.encryptedMPI2.bitLength, err = readMPI(r) + if err != nil { + return + } } _, err = consumeAll(r) return @@ -72,7 +78,8 @@ func (e *EncryptedKey) Decrypt(priv *PrivateKey, config *Config) error { // padding oracle attacks. switch priv.PubKeyAlgo { case PubKeyAlgoRSA, PubKeyAlgoRSAEncryptOnly: - b, err = rsa.DecryptPKCS1v15(config.Random(), priv.PrivateKey.(*rsa.PrivateKey), e.encryptedMPI1.bytes) + k := priv.PrivateKey.(*rsa.PrivateKey) + b, err = rsa.DecryptPKCS1v15(config.Random(), k, padToKeySize(&k.PublicKey, e.encryptedMPI1.bytes)) case PubKeyAlgoElGamal: c1 := new(big.Int).SetBytes(e.encryptedMPI1.bytes) c2 := new(big.Int).SetBytes(e.encryptedMPI2.bytes) diff --git a/vendor/golang.org/x/crypto/openpgp/packet/packet.go b/vendor/golang.org/x/crypto/openpgp/packet/packet.go index 3eded93f042..625bb5ac809 100644 --- a/vendor/golang.org/x/crypto/openpgp/packet/packet.go +++ b/vendor/golang.org/x/crypto/openpgp/packet/packet.go @@ -11,10 +11,12 @@ import ( "crypto/aes" "crypto/cipher" "crypto/des" - "golang.org/x/crypto/cast5" - "golang.org/x/crypto/openpgp/errors" + "crypto/rsa" "io" "math/big" + + "golang.org/x/crypto/cast5" + "golang.org/x/crypto/openpgp/errors" ) // readFull is the same as io.ReadFull except that reading zero bytes returns @@ -500,19 +502,17 @@ func readMPI(r io.Reader) (mpi []byte, bitLength uint16, err error) { numBytes := (int(bitLength) + 7) / 8 mpi = make([]byte, numBytes) _, err = readFull(r, mpi) - return -} - -// mpiLength returns the length of the given *big.Int when serialized as an -// MPI. -func mpiLength(n *big.Int) (mpiLengthInBytes int) { - mpiLengthInBytes = 2 /* MPI length */ - mpiLengthInBytes += (n.BitLen() + 7) / 8 + // According to RFC 4880 3.2. we should check that the MPI has no leading + // zeroes (at least when not an encrypted MPI?), but this implementation + // does generate leading zeroes, so we keep accepting them. return } // writeMPI serializes a big integer to w. func writeMPI(w io.Writer, bitLength uint16, mpiBytes []byte) (err error) { + // Note that we can produce leading zeroes, in violation of RFC 4880 3.2. + // Implementations seem to be tolerant of them, and stripping them would + // make it complex to guarantee matching re-serialization. _, err = w.Write([]byte{byte(bitLength >> 8), byte(bitLength)}) if err == nil { _, err = w.Write(mpiBytes) @@ -525,6 +525,18 @@ func writeBig(w io.Writer, i *big.Int) error { return writeMPI(w, uint16(i.BitLen()), i.Bytes()) } +// padToKeySize left-pads a MPI with zeroes to match the length of the +// specified RSA public. +func padToKeySize(pub *rsa.PublicKey, b []byte) []byte { + k := (pub.N.BitLen() + 7) / 8 + if len(b) >= k { + return b + } + bb := make([]byte, k) + copy(bb[len(bb)-len(b):], b) + return bb +} + // CompressionAlgo Represents the different compression algorithms // supported by OpenPGP (except for BZIP2, which is not currently // supported). See Section 9.3 of RFC 4880. diff --git a/vendor/golang.org/x/crypto/openpgp/packet/public_key.go b/vendor/golang.org/x/crypto/openpgp/packet/public_key.go index ead26233dda..fcd5f525196 100644 --- a/vendor/golang.org/x/crypto/openpgp/packet/public_key.go +++ b/vendor/golang.org/x/crypto/openpgp/packet/public_key.go @@ -244,7 +244,12 @@ func NewECDSAPublicKey(creationTime time.Time, pub *ecdsa.PublicKey) *PublicKey } pk.ec.p.bytes = elliptic.Marshal(pub.Curve, pub.X, pub.Y) - pk.ec.p.bitLength = uint16(8 * len(pk.ec.p.bytes)) + + // The bit length is 3 (for the 0x04 specifying an uncompressed key) + // plus two field elements (for x and y), which are rounded up to the + // nearest byte. See https://tools.ietf.org/html/rfc6637#section-6 + fieldBytes := (pub.Curve.Params().BitSize + 7) & ^7 + pk.ec.p.bitLength = uint16(3 + fieldBytes + fieldBytes) pk.setFingerPrintAndKeyId() return pk @@ -515,7 +520,7 @@ func (pk *PublicKey) VerifySignature(signed hash.Hash, sig *Signature) (err erro switch pk.PubKeyAlgo { case PubKeyAlgoRSA, PubKeyAlgoRSASignOnly: rsaPublicKey, _ := pk.PublicKey.(*rsa.PublicKey) - err = rsa.VerifyPKCS1v15(rsaPublicKey, sig.Hash, hashBytes, sig.RSASignature.bytes) + err = rsa.VerifyPKCS1v15(rsaPublicKey, sig.Hash, hashBytes, padToKeySize(rsaPublicKey, sig.RSASignature.bytes)) if err != nil { return errors.SignatureError("RSA verification failure") } @@ -566,7 +571,7 @@ func (pk *PublicKey) VerifySignatureV3(signed hash.Hash, sig *SignatureV3) (err switch pk.PubKeyAlgo { case PubKeyAlgoRSA, PubKeyAlgoRSASignOnly: rsaPublicKey := pk.PublicKey.(*rsa.PublicKey) - if err = rsa.VerifyPKCS1v15(rsaPublicKey, sig.Hash, hashBytes, sig.RSASignature.bytes); err != nil { + if err = rsa.VerifyPKCS1v15(rsaPublicKey, sig.Hash, hashBytes, padToKeySize(rsaPublicKey, sig.RSASignature.bytes)); err != nil { return errors.SignatureError("RSA verification failure") } return diff --git a/vendor/golang.org/x/crypto/ssh/terminal/util.go b/vendor/golang.org/x/crypto/ssh/terminal/util.go index 02dad484e5c..731c89a284a 100644 --- a/vendor/golang.org/x/crypto/ssh/terminal/util.go +++ b/vendor/golang.org/x/crypto/ssh/terminal/util.go @@ -108,9 +108,7 @@ func ReadPassword(fd int) ([]byte, error) { return nil, err } - defer func() { - unix.IoctlSetTermios(fd, ioctlWriteTermios, termios) - }() + defer unix.IoctlSetTermios(fd, ioctlWriteTermios, termios) return readPasswordLine(passwordReader(fd)) } diff --git a/vendor/golang.org/x/crypto/ssh/terminal/util_solaris.go b/vendor/golang.org/x/crypto/ssh/terminal/util_solaris.go index a2e1b57dc14..9e41b9f43f0 100644 --- a/vendor/golang.org/x/crypto/ssh/terminal/util_solaris.go +++ b/vendor/golang.org/x/crypto/ssh/terminal/util_solaris.go @@ -14,7 +14,7 @@ import ( // State contains the state of a terminal. type State struct { - state *unix.Termios + termios unix.Termios } // IsTerminal returns true if the given file descriptor is a terminal. @@ -75,47 +75,43 @@ func ReadPassword(fd int) ([]byte, error) { // restored. // see http://cr.illumos.org/~webrev/andy_js/1060/ func MakeRaw(fd int) (*State, error) { - oldTermiosPtr, err := unix.IoctlGetTermios(fd, unix.TCGETS) + termios, err := unix.IoctlGetTermios(fd, unix.TCGETS) if err != nil { return nil, err } - oldTermios := *oldTermiosPtr - - newTermios := oldTermios - newTermios.Iflag &^= syscall.IGNBRK | syscall.BRKINT | syscall.PARMRK | syscall.ISTRIP | syscall.INLCR | syscall.IGNCR | syscall.ICRNL | syscall.IXON - newTermios.Oflag &^= syscall.OPOST - newTermios.Lflag &^= syscall.ECHO | syscall.ECHONL | syscall.ICANON | syscall.ISIG | syscall.IEXTEN - newTermios.Cflag &^= syscall.CSIZE | syscall.PARENB - newTermios.Cflag |= syscall.CS8 - newTermios.Cc[unix.VMIN] = 1 - newTermios.Cc[unix.VTIME] = 0 - - if err := unix.IoctlSetTermios(fd, unix.TCSETS, &newTermios); err != nil { + + oldState := State{termios: *termios} + + termios.Iflag &^= unix.IGNBRK | unix.BRKINT | unix.PARMRK | unix.ISTRIP | unix.INLCR | unix.IGNCR | unix.ICRNL | unix.IXON + termios.Oflag &^= unix.OPOST + termios.Lflag &^= unix.ECHO | unix.ECHONL | unix.ICANON | unix.ISIG | unix.IEXTEN + termios.Cflag &^= unix.CSIZE | unix.PARENB + termios.Cflag |= unix.CS8 + termios.Cc[unix.VMIN] = 1 + termios.Cc[unix.VTIME] = 0 + + if err := unix.IoctlSetTermios(fd, unix.TCSETS, termios); err != nil { return nil, err } - return &State{ - state: oldTermiosPtr, - }, nil + return &oldState, nil } // Restore restores the terminal connected to the given file descriptor to a // previous state. func Restore(fd int, oldState *State) error { - return unix.IoctlSetTermios(fd, unix.TCSETS, oldState.state) + return unix.IoctlSetTermios(fd, unix.TCSETS, &oldState.termios) } // GetState returns the current state of a terminal which may be useful to // restore the terminal after a signal. func GetState(fd int) (*State, error) { - oldTermiosPtr, err := unix.IoctlGetTermios(fd, unix.TCGETS) + termios, err := unix.IoctlGetTermios(fd, unix.TCGETS) if err != nil { return nil, err } - return &State{ - state: oldTermiosPtr, - }, nil + return &State{termios: *termios}, nil } // GetSize returns the dimensions of the given terminal. diff --git a/vendor/golang.org/x/crypto/ssh/terminal/util_windows.go b/vendor/golang.org/x/crypto/ssh/terminal/util_windows.go index 4933ac36118..8618955df73 100644 --- a/vendor/golang.org/x/crypto/ssh/terminal/util_windows.go +++ b/vendor/golang.org/x/crypto/ssh/terminal/util_windows.go @@ -89,9 +89,7 @@ func ReadPassword(fd int) ([]byte, error) { return nil, err } - defer func() { - windows.SetConsoleMode(windows.Handle(fd), old) - }() + defer windows.SetConsoleMode(windows.Handle(fd), old) var h windows.Handle p, _ := windows.GetCurrentProcess() diff --git a/vendor/golang.org/x/image/tiff/reader.go b/vendor/golang.org/x/image/tiff/reader.go index 0e3d3325f5f..8a941c112fd 100644 --- a/vendor/golang.org/x/image/tiff/reader.go +++ b/vendor/golang.org/x/image/tiff/reader.go @@ -264,6 +264,9 @@ func (d *decoder) decode(dst image.Image, xmin, ymin, xmax, ymax int) error { } img.SetGray16(x, y, color.Gray16{v}) } + if rMaxX == img.Bounds().Max.X { + d.off += 2 * (xmax - img.Bounds().Max.X) + } } } else { img := dst.(*image.Gray) diff --git a/vendor/golang.org/x/net/http/httpguts/guts.go b/vendor/golang.org/x/net/http/httpguts/guts.go new file mode 100644 index 00000000000..8255fd49b42 --- /dev/null +++ b/vendor/golang.org/x/net/http/httpguts/guts.go @@ -0,0 +1,65 @@ +// Copyright 2018 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 httpguts provides functions implementing various details +// of the HTTP specification. +// +// This package is shared by the standard library (which vendors it) +// and x/net/http2. It comes with no API stability promise. +package httpguts + +import ( + "net/textproto" + "strings" +) + +// SniffedContentType reports whether ct is a Content-Type that is known +// to cause client-side content sniffing. +// +// This provides just a partial implementation of mime.ParseMediaType +// with the assumption that the Content-Type is not attacker controlled. +func SniffedContentType(ct string) bool { + if i := strings.Index(ct, ";"); i != -1 { + ct = ct[:i] + } + ct = strings.ToLower(strings.TrimSpace(ct)) + return ct == "text/plain" || ct == "application/octet-stream" || + ct == "application/unknown" || ct == "unknown/unknown" || ct == "*/*" || + !strings.Contains(ct, "/") +} + +// ValidTrailerHeader reports whether name is a valid header field name to appear +// in trailers. +// See RFC 7230, Section 4.1.2 +func ValidTrailerHeader(name string) bool { + name = textproto.CanonicalMIMEHeaderKey(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/golang.org/x/net/lex/httplex/httplex.go b/vendor/golang.org/x/net/http/httpguts/httplex.go similarity index 97% rename from vendor/golang.org/x/net/lex/httplex/httplex.go rename to vendor/golang.org/x/net/http/httpguts/httplex.go index 20f2b8940ba..e7de24ee64e 100644 --- a/vendor/golang.org/x/net/lex/httplex/httplex.go +++ b/vendor/golang.org/x/net/http/httpguts/httplex.go @@ -2,12 +2,7 @@ // 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 +package httpguts import ( "net" diff --git a/vendor/golang.org/x/net/http2/frame.go b/vendor/golang.org/x/net/http2/frame.go index 3b14890728f..e32500779af 100644 --- a/vendor/golang.org/x/net/http2/frame.go +++ b/vendor/golang.org/x/net/http2/frame.go @@ -14,8 +14,8 @@ import ( "strings" "sync" + "golang.org/x/net/http/httpguts" "golang.org/x/net/http2/hpack" - "golang.org/x/net/lex/httplex" ) const frameHeaderLen = 9 @@ -1462,7 +1462,7 @@ func (fr *Framer) readMetaFrame(hf *HeadersFrame) (*MetaHeadersFrame, error) { if VerboseLogs && fr.logReads { fr.debugReadLoggerf("http2: decoded hpack field %+v", hf) } - if !httplex.ValidHeaderFieldValue(hf.Value) { + if !httpguts.ValidHeaderFieldValue(hf.Value) { invalid = headerFieldValueError(hf.Value) } isPseudo := strings.HasPrefix(hf.Name, ":") diff --git a/vendor/golang.org/x/net/http2/hpack/hpack.go b/vendor/golang.org/x/net/http2/hpack/hpack.go index 176644acdac..166788ceec5 100644 --- a/vendor/golang.org/x/net/http2/hpack/hpack.go +++ b/vendor/golang.org/x/net/http2/hpack/hpack.go @@ -389,6 +389,12 @@ func (d *Decoder) callEmit(hf HeaderField) error { // (same invariants and behavior as parseHeaderFieldRepr) func (d *Decoder) parseDynamicTableSizeUpdate() error { + // RFC 7541, sec 4.2: This dynamic table size update MUST occur at the + // beginning of the first header block following the change to the dynamic table size. + if d.dynTab.size > 0 { + return DecodingError{errors.New("dynamic table size update MUST occur at the beginning of a header block")} + } + buf := d.buf size, buf, err := readVarInt(5, buf) if err != nil { diff --git a/vendor/golang.org/x/net/http2/http2.go b/vendor/golang.org/x/net/http2/http2.go index 71db28a873a..c82428254af 100644 --- a/vendor/golang.org/x/net/http2/http2.go +++ b/vendor/golang.org/x/net/http2/http2.go @@ -29,7 +29,7 @@ import ( "strings" "sync" - "golang.org/x/net/lex/httplex" + "golang.org/x/net/http/httpguts" ) var ( @@ -179,7 +179,7 @@ var ( ) // validWireHeaderFieldName reports whether v is a valid header field -// name (key). See httplex.ValidHeaderName for the base rules. +// name (key). See httpguts.ValidHeaderName for the base rules. // // Further, http2 says: // "Just as in HTTP/1.x, header field names are strings of ASCII @@ -191,7 +191,7 @@ func validWireHeaderFieldName(v string) bool { return false } for _, r := range v { - if !httplex.IsTokenRune(r) { + if !httpguts.IsTokenRune(r) { return false } if 'A' <= r && r <= 'Z' { diff --git a/vendor/golang.org/x/net/http2/server.go b/vendor/golang.org/x/net/http2/server.go index 39ed755a86e..acf3b24186f 100644 --- a/vendor/golang.org/x/net/http2/server.go +++ b/vendor/golang.org/x/net/http2/server.go @@ -46,6 +46,7 @@ import ( "sync" "time" + "golang.org/x/net/http/httpguts" "golang.org/x/net/http2/hpack" ) @@ -1607,7 +1608,10 @@ func (sc *serverConn) processData(f *DataFrame) error { // 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) + // RFC 7540, sec 8.1.2.6: A request or response is also malformed if the + // value of a content-length header field does not equal the sum of the + // DATA frame payload lengths that form the body. + return streamError(id, ErrCodeProtocol) } if f.Length > 0 { // Check whether the client has flow control quota. @@ -1817,7 +1821,7 @@ func (st *stream) processTrailerHeaders(f *MetaHeadersFrame) error { if st.trailer != nil { for _, hf := range f.RegularFields() { key := sc.canonicalHeader(hf.Name) - if !ValidTrailerHeader(key) { + if !httpguts.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. @@ -2284,7 +2288,7 @@ func (rws *responseWriterState) hasTrailers() bool { return len(rws.trailers) != // written in the trailers at the end of the response. func (rws *responseWriterState) declareTrailer(k string) { k = http.CanonicalHeaderKey(k) - if !ValidTrailerHeader(k) { + if !httpguts.ValidTrailerHeader(k) { // Forbidden by RFC 7230, section 4.1.2. rws.conn.logf("ignoring invalid trailer %q", k) return @@ -2308,6 +2312,7 @@ func (rws *responseWriterState) writeChunk(p []byte) (n int, err error) { 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") @@ -2321,10 +2326,33 @@ func (rws *responseWriterState) writeChunk(p []byte) (n int, err error) { 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) && len(p) > 0 { - ctype = http.DetectContentType(p) + if cto := rws.snapHeader.Get("X-Content-Type-Options"); strings.EqualFold("nosniff", cto) { + // nosniff is an explicit directive not to guess a content-type. + // Content-sniffing is no less susceptible to polyglot attacks via + // hosted content when done on the server. + ctype = "application/octet-stream" + rws.conn.logf("http2: WriteHeader called with X-Content-Type-Options:nosniff but no Content-Type") + } else { + ctype = http.DetectContentType(p) + } + } + + var noSniff bool + if bodyAllowedForStatus(rws.status) && (rws.sentContentLen > 0 || len(p) > 0) { + // If the content type triggers client-side sniffing on old browsers, + // attach a X-Content-Type-Options header if not present (or explicitly nil). + if _, ok := rws.snapHeader["X-Content-Type-Options"]; !ok { + if hasContentType { + noSniff = httpguts.SniffedContentType(rws.snapHeader.Get("Content-Type")) + } else if ctype != "" { + noSniff = httpguts.SniffedContentType(ctype) + } + } } + var date string if _, ok := rws.snapHeader["Date"]; !ok { // TODO(bradfitz): be faster here, like net/http? measure. @@ -2343,6 +2371,7 @@ func (rws *responseWriterState) writeChunk(p []byte) (n int, err error) { endStream: endStream, contentType: ctype, contentLength: clen, + noSniff: noSniff, date: date, }) if err != nil { @@ -2838,41 +2867,6 @@ func new400Handler(err error) http.HandlerFunc { } } -// 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, -} - // h1ServerKeepAlivesDisabled reports whether hs has its keep-alives // disabled. See comments on h1ServerShutdownChan above for why // the code is written this way. diff --git a/vendor/golang.org/x/net/http2/transport.go b/vendor/golang.org/x/net/http2/transport.go index e6b321f4bb6..d23a226251c 100644 --- a/vendor/golang.org/x/net/http2/transport.go +++ b/vendor/golang.org/x/net/http2/transport.go @@ -27,9 +27,9 @@ import ( "sync" "time" + "golang.org/x/net/http/httpguts" "golang.org/x/net/http2/hpack" "golang.org/x/net/idna" - "golang.org/x/net/lex/httplex" ) const ( @@ -567,6 +567,10 @@ func (t *Transport) newClientConn(c net.Conn, singleUse bool) (*ClientConn, erro // henc in response to SETTINGS frames? cc.henc = hpack.NewEncoder(&cc.hbuf) + if t.AllowHTTP { + cc.nextStreamID = 3 + } + if cs, ok := c.(connectionStater); ok { state := cs.ConnectionState() cc.tlsState = &state @@ -951,6 +955,9 @@ func (cc *ClientConn) awaitOpenSlotForRequest(req *http.Request) error { for { cc.lastActive = time.Now() if cc.closed || !cc.canTakeNewRequestLocked() { + if waitingForConn != nil { + close(waitingForConn) + } return errClientConnUnusable } if int64(len(cc.streams))+1 <= int64(cc.maxConcurrentStreams) { @@ -1174,7 +1181,7 @@ func (cc *ClientConn) encodeHeaders(req *http.Request, addGzipHeader bool, trail if host == "" { host = req.URL.Host } - host, err := httplex.PunycodeHostPort(host) + host, err := httpguts.PunycodeHostPort(host) if err != nil { return nil, err } @@ -1199,11 +1206,11 @@ func (cc *ClientConn) encodeHeaders(req *http.Request, addGzipHeader bool, trail // 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) { + if !httpguts.ValidHeaderFieldName(k) { return nil, fmt.Errorf("invalid HTTP header name %q", k) } for _, v := range vv { - if !httplex.ValidHeaderFieldValue(v) { + if !httpguts.ValidHeaderFieldValue(v) { return nil, fmt.Errorf("invalid HTTP header value %q for header %q", v, k) } } @@ -2244,7 +2251,7 @@ func (t *Transport) getBodyWriterState(cs *clientStream, body io.Reader) (s body } s.delay = t.expectContinueTimeout() if s.delay == 0 || - !httplex.HeaderValuesContainsToken( + !httpguts.HeaderValuesContainsToken( cs.req.Header["Expect"], "100-continue") { return @@ -2299,5 +2306,5 @@ func (s bodyWriterState) scheduleBodyWrite() { // 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") + return req.Close || httpguts.HeaderValuesContainsToken(req.Header["Connection"], "close") } diff --git a/vendor/golang.org/x/net/http2/write.go b/vendor/golang.org/x/net/http2/write.go index 54ab4a88e7b..a5120412e67 100644 --- a/vendor/golang.org/x/net/http2/write.go +++ b/vendor/golang.org/x/net/http2/write.go @@ -11,8 +11,8 @@ import ( "net/http" "net/url" + "golang.org/x/net/http/httpguts" "golang.org/x/net/http2/hpack" - "golang.org/x/net/lex/httplex" ) // writeFramer is implemented by any type that is used to write frames. @@ -186,6 +186,7 @@ type writeResHeaders struct { date string contentType string contentLength string + noSniff bool } func encKV(enc *hpack.Encoder, k, v string) { @@ -222,6 +223,9 @@ func (w *writeResHeaders) writeFrame(ctx writeContext) error { if w.contentLength != "" { encKV(enc, "content-length", w.contentLength) } + if w.noSniff { + encKV(enc, "x-content-type-options", "nosniff") + } if w.date != "" { encKV(enc, "date", w.date) } @@ -350,7 +354,7 @@ func encodeHeaders(enc *hpack.Encoder, h http.Header, keys []string) { } isTE := k == "transfer-encoding" for _, v := range vv { - if !httplex.ValidHeaderFieldValue(v) { + if !httpguts.ValidHeaderFieldValue(v) { // TODO: return an error? golang.org/issue/14048 // For now just omit it. continue diff --git a/vendor/golang.org/x/net/internal/timeseries/timeseries.go b/vendor/golang.org/x/net/internal/timeseries/timeseries.go new file mode 100644 index 00000000000..685f0e7ea23 --- /dev/null +++ b/vendor/golang.org/x/net/internal/timeseries/timeseries.go @@ -0,0 +1,525 @@ +// 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 timeseries implements a time series structure for stats collection. +package timeseries // import "golang.org/x/net/internal/timeseries" + +import ( + "fmt" + "log" + "time" +) + +const ( + timeSeriesNumBuckets = 64 + minuteHourSeriesNumBuckets = 60 +) + +var timeSeriesResolutions = []time.Duration{ + 1 * time.Second, + 10 * time.Second, + 1 * time.Minute, + 10 * time.Minute, + 1 * time.Hour, + 6 * time.Hour, + 24 * time.Hour, // 1 day + 7 * 24 * time.Hour, // 1 week + 4 * 7 * 24 * time.Hour, // 4 weeks + 16 * 7 * 24 * time.Hour, // 16 weeks +} + +var minuteHourSeriesResolutions = []time.Duration{ + 1 * time.Second, + 1 * time.Minute, +} + +// An Observable is a kind of data that can be aggregated in a time series. +type Observable interface { + Multiply(ratio float64) // Multiplies the data in self by a given ratio + Add(other Observable) // Adds the data from a different observation to self + Clear() // Clears the observation so it can be reused. + CopyFrom(other Observable) // Copies the contents of a given observation to self +} + +// Float attaches the methods of Observable to a float64. +type Float float64 + +// NewFloat returns a Float. +func NewFloat() Observable { + f := Float(0) + return &f +} + +// String returns the float as a string. +func (f *Float) String() string { return fmt.Sprintf("%g", f.Value()) } + +// Value returns the float's value. +func (f *Float) Value() float64 { return float64(*f) } + +func (f *Float) Multiply(ratio float64) { *f *= Float(ratio) } + +func (f *Float) Add(other Observable) { + o := other.(*Float) + *f += *o +} + +func (f *Float) Clear() { *f = 0 } + +func (f *Float) CopyFrom(other Observable) { + o := other.(*Float) + *f = *o +} + +// A Clock tells the current time. +type Clock interface { + Time() time.Time +} + +type defaultClock int + +var defaultClockInstance defaultClock + +func (defaultClock) Time() time.Time { return time.Now() } + +// Information kept per level. Each level consists of a circular list of +// observations. The start of the level may be derived from end and the +// len(buckets) * sizeInMillis. +type tsLevel struct { + oldest int // index to oldest bucketed Observable + newest int // index to newest bucketed Observable + end time.Time // end timestamp for this level + size time.Duration // duration of the bucketed Observable + buckets []Observable // collections of observations + provider func() Observable // used for creating new Observable +} + +func (l *tsLevel) Clear() { + l.oldest = 0 + l.newest = len(l.buckets) - 1 + l.end = time.Time{} + for i := range l.buckets { + if l.buckets[i] != nil { + l.buckets[i].Clear() + l.buckets[i] = nil + } + } +} + +func (l *tsLevel) InitLevel(size time.Duration, numBuckets int, f func() Observable) { + l.size = size + l.provider = f + l.buckets = make([]Observable, numBuckets) +} + +// Keeps a sequence of levels. Each level is responsible for storing data at +// a given resolution. For example, the first level stores data at a one +// minute resolution while the second level stores data at a one hour +// resolution. + +// Each level is represented by a sequence of buckets. Each bucket spans an +// interval equal to the resolution of the level. New observations are added +// to the last bucket. +type timeSeries struct { + provider func() Observable // make more Observable + numBuckets int // number of buckets in each level + levels []*tsLevel // levels of bucketed Observable + lastAdd time.Time // time of last Observable tracked + total Observable // convenient aggregation of all Observable + clock Clock // Clock for getting current time + pending Observable // observations not yet bucketed + pendingTime time.Time // what time are we keeping in pending + dirty bool // if there are pending observations +} + +// init initializes a level according to the supplied criteria. +func (ts *timeSeries) init(resolutions []time.Duration, f func() Observable, numBuckets int, clock Clock) { + ts.provider = f + ts.numBuckets = numBuckets + ts.clock = clock + ts.levels = make([]*tsLevel, len(resolutions)) + + for i := range resolutions { + if i > 0 && resolutions[i-1] >= resolutions[i] { + log.Print("timeseries: resolutions must be monotonically increasing") + break + } + newLevel := new(tsLevel) + newLevel.InitLevel(resolutions[i], ts.numBuckets, ts.provider) + ts.levels[i] = newLevel + } + + ts.Clear() +} + +// Clear removes all observations from the time series. +func (ts *timeSeries) Clear() { + ts.lastAdd = time.Time{} + ts.total = ts.resetObservation(ts.total) + ts.pending = ts.resetObservation(ts.pending) + ts.pendingTime = time.Time{} + ts.dirty = false + + for i := range ts.levels { + ts.levels[i].Clear() + } +} + +// Add records an observation at the current time. +func (ts *timeSeries) Add(observation Observable) { + ts.AddWithTime(observation, ts.clock.Time()) +} + +// AddWithTime records an observation at the specified time. +func (ts *timeSeries) AddWithTime(observation Observable, t time.Time) { + + smallBucketDuration := ts.levels[0].size + + if t.After(ts.lastAdd) { + ts.lastAdd = t + } + + if t.After(ts.pendingTime) { + ts.advance(t) + ts.mergePendingUpdates() + ts.pendingTime = ts.levels[0].end + ts.pending.CopyFrom(observation) + ts.dirty = true + } else if t.After(ts.pendingTime.Add(-1 * smallBucketDuration)) { + // The observation is close enough to go into the pending bucket. + // This compensates for clock skewing and small scheduling delays + // by letting the update stay in the fast path. + ts.pending.Add(observation) + ts.dirty = true + } else { + ts.mergeValue(observation, t) + } +} + +// mergeValue inserts the observation at the specified time in the past into all levels. +func (ts *timeSeries) mergeValue(observation Observable, t time.Time) { + for _, level := range ts.levels { + index := (ts.numBuckets - 1) - int(level.end.Sub(t)/level.size) + if 0 <= index && index < ts.numBuckets { + bucketNumber := (level.oldest + index) % ts.numBuckets + if level.buckets[bucketNumber] == nil { + level.buckets[bucketNumber] = level.provider() + } + level.buckets[bucketNumber].Add(observation) + } + } + ts.total.Add(observation) +} + +// mergePendingUpdates applies the pending updates into all levels. +func (ts *timeSeries) mergePendingUpdates() { + if ts.dirty { + ts.mergeValue(ts.pending, ts.pendingTime) + ts.pending = ts.resetObservation(ts.pending) + ts.dirty = false + } +} + +// advance cycles the buckets at each level until the latest bucket in +// each level can hold the time specified. +func (ts *timeSeries) advance(t time.Time) { + if !t.After(ts.levels[0].end) { + return + } + for i := 0; i < len(ts.levels); i++ { + level := ts.levels[i] + if !level.end.Before(t) { + break + } + + // If the time is sufficiently far, just clear the level and advance + // directly. + if !t.Before(level.end.Add(level.size * time.Duration(ts.numBuckets))) { + for _, b := range level.buckets { + ts.resetObservation(b) + } + level.end = time.Unix(0, (t.UnixNano()/level.size.Nanoseconds())*level.size.Nanoseconds()) + } + + for t.After(level.end) { + level.end = level.end.Add(level.size) + level.newest = level.oldest + level.oldest = (level.oldest + 1) % ts.numBuckets + ts.resetObservation(level.buckets[level.newest]) + } + + t = level.end + } +} + +// Latest returns the sum of the num latest buckets from the level. +func (ts *timeSeries) Latest(level, num int) Observable { + now := ts.clock.Time() + if ts.levels[0].end.Before(now) { + ts.advance(now) + } + + ts.mergePendingUpdates() + + result := ts.provider() + l := ts.levels[level] + index := l.newest + + for i := 0; i < num; i++ { + if l.buckets[index] != nil { + result.Add(l.buckets[index]) + } + if index == 0 { + index = ts.numBuckets + } + index-- + } + + return result +} + +// LatestBuckets returns a copy of the num latest buckets from level. +func (ts *timeSeries) LatestBuckets(level, num int) []Observable { + if level < 0 || level > len(ts.levels) { + log.Print("timeseries: bad level argument: ", level) + return nil + } + if num < 0 || num >= ts.numBuckets { + log.Print("timeseries: bad num argument: ", num) + return nil + } + + results := make([]Observable, num) + now := ts.clock.Time() + if ts.levels[0].end.Before(now) { + ts.advance(now) + } + + ts.mergePendingUpdates() + + l := ts.levels[level] + index := l.newest + + for i := 0; i < num; i++ { + result := ts.provider() + results[i] = result + if l.buckets[index] != nil { + result.CopyFrom(l.buckets[index]) + } + + if index == 0 { + index = ts.numBuckets + } + index -= 1 + } + return results +} + +// ScaleBy updates observations by scaling by factor. +func (ts *timeSeries) ScaleBy(factor float64) { + for _, l := range ts.levels { + for i := 0; i < ts.numBuckets; i++ { + l.buckets[i].Multiply(factor) + } + } + + ts.total.Multiply(factor) + ts.pending.Multiply(factor) +} + +// Range returns the sum of observations added over the specified time range. +// If start or finish times don't fall on bucket boundaries of the same +// level, then return values are approximate answers. +func (ts *timeSeries) Range(start, finish time.Time) Observable { + return ts.ComputeRange(start, finish, 1)[0] +} + +// Recent returns the sum of observations from the last delta. +func (ts *timeSeries) Recent(delta time.Duration) Observable { + now := ts.clock.Time() + return ts.Range(now.Add(-delta), now) +} + +// Total returns the total of all observations. +func (ts *timeSeries) Total() Observable { + ts.mergePendingUpdates() + return ts.total +} + +// ComputeRange computes a specified number of values into a slice using +// the observations recorded over the specified time period. The return +// values are approximate if the start or finish times don't fall on the +// bucket boundaries at the same level or if the number of buckets spanning +// the range is not an integral multiple of num. +func (ts *timeSeries) ComputeRange(start, finish time.Time, num int) []Observable { + if start.After(finish) { + log.Printf("timeseries: start > finish, %v>%v", start, finish) + return nil + } + + if num < 0 { + log.Printf("timeseries: num < 0, %v", num) + return nil + } + + results := make([]Observable, num) + + for _, l := range ts.levels { + if !start.Before(l.end.Add(-l.size * time.Duration(ts.numBuckets))) { + ts.extract(l, start, finish, num, results) + return results + } + } + + // Failed to find a level that covers the desired range. So just + // extract from the last level, even if it doesn't cover the entire + // desired range. + ts.extract(ts.levels[len(ts.levels)-1], start, finish, num, results) + + return results +} + +// RecentList returns the specified number of values in slice over the most +// recent time period of the specified range. +func (ts *timeSeries) RecentList(delta time.Duration, num int) []Observable { + if delta < 0 { + return nil + } + now := ts.clock.Time() + return ts.ComputeRange(now.Add(-delta), now, num) +} + +// extract returns a slice of specified number of observations from a given +// level over a given range. +func (ts *timeSeries) extract(l *tsLevel, start, finish time.Time, num int, results []Observable) { + ts.mergePendingUpdates() + + srcInterval := l.size + dstInterval := finish.Sub(start) / time.Duration(num) + dstStart := start + srcStart := l.end.Add(-srcInterval * time.Duration(ts.numBuckets)) + + srcIndex := 0 + + // Where should scanning start? + if dstStart.After(srcStart) { + advance := dstStart.Sub(srcStart) / srcInterval + srcIndex += int(advance) + srcStart = srcStart.Add(advance * srcInterval) + } + + // The i'th value is computed as show below. + // interval = (finish/start)/num + // i'th value = sum of observation in range + // [ start + i * interval, + // start + (i + 1) * interval ) + for i := 0; i < num; i++ { + results[i] = ts.resetObservation(results[i]) + dstEnd := dstStart.Add(dstInterval) + for srcIndex < ts.numBuckets && srcStart.Before(dstEnd) { + srcEnd := srcStart.Add(srcInterval) + if srcEnd.After(ts.lastAdd) { + srcEnd = ts.lastAdd + } + + if !srcEnd.Before(dstStart) { + srcValue := l.buckets[(srcIndex+l.oldest)%ts.numBuckets] + if !srcStart.Before(dstStart) && !srcEnd.After(dstEnd) { + // dst completely contains src. + if srcValue != nil { + results[i].Add(srcValue) + } + } else { + // dst partially overlaps src. + overlapStart := maxTime(srcStart, dstStart) + overlapEnd := minTime(srcEnd, dstEnd) + base := srcEnd.Sub(srcStart) + fraction := overlapEnd.Sub(overlapStart).Seconds() / base.Seconds() + + used := ts.provider() + if srcValue != nil { + used.CopyFrom(srcValue) + } + used.Multiply(fraction) + results[i].Add(used) + } + + if srcEnd.After(dstEnd) { + break + } + } + srcIndex++ + srcStart = srcStart.Add(srcInterval) + } + dstStart = dstStart.Add(dstInterval) + } +} + +// resetObservation clears the content so the struct may be reused. +func (ts *timeSeries) resetObservation(observation Observable) Observable { + if observation == nil { + observation = ts.provider() + } else { + observation.Clear() + } + return observation +} + +// TimeSeries tracks data at granularities from 1 second to 16 weeks. +type TimeSeries struct { + timeSeries +} + +// NewTimeSeries creates a new TimeSeries using the function provided for creating new Observable. +func NewTimeSeries(f func() Observable) *TimeSeries { + return NewTimeSeriesWithClock(f, defaultClockInstance) +} + +// NewTimeSeriesWithClock creates a new TimeSeries using the function provided for creating new Observable and the clock for +// assigning timestamps. +func NewTimeSeriesWithClock(f func() Observable, clock Clock) *TimeSeries { + ts := new(TimeSeries) + ts.timeSeries.init(timeSeriesResolutions, f, timeSeriesNumBuckets, clock) + return ts +} + +// MinuteHourSeries tracks data at granularities of 1 minute and 1 hour. +type MinuteHourSeries struct { + timeSeries +} + +// NewMinuteHourSeries creates a new MinuteHourSeries using the function provided for creating new Observable. +func NewMinuteHourSeries(f func() Observable) *MinuteHourSeries { + return NewMinuteHourSeriesWithClock(f, defaultClockInstance) +} + +// NewMinuteHourSeriesWithClock creates a new MinuteHourSeries using the function provided for creating new Observable and the clock for +// assigning timestamps. +func NewMinuteHourSeriesWithClock(f func() Observable, clock Clock) *MinuteHourSeries { + ts := new(MinuteHourSeries) + ts.timeSeries.init(minuteHourSeriesResolutions, f, + minuteHourSeriesNumBuckets, clock) + return ts +} + +func (ts *MinuteHourSeries) Minute() Observable { + return ts.timeSeries.Latest(0, 60) +} + +func (ts *MinuteHourSeries) Hour() Observable { + return ts.timeSeries.Latest(1, 60) +} + +func minTime(a, b time.Time) time.Time { + if a.Before(b) { + return a + } + return b +} + +func maxTime(a, b time.Time) time.Time { + if a.After(b) { + return a + } + return b +} diff --git a/vendor/golang.org/x/net/trace/events.go b/vendor/golang.org/x/net/trace/events.go new file mode 100644 index 00000000000..c646a6952e5 --- /dev/null +++ b/vendor/golang.org/x/net/trace/events.go @@ -0,0 +1,532 @@ +// 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 trace + +import ( + "bytes" + "fmt" + "html/template" + "io" + "log" + "net/http" + "runtime" + "sort" + "strconv" + "strings" + "sync" + "sync/atomic" + "text/tabwriter" + "time" +) + +const maxEventsPerLog = 100 + +type bucket struct { + MaxErrAge time.Duration + String string +} + +var buckets = []bucket{ + {0, "total"}, + {10 * time.Second, "errs<10s"}, + {1 * time.Minute, "errs<1m"}, + {10 * time.Minute, "errs<10m"}, + {1 * time.Hour, "errs<1h"}, + {10 * time.Hour, "errs<10h"}, + {24000 * time.Hour, "errors"}, +} + +// RenderEvents renders the HTML page typically served at /debug/events. +// It does not do any auth checking. The request may be nil. +// +// Most users will use the Events handler. +func RenderEvents(w http.ResponseWriter, req *http.Request, sensitive bool) { + now := time.Now() + data := &struct { + Families []string // family names + Buckets []bucket + Counts [][]int // eventLog count per family/bucket + + // Set when a bucket has been selected. + Family string + Bucket int + EventLogs eventLogs + Expanded bool + }{ + Buckets: buckets, + } + + data.Families = make([]string, 0, len(families)) + famMu.RLock() + for name := range families { + data.Families = append(data.Families, name) + } + famMu.RUnlock() + sort.Strings(data.Families) + + // Count the number of eventLogs in each family for each error age. + data.Counts = make([][]int, len(data.Families)) + for i, name := range data.Families { + // TODO(sameer): move this loop under the family lock. + f := getEventFamily(name) + data.Counts[i] = make([]int, len(data.Buckets)) + for j, b := range data.Buckets { + data.Counts[i][j] = f.Count(now, b.MaxErrAge) + } + } + + if req != nil { + var ok bool + data.Family, data.Bucket, ok = parseEventsArgs(req) + if !ok { + // No-op + } else { + data.EventLogs = getEventFamily(data.Family).Copy(now, buckets[data.Bucket].MaxErrAge) + } + if data.EventLogs != nil { + defer data.EventLogs.Free() + sort.Sort(data.EventLogs) + } + if exp, err := strconv.ParseBool(req.FormValue("exp")); err == nil { + data.Expanded = exp + } + } + + famMu.RLock() + defer famMu.RUnlock() + if err := eventsTmpl().Execute(w, data); err != nil { + log.Printf("net/trace: Failed executing template: %v", err) + } +} + +func parseEventsArgs(req *http.Request) (fam string, b int, ok bool) { + fam, bStr := req.FormValue("fam"), req.FormValue("b") + if fam == "" || bStr == "" { + return "", 0, false + } + b, err := strconv.Atoi(bStr) + if err != nil || b < 0 || b >= len(buckets) { + return "", 0, false + } + return fam, b, true +} + +// An EventLog provides a log of events associated with a specific object. +type EventLog interface { + // Printf formats its arguments with fmt.Sprintf and adds the + // result to the event log. + Printf(format string, a ...interface{}) + + // Errorf is like Printf, but it marks this event as an error. + Errorf(format string, a ...interface{}) + + // Finish declares that this event log is complete. + // The event log should not be used after calling this method. + Finish() +} + +// NewEventLog returns a new EventLog with the specified family name +// and title. +func NewEventLog(family, title string) EventLog { + el := newEventLog() + el.ref() + el.Family, el.Title = family, title + el.Start = time.Now() + el.events = make([]logEntry, 0, maxEventsPerLog) + el.stack = make([]uintptr, 32) + n := runtime.Callers(2, el.stack) + el.stack = el.stack[:n] + + getEventFamily(family).add(el) + return el +} + +func (el *eventLog) Finish() { + getEventFamily(el.Family).remove(el) + el.unref() // matches ref in New +} + +var ( + famMu sync.RWMutex + families = make(map[string]*eventFamily) // family name => family +) + +func getEventFamily(fam string) *eventFamily { + famMu.Lock() + defer famMu.Unlock() + f := families[fam] + if f == nil { + f = &eventFamily{} + families[fam] = f + } + return f +} + +type eventFamily struct { + mu sync.RWMutex + eventLogs eventLogs +} + +func (f *eventFamily) add(el *eventLog) { + f.mu.Lock() + f.eventLogs = append(f.eventLogs, el) + f.mu.Unlock() +} + +func (f *eventFamily) remove(el *eventLog) { + f.mu.Lock() + defer f.mu.Unlock() + for i, el0 := range f.eventLogs { + if el == el0 { + copy(f.eventLogs[i:], f.eventLogs[i+1:]) + f.eventLogs = f.eventLogs[:len(f.eventLogs)-1] + return + } + } +} + +func (f *eventFamily) Count(now time.Time, maxErrAge time.Duration) (n int) { + f.mu.RLock() + defer f.mu.RUnlock() + for _, el := range f.eventLogs { + if el.hasRecentError(now, maxErrAge) { + n++ + } + } + return +} + +func (f *eventFamily) Copy(now time.Time, maxErrAge time.Duration) (els eventLogs) { + f.mu.RLock() + defer f.mu.RUnlock() + els = make(eventLogs, 0, len(f.eventLogs)) + for _, el := range f.eventLogs { + if el.hasRecentError(now, maxErrAge) { + el.ref() + els = append(els, el) + } + } + return +} + +type eventLogs []*eventLog + +// Free calls unref on each element of the list. +func (els eventLogs) Free() { + for _, el := range els { + el.unref() + } +} + +// eventLogs may be sorted in reverse chronological order. +func (els eventLogs) Len() int { return len(els) } +func (els eventLogs) Less(i, j int) bool { return els[i].Start.After(els[j].Start) } +func (els eventLogs) Swap(i, j int) { els[i], els[j] = els[j], els[i] } + +// A logEntry is a timestamped log entry in an event log. +type logEntry struct { + When time.Time + Elapsed time.Duration // since previous event in log + NewDay bool // whether this event is on a different day to the previous event + What string + IsErr bool +} + +// WhenString returns a string representation of the elapsed time of the event. +// It will include the date if midnight was crossed. +func (e logEntry) WhenString() string { + if e.NewDay { + return e.When.Format("2006/01/02 15:04:05.000000") + } + return e.When.Format("15:04:05.000000") +} + +// An eventLog represents an active event log. +type eventLog struct { + // Family is the top-level grouping of event logs to which this belongs. + Family string + + // Title is the title of this event log. + Title string + + // Timing information. + Start time.Time + + // Call stack where this event log was created. + stack []uintptr + + // Append-only sequence of events. + // + // TODO(sameer): change this to a ring buffer to avoid the array copy + // when we hit maxEventsPerLog. + mu sync.RWMutex + events []logEntry + LastErrorTime time.Time + discarded int + + refs int32 // how many buckets this is in +} + +func (el *eventLog) reset() { + // Clear all but the mutex. Mutexes may not be copied, even when unlocked. + el.Family = "" + el.Title = "" + el.Start = time.Time{} + el.stack = nil + el.events = nil + el.LastErrorTime = time.Time{} + el.discarded = 0 + el.refs = 0 +} + +func (el *eventLog) hasRecentError(now time.Time, maxErrAge time.Duration) bool { + if maxErrAge == 0 { + return true + } + el.mu.RLock() + defer el.mu.RUnlock() + return now.Sub(el.LastErrorTime) < maxErrAge +} + +// delta returns the elapsed time since the last event or the log start, +// and whether it spans midnight. +// L >= el.mu +func (el *eventLog) delta(t time.Time) (time.Duration, bool) { + if len(el.events) == 0 { + return t.Sub(el.Start), false + } + prev := el.events[len(el.events)-1].When + return t.Sub(prev), prev.Day() != t.Day() + +} + +func (el *eventLog) Printf(format string, a ...interface{}) { + el.printf(false, format, a...) +} + +func (el *eventLog) Errorf(format string, a ...interface{}) { + el.printf(true, format, a...) +} + +func (el *eventLog) printf(isErr bool, format string, a ...interface{}) { + e := logEntry{When: time.Now(), IsErr: isErr, What: fmt.Sprintf(format, a...)} + el.mu.Lock() + e.Elapsed, e.NewDay = el.delta(e.When) + if len(el.events) < maxEventsPerLog { + el.events = append(el.events, e) + } else { + // Discard the oldest event. + if el.discarded == 0 { + // el.discarded starts at two to count for the event it + // is replacing, plus the next one that we are about to + // drop. + el.discarded = 2 + } else { + el.discarded++ + } + // TODO(sameer): if this causes allocations on a critical path, + // change eventLog.What to be a fmt.Stringer, as in trace.go. + el.events[0].What = fmt.Sprintf("(%d events discarded)", el.discarded) + // The timestamp of the discarded meta-event should be + // the time of the last event it is representing. + el.events[0].When = el.events[1].When + copy(el.events[1:], el.events[2:]) + el.events[maxEventsPerLog-1] = e + } + if e.IsErr { + el.LastErrorTime = e.When + } + el.mu.Unlock() +} + +func (el *eventLog) ref() { + atomic.AddInt32(&el.refs, 1) +} + +func (el *eventLog) unref() { + if atomic.AddInt32(&el.refs, -1) == 0 { + freeEventLog(el) + } +} + +func (el *eventLog) When() string { + return el.Start.Format("2006/01/02 15:04:05.000000") +} + +func (el *eventLog) ElapsedTime() string { + elapsed := time.Since(el.Start) + return fmt.Sprintf("%.6f", elapsed.Seconds()) +} + +func (el *eventLog) Stack() string { + buf := new(bytes.Buffer) + tw := tabwriter.NewWriter(buf, 1, 8, 1, '\t', 0) + printStackRecord(tw, el.stack) + tw.Flush() + return buf.String() +} + +// printStackRecord prints the function + source line information +// for a single stack trace. +// Adapted from runtime/pprof/pprof.go. +func printStackRecord(w io.Writer, stk []uintptr) { + for _, pc := range stk { + f := runtime.FuncForPC(pc) + if f == nil { + continue + } + file, line := f.FileLine(pc) + name := f.Name() + // Hide runtime.goexit and any runtime functions at the beginning. + if strings.HasPrefix(name, "runtime.") { + continue + } + fmt.Fprintf(w, "# %s\t%s:%d\n", name, file, line) + } +} + +func (el *eventLog) Events() []logEntry { + el.mu.RLock() + defer el.mu.RUnlock() + return el.events +} + +// freeEventLogs is a freelist of *eventLog +var freeEventLogs = make(chan *eventLog, 1000) + +// newEventLog returns a event log ready to use. +func newEventLog() *eventLog { + select { + case el := <-freeEventLogs: + return el + default: + return new(eventLog) + } +} + +// freeEventLog adds el to freeEventLogs if there's room. +// This is non-blocking. +func freeEventLog(el *eventLog) { + el.reset() + select { + case freeEventLogs <- el: + default: + } +} + +var eventsTmplCache *template.Template +var eventsTmplOnce sync.Once + +func eventsTmpl() *template.Template { + eventsTmplOnce.Do(func() { + eventsTmplCache = template.Must(template.New("events").Funcs(template.FuncMap{ + "elapsed": elapsed, + "trimSpace": strings.TrimSpace, + }).Parse(eventsHTML)) + }) + return eventsTmplCache +} + +const eventsHTML = ` + + + events + + + + +

/debug/events

+ + + {{range $i, $fam := .Families}} + + + + {{range $j, $bucket := $.Buckets}} + {{$n := index $.Counts $i $j}} + + {{end}} + + {{end}} +
{{$fam}} + {{if $n}}{{end}} + [{{$n}} {{$bucket.String}}] + {{if $n}}{{end}} +
+ +{{if $.EventLogs}} +
+

Family: {{$.Family}}

+ +{{if $.Expanded}}{{end}} +[Summary]{{if $.Expanded}}{{end}} + +{{if not $.Expanded}}{{end}} +[Expanded]{{if not $.Expanded}}{{end}} + + + + {{range $el := $.EventLogs}} + + + + + {{if $.Expanded}} + + + + + + {{range $el.Events}} + + + + + + {{end}} + {{end}} + {{end}} +
WhenElapsed
{{$el.When}}{{$el.ElapsedTime}}{{$el.Title}} +
{{$el.Stack|trimSpace}}
{{.WhenString}}{{elapsed .Elapsed}}.{{if .IsErr}}E{{else}}.{{end}}. {{.What}}
+{{end}} + + +` diff --git a/vendor/golang.org/x/net/trace/histogram.go b/vendor/golang.org/x/net/trace/histogram.go new file mode 100644 index 00000000000..9bf4286c794 --- /dev/null +++ b/vendor/golang.org/x/net/trace/histogram.go @@ -0,0 +1,365 @@ +// 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 trace + +// This file implements histogramming for RPC statistics collection. + +import ( + "bytes" + "fmt" + "html/template" + "log" + "math" + "sync" + + "golang.org/x/net/internal/timeseries" +) + +const ( + bucketCount = 38 +) + +// histogram keeps counts of values in buckets that are spaced +// out in powers of 2: 0-1, 2-3, 4-7... +// histogram implements timeseries.Observable +type histogram struct { + sum int64 // running total of measurements + sumOfSquares float64 // square of running total + buckets []int64 // bucketed values for histogram + value int // holds a single value as an optimization + valueCount int64 // number of values recorded for single value +} + +// AddMeasurement records a value measurement observation to the histogram. +func (h *histogram) addMeasurement(value int64) { + // TODO: assert invariant + h.sum += value + h.sumOfSquares += float64(value) * float64(value) + + bucketIndex := getBucket(value) + + if h.valueCount == 0 || (h.valueCount > 0 && h.value == bucketIndex) { + h.value = bucketIndex + h.valueCount++ + } else { + h.allocateBuckets() + h.buckets[bucketIndex]++ + } +} + +func (h *histogram) allocateBuckets() { + if h.buckets == nil { + h.buckets = make([]int64, bucketCount) + h.buckets[h.value] = h.valueCount + h.value = 0 + h.valueCount = -1 + } +} + +func log2(i int64) int { + n := 0 + for ; i >= 0x100; i >>= 8 { + n += 8 + } + for ; i > 0; i >>= 1 { + n += 1 + } + return n +} + +func getBucket(i int64) (index int) { + index = log2(i) - 1 + if index < 0 { + index = 0 + } + if index >= bucketCount { + index = bucketCount - 1 + } + return +} + +// Total returns the number of recorded observations. +func (h *histogram) total() (total int64) { + if h.valueCount >= 0 { + total = h.valueCount + } + for _, val := range h.buckets { + total += int64(val) + } + return +} + +// Average returns the average value of recorded observations. +func (h *histogram) average() float64 { + t := h.total() + if t == 0 { + return 0 + } + return float64(h.sum) / float64(t) +} + +// Variance returns the variance of recorded observations. +func (h *histogram) variance() float64 { + t := float64(h.total()) + if t == 0 { + return 0 + } + s := float64(h.sum) / t + return h.sumOfSquares/t - s*s +} + +// StandardDeviation returns the standard deviation of recorded observations. +func (h *histogram) standardDeviation() float64 { + return math.Sqrt(h.variance()) +} + +// PercentileBoundary estimates the value that the given fraction of recorded +// observations are less than. +func (h *histogram) percentileBoundary(percentile float64) int64 { + total := h.total() + + // Corner cases (make sure result is strictly less than Total()) + if total == 0 { + return 0 + } else if total == 1 { + return int64(h.average()) + } + + percentOfTotal := round(float64(total) * percentile) + var runningTotal int64 + + for i := range h.buckets { + value := h.buckets[i] + runningTotal += value + if runningTotal == percentOfTotal { + // We hit an exact bucket boundary. If the next bucket has data, it is a + // good estimate of the value. If the bucket is empty, we interpolate the + // midpoint between the next bucket's boundary and the next non-zero + // bucket. If the remaining buckets are all empty, then we use the + // boundary for the next bucket as the estimate. + j := uint8(i + 1) + min := bucketBoundary(j) + if runningTotal < total { + for h.buckets[j] == 0 { + j++ + } + } + max := bucketBoundary(j) + return min + round(float64(max-min)/2) + } else if runningTotal > percentOfTotal { + // The value is in this bucket. Interpolate the value. + delta := runningTotal - percentOfTotal + percentBucket := float64(value-delta) / float64(value) + bucketMin := bucketBoundary(uint8(i)) + nextBucketMin := bucketBoundary(uint8(i + 1)) + bucketSize := nextBucketMin - bucketMin + return bucketMin + round(percentBucket*float64(bucketSize)) + } + } + return bucketBoundary(bucketCount - 1) +} + +// Median returns the estimated median of the observed values. +func (h *histogram) median() int64 { + return h.percentileBoundary(0.5) +} + +// Add adds other to h. +func (h *histogram) Add(other timeseries.Observable) { + o := other.(*histogram) + if o.valueCount == 0 { + // Other histogram is empty + } else if h.valueCount >= 0 && o.valueCount > 0 && h.value == o.value { + // Both have a single bucketed value, aggregate them + h.valueCount += o.valueCount + } else { + // Two different values necessitate buckets in this histogram + h.allocateBuckets() + if o.valueCount >= 0 { + h.buckets[o.value] += o.valueCount + } else { + for i := range h.buckets { + h.buckets[i] += o.buckets[i] + } + } + } + h.sumOfSquares += o.sumOfSquares + h.sum += o.sum +} + +// Clear resets the histogram to an empty state, removing all observed values. +func (h *histogram) Clear() { + h.buckets = nil + h.value = 0 + h.valueCount = 0 + h.sum = 0 + h.sumOfSquares = 0 +} + +// CopyFrom copies from other, which must be a *histogram, into h. +func (h *histogram) CopyFrom(other timeseries.Observable) { + o := other.(*histogram) + if o.valueCount == -1 { + h.allocateBuckets() + copy(h.buckets, o.buckets) + } + h.sum = o.sum + h.sumOfSquares = o.sumOfSquares + h.value = o.value + h.valueCount = o.valueCount +} + +// Multiply scales the histogram by the specified ratio. +func (h *histogram) Multiply(ratio float64) { + if h.valueCount == -1 { + for i := range h.buckets { + h.buckets[i] = int64(float64(h.buckets[i]) * ratio) + } + } else { + h.valueCount = int64(float64(h.valueCount) * ratio) + } + h.sum = int64(float64(h.sum) * ratio) + h.sumOfSquares = h.sumOfSquares * ratio +} + +// New creates a new histogram. +func (h *histogram) New() timeseries.Observable { + r := new(histogram) + r.Clear() + return r +} + +func (h *histogram) String() string { + return fmt.Sprintf("%d, %f, %d, %d, %v", + h.sum, h.sumOfSquares, h.value, h.valueCount, h.buckets) +} + +// round returns the closest int64 to the argument +func round(in float64) int64 { + return int64(math.Floor(in + 0.5)) +} + +// bucketBoundary returns the first value in the bucket. +func bucketBoundary(bucket uint8) int64 { + if bucket == 0 { + return 0 + } + return 1 << bucket +} + +// bucketData holds data about a specific bucket for use in distTmpl. +type bucketData struct { + Lower, Upper int64 + N int64 + Pct, CumulativePct float64 + GraphWidth int +} + +// data holds data about a Distribution for use in distTmpl. +type data struct { + Buckets []*bucketData + Count, Median int64 + Mean, StandardDeviation float64 +} + +// maxHTMLBarWidth is the maximum width of the HTML bar for visualizing buckets. +const maxHTMLBarWidth = 350.0 + +// newData returns data representing h for use in distTmpl. +func (h *histogram) newData() *data { + // Force the allocation of buckets to simplify the rendering implementation + h.allocateBuckets() + // We scale the bars on the right so that the largest bar is + // maxHTMLBarWidth pixels in width. + maxBucket := int64(0) + for _, n := range h.buckets { + if n > maxBucket { + maxBucket = n + } + } + total := h.total() + barsizeMult := maxHTMLBarWidth / float64(maxBucket) + var pctMult float64 + if total == 0 { + pctMult = 1.0 + } else { + pctMult = 100.0 / float64(total) + } + + buckets := make([]*bucketData, len(h.buckets)) + runningTotal := int64(0) + for i, n := range h.buckets { + if n == 0 { + continue + } + runningTotal += n + var upperBound int64 + if i < bucketCount-1 { + upperBound = bucketBoundary(uint8(i + 1)) + } else { + upperBound = math.MaxInt64 + } + buckets[i] = &bucketData{ + Lower: bucketBoundary(uint8(i)), + Upper: upperBound, + N: n, + Pct: float64(n) * pctMult, + CumulativePct: float64(runningTotal) * pctMult, + GraphWidth: int(float64(n) * barsizeMult), + } + } + return &data{ + Buckets: buckets, + Count: total, + Median: h.median(), + Mean: h.average(), + StandardDeviation: h.standardDeviation(), + } +} + +func (h *histogram) html() template.HTML { + buf := new(bytes.Buffer) + if err := distTmpl().Execute(buf, h.newData()); err != nil { + buf.Reset() + log.Printf("net/trace: couldn't execute template: %v", err) + } + return template.HTML(buf.String()) +} + +var distTmplCache *template.Template +var distTmplOnce sync.Once + +func distTmpl() *template.Template { + distTmplOnce.Do(func() { + // Input: data + distTmplCache = template.Must(template.New("distTmpl").Parse(` + + + + + + + +
Count: {{.Count}}Mean: {{printf "%.0f" .Mean}}StdDev: {{printf "%.0f" .StandardDeviation}}Median: {{.Median}}
+
+ +{{range $b := .Buckets}} +{{if $b}} + + + + + + + + + +{{end}} +{{end}} +
[{{.Lower}},{{.Upper}}){{.N}}{{printf "%#.3f" .Pct}}%{{printf "%#.3f" .CumulativePct}}%
+`)) + }) + return distTmplCache +} diff --git a/vendor/golang.org/x/net/trace/trace.go b/vendor/golang.org/x/net/trace/trace.go new file mode 100644 index 00000000000..a46ee0eaa31 --- /dev/null +++ b/vendor/golang.org/x/net/trace/trace.go @@ -0,0 +1,1103 @@ +// 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 trace implements tracing of requests and long-lived objects. +It exports HTTP interfaces on /debug/requests and /debug/events. + +A trace.Trace provides tracing for short-lived objects, usually requests. +A request handler might be implemented like this: + + func fooHandler(w http.ResponseWriter, req *http.Request) { + tr := trace.New("mypkg.Foo", req.URL.Path) + defer tr.Finish() + ... + tr.LazyPrintf("some event %q happened", str) + ... + if err := somethingImportant(); err != nil { + tr.LazyPrintf("somethingImportant failed: %v", err) + tr.SetError() + } + } + +The /debug/requests HTTP endpoint organizes the traces by family, +errors, and duration. It also provides histogram of request duration +for each family. + +A trace.EventLog provides tracing for long-lived objects, such as RPC +connections. + + // A Fetcher fetches URL paths for a single domain. + type Fetcher struct { + domain string + events trace.EventLog + } + + func NewFetcher(domain string) *Fetcher { + return &Fetcher{ + domain, + trace.NewEventLog("mypkg.Fetcher", domain), + } + } + + func (f *Fetcher) Fetch(path string) (string, error) { + resp, err := http.Get("http://" + f.domain + "/" + path) + if err != nil { + f.events.Errorf("Get(%q) = %v", path, err) + return "", err + } + f.events.Printf("Get(%q) = %s", path, resp.Status) + ... + } + + func (f *Fetcher) Close() error { + f.events.Finish() + return nil + } + +The /debug/events HTTP endpoint organizes the event logs by family and +by time since the last error. The expanded view displays recent log +entries and the log's call stack. +*/ +package trace // import "golang.org/x/net/trace" + +import ( + "bytes" + "fmt" + "html/template" + "io" + "log" + "net" + "net/http" + "runtime" + "sort" + "strconv" + "sync" + "sync/atomic" + "time" + + "golang.org/x/net/internal/timeseries" +) + +// DebugUseAfterFinish controls whether to debug uses of Trace values after finishing. +// FOR DEBUGGING ONLY. This will slow down the program. +var DebugUseAfterFinish = false + +// AuthRequest determines whether a specific request is permitted to load the +// /debug/requests or /debug/events pages. +// +// It returns two bools; the first indicates whether the page may be viewed at all, +// and the second indicates whether sensitive events will be shown. +// +// AuthRequest may be replaced by a program to customize its authorization requirements. +// +// The default AuthRequest function returns (true, true) if and only if the request +// comes from localhost/127.0.0.1/[::1]. +var AuthRequest = func(req *http.Request) (any, sensitive bool) { + // RemoteAddr is commonly in the form "IP" or "IP:port". + // If it is in the form "IP:port", split off the port. + host, _, err := net.SplitHostPort(req.RemoteAddr) + if err != nil { + host = req.RemoteAddr + } + switch host { + case "localhost", "127.0.0.1", "::1": + return true, true + default: + return false, false + } +} + +func init() { + // TODO(jbd): Serve Traces from /debug/traces in the future? + // There is no requirement for a request to be present to have traces. + http.HandleFunc("/debug/requests", Traces) + http.HandleFunc("/debug/events", Events) +} + +// Traces responds with traces from the program. +// The package initialization registers it in http.DefaultServeMux +// at /debug/requests. +// +// It performs authorization by running AuthRequest. +func Traces(w http.ResponseWriter, req *http.Request) { + any, sensitive := AuthRequest(req) + if !any { + http.Error(w, "not allowed", http.StatusUnauthorized) + return + } + w.Header().Set("Content-Type", "text/html; charset=utf-8") + Render(w, req, sensitive) +} + +// Events responds with a page of events collected by EventLogs. +// The package initialization registers it in http.DefaultServeMux +// at /debug/events. +// +// It performs authorization by running AuthRequest. +func Events(w http.ResponseWriter, req *http.Request) { + any, sensitive := AuthRequest(req) + if !any { + http.Error(w, "not allowed", http.StatusUnauthorized) + return + } + w.Header().Set("Content-Type", "text/html; charset=utf-8") + RenderEvents(w, req, sensitive) +} + +// Render renders the HTML page typically served at /debug/requests. +// It does not do any auth checking. The request may be nil. +// +// Most users will use the Traces handler. +func Render(w io.Writer, req *http.Request, sensitive bool) { + data := &struct { + Families []string + ActiveTraceCount map[string]int + CompletedTraces map[string]*family + + // Set when a bucket has been selected. + Traces traceList + Family string + Bucket int + Expanded bool + Traced bool + Active bool + ShowSensitive bool // whether to show sensitive events + + Histogram template.HTML + HistogramWindow string // e.g. "last minute", "last hour", "all time" + + // If non-zero, the set of traces is a partial set, + // and this is the total number. + Total int + }{ + CompletedTraces: completedTraces, + } + + data.ShowSensitive = sensitive + if req != nil { + // Allow show_sensitive=0 to force hiding of sensitive data for testing. + // This only goes one way; you can't use show_sensitive=1 to see things. + if req.FormValue("show_sensitive") == "0" { + data.ShowSensitive = false + } + + if exp, err := strconv.ParseBool(req.FormValue("exp")); err == nil { + data.Expanded = exp + } + if exp, err := strconv.ParseBool(req.FormValue("rtraced")); err == nil { + data.Traced = exp + } + } + + completedMu.RLock() + data.Families = make([]string, 0, len(completedTraces)) + for fam := range completedTraces { + data.Families = append(data.Families, fam) + } + completedMu.RUnlock() + sort.Strings(data.Families) + + // We are careful here to minimize the time spent locking activeMu, + // since that lock is required every time an RPC starts and finishes. + data.ActiveTraceCount = make(map[string]int, len(data.Families)) + activeMu.RLock() + for fam, s := range activeTraces { + data.ActiveTraceCount[fam] = s.Len() + } + activeMu.RUnlock() + + var ok bool + data.Family, data.Bucket, ok = parseArgs(req) + switch { + case !ok: + // No-op + case data.Bucket == -1: + data.Active = true + n := data.ActiveTraceCount[data.Family] + data.Traces = getActiveTraces(data.Family) + if len(data.Traces) < n { + data.Total = n + } + case data.Bucket < bucketsPerFamily: + if b := lookupBucket(data.Family, data.Bucket); b != nil { + data.Traces = b.Copy(data.Traced) + } + default: + if f := getFamily(data.Family, false); f != nil { + var obs timeseries.Observable + f.LatencyMu.RLock() + switch o := data.Bucket - bucketsPerFamily; o { + case 0: + obs = f.Latency.Minute() + data.HistogramWindow = "last minute" + case 1: + obs = f.Latency.Hour() + data.HistogramWindow = "last hour" + case 2: + obs = f.Latency.Total() + data.HistogramWindow = "all time" + } + f.LatencyMu.RUnlock() + if obs != nil { + data.Histogram = obs.(*histogram).html() + } + } + } + + if data.Traces != nil { + defer data.Traces.Free() + sort.Sort(data.Traces) + } + + completedMu.RLock() + defer completedMu.RUnlock() + if err := pageTmpl().ExecuteTemplate(w, "Page", data); err != nil { + log.Printf("net/trace: Failed executing template: %v", err) + } +} + +func parseArgs(req *http.Request) (fam string, b int, ok bool) { + if req == nil { + return "", 0, false + } + fam, bStr := req.FormValue("fam"), req.FormValue("b") + if fam == "" || bStr == "" { + return "", 0, false + } + b, err := strconv.Atoi(bStr) + if err != nil || b < -1 { + return "", 0, false + } + + return fam, b, true +} + +func lookupBucket(fam string, b int) *traceBucket { + f := getFamily(fam, false) + if f == nil || b < 0 || b >= len(f.Buckets) { + return nil + } + return f.Buckets[b] +} + +type contextKeyT string + +var contextKey = contextKeyT("golang.org/x/net/trace.Trace") + +// Trace represents an active request. +type Trace interface { + // LazyLog adds x to the event log. It will be evaluated each time the + // /debug/requests page is rendered. Any memory referenced by x will be + // pinned until the trace is finished and later discarded. + LazyLog(x fmt.Stringer, sensitive bool) + + // LazyPrintf evaluates its arguments with fmt.Sprintf each time the + // /debug/requests page is rendered. Any memory referenced by a will be + // pinned until the trace is finished and later discarded. + LazyPrintf(format string, a ...interface{}) + + // SetError declares that this trace resulted in an error. + SetError() + + // SetRecycler sets a recycler for the trace. + // f will be called for each event passed to LazyLog at a time when + // it is no longer required, whether while the trace is still active + // and the event is discarded, or when a completed trace is discarded. + SetRecycler(f func(interface{})) + + // SetTraceInfo sets the trace info for the trace. + // This is currently unused. + SetTraceInfo(traceID, spanID uint64) + + // SetMaxEvents sets the maximum number of events that will be stored + // in the trace. This has no effect if any events have already been + // added to the trace. + SetMaxEvents(m int) + + // Finish declares that this trace is complete. + // The trace should not be used after calling this method. + Finish() +} + +type lazySprintf struct { + format string + a []interface{} +} + +func (l *lazySprintf) String() string { + return fmt.Sprintf(l.format, l.a...) +} + +// New returns a new Trace with the specified family and title. +func New(family, title string) Trace { + tr := newTrace() + tr.ref() + tr.Family, tr.Title = family, title + tr.Start = time.Now() + tr.maxEvents = maxEventsPerTrace + tr.events = tr.eventsBuf[:0] + + activeMu.RLock() + s := activeTraces[tr.Family] + activeMu.RUnlock() + if s == nil { + activeMu.Lock() + s = activeTraces[tr.Family] // check again + if s == nil { + s = new(traceSet) + activeTraces[tr.Family] = s + } + activeMu.Unlock() + } + s.Add(tr) + + // Trigger allocation of the completed trace structure for this family. + // This will cause the family to be present in the request page during + // the first trace of this family. We don't care about the return value, + // nor is there any need for this to run inline, so we execute it in its + // own goroutine, but only if the family isn't allocated yet. + completedMu.RLock() + if _, ok := completedTraces[tr.Family]; !ok { + go allocFamily(tr.Family) + } + completedMu.RUnlock() + + return tr +} + +func (tr *trace) Finish() { + elapsed := time.Now().Sub(tr.Start) + tr.mu.Lock() + tr.Elapsed = elapsed + tr.mu.Unlock() + + if DebugUseAfterFinish { + buf := make([]byte, 4<<10) // 4 KB should be enough + n := runtime.Stack(buf, false) + tr.finishStack = buf[:n] + } + + activeMu.RLock() + m := activeTraces[tr.Family] + activeMu.RUnlock() + m.Remove(tr) + + f := getFamily(tr.Family, true) + tr.mu.RLock() // protects tr fields in Cond.match calls + for _, b := range f.Buckets { + if b.Cond.match(tr) { + b.Add(tr) + } + } + tr.mu.RUnlock() + + // Add a sample of elapsed time as microseconds to the family's timeseries + h := new(histogram) + h.addMeasurement(elapsed.Nanoseconds() / 1e3) + f.LatencyMu.Lock() + f.Latency.Add(h) + f.LatencyMu.Unlock() + + tr.unref() // matches ref in New +} + +const ( + bucketsPerFamily = 9 + tracesPerBucket = 10 + maxActiveTraces = 20 // Maximum number of active traces to show. + maxEventsPerTrace = 10 + numHistogramBuckets = 38 +) + +var ( + // The active traces. + activeMu sync.RWMutex + activeTraces = make(map[string]*traceSet) // family -> traces + + // Families of completed traces. + completedMu sync.RWMutex + completedTraces = make(map[string]*family) // family -> traces +) + +type traceSet struct { + mu sync.RWMutex + m map[*trace]bool + + // We could avoid the entire map scan in FirstN by having a slice of all the traces + // ordered by start time, and an index into that from the trace struct, with a periodic + // repack of the slice after enough traces finish; we could also use a skip list or similar. + // However, that would shift some of the expense from /debug/requests time to RPC time, + // which is probably the wrong trade-off. +} + +func (ts *traceSet) Len() int { + ts.mu.RLock() + defer ts.mu.RUnlock() + return len(ts.m) +} + +func (ts *traceSet) Add(tr *trace) { + ts.mu.Lock() + if ts.m == nil { + ts.m = make(map[*trace]bool) + } + ts.m[tr] = true + ts.mu.Unlock() +} + +func (ts *traceSet) Remove(tr *trace) { + ts.mu.Lock() + delete(ts.m, tr) + ts.mu.Unlock() +} + +// FirstN returns the first n traces ordered by time. +func (ts *traceSet) FirstN(n int) traceList { + ts.mu.RLock() + defer ts.mu.RUnlock() + + if n > len(ts.m) { + n = len(ts.m) + } + trl := make(traceList, 0, n) + + // Fast path for when no selectivity is needed. + if n == len(ts.m) { + for tr := range ts.m { + tr.ref() + trl = append(trl, tr) + } + sort.Sort(trl) + return trl + } + + // Pick the oldest n traces. + // This is inefficient. See the comment in the traceSet struct. + for tr := range ts.m { + // Put the first n traces into trl in the order they occur. + // When we have n, sort trl, and thereafter maintain its order. + if len(trl) < n { + tr.ref() + trl = append(trl, tr) + if len(trl) == n { + // This is guaranteed to happen exactly once during this loop. + sort.Sort(trl) + } + continue + } + if tr.Start.After(trl[n-1].Start) { + continue + } + + // Find where to insert this one. + tr.ref() + i := sort.Search(n, func(i int) bool { return trl[i].Start.After(tr.Start) }) + trl[n-1].unref() + copy(trl[i+1:], trl[i:]) + trl[i] = tr + } + + return trl +} + +func getActiveTraces(fam string) traceList { + activeMu.RLock() + s := activeTraces[fam] + activeMu.RUnlock() + if s == nil { + return nil + } + return s.FirstN(maxActiveTraces) +} + +func getFamily(fam string, allocNew bool) *family { + completedMu.RLock() + f := completedTraces[fam] + completedMu.RUnlock() + if f == nil && allocNew { + f = allocFamily(fam) + } + return f +} + +func allocFamily(fam string) *family { + completedMu.Lock() + defer completedMu.Unlock() + f := completedTraces[fam] + if f == nil { + f = newFamily() + completedTraces[fam] = f + } + return f +} + +// family represents a set of trace buckets and associated latency information. +type family struct { + // traces may occur in multiple buckets. + Buckets [bucketsPerFamily]*traceBucket + + // latency time series + LatencyMu sync.RWMutex + Latency *timeseries.MinuteHourSeries +} + +func newFamily() *family { + return &family{ + Buckets: [bucketsPerFamily]*traceBucket{ + {Cond: minCond(0)}, + {Cond: minCond(50 * time.Millisecond)}, + {Cond: minCond(100 * time.Millisecond)}, + {Cond: minCond(200 * time.Millisecond)}, + {Cond: minCond(500 * time.Millisecond)}, + {Cond: minCond(1 * time.Second)}, + {Cond: minCond(10 * time.Second)}, + {Cond: minCond(100 * time.Second)}, + {Cond: errorCond{}}, + }, + Latency: timeseries.NewMinuteHourSeries(func() timeseries.Observable { return new(histogram) }), + } +} + +// traceBucket represents a size-capped bucket of historic traces, +// along with a condition for a trace to belong to the bucket. +type traceBucket struct { + Cond cond + + // Ring buffer implementation of a fixed-size FIFO queue. + mu sync.RWMutex + buf [tracesPerBucket]*trace + start int // < tracesPerBucket + length int // <= tracesPerBucket +} + +func (b *traceBucket) Add(tr *trace) { + b.mu.Lock() + defer b.mu.Unlock() + + i := b.start + b.length + if i >= tracesPerBucket { + i -= tracesPerBucket + } + if b.length == tracesPerBucket { + // "Remove" an element from the bucket. + b.buf[i].unref() + b.start++ + if b.start == tracesPerBucket { + b.start = 0 + } + } + b.buf[i] = tr + if b.length < tracesPerBucket { + b.length++ + } + tr.ref() +} + +// Copy returns a copy of the traces in the bucket. +// If tracedOnly is true, only the traces with trace information will be returned. +// The logs will be ref'd before returning; the caller should call +// the Free method when it is done with them. +// TODO(dsymonds): keep track of traced requests in separate buckets. +func (b *traceBucket) Copy(tracedOnly bool) traceList { + b.mu.RLock() + defer b.mu.RUnlock() + + trl := make(traceList, 0, b.length) + for i, x := 0, b.start; i < b.length; i++ { + tr := b.buf[x] + if !tracedOnly || tr.spanID != 0 { + tr.ref() + trl = append(trl, tr) + } + x++ + if x == b.length { + x = 0 + } + } + return trl +} + +func (b *traceBucket) Empty() bool { + b.mu.RLock() + defer b.mu.RUnlock() + return b.length == 0 +} + +// cond represents a condition on a trace. +type cond interface { + match(t *trace) bool + String() string +} + +type minCond time.Duration + +func (m minCond) match(t *trace) bool { return t.Elapsed >= time.Duration(m) } +func (m minCond) String() string { return fmt.Sprintf("≥%gs", time.Duration(m).Seconds()) } + +type errorCond struct{} + +func (e errorCond) match(t *trace) bool { return t.IsError } +func (e errorCond) String() string { return "errors" } + +type traceList []*trace + +// Free calls unref on each element of the list. +func (trl traceList) Free() { + for _, t := range trl { + t.unref() + } +} + +// traceList may be sorted in reverse chronological order. +func (trl traceList) Len() int { return len(trl) } +func (trl traceList) Less(i, j int) bool { return trl[i].Start.After(trl[j].Start) } +func (trl traceList) Swap(i, j int) { trl[i], trl[j] = trl[j], trl[i] } + +// An event is a timestamped log entry in a trace. +type event struct { + When time.Time + Elapsed time.Duration // since previous event in trace + NewDay bool // whether this event is on a different day to the previous event + Recyclable bool // whether this event was passed via LazyLog + Sensitive bool // whether this event contains sensitive information + What interface{} // string or fmt.Stringer +} + +// WhenString returns a string representation of the elapsed time of the event. +// It will include the date if midnight was crossed. +func (e event) WhenString() string { + if e.NewDay { + return e.When.Format("2006/01/02 15:04:05.000000") + } + return e.When.Format("15:04:05.000000") +} + +// discarded represents a number of discarded events. +// It is stored as *discarded to make it easier to update in-place. +type discarded int + +func (d *discarded) String() string { + return fmt.Sprintf("(%d events discarded)", int(*d)) +} + +// trace represents an active or complete request, +// either sent or received by this program. +type trace struct { + // Family is the top-level grouping of traces to which this belongs. + Family string + + // Title is the title of this trace. + Title string + + // Start time of the this trace. + Start time.Time + + mu sync.RWMutex + events []event // Append-only sequence of events (modulo discards). + maxEvents int + recycler func(interface{}) + IsError bool // Whether this trace resulted in an error. + Elapsed time.Duration // Elapsed time for this trace, zero while active. + traceID uint64 // Trace information if non-zero. + spanID uint64 + + refs int32 // how many buckets this is in + disc discarded // scratch space to avoid allocation + + finishStack []byte // where finish was called, if DebugUseAfterFinish is set + + eventsBuf [4]event // preallocated buffer in case we only log a few events +} + +func (tr *trace) reset() { + // Clear all but the mutex. Mutexes may not be copied, even when unlocked. + tr.Family = "" + tr.Title = "" + tr.Start = time.Time{} + + tr.mu.Lock() + tr.Elapsed = 0 + tr.traceID = 0 + tr.spanID = 0 + tr.IsError = false + tr.maxEvents = 0 + tr.events = nil + tr.recycler = nil + tr.mu.Unlock() + + tr.refs = 0 + tr.disc = 0 + tr.finishStack = nil + for i := range tr.eventsBuf { + tr.eventsBuf[i] = event{} + } +} + +// delta returns the elapsed time since the last event or the trace start, +// and whether it spans midnight. +// L >= tr.mu +func (tr *trace) delta(t time.Time) (time.Duration, bool) { + if len(tr.events) == 0 { + return t.Sub(tr.Start), false + } + prev := tr.events[len(tr.events)-1].When + return t.Sub(prev), prev.Day() != t.Day() +} + +func (tr *trace) addEvent(x interface{}, recyclable, sensitive bool) { + if DebugUseAfterFinish && tr.finishStack != nil { + buf := make([]byte, 4<<10) // 4 KB should be enough + n := runtime.Stack(buf, false) + log.Printf("net/trace: trace used after finish:\nFinished at:\n%s\nUsed at:\n%s", tr.finishStack, buf[:n]) + } + + /* + NOTE TO DEBUGGERS + + If you are here because your program panicked in this code, + it is almost definitely the fault of code using this package, + and very unlikely to be the fault of this code. + + The most likely scenario is that some code elsewhere is using + a trace.Trace after its Finish method is called. + You can temporarily set the DebugUseAfterFinish var + to help discover where that is; do not leave that var set, + since it makes this package much less efficient. + */ + + e := event{When: time.Now(), What: x, Recyclable: recyclable, Sensitive: sensitive} + tr.mu.Lock() + e.Elapsed, e.NewDay = tr.delta(e.When) + if len(tr.events) < tr.maxEvents { + tr.events = append(tr.events, e) + } else { + // Discard the middle events. + di := int((tr.maxEvents - 1) / 2) + if d, ok := tr.events[di].What.(*discarded); ok { + (*d)++ + } else { + // disc starts at two to count for the event it is replacing, + // plus the next one that we are about to drop. + tr.disc = 2 + if tr.recycler != nil && tr.events[di].Recyclable { + go tr.recycler(tr.events[di].What) + } + tr.events[di].What = &tr.disc + } + // The timestamp of the discarded meta-event should be + // the time of the last event it is representing. + tr.events[di].When = tr.events[di+1].When + + if tr.recycler != nil && tr.events[di+1].Recyclable { + go tr.recycler(tr.events[di+1].What) + } + copy(tr.events[di+1:], tr.events[di+2:]) + tr.events[tr.maxEvents-1] = e + } + tr.mu.Unlock() +} + +func (tr *trace) LazyLog(x fmt.Stringer, sensitive bool) { + tr.addEvent(x, true, sensitive) +} + +func (tr *trace) LazyPrintf(format string, a ...interface{}) { + tr.addEvent(&lazySprintf{format, a}, false, false) +} + +func (tr *trace) SetError() { + tr.mu.Lock() + tr.IsError = true + tr.mu.Unlock() +} + +func (tr *trace) SetRecycler(f func(interface{})) { + tr.mu.Lock() + tr.recycler = f + tr.mu.Unlock() +} + +func (tr *trace) SetTraceInfo(traceID, spanID uint64) { + tr.mu.Lock() + tr.traceID, tr.spanID = traceID, spanID + tr.mu.Unlock() +} + +func (tr *trace) SetMaxEvents(m int) { + tr.mu.Lock() + // Always keep at least three events: first, discarded count, last. + if len(tr.events) == 0 && m > 3 { + tr.maxEvents = m + } + tr.mu.Unlock() +} + +func (tr *trace) ref() { + atomic.AddInt32(&tr.refs, 1) +} + +func (tr *trace) unref() { + if atomic.AddInt32(&tr.refs, -1) == 0 { + tr.mu.RLock() + if tr.recycler != nil { + // freeTrace clears tr, so we hold tr.recycler and tr.events here. + go func(f func(interface{}), es []event) { + for _, e := range es { + if e.Recyclable { + f(e.What) + } + } + }(tr.recycler, tr.events) + } + tr.mu.RUnlock() + + freeTrace(tr) + } +} + +func (tr *trace) When() string { + return tr.Start.Format("2006/01/02 15:04:05.000000") +} + +func (tr *trace) ElapsedTime() string { + tr.mu.RLock() + t := tr.Elapsed + tr.mu.RUnlock() + + if t == 0 { + // Active trace. + t = time.Since(tr.Start) + } + return fmt.Sprintf("%.6f", t.Seconds()) +} + +func (tr *trace) Events() []event { + tr.mu.RLock() + defer tr.mu.RUnlock() + return tr.events +} + +var traceFreeList = make(chan *trace, 1000) // TODO(dsymonds): Use sync.Pool? + +// newTrace returns a trace ready to use. +func newTrace() *trace { + select { + case tr := <-traceFreeList: + return tr + default: + return new(trace) + } +} + +// freeTrace adds tr to traceFreeList if there's room. +// This is non-blocking. +func freeTrace(tr *trace) { + if DebugUseAfterFinish { + return // never reuse + } + tr.reset() + select { + case traceFreeList <- tr: + default: + } +} + +func elapsed(d time.Duration) string { + b := []byte(fmt.Sprintf("%.6f", d.Seconds())) + + // For subsecond durations, blank all zeros before decimal point, + // and all zeros between the decimal point and the first non-zero digit. + if d < time.Second { + dot := bytes.IndexByte(b, '.') + for i := 0; i < dot; i++ { + b[i] = ' ' + } + for i := dot + 1; i < len(b); i++ { + if b[i] == '0' { + b[i] = ' ' + } else { + break + } + } + } + + return string(b) +} + +var pageTmplCache *template.Template +var pageTmplOnce sync.Once + +func pageTmpl() *template.Template { + pageTmplOnce.Do(func() { + pageTmplCache = template.Must(template.New("Page").Funcs(template.FuncMap{ + "elapsed": elapsed, + "add": func(a, b int) int { return a + b }, + }).Parse(pageHTML)) + }) + return pageTmplCache +} + +const pageHTML = ` +{{template "Prolog" .}} +{{template "StatusTable" .}} +{{template "Epilog" .}} + +{{define "Prolog"}} + + + /debug/requests + + + + +

/debug/requests

+{{end}} {{/* end of Prolog */}} + +{{define "StatusTable"}} + + {{range $fam := .Families}} + + + + {{$n := index $.ActiveTraceCount $fam}} + + + {{$f := index $.CompletedTraces $fam}} + {{range $i, $b := $f.Buckets}} + {{$empty := $b.Empty}} + + {{end}} + + {{$nb := len $f.Buckets}} + + + + + + {{end}} +
{{$fam}} + {{if $n}}{{end}} + [{{$n}} active] + {{if $n}}{{end}} + + {{if not $empty}}{{end}} + [{{.Cond}}] + {{if not $empty}}{{end}} + + [minute] + + [hour] + + [total] +
+{{end}} {{/* end of StatusTable */}} + +{{define "Epilog"}} +{{if $.Traces}} +
+

Family: {{$.Family}}

+ +{{if or $.Expanded $.Traced}} + [Normal/Summary] +{{else}} + [Normal/Summary] +{{end}} + +{{if or (not $.Expanded) $.Traced}} + [Normal/Expanded] +{{else}} + [Normal/Expanded] +{{end}} + +{{if not $.Active}} + {{if or $.Expanded (not $.Traced)}} + [Traced/Summary] + {{else}} + [Traced/Summary] + {{end}} + {{if or (not $.Expanded) (not $.Traced)}} + [Traced/Expanded] + {{else}} + [Traced/Expanded] + {{end}} +{{end}} + +{{if $.Total}} +

Showing {{len $.Traces}} of {{$.Total}} traces.

+{{end}} + + + + + {{range $tr := $.Traces}} + + + + + {{/* TODO: include traceID/spanID */}} + + {{if $.Expanded}} + {{range $tr.Events}} + + + + + + {{end}} + {{end}} + {{end}} +
+ {{if $.Active}}Active{{else}}Completed{{end}} Requests +
WhenElapsed (s)
{{$tr.When}}{{$tr.ElapsedTime}}{{$tr.Title}}
{{.WhenString}}{{elapsed .Elapsed}}{{if or $.ShowSensitive (not .Sensitive)}}... {{.What}}{{else}}[redacted]{{end}}
+{{end}} {{/* if $.Traces */}} + +{{if $.Histogram}} +

Latency (µs) of {{$.Family}} over {{$.HistogramWindow}}

+{{$.Histogram}} +{{end}} {{/* if $.Histogram */}} + + + +{{end}} {{/* end of Epilog */}} +` diff --git a/vendor/golang.org/x/net/trace/trace_go16.go b/vendor/golang.org/x/net/trace/trace_go16.go new file mode 100644 index 00000000000..d6081911853 --- /dev/null +++ b/vendor/golang.org/x/net/trace/trace_go16.go @@ -0,0 +1,21 @@ +// Copyright 2017 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 trace + +import "golang.org/x/net/context" + +// NewContext returns a copy of the parent context +// and associates it with a Trace. +func NewContext(ctx context.Context, tr Trace) context.Context { + return context.WithValue(ctx, contextKey, tr) +} + +// FromContext returns the Trace bound to the context, if any. +func FromContext(ctx context.Context) (tr Trace, ok bool) { + tr, ok = ctx.Value(contextKey).(Trace) + return +} diff --git a/vendor/golang.org/x/net/trace/trace_go17.go b/vendor/golang.org/x/net/trace/trace_go17.go new file mode 100644 index 00000000000..df6e1fba7ca --- /dev/null +++ b/vendor/golang.org/x/net/trace/trace_go17.go @@ -0,0 +1,21 @@ +// Copyright 2017 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 trace + +import "context" + +// NewContext returns a copy of the parent context +// and associates it with a Trace. +func NewContext(ctx context.Context, tr Trace) context.Context { + return context.WithValue(ctx, contextKey, tr) +} + +// FromContext returns the Trace bound to the context, if any. +func FromContext(ctx context.Context) (tr Trace, ok bool) { + tr, ok = ctx.Value(contextKey).(Trace) + return +} diff --git a/vendor/golang.org/x/oauth2/CONTRIBUTING.md b/vendor/golang.org/x/oauth2/CONTRIBUTING.md index 46aa2b12dda..dfbed62cf54 100644 --- a/vendor/golang.org/x/oauth2/CONTRIBUTING.md +++ b/vendor/golang.org/x/oauth2/CONTRIBUTING.md @@ -4,16 +4,15 @@ 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? +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. @@ -23,9 +22,5 @@ The gophers there will answer or ask you to file an issue if you've tripped over 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/golang.org/x/oauth2/google/default.go b/vendor/golang.org/x/oauth2/google/default.go index b4b62745c45..a31607437d3 100644 --- a/vendor/golang.org/x/oauth2/google/default.go +++ b/vendor/golang.org/x/oauth2/google/default.go @@ -18,20 +18,6 @@ import ( "golang.org/x/oauth2" ) -// DefaultCredentials holds "Application Default Credentials". -// For more details, see: -// https://developers.google.com/accounts/docs/application-default-credentials -type DefaultCredentials struct { - ProjectID string // may be empty - TokenSource oauth2.TokenSource - - // JSON contains the raw bytes from a JSON credentials file. - // This field may be nil if authentication is provided by the - // environment and not with a credentials file, e.g. when code is - // running on Google Cloud Platform. - JSON []byte -} - // DefaultClient returns an HTTP Client that uses the // DefaultTokenSource to obtain authentication credentials. func DefaultClient(ctx context.Context, scope ...string) (*http.Client, error) { @@ -53,25 +39,12 @@ func DefaultTokenSource(ctx context.Context, scope ...string) (oauth2.TokenSourc return creds.TokenSource, nil } -// FindDefaultCredentials searches for "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.) -func FindDefaultCredentials(ctx context.Context, scope ...string) (*DefaultCredentials, error) { +// Common implementation for FindDefaultCredentials. +func findDefaultCredentials(ctx context.Context, scopes []string) (*DefaultCredentials, error) { // First, try the environment variable. const envVar = "GOOGLE_APPLICATION_CREDENTIALS" if filename := os.Getenv(envVar); filename != "" { - creds, err := readCredentialsFile(ctx, filename, scope) + creds, err := readCredentialsFile(ctx, filename, scopes) if err != nil { return nil, fmt.Errorf("google: error getting credentials using %v environment variable: %v", envVar, err) } @@ -80,7 +53,7 @@ func FindDefaultCredentials(ctx context.Context, scope ...string) (*DefaultCrede // Second, try a well-known file. filename := wellKnownFile() - if creds, err := readCredentialsFile(ctx, filename, scope); err == nil { + if creds, err := readCredentialsFile(ctx, filename, scopes); err == nil { return creds, nil } else if !os.IsNotExist(err) { return nil, fmt.Errorf("google: error getting credentials using well-known file (%v): %v", filename, err) @@ -90,7 +63,7 @@ func FindDefaultCredentials(ctx context.Context, scope ...string) (*DefaultCrede if appengineTokenFunc != nil && !appengineFlex { return &DefaultCredentials{ ProjectID: appengineAppIDFunc(ctx), - TokenSource: AppEngineTokenSource(ctx, scope...), + TokenSource: AppEngineTokenSource(ctx, scopes...), }, nil } @@ -108,6 +81,23 @@ func FindDefaultCredentials(ctx context.Context, scope ...string) (*DefaultCrede return nil, fmt.Errorf("google: could not find default credentials. See %v for more information.", url) } +// Common implementation for CredentialsFromJSON. +func credentialsFromJSON(ctx context.Context, jsonData []byte, scopes []string) (*DefaultCredentials, error) { + var f credentialsFile + if err := json.Unmarshal(jsonData, &f); err != nil { + return nil, err + } + ts, err := f.tokenSource(ctx, append([]string(nil), scopes...)) + if err != nil { + return nil, err + } + return &DefaultCredentials{ + ProjectID: f.ProjectID, + TokenSource: ts, + JSON: jsonData, + }, nil +} + func wellKnownFile() string { const f = "application_default_credentials.json" if runtime.GOOS == "windows" { @@ -121,17 +111,5 @@ func readCredentialsFile(ctx context.Context, filename string, scopes []string) if err != nil { return nil, err } - var f credentialsFile - if err := json.Unmarshal(b, &f); err != nil { - return nil, err - } - ts, err := f.tokenSource(ctx, append([]string(nil), scopes...)) - if err != nil { - return nil, err - } - return &DefaultCredentials{ - ProjectID: f.ProjectID, - TokenSource: ts, - JSON: b, - }, nil + return CredentialsFromJSON(ctx, b, scopes...) } diff --git a/vendor/golang.org/x/oauth2/google/doc_go19.go b/vendor/golang.org/x/oauth2/google/doc_go19.go new file mode 100644 index 00000000000..2a86325fe3b --- /dev/null +++ b/vendor/golang.org/x/oauth2/google/doc_go19.go @@ -0,0 +1,42 @@ +// Copyright 2018 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.9 + +// 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. +// +// A brief overview of the package follows. For more information, please read +// https://developers.google.com/accounts/docs/OAuth2 +// and +// https://developers.google.com/accounts/docs/application-default-credentials. +// +// OAuth2 Configs +// +// Two functions in this package return golang.org/x/oauth2.Config values from Google credential +// data. Google supports two JSON formats for OAuth2 credentials: one is handled by ConfigFromJSON, +// the other by JWTConfigFromJSON. The returned Config can be used to obtain a TokenSource or +// create an http.Client. +// +// +// Credentials +// +// The Credentials type represents Google credentials, including Application Default +// Credentials. +// +// Use FindDefaultCredentials to obtain Application Default Credentials. +// FindDefaultCredentials looks in some well-known places for a credentials file, and +// will call AppEngineTokenSource or ComputeTokenSource as needed. +// +// DefaultClient and DefaultTokenSource are convenience methods. They first call FindDefaultCredentials, +// then use the credentials to construct an http.Client or an oauth2.TokenSource. +// +// Use CredentialsFromJSON to obtain credentials from either of the two JSON formats +// described in OAuth2 Configs, above. The TokenSource in the returned value is the +// same as the one obtained from the oauth2.Config returned from ConfigFromJSON or +// JWTConfigFromJSON, but the Credentials may contain additional information +// that is useful is some circumstances. +package google // import "golang.org/x/oauth2/google" diff --git a/vendor/golang.org/x/oauth2/google/doc_not_go19.go b/vendor/golang.org/x/oauth2/google/doc_not_go19.go new file mode 100644 index 00000000000..5c3c6e14812 --- /dev/null +++ b/vendor/golang.org/x/oauth2/google/doc_not_go19.go @@ -0,0 +1,43 @@ +// Copyright 2018 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.9 + +// 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. +// +// A brief overview of the package follows. For more information, please read +// https://developers.google.com/accounts/docs/OAuth2 +// and +// https://developers.google.com/accounts/docs/application-default-credentials. +// +// OAuth2 Configs +// +// Two functions in this package return golang.org/x/oauth2.Config values from Google credential +// data. Google supports two JSON formats for OAuth2 credentials: one is handled by ConfigFromJSON, +// the other by JWTConfigFromJSON. The returned Config can be used to obtain a TokenSource or +// create an http.Client. +// +// +// Credentials +// +// The DefaultCredentials type represents Google Application Default Credentials, as +// well as other forms of credential. +// +// Use FindDefaultCredentials to obtain Application Default Credentials. +// FindDefaultCredentials looks in some well-known places for a credentials file, and +// will call AppEngineTokenSource or ComputeTokenSource as needed. +// +// DefaultClient and DefaultTokenSource are convenience methods. They first call FindDefaultCredentials, +// then use the credentials to construct an http.Client or an oauth2.TokenSource. +// +// Use CredentialsFromJSON to obtain credentials from either of the two JSON +// formats described in OAuth2 Configs, above. (The DefaultCredentials returned may +// not be "Application Default Credentials".) The TokenSource in the returned value +// is the same as the one obtained from the oauth2.Config returned from +// ConfigFromJSON or JWTConfigFromJSON, but the DefaultCredentials may contain +// additional information that is useful is some circumstances. +package google // import "golang.org/x/oauth2/google" diff --git a/vendor/golang.org/x/oauth2/google/go19.go b/vendor/golang.org/x/oauth2/google/go19.go new file mode 100644 index 00000000000..4d0318b1e16 --- /dev/null +++ b/vendor/golang.org/x/oauth2/google/go19.go @@ -0,0 +1,57 @@ +// Copyright 2018 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.9 + +package google + +import ( + "golang.org/x/net/context" + "golang.org/x/oauth2" +) + +// Credentials holds Google credentials, including "Application Default Credentials". +// For more details, see: +// https://developers.google.com/accounts/docs/application-default-credentials +type Credentials struct { + ProjectID string // may be empty + TokenSource oauth2.TokenSource + + // JSON contains the raw bytes from a JSON credentials file. + // This field may be nil if authentication is provided by the + // environment and not with a credentials file, e.g. when code is + // running on Google Cloud Platform. + JSON []byte +} + +// DefaultCredentials is the old name of Credentials. +// +// Deprecated: use Credentials instead. +type DefaultCredentials = Credentials + +// FindDefaultCredentials searches for "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.) +func FindDefaultCredentials(ctx context.Context, scopes ...string) (*Credentials, error) { + return findDefaultCredentials(ctx, scopes) +} + +// CredentialsFromJSON obtains Google credentials from a JSON value. The JSON can +// represent either a Google Developers Console client_credentials.json file (as in +// ConfigFromJSON) or a Google Developers service account key file (as in +// JWTConfigFromJSON). +func CredentialsFromJSON(ctx context.Context, jsonData []byte, scopes ...string) (*Credentials, error) { + return credentialsFromJSON(ctx, jsonData, scopes) +} diff --git a/vendor/golang.org/x/oauth2/google/google.go b/vendor/golang.org/x/oauth2/google/google.go index 66a8b0e1812..f7481fbcc63 100644 --- a/vendor/golang.org/x/oauth2/google/google.go +++ b/vendor/golang.org/x/oauth2/google/google.go @@ -2,17 +2,7 @@ // 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 "golang.org/x/oauth2/google" +package google import ( "encoding/json" diff --git a/vendor/golang.org/x/oauth2/google/not_go19.go b/vendor/golang.org/x/oauth2/google/not_go19.go new file mode 100644 index 00000000000..544e40624e1 --- /dev/null +++ b/vendor/golang.org/x/oauth2/google/not_go19.go @@ -0,0 +1,54 @@ +// Copyright 2018 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.9 + +package google + +import ( + "golang.org/x/net/context" + "golang.org/x/oauth2" +) + +// DefaultCredentials holds Google credentials, including "Application Default Credentials". +// For more details, see: +// https://developers.google.com/accounts/docs/application-default-credentials +type DefaultCredentials struct { + ProjectID string // may be empty + TokenSource oauth2.TokenSource + + // JSON contains the raw bytes from a JSON credentials file. + // This field may be nil if authentication is provided by the + // environment and not with a credentials file, e.g. when code is + // running on Google Cloud Platform. + JSON []byte +} + +// FindDefaultCredentials searches for "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.) +func FindDefaultCredentials(ctx context.Context, scopes ...string) (*DefaultCredentials, error) { + return findDefaultCredentials(ctx, scopes) +} + +// CredentialsFromJSON obtains Google credentials from a JSON value. The JSON can +// represent either a Google Developers Console client_credentials.json file (as in +// ConfigFromJSON) or a Google Developers service account key file (as in +// JWTConfigFromJSON). +// +// Note: despite the name, the returned credentials may not be Application Default Credentials. +func CredentialsFromJSON(ctx context.Context, jsonData []byte, scopes ...string) (*DefaultCredentials, error) { + return credentialsFromJSON(ctx, jsonData, scopes) +} diff --git a/vendor/golang.org/x/oauth2/internal/token.go b/vendor/golang.org/x/oauth2/internal/token.go index ce3f27e0285..30fb315d139 100644 --- a/vendor/golang.org/x/oauth2/internal/token.go +++ b/vendor/golang.org/x/oauth2/internal/token.go @@ -126,6 +126,8 @@ var brokenAuthHeaderProviders = []string{ "https://api.sipgate.com/v1/authorization/oauth", "https://api.medium.com/v1/tokens", "https://log.finalsurge.com/oauth/token", + "https://multisport.todaysplan.com.au/rest/oauth/access_token", + "https://whats.todaysplan.com.au/rest/oauth/access_token", } // brokenAuthHeaderDomains lists broken providers that issue dynamic endpoints. diff --git a/vendor/golang.org/x/oauth2/oauth2.go b/vendor/golang.org/x/oauth2/oauth2.go index a047a5f98b6..10299d2ef58 100644 --- a/vendor/golang.org/x/oauth2/oauth2.go +++ b/vendor/golang.org/x/oauth2/oauth2.go @@ -3,7 +3,8 @@ // license that can be found in the LICENSE file. // Package oauth2 provides support for making -// OAuth2 authorized and authenticated HTTP requests. +// OAuth2 authorized and authenticated HTTP requests, +// as specified in RFC 6749. // It can additionally grant authorization with Bearer JWT. package oauth2 // import "golang.org/x/oauth2" diff --git a/vendor/golang.org/x/oauth2/transport.go b/vendor/golang.org/x/oauth2/transport.go index 92ac7e2531f..aa0d34f1e0e 100644 --- a/vendor/golang.org/x/oauth2/transport.go +++ b/vendor/golang.org/x/oauth2/transport.go @@ -31,9 +31,17 @@ type Transport struct { } // 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. +// access token from Transport's Source. func (t *Transport) RoundTrip(req *http.Request) (*http.Response, error) { + reqBodyClosed := false + if req.Body != nil { + defer func() { + if !reqBodyClosed { + req.Body.Close() + } + }() + } + if t.Source == nil { return nil, errors.New("oauth2: Transport's Source is nil") } @@ -46,6 +54,10 @@ func (t *Transport) RoundTrip(req *http.Request) (*http.Response, error) { token.SetAuthHeader(req2) t.setModReq(req, req2) res, err := t.base().RoundTrip(req2) + + // req.Body is assumed to have been closed by the base RoundTripper. + reqBodyClosed = true + if err != nil { t.setModReq(req, nil) return nil, err diff --git a/vendor/golang.org/x/sys/unix/asm_dragonfly_amd64.s b/vendor/golang.org/x/sys/unix/asm_dragonfly_amd64.s index d5ed6726cc1..603dd5728c4 100644 --- a/vendor/golang.org/x/sys/unix/asm_dragonfly_amd64.s +++ b/vendor/golang.org/x/sys/unix/asm_dragonfly_amd64.s @@ -13,17 +13,17 @@ // Just jump to package syscall's implementation for all these functions. // The runtime may know about them. -TEXT ·Syscall(SB),NOSPLIT,$0-64 +TEXT ·Syscall(SB),NOSPLIT,$0-56 JMP syscall·Syscall(SB) -TEXT ·Syscall6(SB),NOSPLIT,$0-88 +TEXT ·Syscall6(SB),NOSPLIT,$0-80 JMP syscall·Syscall6(SB) -TEXT ·Syscall9(SB),NOSPLIT,$0-112 +TEXT ·Syscall9(SB),NOSPLIT,$0-104 JMP syscall·Syscall9(SB) -TEXT ·RawSyscall(SB),NOSPLIT,$0-64 +TEXT ·RawSyscall(SB),NOSPLIT,$0-56 JMP syscall·RawSyscall(SB) -TEXT ·RawSyscall6(SB),NOSPLIT,$0-88 +TEXT ·RawSyscall6(SB),NOSPLIT,$0-80 JMP syscall·RawSyscall6(SB) diff --git a/vendor/golang.org/x/sys/unix/cap_freebsd.go b/vendor/golang.org/x/sys/unix/cap_freebsd.go index 83b6bceab43..df520487737 100644 --- a/vendor/golang.org/x/sys/unix/cap_freebsd.go +++ b/vendor/golang.org/x/sys/unix/cap_freebsd.go @@ -7,7 +7,7 @@ package unix import ( - errorspkg "errors" + "errors" "fmt" ) @@ -60,26 +60,26 @@ func CapRightsSet(rights *CapRights, setrights []uint64) error { n := caparsize(rights) if n < capArSizeMin || n > capArSizeMax { - return errorspkg.New("bad rights size") + return errors.New("bad rights size") } for _, right := range setrights { if caprver(right) != CAP_RIGHTS_VERSION_00 { - return errorspkg.New("bad right version") + return errors.New("bad right version") } i, err := rightToIndex(right) if err != nil { return err } if i >= n { - return errorspkg.New("index overflow") + return errors.New("index overflow") } if capidxbit(rights.Rights[i]) != capidxbit(right) { - return errorspkg.New("index mismatch") + return errors.New("index mismatch") } rights.Rights[i] |= right if capidxbit(rights.Rights[i]) != capidxbit(right) { - return errorspkg.New("index mismatch (after assign)") + return errors.New("index mismatch (after assign)") } } @@ -95,26 +95,26 @@ func CapRightsClear(rights *CapRights, clearrights []uint64) error { n := caparsize(rights) if n < capArSizeMin || n > capArSizeMax { - return errorspkg.New("bad rights size") + return errors.New("bad rights size") } for _, right := range clearrights { if caprver(right) != CAP_RIGHTS_VERSION_00 { - return errorspkg.New("bad right version") + return errors.New("bad right version") } i, err := rightToIndex(right) if err != nil { return err } if i >= n { - return errorspkg.New("index overflow") + return errors.New("index overflow") } if capidxbit(rights.Rights[i]) != capidxbit(right) { - return errorspkg.New("index mismatch") + return errors.New("index mismatch") } rights.Rights[i] &= ^(right & 0x01FFFFFFFFFFFFFF) if capidxbit(rights.Rights[i]) != capidxbit(right) { - return errorspkg.New("index mismatch (after assign)") + return errors.New("index mismatch (after assign)") } } @@ -130,22 +130,22 @@ func CapRightsIsSet(rights *CapRights, setrights []uint64) (bool, error) { n := caparsize(rights) if n < capArSizeMin || n > capArSizeMax { - return false, errorspkg.New("bad rights size") + return false, errors.New("bad rights size") } for _, right := range setrights { if caprver(right) != CAP_RIGHTS_VERSION_00 { - return false, errorspkg.New("bad right version") + return false, errors.New("bad right version") } i, err := rightToIndex(right) if err != nil { return false, err } if i >= n { - return false, errorspkg.New("index overflow") + return false, errors.New("index overflow") } if capidxbit(rights.Rights[i]) != capidxbit(right) { - return false, errorspkg.New("index mismatch") + return false, errors.New("index mismatch") } if (rights.Rights[i] & right) != right { return false, nil diff --git a/vendor/golang.org/x/sys/unix/flock.go b/vendor/golang.org/x/sys/unix/fcntl.go similarity index 74% rename from vendor/golang.org/x/sys/unix/flock.go rename to vendor/golang.org/x/sys/unix/fcntl.go index 2994ce75f20..0c58c7e1e5a 100644 --- a/vendor/golang.org/x/sys/unix/flock.go +++ b/vendor/golang.org/x/sys/unix/fcntl.go @@ -12,6 +12,12 @@ import "unsafe" // systems by flock_linux_32bit.go to be SYS_FCNTL64. var fcntl64Syscall uintptr = SYS_FCNTL +// FcntlInt performs a fcntl syscall on fd with the provided command and argument. +func FcntlInt(fd uintptr, cmd, arg int) (int, error) { + valptr, _, err := Syscall(fcntl64Syscall, fd, uintptr(cmd), uintptr(arg)) + return int(valptr), err +} + // FcntlFlock performs a fcntl syscall for the F_GETLK, F_SETLK or F_SETLKW command. func FcntlFlock(fd uintptr, cmd int, lk *Flock_t) error { _, _, errno := Syscall(fcntl64Syscall, fd, uintptr(cmd), uintptr(unsafe.Pointer(lk))) diff --git a/vendor/golang.org/x/sys/unix/flock_linux_32bit.go b/vendor/golang.org/x/sys/unix/fcntl_linux_32bit.go similarity index 100% rename from vendor/golang.org/x/sys/unix/flock_linux_32bit.go rename to vendor/golang.org/x/sys/unix/fcntl_linux_32bit.go diff --git a/vendor/golang.org/x/sys/unix/mkerrors.sh b/vendor/golang.org/x/sys/unix/mkerrors.sh index 3b5e2c07b39..ddc50a018a6 100755 --- a/vendor/golang.org/x/sys/unix/mkerrors.sh +++ b/vendor/golang.org/x/sys/unix/mkerrors.sh @@ -50,6 +50,7 @@ includes_Darwin=' #include #include #include +#include #include #include #include @@ -171,6 +172,8 @@ struct ltchars { #include #include #include +#include +#include #include #include #include @@ -189,6 +192,7 @@ struct ltchars { #include #include #include +#include #include #include @@ -383,7 +387,8 @@ ccflags="$@" $2 ~ /^TC[IO](ON|OFF)$/ || $2 ~ /^IN_/ || $2 ~ /^LOCK_(SH|EX|NB|UN)$/ || - $2 ~ /^(AF|SOCK|SO|SOL|IPPROTO|IP|IPV6|ICMP6|TCP|EVFILT|NOTE|EV|SHUT|PROT|MAP|PACKET|MSG|SCM|MCL|DT|MADV|PR)_/ || + $2 ~ /^(AF|SOCK|SO|SOL|IPPROTO|IP|IPV6|ICMP6|TCP|EVFILT|NOTE|EV|SHUT|PROT|MAP|T?PACKET|MSG|SCM|MCL|DT|MADV|PR)_/ || + $2 ~ /^TP_STATUS_/ || $2 ~ /^FALLOC_/ || $2 == "ICMPV6_FILTER" || $2 == "SOMAXCONN" || @@ -425,6 +430,8 @@ ccflags="$@" $2 ~ /^PERF_EVENT_IOC_/ || $2 ~ /^SECCOMP_MODE_/ || $2 ~ /^SPLICE_/ || + $2 !~ /^AUDIT_RECORD_MAGIC/ && + $2 ~ /^[A-Z0-9_]+_MAGIC2?$/ || $2 ~ /^(VM|VMADDR)_/ || $2 ~ /^IOCTL_VM_SOCKETS_/ || $2 ~ /^(TASKSTATS|TS)_/ || @@ -432,10 +439,12 @@ ccflags="$@" $2 ~ /^GENL_/ || $2 ~ /^STATX_/ || $2 ~ /^UTIME_/ || - $2 ~ /^XATTR_(CREATE|REPLACE)/ || + $2 ~ /^XATTR_(CREATE|REPLACE|NO(DEFAULT|FOLLOW|SECURITY)|SHOWCOMPRESSION)/ || $2 ~ /^ATTR_(BIT_MAP_COUNT|(CMN|VOL|FILE)_)/ || $2 ~ /^FSOPT_/ || $2 ~ /^WDIOC_/ || + $2 ~ /^NFN/ || + $2 ~ /^(HDIO|WIN|SMART)_/ || $2 !~ "WMESGLEN" && $2 ~ /^W[A-Z0-9]+$/ || $2 ~ /^BLK[A-Z]*(GET$|SET$|BUF$|PART$|SIZE)/ {printf("\t%s = C.%s\n", $2, $2)} @@ -505,21 +514,26 @@ echo ')' enum { A = 'A', Z = 'Z', a = 'a', z = 'z' }; // avoid need for single quotes below -int errors[] = { +struct tuple { + int num; + const char *name; +}; + +struct tuple errors[] = { " for i in $errors do - echo -E ' '$i, + echo -E ' {'$i', "'$i'" },' done echo -E " }; -int signals[] = { +struct tuple signals[] = { " for i in $signals do - echo -E ' '$i, + echo -E ' {'$i', "'$i'" },' done # Use -E because on some systems bash builtin interprets \n itself. @@ -527,9 +541,9 @@ int signals[] = { }; static int -intcmp(const void *a, const void *b) +tuplecmp(const void *a, const void *b) { - return *(int*)a - *(int*)b; + return ((struct tuple *)a)->num - ((struct tuple *)b)->num; } int @@ -539,26 +553,34 @@ main(void) char buf[1024], *p; printf("\n\n// Error table\n"); - printf("var errors = [...]string {\n"); - qsort(errors, nelem(errors), sizeof errors[0], intcmp); + printf("var errorList = [...]struct {\n"); + printf("\tnum syscall.Errno\n"); + printf("\tname string\n"); + printf("\tdesc string\n"); + printf("} {\n"); + qsort(errors, nelem(errors), sizeof errors[0], tuplecmp); for(i=0; i 0 && errors[i-1] == e) + e = errors[i].num; + if(i > 0 && errors[i-1].num == e) continue; strcpy(buf, strerror(e)); // lowercase first letter: Bad -> bad, but STREAM -> STREAM. if(A <= buf[0] && buf[0] <= Z && a <= buf[1] && buf[1] <= z) buf[0] += a - A; - printf("\t%d: \"%s\",\n", e, buf); + printf("\t{ %d, \"%s\", \"%s\" },\n", e, errors[i].name, buf); } printf("}\n\n"); printf("\n\n// Signal table\n"); - printf("var signals = [...]string {\n"); - qsort(signals, nelem(signals), sizeof signals[0], intcmp); + printf("var signalList = [...]struct {\n"); + printf("\tnum syscall.Signal\n"); + printf("\tname string\n"); + printf("\tdesc string\n"); + printf("} {\n"); + qsort(signals, nelem(signals), sizeof signals[0], tuplecmp); for(i=0; i 0 && signals[i-1] == e) + e = signals[i].num; + if(i > 0 && signals[i-1].num == e) continue; strcpy(buf, strsignal(e)); // lowercase first letter: Bad -> bad, but STREAM -> STREAM. @@ -568,7 +590,7 @@ main(void) p = strrchr(buf, ":"[0]); if(p) *p = '\0'; - printf("\t%d: \"%s\",\n", e, buf); + printf("\t{ %d, \"%s\", \"%s\" },\n", e, signals[i].name, buf); } printf("}\n\n"); diff --git a/vendor/golang.org/x/sys/unix/mkpost.go b/vendor/golang.org/x/sys/unix/mkpost.go index 23590bda366..7e5c22c4735 100644 --- a/vendor/golang.org/x/sys/unix/mkpost.go +++ b/vendor/golang.org/x/sys/unix/mkpost.go @@ -42,6 +42,10 @@ func main() { log.Fatal(err) } + // Intentionally export __val fields in Fsid and Sigset_t + valRegex := regexp.MustCompile(`type (Fsid|Sigset_t) struct {(\s+)X__val(\s+\S+\s+)}`) + b = valRegex.ReplaceAll(b, []byte("type $1 struct {${2}Val$3}")) + // If we have empty Ptrace structs, we should delete them. Only s390x emits // nonempty Ptrace structs. ptraceRexexp := regexp.MustCompile(`type Ptrace((Psw|Fpregs|Per) struct {\s*})`) @@ -69,12 +73,9 @@ func main() { removePaddingFieldsRegex := regexp.MustCompile(`Pad_cgo_\d+`) b = removePaddingFieldsRegex.ReplaceAll(b, []byte("_")) - // We refuse to export private fields on s390x - if goarch == "s390x" && goos == "linux" { - // Remove padding, hidden, or unused fields - removeFieldsRegex = regexp.MustCompile(`\bX_\S+`) - b = removeFieldsRegex.ReplaceAll(b, []byte("_")) - } + // Remove padding, hidden, or unused fields + removeFieldsRegex = regexp.MustCompile(`\b(X_\S+|Padding)`) + b = removeFieldsRegex.ReplaceAll(b, []byte("_")) // Remove the first line of warning from cgo b = b[bytes.IndexByte(b, '\n')+1:] diff --git a/vendor/golang.org/x/sys/unix/openbsd_pledge.go b/vendor/golang.org/x/sys/unix/openbsd_pledge.go index db4f72ea9c4..9b1e86a12ba 100644 --- a/vendor/golang.org/x/sys/unix/openbsd_pledge.go +++ b/vendor/golang.org/x/sys/unix/openbsd_pledge.go @@ -13,7 +13,7 @@ import ( ) const ( - SYS_PLEDGE = 108 + _SYS_PLEDGE = 108 ) // Pledge implements the pledge syscall. For more information see pledge(2). @@ -30,7 +30,7 @@ func Pledge(promises string, paths []string) error { } pathsUnsafe = unsafe.Pointer(&pathsPtr[0]) } - _, _, e := syscall.Syscall(SYS_PLEDGE, uintptr(promisesUnsafe), uintptr(pathsUnsafe), 0) + _, _, e := syscall.Syscall(_SYS_PLEDGE, uintptr(promisesUnsafe), uintptr(pathsUnsafe), 0) if e != 0 { return e } diff --git a/vendor/golang.org/x/sys/unix/syscall.go b/vendor/golang.org/x/sys/unix/syscall.go index 857d2a42d47..ef35fce8041 100644 --- a/vendor/golang.org/x/sys/unix/syscall.go +++ b/vendor/golang.org/x/sys/unix/syscall.go @@ -11,24 +11,27 @@ // system, set $GOOS and $GOARCH to the desired system. For example, if // you want to view documentation for freebsd/arm on linux/amd64, set $GOOS // to freebsd and $GOARCH to arm. +// // The primary use of this package is inside other packages that provide a more // portable interface to the system, such as "os", "time" and "net". Use // those packages rather than this one if you can. +// // For details of the functions and data types in this package consult // the manuals for the appropriate operating system. +// // These calls return err == nil to indicate success; otherwise // err represents an operating system error describing the failure and // holds a value of type syscall.Errno. package unix // import "golang.org/x/sys/unix" +import "strings" + // ByteSliceFromString returns a NUL-terminated slice of bytes // containing the text of s. If s contains a NUL byte at any // location, it returns (nil, EINVAL). func ByteSliceFromString(s string) ([]byte, error) { - for i := 0; i < len(s); i++ { - if s[i] == 0 { - return nil, EINVAL - } + if strings.IndexByte(s, 0) != -1 { + return nil, EINVAL } a := make([]byte, len(s)+1) copy(a, s) diff --git a/vendor/golang.org/x/sys/unix/syscall_bsd.go b/vendor/golang.org/x/sys/unix/syscall_bsd.go index d3903edebad..53fb8518237 100644 --- a/vendor/golang.org/x/sys/unix/syscall_bsd.go +++ b/vendor/golang.org/x/sys/unix/syscall_bsd.go @@ -311,47 +311,6 @@ func Getsockname(fd int) (sa Sockaddr, err error) { //sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error) -func GetsockoptByte(fd, level, opt int) (value byte, err error) { - var n byte - vallen := _Socklen(1) - err = getsockopt(fd, level, opt, unsafe.Pointer(&n), &vallen) - return n, err -} - -func GetsockoptInet4Addr(fd, level, opt int) (value [4]byte, err error) { - vallen := _Socklen(4) - err = getsockopt(fd, level, opt, unsafe.Pointer(&value[0]), &vallen) - return value, err -} - -func GetsockoptIPMreq(fd, level, opt int) (*IPMreq, error) { - var value IPMreq - vallen := _Socklen(SizeofIPMreq) - err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) - return &value, err -} - -func GetsockoptIPv6Mreq(fd, level, opt int) (*IPv6Mreq, error) { - var value IPv6Mreq - vallen := _Socklen(SizeofIPv6Mreq) - err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) - return &value, err -} - -func GetsockoptIPv6MTUInfo(fd, level, opt int) (*IPv6MTUInfo, error) { - var value IPv6MTUInfo - vallen := _Socklen(SizeofIPv6MTUInfo) - err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) - return &value, err -} - -func GetsockoptICMPv6Filter(fd, level, opt int) (*ICMPv6Filter, error) { - var value ICMPv6Filter - vallen := _Socklen(SizeofICMPv6Filter) - err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) - return &value, err -} - // GetsockoptString returns the string value of the socket option opt for the // socket associated with fd at the given socket level. func GetsockoptString(fd, level, opt int) (string, error) { diff --git a/vendor/golang.org/x/sys/unix/syscall_darwin.go b/vendor/golang.org/x/sys/unix/syscall_darwin.go index b9598694c6b..79e94767deb 100644 --- a/vendor/golang.org/x/sys/unix/syscall_darwin.go +++ b/vendor/golang.org/x/sys/unix/syscall_darwin.go @@ -13,7 +13,7 @@ package unix import ( - errorspkg "errors" + "errors" "syscall" "unsafe" ) @@ -98,7 +98,7 @@ type attrList struct { func getAttrList(path string, attrList attrList, attrBuf []byte, options uint) (attrs [][]byte, err error) { if len(attrBuf) < 4 { - return nil, errorspkg.New("attrBuf too small") + return nil, errors.New("attrBuf too small") } attrList.bitmapCount = attrBitMapCount @@ -134,12 +134,12 @@ func getAttrList(path string, attrList attrList, attrBuf []byte, options uint) ( for i := uint32(0); int(i) < len(dat); { header := dat[i:] if len(header) < 8 { - return attrs, errorspkg.New("truncated attribute header") + return attrs, errors.New("truncated attribute header") } datOff := *(*int32)(unsafe.Pointer(&header[0])) attrLen := *(*uint32)(unsafe.Pointer(&header[4])) if datOff < 0 || uint32(datOff)+attrLen > uint32(len(dat)) { - return attrs, errorspkg.New("truncated results; attrBuf too small") + return attrs, errors.New("truncated results; attrBuf too small") } end := uint32(datOff) + attrLen attrs = append(attrs, dat[datOff:end]) @@ -176,6 +176,88 @@ func Getfsstat(buf []Statfs_t, flags int) (n int, err error) { return } +func xattrPointer(dest []byte) *byte { + // It's only when dest is set to NULL that the OS X implementations of + // getxattr() and listxattr() return the current sizes of the named attributes. + // An empty byte array is not sufficient. To maintain the same behaviour as the + // linux implementation, we wrap around the system calls and pass in NULL when + // dest is empty. + var destp *byte + if len(dest) > 0 { + destp = &dest[0] + } + return destp +} + +//sys getxattr(path string, attr string, dest *byte, size int, position uint32, options int) (sz int, err error) + +func Getxattr(path string, attr string, dest []byte) (sz int, err error) { + return getxattr(path, attr, xattrPointer(dest), len(dest), 0, 0) +} + +func Lgetxattr(link string, attr string, dest []byte) (sz int, err error) { + return getxattr(link, attr, xattrPointer(dest), len(dest), 0, XATTR_NOFOLLOW) +} + +//sys setxattr(path string, attr string, data *byte, size int, position uint32, options int) (err error) + +func Setxattr(path string, attr string, data []byte, flags int) (err error) { + // The parameters for the OS X implementation vary slightly compared to the + // linux system call, specifically the position parameter: + // + // linux: + // int setxattr( + // const char *path, + // const char *name, + // const void *value, + // size_t size, + // int flags + // ); + // + // darwin: + // int setxattr( + // const char *path, + // const char *name, + // void *value, + // size_t size, + // u_int32_t position, + // int options + // ); + // + // position specifies the offset within the extended attribute. In the + // current implementation, only the resource fork extended attribute makes + // use of this argument. For all others, position is reserved. We simply + // default to setting it to zero. + return setxattr(path, attr, xattrPointer(data), len(data), 0, flags) +} + +func Lsetxattr(link string, attr string, data []byte, flags int) (err error) { + return setxattr(link, attr, xattrPointer(data), len(data), 0, flags|XATTR_NOFOLLOW) +} + +//sys removexattr(path string, attr string, options int) (err error) + +func Removexattr(path string, attr string) (err error) { + // We wrap around and explicitly zero out the options provided to the OS X + // implementation of removexattr, we do so for interoperability with the + // linux variant. + return removexattr(path, attr, 0) +} + +func Lremovexattr(link string, attr string) (err error) { + return removexattr(link, attr, XATTR_NOFOLLOW) +} + +//sys listxattr(path string, dest *byte, size int, options int) (sz int, err error) + +func Listxattr(path string, dest []byte) (sz int, err error) { + return listxattr(path, xattrPointer(dest), len(dest), 0) +} + +func Llistxattr(link string, dest []byte) (sz int, err error) { + return listxattr(link, xattrPointer(dest), len(dest), XATTR_NOFOLLOW) +} + func setattrlistTimes(path string, times []Timespec, flags int) error { _p0, err := BytePtrFromString(path) if err != nil { @@ -330,6 +412,7 @@ func Uname(uname *Utsname) error { //sys Flock(fd int, how int) (err error) //sys Fpathconf(fd int, name int) (val int, err error) //sys Fstat(fd int, stat *Stat_t) (err error) = SYS_FSTAT64 +//sys Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) = SYS_FSTATAT64 //sys Fstatfs(fd int, stat *Statfs_t) (err error) = SYS_FSTATFS64 //sys Fsync(fd int) (err error) //sys Ftruncate(fd int, length int64) (err error) @@ -446,13 +529,9 @@ func Uname(uname *Utsname) error { // Watchevent // Waitevent // Modwatch -// Getxattr // Fgetxattr -// Setxattr // Fsetxattr -// Removexattr // Fremovexattr -// Listxattr // Flistxattr // Fsctl // Initgroups diff --git a/vendor/golang.org/x/sys/unix/syscall_dragonfly.go b/vendor/golang.org/x/sys/unix/syscall_dragonfly.go index 777860bf09f..b5072de2853 100644 --- a/vendor/golang.org/x/sys/unix/syscall_dragonfly.go +++ b/vendor/golang.org/x/sys/unix/syscall_dragonfly.go @@ -251,10 +251,12 @@ func Uname(uname *Utsname) error { //sys Fchdir(fd int) (err error) //sys Fchflags(fd int, flags int) (err error) //sys Fchmod(fd int, mode uint32) (err error) +//sys Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) //sys Fchown(fd int, uid int, gid int) (err error) //sys Flock(fd int, how int) (err error) //sys Fpathconf(fd int, name int) (val int, err error) //sys Fstat(fd int, stat *Stat_t) (err error) +//sys Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) //sys Fstatfs(fd int, stat *Statfs_t) (err error) //sys Fsync(fd int) (err error) //sys Ftruncate(fd int, length int64) (err error) diff --git a/vendor/golang.org/x/sys/unix/syscall_freebsd.go b/vendor/golang.org/x/sys/unix/syscall_freebsd.go index 89f2c3fc17c..ba9df4ac126 100644 --- a/vendor/golang.org/x/sys/unix/syscall_freebsd.go +++ b/vendor/golang.org/x/sys/unix/syscall_freebsd.go @@ -12,7 +12,10 @@ package unix -import "unsafe" +import ( + "strings" + "unsafe" +) // SockaddrDatalink implements the Sockaddr interface for AF_LINK type sockets. type SockaddrDatalink struct { @@ -134,14 +137,7 @@ func setattrlistTimes(path string, times []Timespec, flags int) error { // Derive extattr namespace and attribute name func xattrnamespace(fullattr string) (ns int, attr string, err error) { - s := -1 - for idx, val := range fullattr { - if val == '.' { - s = idx - break - } - } - + s := strings.IndexByte(fullattr, '.') if s == -1 { return -1, "", ENOATTR } @@ -482,6 +478,7 @@ func Uname(uname *Utsname) error { //sys Flock(fd int, how int) (err error) //sys Fpathconf(fd int, name int) (val int, err error) //sys Fstat(fd int, stat *Stat_t) (err error) +//sys Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) //sys Fstatfs(fd int, stat *Statfs_t) (err error) //sys Fsync(fd int) (err error) //sys Ftruncate(fd int, length int64) (err error) diff --git a/vendor/golang.org/x/sys/unix/syscall_linux.go b/vendor/golang.org/x/sys/unix/syscall_linux.go index 76cf81f5796..04f38c53ee1 100644 --- a/vendor/golang.org/x/sys/unix/syscall_linux.go +++ b/vendor/golang.org/x/sys/unix/syscall_linux.go @@ -782,19 +782,6 @@ func Getsockname(fd int) (sa Sockaddr, err error) { return anyToSockaddr(&rsa) } -func GetsockoptInet4Addr(fd, level, opt int) (value [4]byte, err error) { - vallen := _Socklen(4) - err = getsockopt(fd, level, opt, unsafe.Pointer(&value[0]), &vallen) - return value, err -} - -func GetsockoptIPMreq(fd, level, opt int) (*IPMreq, error) { - var value IPMreq - vallen := _Socklen(SizeofIPMreq) - err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) - return &value, err -} - func GetsockoptIPMreqn(fd, level, opt int) (*IPMreqn, error) { var value IPMreqn vallen := _Socklen(SizeofIPMreqn) @@ -802,27 +789,6 @@ func GetsockoptIPMreqn(fd, level, opt int) (*IPMreqn, error) { return &value, err } -func GetsockoptIPv6Mreq(fd, level, opt int) (*IPv6Mreq, error) { - var value IPv6Mreq - vallen := _Socklen(SizeofIPv6Mreq) - err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) - return &value, err -} - -func GetsockoptIPv6MTUInfo(fd, level, opt int) (*IPv6MTUInfo, error) { - var value IPv6MTUInfo - vallen := _Socklen(SizeofIPv6MTUInfo) - err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) - return &value, err -} - -func GetsockoptICMPv6Filter(fd, level, opt int) (*ICMPv6Filter, error) { - var value ICMPv6Filter - vallen := _Socklen(SizeofICMPv6Filter) - err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) - return &value, err -} - func GetsockoptUcred(fd, level, opt int) (*Ucred, error) { var value Ucred vallen := _Socklen(SizeofUcred) @@ -978,15 +944,17 @@ func Recvmsg(fd int, p, oob []byte, flags int) (n, oobn int, recvflags int, from } var dummy byte if len(oob) > 0 { - var sockType int - sockType, err = GetsockoptInt(fd, SOL_SOCKET, SO_TYPE) - if err != nil { - return - } - // receive at least one normal byte - if sockType != SOCK_DGRAM && len(p) == 0 { - iov.Base = &dummy - iov.SetLen(1) + if len(p) == 0 { + var sockType int + sockType, err = GetsockoptInt(fd, SOL_SOCKET, SO_TYPE) + if err != nil { + return + } + // receive at least one normal byte + if sockType != SOCK_DGRAM { + iov.Base = &dummy + iov.SetLen(1) + } } msg.Control = &oob[0] msg.SetControllen(len(oob)) @@ -1030,15 +998,17 @@ func SendmsgN(fd int, p, oob []byte, to Sockaddr, flags int) (n int, err error) } var dummy byte if len(oob) > 0 { - var sockType int - sockType, err = GetsockoptInt(fd, SOL_SOCKET, SO_TYPE) - if err != nil { - return 0, err - } - // send at least one normal byte - if sockType != SOCK_DGRAM && len(p) == 0 { - iov.Base = &dummy - iov.SetLen(1) + if len(p) == 0 { + var sockType int + sockType, err = GetsockoptInt(fd, SOL_SOCKET, SO_TYPE) + if err != nil { + return 0, err + } + // send at least one normal byte + if sockType != SOCK_DGRAM { + iov.Base = &dummy + iov.SetLen(1) + } } msg.Control = &oob[0] msg.SetControllen(len(oob)) @@ -1294,6 +1264,7 @@ func Getpgrp() (pid int) { //sys Mkdirat(dirfd int, path string, mode uint32) (err error) //sys Mknodat(dirfd int, path string, mode uint32, dev int) (err error) //sys Nanosleep(time *Timespec, leftover *Timespec) (err error) +//sys PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) //sys PivotRoot(newroot string, putold string) (err error) = SYS_PIVOT_ROOT //sysnb prlimit(pid int, resource int, newlimit *Rlimit, old *Rlimit) (err error) = SYS_PRLIMIT64 //sys Prctl(option int, arg2 uintptr, arg3 uintptr, arg4 uintptr, arg5 uintptr) (err error) diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_amd64.go b/vendor/golang.org/x/sys/unix/syscall_linux_amd64.go index 53d38a53428..d121106323e 100644 --- a/vendor/golang.org/x/sys/unix/syscall_linux_amd64.go +++ b/vendor/golang.org/x/sys/unix/syscall_linux_amd64.go @@ -29,7 +29,15 @@ package unix //sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64 //sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64 //sys Seek(fd int, offset int64, whence int) (off int64, err error) = SYS_LSEEK -//sys Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) + +func Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) { + var ts *Timespec + if timeout != nil { + ts = &Timespec{Sec: timeout.Sec, Nsec: timeout.Usec * 1000} + } + return Pselect(nfd, r, w, e, ts, nil) +} + //sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) //sys Setfsgid(gid int) (err error) //sys Setfsuid(uid int) (err error) @@ -40,7 +48,12 @@ package unix //sysnb Setreuid(ruid int, euid int) (err error) //sys Shutdown(fd int, how int) (err error) //sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error) -//sys Stat(path string, stat *Stat_t) (err error) + +func Stat(path string, stat *Stat_t) (err error) { + // Use fstatat, because Android's seccomp policy blocks stat. + return Fstatat(AT_FDCWD, path, stat, 0) +} + //sys Statfs(path string, buf *Statfs_t) (err error) //sys SyncFileRange(fd int, off int64, n int64, flags int) (err error) //sys Truncate(path string, length int64) (err error) diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_arm64.go b/vendor/golang.org/x/sys/unix/syscall_linux_arm64.go index c464783d85e..a1e8a609b26 100644 --- a/vendor/golang.org/x/sys/unix/syscall_linux_arm64.go +++ b/vendor/golang.org/x/sys/unix/syscall_linux_arm64.go @@ -7,6 +7,7 @@ package unix //sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) = SYS_EPOLL_PWAIT +//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_FADVISE64 //sys Fchown(fd int, uid int, gid int) (err error) //sys Fstat(fd int, stat *Stat_t) (err error) //sys Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_gccgo.go b/vendor/golang.org/x/sys/unix/syscall_linux_gccgo.go new file mode 100644 index 00000000000..df9c1237181 --- /dev/null +++ b/vendor/golang.org/x/sys/unix/syscall_linux_gccgo.go @@ -0,0 +1,21 @@ +// Copyright 2018 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 linux +// +build gccgo +// +build 386 arm + +package unix + +import ( + "syscall" + "unsafe" +) + +func seek(fd int, offset int64, whence int) (newoffset int64, err syscall.Errno) { + offsetLow := uint32(offset & 0xffffffff) + offsetHigh := uint32((offset >> 32) & 0xffffffff) + _, _, err = Syscall6(SYS__LLSEEK, uintptr(fd), uintptr(offsetHigh), uintptr(offsetLow), uintptr(unsafe.Pointer(&newoffset)), uintptr(whence), 0) + return newoffset, err +} diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_mips64x.go b/vendor/golang.org/x/sys/unix/syscall_linux_mips64x.go index 15a69cbdde4..090ed404ab8 100644 --- a/vendor/golang.org/x/sys/unix/syscall_linux_mips64x.go +++ b/vendor/golang.org/x/sys/unix/syscall_linux_mips64x.go @@ -9,6 +9,7 @@ package unix //sys Dup2(oldfd int, newfd int) (err error) //sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) +//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_FADVISE64 //sys Fchown(fd int, uid int, gid int) (err error) //sys Fstatat(dirfd int, path string, stat *Stat_t, flags int) (err error) = SYS_NEWFSTATAT //sys Fstatfs(fd int, buf *Statfs_t) (err error) diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_mipsx.go b/vendor/golang.org/x/sys/unix/syscall_linux_mipsx.go index 40b8e4f0fcd..9e16cc9d14e 100644 --- a/vendor/golang.org/x/sys/unix/syscall_linux_mipsx.go +++ b/vendor/golang.org/x/sys/unix/syscall_linux_mipsx.go @@ -15,6 +15,7 @@ import ( func Syscall9(trap, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, err syscall.Errno) //sys Dup2(oldfd int, newfd int) (err error) +//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_FADVISE64 //sys Fchown(fd int, uid int, gid int) (err error) //sys Ftruncate(fd int, length int64) (err error) = SYS_FTRUNCATE64 //sysnb Getegid() (egid int) @@ -35,7 +36,7 @@ func Syscall9(trap, a1, a2, a3, a4, a5, a6, a7, a8, a9 uintptr) (r1, r2 uintptr, //sysnb Setreuid(ruid int, euid int) (err error) //sys Shutdown(fd int, how int) (err error) -//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error) +//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int, err error) //sys SyncFileRange(fd int, off int64, n int64, flags int) (err error) //sys Truncate(path string, length int64) (err error) = SYS_TRUNCATE64 diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_ppc64x.go b/vendor/golang.org/x/sys/unix/syscall_linux_ppc64x.go index 17c9116e811..6fb8733d674 100644 --- a/vendor/golang.org/x/sys/unix/syscall_linux_ppc64x.go +++ b/vendor/golang.org/x/sys/unix/syscall_linux_ppc64x.go @@ -9,6 +9,7 @@ package unix //sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) //sys Dup2(oldfd int, newfd int) (err error) +//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_FADVISE64 //sys Fchown(fd int, uid int, gid int) (err error) //sys Fstat(fd int, stat *Stat_t) (err error) //sys Fstatat(dirfd int, path string, stat *Stat_t, flags int) (err error) = SYS_NEWFSTATAT diff --git a/vendor/golang.org/x/sys/unix/syscall_linux_sparc64.go b/vendor/golang.org/x/sys/unix/syscall_linux_sparc64.go index a00f992798d..78c1e0df1db 100644 --- a/vendor/golang.org/x/sys/unix/syscall_linux_sparc64.go +++ b/vendor/golang.org/x/sys/unix/syscall_linux_sparc64.go @@ -7,6 +7,7 @@ package unix //sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) +//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_FADVISE64 //sys Dup2(oldfd int, newfd int) (err error) //sys Fchown(fd int, uid int, gid int) (err error) //sys Fstat(fd int, stat *Stat_t) (err error) diff --git a/vendor/golang.org/x/sys/unix/syscall_netbsd.go b/vendor/golang.org/x/sys/unix/syscall_netbsd.go index 71b7078380e..e1a3baa237d 100644 --- a/vendor/golang.org/x/sys/unix/syscall_netbsd.go +++ b/vendor/golang.org/x/sys/unix/syscall_netbsd.go @@ -233,13 +233,16 @@ func Uname(uname *Utsname) error { //sys Dup(fd int) (nfd int, err error) //sys Dup2(from int, to int) (err error) //sys Exit(code int) +//sys Fadvise(fd int, offset int64, length int64, advice int) (err error) = SYS_POSIX_FADVISE //sys Fchdir(fd int) (err error) //sys Fchflags(fd int, flags int) (err error) //sys Fchmod(fd int, mode uint32) (err error) +//sys Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) //sys Fchown(fd int, uid int, gid int) (err error) //sys Flock(fd int, how int) (err error) //sys Fpathconf(fd int, name int) (val int, err error) //sys Fstat(fd int, stat *Stat_t) (err error) +//sys Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) //sys Fsync(fd int) (err error) //sys Ftruncate(fd int, length int64) (err error) //sysnb Getegid() (egid int) @@ -320,7 +323,6 @@ func Uname(uname *Utsname) error { // __msync13 // __ntp_gettime30 // __posix_chown -// __posix_fadvise50 // __posix_fchown // __posix_lchown // __posix_rename diff --git a/vendor/golang.org/x/sys/unix/syscall_openbsd.go b/vendor/golang.org/x/sys/unix/syscall_openbsd.go index 37556e775df..614fcf04945 100644 --- a/vendor/golang.org/x/sys/unix/syscall_openbsd.go +++ b/vendor/golang.org/x/sys/unix/syscall_openbsd.go @@ -204,10 +204,12 @@ func Uname(uname *Utsname) error { //sys Fchdir(fd int) (err error) //sys Fchflags(fd int, flags int) (err error) //sys Fchmod(fd int, mode uint32) (err error) +//sys Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) //sys Fchown(fd int, uid int, gid int) (err error) //sys Flock(fd int, how int) (err error) //sys Fpathconf(fd int, name int) (val int, err error) //sys Fstat(fd int, stat *Stat_t) (err error) +//sys Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) //sys Fstatfs(fd int, stat *Statfs_t) (err error) //sys Fsync(fd int) (err error) //sys Ftruncate(fd int, length int64) (err error) @@ -220,6 +222,7 @@ func Uname(uname *Utsname) error { //sysnb Getppid() (ppid int) //sys Getpriority(which int, who int) (prio int, err error) //sysnb Getrlimit(which int, lim *Rlimit) (err error) +//sysnb Getrtable() (rtable int, err error) //sysnb Getrusage(who int, rusage *Rusage) (err error) //sysnb Getsid(pid int) (sid int, err error) //sysnb Gettimeofday(tv *Timeval) (err error) @@ -257,6 +260,7 @@ func Uname(uname *Utsname) error { //sysnb Setresgid(rgid int, egid int, sgid int) (err error) //sysnb Setresuid(ruid int, euid int, suid int) (err error) //sysnb Setrlimit(which int, lim *Rlimit) (err error) +//sysnb Setrtable(rtable int) (err error) //sysnb Setsid() (pid int, err error) //sysnb Settimeofday(tp *Timeval) (err error) //sysnb Setuid(uid int) (err error) @@ -305,7 +309,6 @@ func Uname(uname *Utsname) error { // getlogin // getresgid // getresuid -// getrtable // getthrid // ktrace // lfs_bmapv @@ -341,7 +344,6 @@ func Uname(uname *Utsname) error { // semop // setgroups // setitimer -// setrtable // setsockopt // shmat // shmctl diff --git a/vendor/golang.org/x/sys/unix/syscall_openbsd_amd64.go b/vendor/golang.org/x/sys/unix/syscall_openbsd_amd64.go index 649e67fccc5..9a35334cba4 100644 --- a/vendor/golang.org/x/sys/unix/syscall_openbsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/syscall_openbsd_amd64.go @@ -31,3 +31,7 @@ func (msghdr *Msghdr) SetControllen(length int) { func (cmsg *Cmsghdr) SetLen(length int) { cmsg.Len = uint32(length) } + +// SYS___SYSCTL is used by syscall_bsd.go for all BSDs, but in modern versions +// of openbsd/amd64 the syscall is called sysctl instead of __sysctl. +const SYS___SYSCTL = SYS_SYSCTL diff --git a/vendor/golang.org/x/sys/unix/syscall_solaris.go b/vendor/golang.org/x/sys/unix/syscall_solaris.go index eca8d1d09dc..b7629529b38 100644 --- a/vendor/golang.org/x/sys/unix/syscall_solaris.go +++ b/vendor/golang.org/x/sys/unix/syscall_solaris.go @@ -312,6 +312,12 @@ func UtimesNanoAt(dirfd int, path string, ts []Timespec, flags int) error { //sys fcntl(fd int, cmd int, arg int) (val int, err error) +// FcntlInt performs a fcntl syscall on fd with the provided command and argument. +func FcntlInt(fd uintptr, cmd, arg int) (int, error) { + valptr, _, err := sysvicall6(uintptr(unsafe.Pointer(&procfcntl)), 3, uintptr(fd), uintptr(cmd), uintptr(arg), 0, 0, 0) + return int(valptr), err +} + // FcntlFlock performs a fcntl syscall for the F_GETLK, F_SETLK or F_SETLKW command. func FcntlFlock(fd uintptr, cmd int, lk *Flock_t) error { _, _, e1 := sysvicall6(uintptr(unsafe.Pointer(&procfcntl)), 3, uintptr(fd), uintptr(cmd), uintptr(unsafe.Pointer(lk)), 0, 0, 0) @@ -595,9 +601,10 @@ func Poll(fds []PollFd, timeout int) (n int, err error) { //sys Fchown(fd int, uid int, gid int) (err error) //sys Fchownat(dirfd int, path string, uid int, gid int, flags int) (err error) //sys Fdatasync(fd int) (err error) -//sys Flock(fd int, how int) (err error) +//sys Flock(fd int, how int) (err error) //sys Fpathconf(fd int, name int) (val int, err error) //sys Fstat(fd int, stat *Stat_t) (err error) +//sys Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) //sys Fstatvfs(fd int, vfsstat *Statvfs_t) (err error) //sys Getdents(fd int, buf []byte, basep *uintptr) (n int, err error) //sysnb Getgid() (gid int) @@ -675,6 +682,7 @@ func Poll(fds []PollFd, timeout int) (n int, err error) { //sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error) = libsocket.__xnet_connect //sys mmap(addr uintptr, length uintptr, prot int, flag int, fd int, pos int64) (ret uintptr, err error) //sys munmap(addr uintptr, length uintptr) (err error) +//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) = libsendfile.sendfile //sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error) = libsocket.__xnet_sendto //sys socket(domain int, typ int, proto int) (fd int, err error) = libsocket.__xnet_socket //sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error) = libsocket.__xnet_socketpair diff --git a/vendor/golang.org/x/sys/unix/syscall_solaris_amd64.go b/vendor/golang.org/x/sys/unix/syscall_solaris_amd64.go index 9d4e7a678f6..91c32ddf02a 100644 --- a/vendor/golang.org/x/sys/unix/syscall_solaris_amd64.go +++ b/vendor/golang.org/x/sys/unix/syscall_solaris_amd64.go @@ -21,8 +21,3 @@ func (iov *Iovec) SetLen(length int) { func (cmsg *Cmsghdr) SetLen(length int) { cmsg.Len = uint32(length) } - -func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) { - // TODO(aram): implement this, see issue 5847. - panic("unimplemented") -} diff --git a/vendor/golang.org/x/sys/unix/syscall_unix.go b/vendor/golang.org/x/sys/unix/syscall_unix.go index cd8f3a9c286..b835bad0fe4 100644 --- a/vendor/golang.org/x/sys/unix/syscall_unix.go +++ b/vendor/golang.org/x/sys/unix/syscall_unix.go @@ -7,7 +7,9 @@ package unix import ( + "bytes" "runtime" + "sort" "sync" "syscall" "unsafe" @@ -50,14 +52,35 @@ func errnoErr(e syscall.Errno) error { return e } +// ErrnoName returns the error name for error number e. +func ErrnoName(e syscall.Errno) string { + i := sort.Search(len(errorList), func(i int) bool { + return errorList[i].num >= e + }) + if i < len(errorList) && errorList[i].num == e { + return errorList[i].name + } + return "" +} + +// SignalName returns the signal name for signal number s. +func SignalName(s syscall.Signal) string { + i := sort.Search(len(signalList), func(i int) bool { + return signalList[i].num >= s + }) + if i < len(signalList) && signalList[i].num == s { + return signalList[i].name + } + return "" +} + // clen returns the index of the first NULL byte in n or len(n) if n contains no NULL byte. func clen(n []byte) int { - for i := 0; i < len(n); i++ { - if n[i] == 0 { - return i - } + i := bytes.IndexByte(n, 0) + if i == -1 { + i = len(n) } - return len(n) + return i } // Mmap manager, for use by operating system-specific implementations. @@ -199,6 +222,13 @@ func Getpeername(fd int) (sa Sockaddr, err error) { return anyToSockaddr(&rsa) } +func GetsockoptByte(fd, level, opt int) (value byte, err error) { + var n byte + vallen := _Socklen(1) + err = getsockopt(fd, level, opt, unsafe.Pointer(&n), &vallen) + return n, err +} + func GetsockoptInt(fd, level, opt int) (value int, err error) { var n int32 vallen := _Socklen(4) @@ -206,6 +236,54 @@ func GetsockoptInt(fd, level, opt int) (value int, err error) { return int(n), err } +func GetsockoptInet4Addr(fd, level, opt int) (value [4]byte, err error) { + vallen := _Socklen(4) + err = getsockopt(fd, level, opt, unsafe.Pointer(&value[0]), &vallen) + return value, err +} + +func GetsockoptIPMreq(fd, level, opt int) (*IPMreq, error) { + var value IPMreq + vallen := _Socklen(SizeofIPMreq) + err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) + return &value, err +} + +func GetsockoptIPv6Mreq(fd, level, opt int) (*IPv6Mreq, error) { + var value IPv6Mreq + vallen := _Socklen(SizeofIPv6Mreq) + err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) + return &value, err +} + +func GetsockoptIPv6MTUInfo(fd, level, opt int) (*IPv6MTUInfo, error) { + var value IPv6MTUInfo + vallen := _Socklen(SizeofIPv6MTUInfo) + err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) + return &value, err +} + +func GetsockoptICMPv6Filter(fd, level, opt int) (*ICMPv6Filter, error) { + var value ICMPv6Filter + vallen := _Socklen(SizeofICMPv6Filter) + err := getsockopt(fd, level, opt, unsafe.Pointer(&value), &vallen) + return &value, err +} + +func GetsockoptLinger(fd, level, opt int) (*Linger, error) { + var linger Linger + vallen := _Socklen(SizeofLinger) + err := getsockopt(fd, level, opt, unsafe.Pointer(&linger), &vallen) + return &linger, err +} + +func GetsockoptTimeval(fd, level, opt int) (*Timeval, error) { + var tv Timeval + vallen := _Socklen(unsafe.Sizeof(tv)) + err := getsockopt(fd, level, opt, unsafe.Pointer(&tv), &vallen) + return &tv, err +} + func Recvfrom(fd int, p []byte, flags int) (n int, from Sockaddr, err error) { var rsa RawSockaddrAny var len _Socklen = SizeofSockaddrAny @@ -305,3 +383,12 @@ func SetNonblock(fd int, nonblocking bool) (err error) { _, err = fcntl(fd, F_SETFL, flag) return err } + +// Exec calls execve(2), which replaces the calling executable in the process +// tree. argv0 should be the full path to an executable ("/bin/ls") and the +// executable name should also be the first argument in argv (["ls", "-l"]). +// envv are the environment variables that should be passed to the new +// process (["USER=go", "PWD=/tmp"]). +func Exec(argv0 string, argv []string, envv []string) error { + return syscall.Exec(argv0, argv, envv) +} diff --git a/vendor/golang.org/x/sys/unix/types_netbsd.go b/vendor/golang.org/x/sys/unix/types_netbsd.go index 10aa9b3a4f3..1494aafcbb5 100644 --- a/vendor/golang.org/x/sys/unix/types_netbsd.go +++ b/vendor/golang.org/x/sys/unix/types_netbsd.go @@ -118,6 +118,17 @@ const ( PathMax = C.PATH_MAX ) +// Advice to Fadvise + +const ( + FADV_NORMAL = C.POSIX_FADV_NORMAL + FADV_RANDOM = C.POSIX_FADV_RANDOM + FADV_SEQUENTIAL = C.POSIX_FADV_SEQUENTIAL + FADV_WILLNEED = C.POSIX_FADV_WILLNEED + FADV_DONTNEED = C.POSIX_FADV_DONTNEED + FADV_NOREUSE = C.POSIX_FADV_NOREUSE +) + // Sockets type RawSockaddrInet4 C.struct_sockaddr_in diff --git a/vendor/golang.org/x/sys/unix/zerrors_darwin_386.go b/vendor/golang.org/x/sys/unix/zerrors_darwin_386.go index dcba88424b1..3b39d7408ad 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_darwin_386.go +++ b/vendor/golang.org/x/sys/unix/zerrors_darwin_386.go @@ -1473,6 +1473,12 @@ const ( WORDSIZE = 0x20 WSTOPPED = 0x8 WUNTRACED = 0x2 + XATTR_CREATE = 0x2 + XATTR_NODEFAULT = 0x10 + XATTR_NOFOLLOW = 0x1 + XATTR_NOSECURITY = 0x8 + XATTR_REPLACE = 0x4 + XATTR_SHOWCOMPRESSION = 0x20 ) // Errors @@ -1624,146 +1630,154 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "resource busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "operation timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "device power is off", - 83: "device error", - 84: "value too large to be stored in data type", - 85: "bad executable (or shared library)", - 86: "bad CPU type in executable", - 87: "shared library version mismatch", - 88: "malformed Mach-o file", - 89: "operation canceled", - 90: "identifier removed", - 91: "no message of desired type", - 92: "illegal byte sequence", - 93: "attribute not found", - 94: "bad message", - 95: "EMULTIHOP (Reserved)", - 96: "no message available on STREAM", - 97: "ENOLINK (Reserved)", - 98: "no STREAM resources", - 99: "not a STREAM", - 100: "protocol error", - 101: "STREAM ioctl timeout", - 102: "operation not supported on socket", - 103: "policy not found", - 104: "state not recoverable", - 105: "previous owner died", - 106: "interface output queue is full", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "ENOTSUP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EPWROFF", "device power is off"}, + {83, "EDEVERR", "device error"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "EBADEXEC", "bad executable (or shared library)"}, + {86, "EBADARCH", "bad CPU type in executable"}, + {87, "ESHLIBVERS", "shared library version mismatch"}, + {88, "EBADMACHO", "malformed Mach-o file"}, + {89, "ECANCELED", "operation canceled"}, + {90, "EIDRM", "identifier removed"}, + {91, "ENOMSG", "no message of desired type"}, + {92, "EILSEQ", "illegal byte sequence"}, + {93, "ENOATTR", "attribute not found"}, + {94, "EBADMSG", "bad message"}, + {95, "EMULTIHOP", "EMULTIHOP (Reserved)"}, + {96, "ENODATA", "no message available on STREAM"}, + {97, "ENOLINK", "ENOLINK (Reserved)"}, + {98, "ENOSR", "no STREAM resources"}, + {99, "ENOSTR", "not a STREAM"}, + {100, "EPROTO", "protocol error"}, + {101, "ETIME", "STREAM ioctl timeout"}, + {102, "EOPNOTSUPP", "operation not supported on socket"}, + {103, "ENOPOLICY", "policy not found"}, + {104, "ENOTRECOVERABLE", "state not recoverable"}, + {105, "EOWNERDEAD", "previous owner died"}, + {106, "EQFULL", "interface output queue is full"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "suspended (signal)", - 18: "suspended", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGABRT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_darwin_amd64.go b/vendor/golang.org/x/sys/unix/zerrors_darwin_amd64.go index 1a51c963c89..8fe5547775b 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_darwin_amd64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_darwin_amd64.go @@ -1473,6 +1473,12 @@ const ( WORDSIZE = 0x40 WSTOPPED = 0x8 WUNTRACED = 0x2 + XATTR_CREATE = 0x2 + XATTR_NODEFAULT = 0x10 + XATTR_NOFOLLOW = 0x1 + XATTR_NOSECURITY = 0x8 + XATTR_REPLACE = 0x4 + XATTR_SHOWCOMPRESSION = 0x20 ) // Errors @@ -1624,146 +1630,154 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "resource busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "operation timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "device power is off", - 83: "device error", - 84: "value too large to be stored in data type", - 85: "bad executable (or shared library)", - 86: "bad CPU type in executable", - 87: "shared library version mismatch", - 88: "malformed Mach-o file", - 89: "operation canceled", - 90: "identifier removed", - 91: "no message of desired type", - 92: "illegal byte sequence", - 93: "attribute not found", - 94: "bad message", - 95: "EMULTIHOP (Reserved)", - 96: "no message available on STREAM", - 97: "ENOLINK (Reserved)", - 98: "no STREAM resources", - 99: "not a STREAM", - 100: "protocol error", - 101: "STREAM ioctl timeout", - 102: "operation not supported on socket", - 103: "policy not found", - 104: "state not recoverable", - 105: "previous owner died", - 106: "interface output queue is full", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "ENOTSUP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EPWROFF", "device power is off"}, + {83, "EDEVERR", "device error"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "EBADEXEC", "bad executable (or shared library)"}, + {86, "EBADARCH", "bad CPU type in executable"}, + {87, "ESHLIBVERS", "shared library version mismatch"}, + {88, "EBADMACHO", "malformed Mach-o file"}, + {89, "ECANCELED", "operation canceled"}, + {90, "EIDRM", "identifier removed"}, + {91, "ENOMSG", "no message of desired type"}, + {92, "EILSEQ", "illegal byte sequence"}, + {93, "ENOATTR", "attribute not found"}, + {94, "EBADMSG", "bad message"}, + {95, "EMULTIHOP", "EMULTIHOP (Reserved)"}, + {96, "ENODATA", "no message available on STREAM"}, + {97, "ENOLINK", "ENOLINK (Reserved)"}, + {98, "ENOSR", "no STREAM resources"}, + {99, "ENOSTR", "not a STREAM"}, + {100, "EPROTO", "protocol error"}, + {101, "ETIME", "STREAM ioctl timeout"}, + {102, "EOPNOTSUPP", "operation not supported on socket"}, + {103, "ENOPOLICY", "policy not found"}, + {104, "ENOTRECOVERABLE", "state not recoverable"}, + {105, "EOWNERDEAD", "previous owner died"}, + {106, "EQFULL", "interface output queue is full"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "suspended (signal)", - 18: "suspended", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGABRT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_darwin_arm.go b/vendor/golang.org/x/sys/unix/zerrors_darwin_arm.go index fa135b17c15..7a977770d0a 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_darwin_arm.go +++ b/vendor/golang.org/x/sys/unix/zerrors_darwin_arm.go @@ -1473,6 +1473,12 @@ const ( WORDSIZE = 0x40 WSTOPPED = 0x8 WUNTRACED = 0x2 + XATTR_CREATE = 0x2 + XATTR_NODEFAULT = 0x10 + XATTR_NOFOLLOW = 0x1 + XATTR_NOSECURITY = 0x8 + XATTR_REPLACE = 0x4 + XATTR_SHOWCOMPRESSION = 0x20 ) // Errors @@ -1624,146 +1630,154 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "resource busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "operation timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "device power is off", - 83: "device error", - 84: "value too large to be stored in data type", - 85: "bad executable (or shared library)", - 86: "bad CPU type in executable", - 87: "shared library version mismatch", - 88: "malformed Mach-o file", - 89: "operation canceled", - 90: "identifier removed", - 91: "no message of desired type", - 92: "illegal byte sequence", - 93: "attribute not found", - 94: "bad message", - 95: "EMULTIHOP (Reserved)", - 96: "no message available on STREAM", - 97: "ENOLINK (Reserved)", - 98: "no STREAM resources", - 99: "not a STREAM", - 100: "protocol error", - 101: "STREAM ioctl timeout", - 102: "operation not supported on socket", - 103: "policy not found", - 104: "state not recoverable", - 105: "previous owner died", - 106: "interface output queue is full", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "ENOTSUP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EPWROFF", "device power is off"}, + {83, "EDEVERR", "device error"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "EBADEXEC", "bad executable (or shared library)"}, + {86, "EBADARCH", "bad CPU type in executable"}, + {87, "ESHLIBVERS", "shared library version mismatch"}, + {88, "EBADMACHO", "malformed Mach-o file"}, + {89, "ECANCELED", "operation canceled"}, + {90, "EIDRM", "identifier removed"}, + {91, "ENOMSG", "no message of desired type"}, + {92, "EILSEQ", "illegal byte sequence"}, + {93, "ENOATTR", "attribute not found"}, + {94, "EBADMSG", "bad message"}, + {95, "EMULTIHOP", "EMULTIHOP (Reserved)"}, + {96, "ENODATA", "no message available on STREAM"}, + {97, "ENOLINK", "ENOLINK (Reserved)"}, + {98, "ENOSR", "no STREAM resources"}, + {99, "ENOSTR", "not a STREAM"}, + {100, "EPROTO", "protocol error"}, + {101, "ETIME", "STREAM ioctl timeout"}, + {102, "EOPNOTSUPP", "operation not supported on socket"}, + {103, "ENOPOLICY", "policy not found"}, + {104, "ENOTRECOVERABLE", "state not recoverable"}, + {105, "EOWNERDEAD", "previous owner died"}, + {106, "EQFULL", "interface output queue is full"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "suspended (signal)", - 18: "suspended", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGABRT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_darwin_arm64.go b/vendor/golang.org/x/sys/unix/zerrors_darwin_arm64.go index 6419c65e13b..6d56d8a059d 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_darwin_arm64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_darwin_arm64.go @@ -1473,6 +1473,12 @@ const ( WORDSIZE = 0x40 WSTOPPED = 0x8 WUNTRACED = 0x2 + XATTR_CREATE = 0x2 + XATTR_NODEFAULT = 0x10 + XATTR_NOFOLLOW = 0x1 + XATTR_NOSECURITY = 0x8 + XATTR_REPLACE = 0x4 + XATTR_SHOWCOMPRESSION = 0x20 ) // Errors @@ -1624,146 +1630,154 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "resource busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "operation timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "device power is off", - 83: "device error", - 84: "value too large to be stored in data type", - 85: "bad executable (or shared library)", - 86: "bad CPU type in executable", - 87: "shared library version mismatch", - 88: "malformed Mach-o file", - 89: "operation canceled", - 90: "identifier removed", - 91: "no message of desired type", - 92: "illegal byte sequence", - 93: "attribute not found", - 94: "bad message", - 95: "EMULTIHOP (Reserved)", - 96: "no message available on STREAM", - 97: "ENOLINK (Reserved)", - 98: "no STREAM resources", - 99: "not a STREAM", - 100: "protocol error", - 101: "STREAM ioctl timeout", - 102: "operation not supported on socket", - 103: "policy not found", - 104: "state not recoverable", - 105: "previous owner died", - 106: "interface output queue is full", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "ENOTSUP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EPWROFF", "device power is off"}, + {83, "EDEVERR", "device error"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "EBADEXEC", "bad executable (or shared library)"}, + {86, "EBADARCH", "bad CPU type in executable"}, + {87, "ESHLIBVERS", "shared library version mismatch"}, + {88, "EBADMACHO", "malformed Mach-o file"}, + {89, "ECANCELED", "operation canceled"}, + {90, "EIDRM", "identifier removed"}, + {91, "ENOMSG", "no message of desired type"}, + {92, "EILSEQ", "illegal byte sequence"}, + {93, "ENOATTR", "attribute not found"}, + {94, "EBADMSG", "bad message"}, + {95, "EMULTIHOP", "EMULTIHOP (Reserved)"}, + {96, "ENODATA", "no message available on STREAM"}, + {97, "ENOLINK", "ENOLINK (Reserved)"}, + {98, "ENOSR", "no STREAM resources"}, + {99, "ENOSTR", "not a STREAM"}, + {100, "EPROTO", "protocol error"}, + {101, "ETIME", "STREAM ioctl timeout"}, + {102, "EOPNOTSUPP", "operation not supported on socket"}, + {103, "ENOPOLICY", "policy not found"}, + {104, "ENOTRECOVERABLE", "state not recoverable"}, + {105, "EOWNERDEAD", "previous owner died"}, + {106, "EQFULL", "interface output queue is full"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "suspended (signal)", - 18: "suspended", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGABRT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_dragonfly_amd64.go b/vendor/golang.org/x/sys/unix/zerrors_dragonfly_amd64.go index d96015505fb..46a082b6d59 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_dragonfly_amd64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_dragonfly_amd64.go @@ -980,7 +980,10 @@ const ( RLIMIT_CPU = 0x0 RLIMIT_DATA = 0x2 RLIMIT_FSIZE = 0x1 + RLIMIT_MEMLOCK = 0x6 RLIMIT_NOFILE = 0x8 + RLIMIT_NPROC = 0x7 + RLIMIT_RSS = 0x5 RLIMIT_STACK = 0x3 RLIM_INFINITY = 0x7fffffffffffffff RTAX_AUTHOR = 0x6 @@ -1434,142 +1437,150 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "operation timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "identifier removed", - 83: "no message of desired type", - 84: "value too large to be stored in data type", - 85: "operation canceled", - 86: "illegal byte sequence", - 87: "attribute not found", - 88: "programming error", - 89: "bad message", - 90: "multihop attempted", - 91: "link has been severed", - 92: "protocol error", - 93: "no medium found", - 94: "unknown error: 94", - 95: "unknown error: 95", - 96: "unknown error: 96", - 97: "unknown error: 97", - 98: "unknown error: 98", - 99: "unknown error: 99", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EWOULDBLOCK", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIDRM", "identifier removed"}, + {83, "ENOMSG", "no message of desired type"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "ECANCELED", "operation canceled"}, + {86, "EILSEQ", "illegal byte sequence"}, + {87, "ENOATTR", "attribute not found"}, + {88, "EDOOFUS", "programming error"}, + {89, "EBADMSG", "bad message"}, + {90, "EMULTIHOP", "multihop attempted"}, + {91, "ENOLINK", "link has been severed"}, + {92, "EPROTO", "protocol error"}, + {93, "ENOMEDIUM", "no medium found"}, + {94, "EUNUSED94", "unknown error: 94"}, + {95, "EUNUSED95", "unknown error: 95"}, + {96, "EUNUSED96", "unknown error: 96"}, + {97, "EUNUSED97", "unknown error: 97"}, + {98, "EUNUSED98", "unknown error: 98"}, + {99, "ELAST", "unknown error: 99"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "suspended (signal)", - 18: "suspended", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "thread Scheduler", - 33: "checkPoint", - 34: "checkPointExit", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGIOT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGTHR", "thread Scheduler"}, + {33, "SIGCKPT", "checkPoint"}, + {34, "SIGCKPTEXIT", "checkPointExit"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_freebsd_386.go b/vendor/golang.org/x/sys/unix/zerrors_freebsd_386.go index a8b05878e38..2947dc0382e 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_freebsd_386.go +++ b/vendor/golang.org/x/sys/unix/zerrors_freebsd_386.go @@ -1619,138 +1619,146 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "operation timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "identifier removed", - 83: "no message of desired type", - 84: "value too large to be stored in data type", - 85: "operation canceled", - 86: "illegal byte sequence", - 87: "attribute not found", - 88: "programming error", - 89: "bad message", - 90: "multihop attempted", - 91: "link has been severed", - 92: "protocol error", - 93: "capabilities insufficient", - 94: "not permitted in capability mode", - 95: "state not recoverable", - 96: "previous owner died", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIDRM", "identifier removed"}, + {83, "ENOMSG", "no message of desired type"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "ECANCELED", "operation canceled"}, + {86, "EILSEQ", "illegal byte sequence"}, + {87, "ENOATTR", "attribute not found"}, + {88, "EDOOFUS", "programming error"}, + {89, "EBADMSG", "bad message"}, + {90, "EMULTIHOP", "multihop attempted"}, + {91, "ENOLINK", "link has been severed"}, + {92, "EPROTO", "protocol error"}, + {93, "ENOTCAPABLE", "capabilities insufficient"}, + {94, "ECAPMODE", "not permitted in capability mode"}, + {95, "ENOTRECOVERABLE", "state not recoverable"}, + {96, "EOWNERDEAD", "previous owner died"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "suspended (signal)", - 18: "suspended", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "unknown signal", - 33: "unknown signal", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGIOT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGTHR", "unknown signal"}, + {33, "SIGLIBRT", "unknown signal"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_freebsd_amd64.go b/vendor/golang.org/x/sys/unix/zerrors_freebsd_amd64.go index cf5f01260e5..c600d012d06 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_freebsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_freebsd_amd64.go @@ -1620,138 +1620,146 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "operation timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "identifier removed", - 83: "no message of desired type", - 84: "value too large to be stored in data type", - 85: "operation canceled", - 86: "illegal byte sequence", - 87: "attribute not found", - 88: "programming error", - 89: "bad message", - 90: "multihop attempted", - 91: "link has been severed", - 92: "protocol error", - 93: "capabilities insufficient", - 94: "not permitted in capability mode", - 95: "state not recoverable", - 96: "previous owner died", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIDRM", "identifier removed"}, + {83, "ENOMSG", "no message of desired type"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "ECANCELED", "operation canceled"}, + {86, "EILSEQ", "illegal byte sequence"}, + {87, "ENOATTR", "attribute not found"}, + {88, "EDOOFUS", "programming error"}, + {89, "EBADMSG", "bad message"}, + {90, "EMULTIHOP", "multihop attempted"}, + {91, "ENOLINK", "link has been severed"}, + {92, "EPROTO", "protocol error"}, + {93, "ENOTCAPABLE", "capabilities insufficient"}, + {94, "ECAPMODE", "not permitted in capability mode"}, + {95, "ENOTRECOVERABLE", "state not recoverable"}, + {96, "EOWNERDEAD", "previous owner died"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "suspended (signal)", - 18: "suspended", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "unknown signal", - 33: "unknown signal", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGIOT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGTHR", "unknown signal"}, + {33, "SIGLIBRT", "unknown signal"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_freebsd_arm.go b/vendor/golang.org/x/sys/unix/zerrors_freebsd_arm.go index 9bbb90ad8a0..e8240d2397b 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_freebsd_arm.go +++ b/vendor/golang.org/x/sys/unix/zerrors_freebsd_arm.go @@ -1628,138 +1628,146 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "operation timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "identifier removed", - 83: "no message of desired type", - 84: "value too large to be stored in data type", - 85: "operation canceled", - 86: "illegal byte sequence", - 87: "attribute not found", - 88: "programming error", - 89: "bad message", - 90: "multihop attempted", - 91: "link has been severed", - 92: "protocol error", - 93: "capabilities insufficient", - 94: "not permitted in capability mode", - 95: "state not recoverable", - 96: "previous owner died", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIDRM", "identifier removed"}, + {83, "ENOMSG", "no message of desired type"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "ECANCELED", "operation canceled"}, + {86, "EILSEQ", "illegal byte sequence"}, + {87, "ENOATTR", "attribute not found"}, + {88, "EDOOFUS", "programming error"}, + {89, "EBADMSG", "bad message"}, + {90, "EMULTIHOP", "multihop attempted"}, + {91, "ENOLINK", "link has been severed"}, + {92, "EPROTO", "protocol error"}, + {93, "ENOTCAPABLE", "capabilities insufficient"}, + {94, "ECAPMODE", "not permitted in capability mode"}, + {95, "ENOTRECOVERABLE", "state not recoverable"}, + {96, "EOWNERDEAD", "previous owner died"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "suspended (signal)", - 18: "suspended", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "unknown signal", - 33: "unknown signal", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGIOT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGTHR", "unknown signal"}, + {33, "SIGLIBRT", "unknown signal"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_386.go b/vendor/golang.org/x/sys/unix/zerrors_linux_386.go index fa063740894..ee17d4bd4a5 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_386.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_386.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x1008 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x1007 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x80041270 BLKBSZSET = 0x40041271 BLKFLSBUF = 0x1261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x2000 BSDLY = 0x2000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0x100f CBAUDEX = 0x1000 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0x100f0000 CLOCAL = 0x800 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x200 CR2 = 0x400 CR3 = 0x600 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x600 CREAD = 0x80 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x40 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x800 ECHONL = 0x40 ECHOPRT = 0x400 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x800 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -461,6 +490,7 @@ const ( FF1 = 0x8000 FFDLY = 0x8000 FLUSHO = 0x1000 + FP_XSTATE_MAGIC2 = 0x46505845 FS_ENCRYPTION_MODE_AES_128_CBC = 0x5 FS_ENCRYPTION_MODE_AES_128_CTS = 0x6 FS_ENCRYPTION_MODE_AES_256_CBC = 0x3 @@ -481,6 +511,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +573,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x400 IBSHIFT = 0x10 ICANON = 0x2 @@ -792,12 +866,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x1 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x200 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x1000 IXON = 0x400 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -894,9 +970,15 @@ const ( MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MCL_ONFAULT = 0x4 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -956,7 +1038,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -991,6 +1075,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NLA_ALIGNTO = 0x4 @@ -1023,6 +1138,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1030,7 +1147,9 @@ const ( ONLCR = 0x4 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x400 O_ASYNC = 0x2000 @@ -1117,14 +1236,17 @@ const ( PERF_EVENT_IOC_ID = 0x80042407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x40042409 PERF_EVENT_IOC_PERIOD = 0x40082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc004240a PERF_EVENT_IOC_REFRESH = 0x2402 PERF_EVENT_IOC_RESET = 0x2403 PERF_EVENT_IOC_SET_BPF = 0x40042408 PERF_EVENT_IOC_SET_FILTER = 0x40042406 PERF_EVENT_IOC_SET_OUTPUT = 0x2405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1230,6 +1352,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1273,6 +1396,7 @@ const ( PTRACE_POKETEXT = 0x4 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETFPREGS = 0xf PTRACE_SETFPXREGS = 0x13 @@ -1288,6 +1412,11 @@ const ( PTRACE_SYSEMU = 0x1f PTRACE_SYSEMU_SINGLESTEP = 0x20 PTRACE_TRACEME = 0x0 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x9 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1473,6 +1602,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1557,6 +1688,23 @@ const ( SIOCSPGRP = 0x8902 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x2 @@ -1667,6 +1815,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1688,6 +1838,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1869,7 +2020,27 @@ const ( TIOCSTI = 0x5412 TIOCSWINSZ = 0x5414 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x100 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x400854d5 TUNDETACHFILTER = 0x400854d6 @@ -1881,6 +2052,7 @@ const ( TUNGETVNETHDRSZ = 0x800454d7 TUNGETVNETLE = 0x800454dd TUNSETDEBUG = 0x400454c9 + TUNSETFILTEREBPF = 0x800454e1 TUNSETGROUP = 0x400454ce TUNSETIFF = 0x400454ca TUNSETIFINDEX = 0x400454da @@ -1891,13 +2063,17 @@ const ( TUNSETPERSIST = 0x400454cb TUNSETQUEUE = 0x400454d9 TUNSETSNDBUF = 0x400454d4 + TUNSETSTEERINGEBPF = 0x800454e0 TUNSETTXFILTER = 0x400454d1 TUNSETVNETBE = 0x400454de TUNSETVNETHDRSZ = 0x400454d8 TUNSETVNETLE = 0x400454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0xd VEOF = 0x4 VEOL = 0xb @@ -1939,16 +2115,99 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 WORDSIZE = 0x20 WSTOPPED = 0x2 WUNTRACED = 0x2 + X86_FXSR_MAGIC = 0x0 XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0x1800 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2128,171 +2387,179 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "resource deadlock avoided", - 36: "file name too long", - 37: "no locks available", - 38: "function not implemented", - 39: "directory not empty", - 40: "too many levels of symbolic links", - 42: "no message of desired type", - 43: "identifier removed", - 44: "channel number out of range", - 45: "level 2 not synchronized", - 46: "level 3 halted", - 47: "level 3 reset", - 48: "link number out of range", - 49: "protocol driver not attached", - 50: "no CSI structure available", - 51: "level 2 halted", - 52: "invalid exchange", - 53: "invalid request descriptor", - 54: "exchange full", - 55: "no anode", - 56: "invalid request code", - 57: "invalid slot", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 72: "multihop attempted", - 73: "RFS specific error", - 74: "bad message", - 75: "value too large for defined data type", - 76: "name not unique on network", - 77: "file descriptor in bad state", - 78: "remote address changed", - 79: "can not access a needed shared library", - 80: "accessing a corrupted shared library", - 81: ".lib section in a.out corrupted", - 82: "attempting to link in too many shared libraries", - 83: "cannot exec a shared library directly", - 84: "invalid or incomplete multibyte or wide character", - 85: "interrupted system call should be restarted", - 86: "streams pipe error", - 87: "too many users", - 88: "socket operation on non-socket", - 89: "destination address required", - 90: "message too long", - 91: "protocol wrong type for socket", - 92: "protocol not available", - 93: "protocol not supported", - 94: "socket type not supported", - 95: "operation not supported", - 96: "protocol family not supported", - 97: "address family not supported by protocol", - 98: "address already in use", - 99: "cannot assign requested address", - 100: "network is down", - 101: "network is unreachable", - 102: "network dropped connection on reset", - 103: "software caused connection abort", - 104: "connection reset by peer", - 105: "no buffer space available", - 106: "transport endpoint is already connected", - 107: "transport endpoint is not connected", - 108: "cannot send after transport endpoint shutdown", - 109: "too many references: cannot splice", - 110: "connection timed out", - 111: "connection refused", - 112: "host is down", - 113: "no route to host", - 114: "operation already in progress", - 115: "operation now in progress", - 116: "stale file handle", - 117: "structure needs cleaning", - 118: "not a XENIX named type file", - 119: "no XENIX semaphores available", - 120: "is a named type file", - 121: "remote I/O error", - 122: "disk quota exceeded", - 123: "no medium found", - 124: "wrong medium type", - 125: "operation canceled", - 126: "required key not available", - 127: "key has expired", - 128: "key has been revoked", - 129: "key was rejected by service", - 130: "owner died", - 131: "state not recoverable", - 132: "operation not possible due to RF-kill", - 133: "memory page has hardware error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "EDEADLK", "resource deadlock avoided"}, + {36, "ENAMETOOLONG", "file name too long"}, + {37, "ENOLCK", "no locks available"}, + {38, "ENOSYS", "function not implemented"}, + {39, "ENOTEMPTY", "directory not empty"}, + {40, "ELOOP", "too many levels of symbolic links"}, + {42, "ENOMSG", "no message of desired type"}, + {43, "EIDRM", "identifier removed"}, + {44, "ECHRNG", "channel number out of range"}, + {45, "EL2NSYNC", "level 2 not synchronized"}, + {46, "EL3HLT", "level 3 halted"}, + {47, "EL3RST", "level 3 reset"}, + {48, "ELNRNG", "link number out of range"}, + {49, "EUNATCH", "protocol driver not attached"}, + {50, "ENOCSI", "no CSI structure available"}, + {51, "EL2HLT", "level 2 halted"}, + {52, "EBADE", "invalid exchange"}, + {53, "EBADR", "invalid request descriptor"}, + {54, "EXFULL", "exchange full"}, + {55, "ENOANO", "no anode"}, + {56, "EBADRQC", "invalid request code"}, + {57, "EBADSLT", "invalid slot"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {72, "EMULTIHOP", "multihop attempted"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EBADMSG", "bad message"}, + {75, "EOVERFLOW", "value too large for defined data type"}, + {76, "ENOTUNIQ", "name not unique on network"}, + {77, "EBADFD", "file descriptor in bad state"}, + {78, "EREMCHG", "remote address changed"}, + {79, "ELIBACC", "can not access a needed shared library"}, + {80, "ELIBBAD", "accessing a corrupted shared library"}, + {81, "ELIBSCN", ".lib section in a.out corrupted"}, + {82, "ELIBMAX", "attempting to link in too many shared libraries"}, + {83, "ELIBEXEC", "cannot exec a shared library directly"}, + {84, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {85, "ERESTART", "interrupted system call should be restarted"}, + {86, "ESTRPIPE", "streams pipe error"}, + {87, "EUSERS", "too many users"}, + {88, "ENOTSOCK", "socket operation on non-socket"}, + {89, "EDESTADDRREQ", "destination address required"}, + {90, "EMSGSIZE", "message too long"}, + {91, "EPROTOTYPE", "protocol wrong type for socket"}, + {92, "ENOPROTOOPT", "protocol not available"}, + {93, "EPROTONOSUPPORT", "protocol not supported"}, + {94, "ESOCKTNOSUPPORT", "socket type not supported"}, + {95, "ENOTSUP", "operation not supported"}, + {96, "EPFNOSUPPORT", "protocol family not supported"}, + {97, "EAFNOSUPPORT", "address family not supported by protocol"}, + {98, "EADDRINUSE", "address already in use"}, + {99, "EADDRNOTAVAIL", "cannot assign requested address"}, + {100, "ENETDOWN", "network is down"}, + {101, "ENETUNREACH", "network is unreachable"}, + {102, "ENETRESET", "network dropped connection on reset"}, + {103, "ECONNABORTED", "software caused connection abort"}, + {104, "ECONNRESET", "connection reset by peer"}, + {105, "ENOBUFS", "no buffer space available"}, + {106, "EISCONN", "transport endpoint is already connected"}, + {107, "ENOTCONN", "transport endpoint is not connected"}, + {108, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {109, "ETOOMANYREFS", "too many references: cannot splice"}, + {110, "ETIMEDOUT", "connection timed out"}, + {111, "ECONNREFUSED", "connection refused"}, + {112, "EHOSTDOWN", "host is down"}, + {113, "EHOSTUNREACH", "no route to host"}, + {114, "EALREADY", "operation already in progress"}, + {115, "EINPROGRESS", "operation now in progress"}, + {116, "ESTALE", "stale file handle"}, + {117, "EUCLEAN", "structure needs cleaning"}, + {118, "ENOTNAM", "not a XENIX named type file"}, + {119, "ENAVAIL", "no XENIX semaphores available"}, + {120, "EISNAM", "is a named type file"}, + {121, "EREMOTEIO", "remote I/O error"}, + {122, "EDQUOT", "disk quota exceeded"}, + {123, "ENOMEDIUM", "no medium found"}, + {124, "EMEDIUMTYPE", "wrong medium type"}, + {125, "ECANCELED", "operation canceled"}, + {126, "ENOKEY", "required key not available"}, + {127, "EKEYEXPIRED", "key has expired"}, + {128, "EKEYREVOKED", "key has been revoked"}, + {129, "EKEYREJECTED", "key was rejected by service"}, + {130, "EOWNERDEAD", "owner died"}, + {131, "ENOTRECOVERABLE", "state not recoverable"}, + {132, "ERFKILL", "operation not possible due to RF-kill"}, + {133, "EHWPOISON", "memory page has hardware error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "bus error", - 8: "floating point exception", - 9: "killed", - 10: "user defined signal 1", - 11: "segmentation fault", - 12: "user defined signal 2", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "stack fault", - 17: "child exited", - 18: "continued", - 19: "stopped (signal)", - 20: "stopped", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "urgent I/O condition", - 24: "CPU time limit exceeded", - 25: "file size limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window changed", - 29: "I/O possible", - 30: "power failure", - 31: "bad system call", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGBUS", "bus error"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGUSR1", "user defined signal 1"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGUSR2", "user defined signal 2"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGSTKFLT", "stack fault"}, + {17, "SIGCHLD", "child exited"}, + {18, "SIGCONT", "continued"}, + {19, "SIGSTOP", "stopped (signal)"}, + {20, "SIGTSTP", "stopped"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGURG", "urgent I/O condition"}, + {24, "SIGXCPU", "CPU time limit exceeded"}, + {25, "SIGXFSZ", "file size limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window changed"}, + {29, "SIGIO", "I/O possible"}, + {30, "SIGPWR", "power failure"}, + {31, "SIGSYS", "bad system call"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_amd64.go b/vendor/golang.org/x/sys/unix/zerrors_linux_amd64.go index eb2a22f6501..64ab9f40ade 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_amd64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_amd64.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x1008 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x1007 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x80081270 BLKBSZSET = 0x40081271 BLKFLSBUF = 0x1261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x2000 BSDLY = 0x2000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0x100f CBAUDEX = 0x1000 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0x100f0000 CLOCAL = 0x800 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x200 CR2 = 0x400 CR3 = 0x600 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x600 CREAD = 0x80 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x40 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x800 ECHONL = 0x40 ECHOPRT = 0x400 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x800 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -461,6 +490,7 @@ const ( FF1 = 0x8000 FFDLY = 0x8000 FLUSHO = 0x1000 + FP_XSTATE_MAGIC2 = 0x46505845 FS_ENCRYPTION_MODE_AES_128_CBC = 0x5 FS_ENCRYPTION_MODE_AES_128_CTS = 0x6 FS_ENCRYPTION_MODE_AES_256_CBC = 0x3 @@ -481,6 +511,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +573,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x400 IBSHIFT = 0x10 ICANON = 0x2 @@ -792,12 +866,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x1 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x200 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x1000 IXON = 0x400 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -894,9 +970,15 @@ const ( MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MCL_ONFAULT = 0x4 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -956,7 +1038,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -991,6 +1075,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NLA_ALIGNTO = 0x4 @@ -1023,6 +1138,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1030,7 +1147,9 @@ const ( ONLCR = 0x4 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x400 O_ASYNC = 0x2000 @@ -1117,14 +1236,17 @@ const ( PERF_EVENT_IOC_ID = 0x80082407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x40042409 PERF_EVENT_IOC_PERIOD = 0x40082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc008240a PERF_EVENT_IOC_REFRESH = 0x2402 PERF_EVENT_IOC_RESET = 0x2403 PERF_EVENT_IOC_SET_BPF = 0x40042408 PERF_EVENT_IOC_SET_FILTER = 0x40082406 PERF_EVENT_IOC_SET_OUTPUT = 0x2405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1230,6 +1352,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ARCH_PRCTL = 0x1e PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 @@ -1274,6 +1397,7 @@ const ( PTRACE_POKETEXT = 0x4 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETFPREGS = 0xf PTRACE_SETFPXREGS = 0x13 @@ -1289,6 +1413,11 @@ const ( PTRACE_SYSEMU = 0x1f PTRACE_SYSEMU_SINGLESTEP = 0x20 PTRACE_TRACEME = 0x0 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x9 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1474,6 +1603,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1558,6 +1689,23 @@ const ( SIOCSPGRP = 0x8902 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x2 @@ -1668,6 +1816,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1689,6 +1839,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1870,7 +2021,27 @@ const ( TIOCSTI = 0x5412 TIOCSWINSZ = 0x5414 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x100 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x401054d5 TUNDETACHFILTER = 0x401054d6 @@ -1882,6 +2053,7 @@ const ( TUNGETVNETHDRSZ = 0x800454d7 TUNGETVNETLE = 0x800454dd TUNSETDEBUG = 0x400454c9 + TUNSETFILTEREBPF = 0x800454e1 TUNSETGROUP = 0x400454ce TUNSETIFF = 0x400454ca TUNSETIFINDEX = 0x400454da @@ -1892,13 +2064,17 @@ const ( TUNSETPERSIST = 0x400454cb TUNSETQUEUE = 0x400454d9 TUNSETSNDBUF = 0x400454d4 + TUNSETSTEERINGEBPF = 0x800454e0 TUNSETTXFILTER = 0x400454d1 TUNSETVNETBE = 0x400454de TUNSETVNETHDRSZ = 0x400454d8 TUNSETVNETLE = 0x400454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0xd VEOF = 0x4 VEOL = 0xb @@ -1940,6 +2116,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -1949,7 +2205,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0x1800 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2129,171 +2387,179 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "resource deadlock avoided", - 36: "file name too long", - 37: "no locks available", - 38: "function not implemented", - 39: "directory not empty", - 40: "too many levels of symbolic links", - 42: "no message of desired type", - 43: "identifier removed", - 44: "channel number out of range", - 45: "level 2 not synchronized", - 46: "level 3 halted", - 47: "level 3 reset", - 48: "link number out of range", - 49: "protocol driver not attached", - 50: "no CSI structure available", - 51: "level 2 halted", - 52: "invalid exchange", - 53: "invalid request descriptor", - 54: "exchange full", - 55: "no anode", - 56: "invalid request code", - 57: "invalid slot", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 72: "multihop attempted", - 73: "RFS specific error", - 74: "bad message", - 75: "value too large for defined data type", - 76: "name not unique on network", - 77: "file descriptor in bad state", - 78: "remote address changed", - 79: "can not access a needed shared library", - 80: "accessing a corrupted shared library", - 81: ".lib section in a.out corrupted", - 82: "attempting to link in too many shared libraries", - 83: "cannot exec a shared library directly", - 84: "invalid or incomplete multibyte or wide character", - 85: "interrupted system call should be restarted", - 86: "streams pipe error", - 87: "too many users", - 88: "socket operation on non-socket", - 89: "destination address required", - 90: "message too long", - 91: "protocol wrong type for socket", - 92: "protocol not available", - 93: "protocol not supported", - 94: "socket type not supported", - 95: "operation not supported", - 96: "protocol family not supported", - 97: "address family not supported by protocol", - 98: "address already in use", - 99: "cannot assign requested address", - 100: "network is down", - 101: "network is unreachable", - 102: "network dropped connection on reset", - 103: "software caused connection abort", - 104: "connection reset by peer", - 105: "no buffer space available", - 106: "transport endpoint is already connected", - 107: "transport endpoint is not connected", - 108: "cannot send after transport endpoint shutdown", - 109: "too many references: cannot splice", - 110: "connection timed out", - 111: "connection refused", - 112: "host is down", - 113: "no route to host", - 114: "operation already in progress", - 115: "operation now in progress", - 116: "stale file handle", - 117: "structure needs cleaning", - 118: "not a XENIX named type file", - 119: "no XENIX semaphores available", - 120: "is a named type file", - 121: "remote I/O error", - 122: "disk quota exceeded", - 123: "no medium found", - 124: "wrong medium type", - 125: "operation canceled", - 126: "required key not available", - 127: "key has expired", - 128: "key has been revoked", - 129: "key was rejected by service", - 130: "owner died", - 131: "state not recoverable", - 132: "operation not possible due to RF-kill", - 133: "memory page has hardware error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "EDEADLK", "resource deadlock avoided"}, + {36, "ENAMETOOLONG", "file name too long"}, + {37, "ENOLCK", "no locks available"}, + {38, "ENOSYS", "function not implemented"}, + {39, "ENOTEMPTY", "directory not empty"}, + {40, "ELOOP", "too many levels of symbolic links"}, + {42, "ENOMSG", "no message of desired type"}, + {43, "EIDRM", "identifier removed"}, + {44, "ECHRNG", "channel number out of range"}, + {45, "EL2NSYNC", "level 2 not synchronized"}, + {46, "EL3HLT", "level 3 halted"}, + {47, "EL3RST", "level 3 reset"}, + {48, "ELNRNG", "link number out of range"}, + {49, "EUNATCH", "protocol driver not attached"}, + {50, "ENOCSI", "no CSI structure available"}, + {51, "EL2HLT", "level 2 halted"}, + {52, "EBADE", "invalid exchange"}, + {53, "EBADR", "invalid request descriptor"}, + {54, "EXFULL", "exchange full"}, + {55, "ENOANO", "no anode"}, + {56, "EBADRQC", "invalid request code"}, + {57, "EBADSLT", "invalid slot"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {72, "EMULTIHOP", "multihop attempted"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EBADMSG", "bad message"}, + {75, "EOVERFLOW", "value too large for defined data type"}, + {76, "ENOTUNIQ", "name not unique on network"}, + {77, "EBADFD", "file descriptor in bad state"}, + {78, "EREMCHG", "remote address changed"}, + {79, "ELIBACC", "can not access a needed shared library"}, + {80, "ELIBBAD", "accessing a corrupted shared library"}, + {81, "ELIBSCN", ".lib section in a.out corrupted"}, + {82, "ELIBMAX", "attempting to link in too many shared libraries"}, + {83, "ELIBEXEC", "cannot exec a shared library directly"}, + {84, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {85, "ERESTART", "interrupted system call should be restarted"}, + {86, "ESTRPIPE", "streams pipe error"}, + {87, "EUSERS", "too many users"}, + {88, "ENOTSOCK", "socket operation on non-socket"}, + {89, "EDESTADDRREQ", "destination address required"}, + {90, "EMSGSIZE", "message too long"}, + {91, "EPROTOTYPE", "protocol wrong type for socket"}, + {92, "ENOPROTOOPT", "protocol not available"}, + {93, "EPROTONOSUPPORT", "protocol not supported"}, + {94, "ESOCKTNOSUPPORT", "socket type not supported"}, + {95, "ENOTSUP", "operation not supported"}, + {96, "EPFNOSUPPORT", "protocol family not supported"}, + {97, "EAFNOSUPPORT", "address family not supported by protocol"}, + {98, "EADDRINUSE", "address already in use"}, + {99, "EADDRNOTAVAIL", "cannot assign requested address"}, + {100, "ENETDOWN", "network is down"}, + {101, "ENETUNREACH", "network is unreachable"}, + {102, "ENETRESET", "network dropped connection on reset"}, + {103, "ECONNABORTED", "software caused connection abort"}, + {104, "ECONNRESET", "connection reset by peer"}, + {105, "ENOBUFS", "no buffer space available"}, + {106, "EISCONN", "transport endpoint is already connected"}, + {107, "ENOTCONN", "transport endpoint is not connected"}, + {108, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {109, "ETOOMANYREFS", "too many references: cannot splice"}, + {110, "ETIMEDOUT", "connection timed out"}, + {111, "ECONNREFUSED", "connection refused"}, + {112, "EHOSTDOWN", "host is down"}, + {113, "EHOSTUNREACH", "no route to host"}, + {114, "EALREADY", "operation already in progress"}, + {115, "EINPROGRESS", "operation now in progress"}, + {116, "ESTALE", "stale file handle"}, + {117, "EUCLEAN", "structure needs cleaning"}, + {118, "ENOTNAM", "not a XENIX named type file"}, + {119, "ENAVAIL", "no XENIX semaphores available"}, + {120, "EISNAM", "is a named type file"}, + {121, "EREMOTEIO", "remote I/O error"}, + {122, "EDQUOT", "disk quota exceeded"}, + {123, "ENOMEDIUM", "no medium found"}, + {124, "EMEDIUMTYPE", "wrong medium type"}, + {125, "ECANCELED", "operation canceled"}, + {126, "ENOKEY", "required key not available"}, + {127, "EKEYEXPIRED", "key has expired"}, + {128, "EKEYREVOKED", "key has been revoked"}, + {129, "EKEYREJECTED", "key was rejected by service"}, + {130, "EOWNERDEAD", "owner died"}, + {131, "ENOTRECOVERABLE", "state not recoverable"}, + {132, "ERFKILL", "operation not possible due to RF-kill"}, + {133, "EHWPOISON", "memory page has hardware error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "bus error", - 8: "floating point exception", - 9: "killed", - 10: "user defined signal 1", - 11: "segmentation fault", - 12: "user defined signal 2", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "stack fault", - 17: "child exited", - 18: "continued", - 19: "stopped (signal)", - 20: "stopped", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "urgent I/O condition", - 24: "CPU time limit exceeded", - 25: "file size limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window changed", - 29: "I/O possible", - 30: "power failure", - 31: "bad system call", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGBUS", "bus error"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGUSR1", "user defined signal 1"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGUSR2", "user defined signal 2"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGSTKFLT", "stack fault"}, + {17, "SIGCHLD", "child exited"}, + {18, "SIGCONT", "continued"}, + {19, "SIGSTOP", "stopped (signal)"}, + {20, "SIGTSTP", "stopped"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGURG", "urgent I/O condition"}, + {24, "SIGXCPU", "CPU time limit exceeded"}, + {25, "SIGXFSZ", "file size limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window changed"}, + {29, "SIGIO", "I/O possible"}, + {30, "SIGPWR", "power failure"}, + {31, "SIGSYS", "bad system call"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_arm.go b/vendor/golang.org/x/sys/unix/zerrors_linux_arm.go index 37d212ca494..6ae0ac6f862 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_arm.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_arm.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x1008 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x1007 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x80041270 BLKBSZSET = 0x40041271 BLKFLSBUF = 0x1261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x2000 BSDLY = 0x2000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0x100f CBAUDEX = 0x1000 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0x100f0000 CLOCAL = 0x800 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x200 CR2 = 0x400 CR3 = 0x600 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x600 CREAD = 0x80 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x40 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x800 ECHONL = 0x40 ECHOPRT = 0x400 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x800 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -481,6 +510,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +572,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x400 IBSHIFT = 0x10 ICANON = 0x2 @@ -792,12 +865,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x1 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x200 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x1000 IXON = 0x400 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -893,9 +968,15 @@ const ( MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MCL_ONFAULT = 0x4 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -955,7 +1036,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -990,6 +1073,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NLA_ALIGNTO = 0x4 @@ -1022,6 +1136,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1029,7 +1145,9 @@ const ( ONLCR = 0x4 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x400 O_ASYNC = 0x2000 @@ -1116,14 +1234,17 @@ const ( PERF_EVENT_IOC_ID = 0x80042407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x40042409 PERF_EVENT_IOC_PERIOD = 0x40082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc004240a PERF_EVENT_IOC_REFRESH = 0x2402 PERF_EVENT_IOC_RESET = 0x2403 PERF_EVENT_IOC_SET_BPF = 0x40042408 PERF_EVENT_IOC_SET_FILTER = 0x40042406 PERF_EVENT_IOC_SET_OUTPUT = 0x2405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1229,6 +1350,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1278,6 +1400,7 @@ const ( PTRACE_POKETEXT = 0x4 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETCRUNCHREGS = 0x1a PTRACE_SETFPREGS = 0xf @@ -1296,6 +1419,11 @@ const ( PT_DATA_ADDR = 0x10004 PT_TEXT_ADDR = 0x10000 PT_TEXT_END_ADDR = 0x10008 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x9 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1481,6 +1609,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1565,6 +1695,23 @@ const ( SIOCSPGRP = 0x8902 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x2 @@ -1675,6 +1822,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1696,6 +1845,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1877,7 +2027,27 @@ const ( TIOCSTI = 0x5412 TIOCSWINSZ = 0x5414 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x100 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x400854d5 TUNDETACHFILTER = 0x400854d6 @@ -1889,6 +2059,7 @@ const ( TUNGETVNETHDRSZ = 0x800454d7 TUNGETVNETLE = 0x800454dd TUNSETDEBUG = 0x400454c9 + TUNSETFILTEREBPF = 0x800454e1 TUNSETGROUP = 0x400454ce TUNSETIFF = 0x400454ca TUNSETIFINDEX = 0x400454da @@ -1899,13 +2070,17 @@ const ( TUNSETPERSIST = 0x400454cb TUNSETQUEUE = 0x400454d9 TUNSETSNDBUF = 0x400454d4 + TUNSETSTEERINGEBPF = 0x800454e0 TUNSETTXFILTER = 0x400454d1 TUNSETVNETBE = 0x400454de TUNSETVNETHDRSZ = 0x400454d8 TUNSETVNETLE = 0x400454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0xd VEOF = 0x4 VEOL = 0xb @@ -1947,6 +2122,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -1956,7 +2211,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0x1800 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2136,171 +2393,179 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "resource deadlock avoided", - 36: "file name too long", - 37: "no locks available", - 38: "function not implemented", - 39: "directory not empty", - 40: "too many levels of symbolic links", - 42: "no message of desired type", - 43: "identifier removed", - 44: "channel number out of range", - 45: "level 2 not synchronized", - 46: "level 3 halted", - 47: "level 3 reset", - 48: "link number out of range", - 49: "protocol driver not attached", - 50: "no CSI structure available", - 51: "level 2 halted", - 52: "invalid exchange", - 53: "invalid request descriptor", - 54: "exchange full", - 55: "no anode", - 56: "invalid request code", - 57: "invalid slot", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 72: "multihop attempted", - 73: "RFS specific error", - 74: "bad message", - 75: "value too large for defined data type", - 76: "name not unique on network", - 77: "file descriptor in bad state", - 78: "remote address changed", - 79: "can not access a needed shared library", - 80: "accessing a corrupted shared library", - 81: ".lib section in a.out corrupted", - 82: "attempting to link in too many shared libraries", - 83: "cannot exec a shared library directly", - 84: "invalid or incomplete multibyte or wide character", - 85: "interrupted system call should be restarted", - 86: "streams pipe error", - 87: "too many users", - 88: "socket operation on non-socket", - 89: "destination address required", - 90: "message too long", - 91: "protocol wrong type for socket", - 92: "protocol not available", - 93: "protocol not supported", - 94: "socket type not supported", - 95: "operation not supported", - 96: "protocol family not supported", - 97: "address family not supported by protocol", - 98: "address already in use", - 99: "cannot assign requested address", - 100: "network is down", - 101: "network is unreachable", - 102: "network dropped connection on reset", - 103: "software caused connection abort", - 104: "connection reset by peer", - 105: "no buffer space available", - 106: "transport endpoint is already connected", - 107: "transport endpoint is not connected", - 108: "cannot send after transport endpoint shutdown", - 109: "too many references: cannot splice", - 110: "connection timed out", - 111: "connection refused", - 112: "host is down", - 113: "no route to host", - 114: "operation already in progress", - 115: "operation now in progress", - 116: "stale file handle", - 117: "structure needs cleaning", - 118: "not a XENIX named type file", - 119: "no XENIX semaphores available", - 120: "is a named type file", - 121: "remote I/O error", - 122: "disk quota exceeded", - 123: "no medium found", - 124: "wrong medium type", - 125: "operation canceled", - 126: "required key not available", - 127: "key has expired", - 128: "key has been revoked", - 129: "key was rejected by service", - 130: "owner died", - 131: "state not recoverable", - 132: "operation not possible due to RF-kill", - 133: "memory page has hardware error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "EDEADLK", "resource deadlock avoided"}, + {36, "ENAMETOOLONG", "file name too long"}, + {37, "ENOLCK", "no locks available"}, + {38, "ENOSYS", "function not implemented"}, + {39, "ENOTEMPTY", "directory not empty"}, + {40, "ELOOP", "too many levels of symbolic links"}, + {42, "ENOMSG", "no message of desired type"}, + {43, "EIDRM", "identifier removed"}, + {44, "ECHRNG", "channel number out of range"}, + {45, "EL2NSYNC", "level 2 not synchronized"}, + {46, "EL3HLT", "level 3 halted"}, + {47, "EL3RST", "level 3 reset"}, + {48, "ELNRNG", "link number out of range"}, + {49, "EUNATCH", "protocol driver not attached"}, + {50, "ENOCSI", "no CSI structure available"}, + {51, "EL2HLT", "level 2 halted"}, + {52, "EBADE", "invalid exchange"}, + {53, "EBADR", "invalid request descriptor"}, + {54, "EXFULL", "exchange full"}, + {55, "ENOANO", "no anode"}, + {56, "EBADRQC", "invalid request code"}, + {57, "EBADSLT", "invalid slot"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {72, "EMULTIHOP", "multihop attempted"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EBADMSG", "bad message"}, + {75, "EOVERFLOW", "value too large for defined data type"}, + {76, "ENOTUNIQ", "name not unique on network"}, + {77, "EBADFD", "file descriptor in bad state"}, + {78, "EREMCHG", "remote address changed"}, + {79, "ELIBACC", "can not access a needed shared library"}, + {80, "ELIBBAD", "accessing a corrupted shared library"}, + {81, "ELIBSCN", ".lib section in a.out corrupted"}, + {82, "ELIBMAX", "attempting to link in too many shared libraries"}, + {83, "ELIBEXEC", "cannot exec a shared library directly"}, + {84, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {85, "ERESTART", "interrupted system call should be restarted"}, + {86, "ESTRPIPE", "streams pipe error"}, + {87, "EUSERS", "too many users"}, + {88, "ENOTSOCK", "socket operation on non-socket"}, + {89, "EDESTADDRREQ", "destination address required"}, + {90, "EMSGSIZE", "message too long"}, + {91, "EPROTOTYPE", "protocol wrong type for socket"}, + {92, "ENOPROTOOPT", "protocol not available"}, + {93, "EPROTONOSUPPORT", "protocol not supported"}, + {94, "ESOCKTNOSUPPORT", "socket type not supported"}, + {95, "ENOTSUP", "operation not supported"}, + {96, "EPFNOSUPPORT", "protocol family not supported"}, + {97, "EAFNOSUPPORT", "address family not supported by protocol"}, + {98, "EADDRINUSE", "address already in use"}, + {99, "EADDRNOTAVAIL", "cannot assign requested address"}, + {100, "ENETDOWN", "network is down"}, + {101, "ENETUNREACH", "network is unreachable"}, + {102, "ENETRESET", "network dropped connection on reset"}, + {103, "ECONNABORTED", "software caused connection abort"}, + {104, "ECONNRESET", "connection reset by peer"}, + {105, "ENOBUFS", "no buffer space available"}, + {106, "EISCONN", "transport endpoint is already connected"}, + {107, "ENOTCONN", "transport endpoint is not connected"}, + {108, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {109, "ETOOMANYREFS", "too many references: cannot splice"}, + {110, "ETIMEDOUT", "connection timed out"}, + {111, "ECONNREFUSED", "connection refused"}, + {112, "EHOSTDOWN", "host is down"}, + {113, "EHOSTUNREACH", "no route to host"}, + {114, "EALREADY", "operation already in progress"}, + {115, "EINPROGRESS", "operation now in progress"}, + {116, "ESTALE", "stale file handle"}, + {117, "EUCLEAN", "structure needs cleaning"}, + {118, "ENOTNAM", "not a XENIX named type file"}, + {119, "ENAVAIL", "no XENIX semaphores available"}, + {120, "EISNAM", "is a named type file"}, + {121, "EREMOTEIO", "remote I/O error"}, + {122, "EDQUOT", "disk quota exceeded"}, + {123, "ENOMEDIUM", "no medium found"}, + {124, "EMEDIUMTYPE", "wrong medium type"}, + {125, "ECANCELED", "operation canceled"}, + {126, "ENOKEY", "required key not available"}, + {127, "EKEYEXPIRED", "key has expired"}, + {128, "EKEYREVOKED", "key has been revoked"}, + {129, "EKEYREJECTED", "key was rejected by service"}, + {130, "EOWNERDEAD", "owner died"}, + {131, "ENOTRECOVERABLE", "state not recoverable"}, + {132, "ERFKILL", "operation not possible due to RF-kill"}, + {133, "EHWPOISON", "memory page has hardware error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "bus error", - 8: "floating point exception", - 9: "killed", - 10: "user defined signal 1", - 11: "segmentation fault", - 12: "user defined signal 2", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "stack fault", - 17: "child exited", - 18: "continued", - 19: "stopped (signal)", - 20: "stopped", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "urgent I/O condition", - 24: "CPU time limit exceeded", - 25: "file size limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window changed", - 29: "I/O possible", - 30: "power failure", - 31: "bad system call", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGBUS", "bus error"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGUSR1", "user defined signal 1"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGUSR2", "user defined signal 2"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGSTKFLT", "stack fault"}, + {17, "SIGCHLD", "child exited"}, + {18, "SIGCONT", "continued"}, + {19, "SIGSTOP", "stopped (signal)"}, + {20, "SIGTSTP", "stopped"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGURG", "urgent I/O condition"}, + {24, "SIGXCPU", "CPU time limit exceeded"}, + {25, "SIGXFSZ", "file size limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window changed"}, + {29, "SIGIO", "I/O possible"}, + {30, "SIGPWR", "power failure"}, + {31, "SIGSYS", "bad system call"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_arm64.go b/vendor/golang.org/x/sys/unix/zerrors_linux_arm64.go index 51d84a35c30..f58450bf3d3 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_arm64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_arm64.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x1008 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x1007 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x80081270 BLKBSZSET = 0x40081271 BLKFLSBUF = 0x1261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x2000 BSDLY = 0x2000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0x100f CBAUDEX = 0x1000 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0x100f0000 CLOCAL = 0x800 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x200 CR2 = 0x400 CR3 = 0x600 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x600 CREAD = 0x80 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x40 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x800 ECHONL = 0x40 ECHOPRT = 0x400 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x800 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -393,6 +416,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -446,10 +470,15 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000 EXTRA_MAGIC = 0x45585401 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -463,6 +492,7 @@ const ( FF1 = 0x8000 FFDLY = 0x8000 FLUSHO = 0x1000 + FPSIMD_MAGIC = 0x46508001 FS_ENCRYPTION_MODE_AES_128_CBC = 0x5 FS_ENCRYPTION_MODE_AES_128_CTS = 0x6 FS_ENCRYPTION_MODE_AES_256_CBC = 0x3 @@ -483,6 +513,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -544,6 +575,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x400 IBSHIFT = 0x10 ICANON = 0x2 @@ -794,12 +868,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x1 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x200 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x1000 IXON = 0x400 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -895,9 +971,15 @@ const ( MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MCL_ONFAULT = 0x4 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -957,7 +1039,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -992,6 +1076,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NLA_ALIGNTO = 0x4 @@ -1024,6 +1139,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1031,7 +1148,9 @@ const ( ONLCR = 0x4 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x400 O_ASYNC = 0x2000 @@ -1118,14 +1237,17 @@ const ( PERF_EVENT_IOC_ID = 0x80082407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x40042409 PERF_EVENT_IOC_PERIOD = 0x40082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc008240a PERF_EVENT_IOC_REFRESH = 0x2402 PERF_EVENT_IOC_RESET = 0x2403 PERF_EVENT_IOC_SET_BPF = 0x40042408 PERF_EVENT_IOC_SET_FILTER = 0x40082406 PERF_EVENT_IOC_SET_OUTPUT = 0x2405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1231,6 +1353,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1270,6 +1393,7 @@ const ( PTRACE_POKETEXT = 0x4 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETOPTIONS = 0x4200 PTRACE_SETREGS = 0xd @@ -1279,6 +1403,11 @@ const ( PTRACE_SINGLESTEP = 0x9 PTRACE_SYSCALL = 0x18 PTRACE_TRACEME = 0x0 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x9 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1464,6 +1593,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1548,6 +1679,23 @@ const ( SIOCSPGRP = 0x8902 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x2 @@ -1658,6 +1806,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1679,6 +1829,8 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SVE_MAGIC = 0x53564501 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1860,7 +2012,27 @@ const ( TIOCSTI = 0x5412 TIOCSWINSZ = 0x5414 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x100 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x401054d5 TUNDETACHFILTER = 0x401054d6 @@ -1872,6 +2044,7 @@ const ( TUNGETVNETHDRSZ = 0x800454d7 TUNGETVNETLE = 0x800454dd TUNSETDEBUG = 0x400454c9 + TUNSETFILTEREBPF = 0x800454e1 TUNSETGROUP = 0x400454ce TUNSETIFF = 0x400454ca TUNSETIFINDEX = 0x400454da @@ -1882,13 +2055,17 @@ const ( TUNSETPERSIST = 0x400454cb TUNSETQUEUE = 0x400454d9 TUNSETSNDBUF = 0x400454d4 + TUNSETSTEERINGEBPF = 0x800454e0 TUNSETTXFILTER = 0x400454d1 TUNSETVNETBE = 0x400454de TUNSETVNETHDRSZ = 0x400454d8 TUNSETVNETLE = 0x400454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0xd VEOF = 0x4 VEOL = 0xb @@ -1930,6 +2107,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -1939,7 +2196,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0x1800 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2119,171 +2378,179 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "resource deadlock avoided", - 36: "file name too long", - 37: "no locks available", - 38: "function not implemented", - 39: "directory not empty", - 40: "too many levels of symbolic links", - 42: "no message of desired type", - 43: "identifier removed", - 44: "channel number out of range", - 45: "level 2 not synchronized", - 46: "level 3 halted", - 47: "level 3 reset", - 48: "link number out of range", - 49: "protocol driver not attached", - 50: "no CSI structure available", - 51: "level 2 halted", - 52: "invalid exchange", - 53: "invalid request descriptor", - 54: "exchange full", - 55: "no anode", - 56: "invalid request code", - 57: "invalid slot", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 72: "multihop attempted", - 73: "RFS specific error", - 74: "bad message", - 75: "value too large for defined data type", - 76: "name not unique on network", - 77: "file descriptor in bad state", - 78: "remote address changed", - 79: "can not access a needed shared library", - 80: "accessing a corrupted shared library", - 81: ".lib section in a.out corrupted", - 82: "attempting to link in too many shared libraries", - 83: "cannot exec a shared library directly", - 84: "invalid or incomplete multibyte or wide character", - 85: "interrupted system call should be restarted", - 86: "streams pipe error", - 87: "too many users", - 88: "socket operation on non-socket", - 89: "destination address required", - 90: "message too long", - 91: "protocol wrong type for socket", - 92: "protocol not available", - 93: "protocol not supported", - 94: "socket type not supported", - 95: "operation not supported", - 96: "protocol family not supported", - 97: "address family not supported by protocol", - 98: "address already in use", - 99: "cannot assign requested address", - 100: "network is down", - 101: "network is unreachable", - 102: "network dropped connection on reset", - 103: "software caused connection abort", - 104: "connection reset by peer", - 105: "no buffer space available", - 106: "transport endpoint is already connected", - 107: "transport endpoint is not connected", - 108: "cannot send after transport endpoint shutdown", - 109: "too many references: cannot splice", - 110: "connection timed out", - 111: "connection refused", - 112: "host is down", - 113: "no route to host", - 114: "operation already in progress", - 115: "operation now in progress", - 116: "stale file handle", - 117: "structure needs cleaning", - 118: "not a XENIX named type file", - 119: "no XENIX semaphores available", - 120: "is a named type file", - 121: "remote I/O error", - 122: "disk quota exceeded", - 123: "no medium found", - 124: "wrong medium type", - 125: "operation canceled", - 126: "required key not available", - 127: "key has expired", - 128: "key has been revoked", - 129: "key was rejected by service", - 130: "owner died", - 131: "state not recoverable", - 132: "operation not possible due to RF-kill", - 133: "memory page has hardware error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "EDEADLK", "resource deadlock avoided"}, + {36, "ENAMETOOLONG", "file name too long"}, + {37, "ENOLCK", "no locks available"}, + {38, "ENOSYS", "function not implemented"}, + {39, "ENOTEMPTY", "directory not empty"}, + {40, "ELOOP", "too many levels of symbolic links"}, + {42, "ENOMSG", "no message of desired type"}, + {43, "EIDRM", "identifier removed"}, + {44, "ECHRNG", "channel number out of range"}, + {45, "EL2NSYNC", "level 2 not synchronized"}, + {46, "EL3HLT", "level 3 halted"}, + {47, "EL3RST", "level 3 reset"}, + {48, "ELNRNG", "link number out of range"}, + {49, "EUNATCH", "protocol driver not attached"}, + {50, "ENOCSI", "no CSI structure available"}, + {51, "EL2HLT", "level 2 halted"}, + {52, "EBADE", "invalid exchange"}, + {53, "EBADR", "invalid request descriptor"}, + {54, "EXFULL", "exchange full"}, + {55, "ENOANO", "no anode"}, + {56, "EBADRQC", "invalid request code"}, + {57, "EBADSLT", "invalid slot"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {72, "EMULTIHOP", "multihop attempted"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EBADMSG", "bad message"}, + {75, "EOVERFLOW", "value too large for defined data type"}, + {76, "ENOTUNIQ", "name not unique on network"}, + {77, "EBADFD", "file descriptor in bad state"}, + {78, "EREMCHG", "remote address changed"}, + {79, "ELIBACC", "can not access a needed shared library"}, + {80, "ELIBBAD", "accessing a corrupted shared library"}, + {81, "ELIBSCN", ".lib section in a.out corrupted"}, + {82, "ELIBMAX", "attempting to link in too many shared libraries"}, + {83, "ELIBEXEC", "cannot exec a shared library directly"}, + {84, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {85, "ERESTART", "interrupted system call should be restarted"}, + {86, "ESTRPIPE", "streams pipe error"}, + {87, "EUSERS", "too many users"}, + {88, "ENOTSOCK", "socket operation on non-socket"}, + {89, "EDESTADDRREQ", "destination address required"}, + {90, "EMSGSIZE", "message too long"}, + {91, "EPROTOTYPE", "protocol wrong type for socket"}, + {92, "ENOPROTOOPT", "protocol not available"}, + {93, "EPROTONOSUPPORT", "protocol not supported"}, + {94, "ESOCKTNOSUPPORT", "socket type not supported"}, + {95, "ENOTSUP", "operation not supported"}, + {96, "EPFNOSUPPORT", "protocol family not supported"}, + {97, "EAFNOSUPPORT", "address family not supported by protocol"}, + {98, "EADDRINUSE", "address already in use"}, + {99, "EADDRNOTAVAIL", "cannot assign requested address"}, + {100, "ENETDOWN", "network is down"}, + {101, "ENETUNREACH", "network is unreachable"}, + {102, "ENETRESET", "network dropped connection on reset"}, + {103, "ECONNABORTED", "software caused connection abort"}, + {104, "ECONNRESET", "connection reset by peer"}, + {105, "ENOBUFS", "no buffer space available"}, + {106, "EISCONN", "transport endpoint is already connected"}, + {107, "ENOTCONN", "transport endpoint is not connected"}, + {108, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {109, "ETOOMANYREFS", "too many references: cannot splice"}, + {110, "ETIMEDOUT", "connection timed out"}, + {111, "ECONNREFUSED", "connection refused"}, + {112, "EHOSTDOWN", "host is down"}, + {113, "EHOSTUNREACH", "no route to host"}, + {114, "EALREADY", "operation already in progress"}, + {115, "EINPROGRESS", "operation now in progress"}, + {116, "ESTALE", "stale file handle"}, + {117, "EUCLEAN", "structure needs cleaning"}, + {118, "ENOTNAM", "not a XENIX named type file"}, + {119, "ENAVAIL", "no XENIX semaphores available"}, + {120, "EISNAM", "is a named type file"}, + {121, "EREMOTEIO", "remote I/O error"}, + {122, "EDQUOT", "disk quota exceeded"}, + {123, "ENOMEDIUM", "no medium found"}, + {124, "EMEDIUMTYPE", "wrong medium type"}, + {125, "ECANCELED", "operation canceled"}, + {126, "ENOKEY", "required key not available"}, + {127, "EKEYEXPIRED", "key has expired"}, + {128, "EKEYREVOKED", "key has been revoked"}, + {129, "EKEYREJECTED", "key was rejected by service"}, + {130, "EOWNERDEAD", "owner died"}, + {131, "ENOTRECOVERABLE", "state not recoverable"}, + {132, "ERFKILL", "operation not possible due to RF-kill"}, + {133, "EHWPOISON", "memory page has hardware error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "bus error", - 8: "floating point exception", - 9: "killed", - 10: "user defined signal 1", - 11: "segmentation fault", - 12: "user defined signal 2", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "stack fault", - 17: "child exited", - 18: "continued", - 19: "stopped (signal)", - 20: "stopped", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "urgent I/O condition", - 24: "CPU time limit exceeded", - 25: "file size limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window changed", - 29: "I/O possible", - 30: "power failure", - 31: "bad system call", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGBUS", "bus error"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGUSR1", "user defined signal 1"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGUSR2", "user defined signal 2"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGSTKFLT", "stack fault"}, + {17, "SIGCHLD", "child exited"}, + {18, "SIGCONT", "continued"}, + {19, "SIGSTOP", "stopped (signal)"}, + {20, "SIGTSTP", "stopped"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGURG", "urgent I/O condition"}, + {24, "SIGXCPU", "CPU time limit exceeded"}, + {25, "SIGXFSZ", "file size limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window changed"}, + {29, "SIGIO", "I/O possible"}, + {30, "SIGPWR", "power failure"}, + {31, "SIGSYS", "bad system call"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_mips.go b/vendor/golang.org/x/sys/unix/zerrors_linux_mips.go index 8aec95d6c24..465ff2f0f3c 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_mips.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_mips.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x1008 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x1007 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x40041270 BLKBSZSET = 0x80041271 BLKFLSBUF = 0x20001261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x2000 BSDLY = 0x2000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0x100f CBAUDEX = 0x1000 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0x100f0000 CLOCAL = 0x800 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x200 CR2 = 0x400 CR3 = 0x600 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x600 CREAD = 0x80 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x40 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x800 ECHONL = 0x40 ECHOPRT = 0x400 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x80 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -481,6 +510,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +572,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x400 IBSHIFT = 0x10 ICANON = 0x2 @@ -792,12 +865,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x1 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x200 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x1000 IXON = 0x400 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -894,9 +969,15 @@ const ( MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MCL_ONFAULT = 0x4 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -956,7 +1037,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -991,6 +1074,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NLA_ALIGNTO = 0x4 @@ -1023,6 +1137,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1030,7 +1146,9 @@ const ( ONLCR = 0x4 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x8 O_ASYNC = 0x1000 @@ -1117,14 +1235,17 @@ const ( PERF_EVENT_IOC_ID = 0x40042407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x80042409 PERF_EVENT_IOC_PERIOD = 0x80082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc004240a PERF_EVENT_IOC_REFRESH = 0x20002402 PERF_EVENT_IOC_RESET = 0x20002403 PERF_EVENT_IOC_SET_BPF = 0x80042408 PERF_EVENT_IOC_SET_FILTER = 0x80042406 PERF_EVENT_IOC_SET_OUTPUT = 0x20002405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1230,6 +1351,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1278,6 +1400,7 @@ const ( PTRACE_POKETEXT_3264 = 0xc2 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETFPREGS = 0xf PTRACE_SETOPTIONS = 0x4200 @@ -1290,6 +1413,11 @@ const ( PTRACE_SINGLESTEP = 0x9 PTRACE_SYSCALL = 0x18 PTRACE_TRACEME = 0x0 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x6 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1475,6 +1603,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1559,6 +1689,23 @@ const ( SIOCSPGRP = 0x80047308 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x1 @@ -1670,6 +1817,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1691,6 +1840,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1873,7 +2023,27 @@ const ( TIOCSTI = 0x5472 TIOCSWINSZ = 0x80087467 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x8000 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x800854d5 TUNDETACHFILTER = 0x800854d6 @@ -1885,6 +2055,7 @@ const ( TUNGETVNETHDRSZ = 0x400454d7 TUNGETVNETLE = 0x400454dd TUNSETDEBUG = 0x800454c9 + TUNSETFILTEREBPF = 0x400454e1 TUNSETGROUP = 0x800454ce TUNSETIFF = 0x800454ca TUNSETIFINDEX = 0x800454da @@ -1895,13 +2066,17 @@ const ( TUNSETPERSIST = 0x800454cb TUNSETQUEUE = 0x800454d9 TUNSETSNDBUF = 0x800454d4 + TUNSETSTEERINGEBPF = 0x400454e0 TUNSETTXFILTER = 0x800454d1 TUNSETVNETBE = 0x800454de TUNSETVNETHDRSZ = 0x800454d8 TUNSETVNETLE = 0x800454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0xd VEOF = 0x10 VEOL = 0x11 @@ -1944,6 +2119,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -1953,7 +2208,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0x1800 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2135,174 +2392,182 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "no message of desired type", - 36: "identifier removed", - 37: "channel number out of range", - 38: "level 2 not synchronized", - 39: "level 3 halted", - 40: "level 3 reset", - 41: "link number out of range", - 42: "protocol driver not attached", - 43: "no CSI structure available", - 44: "level 2 halted", - 45: "resource deadlock avoided", - 46: "no locks available", - 50: "invalid exchange", - 51: "invalid request descriptor", - 52: "exchange full", - 53: "no anode", - 54: "invalid request code", - 55: "invalid slot", - 56: "file locking deadlock error", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 73: "RFS specific error", - 74: "multihop attempted", - 77: "bad message", - 78: "file name too long", - 79: "value too large for defined data type", - 80: "name not unique on network", - 81: "file descriptor in bad state", - 82: "remote address changed", - 83: "can not access a needed shared library", - 84: "accessing a corrupted shared library", - 85: ".lib section in a.out corrupted", - 86: "attempting to link in too many shared libraries", - 87: "cannot exec a shared library directly", - 88: "invalid or incomplete multibyte or wide character", - 89: "function not implemented", - 90: "too many levels of symbolic links", - 91: "interrupted system call should be restarted", - 92: "streams pipe error", - 93: "directory not empty", - 94: "too many users", - 95: "socket operation on non-socket", - 96: "destination address required", - 97: "message too long", - 98: "protocol wrong type for socket", - 99: "protocol not available", - 120: "protocol not supported", - 121: "socket type not supported", - 122: "operation not supported", - 123: "protocol family not supported", - 124: "address family not supported by protocol", - 125: "address already in use", - 126: "cannot assign requested address", - 127: "network is down", - 128: "network is unreachable", - 129: "network dropped connection on reset", - 130: "software caused connection abort", - 131: "connection reset by peer", - 132: "no buffer space available", - 133: "transport endpoint is already connected", - 134: "transport endpoint is not connected", - 135: "structure needs cleaning", - 137: "not a XENIX named type file", - 138: "no XENIX semaphores available", - 139: "is a named type file", - 140: "remote I/O error", - 141: "unknown error 141", - 142: "unknown error 142", - 143: "cannot send after transport endpoint shutdown", - 144: "too many references: cannot splice", - 145: "connection timed out", - 146: "connection refused", - 147: "host is down", - 148: "no route to host", - 149: "operation already in progress", - 150: "operation now in progress", - 151: "stale file handle", - 158: "operation canceled", - 159: "no medium found", - 160: "wrong medium type", - 161: "required key not available", - 162: "key has expired", - 163: "key has been revoked", - 164: "key was rejected by service", - 165: "owner died", - 166: "state not recoverable", - 167: "operation not possible due to RF-kill", - 168: "memory page has hardware error", - 1133: "disk quota exceeded", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "ENOMSG", "no message of desired type"}, + {36, "EIDRM", "identifier removed"}, + {37, "ECHRNG", "channel number out of range"}, + {38, "EL2NSYNC", "level 2 not synchronized"}, + {39, "EL3HLT", "level 3 halted"}, + {40, "EL3RST", "level 3 reset"}, + {41, "ELNRNG", "link number out of range"}, + {42, "EUNATCH", "protocol driver not attached"}, + {43, "ENOCSI", "no CSI structure available"}, + {44, "EL2HLT", "level 2 halted"}, + {45, "EDEADLK", "resource deadlock avoided"}, + {46, "ENOLCK", "no locks available"}, + {50, "EBADE", "invalid exchange"}, + {51, "EBADR", "invalid request descriptor"}, + {52, "EXFULL", "exchange full"}, + {53, "ENOANO", "no anode"}, + {54, "EBADRQC", "invalid request code"}, + {55, "EBADSLT", "invalid slot"}, + {56, "EDEADLOCK", "file locking deadlock error"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EMULTIHOP", "multihop attempted"}, + {77, "EBADMSG", "bad message"}, + {78, "ENAMETOOLONG", "file name too long"}, + {79, "EOVERFLOW", "value too large for defined data type"}, + {80, "ENOTUNIQ", "name not unique on network"}, + {81, "EBADFD", "file descriptor in bad state"}, + {82, "EREMCHG", "remote address changed"}, + {83, "ELIBACC", "can not access a needed shared library"}, + {84, "ELIBBAD", "accessing a corrupted shared library"}, + {85, "ELIBSCN", ".lib section in a.out corrupted"}, + {86, "ELIBMAX", "attempting to link in too many shared libraries"}, + {87, "ELIBEXEC", "cannot exec a shared library directly"}, + {88, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {89, "ENOSYS", "function not implemented"}, + {90, "ELOOP", "too many levels of symbolic links"}, + {91, "ERESTART", "interrupted system call should be restarted"}, + {92, "ESTRPIPE", "streams pipe error"}, + {93, "ENOTEMPTY", "directory not empty"}, + {94, "EUSERS", "too many users"}, + {95, "ENOTSOCK", "socket operation on non-socket"}, + {96, "EDESTADDRREQ", "destination address required"}, + {97, "EMSGSIZE", "message too long"}, + {98, "EPROTOTYPE", "protocol wrong type for socket"}, + {99, "ENOPROTOOPT", "protocol not available"}, + {120, "EPROTONOSUPPORT", "protocol not supported"}, + {121, "ESOCKTNOSUPPORT", "socket type not supported"}, + {122, "ENOTSUP", "operation not supported"}, + {123, "EPFNOSUPPORT", "protocol family not supported"}, + {124, "EAFNOSUPPORT", "address family not supported by protocol"}, + {125, "EADDRINUSE", "address already in use"}, + {126, "EADDRNOTAVAIL", "cannot assign requested address"}, + {127, "ENETDOWN", "network is down"}, + {128, "ENETUNREACH", "network is unreachable"}, + {129, "ENETRESET", "network dropped connection on reset"}, + {130, "ECONNABORTED", "software caused connection abort"}, + {131, "ECONNRESET", "connection reset by peer"}, + {132, "ENOBUFS", "no buffer space available"}, + {133, "EISCONN", "transport endpoint is already connected"}, + {134, "ENOTCONN", "transport endpoint is not connected"}, + {135, "EUCLEAN", "structure needs cleaning"}, + {137, "ENOTNAM", "not a XENIX named type file"}, + {138, "ENAVAIL", "no XENIX semaphores available"}, + {139, "EISNAM", "is a named type file"}, + {140, "EREMOTEIO", "remote I/O error"}, + {141, "EINIT", "unknown error 141"}, + {142, "EREMDEV", "unknown error 142"}, + {143, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {144, "ETOOMANYREFS", "too many references: cannot splice"}, + {145, "ETIMEDOUT", "connection timed out"}, + {146, "ECONNREFUSED", "connection refused"}, + {147, "EHOSTDOWN", "host is down"}, + {148, "EHOSTUNREACH", "no route to host"}, + {149, "EALREADY", "operation already in progress"}, + {150, "EINPROGRESS", "operation now in progress"}, + {151, "ESTALE", "stale file handle"}, + {158, "ECANCELED", "operation canceled"}, + {159, "ENOMEDIUM", "no medium found"}, + {160, "EMEDIUMTYPE", "wrong medium type"}, + {161, "ENOKEY", "required key not available"}, + {162, "EKEYEXPIRED", "key has expired"}, + {163, "EKEYREVOKED", "key has been revoked"}, + {164, "EKEYREJECTED", "key was rejected by service"}, + {165, "EOWNERDEAD", "owner died"}, + {166, "ENOTRECOVERABLE", "state not recoverable"}, + {167, "ERFKILL", "operation not possible due to RF-kill"}, + {168, "EHWPOISON", "memory page has hardware error"}, + {1133, "EDQUOT", "disk quota exceeded"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "user defined signal 1", - 17: "user defined signal 2", - 18: "child exited", - 19: "power failure", - 20: "window changed", - 21: "urgent I/O condition", - 22: "I/O possible", - 23: "stopped (signal)", - 24: "stopped", - 25: "continued", - 26: "stopped (tty input)", - 27: "stopped (tty output)", - 28: "virtual timer expired", - 29: "profiling timer expired", - 30: "CPU time limit exceeded", - 31: "file size limit exceeded", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGUSR1", "user defined signal 1"}, + {17, "SIGUSR2", "user defined signal 2"}, + {18, "SIGCHLD", "child exited"}, + {19, "SIGPWR", "power failure"}, + {20, "SIGWINCH", "window changed"}, + {21, "SIGURG", "urgent I/O condition"}, + {22, "SIGIO", "I/O possible"}, + {23, "SIGSTOP", "stopped (signal)"}, + {24, "SIGTSTP", "stopped"}, + {25, "SIGCONT", "continued"}, + {26, "SIGTTIN", "stopped (tty input)"}, + {27, "SIGTTOU", "stopped (tty output)"}, + {28, "SIGVTALRM", "virtual timer expired"}, + {29, "SIGPROF", "profiling timer expired"}, + {30, "SIGXCPU", "CPU time limit exceeded"}, + {31, "SIGXFSZ", "file size limit exceeded"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_mips64.go b/vendor/golang.org/x/sys/unix/zerrors_linux_mips64.go index 423f48ae09b..37e851aabe4 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_mips64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_mips64.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x1008 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x1007 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x40081270 BLKBSZSET = 0x80081271 BLKFLSBUF = 0x20001261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x2000 BSDLY = 0x2000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0x100f CBAUDEX = 0x1000 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0x100f0000 CLOCAL = 0x800 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x200 CR2 = 0x400 CR3 = 0x600 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x600 CREAD = 0x80 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x40 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x800 ECHONL = 0x40 ECHOPRT = 0x400 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x80 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -481,6 +510,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +572,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x400 IBSHIFT = 0x10 ICANON = 0x2 @@ -792,12 +865,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x1 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x200 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x1000 IXON = 0x400 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -894,9 +969,15 @@ const ( MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MCL_ONFAULT = 0x4 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -956,7 +1037,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -991,6 +1074,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NLA_ALIGNTO = 0x4 @@ -1023,6 +1137,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1030,7 +1146,9 @@ const ( ONLCR = 0x4 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x8 O_ASYNC = 0x1000 @@ -1117,14 +1235,17 @@ const ( PERF_EVENT_IOC_ID = 0x40082407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x80042409 PERF_EVENT_IOC_PERIOD = 0x80082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc008240a PERF_EVENT_IOC_REFRESH = 0x20002402 PERF_EVENT_IOC_RESET = 0x20002403 PERF_EVENT_IOC_SET_BPF = 0x80042408 PERF_EVENT_IOC_SET_FILTER = 0x80082406 PERF_EVENT_IOC_SET_OUTPUT = 0x20002405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1230,6 +1351,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1278,6 +1400,7 @@ const ( PTRACE_POKETEXT_3264 = 0xc2 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETFPREGS = 0xf PTRACE_SETOPTIONS = 0x4200 @@ -1290,6 +1413,11 @@ const ( PTRACE_SINGLESTEP = 0x9 PTRACE_SYSCALL = 0x18 PTRACE_TRACEME = 0x0 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x6 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1475,6 +1603,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1559,6 +1689,23 @@ const ( SIOCSPGRP = 0x80047308 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x1 @@ -1670,6 +1817,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1691,6 +1840,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1873,7 +2023,27 @@ const ( TIOCSTI = 0x5472 TIOCSWINSZ = 0x80087467 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x8000 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x801054d5 TUNDETACHFILTER = 0x801054d6 @@ -1885,6 +2055,7 @@ const ( TUNGETVNETHDRSZ = 0x400454d7 TUNGETVNETLE = 0x400454dd TUNSETDEBUG = 0x800454c9 + TUNSETFILTEREBPF = 0x400454e1 TUNSETGROUP = 0x800454ce TUNSETIFF = 0x800454ca TUNSETIFINDEX = 0x800454da @@ -1895,13 +2066,17 @@ const ( TUNSETPERSIST = 0x800454cb TUNSETQUEUE = 0x800454d9 TUNSETSNDBUF = 0x800454d4 + TUNSETSTEERINGEBPF = 0x400454e0 TUNSETTXFILTER = 0x800454d1 TUNSETVNETBE = 0x800454de TUNSETVNETHDRSZ = 0x800454d8 TUNSETVNETLE = 0x800454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0xd VEOF = 0x10 VEOL = 0x11 @@ -1944,6 +2119,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -1953,7 +2208,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0x1800 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2135,174 +2392,182 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "no message of desired type", - 36: "identifier removed", - 37: "channel number out of range", - 38: "level 2 not synchronized", - 39: "level 3 halted", - 40: "level 3 reset", - 41: "link number out of range", - 42: "protocol driver not attached", - 43: "no CSI structure available", - 44: "level 2 halted", - 45: "resource deadlock avoided", - 46: "no locks available", - 50: "invalid exchange", - 51: "invalid request descriptor", - 52: "exchange full", - 53: "no anode", - 54: "invalid request code", - 55: "invalid slot", - 56: "file locking deadlock error", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 73: "RFS specific error", - 74: "multihop attempted", - 77: "bad message", - 78: "file name too long", - 79: "value too large for defined data type", - 80: "name not unique on network", - 81: "file descriptor in bad state", - 82: "remote address changed", - 83: "can not access a needed shared library", - 84: "accessing a corrupted shared library", - 85: ".lib section in a.out corrupted", - 86: "attempting to link in too many shared libraries", - 87: "cannot exec a shared library directly", - 88: "invalid or incomplete multibyte or wide character", - 89: "function not implemented", - 90: "too many levels of symbolic links", - 91: "interrupted system call should be restarted", - 92: "streams pipe error", - 93: "directory not empty", - 94: "too many users", - 95: "socket operation on non-socket", - 96: "destination address required", - 97: "message too long", - 98: "protocol wrong type for socket", - 99: "protocol not available", - 120: "protocol not supported", - 121: "socket type not supported", - 122: "operation not supported", - 123: "protocol family not supported", - 124: "address family not supported by protocol", - 125: "address already in use", - 126: "cannot assign requested address", - 127: "network is down", - 128: "network is unreachable", - 129: "network dropped connection on reset", - 130: "software caused connection abort", - 131: "connection reset by peer", - 132: "no buffer space available", - 133: "transport endpoint is already connected", - 134: "transport endpoint is not connected", - 135: "structure needs cleaning", - 137: "not a XENIX named type file", - 138: "no XENIX semaphores available", - 139: "is a named type file", - 140: "remote I/O error", - 141: "unknown error 141", - 142: "unknown error 142", - 143: "cannot send after transport endpoint shutdown", - 144: "too many references: cannot splice", - 145: "connection timed out", - 146: "connection refused", - 147: "host is down", - 148: "no route to host", - 149: "operation already in progress", - 150: "operation now in progress", - 151: "stale file handle", - 158: "operation canceled", - 159: "no medium found", - 160: "wrong medium type", - 161: "required key not available", - 162: "key has expired", - 163: "key has been revoked", - 164: "key was rejected by service", - 165: "owner died", - 166: "state not recoverable", - 167: "operation not possible due to RF-kill", - 168: "memory page has hardware error", - 1133: "disk quota exceeded", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "ENOMSG", "no message of desired type"}, + {36, "EIDRM", "identifier removed"}, + {37, "ECHRNG", "channel number out of range"}, + {38, "EL2NSYNC", "level 2 not synchronized"}, + {39, "EL3HLT", "level 3 halted"}, + {40, "EL3RST", "level 3 reset"}, + {41, "ELNRNG", "link number out of range"}, + {42, "EUNATCH", "protocol driver not attached"}, + {43, "ENOCSI", "no CSI structure available"}, + {44, "EL2HLT", "level 2 halted"}, + {45, "EDEADLK", "resource deadlock avoided"}, + {46, "ENOLCK", "no locks available"}, + {50, "EBADE", "invalid exchange"}, + {51, "EBADR", "invalid request descriptor"}, + {52, "EXFULL", "exchange full"}, + {53, "ENOANO", "no anode"}, + {54, "EBADRQC", "invalid request code"}, + {55, "EBADSLT", "invalid slot"}, + {56, "EDEADLOCK", "file locking deadlock error"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EMULTIHOP", "multihop attempted"}, + {77, "EBADMSG", "bad message"}, + {78, "ENAMETOOLONG", "file name too long"}, + {79, "EOVERFLOW", "value too large for defined data type"}, + {80, "ENOTUNIQ", "name not unique on network"}, + {81, "EBADFD", "file descriptor in bad state"}, + {82, "EREMCHG", "remote address changed"}, + {83, "ELIBACC", "can not access a needed shared library"}, + {84, "ELIBBAD", "accessing a corrupted shared library"}, + {85, "ELIBSCN", ".lib section in a.out corrupted"}, + {86, "ELIBMAX", "attempting to link in too many shared libraries"}, + {87, "ELIBEXEC", "cannot exec a shared library directly"}, + {88, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {89, "ENOSYS", "function not implemented"}, + {90, "ELOOP", "too many levels of symbolic links"}, + {91, "ERESTART", "interrupted system call should be restarted"}, + {92, "ESTRPIPE", "streams pipe error"}, + {93, "ENOTEMPTY", "directory not empty"}, + {94, "EUSERS", "too many users"}, + {95, "ENOTSOCK", "socket operation on non-socket"}, + {96, "EDESTADDRREQ", "destination address required"}, + {97, "EMSGSIZE", "message too long"}, + {98, "EPROTOTYPE", "protocol wrong type for socket"}, + {99, "ENOPROTOOPT", "protocol not available"}, + {120, "EPROTONOSUPPORT", "protocol not supported"}, + {121, "ESOCKTNOSUPPORT", "socket type not supported"}, + {122, "ENOTSUP", "operation not supported"}, + {123, "EPFNOSUPPORT", "protocol family not supported"}, + {124, "EAFNOSUPPORT", "address family not supported by protocol"}, + {125, "EADDRINUSE", "address already in use"}, + {126, "EADDRNOTAVAIL", "cannot assign requested address"}, + {127, "ENETDOWN", "network is down"}, + {128, "ENETUNREACH", "network is unreachable"}, + {129, "ENETRESET", "network dropped connection on reset"}, + {130, "ECONNABORTED", "software caused connection abort"}, + {131, "ECONNRESET", "connection reset by peer"}, + {132, "ENOBUFS", "no buffer space available"}, + {133, "EISCONN", "transport endpoint is already connected"}, + {134, "ENOTCONN", "transport endpoint is not connected"}, + {135, "EUCLEAN", "structure needs cleaning"}, + {137, "ENOTNAM", "not a XENIX named type file"}, + {138, "ENAVAIL", "no XENIX semaphores available"}, + {139, "EISNAM", "is a named type file"}, + {140, "EREMOTEIO", "remote I/O error"}, + {141, "EINIT", "unknown error 141"}, + {142, "EREMDEV", "unknown error 142"}, + {143, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {144, "ETOOMANYREFS", "too many references: cannot splice"}, + {145, "ETIMEDOUT", "connection timed out"}, + {146, "ECONNREFUSED", "connection refused"}, + {147, "EHOSTDOWN", "host is down"}, + {148, "EHOSTUNREACH", "no route to host"}, + {149, "EALREADY", "operation already in progress"}, + {150, "EINPROGRESS", "operation now in progress"}, + {151, "ESTALE", "stale file handle"}, + {158, "ECANCELED", "operation canceled"}, + {159, "ENOMEDIUM", "no medium found"}, + {160, "EMEDIUMTYPE", "wrong medium type"}, + {161, "ENOKEY", "required key not available"}, + {162, "EKEYEXPIRED", "key has expired"}, + {163, "EKEYREVOKED", "key has been revoked"}, + {164, "EKEYREJECTED", "key was rejected by service"}, + {165, "EOWNERDEAD", "owner died"}, + {166, "ENOTRECOVERABLE", "state not recoverable"}, + {167, "ERFKILL", "operation not possible due to RF-kill"}, + {168, "EHWPOISON", "memory page has hardware error"}, + {1133, "EDQUOT", "disk quota exceeded"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "user defined signal 1", - 17: "user defined signal 2", - 18: "child exited", - 19: "power failure", - 20: "window changed", - 21: "urgent I/O condition", - 22: "I/O possible", - 23: "stopped (signal)", - 24: "stopped", - 25: "continued", - 26: "stopped (tty input)", - 27: "stopped (tty output)", - 28: "virtual timer expired", - 29: "profiling timer expired", - 30: "CPU time limit exceeded", - 31: "file size limit exceeded", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGUSR1", "user defined signal 1"}, + {17, "SIGUSR2", "user defined signal 2"}, + {18, "SIGCHLD", "child exited"}, + {19, "SIGPWR", "power failure"}, + {20, "SIGWINCH", "window changed"}, + {21, "SIGURG", "urgent I/O condition"}, + {22, "SIGIO", "I/O possible"}, + {23, "SIGSTOP", "stopped (signal)"}, + {24, "SIGTSTP", "stopped"}, + {25, "SIGCONT", "continued"}, + {26, "SIGTTIN", "stopped (tty input)"}, + {27, "SIGTTOU", "stopped (tty output)"}, + {28, "SIGVTALRM", "virtual timer expired"}, + {29, "SIGPROF", "profiling timer expired"}, + {30, "SIGXCPU", "CPU time limit exceeded"}, + {31, "SIGXFSZ", "file size limit exceeded"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_mips64le.go b/vendor/golang.org/x/sys/unix/zerrors_linux_mips64le.go index 5e406070180..1131d3ca165 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_mips64le.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_mips64le.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x1008 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x1007 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x40081270 BLKBSZSET = 0x80081271 BLKFLSBUF = 0x20001261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x2000 BSDLY = 0x2000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0x100f CBAUDEX = 0x1000 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0x100f0000 CLOCAL = 0x800 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x200 CR2 = 0x400 CR3 = 0x600 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x600 CREAD = 0x80 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x40 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x800 ECHONL = 0x40 ECHOPRT = 0x400 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x80 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -481,6 +510,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +572,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x400 IBSHIFT = 0x10 ICANON = 0x2 @@ -792,12 +865,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x1 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x200 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x1000 IXON = 0x400 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -894,9 +969,15 @@ const ( MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MCL_ONFAULT = 0x4 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -956,7 +1037,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -991,6 +1074,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NLA_ALIGNTO = 0x4 @@ -1023,6 +1137,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1030,7 +1146,9 @@ const ( ONLCR = 0x4 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x8 O_ASYNC = 0x1000 @@ -1117,14 +1235,17 @@ const ( PERF_EVENT_IOC_ID = 0x40082407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x80042409 PERF_EVENT_IOC_PERIOD = 0x80082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc008240a PERF_EVENT_IOC_REFRESH = 0x20002402 PERF_EVENT_IOC_RESET = 0x20002403 PERF_EVENT_IOC_SET_BPF = 0x80042408 PERF_EVENT_IOC_SET_FILTER = 0x80082406 PERF_EVENT_IOC_SET_OUTPUT = 0x20002405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1230,6 +1351,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1278,6 +1400,7 @@ const ( PTRACE_POKETEXT_3264 = 0xc2 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETFPREGS = 0xf PTRACE_SETOPTIONS = 0x4200 @@ -1290,6 +1413,11 @@ const ( PTRACE_SINGLESTEP = 0x9 PTRACE_SYSCALL = 0x18 PTRACE_TRACEME = 0x0 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x6 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1475,6 +1603,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1559,6 +1689,23 @@ const ( SIOCSPGRP = 0x80047308 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x1 @@ -1670,6 +1817,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1691,6 +1840,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1873,7 +2023,27 @@ const ( TIOCSTI = 0x5472 TIOCSWINSZ = 0x80087467 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x8000 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x801054d5 TUNDETACHFILTER = 0x801054d6 @@ -1885,6 +2055,7 @@ const ( TUNGETVNETHDRSZ = 0x400454d7 TUNGETVNETLE = 0x400454dd TUNSETDEBUG = 0x800454c9 + TUNSETFILTEREBPF = 0x400454e1 TUNSETGROUP = 0x800454ce TUNSETIFF = 0x800454ca TUNSETIFINDEX = 0x800454da @@ -1895,13 +2066,17 @@ const ( TUNSETPERSIST = 0x800454cb TUNSETQUEUE = 0x800454d9 TUNSETSNDBUF = 0x800454d4 + TUNSETSTEERINGEBPF = 0x400454e0 TUNSETTXFILTER = 0x800454d1 TUNSETVNETBE = 0x800454de TUNSETVNETHDRSZ = 0x800454d8 TUNSETVNETLE = 0x800454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0xd VEOF = 0x10 VEOL = 0x11 @@ -1944,6 +2119,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -1953,7 +2208,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0x1800 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2135,174 +2392,182 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "no message of desired type", - 36: "identifier removed", - 37: "channel number out of range", - 38: "level 2 not synchronized", - 39: "level 3 halted", - 40: "level 3 reset", - 41: "link number out of range", - 42: "protocol driver not attached", - 43: "no CSI structure available", - 44: "level 2 halted", - 45: "resource deadlock avoided", - 46: "no locks available", - 50: "invalid exchange", - 51: "invalid request descriptor", - 52: "exchange full", - 53: "no anode", - 54: "invalid request code", - 55: "invalid slot", - 56: "file locking deadlock error", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 73: "RFS specific error", - 74: "multihop attempted", - 77: "bad message", - 78: "file name too long", - 79: "value too large for defined data type", - 80: "name not unique on network", - 81: "file descriptor in bad state", - 82: "remote address changed", - 83: "can not access a needed shared library", - 84: "accessing a corrupted shared library", - 85: ".lib section in a.out corrupted", - 86: "attempting to link in too many shared libraries", - 87: "cannot exec a shared library directly", - 88: "invalid or incomplete multibyte or wide character", - 89: "function not implemented", - 90: "too many levels of symbolic links", - 91: "interrupted system call should be restarted", - 92: "streams pipe error", - 93: "directory not empty", - 94: "too many users", - 95: "socket operation on non-socket", - 96: "destination address required", - 97: "message too long", - 98: "protocol wrong type for socket", - 99: "protocol not available", - 120: "protocol not supported", - 121: "socket type not supported", - 122: "operation not supported", - 123: "protocol family not supported", - 124: "address family not supported by protocol", - 125: "address already in use", - 126: "cannot assign requested address", - 127: "network is down", - 128: "network is unreachable", - 129: "network dropped connection on reset", - 130: "software caused connection abort", - 131: "connection reset by peer", - 132: "no buffer space available", - 133: "transport endpoint is already connected", - 134: "transport endpoint is not connected", - 135: "structure needs cleaning", - 137: "not a XENIX named type file", - 138: "no XENIX semaphores available", - 139: "is a named type file", - 140: "remote I/O error", - 141: "unknown error 141", - 142: "unknown error 142", - 143: "cannot send after transport endpoint shutdown", - 144: "too many references: cannot splice", - 145: "connection timed out", - 146: "connection refused", - 147: "host is down", - 148: "no route to host", - 149: "operation already in progress", - 150: "operation now in progress", - 151: "stale file handle", - 158: "operation canceled", - 159: "no medium found", - 160: "wrong medium type", - 161: "required key not available", - 162: "key has expired", - 163: "key has been revoked", - 164: "key was rejected by service", - 165: "owner died", - 166: "state not recoverable", - 167: "operation not possible due to RF-kill", - 168: "memory page has hardware error", - 1133: "disk quota exceeded", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "ENOMSG", "no message of desired type"}, + {36, "EIDRM", "identifier removed"}, + {37, "ECHRNG", "channel number out of range"}, + {38, "EL2NSYNC", "level 2 not synchronized"}, + {39, "EL3HLT", "level 3 halted"}, + {40, "EL3RST", "level 3 reset"}, + {41, "ELNRNG", "link number out of range"}, + {42, "EUNATCH", "protocol driver not attached"}, + {43, "ENOCSI", "no CSI structure available"}, + {44, "EL2HLT", "level 2 halted"}, + {45, "EDEADLK", "resource deadlock avoided"}, + {46, "ENOLCK", "no locks available"}, + {50, "EBADE", "invalid exchange"}, + {51, "EBADR", "invalid request descriptor"}, + {52, "EXFULL", "exchange full"}, + {53, "ENOANO", "no anode"}, + {54, "EBADRQC", "invalid request code"}, + {55, "EBADSLT", "invalid slot"}, + {56, "EDEADLOCK", "file locking deadlock error"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EMULTIHOP", "multihop attempted"}, + {77, "EBADMSG", "bad message"}, + {78, "ENAMETOOLONG", "file name too long"}, + {79, "EOVERFLOW", "value too large for defined data type"}, + {80, "ENOTUNIQ", "name not unique on network"}, + {81, "EBADFD", "file descriptor in bad state"}, + {82, "EREMCHG", "remote address changed"}, + {83, "ELIBACC", "can not access a needed shared library"}, + {84, "ELIBBAD", "accessing a corrupted shared library"}, + {85, "ELIBSCN", ".lib section in a.out corrupted"}, + {86, "ELIBMAX", "attempting to link in too many shared libraries"}, + {87, "ELIBEXEC", "cannot exec a shared library directly"}, + {88, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {89, "ENOSYS", "function not implemented"}, + {90, "ELOOP", "too many levels of symbolic links"}, + {91, "ERESTART", "interrupted system call should be restarted"}, + {92, "ESTRPIPE", "streams pipe error"}, + {93, "ENOTEMPTY", "directory not empty"}, + {94, "EUSERS", "too many users"}, + {95, "ENOTSOCK", "socket operation on non-socket"}, + {96, "EDESTADDRREQ", "destination address required"}, + {97, "EMSGSIZE", "message too long"}, + {98, "EPROTOTYPE", "protocol wrong type for socket"}, + {99, "ENOPROTOOPT", "protocol not available"}, + {120, "EPROTONOSUPPORT", "protocol not supported"}, + {121, "ESOCKTNOSUPPORT", "socket type not supported"}, + {122, "ENOTSUP", "operation not supported"}, + {123, "EPFNOSUPPORT", "protocol family not supported"}, + {124, "EAFNOSUPPORT", "address family not supported by protocol"}, + {125, "EADDRINUSE", "address already in use"}, + {126, "EADDRNOTAVAIL", "cannot assign requested address"}, + {127, "ENETDOWN", "network is down"}, + {128, "ENETUNREACH", "network is unreachable"}, + {129, "ENETRESET", "network dropped connection on reset"}, + {130, "ECONNABORTED", "software caused connection abort"}, + {131, "ECONNRESET", "connection reset by peer"}, + {132, "ENOBUFS", "no buffer space available"}, + {133, "EISCONN", "transport endpoint is already connected"}, + {134, "ENOTCONN", "transport endpoint is not connected"}, + {135, "EUCLEAN", "structure needs cleaning"}, + {137, "ENOTNAM", "not a XENIX named type file"}, + {138, "ENAVAIL", "no XENIX semaphores available"}, + {139, "EISNAM", "is a named type file"}, + {140, "EREMOTEIO", "remote I/O error"}, + {141, "EINIT", "unknown error 141"}, + {142, "EREMDEV", "unknown error 142"}, + {143, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {144, "ETOOMANYREFS", "too many references: cannot splice"}, + {145, "ETIMEDOUT", "connection timed out"}, + {146, "ECONNREFUSED", "connection refused"}, + {147, "EHOSTDOWN", "host is down"}, + {148, "EHOSTUNREACH", "no route to host"}, + {149, "EALREADY", "operation already in progress"}, + {150, "EINPROGRESS", "operation now in progress"}, + {151, "ESTALE", "stale file handle"}, + {158, "ECANCELED", "operation canceled"}, + {159, "ENOMEDIUM", "no medium found"}, + {160, "EMEDIUMTYPE", "wrong medium type"}, + {161, "ENOKEY", "required key not available"}, + {162, "EKEYEXPIRED", "key has expired"}, + {163, "EKEYREVOKED", "key has been revoked"}, + {164, "EKEYREJECTED", "key was rejected by service"}, + {165, "EOWNERDEAD", "owner died"}, + {166, "ENOTRECOVERABLE", "state not recoverable"}, + {167, "ERFKILL", "operation not possible due to RF-kill"}, + {168, "EHWPOISON", "memory page has hardware error"}, + {1133, "EDQUOT", "disk quota exceeded"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "user defined signal 1", - 17: "user defined signal 2", - 18: "child exited", - 19: "power failure", - 20: "window changed", - 21: "urgent I/O condition", - 22: "I/O possible", - 23: "stopped (signal)", - 24: "stopped", - 25: "continued", - 26: "stopped (tty input)", - 27: "stopped (tty output)", - 28: "virtual timer expired", - 29: "profiling timer expired", - 30: "CPU time limit exceeded", - 31: "file size limit exceeded", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGUSR1", "user defined signal 1"}, + {17, "SIGUSR2", "user defined signal 2"}, + {18, "SIGCHLD", "child exited"}, + {19, "SIGPWR", "power failure"}, + {20, "SIGWINCH", "window changed"}, + {21, "SIGURG", "urgent I/O condition"}, + {22, "SIGIO", "I/O possible"}, + {23, "SIGSTOP", "stopped (signal)"}, + {24, "SIGTSTP", "stopped"}, + {25, "SIGCONT", "continued"}, + {26, "SIGTTIN", "stopped (tty input)"}, + {27, "SIGTTOU", "stopped (tty output)"}, + {28, "SIGVTALRM", "virtual timer expired"}, + {29, "SIGPROF", "profiling timer expired"}, + {30, "SIGXCPU", "CPU time limit exceeded"}, + {31, "SIGXFSZ", "file size limit exceeded"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_mipsle.go b/vendor/golang.org/x/sys/unix/zerrors_linux_mipsle.go index b9b9d6374fe..d04a43b2bc7 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_mipsle.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_mipsle.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x1008 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x1007 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x40041270 BLKBSZSET = 0x80041271 BLKFLSBUF = 0x20001261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x2000 BSDLY = 0x2000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0x100f CBAUDEX = 0x1000 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0x100f0000 CLOCAL = 0x800 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x200 CR2 = 0x400 CR3 = 0x600 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x600 CREAD = 0x80 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x40 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x800 ECHONL = 0x40 ECHOPRT = 0x400 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x80 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -481,6 +510,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +572,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x400 IBSHIFT = 0x10 ICANON = 0x2 @@ -792,12 +865,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x1 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x200 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x1000 IXON = 0x400 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -894,9 +969,15 @@ const ( MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MCL_ONFAULT = 0x4 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -956,7 +1037,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -991,6 +1074,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NLA_ALIGNTO = 0x4 @@ -1023,6 +1137,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1030,7 +1146,9 @@ const ( ONLCR = 0x4 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x8 O_ASYNC = 0x1000 @@ -1117,14 +1235,17 @@ const ( PERF_EVENT_IOC_ID = 0x40042407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x80042409 PERF_EVENT_IOC_PERIOD = 0x80082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc004240a PERF_EVENT_IOC_REFRESH = 0x20002402 PERF_EVENT_IOC_RESET = 0x20002403 PERF_EVENT_IOC_SET_BPF = 0x80042408 PERF_EVENT_IOC_SET_FILTER = 0x80042406 PERF_EVENT_IOC_SET_OUTPUT = 0x20002405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1230,6 +1351,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1278,6 +1400,7 @@ const ( PTRACE_POKETEXT_3264 = 0xc2 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETFPREGS = 0xf PTRACE_SETOPTIONS = 0x4200 @@ -1290,6 +1413,11 @@ const ( PTRACE_SINGLESTEP = 0x9 PTRACE_SYSCALL = 0x18 PTRACE_TRACEME = 0x0 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x6 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1475,6 +1603,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1559,6 +1689,23 @@ const ( SIOCSPGRP = 0x80047308 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x1 @@ -1670,6 +1817,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1691,6 +1840,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1873,7 +2023,27 @@ const ( TIOCSTI = 0x5472 TIOCSWINSZ = 0x80087467 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x8000 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x800854d5 TUNDETACHFILTER = 0x800854d6 @@ -1885,6 +2055,7 @@ const ( TUNGETVNETHDRSZ = 0x400454d7 TUNGETVNETLE = 0x400454dd TUNSETDEBUG = 0x800454c9 + TUNSETFILTEREBPF = 0x400454e1 TUNSETGROUP = 0x800454ce TUNSETIFF = 0x800454ca TUNSETIFINDEX = 0x800454da @@ -1895,13 +2066,17 @@ const ( TUNSETPERSIST = 0x800454cb TUNSETQUEUE = 0x800454d9 TUNSETSNDBUF = 0x800454d4 + TUNSETSTEERINGEBPF = 0x400454e0 TUNSETTXFILTER = 0x800454d1 TUNSETVNETBE = 0x800454de TUNSETVNETHDRSZ = 0x800454d8 TUNSETVNETLE = 0x800454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0xd VEOF = 0x10 VEOL = 0x11 @@ -1944,6 +2119,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -1953,7 +2208,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0x1800 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2135,174 +2392,182 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "no message of desired type", - 36: "identifier removed", - 37: "channel number out of range", - 38: "level 2 not synchronized", - 39: "level 3 halted", - 40: "level 3 reset", - 41: "link number out of range", - 42: "protocol driver not attached", - 43: "no CSI structure available", - 44: "level 2 halted", - 45: "resource deadlock avoided", - 46: "no locks available", - 50: "invalid exchange", - 51: "invalid request descriptor", - 52: "exchange full", - 53: "no anode", - 54: "invalid request code", - 55: "invalid slot", - 56: "file locking deadlock error", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 73: "RFS specific error", - 74: "multihop attempted", - 77: "bad message", - 78: "file name too long", - 79: "value too large for defined data type", - 80: "name not unique on network", - 81: "file descriptor in bad state", - 82: "remote address changed", - 83: "can not access a needed shared library", - 84: "accessing a corrupted shared library", - 85: ".lib section in a.out corrupted", - 86: "attempting to link in too many shared libraries", - 87: "cannot exec a shared library directly", - 88: "invalid or incomplete multibyte or wide character", - 89: "function not implemented", - 90: "too many levels of symbolic links", - 91: "interrupted system call should be restarted", - 92: "streams pipe error", - 93: "directory not empty", - 94: "too many users", - 95: "socket operation on non-socket", - 96: "destination address required", - 97: "message too long", - 98: "protocol wrong type for socket", - 99: "protocol not available", - 120: "protocol not supported", - 121: "socket type not supported", - 122: "operation not supported", - 123: "protocol family not supported", - 124: "address family not supported by protocol", - 125: "address already in use", - 126: "cannot assign requested address", - 127: "network is down", - 128: "network is unreachable", - 129: "network dropped connection on reset", - 130: "software caused connection abort", - 131: "connection reset by peer", - 132: "no buffer space available", - 133: "transport endpoint is already connected", - 134: "transport endpoint is not connected", - 135: "structure needs cleaning", - 137: "not a XENIX named type file", - 138: "no XENIX semaphores available", - 139: "is a named type file", - 140: "remote I/O error", - 141: "unknown error 141", - 142: "unknown error 142", - 143: "cannot send after transport endpoint shutdown", - 144: "too many references: cannot splice", - 145: "connection timed out", - 146: "connection refused", - 147: "host is down", - 148: "no route to host", - 149: "operation already in progress", - 150: "operation now in progress", - 151: "stale file handle", - 158: "operation canceled", - 159: "no medium found", - 160: "wrong medium type", - 161: "required key not available", - 162: "key has expired", - 163: "key has been revoked", - 164: "key was rejected by service", - 165: "owner died", - 166: "state not recoverable", - 167: "operation not possible due to RF-kill", - 168: "memory page has hardware error", - 1133: "disk quota exceeded", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "ENOMSG", "no message of desired type"}, + {36, "EIDRM", "identifier removed"}, + {37, "ECHRNG", "channel number out of range"}, + {38, "EL2NSYNC", "level 2 not synchronized"}, + {39, "EL3HLT", "level 3 halted"}, + {40, "EL3RST", "level 3 reset"}, + {41, "ELNRNG", "link number out of range"}, + {42, "EUNATCH", "protocol driver not attached"}, + {43, "ENOCSI", "no CSI structure available"}, + {44, "EL2HLT", "level 2 halted"}, + {45, "EDEADLK", "resource deadlock avoided"}, + {46, "ENOLCK", "no locks available"}, + {50, "EBADE", "invalid exchange"}, + {51, "EBADR", "invalid request descriptor"}, + {52, "EXFULL", "exchange full"}, + {53, "ENOANO", "no anode"}, + {54, "EBADRQC", "invalid request code"}, + {55, "EBADSLT", "invalid slot"}, + {56, "EDEADLOCK", "file locking deadlock error"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EMULTIHOP", "multihop attempted"}, + {77, "EBADMSG", "bad message"}, + {78, "ENAMETOOLONG", "file name too long"}, + {79, "EOVERFLOW", "value too large for defined data type"}, + {80, "ENOTUNIQ", "name not unique on network"}, + {81, "EBADFD", "file descriptor in bad state"}, + {82, "EREMCHG", "remote address changed"}, + {83, "ELIBACC", "can not access a needed shared library"}, + {84, "ELIBBAD", "accessing a corrupted shared library"}, + {85, "ELIBSCN", ".lib section in a.out corrupted"}, + {86, "ELIBMAX", "attempting to link in too many shared libraries"}, + {87, "ELIBEXEC", "cannot exec a shared library directly"}, + {88, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {89, "ENOSYS", "function not implemented"}, + {90, "ELOOP", "too many levels of symbolic links"}, + {91, "ERESTART", "interrupted system call should be restarted"}, + {92, "ESTRPIPE", "streams pipe error"}, + {93, "ENOTEMPTY", "directory not empty"}, + {94, "EUSERS", "too many users"}, + {95, "ENOTSOCK", "socket operation on non-socket"}, + {96, "EDESTADDRREQ", "destination address required"}, + {97, "EMSGSIZE", "message too long"}, + {98, "EPROTOTYPE", "protocol wrong type for socket"}, + {99, "ENOPROTOOPT", "protocol not available"}, + {120, "EPROTONOSUPPORT", "protocol not supported"}, + {121, "ESOCKTNOSUPPORT", "socket type not supported"}, + {122, "ENOTSUP", "operation not supported"}, + {123, "EPFNOSUPPORT", "protocol family not supported"}, + {124, "EAFNOSUPPORT", "address family not supported by protocol"}, + {125, "EADDRINUSE", "address already in use"}, + {126, "EADDRNOTAVAIL", "cannot assign requested address"}, + {127, "ENETDOWN", "network is down"}, + {128, "ENETUNREACH", "network is unreachable"}, + {129, "ENETRESET", "network dropped connection on reset"}, + {130, "ECONNABORTED", "software caused connection abort"}, + {131, "ECONNRESET", "connection reset by peer"}, + {132, "ENOBUFS", "no buffer space available"}, + {133, "EISCONN", "transport endpoint is already connected"}, + {134, "ENOTCONN", "transport endpoint is not connected"}, + {135, "EUCLEAN", "structure needs cleaning"}, + {137, "ENOTNAM", "not a XENIX named type file"}, + {138, "ENAVAIL", "no XENIX semaphores available"}, + {139, "EISNAM", "is a named type file"}, + {140, "EREMOTEIO", "remote I/O error"}, + {141, "EINIT", "unknown error 141"}, + {142, "EREMDEV", "unknown error 142"}, + {143, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {144, "ETOOMANYREFS", "too many references: cannot splice"}, + {145, "ETIMEDOUT", "connection timed out"}, + {146, "ECONNREFUSED", "connection refused"}, + {147, "EHOSTDOWN", "host is down"}, + {148, "EHOSTUNREACH", "no route to host"}, + {149, "EALREADY", "operation already in progress"}, + {150, "EINPROGRESS", "operation now in progress"}, + {151, "ESTALE", "stale file handle"}, + {158, "ECANCELED", "operation canceled"}, + {159, "ENOMEDIUM", "no medium found"}, + {160, "EMEDIUMTYPE", "wrong medium type"}, + {161, "ENOKEY", "required key not available"}, + {162, "EKEYEXPIRED", "key has expired"}, + {163, "EKEYREVOKED", "key has been revoked"}, + {164, "EKEYREJECTED", "key was rejected by service"}, + {165, "EOWNERDEAD", "owner died"}, + {166, "ENOTRECOVERABLE", "state not recoverable"}, + {167, "ERFKILL", "operation not possible due to RF-kill"}, + {168, "EHWPOISON", "memory page has hardware error"}, + {1133, "EDQUOT", "disk quota exceeded"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "user defined signal 1", - 17: "user defined signal 2", - 18: "child exited", - 19: "power failure", - 20: "window changed", - 21: "urgent I/O condition", - 22: "I/O possible", - 23: "stopped (signal)", - 24: "stopped", - 25: "continued", - 26: "stopped (tty input)", - 27: "stopped (tty output)", - 28: "virtual timer expired", - 29: "profiling timer expired", - 30: "CPU time limit exceeded", - 31: "file size limit exceeded", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGUSR1", "user defined signal 1"}, + {17, "SIGUSR2", "user defined signal 2"}, + {18, "SIGCHLD", "child exited"}, + {19, "SIGPWR", "power failure"}, + {20, "SIGWINCH", "window changed"}, + {21, "SIGURG", "urgent I/O condition"}, + {22, "SIGIO", "I/O possible"}, + {23, "SIGSTOP", "stopped (signal)"}, + {24, "SIGTSTP", "stopped"}, + {25, "SIGCONT", "continued"}, + {26, "SIGTTIN", "stopped (tty input)"}, + {27, "SIGTTOU", "stopped (tty output)"}, + {28, "SIGVTALRM", "virtual timer expired"}, + {29, "SIGPROF", "profiling timer expired"}, + {30, "SIGXCPU", "CPU time limit exceeded"}, + {31, "SIGXFSZ", "file size limit exceeded"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_ppc64.go b/vendor/golang.org/x/sys/unix/zerrors_linux_ppc64.go index 509418ef2e0..710410efdd8 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_ppc64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_ppc64.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x17 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x16 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x40081270 BLKBSZSET = 0x80081271 BLKFLSBUF = 0x20001261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x8000 BSDLY = 0x8000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0xff CBAUDEX = 0x0 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0xff0000 CLOCAL = 0x8000 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x1000 CR2 = 0x2000 CR3 = 0x3000 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x3000 CREAD = 0x800 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x400 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x1 ECHONL = 0x10 ECHOPRT = 0x20 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x800 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -481,6 +510,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +572,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x4000 IBSHIFT = 0x10 ICANON = 0x100 @@ -792,12 +865,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x80 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x1000 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x400 IXON = 0x200 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -893,9 +968,15 @@ const ( MCL_CURRENT = 0x2000 MCL_FUTURE = 0x4000 MCL_ONFAULT = 0x8000 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -955,7 +1036,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -990,6 +1073,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NL2 = 0x200 @@ -1024,6 +1138,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80000000 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1031,7 +1147,9 @@ const ( ONLCR = 0x2 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x400 O_ASYNC = 0x2000 @@ -1118,14 +1236,17 @@ const ( PERF_EVENT_IOC_ID = 0x40082407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x80042409 PERF_EVENT_IOC_PERIOD = 0x80082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc008240a PERF_EVENT_IOC_REFRESH = 0x20002402 PERF_EVENT_IOC_RESET = 0x20002403 PERF_EVENT_IOC_SET_BPF = 0x80042408 PERF_EVENT_IOC_SET_FILTER = 0x80082406 PERF_EVENT_IOC_SET_OUTPUT = 0x20002405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1232,6 +1353,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1277,6 +1399,7 @@ const ( PTRACE_POKETEXT = 0x4 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETEVRREGS = 0x15 PTRACE_SETFPREGS = 0xf @@ -1346,6 +1469,11 @@ const ( PT_VSR0 = 0x96 PT_VSR31 = 0xd4 PT_XER = 0x25 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x9 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1531,6 +1659,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1615,6 +1745,23 @@ const ( SIOCSPGRP = 0x8902 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x2 @@ -1725,6 +1872,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1746,6 +1895,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1931,7 +2081,27 @@ const ( TIOCSTOP = 0x2000746f TIOCSWINSZ = 0x80087467 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x400000 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x801054d5 TUNDETACHFILTER = 0x801054d6 @@ -1943,6 +2113,7 @@ const ( TUNGETVNETHDRSZ = 0x400454d7 TUNGETVNETLE = 0x400454dd TUNSETDEBUG = 0x800454c9 + TUNSETFILTEREBPF = 0x400454e1 TUNSETGROUP = 0x800454ce TUNSETIFF = 0x800454ca TUNSETIFINDEX = 0x800454da @@ -1953,13 +2124,17 @@ const ( TUNSETPERSIST = 0x800454cb TUNSETQUEUE = 0x800454d9 TUNSETSNDBUF = 0x800454d4 + TUNSETSTEERINGEBPF = 0x400454e0 TUNSETTXFILTER = 0x800454d1 TUNSETVNETBE = 0x800454de TUNSETVNETHDRSZ = 0x800454d8 TUNSETVNETLE = 0x800454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0x10 VEOF = 0x4 VEOL = 0x6 @@ -2001,6 +2176,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -2010,7 +2265,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4000 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0xc00 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2190,172 +2447,180 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "resource deadlock avoided", - 36: "file name too long", - 37: "no locks available", - 38: "function not implemented", - 39: "directory not empty", - 40: "too many levels of symbolic links", - 42: "no message of desired type", - 43: "identifier removed", - 44: "channel number out of range", - 45: "level 2 not synchronized", - 46: "level 3 halted", - 47: "level 3 reset", - 48: "link number out of range", - 49: "protocol driver not attached", - 50: "no CSI structure available", - 51: "level 2 halted", - 52: "invalid exchange", - 53: "invalid request descriptor", - 54: "exchange full", - 55: "no anode", - 56: "invalid request code", - 57: "invalid slot", - 58: "file locking deadlock error", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 72: "multihop attempted", - 73: "RFS specific error", - 74: "bad message", - 75: "value too large for defined data type", - 76: "name not unique on network", - 77: "file descriptor in bad state", - 78: "remote address changed", - 79: "can not access a needed shared library", - 80: "accessing a corrupted shared library", - 81: ".lib section in a.out corrupted", - 82: "attempting to link in too many shared libraries", - 83: "cannot exec a shared library directly", - 84: "invalid or incomplete multibyte or wide character", - 85: "interrupted system call should be restarted", - 86: "streams pipe error", - 87: "too many users", - 88: "socket operation on non-socket", - 89: "destination address required", - 90: "message too long", - 91: "protocol wrong type for socket", - 92: "protocol not available", - 93: "protocol not supported", - 94: "socket type not supported", - 95: "operation not supported", - 96: "protocol family not supported", - 97: "address family not supported by protocol", - 98: "address already in use", - 99: "cannot assign requested address", - 100: "network is down", - 101: "network is unreachable", - 102: "network dropped connection on reset", - 103: "software caused connection abort", - 104: "connection reset by peer", - 105: "no buffer space available", - 106: "transport endpoint is already connected", - 107: "transport endpoint is not connected", - 108: "cannot send after transport endpoint shutdown", - 109: "too many references: cannot splice", - 110: "connection timed out", - 111: "connection refused", - 112: "host is down", - 113: "no route to host", - 114: "operation already in progress", - 115: "operation now in progress", - 116: "stale file handle", - 117: "structure needs cleaning", - 118: "not a XENIX named type file", - 119: "no XENIX semaphores available", - 120: "is a named type file", - 121: "remote I/O error", - 122: "disk quota exceeded", - 123: "no medium found", - 124: "wrong medium type", - 125: "operation canceled", - 126: "required key not available", - 127: "key has expired", - 128: "key has been revoked", - 129: "key was rejected by service", - 130: "owner died", - 131: "state not recoverable", - 132: "operation not possible due to RF-kill", - 133: "memory page has hardware error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "EDEADLK", "resource deadlock avoided"}, + {36, "ENAMETOOLONG", "file name too long"}, + {37, "ENOLCK", "no locks available"}, + {38, "ENOSYS", "function not implemented"}, + {39, "ENOTEMPTY", "directory not empty"}, + {40, "ELOOP", "too many levels of symbolic links"}, + {42, "ENOMSG", "no message of desired type"}, + {43, "EIDRM", "identifier removed"}, + {44, "ECHRNG", "channel number out of range"}, + {45, "EL2NSYNC", "level 2 not synchronized"}, + {46, "EL3HLT", "level 3 halted"}, + {47, "EL3RST", "level 3 reset"}, + {48, "ELNRNG", "link number out of range"}, + {49, "EUNATCH", "protocol driver not attached"}, + {50, "ENOCSI", "no CSI structure available"}, + {51, "EL2HLT", "level 2 halted"}, + {52, "EBADE", "invalid exchange"}, + {53, "EBADR", "invalid request descriptor"}, + {54, "EXFULL", "exchange full"}, + {55, "ENOANO", "no anode"}, + {56, "EBADRQC", "invalid request code"}, + {57, "EBADSLT", "invalid slot"}, + {58, "EDEADLOCK", "file locking deadlock error"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {72, "EMULTIHOP", "multihop attempted"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EBADMSG", "bad message"}, + {75, "EOVERFLOW", "value too large for defined data type"}, + {76, "ENOTUNIQ", "name not unique on network"}, + {77, "EBADFD", "file descriptor in bad state"}, + {78, "EREMCHG", "remote address changed"}, + {79, "ELIBACC", "can not access a needed shared library"}, + {80, "ELIBBAD", "accessing a corrupted shared library"}, + {81, "ELIBSCN", ".lib section in a.out corrupted"}, + {82, "ELIBMAX", "attempting to link in too many shared libraries"}, + {83, "ELIBEXEC", "cannot exec a shared library directly"}, + {84, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {85, "ERESTART", "interrupted system call should be restarted"}, + {86, "ESTRPIPE", "streams pipe error"}, + {87, "EUSERS", "too many users"}, + {88, "ENOTSOCK", "socket operation on non-socket"}, + {89, "EDESTADDRREQ", "destination address required"}, + {90, "EMSGSIZE", "message too long"}, + {91, "EPROTOTYPE", "protocol wrong type for socket"}, + {92, "ENOPROTOOPT", "protocol not available"}, + {93, "EPROTONOSUPPORT", "protocol not supported"}, + {94, "ESOCKTNOSUPPORT", "socket type not supported"}, + {95, "ENOTSUP", "operation not supported"}, + {96, "EPFNOSUPPORT", "protocol family not supported"}, + {97, "EAFNOSUPPORT", "address family not supported by protocol"}, + {98, "EADDRINUSE", "address already in use"}, + {99, "EADDRNOTAVAIL", "cannot assign requested address"}, + {100, "ENETDOWN", "network is down"}, + {101, "ENETUNREACH", "network is unreachable"}, + {102, "ENETRESET", "network dropped connection on reset"}, + {103, "ECONNABORTED", "software caused connection abort"}, + {104, "ECONNRESET", "connection reset by peer"}, + {105, "ENOBUFS", "no buffer space available"}, + {106, "EISCONN", "transport endpoint is already connected"}, + {107, "ENOTCONN", "transport endpoint is not connected"}, + {108, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {109, "ETOOMANYREFS", "too many references: cannot splice"}, + {110, "ETIMEDOUT", "connection timed out"}, + {111, "ECONNREFUSED", "connection refused"}, + {112, "EHOSTDOWN", "host is down"}, + {113, "EHOSTUNREACH", "no route to host"}, + {114, "EALREADY", "operation already in progress"}, + {115, "EINPROGRESS", "operation now in progress"}, + {116, "ESTALE", "stale file handle"}, + {117, "EUCLEAN", "structure needs cleaning"}, + {118, "ENOTNAM", "not a XENIX named type file"}, + {119, "ENAVAIL", "no XENIX semaphores available"}, + {120, "EISNAM", "is a named type file"}, + {121, "EREMOTEIO", "remote I/O error"}, + {122, "EDQUOT", "disk quota exceeded"}, + {123, "ENOMEDIUM", "no medium found"}, + {124, "EMEDIUMTYPE", "wrong medium type"}, + {125, "ECANCELED", "operation canceled"}, + {126, "ENOKEY", "required key not available"}, + {127, "EKEYEXPIRED", "key has expired"}, + {128, "EKEYREVOKED", "key has been revoked"}, + {129, "EKEYREJECTED", "key was rejected by service"}, + {130, "EOWNERDEAD", "owner died"}, + {131, "ENOTRECOVERABLE", "state not recoverable"}, + {132, "ERFKILL", "operation not possible due to RF-kill"}, + {133, "EHWPOISON", "memory page has hardware error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "bus error", - 8: "floating point exception", - 9: "killed", - 10: "user defined signal 1", - 11: "segmentation fault", - 12: "user defined signal 2", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "stack fault", - 17: "child exited", - 18: "continued", - 19: "stopped (signal)", - 20: "stopped", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "urgent I/O condition", - 24: "CPU time limit exceeded", - 25: "file size limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window changed", - 29: "I/O possible", - 30: "power failure", - 31: "bad system call", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGBUS", "bus error"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGUSR1", "user defined signal 1"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGUSR2", "user defined signal 2"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGSTKFLT", "stack fault"}, + {17, "SIGCHLD", "child exited"}, + {18, "SIGCONT", "continued"}, + {19, "SIGSTOP", "stopped (signal)"}, + {20, "SIGTSTP", "stopped"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGURG", "urgent I/O condition"}, + {24, "SIGXCPU", "CPU time limit exceeded"}, + {25, "SIGXFSZ", "file size limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window changed"}, + {29, "SIGIO", "I/O possible"}, + {30, "SIGPWR", "power failure"}, + {31, "SIGSYS", "bad system call"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_ppc64le.go b/vendor/golang.org/x/sys/unix/zerrors_linux_ppc64le.go index 26afbb8dedc..c1c1c01bcf5 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_ppc64le.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_ppc64le.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x17 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x16 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x40081270 BLKBSZSET = 0x80081271 BLKFLSBUF = 0x20001261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x8000 BSDLY = 0x8000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0xff CBAUDEX = 0x0 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0xff0000 CLOCAL = 0x8000 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x1000 CR2 = 0x2000 CR3 = 0x3000 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x3000 CREAD = 0x800 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x400 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x1 ECHONL = 0x10 ECHOPRT = 0x20 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x800 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -481,6 +510,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +572,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x4000 IBSHIFT = 0x10 ICANON = 0x100 @@ -792,12 +865,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x80 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x1000 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x400 IXON = 0x200 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -893,9 +968,15 @@ const ( MCL_CURRENT = 0x2000 MCL_FUTURE = 0x4000 MCL_ONFAULT = 0x8000 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -955,7 +1036,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -990,6 +1073,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NL2 = 0x200 @@ -1024,6 +1138,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80000000 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1031,7 +1147,9 @@ const ( ONLCR = 0x2 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x400 O_ASYNC = 0x2000 @@ -1118,14 +1236,17 @@ const ( PERF_EVENT_IOC_ID = 0x40082407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x80042409 PERF_EVENT_IOC_PERIOD = 0x80082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc008240a PERF_EVENT_IOC_REFRESH = 0x20002402 PERF_EVENT_IOC_RESET = 0x20002403 PERF_EVENT_IOC_SET_BPF = 0x80042408 PERF_EVENT_IOC_SET_FILTER = 0x80082406 PERF_EVENT_IOC_SET_OUTPUT = 0x20002405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1232,6 +1353,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1277,6 +1399,7 @@ const ( PTRACE_POKETEXT = 0x4 PTRACE_POKEUSR = 0x6 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETEVRREGS = 0x15 PTRACE_SETFPREGS = 0xf @@ -1346,6 +1469,11 @@ const ( PT_VSR0 = 0x96 PT_VSR31 = 0xd4 PT_XER = 0x25 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x9 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1531,6 +1659,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1615,6 +1745,23 @@ const ( SIOCSPGRP = 0x8902 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x2 @@ -1725,6 +1872,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1746,6 +1895,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1931,7 +2081,27 @@ const ( TIOCSTOP = 0x2000746f TIOCSWINSZ = 0x80087467 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x400000 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x801054d5 TUNDETACHFILTER = 0x801054d6 @@ -1943,6 +2113,7 @@ const ( TUNGETVNETHDRSZ = 0x400454d7 TUNGETVNETLE = 0x400454dd TUNSETDEBUG = 0x800454c9 + TUNSETFILTEREBPF = 0x400454e1 TUNSETGROUP = 0x800454ce TUNSETIFF = 0x800454ca TUNSETIFINDEX = 0x800454da @@ -1953,13 +2124,17 @@ const ( TUNSETPERSIST = 0x800454cb TUNSETQUEUE = 0x800454d9 TUNSETSNDBUF = 0x800454d4 + TUNSETSTEERINGEBPF = 0x400454e0 TUNSETTXFILTER = 0x800454d1 TUNSETVNETBE = 0x800454de TUNSETVNETHDRSZ = 0x800454d8 TUNSETVNETLE = 0x800454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0x10 VEOF = 0x4 VEOL = 0x6 @@ -2001,6 +2176,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -2010,7 +2265,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4000 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0xc00 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2190,172 +2447,180 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "resource deadlock avoided", - 36: "file name too long", - 37: "no locks available", - 38: "function not implemented", - 39: "directory not empty", - 40: "too many levels of symbolic links", - 42: "no message of desired type", - 43: "identifier removed", - 44: "channel number out of range", - 45: "level 2 not synchronized", - 46: "level 3 halted", - 47: "level 3 reset", - 48: "link number out of range", - 49: "protocol driver not attached", - 50: "no CSI structure available", - 51: "level 2 halted", - 52: "invalid exchange", - 53: "invalid request descriptor", - 54: "exchange full", - 55: "no anode", - 56: "invalid request code", - 57: "invalid slot", - 58: "file locking deadlock error", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 72: "multihop attempted", - 73: "RFS specific error", - 74: "bad message", - 75: "value too large for defined data type", - 76: "name not unique on network", - 77: "file descriptor in bad state", - 78: "remote address changed", - 79: "can not access a needed shared library", - 80: "accessing a corrupted shared library", - 81: ".lib section in a.out corrupted", - 82: "attempting to link in too many shared libraries", - 83: "cannot exec a shared library directly", - 84: "invalid or incomplete multibyte or wide character", - 85: "interrupted system call should be restarted", - 86: "streams pipe error", - 87: "too many users", - 88: "socket operation on non-socket", - 89: "destination address required", - 90: "message too long", - 91: "protocol wrong type for socket", - 92: "protocol not available", - 93: "protocol not supported", - 94: "socket type not supported", - 95: "operation not supported", - 96: "protocol family not supported", - 97: "address family not supported by protocol", - 98: "address already in use", - 99: "cannot assign requested address", - 100: "network is down", - 101: "network is unreachable", - 102: "network dropped connection on reset", - 103: "software caused connection abort", - 104: "connection reset by peer", - 105: "no buffer space available", - 106: "transport endpoint is already connected", - 107: "transport endpoint is not connected", - 108: "cannot send after transport endpoint shutdown", - 109: "too many references: cannot splice", - 110: "connection timed out", - 111: "connection refused", - 112: "host is down", - 113: "no route to host", - 114: "operation already in progress", - 115: "operation now in progress", - 116: "stale file handle", - 117: "structure needs cleaning", - 118: "not a XENIX named type file", - 119: "no XENIX semaphores available", - 120: "is a named type file", - 121: "remote I/O error", - 122: "disk quota exceeded", - 123: "no medium found", - 124: "wrong medium type", - 125: "operation canceled", - 126: "required key not available", - 127: "key has expired", - 128: "key has been revoked", - 129: "key was rejected by service", - 130: "owner died", - 131: "state not recoverable", - 132: "operation not possible due to RF-kill", - 133: "memory page has hardware error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "EDEADLK", "resource deadlock avoided"}, + {36, "ENAMETOOLONG", "file name too long"}, + {37, "ENOLCK", "no locks available"}, + {38, "ENOSYS", "function not implemented"}, + {39, "ENOTEMPTY", "directory not empty"}, + {40, "ELOOP", "too many levels of symbolic links"}, + {42, "ENOMSG", "no message of desired type"}, + {43, "EIDRM", "identifier removed"}, + {44, "ECHRNG", "channel number out of range"}, + {45, "EL2NSYNC", "level 2 not synchronized"}, + {46, "EL3HLT", "level 3 halted"}, + {47, "EL3RST", "level 3 reset"}, + {48, "ELNRNG", "link number out of range"}, + {49, "EUNATCH", "protocol driver not attached"}, + {50, "ENOCSI", "no CSI structure available"}, + {51, "EL2HLT", "level 2 halted"}, + {52, "EBADE", "invalid exchange"}, + {53, "EBADR", "invalid request descriptor"}, + {54, "EXFULL", "exchange full"}, + {55, "ENOANO", "no anode"}, + {56, "EBADRQC", "invalid request code"}, + {57, "EBADSLT", "invalid slot"}, + {58, "EDEADLOCK", "file locking deadlock error"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {72, "EMULTIHOP", "multihop attempted"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EBADMSG", "bad message"}, + {75, "EOVERFLOW", "value too large for defined data type"}, + {76, "ENOTUNIQ", "name not unique on network"}, + {77, "EBADFD", "file descriptor in bad state"}, + {78, "EREMCHG", "remote address changed"}, + {79, "ELIBACC", "can not access a needed shared library"}, + {80, "ELIBBAD", "accessing a corrupted shared library"}, + {81, "ELIBSCN", ".lib section in a.out corrupted"}, + {82, "ELIBMAX", "attempting to link in too many shared libraries"}, + {83, "ELIBEXEC", "cannot exec a shared library directly"}, + {84, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {85, "ERESTART", "interrupted system call should be restarted"}, + {86, "ESTRPIPE", "streams pipe error"}, + {87, "EUSERS", "too many users"}, + {88, "ENOTSOCK", "socket operation on non-socket"}, + {89, "EDESTADDRREQ", "destination address required"}, + {90, "EMSGSIZE", "message too long"}, + {91, "EPROTOTYPE", "protocol wrong type for socket"}, + {92, "ENOPROTOOPT", "protocol not available"}, + {93, "EPROTONOSUPPORT", "protocol not supported"}, + {94, "ESOCKTNOSUPPORT", "socket type not supported"}, + {95, "ENOTSUP", "operation not supported"}, + {96, "EPFNOSUPPORT", "protocol family not supported"}, + {97, "EAFNOSUPPORT", "address family not supported by protocol"}, + {98, "EADDRINUSE", "address already in use"}, + {99, "EADDRNOTAVAIL", "cannot assign requested address"}, + {100, "ENETDOWN", "network is down"}, + {101, "ENETUNREACH", "network is unreachable"}, + {102, "ENETRESET", "network dropped connection on reset"}, + {103, "ECONNABORTED", "software caused connection abort"}, + {104, "ECONNRESET", "connection reset by peer"}, + {105, "ENOBUFS", "no buffer space available"}, + {106, "EISCONN", "transport endpoint is already connected"}, + {107, "ENOTCONN", "transport endpoint is not connected"}, + {108, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {109, "ETOOMANYREFS", "too many references: cannot splice"}, + {110, "ETIMEDOUT", "connection timed out"}, + {111, "ECONNREFUSED", "connection refused"}, + {112, "EHOSTDOWN", "host is down"}, + {113, "EHOSTUNREACH", "no route to host"}, + {114, "EALREADY", "operation already in progress"}, + {115, "EINPROGRESS", "operation now in progress"}, + {116, "ESTALE", "stale file handle"}, + {117, "EUCLEAN", "structure needs cleaning"}, + {118, "ENOTNAM", "not a XENIX named type file"}, + {119, "ENAVAIL", "no XENIX semaphores available"}, + {120, "EISNAM", "is a named type file"}, + {121, "EREMOTEIO", "remote I/O error"}, + {122, "EDQUOT", "disk quota exceeded"}, + {123, "ENOMEDIUM", "no medium found"}, + {124, "EMEDIUMTYPE", "wrong medium type"}, + {125, "ECANCELED", "operation canceled"}, + {126, "ENOKEY", "required key not available"}, + {127, "EKEYEXPIRED", "key has expired"}, + {128, "EKEYREVOKED", "key has been revoked"}, + {129, "EKEYREJECTED", "key was rejected by service"}, + {130, "EOWNERDEAD", "owner died"}, + {131, "ENOTRECOVERABLE", "state not recoverable"}, + {132, "ERFKILL", "operation not possible due to RF-kill"}, + {133, "EHWPOISON", "memory page has hardware error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "bus error", - 8: "floating point exception", - 9: "killed", - 10: "user defined signal 1", - 11: "segmentation fault", - 12: "user defined signal 2", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "stack fault", - 17: "child exited", - 18: "continued", - 19: "stopped (signal)", - 20: "stopped", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "urgent I/O condition", - 24: "CPU time limit exceeded", - 25: "file size limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window changed", - 29: "I/O possible", - 30: "power failure", - 31: "bad system call", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGBUS", "bus error"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGUSR1", "user defined signal 1"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGUSR2", "user defined signal 2"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGSTKFLT", "stack fault"}, + {17, "SIGCHLD", "child exited"}, + {18, "SIGCONT", "continued"}, + {19, "SIGSTOP", "stopped (signal)"}, + {20, "SIGTSTP", "stopped"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGURG", "urgent I/O condition"}, + {24, "SIGXCPU", "CPU time limit exceeded"}, + {25, "SIGXFSZ", "file size limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window changed"}, + {29, "SIGIO", "I/O possible"}, + {30, "SIGPWR", "power failure"}, + {31, "SIGSYS", "bad system call"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_linux_s390x.go b/vendor/golang.org/x/sys/unix/zerrors_linux_s390x.go index eeb9941debd..c7583e15eb4 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_linux_s390x.go +++ b/vendor/golang.org/x/sys/unix/zerrors_linux_s390x.go @@ -11,6 +11,11 @@ package unix import "syscall" const ( + AAFS_MAGIC = 0x5a3c69f0 + ADFS_SUPER_MAGIC = 0xadf5 + AFFS_SUPER_MAGIC = 0xadff + AFS_FS_MAGIC = 0x6b414653 + AFS_SUPER_MAGIC = 0x5346414f AF_ALG = 0x26 AF_APPLETALK = 0x5 AF_ASH = 0x12 @@ -66,6 +71,7 @@ const ( ALG_SET_IV = 0x2 ALG_SET_KEY = 0x1 ALG_SET_OP = 0x3 + ANON_INODE_FS_MAGIC = 0x9041934 ARPHRD_6LOWPAN = 0x339 ARPHRD_ADAPT = 0x108 ARPHRD_APPLETLK = 0x8 @@ -133,6 +139,7 @@ const ( ARPHRD_VOID = 0xffff ARPHRD_VSOCKMON = 0x33a ARPHRD_X25 = 0x10f + AUTOFS_SUPER_MAGIC = 0x187 B0 = 0x0 B1000000 = 0x1008 B110 = 0x3 @@ -164,6 +171,9 @@ const ( B75 = 0x2 B921600 = 0x1007 B9600 = 0xd + BALLOON_KVM_MAGIC = 0x13661366 + BDEVFS_MAGIC = 0x62646576 + BINFMTFS_MAGIC = 0x42494e4d BLKBSZGET = 0x80081270 BLKBSZSET = 0x40081271 BLKFLSBUF = 0x1261 @@ -188,6 +198,7 @@ const ( BPF_AND = 0x50 BPF_B = 0x10 BPF_DIV = 0x30 + BPF_FS_MAGIC = 0xcafe4a11 BPF_H = 0x8 BPF_IMM = 0x0 BPF_IND = 0x40 @@ -229,6 +240,8 @@ const ( BS0 = 0x0 BS1 = 0x2000 BSDLY = 0x2000 + BTRFS_SUPER_MAGIC = 0x9123683e + BTRFS_TEST_MAGIC = 0x73727279 CAN_BCM = 0x2 CAN_EFF_FLAG = 0x80000000 CAN_EFF_ID_BITS = 0x1d @@ -252,6 +265,8 @@ const ( CBAUD = 0x100f CBAUDEX = 0x1000 CFLUSH = 0xf + CGROUP2_SUPER_MAGIC = 0x63677270 + CGROUP_SUPER_MAGIC = 0x27e0eb CIBAUD = 0x100f0000 CLOCAL = 0x800 CLOCK_BOOTTIME = 0x7 @@ -294,10 +309,12 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CMSPAR = 0x40000000 + CODA_SUPER_MAGIC = 0x73757245 CR0 = 0x0 CR1 = 0x200 CR2 = 0x400 CR3 = 0x600 + CRAMFS_MAGIC = 0x28cd3d45 CRDLY = 0x600 CREAD = 0x80 CRTSCTS = 0x80000000 @@ -312,6 +329,9 @@ const ( CSTOP = 0x13 CSTOPB = 0x40 CSUSP = 0x1a + DAXFS_MAGIC = 0x64646178 + DEBUGFS_MAGIC = 0x64626720 + DEVPTS_SUPER_MAGIC = 0x1cd1 DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -328,9 +348,12 @@ const ( ECHOKE = 0x800 ECHONL = 0x40 ECHOPRT = 0x400 + ECRYPTFS_SUPER_MAGIC = 0xf15f EFD_CLOEXEC = 0x80000 EFD_NONBLOCK = 0x800 EFD_SEMAPHORE = 0x1 + EFIVARFS_MAGIC = 0xde5e81e4 + EFS_SUPER_MAGIC = 0x414a53 ENCODING_DEFAULT = 0x0 ENCODING_FM_MARK = 0x3 ENCODING_FM_SPACE = 0x4 @@ -392,6 +415,7 @@ const ( ETH_P_ECONET = 0x18 ETH_P_EDSA = 0xdada ETH_P_ERSPAN = 0x88be + ETH_P_ERSPAN2 = 0x22eb ETH_P_FCOE = 0x8906 ETH_P_FIP = 0x8914 ETH_P_HDLC = 0x19 @@ -445,9 +469,14 @@ const ( ETH_P_WCCP = 0x883e ETH_P_X25 = 0x805 ETH_P_XDSA = 0xf8 + EXABYTE_ENABLE_NEST = 0xf0 + EXT2_SUPER_MAGIC = 0xef53 + EXT3_SUPER_MAGIC = 0xef53 + EXT4_SUPER_MAGIC = 0xef53 EXTA = 0xe EXTB = 0xf EXTPROC = 0x10000 + F2FS_SUPER_MAGIC = 0xf2f52010 FALLOC_FL_COLLAPSE_RANGE = 0x8 FALLOC_FL_INSERT_RANGE = 0x20 FALLOC_FL_KEEP_SIZE = 0x1 @@ -481,6 +510,7 @@ const ( FS_POLICY_FLAGS_PAD_8 = 0x1 FS_POLICY_FLAGS_PAD_MASK = 0x3 FS_POLICY_FLAGS_VALID = 0x3 + FUTEXFS_SUPER_MAGIC = 0xbad1dea F_ADD_SEALS = 0x409 F_DUPFD = 0x0 F_DUPFD_CLOEXEC = 0x406 @@ -542,6 +572,49 @@ const ( GENL_UNS_ADMIN_PERM = 0x10 GRND_NONBLOCK = 0x1 GRND_RANDOM = 0x2 + HDIO_DRIVE_CMD = 0x31f + HDIO_DRIVE_CMD_AEB = 0x31e + HDIO_DRIVE_CMD_HDR_SIZE = 0x4 + HDIO_DRIVE_HOB_HDR_SIZE = 0x8 + HDIO_DRIVE_RESET = 0x31c + HDIO_DRIVE_TASK = 0x31e + HDIO_DRIVE_TASKFILE = 0x31d + HDIO_DRIVE_TASK_HDR_SIZE = 0x8 + HDIO_GETGEO = 0x301 + HDIO_GET_32BIT = 0x309 + HDIO_GET_ACOUSTIC = 0x30f + HDIO_GET_ADDRESS = 0x310 + HDIO_GET_BUSSTATE = 0x31a + HDIO_GET_DMA = 0x30b + HDIO_GET_IDENTITY = 0x30d + HDIO_GET_KEEPSETTINGS = 0x308 + HDIO_GET_MULTCOUNT = 0x304 + HDIO_GET_NICE = 0x30c + HDIO_GET_NOWERR = 0x30a + HDIO_GET_QDMA = 0x305 + HDIO_GET_UNMASKINTR = 0x302 + HDIO_GET_WCACHE = 0x30e + HDIO_OBSOLETE_IDENTITY = 0x307 + HDIO_SCAN_HWIF = 0x328 + HDIO_SET_32BIT = 0x324 + HDIO_SET_ACOUSTIC = 0x32c + HDIO_SET_ADDRESS = 0x32f + HDIO_SET_BUSSTATE = 0x32d + HDIO_SET_DMA = 0x326 + HDIO_SET_KEEPSETTINGS = 0x323 + HDIO_SET_MULTCOUNT = 0x321 + HDIO_SET_NICE = 0x329 + HDIO_SET_NOWERR = 0x325 + HDIO_SET_PIO_MODE = 0x327 + HDIO_SET_QDMA = 0x32e + HDIO_SET_UNMASKINTR = 0x322 + HDIO_SET_WCACHE = 0x32b + HDIO_SET_XFER = 0x306 + HDIO_TRISTATE_HWIF = 0x31b + HDIO_UNREGISTER_HWIF = 0x32a + HOSTFS_SUPER_MAGIC = 0xc0ffee + HPFS_SUPER_MAGIC = 0xf995e849 + HUGETLBFS_MAGIC = 0x958458f6 HUPCL = 0x400 IBSHIFT = 0x10 ICANON = 0x2 @@ -792,12 +865,14 @@ const ( IP_UNICAST_IF = 0x32 IP_XFRM_POLICY = 0x11 ISIG = 0x1 + ISOFS_SUPER_MAGIC = 0x9660 ISTRIP = 0x20 IUCLC = 0x200 IUTF8 = 0x4000 IXANY = 0x800 IXOFF = 0x1000 IXON = 0x400 + JFFS2_SUPER_MAGIC = 0x72b6 KEYCTL_ASSUME_AUTHORITY = 0x10 KEYCTL_CHOWN = 0x4 KEYCTL_CLEAR = 0x7 @@ -893,9 +968,15 @@ const ( MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MCL_ONFAULT = 0x4 + MINIX2_SUPER_MAGIC = 0x2468 + MINIX2_SUPER_MAGIC2 = 0x2478 + MINIX3_SUPER_MAGIC = 0x4d5a + MINIX_SUPER_MAGIC = 0x137f + MINIX_SUPER_MAGIC2 = 0x138f MNT_DETACH = 0x2 MNT_EXPIRE = 0x4 MNT_FORCE = 0x1 + MSDOS_SUPER_MAGIC = 0x4d44 MSG_BATCH = 0x40000 MSG_CMSG_CLOEXEC = 0x40000000 MSG_CONFIRM = 0x800 @@ -955,7 +1036,9 @@ const ( MS_SYNCHRONOUS = 0x10 MS_UNBINDABLE = 0x20000 MS_VERBOSE = 0x8000 + MTD_INODE_FS_MAGIC = 0x11307854 NAME_MAX = 0xff + NCP_SUPER_MAGIC = 0x564c NETLINK_ADD_MEMBERSHIP = 0x1 NETLINK_AUDIT = 0x9 NETLINK_BROADCAST_ERROR = 0x4 @@ -990,6 +1073,37 @@ const ( NETLINK_UNUSED = 0x1 NETLINK_USERSOCK = 0x2 NETLINK_XFRM = 0x6 + NFNETLINK_V0 = 0x0 + NFNLGRP_ACCT_QUOTA = 0x8 + NFNLGRP_CONNTRACK_DESTROY = 0x3 + NFNLGRP_CONNTRACK_EXP_DESTROY = 0x6 + NFNLGRP_CONNTRACK_EXP_NEW = 0x4 + NFNLGRP_CONNTRACK_EXP_UPDATE = 0x5 + NFNLGRP_CONNTRACK_NEW = 0x1 + NFNLGRP_CONNTRACK_UPDATE = 0x2 + NFNLGRP_MAX = 0x9 + NFNLGRP_NFTABLES = 0x7 + NFNLGRP_NFTRACE = 0x9 + NFNLGRP_NONE = 0x0 + NFNL_BATCH_MAX = 0x1 + NFNL_MSG_BATCH_BEGIN = 0x10 + NFNL_MSG_BATCH_END = 0x11 + NFNL_NFA_NEST = 0x8000 + NFNL_SUBSYS_ACCT = 0x7 + NFNL_SUBSYS_COUNT = 0xc + NFNL_SUBSYS_CTHELPER = 0x9 + NFNL_SUBSYS_CTNETLINK = 0x1 + NFNL_SUBSYS_CTNETLINK_EXP = 0x2 + NFNL_SUBSYS_CTNETLINK_TIMEOUT = 0x8 + NFNL_SUBSYS_IPSET = 0x6 + NFNL_SUBSYS_NFTABLES = 0xa + NFNL_SUBSYS_NFT_COMPAT = 0xb + NFNL_SUBSYS_NONE = 0x0 + NFNL_SUBSYS_OSF = 0x5 + NFNL_SUBSYS_QUEUE = 0x3 + NFNL_SUBSYS_ULOG = 0x4 + NFS_SUPER_MAGIC = 0x6969 + NILFS_SUPER_MAGIC = 0x3434 NL0 = 0x0 NL1 = 0x100 NLA_ALIGNTO = 0x4 @@ -1022,6 +1136,8 @@ const ( NLM_F_REQUEST = 0x1 NLM_F_ROOT = 0x100 NOFLSH = 0x80 + NSFS_MAGIC = 0x6e736673 + OCFS2_SUPER_MAGIC = 0x7461636f OCRNL = 0x8 OFDEL = 0x80 OFILL = 0x40 @@ -1029,7 +1145,9 @@ const ( ONLCR = 0x4 ONLRET = 0x20 ONOCR = 0x10 + OPENPROM_SUPER_MAGIC = 0x9fa1 OPOST = 0x1 + OVERLAYFS_SUPER_MAGIC = 0x794c7630 O_ACCMODE = 0x3 O_APPEND = 0x400 O_ASYNC = 0x2000 @@ -1116,14 +1234,17 @@ const ( PERF_EVENT_IOC_ID = 0x80082407 PERF_EVENT_IOC_PAUSE_OUTPUT = 0x40042409 PERF_EVENT_IOC_PERIOD = 0x40082404 + PERF_EVENT_IOC_QUERY_BPF = 0xc008240a PERF_EVENT_IOC_REFRESH = 0x2402 PERF_EVENT_IOC_RESET = 0x2403 PERF_EVENT_IOC_SET_BPF = 0x40042408 PERF_EVENT_IOC_SET_FILTER = 0x40082406 PERF_EVENT_IOC_SET_OUTPUT = 0x2405 + PIPEFS_MAGIC = 0x50495045 PRIO_PGRP = 0x1 PRIO_PROCESS = 0x0 PRIO_USER = 0x2 + PROC_SUPER_MAGIC = 0x9fa0 PROT_EXEC = 0x4 PROT_GROWSDOWN = 0x1000000 PROT_GROWSUP = 0x2000000 @@ -1229,6 +1350,7 @@ const ( PR_TSC_SIGSEGV = 0x2 PR_UNALIGN_NOPRINT = 0x1 PR_UNALIGN_SIGBUS = 0x2 + PSTOREFS_MAGIC = 0x6165676c PTRACE_ATTACH = 0x10 PTRACE_CONT = 0x7 PTRACE_DETACH = 0x11 @@ -1281,6 +1403,7 @@ const ( PTRACE_POKE_SYSTEM_CALL = 0x5008 PTRACE_PROT = 0x15 PTRACE_SECCOMP_GET_FILTER = 0x420c + PTRACE_SECCOMP_GET_METADATA = 0x420d PTRACE_SEIZE = 0x4206 PTRACE_SETOPTIONS = 0x4200 PTRACE_SETREGS = 0xd @@ -1350,6 +1473,11 @@ const ( PT_ORIGGPR2 = 0xd0 PT_PSWADDR = 0x8 PT_PSWMASK = 0x0 + QNX4_SUPER_MAGIC = 0x2f + QNX6_SUPER_MAGIC = 0x68191122 + RAMFS_MAGIC = 0x858458f6 + RDTGROUP_SUPER_MAGIC = 0x7655821 + REISERFS_SUPER_MAGIC = 0x52654973 RLIMIT_AS = 0x9 RLIMIT_CORE = 0x4 RLIMIT_CPU = 0x0 @@ -1535,6 +1663,8 @@ const ( SECCOMP_MODE_DISABLED = 0x0 SECCOMP_MODE_FILTER = 0x2 SECCOMP_MODE_STRICT = 0x1 + SECURITYFS_MAGIC = 0x73636673 + SELINUX_MAGIC = 0xf97cff8c SHUT_RD = 0x0 SHUT_RDWR = 0x2 SHUT_WR = 0x1 @@ -1619,6 +1749,23 @@ const ( SIOCSPGRP = 0x8902 SIOCSRARP = 0x8962 SIOCWANDEV = 0x894a + SMACK_MAGIC = 0x43415d53 + SMART_AUTOSAVE = 0xd2 + SMART_AUTO_OFFLINE = 0xdb + SMART_DISABLE = 0xd9 + SMART_ENABLE = 0xd8 + SMART_HCYL_PASS = 0xc2 + SMART_IMMEDIATE_OFFLINE = 0xd4 + SMART_LCYL_PASS = 0x4f + SMART_READ_LOG_SECTOR = 0xd5 + SMART_READ_THRESHOLDS = 0xd1 + SMART_READ_VALUES = 0xd0 + SMART_SAVE = 0xd3 + SMART_STATUS = 0xda + SMART_WRITE_LOG_SECTOR = 0xd6 + SMART_WRITE_THRESHOLDS = 0xd7 + SMB_SUPER_MAGIC = 0x517b + SOCKFS_MAGIC = 0x534f434b SOCK_CLOEXEC = 0x80000 SOCK_DCCP = 0x6 SOCK_DGRAM = 0x2 @@ -1729,6 +1876,8 @@ const ( SPLICE_F_MORE = 0x4 SPLICE_F_MOVE = 0x1 SPLICE_F_NONBLOCK = 0x2 + SQUASHFS_MAGIC = 0x73717368 + STACK_END_MAGIC = 0x57ac6e9d STATX_ALL = 0xfff STATX_ATIME = 0x20 STATX_ATTR_APPEND = 0x20 @@ -1750,6 +1899,7 @@ const ( STATX_TYPE = 0x1 STATX_UID = 0x8 STATX__RESERVED = 0x80000000 + SYSFS_MAGIC = 0x62656572 S_BLKSIZE = 0x200 S_IEXEC = 0x40 S_IFBLK = 0x6000 @@ -1931,7 +2081,27 @@ const ( TIOCSTI = 0x5412 TIOCSWINSZ = 0x5414 TIOCVHANGUP = 0x5437 + TMPFS_MAGIC = 0x1021994 TOSTOP = 0x100 + TPACKET_ALIGNMENT = 0x10 + TPACKET_HDRLEN = 0x34 + TP_STATUS_AVAILABLE = 0x0 + TP_STATUS_BLK_TMO = 0x20 + TP_STATUS_COPY = 0x2 + TP_STATUS_CSUMNOTREADY = 0x8 + TP_STATUS_CSUM_VALID = 0x80 + TP_STATUS_KERNEL = 0x0 + TP_STATUS_LOSING = 0x4 + TP_STATUS_SENDING = 0x2 + TP_STATUS_SEND_REQUEST = 0x1 + TP_STATUS_TS_RAW_HARDWARE = -0x80000000 + TP_STATUS_TS_SOFTWARE = 0x20000000 + TP_STATUS_TS_SYS_HARDWARE = 0x40000000 + TP_STATUS_USER = 0x1 + TP_STATUS_VLAN_TPID_VALID = 0x40 + TP_STATUS_VLAN_VALID = 0x10 + TP_STATUS_WRONG_FORMAT = 0x4 + TRACEFS_MAGIC = 0x74726163 TS_COMM_LEN = 0x20 TUNATTACHFILTER = 0x401054d5 TUNDETACHFILTER = 0x401054d6 @@ -1943,6 +2113,7 @@ const ( TUNGETVNETHDRSZ = 0x800454d7 TUNGETVNETLE = 0x800454dd TUNSETDEBUG = 0x400454c9 + TUNSETFILTEREBPF = 0x800454e1 TUNSETGROUP = 0x400454ce TUNSETIFF = 0x400454ca TUNSETIFINDEX = 0x400454da @@ -1953,13 +2124,17 @@ const ( TUNSETPERSIST = 0x400454cb TUNSETQUEUE = 0x400454d9 TUNSETSNDBUF = 0x400454d4 + TUNSETSTEERINGEBPF = 0x800454e0 TUNSETTXFILTER = 0x400454d1 TUNSETVNETBE = 0x400454de TUNSETVNETHDRSZ = 0x400454d8 TUNSETVNETLE = 0x400454dc + UDF_SUPER_MAGIC = 0x15013346 UMOUNT_NOFOLLOW = 0x8 + USBDEVICE_SUPER_MAGIC = 0x9fa2 UTIME_NOW = 0x3fffffff UTIME_OMIT = 0x3ffffffe + V9FS_MAGIC = 0x1021997 VDISCARD = 0xd VEOF = 0x4 VEOL = 0xb @@ -2001,6 +2176,86 @@ const ( WDIOC_SETPRETIMEOUT = 0xc0045708 WDIOC_SETTIMEOUT = 0xc0045706 WEXITED = 0x4 + WIN_ACKMEDIACHANGE = 0xdb + WIN_CHECKPOWERMODE1 = 0xe5 + WIN_CHECKPOWERMODE2 = 0x98 + WIN_DEVICE_RESET = 0x8 + WIN_DIAGNOSE = 0x90 + WIN_DOORLOCK = 0xde + WIN_DOORUNLOCK = 0xdf + WIN_DOWNLOAD_MICROCODE = 0x92 + WIN_FLUSH_CACHE = 0xe7 + WIN_FLUSH_CACHE_EXT = 0xea + WIN_FORMAT = 0x50 + WIN_GETMEDIASTATUS = 0xda + WIN_IDENTIFY = 0xec + WIN_IDENTIFY_DMA = 0xee + WIN_IDLEIMMEDIATE = 0xe1 + WIN_INIT = 0x60 + WIN_MEDIAEJECT = 0xed + WIN_MULTREAD = 0xc4 + WIN_MULTREAD_EXT = 0x29 + WIN_MULTWRITE = 0xc5 + WIN_MULTWRITE_EXT = 0x39 + WIN_NOP = 0x0 + WIN_PACKETCMD = 0xa0 + WIN_PIDENTIFY = 0xa1 + WIN_POSTBOOT = 0xdc + WIN_PREBOOT = 0xdd + WIN_QUEUED_SERVICE = 0xa2 + WIN_READ = 0x20 + WIN_READDMA = 0xc8 + WIN_READDMA_EXT = 0x25 + WIN_READDMA_ONCE = 0xc9 + WIN_READDMA_QUEUED = 0xc7 + WIN_READDMA_QUEUED_EXT = 0x26 + WIN_READ_BUFFER = 0xe4 + WIN_READ_EXT = 0x24 + WIN_READ_LONG = 0x22 + WIN_READ_LONG_ONCE = 0x23 + WIN_READ_NATIVE_MAX = 0xf8 + WIN_READ_NATIVE_MAX_EXT = 0x27 + WIN_READ_ONCE = 0x21 + WIN_RECAL = 0x10 + WIN_RESTORE = 0x10 + WIN_SECURITY_DISABLE = 0xf6 + WIN_SECURITY_ERASE_PREPARE = 0xf3 + WIN_SECURITY_ERASE_UNIT = 0xf4 + WIN_SECURITY_FREEZE_LOCK = 0xf5 + WIN_SECURITY_SET_PASS = 0xf1 + WIN_SECURITY_UNLOCK = 0xf2 + WIN_SEEK = 0x70 + WIN_SETFEATURES = 0xef + WIN_SETIDLE1 = 0xe3 + WIN_SETIDLE2 = 0x97 + WIN_SETMULT = 0xc6 + WIN_SET_MAX = 0xf9 + WIN_SET_MAX_EXT = 0x37 + WIN_SLEEPNOW1 = 0xe6 + WIN_SLEEPNOW2 = 0x99 + WIN_SMART = 0xb0 + WIN_SPECIFY = 0x91 + WIN_SRST = 0x8 + WIN_STANDBY = 0xe2 + WIN_STANDBY2 = 0x96 + WIN_STANDBYNOW1 = 0xe0 + WIN_STANDBYNOW2 = 0x94 + WIN_VERIFY = 0x40 + WIN_VERIFY_EXT = 0x42 + WIN_VERIFY_ONCE = 0x41 + WIN_WRITE = 0x30 + WIN_WRITEDMA = 0xca + WIN_WRITEDMA_EXT = 0x35 + WIN_WRITEDMA_ONCE = 0xcb + WIN_WRITEDMA_QUEUED = 0xcc + WIN_WRITEDMA_QUEUED_EXT = 0x36 + WIN_WRITE_BUFFER = 0xe8 + WIN_WRITE_EXT = 0x34 + WIN_WRITE_LONG = 0x32 + WIN_WRITE_LONG_ONCE = 0x33 + WIN_WRITE_ONCE = 0x31 + WIN_WRITE_SAME = 0xe9 + WIN_WRITE_VERIFY = 0x3c WNOHANG = 0x1 WNOTHREAD = 0x20000000 WNOWAIT = 0x1000000 @@ -2010,7 +2265,9 @@ const ( XATTR_CREATE = 0x1 XATTR_REPLACE = 0x2 XCASE = 0x4 + XENFS_SUPER_MAGIC = 0xabba1974 XTABS = 0x1800 + ZSMALLOC_MAGIC = 0x58295829 ) // Errors @@ -2190,171 +2447,179 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "no such device or address", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device or resource busy", - 17: "file exists", - 18: "invalid cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "numerical result out of range", - 35: "resource deadlock avoided", - 36: "file name too long", - 37: "no locks available", - 38: "function not implemented", - 39: "directory not empty", - 40: "too many levels of symbolic links", - 42: "no message of desired type", - 43: "identifier removed", - 44: "channel number out of range", - 45: "level 2 not synchronized", - 46: "level 3 halted", - 47: "level 3 reset", - 48: "link number out of range", - 49: "protocol driver not attached", - 50: "no CSI structure available", - 51: "level 2 halted", - 52: "invalid exchange", - 53: "invalid request descriptor", - 54: "exchange full", - 55: "no anode", - 56: "invalid request code", - 57: "invalid slot", - 59: "bad font file format", - 60: "device not a stream", - 61: "no data available", - 62: "timer expired", - 63: "out of streams resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 72: "multihop attempted", - 73: "RFS specific error", - 74: "bad message", - 75: "value too large for defined data type", - 76: "name not unique on network", - 77: "file descriptor in bad state", - 78: "remote address changed", - 79: "can not access a needed shared library", - 80: "accessing a corrupted shared library", - 81: ".lib section in a.out corrupted", - 82: "attempting to link in too many shared libraries", - 83: "cannot exec a shared library directly", - 84: "invalid or incomplete multibyte or wide character", - 85: "interrupted system call should be restarted", - 86: "streams pipe error", - 87: "too many users", - 88: "socket operation on non-socket", - 89: "destination address required", - 90: "message too long", - 91: "protocol wrong type for socket", - 92: "protocol not available", - 93: "protocol not supported", - 94: "socket type not supported", - 95: "operation not supported", - 96: "protocol family not supported", - 97: "address family not supported by protocol", - 98: "address already in use", - 99: "cannot assign requested address", - 100: "network is down", - 101: "network is unreachable", - 102: "network dropped connection on reset", - 103: "software caused connection abort", - 104: "connection reset by peer", - 105: "no buffer space available", - 106: "transport endpoint is already connected", - 107: "transport endpoint is not connected", - 108: "cannot send after transport endpoint shutdown", - 109: "too many references: cannot splice", - 110: "connection timed out", - 111: "connection refused", - 112: "host is down", - 113: "no route to host", - 114: "operation already in progress", - 115: "operation now in progress", - 116: "stale file handle", - 117: "structure needs cleaning", - 118: "not a XENIX named type file", - 119: "no XENIX semaphores available", - 120: "is a named type file", - 121: "remote I/O error", - 122: "disk quota exceeded", - 123: "no medium found", - 124: "wrong medium type", - 125: "operation canceled", - 126: "required key not available", - 127: "key has expired", - 128: "key has been revoked", - 129: "key was rejected by service", - 130: "owner died", - 131: "state not recoverable", - 132: "operation not possible due to RF-kill", - 133: "memory page has hardware error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device or resource busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "invalid cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "numerical result out of range"}, + {35, "EDEADLK", "resource deadlock avoided"}, + {36, "ENAMETOOLONG", "file name too long"}, + {37, "ENOLCK", "no locks available"}, + {38, "ENOSYS", "function not implemented"}, + {39, "ENOTEMPTY", "directory not empty"}, + {40, "ELOOP", "too many levels of symbolic links"}, + {42, "ENOMSG", "no message of desired type"}, + {43, "EIDRM", "identifier removed"}, + {44, "ECHRNG", "channel number out of range"}, + {45, "EL2NSYNC", "level 2 not synchronized"}, + {46, "EL3HLT", "level 3 halted"}, + {47, "EL3RST", "level 3 reset"}, + {48, "ELNRNG", "link number out of range"}, + {49, "EUNATCH", "protocol driver not attached"}, + {50, "ENOCSI", "no CSI structure available"}, + {51, "EL2HLT", "level 2 halted"}, + {52, "EBADE", "invalid exchange"}, + {53, "EBADR", "invalid request descriptor"}, + {54, "EXFULL", "exchange full"}, + {55, "ENOANO", "no anode"}, + {56, "EBADRQC", "invalid request code"}, + {57, "EBADSLT", "invalid slot"}, + {59, "EBFONT", "bad font file format"}, + {60, "ENOSTR", "device not a stream"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of streams resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {72, "EMULTIHOP", "multihop attempted"}, + {73, "EDOTDOT", "RFS specific error"}, + {74, "EBADMSG", "bad message"}, + {75, "EOVERFLOW", "value too large for defined data type"}, + {76, "ENOTUNIQ", "name not unique on network"}, + {77, "EBADFD", "file descriptor in bad state"}, + {78, "EREMCHG", "remote address changed"}, + {79, "ELIBACC", "can not access a needed shared library"}, + {80, "ELIBBAD", "accessing a corrupted shared library"}, + {81, "ELIBSCN", ".lib section in a.out corrupted"}, + {82, "ELIBMAX", "attempting to link in too many shared libraries"}, + {83, "ELIBEXEC", "cannot exec a shared library directly"}, + {84, "EILSEQ", "invalid or incomplete multibyte or wide character"}, + {85, "ERESTART", "interrupted system call should be restarted"}, + {86, "ESTRPIPE", "streams pipe error"}, + {87, "EUSERS", "too many users"}, + {88, "ENOTSOCK", "socket operation on non-socket"}, + {89, "EDESTADDRREQ", "destination address required"}, + {90, "EMSGSIZE", "message too long"}, + {91, "EPROTOTYPE", "protocol wrong type for socket"}, + {92, "ENOPROTOOPT", "protocol not available"}, + {93, "EPROTONOSUPPORT", "protocol not supported"}, + {94, "ESOCKTNOSUPPORT", "socket type not supported"}, + {95, "ENOTSUP", "operation not supported"}, + {96, "EPFNOSUPPORT", "protocol family not supported"}, + {97, "EAFNOSUPPORT", "address family not supported by protocol"}, + {98, "EADDRINUSE", "address already in use"}, + {99, "EADDRNOTAVAIL", "cannot assign requested address"}, + {100, "ENETDOWN", "network is down"}, + {101, "ENETUNREACH", "network is unreachable"}, + {102, "ENETRESET", "network dropped connection on reset"}, + {103, "ECONNABORTED", "software caused connection abort"}, + {104, "ECONNRESET", "connection reset by peer"}, + {105, "ENOBUFS", "no buffer space available"}, + {106, "EISCONN", "transport endpoint is already connected"}, + {107, "ENOTCONN", "transport endpoint is not connected"}, + {108, "ESHUTDOWN", "cannot send after transport endpoint shutdown"}, + {109, "ETOOMANYREFS", "too many references: cannot splice"}, + {110, "ETIMEDOUT", "connection timed out"}, + {111, "ECONNREFUSED", "connection refused"}, + {112, "EHOSTDOWN", "host is down"}, + {113, "EHOSTUNREACH", "no route to host"}, + {114, "EALREADY", "operation already in progress"}, + {115, "EINPROGRESS", "operation now in progress"}, + {116, "ESTALE", "stale file handle"}, + {117, "EUCLEAN", "structure needs cleaning"}, + {118, "ENOTNAM", "not a XENIX named type file"}, + {119, "ENAVAIL", "no XENIX semaphores available"}, + {120, "EISNAM", "is a named type file"}, + {121, "EREMOTEIO", "remote I/O error"}, + {122, "EDQUOT", "disk quota exceeded"}, + {123, "ENOMEDIUM", "no medium found"}, + {124, "EMEDIUMTYPE", "wrong medium type"}, + {125, "ECANCELED", "operation canceled"}, + {126, "ENOKEY", "required key not available"}, + {127, "EKEYEXPIRED", "key has expired"}, + {128, "EKEYREVOKED", "key has been revoked"}, + {129, "EKEYREJECTED", "key was rejected by service"}, + {130, "EOWNERDEAD", "owner died"}, + {131, "ENOTRECOVERABLE", "state not recoverable"}, + {132, "ERFKILL", "operation not possible due to RF-kill"}, + {133, "EHWPOISON", "memory page has hardware error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/breakpoint trap", - 6: "aborted", - 7: "bus error", - 8: "floating point exception", - 9: "killed", - 10: "user defined signal 1", - 11: "segmentation fault", - 12: "user defined signal 2", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "stack fault", - 17: "child exited", - 18: "continued", - 19: "stopped (signal)", - 20: "stopped", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "urgent I/O condition", - 24: "CPU time limit exceeded", - 25: "file size limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window changed", - 29: "I/O possible", - 30: "power failure", - 31: "bad system call", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/breakpoint trap"}, + {6, "SIGABRT", "aborted"}, + {7, "SIGBUS", "bus error"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGUSR1", "user defined signal 1"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGUSR2", "user defined signal 2"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGSTKFLT", "stack fault"}, + {17, "SIGCHLD", "child exited"}, + {18, "SIGCONT", "continued"}, + {19, "SIGSTOP", "stopped (signal)"}, + {20, "SIGTSTP", "stopped"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGURG", "urgent I/O condition"}, + {24, "SIGXCPU", "CPU time limit exceeded"}, + {25, "SIGXFSZ", "file size limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window changed"}, + {29, "SIGIO", "I/O possible"}, + {30, "SIGPWR", "power failure"}, + {31, "SIGSYS", "bad system call"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_netbsd_386.go b/vendor/golang.org/x/sys/unix/zerrors_netbsd_386.go index 1612b660916..cd93ce0d85e 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_netbsd_386.go +++ b/vendor/golang.org/x/sys/unix/zerrors_netbsd_386.go @@ -159,6 +159,7 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CREAD = 0x800 + CRTSCTS = 0x10000 CS5 = 0x0 CS6 = 0x100 CS7 = 0x200 @@ -1583,137 +1584,145 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large or too small", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol option not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "connection timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "identifier removed", - 83: "no message of desired type", - 84: "value too large to be stored in data type", - 85: "illegal byte sequence", - 86: "not supported", - 87: "operation Canceled", - 88: "bad or Corrupt message", - 89: "no message available", - 90: "no STREAM resources", - 91: "not a STREAM", - 92: "STREAM ioctl timeout", - 93: "attribute not found", - 94: "multihop attempted", - 95: "link has been severed", - 96: "protocol error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large or too small"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol option not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "connection timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIDRM", "identifier removed"}, + {83, "ENOMSG", "no message of desired type"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "EILSEQ", "illegal byte sequence"}, + {86, "ENOTSUP", "not supported"}, + {87, "ECANCELED", "operation Canceled"}, + {88, "EBADMSG", "bad or Corrupt message"}, + {89, "ENODATA", "no message available"}, + {90, "ENOSR", "no STREAM resources"}, + {91, "ENOSTR", "not a STREAM"}, + {92, "ETIME", "STREAM ioctl timeout"}, + {93, "ENOATTR", "attribute not found"}, + {94, "EMULTIHOP", "multihop attempted"}, + {95, "ENOLINK", "link has been severed"}, + {96, "ELAST", "protocol error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "stopped (signal)", - 18: "stopped", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "power fail/restart", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGIOT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "stopped (signal)"}, + {18, "SIGTSTP", "stopped"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGPWR", "power fail/restart"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_netbsd_amd64.go b/vendor/golang.org/x/sys/unix/zerrors_netbsd_amd64.go index c994ab610c0..071701c4118 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_netbsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_netbsd_amd64.go @@ -159,6 +159,7 @@ const ( CLONE_VFORK = 0x4000 CLONE_VM = 0x100 CREAD = 0x800 + CRTSCTS = 0x10000 CS5 = 0x0 CS6 = 0x100 CS7 = 0x200 @@ -1573,137 +1574,145 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large or too small", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol option not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "connection timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "identifier removed", - 83: "no message of desired type", - 84: "value too large to be stored in data type", - 85: "illegal byte sequence", - 86: "not supported", - 87: "operation Canceled", - 88: "bad or Corrupt message", - 89: "no message available", - 90: "no STREAM resources", - 91: "not a STREAM", - 92: "STREAM ioctl timeout", - 93: "attribute not found", - 94: "multihop attempted", - 95: "link has been severed", - 96: "protocol error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large or too small"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol option not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "connection timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIDRM", "identifier removed"}, + {83, "ENOMSG", "no message of desired type"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "EILSEQ", "illegal byte sequence"}, + {86, "ENOTSUP", "not supported"}, + {87, "ECANCELED", "operation Canceled"}, + {88, "EBADMSG", "bad or Corrupt message"}, + {89, "ENODATA", "no message available"}, + {90, "ENOSR", "no STREAM resources"}, + {91, "ENOSTR", "not a STREAM"}, + {92, "ETIME", "STREAM ioctl timeout"}, + {93, "ENOATTR", "attribute not found"}, + {94, "EMULTIHOP", "multihop attempted"}, + {95, "ENOLINK", "link has been severed"}, + {96, "ELAST", "protocol error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "stopped (signal)", - 18: "stopped", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "power fail/restart", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGIOT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "stopped (signal)"}, + {18, "SIGTSTP", "stopped"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGPWR", "power fail/restart"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_netbsd_arm.go b/vendor/golang.org/x/sys/unix/zerrors_netbsd_arm.go index a8f9efedec5..5fe56ae8c72 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_netbsd_arm.go +++ b/vendor/golang.org/x/sys/unix/zerrors_netbsd_arm.go @@ -151,6 +151,7 @@ const ( CFLUSH = 0xf CLOCAL = 0x8000 CREAD = 0x800 + CRTSCTS = 0x10000 CS5 = 0x0 CS6 = 0x100 CS7 = 0x200 @@ -1562,137 +1563,145 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large or too small", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol option not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "connection timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "identifier removed", - 83: "no message of desired type", - 84: "value too large to be stored in data type", - 85: "illegal byte sequence", - 86: "not supported", - 87: "operation Canceled", - 88: "bad or Corrupt message", - 89: "no message available", - 90: "no STREAM resources", - 91: "not a STREAM", - 92: "STREAM ioctl timeout", - 93: "attribute not found", - 94: "multihop attempted", - 95: "link has been severed", - 96: "protocol error", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large or too small"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol option not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "connection timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disc quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC prog. not avail"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIDRM", "identifier removed"}, + {83, "ENOMSG", "no message of desired type"}, + {84, "EOVERFLOW", "value too large to be stored in data type"}, + {85, "EILSEQ", "illegal byte sequence"}, + {86, "ENOTSUP", "not supported"}, + {87, "ECANCELED", "operation Canceled"}, + {88, "EBADMSG", "bad or Corrupt message"}, + {89, "ENODATA", "no message available"}, + {90, "ENOSR", "no STREAM resources"}, + {91, "ENOSTR", "not a STREAM"}, + {92, "ETIME", "STREAM ioctl timeout"}, + {93, "ENOATTR", "attribute not found"}, + {94, "EMULTIHOP", "multihop attempted"}, + {95, "ENOLINK", "link has been severed"}, + {96, "ELAST", "protocol error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "stopped (signal)", - 18: "stopped", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "power fail/restart", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGIOT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "stopped (signal)"}, + {18, "SIGTSTP", "stopped"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGPWR", "power fail/restart"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_openbsd_386.go b/vendor/golang.org/x/sys/unix/zerrors_openbsd_386.go index 04e4f33198d..0a1c3e7e8c3 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_openbsd_386.go +++ b/vendor/golang.org/x/sys/unix/zerrors_openbsd_386.go @@ -147,6 +147,7 @@ const ( CFLUSH = 0xf CLOCAL = 0x8000 CREAD = 0x800 + CRTSCTS = 0x10000 CS5 = 0x0 CS6 = 0x100 CS7 = 0x200 @@ -1460,132 +1461,140 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "connection timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "IPsec processing failure", - 83: "attribute not found", - 84: "illegal byte sequence", - 85: "no medium found", - 86: "wrong medium type", - 87: "value too large to be stored in data type", - 88: "operation canceled", - 89: "identifier removed", - 90: "no message of desired type", - 91: "not supported", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EWOULDBLOCK", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disk quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC program not available"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIPSEC", "IPsec processing failure"}, + {83, "ENOATTR", "attribute not found"}, + {84, "EILSEQ", "illegal byte sequence"}, + {85, "ENOMEDIUM", "no medium found"}, + {86, "EMEDIUMTYPE", "wrong medium type"}, + {87, "EOVERFLOW", "value too large to be stored in data type"}, + {88, "ECANCELED", "operation canceled"}, + {89, "EIDRM", "identifier removed"}, + {90, "ENOMSG", "no message of desired type"}, + {91, "ELAST", "not supported"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "stopped (signal)", - 18: "stopped", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "thread AST", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGABRT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGTHR", "thread AST"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_openbsd_amd64.go b/vendor/golang.org/x/sys/unix/zerrors_openbsd_amd64.go index c80ff981200..acfc6646919 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_openbsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_openbsd_amd64.go @@ -45,6 +45,7 @@ const ( AF_SNA = 0xb AF_UNIX = 0x1 AF_UNSPEC = 0x0 + ALTWERASE = 0x200 ARPHRD_ETHER = 0x1 ARPHRD_FRELAY = 0xf ARPHRD_IEEE1394 = 0x18 @@ -146,7 +147,14 @@ const ( BRKINT = 0x2 CFLUSH = 0xf CLOCAL = 0x8000 + CLOCK_BOOTTIME = 0x6 + CLOCK_MONOTONIC = 0x3 + CLOCK_PROCESS_CPUTIME_ID = 0x2 + CLOCK_REALTIME = 0x0 + CLOCK_THREAD_CPUTIME_ID = 0x4 + CLOCK_UPTIME = 0x5 CREAD = 0x800 + CRTSCTS = 0x10000 CS5 = 0x0 CS6 = 0x100 CS7 = 0x200 @@ -177,6 +185,7 @@ const ( DLT_LOOP = 0xc DLT_MPLS = 0xdb DLT_NULL = 0x0 + DLT_OPENFLOW = 0x10b DLT_PFLOG = 0x75 DLT_PFSYNC = 0x12 DLT_PPP = 0x9 @@ -187,6 +196,23 @@ const ( DLT_RAW = 0xe DLT_SLIP = 0x8 DLT_SLIP_BSDOS = 0xf + DLT_USBPCAP = 0xf9 + DLT_USER0 = 0x93 + DLT_USER1 = 0x94 + DLT_USER10 = 0x9d + DLT_USER11 = 0x9e + DLT_USER12 = 0x9f + DLT_USER13 = 0xa0 + DLT_USER14 = 0xa1 + DLT_USER15 = 0xa2 + DLT_USER2 = 0x95 + DLT_USER3 = 0x96 + DLT_USER4 = 0x97 + DLT_USER5 = 0x98 + DLT_USER6 = 0x99 + DLT_USER7 = 0x9a + DLT_USER8 = 0x9b + DLT_USER9 = 0x9c DT_BLK = 0x6 DT_CHR = 0x2 DT_DIR = 0x4 @@ -400,27 +426,38 @@ const ( ETHER_CRC_POLY_LE = 0xedb88320 ETHER_HDR_LEN = 0xe ETHER_MAX_DIX_LEN = 0x600 + ETHER_MAX_HARDMTU_LEN = 0xff9b ETHER_MAX_LEN = 0x5ee ETHER_MIN_LEN = 0x40 ETHER_TYPE_LEN = 0x2 ETHER_VLAN_ENCAP_LEN = 0x4 EVFILT_AIO = -0x3 + EVFILT_DEVICE = -0x8 EVFILT_PROC = -0x5 EVFILT_READ = -0x1 EVFILT_SIGNAL = -0x6 - EVFILT_SYSCOUNT = 0x7 + EVFILT_SYSCOUNT = 0x8 EVFILT_TIMER = -0x7 EVFILT_VNODE = -0x4 EVFILT_WRITE = -0x2 + EVL_ENCAPLEN = 0x4 + EVL_PRIO_BITS = 0xd + EVL_PRIO_MAX = 0x7 + EVL_VLID_MASK = 0xfff + EVL_VLID_MAX = 0xffe + EVL_VLID_MIN = 0x1 + EVL_VLID_NULL = 0x0 EV_ADD = 0x1 EV_CLEAR = 0x20 EV_DELETE = 0x2 EV_DISABLE = 0x8 + EV_DISPATCH = 0x80 EV_ENABLE = 0x4 EV_EOF = 0x8000 EV_ERROR = 0x4000 EV_FLAG1 = 0x2000 EV_ONESHOT = 0x10 + EV_RECEIPT = 0x40 EV_SYSFLAGS = 0xf000 EXTA = 0x4b00 EXTB = 0x9600 @@ -434,7 +471,7 @@ const ( F_GETFL = 0x3 F_GETLK = 0x7 F_GETOWN = 0x5 - F_OK = 0x0 + F_ISATTY = 0xb F_RDLCK = 0x1 F_SETFD = 0x2 F_SETFL = 0x4 @@ -451,7 +488,6 @@ const ( IEXTEN = 0x400 IFAN_ARRIVAL = 0x0 IFAN_DEPARTURE = 0x1 - IFA_ROUTE = 0x1 IFF_ALLMULTI = 0x200 IFF_BROADCAST = 0x2 IFF_CANTCHANGE = 0x8e52 @@ -462,12 +498,12 @@ const ( IFF_LOOPBACK = 0x8 IFF_MULTICAST = 0x8000 IFF_NOARP = 0x80 - IFF_NOTRAILERS = 0x20 IFF_OACTIVE = 0x400 IFF_POINTOPOINT = 0x10 IFF_PROMISC = 0x100 IFF_RUNNING = 0x40 IFF_SIMPLEX = 0x800 + IFF_STATICARP = 0x20 IFF_UP = 0x1 IFNAMSIZ = 0x10 IFT_1822 = 0x2 @@ -596,6 +632,7 @@ const ( IFT_LINEGROUP = 0xd2 IFT_LOCALTALK = 0x2a IFT_LOOP = 0x18 + IFT_MBIM = 0xfa IFT_MEDIAMAILOVERIP = 0x8b IFT_MFSIGLINK = 0xa7 IFT_MIOX25 = 0x26 @@ -720,8 +757,6 @@ const ( IPPROTO_AH = 0x33 IPPROTO_CARP = 0x70 IPPROTO_DIVERT = 0x102 - IPPROTO_DIVERT_INIT = 0x2 - IPPROTO_DIVERT_RESP = 0x1 IPPROTO_DONE = 0x101 IPPROTO_DSTOPTS = 0x3c IPPROTO_EGP = 0x8 @@ -778,6 +813,7 @@ const ( IPV6_LEAVE_GROUP = 0xd IPV6_MAXHLIM = 0xff IPV6_MAXPACKET = 0xffff + IPV6_MINHOPCOUNT = 0x41 IPV6_MMTU = 0x500 IPV6_MULTICAST_HOPS = 0xa IPV6_MULTICAST_IF = 0x9 @@ -817,12 +853,12 @@ const ( IP_DEFAULT_MULTICAST_LOOP = 0x1 IP_DEFAULT_MULTICAST_TTL = 0x1 IP_DF = 0x4000 - IP_DIVERTFL = 0x1022 IP_DROP_MEMBERSHIP = 0xd IP_ESP_NETWORK_LEVEL = 0x16 IP_ESP_TRANS_LEVEL = 0x15 IP_HDRINCL = 0x2 IP_IPCOMP_LEVEL = 0x1d + IP_IPDEFTTL = 0x25 IP_IPSECFLOWINFO = 0x24 IP_IPSEC_LOCAL_AUTH = 0x1b IP_IPSEC_LOCAL_CRED = 0x19 @@ -856,10 +892,12 @@ const ( IP_RETOPTS = 0x8 IP_RF = 0x8000 IP_RTABLE = 0x1021 + IP_SENDSRCADDR = 0x7 IP_TOS = 0x3 IP_TTL = 0x4 ISIG = 0x80 ISTRIP = 0x20 + IUCLC = 0x1000 IXANY = 0x800 IXOFF = 0x400 IXON = 0x200 @@ -880,25 +918,28 @@ const ( MADV_SPACEAVAIL = 0x5 MADV_WILLNEED = 0x3 MAP_ANON = 0x1000 - MAP_COPY = 0x4 + MAP_ANONYMOUS = 0x1000 + MAP_COPY = 0x2 MAP_FILE = 0x0 MAP_FIXED = 0x10 - MAP_FLAGMASK = 0x1ff7 - MAP_HASSEMAPHORE = 0x200 - MAP_INHERIT = 0x80 + MAP_FLAGMASK = 0x7ff7 + MAP_HASSEMAPHORE = 0x0 + MAP_INHERIT = 0x0 MAP_INHERIT_COPY = 0x1 - MAP_INHERIT_DONATE_COPY = 0x3 MAP_INHERIT_NONE = 0x2 MAP_INHERIT_SHARE = 0x0 - MAP_NOEXTEND = 0x100 - MAP_NORESERVE = 0x40 + MAP_INHERIT_ZERO = 0x3 + MAP_NOEXTEND = 0x0 + MAP_NORESERVE = 0x0 MAP_PRIVATE = 0x2 - MAP_RENAME = 0x20 + MAP_RENAME = 0x0 MAP_SHARED = 0x1 - MAP_TRYFIXED = 0x400 + MAP_STACK = 0x4000 + MAP_TRYFIXED = 0x0 MCL_CURRENT = 0x1 MCL_FUTURE = 0x2 MSG_BCAST = 0x100 + MSG_CMSG_CLOEXEC = 0x800 MSG_CTRUNC = 0x20 MSG_DONTROUTE = 0x4 MSG_DONTWAIT = 0x80 @@ -916,11 +957,14 @@ const ( NET_RT_DUMP = 0x1 NET_RT_FLAGS = 0x2 NET_RT_IFLIST = 0x3 - NET_RT_MAXID = 0x6 + NET_RT_IFNAMES = 0x6 + NET_RT_MAXID = 0x7 NET_RT_STATS = 0x4 NET_RT_TABLE = 0x5 NOFLSH = 0x80000000 + NOKERNINFO = 0x2000000 NOTE_ATTRIB = 0x8 + NOTE_CHANGE = 0x1 NOTE_CHILD = 0x4 NOTE_DELETE = 0x1 NOTE_EOF = 0x2 @@ -939,11 +983,13 @@ const ( NOTE_TRUNCATE = 0x80 NOTE_WRITE = 0x2 OCRNL = 0x10 + OLCUC = 0x20 ONLCR = 0x2 ONLRET = 0x80 ONOCR = 0x40 ONOEOT = 0x8 OPOST = 0x1 + OXTABS = 0x4 O_ACCMODE = 0x3 O_APPEND = 0x8 O_ASYNC = 0x40 @@ -981,23 +1027,32 @@ const ( RLIMIT_CPU = 0x0 RLIMIT_DATA = 0x2 RLIMIT_FSIZE = 0x1 + RLIMIT_MEMLOCK = 0x6 RLIMIT_NOFILE = 0x8 + RLIMIT_NPROC = 0x7 + RLIMIT_RSS = 0x5 RLIMIT_STACK = 0x3 RLIM_INFINITY = 0x7fffffffffffffff RTAX_AUTHOR = 0x6 + RTAX_BFD = 0xb RTAX_BRD = 0x7 + RTAX_DNS = 0xc RTAX_DST = 0x0 RTAX_GATEWAY = 0x1 RTAX_GENMASK = 0x3 RTAX_IFA = 0x5 RTAX_IFP = 0x4 RTAX_LABEL = 0xa - RTAX_MAX = 0xb + RTAX_MAX = 0xf RTAX_NETMASK = 0x2 + RTAX_SEARCH = 0xe RTAX_SRC = 0x8 RTAX_SRCMASK = 0x9 + RTAX_STATIC = 0xd RTA_AUTHOR = 0x40 + RTA_BFD = 0x800 RTA_BRD = 0x80 + RTA_DNS = 0x1000 RTA_DST = 0x1 RTA_GATEWAY = 0x2 RTA_GENMASK = 0x8 @@ -1005,34 +1060,39 @@ const ( RTA_IFP = 0x10 RTA_LABEL = 0x400 RTA_NETMASK = 0x4 + RTA_SEARCH = 0x4000 RTA_SRC = 0x100 RTA_SRCMASK = 0x200 + RTA_STATIC = 0x2000 RTF_ANNOUNCE = 0x4000 + RTF_BFD = 0x1000000 RTF_BLACKHOLE = 0x1000 + RTF_BROADCAST = 0x400000 + RTF_CACHED = 0x20000 RTF_CLONED = 0x10000 RTF_CLONING = 0x100 + RTF_CONNECTED = 0x800000 RTF_DONE = 0x40 RTF_DYNAMIC = 0x10 - RTF_FMASK = 0x10f808 + RTF_FMASK = 0x110fc08 RTF_GATEWAY = 0x2 RTF_HOST = 0x4 RTF_LLINFO = 0x400 - RTF_MASK = 0x80 + RTF_LOCAL = 0x200000 RTF_MODIFIED = 0x20 RTF_MPATH = 0x40000 RTF_MPLS = 0x100000 + RTF_MULTICAST = 0x200 RTF_PERMANENT_ARP = 0x2000 RTF_PROTO1 = 0x8000 RTF_PROTO2 = 0x4000 RTF_PROTO3 = 0x2000 RTF_REJECT = 0x8 - RTF_SOURCE = 0x20000 RTF_STATIC = 0x800 - RTF_TUNNEL = 0x100000 RTF_UP = 0x1 RTF_USETRAILERS = 0x8000 - RTF_XRESOLVE = 0x200 RTM_ADD = 0x1 + RTM_BFD = 0x12 RTM_CHANGE = 0x3 RTM_DELADDR = 0xd RTM_DELETE = 0x2 @@ -1040,11 +1100,13 @@ const ( RTM_GET = 0x4 RTM_IFANNOUNCE = 0xf RTM_IFINFO = 0xe + RTM_INVALIDATE = 0x11 RTM_LOCK = 0x8 RTM_LOSING = 0x5 RTM_MAXSIZE = 0x800 RTM_MISS = 0x7 RTM_NEWADDR = 0xc + RTM_PROPOSAL = 0x13 RTM_REDIRECT = 0x6 RTM_RESOLVE = 0xb RTM_RTTUNIT = 0xf4240 @@ -1057,6 +1119,8 @@ const ( RTV_RTTVAR = 0x80 RTV_SPIPE = 0x10 RTV_SSTHRESH = 0x20 + RT_TABLEID_BITS = 0x8 + RT_TABLEID_MASK = 0xff RT_TABLEID_MAX = 0xff RUSAGE_CHILDREN = -0x1 RUSAGE_SELF = 0x0 @@ -1069,55 +1133,55 @@ const ( SIOCADDMULTI = 0x80206931 SIOCAIFADDR = 0x8040691a SIOCAIFGROUP = 0x80286987 - SIOCALIFADDR = 0x8218691c SIOCATMARK = 0x40047307 - SIOCBRDGADD = 0x8058693c - SIOCBRDGADDS = 0x80586941 - SIOCBRDGARL = 0x806e694d + SIOCBRDGADD = 0x8060693c + SIOCBRDGADDL = 0x80606949 + SIOCBRDGADDS = 0x80606941 + SIOCBRDGARL = 0x808c694d SIOCBRDGDADDR = 0x81286947 - SIOCBRDGDEL = 0x8058693d - SIOCBRDGDELS = 0x80586942 - SIOCBRDGFLUSH = 0x80586948 - SIOCBRDGFRL = 0x806e694e - SIOCBRDGGCACHE = 0xc0146941 - SIOCBRDGGFD = 0xc0146952 - SIOCBRDGGHT = 0xc0146951 - SIOCBRDGGIFFLGS = 0xc058693e - SIOCBRDGGMA = 0xc0146953 + SIOCBRDGDEL = 0x8060693d + SIOCBRDGDELS = 0x80606942 + SIOCBRDGFLUSH = 0x80606948 + SIOCBRDGFRL = 0x808c694e + SIOCBRDGGCACHE = 0xc0186941 + SIOCBRDGGFD = 0xc0186952 + SIOCBRDGGHT = 0xc0186951 + SIOCBRDGGIFFLGS = 0xc060693e + SIOCBRDGGMA = 0xc0186953 SIOCBRDGGPARAM = 0xc0406958 - SIOCBRDGGPRI = 0xc0146950 + SIOCBRDGGPRI = 0xc0186950 SIOCBRDGGRL = 0xc030694f - SIOCBRDGGSIFS = 0xc058693c - SIOCBRDGGTO = 0xc0146946 - SIOCBRDGIFS = 0xc0586942 + SIOCBRDGGTO = 0xc0186946 + SIOCBRDGIFS = 0xc0606942 SIOCBRDGRTS = 0xc0206943 SIOCBRDGSADDR = 0xc1286944 - SIOCBRDGSCACHE = 0x80146940 - SIOCBRDGSFD = 0x80146952 - SIOCBRDGSHT = 0x80146951 - SIOCBRDGSIFCOST = 0x80586955 - SIOCBRDGSIFFLGS = 0x8058693f - SIOCBRDGSIFPRIO = 0x80586954 - SIOCBRDGSMA = 0x80146953 - SIOCBRDGSPRI = 0x80146950 - SIOCBRDGSPROTO = 0x8014695a - SIOCBRDGSTO = 0x80146945 - SIOCBRDGSTXHC = 0x80146959 + SIOCBRDGSCACHE = 0x80186940 + SIOCBRDGSFD = 0x80186952 + SIOCBRDGSHT = 0x80186951 + SIOCBRDGSIFCOST = 0x80606955 + SIOCBRDGSIFFLGS = 0x8060693f + SIOCBRDGSIFPRIO = 0x80606954 + SIOCBRDGSIFPROT = 0x8060694a + SIOCBRDGSMA = 0x80186953 + SIOCBRDGSPRI = 0x80186950 + SIOCBRDGSPROTO = 0x8018695a + SIOCBRDGSTO = 0x80186945 + SIOCBRDGSTXHC = 0x80186959 SIOCDELMULTI = 0x80206932 SIOCDIFADDR = 0x80206919 SIOCDIFGROUP = 0x80286989 + SIOCDIFPARENT = 0x802069b4 SIOCDIFPHYADDR = 0x80206949 - SIOCDLIFADDR = 0x8218691e + SIOCDVNETID = 0x802069af SIOCGETKALIVE = 0xc01869a4 SIOCGETLABEL = 0x8020699a + SIOCGETMPWCFG = 0xc02069ae SIOCGETPFLOW = 0xc02069fe SIOCGETPFSYNC = 0xc02069f8 SIOCGETSGCNT = 0xc0207534 SIOCGETVIFCNT = 0xc0287533 SIOCGETVLAN = 0xc0206990 - SIOCGHIWAT = 0x40047301 SIOCGIFADDR = 0xc0206921 - SIOCGIFASYNCMAP = 0xc020697c SIOCGIFBRDADDR = 0xc0206923 SIOCGIFCONF = 0xc0106924 SIOCGIFDATA = 0xc020691b @@ -1129,37 +1193,41 @@ const ( SIOCGIFGMEMB = 0xc028698a SIOCGIFGROUP = 0xc0286988 SIOCGIFHARDMTU = 0xc02069a5 - SIOCGIFMEDIA = 0xc0306936 + SIOCGIFLLPRIO = 0xc02069b6 + SIOCGIFMEDIA = 0xc0406938 SIOCGIFMETRIC = 0xc0206917 SIOCGIFMTU = 0xc020697e SIOCGIFNETMASK = 0xc0206925 - SIOCGIFPDSTADDR = 0xc0206948 + SIOCGIFPAIR = 0xc02069b1 + SIOCGIFPARENT = 0xc02069b3 SIOCGIFPRIORITY = 0xc020699c - SIOCGIFPSRCADDR = 0xc0206947 SIOCGIFRDOMAIN = 0xc02069a0 SIOCGIFRTLABEL = 0xc0206983 - SIOCGIFTIMESLOT = 0xc0206986 + SIOCGIFRXR = 0x802069aa SIOCGIFXFLAGS = 0xc020699e - SIOCGLIFADDR = 0xc218691d SIOCGLIFPHYADDR = 0xc218694b + SIOCGLIFPHYDF = 0xc02069c2 SIOCGLIFPHYRTABLE = 0xc02069a2 SIOCGLIFPHYTTL = 0xc02069a9 - SIOCGLOWAT = 0x40047303 SIOCGPGRP = 0x40047309 SIOCGSPPPPARAMS = 0xc0206994 + SIOCGUMBINFO = 0xc02069be + SIOCGUMBPARAM = 0xc02069c0 SIOCGVH = 0xc02069f6 + SIOCGVNETFLOWID = 0xc02069c4 SIOCGVNETID = 0xc02069a7 + SIOCIFAFATTACH = 0x801169ab + SIOCIFAFDETACH = 0x801169ac SIOCIFCREATE = 0x8020697a SIOCIFDESTROY = 0x80206979 SIOCIFGCLONERS = 0xc0106978 SIOCSETKALIVE = 0x801869a3 SIOCSETLABEL = 0x80206999 + SIOCSETMPWCFG = 0x802069ad SIOCSETPFLOW = 0x802069fd SIOCSETPFSYNC = 0x802069f7 SIOCSETVLAN = 0x8020698f - SIOCSHIWAT = 0x80047300 SIOCSIFADDR = 0x8020690c - SIOCSIFASYNCMAP = 0x8020697d SIOCSIFBRDADDR = 0x80206913 SIOCSIFDESCR = 0x80206980 SIOCSIFDSTADDR = 0x8020690e @@ -1167,25 +1235,36 @@ const ( SIOCSIFGATTR = 0x8028698c SIOCSIFGENERIC = 0x80206939 SIOCSIFLLADDR = 0x8020691f - SIOCSIFMEDIA = 0xc0206935 + SIOCSIFLLPRIO = 0x802069b5 + SIOCSIFMEDIA = 0xc0206937 SIOCSIFMETRIC = 0x80206918 SIOCSIFMTU = 0x8020697f SIOCSIFNETMASK = 0x80206916 - SIOCSIFPHYADDR = 0x80406946 + SIOCSIFPAIR = 0x802069b0 + SIOCSIFPARENT = 0x802069b2 SIOCSIFPRIORITY = 0x8020699b SIOCSIFRDOMAIN = 0x8020699f SIOCSIFRTLABEL = 0x80206982 - SIOCSIFTIMESLOT = 0x80206985 SIOCSIFXFLAGS = 0x8020699d SIOCSLIFPHYADDR = 0x8218694a + SIOCSLIFPHYDF = 0x802069c1 SIOCSLIFPHYRTABLE = 0x802069a1 SIOCSLIFPHYTTL = 0x802069a8 - SIOCSLOWAT = 0x80047302 SIOCSPGRP = 0x80047308 SIOCSSPPPPARAMS = 0x80206993 + SIOCSUMBPARAM = 0x802069bf SIOCSVH = 0xc02069f5 + SIOCSVNETFLOWID = 0x802069c3 SIOCSVNETID = 0x802069a6 + SIOCSWGDPID = 0xc018695b + SIOCSWGMAXFLOW = 0xc0186960 + SIOCSWGMAXGROUP = 0xc018695d + SIOCSWSDPID = 0x8018695c + SIOCSWSPORTNO = 0xc060695f + SOCK_CLOEXEC = 0x8000 SOCK_DGRAM = 0x2 + SOCK_DNS = 0x1000 + SOCK_NONBLOCK = 0x4000 SOCK_RAW = 0x3 SOCK_RDM = 0x4 SOCK_SEQPACKET = 0x5 @@ -1216,9 +1295,14 @@ const ( SO_TIMESTAMP = 0x800 SO_TYPE = 0x1008 SO_USELOOPBACK = 0x40 + SO_ZEROIZE = 0x2000 TCIFLUSH = 0x1 + TCIOFF = 0x3 TCIOFLUSH = 0x3 + TCION = 0x4 TCOFLUSH = 0x2 + TCOOFF = 0x1 + TCOON = 0x2 TCP_MAXBURST = 0x4 TCP_MAXSEG = 0x2 TCP_MAXWIN = 0xffff @@ -1228,11 +1312,12 @@ const ( TCP_MSS = 0x200 TCP_NODELAY = 0x1 TCP_NOPUSH = 0x10 - TCP_NSTATES = 0xb TCP_SACK_ENABLE = 0x8 TCSAFLUSH = 0x2 TIOCCBRK = 0x2000747a TIOCCDTR = 0x20007478 + TIOCCHKVERAUTH = 0x2000741e + TIOCCLRVERAUTH = 0x2000741d TIOCCONS = 0x80047462 TIOCDRAIN = 0x2000745e TIOCEXCL = 0x2000740d @@ -1287,16 +1372,19 @@ const ( TIOCSETAF = 0x802c7416 TIOCSETAW = 0x802c7415 TIOCSETD = 0x8004741b + TIOCSETVERAUTH = 0x8004741c TIOCSFLAGS = 0x8004745c TIOCSIG = 0x8004745f TIOCSPGRP = 0x80047476 TIOCSTART = 0x2000746e - TIOCSTAT = 0x80047465 + TIOCSTAT = 0x20007465 TIOCSTI = 0x80017472 TIOCSTOP = 0x2000746f TIOCSTSTAMP = 0x8008745a TIOCSWINSZ = 0x80087467 TIOCUCNTL = 0x80047466 + TIOCUCNTL_CBRK = 0x7a + TIOCUCNTL_SBRK = 0x7b TOSTOP = 0x400000 VDISCARD = 0xf VDSUSP = 0xb @@ -1308,6 +1396,18 @@ const ( VKILL = 0x5 VLNEXT = 0xe VMIN = 0x10 + VM_ANONMIN = 0x7 + VM_LOADAVG = 0x2 + VM_MAXID = 0xc + VM_MAXSLP = 0xa + VM_METER = 0x1 + VM_NKMEMPAGES = 0x6 + VM_PSSTRINGS = 0x3 + VM_SWAPENCRYPT = 0x5 + VM_USPACE = 0xb + VM_UVMEXP = 0x4 + VM_VNODEMIN = 0x9 + VM_VTEXTMIN = 0x8 VQUIT = 0x9 VREPRINT = 0x6 VSTART = 0xc @@ -1320,8 +1420,8 @@ const ( WCONTINUED = 0x8 WCOREFLAG = 0x80 WNOHANG = 0x1 - WSTOPPED = 0x7f WUNTRACED = 0x2 + XCASE = 0x1000000 ) // Errors @@ -1335,6 +1435,7 @@ const ( EALREADY = syscall.Errno(0x25) EAUTH = syscall.Errno(0x50) EBADF = syscall.Errno(0x9) + EBADMSG = syscall.Errno(0x5c) EBADRPC = syscall.Errno(0x48) EBUSY = syscall.Errno(0x10) ECANCELED = syscall.Errno(0x58) @@ -1361,7 +1462,7 @@ const ( EIPSEC = syscall.Errno(0x52) EISCONN = syscall.Errno(0x38) EISDIR = syscall.Errno(0x15) - ELAST = syscall.Errno(0x5b) + ELAST = syscall.Errno(0x5f) ELOOP = syscall.Errno(0x3e) EMEDIUMTYPE = syscall.Errno(0x56) EMFILE = syscall.Errno(0x18) @@ -1389,12 +1490,14 @@ const ( ENOTCONN = syscall.Errno(0x39) ENOTDIR = syscall.Errno(0x14) ENOTEMPTY = syscall.Errno(0x42) + ENOTRECOVERABLE = syscall.Errno(0x5d) ENOTSOCK = syscall.Errno(0x26) ENOTSUP = syscall.Errno(0x5b) ENOTTY = syscall.Errno(0x19) ENXIO = syscall.Errno(0x6) EOPNOTSUPP = syscall.Errno(0x2d) EOVERFLOW = syscall.Errno(0x57) + EOWNERDEAD = syscall.Errno(0x5e) EPERM = syscall.Errno(0x1) EPFNOSUPPORT = syscall.Errno(0x2e) EPIPE = syscall.Errno(0x20) @@ -1402,6 +1505,7 @@ const ( EPROCUNAVAIL = syscall.Errno(0x4c) EPROGMISMATCH = syscall.Errno(0x4b) EPROGUNAVAIL = syscall.Errno(0x4a) + EPROTO = syscall.Errno(0x5f) EPROTONOSUPPORT = syscall.Errno(0x2b) EPROTOTYPE = syscall.Errno(0x29) ERANGE = syscall.Errno(0x22) @@ -1459,132 +1563,144 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "connection timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "IPsec processing failure", - 83: "attribute not found", - 84: "illegal byte sequence", - 85: "no medium found", - 86: "wrong medium type", - 87: "value too large to be stored in data type", - 88: "operation canceled", - 89: "identifier removed", - 90: "no message of desired type", - 91: "not supported", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EAGAIN", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disk quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC program not available"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIPSEC", "IPsec processing failure"}, + {83, "ENOATTR", "attribute not found"}, + {84, "EILSEQ", "illegal byte sequence"}, + {85, "ENOMEDIUM", "no medium found"}, + {86, "EMEDIUMTYPE", "wrong medium type"}, + {87, "EOVERFLOW", "value too large to be stored in data type"}, + {88, "ECANCELED", "operation canceled"}, + {89, "EIDRM", "identifier removed"}, + {90, "ENOMSG", "no message of desired type"}, + {91, "ENOTSUP", "not supported"}, + {92, "EBADMSG", "bad message"}, + {93, "ENOTRECOVERABLE", "state not recoverable"}, + {94, "EOWNERDEAD", "previous owner died"}, + {95, "ELAST", "protocol error"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "stopped (signal)", - 18: "stopped", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "thread AST", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGABRT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGTHR", "thread AST"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_openbsd_arm.go b/vendor/golang.org/x/sys/unix/zerrors_openbsd_arm.go index 4c320495cc4..93e37c4b289 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_openbsd_arm.go +++ b/vendor/golang.org/x/sys/unix/zerrors_openbsd_arm.go @@ -147,6 +147,7 @@ const ( CFLUSH = 0xf CLOCAL = 0x8000 CREAD = 0x800 + CRTSCTS = 0x10000 CS5 = 0x0 CS6 = 0x100 CS7 = 0x200 @@ -1462,132 +1463,140 @@ const ( ) // Error table -var errors = [...]string{ - 1: "operation not permitted", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "input/output error", - 6: "device not configured", - 7: "argument list too long", - 8: "exec format error", - 9: "bad file descriptor", - 10: "no child processes", - 11: "resource deadlock avoided", - 12: "cannot allocate memory", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "operation not supported by device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "too many open files in system", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "numerical argument out of domain", - 34: "result too large", - 35: "resource temporarily unavailable", - 36: "operation now in progress", - 37: "operation already in progress", - 38: "socket operation on non-socket", - 39: "destination address required", - 40: "message too long", - 41: "protocol wrong type for socket", - 42: "protocol not available", - 43: "protocol not supported", - 44: "socket type not supported", - 45: "operation not supported", - 46: "protocol family not supported", - 47: "address family not supported by protocol family", - 48: "address already in use", - 49: "can't assign requested address", - 50: "network is down", - 51: "network is unreachable", - 52: "network dropped connection on reset", - 53: "software caused connection abort", - 54: "connection reset by peer", - 55: "no buffer space available", - 56: "socket is already connected", - 57: "socket is not connected", - 58: "can't send after socket shutdown", - 59: "too many references: can't splice", - 60: "connection timed out", - 61: "connection refused", - 62: "too many levels of symbolic links", - 63: "file name too long", - 64: "host is down", - 65: "no route to host", - 66: "directory not empty", - 67: "too many processes", - 68: "too many users", - 69: "disc quota exceeded", - 70: "stale NFS file handle", - 71: "too many levels of remote in path", - 72: "RPC struct is bad", - 73: "RPC version wrong", - 74: "RPC prog. not avail", - 75: "program version wrong", - 76: "bad procedure for program", - 77: "no locks available", - 78: "function not implemented", - 79: "inappropriate file type or format", - 80: "authentication error", - 81: "need authenticator", - 82: "IPsec processing failure", - 83: "attribute not found", - 84: "illegal byte sequence", - 85: "no medium found", - 86: "wrong medium type", - 87: "value too large to be stored in data type", - 88: "operation canceled", - 89: "identifier removed", - 90: "no message of desired type", - 91: "not supported", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "operation not permitted"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "input/output error"}, + {6, "ENXIO", "device not configured"}, + {7, "E2BIG", "argument list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file descriptor"}, + {10, "ECHILD", "no child processes"}, + {11, "EDEADLK", "resource deadlock avoided"}, + {12, "ENOMEM", "cannot allocate memory"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "operation not supported by device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "too many open files in system"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "numerical argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "EWOULDBLOCK", "resource temporarily unavailable"}, + {36, "EINPROGRESS", "operation now in progress"}, + {37, "EALREADY", "operation already in progress"}, + {38, "ENOTSOCK", "socket operation on non-socket"}, + {39, "EDESTADDRREQ", "destination address required"}, + {40, "EMSGSIZE", "message too long"}, + {41, "EPROTOTYPE", "protocol wrong type for socket"}, + {42, "ENOPROTOOPT", "protocol not available"}, + {43, "EPROTONOSUPPORT", "protocol not supported"}, + {44, "ESOCKTNOSUPPORT", "socket type not supported"}, + {45, "EOPNOTSUPP", "operation not supported"}, + {46, "EPFNOSUPPORT", "protocol family not supported"}, + {47, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {48, "EADDRINUSE", "address already in use"}, + {49, "EADDRNOTAVAIL", "can't assign requested address"}, + {50, "ENETDOWN", "network is down"}, + {51, "ENETUNREACH", "network is unreachable"}, + {52, "ENETRESET", "network dropped connection on reset"}, + {53, "ECONNABORTED", "software caused connection abort"}, + {54, "ECONNRESET", "connection reset by peer"}, + {55, "ENOBUFS", "no buffer space available"}, + {56, "EISCONN", "socket is already connected"}, + {57, "ENOTCONN", "socket is not connected"}, + {58, "ESHUTDOWN", "can't send after socket shutdown"}, + {59, "ETOOMANYREFS", "too many references: can't splice"}, + {60, "ETIMEDOUT", "operation timed out"}, + {61, "ECONNREFUSED", "connection refused"}, + {62, "ELOOP", "too many levels of symbolic links"}, + {63, "ENAMETOOLONG", "file name too long"}, + {64, "EHOSTDOWN", "host is down"}, + {65, "EHOSTUNREACH", "no route to host"}, + {66, "ENOTEMPTY", "directory not empty"}, + {67, "EPROCLIM", "too many processes"}, + {68, "EUSERS", "too many users"}, + {69, "EDQUOT", "disk quota exceeded"}, + {70, "ESTALE", "stale NFS file handle"}, + {71, "EREMOTE", "too many levels of remote in path"}, + {72, "EBADRPC", "RPC struct is bad"}, + {73, "ERPCMISMATCH", "RPC version wrong"}, + {74, "EPROGUNAVAIL", "RPC program not available"}, + {75, "EPROGMISMATCH", "program version wrong"}, + {76, "EPROCUNAVAIL", "bad procedure for program"}, + {77, "ENOLCK", "no locks available"}, + {78, "ENOSYS", "function not implemented"}, + {79, "EFTYPE", "inappropriate file type or format"}, + {80, "EAUTH", "authentication error"}, + {81, "ENEEDAUTH", "need authenticator"}, + {82, "EIPSEC", "IPsec processing failure"}, + {83, "ENOATTR", "attribute not found"}, + {84, "EILSEQ", "illegal byte sequence"}, + {85, "ENOMEDIUM", "no medium found"}, + {86, "EMEDIUMTYPE", "wrong medium type"}, + {87, "EOVERFLOW", "value too large to be stored in data type"}, + {88, "ECANCELED", "operation canceled"}, + {89, "EIDRM", "identifier removed"}, + {90, "ENOMSG", "no message of desired type"}, + {91, "ELAST", "not supported"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal instruction", - 5: "trace/BPT trap", - 6: "abort trap", - 7: "EMT trap", - 8: "floating point exception", - 9: "killed", - 10: "bus error", - 11: "segmentation fault", - 12: "bad system call", - 13: "broken pipe", - 14: "alarm clock", - 15: "terminated", - 16: "urgent I/O condition", - 17: "stopped (signal)", - 18: "stopped", - 19: "continued", - 20: "child exited", - 21: "stopped (tty input)", - 22: "stopped (tty output)", - 23: "I/O possible", - 24: "cputime limit exceeded", - 25: "filesize limit exceeded", - 26: "virtual timer expired", - 27: "profiling timer expired", - 28: "window size changes", - 29: "information request", - 30: "user defined signal 1", - 31: "user defined signal 2", - 32: "thread AST", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal instruction"}, + {5, "SIGTRAP", "trace/BPT trap"}, + {6, "SIGABRT", "abort trap"}, + {7, "SIGEMT", "EMT trap"}, + {8, "SIGFPE", "floating point exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus error"}, + {11, "SIGSEGV", "segmentation fault"}, + {12, "SIGSYS", "bad system call"}, + {13, "SIGPIPE", "broken pipe"}, + {14, "SIGALRM", "alarm clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGURG", "urgent I/O condition"}, + {17, "SIGSTOP", "suspended (signal)"}, + {18, "SIGTSTP", "suspended"}, + {19, "SIGCONT", "continued"}, + {20, "SIGCHLD", "child exited"}, + {21, "SIGTTIN", "stopped (tty input)"}, + {22, "SIGTTOU", "stopped (tty output)"}, + {23, "SIGIO", "I/O possible"}, + {24, "SIGXCPU", "cputime limit exceeded"}, + {25, "SIGXFSZ", "filesize limit exceeded"}, + {26, "SIGVTALRM", "virtual timer expired"}, + {27, "SIGPROF", "profiling timer expired"}, + {28, "SIGWINCH", "window size changes"}, + {29, "SIGINFO", "information request"}, + {30, "SIGUSR1", "user defined signal 1"}, + {31, "SIGUSR2", "user defined signal 2"}, + {32, "SIGTHR", "thread AST"}, } diff --git a/vendor/golang.org/x/sys/unix/zerrors_solaris_amd64.go b/vendor/golang.org/x/sys/unix/zerrors_solaris_amd64.go index 09eedb00935..be42830cf3d 100644 --- a/vendor/golang.org/x/sys/unix/zerrors_solaris_amd64.go +++ b/vendor/golang.org/x/sys/unix/zerrors_solaris_amd64.go @@ -1319,171 +1319,179 @@ const ( ) // Error table -var errors = [...]string{ - 1: "not owner", - 2: "no such file or directory", - 3: "no such process", - 4: "interrupted system call", - 5: "I/O error", - 6: "no such device or address", - 7: "arg list too long", - 8: "exec format error", - 9: "bad file number", - 10: "no child processes", - 11: "resource temporarily unavailable", - 12: "not enough space", - 13: "permission denied", - 14: "bad address", - 15: "block device required", - 16: "device busy", - 17: "file exists", - 18: "cross-device link", - 19: "no such device", - 20: "not a directory", - 21: "is a directory", - 22: "invalid argument", - 23: "file table overflow", - 24: "too many open files", - 25: "inappropriate ioctl for device", - 26: "text file busy", - 27: "file too large", - 28: "no space left on device", - 29: "illegal seek", - 30: "read-only file system", - 31: "too many links", - 32: "broken pipe", - 33: "argument out of domain", - 34: "result too large", - 35: "no message of desired type", - 36: "identifier removed", - 37: "channel number out of range", - 38: "level 2 not synchronized", - 39: "level 3 halted", - 40: "level 3 reset", - 41: "link number out of range", - 42: "protocol driver not attached", - 43: "no CSI structure available", - 44: "level 2 halted", - 45: "deadlock situation detected/avoided", - 46: "no record locks available", - 47: "operation canceled", - 48: "operation not supported", - 49: "disc quota exceeded", - 50: "bad exchange descriptor", - 51: "bad request descriptor", - 52: "message tables full", - 53: "anode table overflow", - 54: "bad request code", - 55: "invalid slot", - 56: "file locking deadlock", - 57: "bad font file format", - 58: "owner of the lock died", - 59: "lock is not recoverable", - 60: "not a stream device", - 61: "no data available", - 62: "timer expired", - 63: "out of stream resources", - 64: "machine is not on the network", - 65: "package not installed", - 66: "object is remote", - 67: "link has been severed", - 68: "advertise error", - 69: "srmount error", - 70: "communication error on send", - 71: "protocol error", - 72: "locked lock was unmapped ", - 73: "facility is not active", - 74: "multihop attempted", - 77: "not a data message", - 78: "file name too long", - 79: "value too large for defined data type", - 80: "name not unique on network", - 81: "file descriptor in bad state", - 82: "remote address changed", - 83: "can not access a needed shared library", - 84: "accessing a corrupted shared library", - 85: ".lib section in a.out corrupted", - 86: "attempting to link in more shared libraries than system limit", - 87: "can not exec a shared library directly", - 88: "illegal byte sequence", - 89: "operation not applicable", - 90: "number of symbolic links encountered during path name traversal exceeds MAXSYMLINKS", - 91: "error 91", - 92: "error 92", - 93: "directory not empty", - 94: "too many users", - 95: "socket operation on non-socket", - 96: "destination address required", - 97: "message too long", - 98: "protocol wrong type for socket", - 99: "option not supported by protocol", - 120: "protocol not supported", - 121: "socket type not supported", - 122: "operation not supported on transport endpoint", - 123: "protocol family not supported", - 124: "address family not supported by protocol family", - 125: "address already in use", - 126: "cannot assign requested address", - 127: "network is down", - 128: "network is unreachable", - 129: "network dropped connection because of reset", - 130: "software caused connection abort", - 131: "connection reset by peer", - 132: "no buffer space available", - 133: "transport endpoint is already connected", - 134: "transport endpoint is not connected", - 143: "cannot send after socket shutdown", - 144: "too many references: cannot splice", - 145: "connection timed out", - 146: "connection refused", - 147: "host is down", - 148: "no route to host", - 149: "operation already in progress", - 150: "operation now in progress", - 151: "stale NFS file handle", +var errorList = [...]struct { + num syscall.Errno + name string + desc string +}{ + {1, "EPERM", "not owner"}, + {2, "ENOENT", "no such file or directory"}, + {3, "ESRCH", "no such process"}, + {4, "EINTR", "interrupted system call"}, + {5, "EIO", "I/O error"}, + {6, "ENXIO", "no such device or address"}, + {7, "E2BIG", "arg list too long"}, + {8, "ENOEXEC", "exec format error"}, + {9, "EBADF", "bad file number"}, + {10, "ECHILD", "no child processes"}, + {11, "EAGAIN", "resource temporarily unavailable"}, + {12, "ENOMEM", "not enough space"}, + {13, "EACCES", "permission denied"}, + {14, "EFAULT", "bad address"}, + {15, "ENOTBLK", "block device required"}, + {16, "EBUSY", "device busy"}, + {17, "EEXIST", "file exists"}, + {18, "EXDEV", "cross-device link"}, + {19, "ENODEV", "no such device"}, + {20, "ENOTDIR", "not a directory"}, + {21, "EISDIR", "is a directory"}, + {22, "EINVAL", "invalid argument"}, + {23, "ENFILE", "file table overflow"}, + {24, "EMFILE", "too many open files"}, + {25, "ENOTTY", "inappropriate ioctl for device"}, + {26, "ETXTBSY", "text file busy"}, + {27, "EFBIG", "file too large"}, + {28, "ENOSPC", "no space left on device"}, + {29, "ESPIPE", "illegal seek"}, + {30, "EROFS", "read-only file system"}, + {31, "EMLINK", "too many links"}, + {32, "EPIPE", "broken pipe"}, + {33, "EDOM", "argument out of domain"}, + {34, "ERANGE", "result too large"}, + {35, "ENOMSG", "no message of desired type"}, + {36, "EIDRM", "identifier removed"}, + {37, "ECHRNG", "channel number out of range"}, + {38, "EL2NSYNC", "level 2 not synchronized"}, + {39, "EL3HLT", "level 3 halted"}, + {40, "EL3RST", "level 3 reset"}, + {41, "ELNRNG", "link number out of range"}, + {42, "EUNATCH", "protocol driver not attached"}, + {43, "ENOCSI", "no CSI structure available"}, + {44, "EL2HLT", "level 2 halted"}, + {45, "EDEADLK", "deadlock situation detected/avoided"}, + {46, "ENOLCK", "no record locks available"}, + {47, "ECANCELED", "operation canceled"}, + {48, "ENOTSUP", "operation not supported"}, + {49, "EDQUOT", "disc quota exceeded"}, + {50, "EBADE", "bad exchange descriptor"}, + {51, "EBADR", "bad request descriptor"}, + {52, "EXFULL", "message tables full"}, + {53, "ENOANO", "anode table overflow"}, + {54, "EBADRQC", "bad request code"}, + {55, "EBADSLT", "invalid slot"}, + {56, "EDEADLOCK", "file locking deadlock"}, + {57, "EBFONT", "bad font file format"}, + {58, "EOWNERDEAD", "owner of the lock died"}, + {59, "ENOTRECOVERABLE", "lock is not recoverable"}, + {60, "ENOSTR", "not a stream device"}, + {61, "ENODATA", "no data available"}, + {62, "ETIME", "timer expired"}, + {63, "ENOSR", "out of stream resources"}, + {64, "ENONET", "machine is not on the network"}, + {65, "ENOPKG", "package not installed"}, + {66, "EREMOTE", "object is remote"}, + {67, "ENOLINK", "link has been severed"}, + {68, "EADV", "advertise error"}, + {69, "ESRMNT", "srmount error"}, + {70, "ECOMM", "communication error on send"}, + {71, "EPROTO", "protocol error"}, + {72, "ELOCKUNMAPPED", "locked lock was unmapped "}, + {73, "ENOTACTIVE", "facility is not active"}, + {74, "EMULTIHOP", "multihop attempted"}, + {77, "EBADMSG", "not a data message"}, + {78, "ENAMETOOLONG", "file name too long"}, + {79, "EOVERFLOW", "value too large for defined data type"}, + {80, "ENOTUNIQ", "name not unique on network"}, + {81, "EBADFD", "file descriptor in bad state"}, + {82, "EREMCHG", "remote address changed"}, + {83, "ELIBACC", "can not access a needed shared library"}, + {84, "ELIBBAD", "accessing a corrupted shared library"}, + {85, "ELIBSCN", ".lib section in a.out corrupted"}, + {86, "ELIBMAX", "attempting to link in more shared libraries than system limit"}, + {87, "ELIBEXEC", "can not exec a shared library directly"}, + {88, "EILSEQ", "illegal byte sequence"}, + {89, "ENOSYS", "operation not applicable"}, + {90, "ELOOP", "number of symbolic links encountered during path name traversal exceeds MAXSYMLINKS"}, + {91, "ERESTART", "error 91"}, + {92, "ESTRPIPE", "error 92"}, + {93, "ENOTEMPTY", "directory not empty"}, + {94, "EUSERS", "too many users"}, + {95, "ENOTSOCK", "socket operation on non-socket"}, + {96, "EDESTADDRREQ", "destination address required"}, + {97, "EMSGSIZE", "message too long"}, + {98, "EPROTOTYPE", "protocol wrong type for socket"}, + {99, "ENOPROTOOPT", "option not supported by protocol"}, + {120, "EPROTONOSUPPORT", "protocol not supported"}, + {121, "ESOCKTNOSUPPORT", "socket type not supported"}, + {122, "EOPNOTSUPP", "operation not supported on transport endpoint"}, + {123, "EPFNOSUPPORT", "protocol family not supported"}, + {124, "EAFNOSUPPORT", "address family not supported by protocol family"}, + {125, "EADDRINUSE", "address already in use"}, + {126, "EADDRNOTAVAIL", "cannot assign requested address"}, + {127, "ENETDOWN", "network is down"}, + {128, "ENETUNREACH", "network is unreachable"}, + {129, "ENETRESET", "network dropped connection because of reset"}, + {130, "ECONNABORTED", "software caused connection abort"}, + {131, "ECONNRESET", "connection reset by peer"}, + {132, "ENOBUFS", "no buffer space available"}, + {133, "EISCONN", "transport endpoint is already connected"}, + {134, "ENOTCONN", "transport endpoint is not connected"}, + {143, "ESHUTDOWN", "cannot send after socket shutdown"}, + {144, "ETOOMANYREFS", "too many references: cannot splice"}, + {145, "ETIMEDOUT", "connection timed out"}, + {146, "ECONNREFUSED", "connection refused"}, + {147, "EHOSTDOWN", "host is down"}, + {148, "EHOSTUNREACH", "no route to host"}, + {149, "EALREADY", "operation already in progress"}, + {150, "EINPROGRESS", "operation now in progress"}, + {151, "ESTALE", "stale NFS file handle"}, } // Signal table -var signals = [...]string{ - 1: "hangup", - 2: "interrupt", - 3: "quit", - 4: "illegal Instruction", - 5: "trace/Breakpoint Trap", - 6: "abort", - 7: "emulation Trap", - 8: "arithmetic Exception", - 9: "killed", - 10: "bus Error", - 11: "segmentation Fault", - 12: "bad System Call", - 13: "broken Pipe", - 14: "alarm Clock", - 15: "terminated", - 16: "user Signal 1", - 17: "user Signal 2", - 18: "child Status Changed", - 19: "power-Fail/Restart", - 20: "window Size Change", - 21: "urgent Socket Condition", - 22: "pollable Event", - 23: "stopped (signal)", - 24: "stopped (user)", - 25: "continued", - 26: "stopped (tty input)", - 27: "stopped (tty output)", - 28: "virtual Timer Expired", - 29: "profiling Timer Expired", - 30: "cpu Limit Exceeded", - 31: "file Size Limit Exceeded", - 32: "no runnable lwp", - 33: "inter-lwp signal", - 34: "checkpoint Freeze", - 35: "checkpoint Thaw", - 36: "thread Cancellation", - 37: "resource Lost", - 38: "resource Control Exceeded", - 39: "reserved for JVM 1", - 40: "reserved for JVM 2", - 41: "information Request", +var signalList = [...]struct { + num syscall.Signal + name string + desc string +}{ + {1, "SIGHUP", "hangup"}, + {2, "SIGINT", "interrupt"}, + {3, "SIGQUIT", "quit"}, + {4, "SIGILL", "illegal Instruction"}, + {5, "SIGTRAP", "trace/Breakpoint Trap"}, + {6, "SIGABRT", "abort"}, + {7, "SIGEMT", "emulation Trap"}, + {8, "SIGFPE", "arithmetic Exception"}, + {9, "SIGKILL", "killed"}, + {10, "SIGBUS", "bus Error"}, + {11, "SIGSEGV", "segmentation Fault"}, + {12, "SIGSYS", "bad System Call"}, + {13, "SIGPIPE", "broken Pipe"}, + {14, "SIGALRM", "alarm Clock"}, + {15, "SIGTERM", "terminated"}, + {16, "SIGUSR1", "user Signal 1"}, + {17, "SIGUSR2", "user Signal 2"}, + {18, "SIGCHLD", "child Status Changed"}, + {19, "SIGPWR", "power-Fail/Restart"}, + {20, "SIGWINCH", "window Size Change"}, + {21, "SIGURG", "urgent Socket Condition"}, + {22, "SIGIO", "pollable Event"}, + {23, "SIGSTOP", "stopped (signal)"}, + {24, "SIGTSTP", "stopped (user)"}, + {25, "SIGCONT", "continued"}, + {26, "SIGTTIN", "stopped (tty input)"}, + {27, "SIGTTOU", "stopped (tty output)"}, + {28, "SIGVTALRM", "virtual Timer Expired"}, + {29, "SIGPROF", "profiling Timer Expired"}, + {30, "SIGXCPU", "cpu Limit Exceeded"}, + {31, "SIGXFSZ", "file Size Limit Exceeded"}, + {32, "SIGWAITING", "no runnable lwp"}, + {33, "SIGLWP", "inter-lwp signal"}, + {34, "SIGFREEZE", "checkpoint Freeze"}, + {35, "SIGTHAW", "checkpoint Thaw"}, + {36, "SIGCANCEL", "thread Cancellation"}, + {37, "SIGLOST", "resource Lost"}, + {38, "SIGXRES", "resource Control Exceeded"}, + {39, "SIGJVM1", "reserved for JVM 1"}, + {40, "SIGJVM2", "reserved for JVM 2"}, + {41, "SIGINFO", "information Request"}, } diff --git a/vendor/golang.org/x/sys/unix/zsyscall_darwin_386.go b/vendor/golang.org/x/sys/unix/zsyscall_darwin_386.go index 763ae4fbb93..ac02d4d8419 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_darwin_386.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_darwin_386.go @@ -399,6 +399,83 @@ func pipe() (r int, w int, err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func getxattr(path string, attr string, dest *byte, size int, position uint32, options int) (sz int, err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + r0, _, e1 := Syscall6(SYS_GETXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(unsafe.Pointer(dest)), uintptr(size), uintptr(position), uintptr(options)) + sz = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func setxattr(path string, attr string, data *byte, size int, position uint32, options int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_SETXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(unsafe.Pointer(data)), uintptr(size), uintptr(position), uintptr(options)) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func removexattr(path string, attr string, options int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + _, _, e1 := Syscall(SYS_REMOVEXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(options)) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func listxattr(path string, dest *byte, size int, options int) (sz int, err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + r0, _, e1 := Syscall6(SYS_LISTXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(dest)), uintptr(size), uintptr(options), 0, 0) + sz = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func kill(pid int, signum int, posix int) (err error) { _, _, e1 := Syscall(SYS_KILL, uintptr(pid), uintptr(signum), uintptr(posix)) if e1 != 0 { @@ -693,6 +770,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT64, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS64, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_darwin_amd64.go b/vendor/golang.org/x/sys/unix/zsyscall_darwin_amd64.go index d6808e072de..1dd3cfa0e17 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_darwin_amd64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_darwin_amd64.go @@ -399,6 +399,83 @@ func pipe() (r int, w int, err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func getxattr(path string, attr string, dest *byte, size int, position uint32, options int) (sz int, err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + r0, _, e1 := Syscall6(SYS_GETXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(unsafe.Pointer(dest)), uintptr(size), uintptr(position), uintptr(options)) + sz = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func setxattr(path string, attr string, data *byte, size int, position uint32, options int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_SETXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(unsafe.Pointer(data)), uintptr(size), uintptr(position), uintptr(options)) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func removexattr(path string, attr string, options int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + _, _, e1 := Syscall(SYS_REMOVEXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(options)) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func listxattr(path string, dest *byte, size int, options int) (sz int, err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + r0, _, e1 := Syscall6(SYS_LISTXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(dest)), uintptr(size), uintptr(options), 0, 0) + sz = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func kill(pid int, signum int, posix int) (err error) { _, _, e1 := Syscall(SYS_KILL, uintptr(pid), uintptr(signum), uintptr(posix)) if e1 != 0 { @@ -693,6 +770,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT64, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS64, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_darwin_arm.go b/vendor/golang.org/x/sys/unix/zsyscall_darwin_arm.go index 6ae95e6b9a2..cab46e74ba4 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_darwin_arm.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_darwin_arm.go @@ -1,4 +1,4 @@ -// mksyscall.pl -tags darwin,arm syscall_bsd.go syscall_darwin.go syscall_darwin_arm.go +// mksyscall.pl -l32 -tags darwin,arm syscall_bsd.go syscall_darwin.go syscall_darwin_arm.go // Code generated by the command above; see README.md. DO NOT EDIT. // +build darwin,arm @@ -399,6 +399,83 @@ func pipe() (r int, w int, err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func getxattr(path string, attr string, dest *byte, size int, position uint32, options int) (sz int, err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + r0, _, e1 := Syscall6(SYS_GETXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(unsafe.Pointer(dest)), uintptr(size), uintptr(position), uintptr(options)) + sz = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func setxattr(path string, attr string, data *byte, size int, position uint32, options int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_SETXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(unsafe.Pointer(data)), uintptr(size), uintptr(position), uintptr(options)) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func removexattr(path string, attr string, options int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + _, _, e1 := Syscall(SYS_REMOVEXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(options)) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func listxattr(path string, dest *byte, size int, options int) (sz int, err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + r0, _, e1 := Syscall6(SYS_LISTXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(dest)), uintptr(size), uintptr(options), 0, 0) + sz = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func kill(pid int, signum int, posix int) (err error) { _, _, e1 := Syscall(SYS_KILL, uintptr(pid), uintptr(signum), uintptr(posix)) if e1 != 0 { @@ -693,6 +770,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT64, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS64, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_darwin_arm64.go b/vendor/golang.org/x/sys/unix/zsyscall_darwin_arm64.go index ca6a7ea8b76..13478dd0bcf 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_darwin_arm64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_darwin_arm64.go @@ -399,6 +399,83 @@ func pipe() (r int, w int, err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func getxattr(path string, attr string, dest *byte, size int, position uint32, options int) (sz int, err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + r0, _, e1 := Syscall6(SYS_GETXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(unsafe.Pointer(dest)), uintptr(size), uintptr(position), uintptr(options)) + sz = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func setxattr(path string, attr string, data *byte, size int, position uint32, options int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_SETXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(unsafe.Pointer(data)), uintptr(size), uintptr(position), uintptr(options)) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func removexattr(path string, attr string, options int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + var _p1 *byte + _p1, err = BytePtrFromString(attr) + if err != nil { + return + } + _, _, e1 := Syscall(SYS_REMOVEXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(_p1)), uintptr(options)) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + +func listxattr(path string, dest *byte, size int, options int) (sz int, err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + r0, _, e1 := Syscall6(SYS_LISTXATTR, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(dest)), uintptr(size), uintptr(options), 0, 0) + sz = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func kill(pid int, signum int, posix int) (err error) { _, _, e1 := Syscall(SYS_KILL, uintptr(pid), uintptr(signum), uintptr(posix)) if e1 != 0 { @@ -693,6 +770,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT64, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS64, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_dragonfly_amd64.go b/vendor/golang.org/x/sys/unix/zsyscall_dragonfly_amd64.go index a0241de195a..91f36e9ec30 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_dragonfly_amd64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_dragonfly_amd64.go @@ -618,6 +618,21 @@ func Fchmod(fd int, mode uint32) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FCHMODAT, uintptr(dirfd), uintptr(unsafe.Pointer(_p0)), uintptr(mode), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { @@ -659,6 +674,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_freebsd_386.go b/vendor/golang.org/x/sys/unix/zsyscall_freebsd_386.go index fd9ca5a4a69..a86434a7ba8 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_freebsd_386.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_freebsd_386.go @@ -924,6 +924,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_freebsd_amd64.go b/vendor/golang.org/x/sys/unix/zsyscall_freebsd_amd64.go index a9f18b22d32..040e2f760cd 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_freebsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_freebsd_amd64.go @@ -924,6 +924,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_freebsd_arm.go b/vendor/golang.org/x/sys/unix/zsyscall_freebsd_arm.go index 9823e18a176..cddc5e86b19 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_freebsd_arm.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_freebsd_arm.go @@ -924,6 +924,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_386.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_386.go index ef9602c1eb0..433becfd02a 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_386.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_386.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_amd64.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_amd64.go index 63054b35859..33c02b2695d 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_amd64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_amd64.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) @@ -1784,17 +1795,6 @@ func Seek(fd int, offset int64, whence int) (off int64, err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT -func Select(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timeval) (n int, err error) { - r0, _, e1 := Syscall6(SYS_SELECT, uintptr(nfd), uintptr(unsafe.Pointer(r)), uintptr(unsafe.Pointer(w)), uintptr(unsafe.Pointer(e)), uintptr(unsafe.Pointer(timeout)), 0) - n = int(r0) - if e1 != 0 { - err = errnoErr(e1) - } - return -} - -// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT - func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) { r0, _, e1 := Syscall6(SYS_SENDFILE, uintptr(outfd), uintptr(infd), uintptr(unsafe.Pointer(offset)), uintptr(count), 0, 0) written = int(r0) @@ -1897,21 +1897,6 @@ func Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n i // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT -func Stat(path string, stat *Stat_t) (err error) { - var _p0 *byte - _p0, err = BytePtrFromString(path) - if err != nil { - return - } - _, _, e1 := Syscall(SYS_STAT, uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), 0) - if e1 != 0 { - err = errnoErr(e1) - } - return -} - -// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT - func Statfs(path string, buf *Statfs_t) (err error) { var _p0 *byte _p0, err = BytePtrFromString(path) diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_arm.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_arm.go index 8b10ee14452..f91b56c2175 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_arm.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_arm.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_arm64.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_arm64.go index 8f276d65ff9..52d75952503 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_arm64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_arm64.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) @@ -1541,6 +1552,16 @@ func EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall6(SYS_FADVISE64, uintptr(fd), uintptr(offset), uintptr(length), uintptr(advice), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_mips.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_mips.go index 61169b331bb..970a5c132d5 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_mips.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_mips.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) @@ -1534,6 +1545,16 @@ func Dup2(oldfd int, newfd int) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall9(SYS_FADVISE64, uintptr(fd), 0, uintptr(offset>>32), uintptr(offset), uintptr(length>>32), uintptr(length), uintptr(advice), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { @@ -1737,9 +1758,9 @@ func Shutdown(fd int, how int) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT -func Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error) { - r0, r1, e1 := Syscall6(SYS_SPLICE, uintptr(rfd), uintptr(unsafe.Pointer(roff)), uintptr(wfd), uintptr(unsafe.Pointer(woff)), uintptr(len), uintptr(flags)) - n = int64(int64(r0)<<32 | int64(r1)) +func Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int, err error) { + r0, _, e1 := Syscall6(SYS_SPLICE, uintptr(rfd), uintptr(unsafe.Pointer(roff)), uintptr(wfd), uintptr(unsafe.Pointer(woff)), uintptr(len), uintptr(flags)) + n = int(r0) if e1 != 0 { err = errnoErr(e1) } diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_mips64.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_mips64.go index 4cb59b4a5c7..b989d0f2826 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_mips64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_mips64.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) @@ -1551,6 +1562,16 @@ func EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall6(SYS_FADVISE64, uintptr(fd), uintptr(offset), uintptr(length), uintptr(advice), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_mips64le.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_mips64le.go index 0b547ae3010..1f8d14cacc5 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_mips64le.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_mips64le.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) @@ -1551,6 +1562,16 @@ func EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall6(SYS_FADVISE64, uintptr(fd), uintptr(offset), uintptr(length), uintptr(advice), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_mipsle.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_mipsle.go index cd94d3a832b..a9c7e520e49 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_mipsle.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_mipsle.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) @@ -1534,6 +1545,16 @@ func Dup2(oldfd int, newfd int) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall9(SYS_FADVISE64, uintptr(fd), 0, uintptr(offset), uintptr(offset>>32), uintptr(length), uintptr(length>>32), uintptr(advice), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { @@ -1737,9 +1758,9 @@ func Shutdown(fd int, how int) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT -func Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error) { - r0, r1, e1 := Syscall6(SYS_SPLICE, uintptr(rfd), uintptr(unsafe.Pointer(roff)), uintptr(wfd), uintptr(unsafe.Pointer(woff)), uintptr(len), uintptr(flags)) - n = int64(int64(r1)<<32 | int64(r0)) +func Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int, err error) { + r0, _, e1 := Syscall6(SYS_SPLICE, uintptr(rfd), uintptr(unsafe.Pointer(roff)), uintptr(wfd), uintptr(unsafe.Pointer(woff)), uintptr(len), uintptr(flags)) + n = int(r0) if e1 != 0 { err = errnoErr(e1) } diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_ppc64.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_ppc64.go index cdad555a5d5..3bb9a20992f 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_ppc64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_ppc64.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) @@ -1551,6 +1562,16 @@ func Dup2(oldfd int, newfd int) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall6(SYS_FADVISE64, uintptr(fd), uintptr(offset), uintptr(length), uintptr(advice), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_ppc64le.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_ppc64le.go index 38f4e44b620..56116623d69 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_ppc64le.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_ppc64le.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) @@ -1551,6 +1562,16 @@ func Dup2(oldfd int, newfd int) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall6(SYS_FADVISE64, uintptr(fd), uintptr(offset), uintptr(length), uintptr(advice), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_s390x.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_s390x.go index c443baf63f0..9696a0199df 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_s390x.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_s390x.go @@ -995,6 +995,17 @@ func Nanosleep(time *Timespec, leftover *Timespec) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func PerfEventOpen(attr *PerfEventAttr, pid int, cpu int, groupFd int, flags int) (fd int, err error) { + r0, _, e1 := Syscall6(SYS_PERF_EVENT_OPEN, uintptr(unsafe.Pointer(attr)), uintptr(pid), uintptr(cpu), uintptr(groupFd), uintptr(flags), 0) + fd = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func PivotRoot(newroot string, putold string) (err error) { var _p0 *byte _p0, err = BytePtrFromString(newroot) diff --git a/vendor/golang.org/x/sys/unix/zsyscall_linux_sparc64.go b/vendor/golang.org/x/sys/unix/zsyscall_linux_sparc64.go index 2dd98434ead..c01b3b6bab2 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_linux_sparc64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_linux_sparc64.go @@ -1222,6 +1222,16 @@ func EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall6(SYS_FADVISE64, uintptr(fd), uintptr(offset), uintptr(length), uintptr(advice), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Dup2(oldfd int, newfd int) (err error) { _, _, e1 := Syscall(SYS_DUP2, uintptr(oldfd), uintptr(newfd), 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_netbsd_386.go b/vendor/golang.org/x/sys/unix/zsyscall_netbsd_386.go index 62eadff1c96..fb4b9627829 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_netbsd_386.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_netbsd_386.go @@ -571,6 +571,16 @@ func Exit(code int) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall9(SYS_POSIX_FADVISE, uintptr(fd), 0, uintptr(offset), uintptr(offset>>32), 0, uintptr(length), uintptr(length>>32), uintptr(advice), 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchdir(fd int) (err error) { _, _, e1 := Syscall(SYS_FCHDIR, uintptr(fd), 0, 0) if e1 != 0 { @@ -601,6 +611,21 @@ func Fchmod(fd int, mode uint32) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FCHMODAT, uintptr(dirfd), uintptr(unsafe.Pointer(_p0)), uintptr(mode), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { @@ -642,6 +667,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fsync(fd int) (err error) { _, _, e1 := Syscall(SYS_FSYNC, uintptr(fd), 0, 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_netbsd_amd64.go b/vendor/golang.org/x/sys/unix/zsyscall_netbsd_amd64.go index 307f4e99e93..beac82ef86a 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_netbsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_netbsd_amd64.go @@ -571,6 +571,16 @@ func Exit(code int) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall6(SYS_POSIX_FADVISE, uintptr(fd), 0, uintptr(offset), 0, uintptr(length), uintptr(advice)) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchdir(fd int) (err error) { _, _, e1 := Syscall(SYS_FCHDIR, uintptr(fd), 0, 0) if e1 != 0 { @@ -601,6 +611,21 @@ func Fchmod(fd int, mode uint32) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FCHMODAT, uintptr(dirfd), uintptr(unsafe.Pointer(_p0)), uintptr(mode), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { @@ -642,6 +667,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fsync(fd int) (err error) { _, _, e1 := Syscall(SYS_FSYNC, uintptr(fd), 0, 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_netbsd_arm.go b/vendor/golang.org/x/sys/unix/zsyscall_netbsd_arm.go index 61109313c81..7bd5f60b00d 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_netbsd_arm.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_netbsd_arm.go @@ -571,6 +571,16 @@ func Exit(code int) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fadvise(fd int, offset int64, length int64, advice int) (err error) { + _, _, e1 := Syscall9(SYS_POSIX_FADVISE, uintptr(fd), 0, uintptr(offset), uintptr(offset>>32), 0, uintptr(length), uintptr(length>>32), uintptr(advice), 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchdir(fd int) (err error) { _, _, e1 := Syscall(SYS_FCHDIR, uintptr(fd), 0, 0) if e1 != 0 { @@ -601,6 +611,21 @@ func Fchmod(fd int, mode uint32) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FCHMODAT, uintptr(dirfd), uintptr(unsafe.Pointer(_p0)), uintptr(mode), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { @@ -642,6 +667,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fsync(fd int) (err error) { _, _, e1 := Syscall(SYS_FSYNC, uintptr(fd), 0, 0) if e1 != 0 { diff --git a/vendor/golang.org/x/sys/unix/zsyscall_openbsd_386.go b/vendor/golang.org/x/sys/unix/zsyscall_openbsd_386.go index 003f820e679..49b3b5e8a43 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_openbsd_386.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_openbsd_386.go @@ -599,6 +599,21 @@ func Fchmod(fd int, mode uint32) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FCHMODAT, uintptr(dirfd), uintptr(unsafe.Pointer(_p0)), uintptr(mode), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { @@ -640,6 +655,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { @@ -750,6 +780,17 @@ func Getrlimit(which int, lim *Rlimit) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Getrtable() (rtable int, err error) { + r0, _, e1 := RawSyscall(SYS_GETRTABLE, 0, 0, 0) + rtable = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Getrusage(who int, rusage *Rusage) (err error) { _, _, e1 := RawSyscall(SYS_GETRUSAGE, uintptr(who), uintptr(unsafe.Pointer(rusage)), 0) if e1 != 0 { @@ -1224,6 +1265,16 @@ func Setrlimit(which int, lim *Rlimit) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Setrtable(rtable int) (err error) { + _, _, e1 := RawSyscall(SYS_SETRTABLE, uintptr(rtable), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Setsid() (pid int, err error) { r0, _, e1 := RawSyscall(SYS_SETSID, 0, 0, 0) pid = int(r0) diff --git a/vendor/golang.org/x/sys/unix/zsyscall_openbsd_amd64.go b/vendor/golang.org/x/sys/unix/zsyscall_openbsd_amd64.go index ba0e8f32996..c4c7d8540c0 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_openbsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_openbsd_amd64.go @@ -599,6 +599,21 @@ func Fchmod(fd int, mode uint32) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FCHMODAT, uintptr(dirfd), uintptr(unsafe.Pointer(_p0)), uintptr(mode), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { @@ -640,6 +655,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { @@ -750,6 +780,17 @@ func Getrlimit(which int, lim *Rlimit) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Getrtable() (rtable int, err error) { + r0, _, e1 := RawSyscall(SYS_GETRTABLE, 0, 0, 0) + rtable = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Getrusage(who int, rusage *Rusage) (err error) { _, _, e1 := RawSyscall(SYS_GETRUSAGE, uintptr(who), uintptr(unsafe.Pointer(rusage)), 0) if e1 != 0 { @@ -1224,6 +1265,16 @@ func Setrlimit(which int, lim *Rlimit) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Setrtable(rtable int) (err error) { + _, _, e1 := RawSyscall(SYS_SETRTABLE, uintptr(rtable), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Setsid() (pid int, err error) { r0, _, e1 := RawSyscall(SYS_SETSID, 0, 0, 0) pid = int(r0) diff --git a/vendor/golang.org/x/sys/unix/zsyscall_openbsd_arm.go b/vendor/golang.org/x/sys/unix/zsyscall_openbsd_arm.go index 2ce02c7c4e7..210285b0ba5 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_openbsd_arm.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_openbsd_arm.go @@ -599,6 +599,21 @@ func Fchmod(fd int, mode uint32) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fchmodat(dirfd int, path string, mode uint32, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FCHMODAT, uintptr(dirfd), uintptr(unsafe.Pointer(_p0)), uintptr(mode), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fchown(fd int, uid int, gid int) (err error) { _, _, e1 := Syscall(SYS_FCHOWN, uintptr(fd), uintptr(uid), uintptr(gid)) if e1 != 0 { @@ -640,6 +655,21 @@ func Fstat(fd int, stat *Stat_t) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := Syscall6(SYS_FSTATAT, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Fstatfs(fd int, stat *Statfs_t) (err error) { _, _, e1 := Syscall(SYS_FSTATFS, uintptr(fd), uintptr(unsafe.Pointer(stat)), 0) if e1 != 0 { @@ -750,6 +780,17 @@ func Getrlimit(which int, lim *Rlimit) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Getrtable() (rtable int, err error) { + r0, _, e1 := RawSyscall(SYS_GETRTABLE, 0, 0, 0) + rtable = int(r0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Getrusage(who int, rusage *Rusage) (err error) { _, _, e1 := RawSyscall(SYS_GETRUSAGE, uintptr(who), uintptr(unsafe.Pointer(rusage)), 0) if e1 != 0 { @@ -1224,6 +1265,16 @@ func Setrlimit(which int, lim *Rlimit) (err error) { // THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT +func Setrtable(rtable int) (err error) { + _, _, e1 := RawSyscall(SYS_SETRTABLE, uintptr(rtable), 0, 0) + if e1 != 0 { + err = errnoErr(e1) + } + return +} + +// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT + func Setsid() (pid int, err error) { r0, _, e1 := RawSyscall(SYS_SETSID, 0, 0, 0) pid = int(r0) diff --git a/vendor/golang.org/x/sys/unix/zsyscall_solaris_amd64.go b/vendor/golang.org/x/sys/unix/zsyscall_solaris_amd64.go index f5d01b3a883..397896300de 100644 --- a/vendor/golang.org/x/sys/unix/zsyscall_solaris_amd64.go +++ b/vendor/golang.org/x/sys/unix/zsyscall_solaris_amd64.go @@ -50,6 +50,7 @@ import ( //go:cgo_import_dynamic libc_flock flock "libc.so" //go:cgo_import_dynamic libc_fpathconf fpathconf "libc.so" //go:cgo_import_dynamic libc_fstat fstat "libc.so" +//go:cgo_import_dynamic libc_fstatat fstatat "libc.so" //go:cgo_import_dynamic libc_fstatvfs fstatvfs "libc.so" //go:cgo_import_dynamic libc_getdents getdents "libc.so" //go:cgo_import_dynamic libc_getgid getgid "libc.so" @@ -127,6 +128,7 @@ import ( //go:cgo_import_dynamic libc___xnet_connect __xnet_connect "libsocket.so" //go:cgo_import_dynamic libc_mmap mmap "libc.so" //go:cgo_import_dynamic libc_munmap munmap "libc.so" +//go:cgo_import_dynamic libc_sendfile sendfile "libsendfile.so" //go:cgo_import_dynamic libc___xnet_sendto __xnet_sendto "libsocket.so" //go:cgo_import_dynamic libc___xnet_socket __xnet_socket "libsocket.so" //go:cgo_import_dynamic libc___xnet_socketpair __xnet_socketpair "libsocket.so" @@ -176,6 +178,7 @@ import ( //go:linkname procFlock libc_flock //go:linkname procFpathconf libc_fpathconf //go:linkname procFstat libc_fstat +//go:linkname procFstatat libc_fstatat //go:linkname procFstatvfs libc_fstatvfs //go:linkname procGetdents libc_getdents //go:linkname procGetgid libc_getgid @@ -253,6 +256,7 @@ import ( //go:linkname proc__xnet_connect libc___xnet_connect //go:linkname procmmap libc_mmap //go:linkname procmunmap libc_munmap +//go:linkname procsendfile libc_sendfile //go:linkname proc__xnet_sendto libc___xnet_sendto //go:linkname proc__xnet_socket libc___xnet_socket //go:linkname proc__xnet_socketpair libc___xnet_socketpair @@ -303,6 +307,7 @@ var ( procFlock, procFpathconf, procFstat, + procFstatat, procFstatvfs, procGetdents, procGetgid, @@ -380,6 +385,7 @@ var ( proc__xnet_connect, procmmap, procmunmap, + procsendfile, proc__xnet_sendto, proc__xnet_socket, proc__xnet_socketpair, @@ -772,6 +778,19 @@ func Fstat(fd int, stat *Stat_t) (err error) { return } +func Fstatat(fd int, path string, stat *Stat_t, flags int) (err error) { + var _p0 *byte + _p0, err = BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := sysvicall6(uintptr(unsafe.Pointer(&procFstatat)), 4, uintptr(fd), uintptr(unsafe.Pointer(_p0)), uintptr(unsafe.Pointer(stat)), uintptr(flags), 0, 0) + if e1 != 0 { + err = e1 + } + return +} + func Fstatvfs(fd int, vfsstat *Statvfs_t) (err error) { _, _, e1 := sysvicall6(uintptr(unsafe.Pointer(&procFstatvfs)), 2, uintptr(fd), uintptr(unsafe.Pointer(vfsstat)), 0, 0, 0, 0) if e1 != 0 { @@ -1573,6 +1592,15 @@ func munmap(addr uintptr, length uintptr) (err error) { return } +func sendfile(outfd int, infd int, offset *int64, count int) (written int, err error) { + r0, _, e1 := sysvicall6(uintptr(unsafe.Pointer(&procsendfile)), 4, uintptr(outfd), uintptr(infd), uintptr(unsafe.Pointer(offset)), uintptr(count), 0, 0) + written = int(r0) + if e1 != 0 { + err = e1 + } + return +} + func sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error) { var _p0 *byte if len(buf) > 0 { diff --git a/vendor/golang.org/x/sys/unix/zsysctl_openbsd_amd64.go b/vendor/golang.org/x/sys/unix/zsysctl_openbsd_amd64.go index 83bb935b91c..207b27938b2 100644 --- a/vendor/golang.org/x/sys/unix/zsysctl_openbsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/zsysctl_openbsd_amd64.go @@ -1,6 +1,8 @@ // mksysctl_openbsd.pl // MACHINE GENERATED BY THE ABOVE COMMAND; DO NOT EDIT +// +build amd64,openbsd + package unix type mibentry struct { @@ -14,6 +16,7 @@ var sysctlMib = []mibentry{ {"ddb.max_line", []_C_int{9, 3}}, {"ddb.max_width", []_C_int{9, 2}}, {"ddb.panic", []_C_int{9, 5}}, + {"ddb.profile", []_C_int{9, 9}}, {"ddb.radix", []_C_int{9, 1}}, {"ddb.tab_stop_width", []_C_int{9, 4}}, {"ddb.trigger", []_C_int{9, 8}}, @@ -29,6 +32,7 @@ var sysctlMib = []mibentry{ {"hw.ncpu", []_C_int{6, 3}}, {"hw.ncpufound", []_C_int{6, 21}}, {"hw.pagesize", []_C_int{6, 7}}, + {"hw.perfpolicy", []_C_int{6, 23}}, {"hw.physmem", []_C_int{6, 19}}, {"hw.product", []_C_int{6, 15}}, {"hw.serialno", []_C_int{6, 17}}, @@ -37,7 +41,7 @@ var sysctlMib = []mibentry{ {"hw.uuid", []_C_int{6, 18}}, {"hw.vendor", []_C_int{6, 14}}, {"hw.version", []_C_int{6, 16}}, - {"kern.arandom", []_C_int{1, 37}}, + {"kern.allowkmem", []_C_int{1, 52}}, {"kern.argmax", []_C_int{1, 8}}, {"kern.boottime", []_C_int{1, 21}}, {"kern.bufcachepercent", []_C_int{1, 72}}, @@ -46,12 +50,13 @@ var sysctlMib = []mibentry{ {"kern.consdev", []_C_int{1, 75}}, {"kern.cp_time", []_C_int{1, 40}}, {"kern.cp_time2", []_C_int{1, 71}}, - {"kern.cryptodevallowsoft", []_C_int{1, 53}}, + {"kern.dnsjackport", []_C_int{1, 13}}, {"kern.domainname", []_C_int{1, 22}}, {"kern.file", []_C_int{1, 73}}, {"kern.forkstat", []_C_int{1, 42}}, {"kern.fscale", []_C_int{1, 46}}, {"kern.fsync", []_C_int{1, 33}}, + {"kern.global_ptrace", []_C_int{1, 81}}, {"kern.hostid", []_C_int{1, 11}}, {"kern.hostname", []_C_int{1, 10}}, {"kern.intrcnt.nintrcnt", []_C_int{1, 63, 1}}, @@ -84,7 +89,6 @@ var sysctlMib = []mibentry{ {"kern.pool_debug", []_C_int{1, 77}}, {"kern.posix1version", []_C_int{1, 17}}, {"kern.proc", []_C_int{1, 66}}, - {"kern.random", []_C_int{1, 31}}, {"kern.rawpartition", []_C_int{1, 24}}, {"kern.saved_ids", []_C_int{1, 20}}, {"kern.securelevel", []_C_int{1, 9}}, @@ -102,21 +106,16 @@ var sysctlMib = []mibentry{ {"kern.timecounter.hardware", []_C_int{1, 69, 3}}, {"kern.timecounter.tick", []_C_int{1, 69, 1}}, {"kern.timecounter.timestepwarnings", []_C_int{1, 69, 2}}, - {"kern.tty.maxptys", []_C_int{1, 44, 6}}, - {"kern.tty.nptys", []_C_int{1, 44, 7}}, {"kern.tty.tk_cancc", []_C_int{1, 44, 4}}, {"kern.tty.tk_nin", []_C_int{1, 44, 1}}, {"kern.tty.tk_nout", []_C_int{1, 44, 2}}, {"kern.tty.tk_rawcc", []_C_int{1, 44, 3}}, {"kern.tty.ttyinfo", []_C_int{1, 44, 5}}, {"kern.ttycount", []_C_int{1, 57}}, - {"kern.userasymcrypto", []_C_int{1, 60}}, - {"kern.usercrypto", []_C_int{1, 52}}, - {"kern.usermount", []_C_int{1, 30}}, {"kern.version", []_C_int{1, 4}}, - {"kern.vnode", []_C_int{1, 13}}, {"kern.watchdog.auto", []_C_int{1, 64, 2}}, {"kern.watchdog.period", []_C_int{1, 64, 1}}, + {"kern.wxabort", []_C_int{1, 74}}, {"net.bpf.bufsize", []_C_int{4, 31, 1}}, {"net.bpf.maxbufsize", []_C_int{4, 31, 2}}, {"net.inet.ah.enable", []_C_int{4, 2, 51, 1}}, @@ -144,7 +143,9 @@ var sysctlMib = []mibentry{ {"net.inet.icmp.stats", []_C_int{4, 2, 1, 7}}, {"net.inet.icmp.tstamprepl", []_C_int{4, 2, 1, 6}}, {"net.inet.igmp.stats", []_C_int{4, 2, 2, 1}}, + {"net.inet.ip.arpdown", []_C_int{4, 2, 0, 40}}, {"net.inet.ip.arpqueued", []_C_int{4, 2, 0, 36}}, + {"net.inet.ip.arptimeout", []_C_int{4, 2, 0, 39}}, {"net.inet.ip.encdebug", []_C_int{4, 2, 0, 12}}, {"net.inet.ip.forwarding", []_C_int{4, 2, 0, 1}}, {"net.inet.ip.ifq.congestion", []_C_int{4, 2, 0, 30, 4}}, @@ -153,8 +154,10 @@ var sysctlMib = []mibentry{ {"net.inet.ip.ifq.maxlen", []_C_int{4, 2, 0, 30, 2}}, {"net.inet.ip.maxqueue", []_C_int{4, 2, 0, 11}}, {"net.inet.ip.mforwarding", []_C_int{4, 2, 0, 31}}, + {"net.inet.ip.mrtmfc", []_C_int{4, 2, 0, 37}}, {"net.inet.ip.mrtproto", []_C_int{4, 2, 0, 34}}, {"net.inet.ip.mrtstats", []_C_int{4, 2, 0, 35}}, + {"net.inet.ip.mrtvif", []_C_int{4, 2, 0, 38}}, {"net.inet.ip.mtu", []_C_int{4, 2, 0, 4}}, {"net.inet.ip.mtudisc", []_C_int{4, 2, 0, 27}}, {"net.inet.ip.mtudisctimeout", []_C_int{4, 2, 0, 28}}, @@ -173,7 +176,6 @@ var sysctlMib = []mibentry{ {"net.inet.ipip.stats", []_C_int{4, 2, 4, 2}}, {"net.inet.mobileip.allow", []_C_int{4, 2, 55, 1}}, {"net.inet.pfsync.stats", []_C_int{4, 2, 240, 1}}, - {"net.inet.pim.stats", []_C_int{4, 2, 103, 1}}, {"net.inet.tcp.ackonpush", []_C_int{4, 2, 6, 13}}, {"net.inet.tcp.always_keepalive", []_C_int{4, 2, 6, 22}}, {"net.inet.tcp.baddynamic", []_C_int{4, 2, 6, 6}}, @@ -187,6 +189,7 @@ var sysctlMib = []mibentry{ {"net.inet.tcp.reasslimit", []_C_int{4, 2, 6, 18}}, {"net.inet.tcp.rfc1323", []_C_int{4, 2, 6, 1}}, {"net.inet.tcp.rfc3390", []_C_int{4, 2, 6, 17}}, + {"net.inet.tcp.rootonly", []_C_int{4, 2, 6, 24}}, {"net.inet.tcp.rstppslimit", []_C_int{4, 2, 6, 12}}, {"net.inet.tcp.sack", []_C_int{4, 2, 6, 10}}, {"net.inet.tcp.sackholelimit", []_C_int{4, 2, 6, 20}}, @@ -194,9 +197,12 @@ var sysctlMib = []mibentry{ {"net.inet.tcp.stats", []_C_int{4, 2, 6, 21}}, {"net.inet.tcp.synbucketlimit", []_C_int{4, 2, 6, 16}}, {"net.inet.tcp.syncachelimit", []_C_int{4, 2, 6, 15}}, + {"net.inet.tcp.synhashsize", []_C_int{4, 2, 6, 25}}, + {"net.inet.tcp.synuselimit", []_C_int{4, 2, 6, 23}}, {"net.inet.udp.baddynamic", []_C_int{4, 2, 17, 2}}, {"net.inet.udp.checksum", []_C_int{4, 2, 17, 1}}, {"net.inet.udp.recvspace", []_C_int{4, 2, 17, 3}}, + {"net.inet.udp.rootonly", []_C_int{4, 2, 17, 6}}, {"net.inet.udp.sendspace", []_C_int{4, 2, 17, 4}}, {"net.inet.udp.stats", []_C_int{4, 2, 17, 5}}, {"net.inet6.divert.recvspace", []_C_int{4, 24, 86, 1}}, @@ -209,13 +215,8 @@ var sysctlMib = []mibentry{ {"net.inet6.icmp6.nd6_delay", []_C_int{4, 24, 30, 8}}, {"net.inet6.icmp6.nd6_maxnudhint", []_C_int{4, 24, 30, 15}}, {"net.inet6.icmp6.nd6_mmaxtries", []_C_int{4, 24, 30, 10}}, - {"net.inet6.icmp6.nd6_prune", []_C_int{4, 24, 30, 6}}, {"net.inet6.icmp6.nd6_umaxtries", []_C_int{4, 24, 30, 9}}, - {"net.inet6.icmp6.nd6_useloopback", []_C_int{4, 24, 30, 11}}, - {"net.inet6.icmp6.nodeinfo", []_C_int{4, 24, 30, 13}}, - {"net.inet6.icmp6.rediraccept", []_C_int{4, 24, 30, 2}}, {"net.inet6.icmp6.redirtimeout", []_C_int{4, 24, 30, 3}}, - {"net.inet6.ip6.accept_rtadv", []_C_int{4, 24, 17, 12}}, {"net.inet6.ip6.auto_flowlabel", []_C_int{4, 24, 17, 17}}, {"net.inet6.ip6.dad_count", []_C_int{4, 24, 17, 16}}, {"net.inet6.ip6.dad_pending", []_C_int{4, 24, 17, 49}}, @@ -228,20 +229,19 @@ var sysctlMib = []mibentry{ {"net.inet6.ip6.maxdynroutes", []_C_int{4, 24, 17, 48}}, {"net.inet6.ip6.maxfragpackets", []_C_int{4, 24, 17, 9}}, {"net.inet6.ip6.maxfrags", []_C_int{4, 24, 17, 41}}, - {"net.inet6.ip6.maxifdefrouters", []_C_int{4, 24, 17, 47}}, - {"net.inet6.ip6.maxifprefixes", []_C_int{4, 24, 17, 46}}, {"net.inet6.ip6.mforwarding", []_C_int{4, 24, 17, 42}}, + {"net.inet6.ip6.mrtmfc", []_C_int{4, 24, 17, 53}}, + {"net.inet6.ip6.mrtmif", []_C_int{4, 24, 17, 52}}, {"net.inet6.ip6.mrtproto", []_C_int{4, 24, 17, 8}}, {"net.inet6.ip6.mtudisctimeout", []_C_int{4, 24, 17, 50}}, {"net.inet6.ip6.multicast_mtudisc", []_C_int{4, 24, 17, 44}}, {"net.inet6.ip6.multipath", []_C_int{4, 24, 17, 43}}, {"net.inet6.ip6.neighborgcthresh", []_C_int{4, 24, 17, 45}}, {"net.inet6.ip6.redirect", []_C_int{4, 24, 17, 2}}, - {"net.inet6.ip6.rr_prune", []_C_int{4, 24, 17, 22}}, + {"net.inet6.ip6.soiikey", []_C_int{4, 24, 17, 54}}, {"net.inet6.ip6.sourcecheck", []_C_int{4, 24, 17, 10}}, {"net.inet6.ip6.sourcecheck_logint", []_C_int{4, 24, 17, 11}}, {"net.inet6.ip6.use_deprecated", []_C_int{4, 24, 17, 21}}, - {"net.inet6.ip6.v6only", []_C_int{4, 24, 17, 24}}, {"net.key.sadb_dump", []_C_int{4, 30, 1}}, {"net.key.spd_dump", []_C_int{4, 30, 2}}, {"net.mpls.ifq.congestion", []_C_int{4, 33, 3, 4}}, @@ -254,17 +254,4 @@ var sysctlMib = []mibentry{ {"net.mpls.ttl", []_C_int{4, 33, 2}}, {"net.pflow.stats", []_C_int{4, 34, 1}}, {"net.pipex.enable", []_C_int{4, 35, 1}}, - {"vm.anonmin", []_C_int{2, 7}}, - {"vm.loadavg", []_C_int{2, 2}}, - {"vm.maxslp", []_C_int{2, 10}}, - {"vm.nkmempages", []_C_int{2, 6}}, - {"vm.psstrings", []_C_int{2, 3}}, - {"vm.swapencrypt.enable", []_C_int{2, 5, 0}}, - {"vm.swapencrypt.keyscreated", []_C_int{2, 5, 1}}, - {"vm.swapencrypt.keysdeleted", []_C_int{2, 5, 2}}, - {"vm.uspace", []_C_int{2, 11}}, - {"vm.uvmexp", []_C_int{2, 4}}, - {"vm.vmmeter", []_C_int{2, 1}}, - {"vm.vnodemin", []_C_int{2, 9}}, - {"vm.vtextmin", []_C_int{2, 8}}, } diff --git a/vendor/golang.org/x/sys/unix/zsysnum_linux_ppc64.go b/vendor/golang.org/x/sys/unix/zsysnum_linux_ppc64.go index dfe5dab67ee..384d49bfa5a 100644 --- a/vendor/golang.org/x/sys/unix/zsysnum_linux_ppc64.go +++ b/vendor/golang.org/x/sys/unix/zsysnum_linux_ppc64.go @@ -367,4 +367,7 @@ const ( SYS_PWRITEV2 = 381 SYS_KEXEC_FILE_LOAD = 382 SYS_STATX = 383 + SYS_PKEY_ALLOC = 384 + SYS_PKEY_FREE = 385 + SYS_PKEY_MPROTECT = 386 ) diff --git a/vendor/golang.org/x/sys/unix/zsysnum_linux_ppc64le.go b/vendor/golang.org/x/sys/unix/zsysnum_linux_ppc64le.go index eca97f738b7..9623248a5ef 100644 --- a/vendor/golang.org/x/sys/unix/zsysnum_linux_ppc64le.go +++ b/vendor/golang.org/x/sys/unix/zsysnum_linux_ppc64le.go @@ -367,4 +367,7 @@ const ( SYS_PWRITEV2 = 381 SYS_KEXEC_FILE_LOAD = 382 SYS_STATX = 383 + SYS_PKEY_ALLOC = 384 + SYS_PKEY_FREE = 385 + SYS_PKEY_MPROTECT = 386 ) diff --git a/vendor/golang.org/x/sys/unix/zsysnum_linux_s390x.go b/vendor/golang.org/x/sys/unix/zsysnum_linux_s390x.go index 8bf50c8d43b..ed92409d97f 100644 --- a/vendor/golang.org/x/sys/unix/zsysnum_linux_s390x.go +++ b/vendor/golang.org/x/sys/unix/zsysnum_linux_s390x.go @@ -109,6 +109,7 @@ const ( SYS_PERSONALITY = 136 SYS_AFS_SYSCALL = 137 SYS_GETDENTS = 141 + SYS_SELECT = 142 SYS_FLOCK = 143 SYS_MSYNC = 144 SYS_READV = 145 @@ -151,6 +152,26 @@ const ( SYS_GETPMSG = 188 SYS_PUTPMSG = 189 SYS_VFORK = 190 + SYS_GETRLIMIT = 191 + SYS_LCHOWN = 198 + SYS_GETUID = 199 + SYS_GETGID = 200 + SYS_GETEUID = 201 + SYS_GETEGID = 202 + SYS_SETREUID = 203 + SYS_SETREGID = 204 + SYS_GETGROUPS = 205 + SYS_SETGROUPS = 206 + SYS_FCHOWN = 207 + SYS_SETRESUID = 208 + SYS_GETRESUID = 209 + SYS_SETRESGID = 210 + SYS_GETRESGID = 211 + SYS_CHOWN = 212 + SYS_SETUID = 213 + SYS_SETGID = 214 + SYS_SETFSUID = 215 + SYS_SETFSGID = 216 SYS_PIVOT_ROOT = 217 SYS_MINCORE = 218 SYS_MADVISE = 219 @@ -222,6 +243,7 @@ const ( SYS_MKNODAT = 290 SYS_FCHOWNAT = 291 SYS_FUTIMESAT = 292 + SYS_NEWFSTATAT = 293 SYS_UNLINKAT = 294 SYS_RENAMEAT = 295 SYS_LINKAT = 296 @@ -309,26 +331,4 @@ const ( SYS_S390_GUARDED_STORAGE = 378 SYS_STATX = 379 SYS_S390_STHYI = 380 - SYS_SELECT = 142 - SYS_GETRLIMIT = 191 - SYS_LCHOWN = 198 - SYS_GETUID = 199 - SYS_GETGID = 200 - SYS_GETEUID = 201 - SYS_GETEGID = 202 - SYS_SETREUID = 203 - SYS_SETREGID = 204 - SYS_GETGROUPS = 205 - SYS_SETGROUPS = 206 - SYS_FCHOWN = 207 - SYS_SETRESUID = 208 - SYS_GETRESUID = 209 - SYS_SETRESGID = 210 - SYS_GETRESGID = 211 - SYS_CHOWN = 212 - SYS_SETUID = 213 - SYS_SETGID = 214 - SYS_SETFSUID = 215 - SYS_SETFSGID = 216 - SYS_NEWFSTATAT = 293 ) diff --git a/vendor/golang.org/x/sys/unix/zsysnum_openbsd_amd64.go b/vendor/golang.org/x/sys/unix/zsysnum_openbsd_amd64.go index bd28146ddd5..10edff07d57 100644 --- a/vendor/golang.org/x/sys/unix/zsysnum_openbsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/zsysnum_openbsd_amd64.go @@ -1,5 +1,5 @@ // mksysnum_openbsd.pl -// MACHINE GENERATED BY THE ABOVE COMMAND; DO NOT EDIT +// Code generated by the command above; see README.md. DO NOT EDIT. // +build amd64,openbsd @@ -12,6 +12,7 @@ const ( SYS_WRITE = 4 // { ssize_t sys_write(int fd, const void *buf, \ SYS_OPEN = 5 // { int sys_open(const char *path, \ SYS_CLOSE = 6 // { int sys_close(int fd); } + SYS_GETENTROPY = 7 // { int sys_getentropy(void *buf, size_t nbyte); } SYS___TFORK = 8 // { int sys___tfork(const struct __tfork *param, \ SYS_LINK = 9 // { int sys_link(const char *path, const char *link); } SYS_UNLINK = 10 // { int sys_unlink(const char *path); } @@ -37,11 +38,10 @@ const ( SYS_ACCEPT = 30 // { int sys_accept(int s, struct sockaddr *name, \ SYS_GETPEERNAME = 31 // { int sys_getpeername(int fdes, struct sockaddr *asa, \ SYS_GETSOCKNAME = 32 // { int sys_getsockname(int fdes, struct sockaddr *asa, \ - SYS_ACCESS = 33 // { int sys_access(const char *path, int flags); } + SYS_ACCESS = 33 // { int sys_access(const char *path, int amode); } SYS_CHFLAGS = 34 // { int sys_chflags(const char *path, u_int flags); } SYS_FCHFLAGS = 35 // { int sys_fchflags(int fd, u_int flags); } SYS_SYNC = 36 // { void sys_sync(void); } - SYS_KILL = 37 // { int sys_kill(int pid, int signum); } SYS_STAT = 38 // { int sys_stat(const char *path, struct stat *ub); } SYS_GETPPID = 39 // { pid_t sys_getppid(void); } SYS_LSTAT = 40 // { int sys_lstat(const char *path, struct stat *ub); } @@ -53,7 +53,6 @@ const ( SYS_SIGACTION = 46 // { int sys_sigaction(int signum, \ SYS_GETGID = 47 // { gid_t sys_getgid(void); } SYS_SIGPROCMASK = 48 // { int sys_sigprocmask(int how, sigset_t mask); } - SYS_GETLOGIN = 49 // { int sys_getlogin(char *namebuf, u_int namelen); } SYS_SETLOGIN = 50 // { int sys_setlogin(const char *namebuf); } SYS_ACCT = 51 // { int sys_acct(const char *path); } SYS_SIGPENDING = 52 // { int sys_sigpending(void); } @@ -62,7 +61,7 @@ const ( SYS_REBOOT = 55 // { int sys_reboot(int opt); } SYS_REVOKE = 56 // { int sys_revoke(const char *path); } SYS_SYMLINK = 57 // { int sys_symlink(const char *path, \ - SYS_READLINK = 58 // { int sys_readlink(const char *path, char *buf, \ + SYS_READLINK = 58 // { ssize_t sys_readlink(const char *path, \ SYS_EXECVE = 59 // { int sys_execve(const char *path, \ SYS_UMASK = 60 // { mode_t sys_umask(mode_t newmask); } SYS_CHROOT = 61 // { int sys_chroot(const char *path); } @@ -86,15 +85,18 @@ const ( SYS_GETGROUPS = 79 // { int sys_getgroups(int gidsetsize, \ SYS_SETGROUPS = 80 // { int sys_setgroups(int gidsetsize, \ SYS_GETPGRP = 81 // { int sys_getpgrp(void); } - SYS_SETPGID = 82 // { int sys_setpgid(pid_t pid, int pgid); } + SYS_SETPGID = 82 // { int sys_setpgid(pid_t pid, pid_t pgid); } + SYS_FUTEX = 83 // { int sys_futex(uint32_t *f, int op, int val, \ SYS_UTIMENSAT = 84 // { int sys_utimensat(int fd, const char *path, \ SYS_FUTIMENS = 85 // { int sys_futimens(int fd, \ + SYS_KBIND = 86 // { int sys_kbind(const struct __kbind *param, \ SYS_CLOCK_GETTIME = 87 // { int sys_clock_gettime(clockid_t clock_id, \ SYS_CLOCK_SETTIME = 88 // { int sys_clock_settime(clockid_t clock_id, \ SYS_CLOCK_GETRES = 89 // { int sys_clock_getres(clockid_t clock_id, \ SYS_DUP2 = 90 // { int sys_dup2(int from, int to); } SYS_NANOSLEEP = 91 // { int sys_nanosleep(const struct timespec *rqtp, \ SYS_FCNTL = 92 // { int sys_fcntl(int fd, int cmd, ... void *arg); } + SYS_ACCEPT4 = 93 // { int sys_accept4(int s, struct sockaddr *name, \ SYS___THRSLEEP = 94 // { int sys___thrsleep(const volatile void *ident, \ SYS_FSYNC = 95 // { int sys_fsync(int fd); } SYS_SETPRIORITY = 96 // { int sys_setpriority(int which, id_t who, int prio); } @@ -102,16 +104,23 @@ const ( SYS_CONNECT = 98 // { int sys_connect(int s, const struct sockaddr *name, \ SYS_GETDENTS = 99 // { int sys_getdents(int fd, void *buf, size_t buflen); } SYS_GETPRIORITY = 100 // { int sys_getpriority(int which, id_t who); } + SYS_PIPE2 = 101 // { int sys_pipe2(int *fdp, int flags); } + SYS_DUP3 = 102 // { int sys_dup3(int from, int to, int flags); } SYS_SIGRETURN = 103 // { int sys_sigreturn(struct sigcontext *sigcntxp); } SYS_BIND = 104 // { int sys_bind(int s, const struct sockaddr *name, \ SYS_SETSOCKOPT = 105 // { int sys_setsockopt(int s, int level, int name, \ SYS_LISTEN = 106 // { int sys_listen(int s, int backlog); } + SYS_CHFLAGSAT = 107 // { int sys_chflagsat(int fd, const char *path, \ + SYS_PLEDGE = 108 // { int sys_pledge(const char *promises, \ SYS_PPOLL = 109 // { int sys_ppoll(struct pollfd *fds, \ SYS_PSELECT = 110 // { int sys_pselect(int nd, fd_set *in, fd_set *ou, \ SYS_SIGSUSPEND = 111 // { int sys_sigsuspend(int mask); } + SYS_SENDSYSLOG = 112 // { int sys_sendsyslog(const char *buf, size_t nbyte, \ SYS_GETSOCKOPT = 118 // { int sys_getsockopt(int s, int level, int name, \ + SYS_THRKILL = 119 // { int sys_thrkill(pid_t tid, int signum, void *tcb); } SYS_READV = 120 // { ssize_t sys_readv(int fd, \ SYS_WRITEV = 121 // { ssize_t sys_writev(int fd, \ + SYS_KILL = 122 // { int sys_kill(int pid, int signum); } SYS_FCHOWN = 123 // { int sys_fchown(int fd, uid_t uid, gid_t gid); } SYS_FCHMOD = 124 // { int sys_fchmod(int fd, mode_t mode); } SYS_SETREUID = 126 // { int sys_setreuid(uid_t ruid, uid_t euid); } @@ -125,6 +134,7 @@ const ( SYS_MKDIR = 136 // { int sys_mkdir(const char *path, mode_t mode); } SYS_RMDIR = 137 // { int sys_rmdir(const char *path); } SYS_ADJTIME = 140 // { int sys_adjtime(const struct timeval *delta, \ + SYS_GETLOGIN_R = 141 // { int sys_getlogin_r(char *namebuf, u_int namelen); } SYS_SETSID = 147 // { int sys_setsid(void); } SYS_QUOTACTL = 148 // { int sys_quotactl(const char *path, int cmd, \ SYS_NFSSVC = 155 // { int sys_nfssvc(int flag, void *argp); } @@ -144,7 +154,7 @@ const ( SYS_LSEEK = 199 // { off_t sys_lseek(int fd, int pad, off_t offset, \ SYS_TRUNCATE = 200 // { int sys_truncate(const char *path, int pad, \ SYS_FTRUNCATE = 201 // { int sys_ftruncate(int fd, int pad, off_t length); } - SYS___SYSCTL = 202 // { int sys___sysctl(const int *name, u_int namelen, \ + SYS_SYSCTL = 202 // { int sys_sysctl(const int *name, u_int namelen, \ SYS_MLOCK = 203 // { int sys_mlock(const void *addr, size_t len); } SYS_MUNLOCK = 204 // { int sys_munlock(const void *addr, size_t len); } SYS_GETPGID = 207 // { pid_t sys_getpgid(pid_t pid); } diff --git a/vendor/golang.org/x/sys/unix/ztypes_darwin_386.go b/vendor/golang.org/x/sys/unix/ztypes_darwin_386.go index bc4bc89f840..327af5fba16 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_darwin_386.go +++ b/vendor/golang.org/x/sys/unix/ztypes_darwin_386.go @@ -136,13 +136,13 @@ type Fsid struct { } type Dirent struct { - Ino uint64 - Seekoff uint64 - Reclen uint16 - Namlen uint16 - Type uint8 - Name [1024]int8 - Pad_cgo_0 [3]byte + Ino uint64 + Seekoff uint64 + Reclen uint16 + Namlen uint16 + Type uint8 + Name [1024]int8 + _ [3]byte } type RawSockaddrInet4 struct { @@ -295,14 +295,14 @@ const ( ) type IfMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Data IfData + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Data IfData } type IfData struct { @@ -338,51 +338,51 @@ type IfData struct { } type IfaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Metric int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Metric int32 } type IfmaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte } type IfmaMsghdr2 struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Refcount int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Refcount int32 } type RtMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Index uint16 - Pad_cgo_0 [2]byte - Flags int32 - Addrs int32 - Pid int32 - Seq int32 - Errno int32 - Use int32 - Inits uint32 - Rmx RtMetrics + Msglen uint16 + Version uint8 + Type uint8 + Index uint16 + _ [2]byte + Flags int32 + Addrs int32 + Pid int32 + Seq int32 + Errno int32 + Use int32 + Inits uint32 + Rmx RtMetrics } type RtMetrics struct { @@ -430,11 +430,11 @@ type BpfInsn struct { } type BpfHdr struct { - Tstamp Timeval - Caplen uint32 - Datalen uint32 - Hdrlen uint16 - Pad_cgo_0 [2]byte + Tstamp Timeval + Caplen uint32 + Datalen uint32 + Hdrlen uint16 + _ [2]byte } type Termios struct { diff --git a/vendor/golang.org/x/sys/unix/ztypes_darwin_amd64.go b/vendor/golang.org/x/sys/unix/ztypes_darwin_amd64.go index d8abcab1213..116e6e07578 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_darwin_amd64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_darwin_amd64.go @@ -26,9 +26,9 @@ type Timespec struct { } type Timeval struct { - Sec int64 - Usec int32 - Pad_cgo_0 [4]byte + Sec int64 + Usec int32 + _ [4]byte } type Timeval32 struct { @@ -70,7 +70,7 @@ type Stat_t struct { Uid uint32 Gid uint32 Rdev int32 - Pad_cgo_0 [4]byte + _ [4]byte Atimespec Timespec Mtimespec Timespec Ctimespec Timespec @@ -120,9 +120,9 @@ type Fstore_t struct { } type Radvisory_t struct { - Offset int64 - Count int32 - Pad_cgo_0 [4]byte + Offset int64 + Count int32 + _ [4]byte } type Fbootstraptransfer_t struct { @@ -132,9 +132,9 @@ type Fbootstraptransfer_t struct { } type Log2phys_t struct { - Flags uint32 - Pad_cgo_0 [8]byte - Pad_cgo_1 [8]byte + Flags uint32 + _ [8]byte + _ [8]byte } type Fsid struct { @@ -142,13 +142,13 @@ type Fsid struct { } type Dirent struct { - Ino uint64 - Seekoff uint64 - Reclen uint16 - Namlen uint16 - Type uint8 - Name [1024]int8 - Pad_cgo_0 [3]byte + Ino uint64 + Seekoff uint64 + Reclen uint16 + Namlen uint16 + Type uint8 + Name [1024]int8 + _ [3]byte } type RawSockaddrInet4 struct { @@ -221,10 +221,10 @@ type IPv6Mreq struct { type Msghdr struct { Name *byte Namelen uint32 - Pad_cgo_0 [4]byte + _ [4]byte Iov *Iovec Iovlen int32 - Pad_cgo_1 [4]byte + _ [4]byte Control *byte Controllen uint32 Flags int32 @@ -303,14 +303,14 @@ const ( ) type IfMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Data IfData + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Data IfData } type IfData struct { @@ -346,51 +346,51 @@ type IfData struct { } type IfaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Metric int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Metric int32 } type IfmaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte } type IfmaMsghdr2 struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Refcount int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Refcount int32 } type RtMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Index uint16 - Pad_cgo_0 [2]byte - Flags int32 - Addrs int32 - Pid int32 - Seq int32 - Errno int32 - Use int32 - Inits uint32 - Rmx RtMetrics + Msglen uint16 + Version uint8 + Type uint8 + Index uint16 + _ [2]byte + Flags int32 + Addrs int32 + Pid int32 + Seq int32 + Errno int32 + Use int32 + Inits uint32 + Rmx RtMetrics } type RtMetrics struct { @@ -426,9 +426,9 @@ type BpfStat struct { } type BpfProgram struct { - Len uint32 - Pad_cgo_0 [4]byte - Insns *BpfInsn + Len uint32 + _ [4]byte + Insns *BpfInsn } type BpfInsn struct { @@ -439,22 +439,22 @@ type BpfInsn struct { } type BpfHdr struct { - Tstamp Timeval32 - Caplen uint32 - Datalen uint32 - Hdrlen uint16 - Pad_cgo_0 [2]byte + Tstamp Timeval32 + Caplen uint32 + Datalen uint32 + Hdrlen uint16 + _ [2]byte } type Termios struct { - Iflag uint64 - Oflag uint64 - Cflag uint64 - Lflag uint64 - Cc [20]uint8 - Pad_cgo_0 [4]byte - Ispeed uint64 - Ospeed uint64 + Iflag uint64 + Oflag uint64 + Cflag uint64 + Lflag uint64 + Cc [20]uint8 + _ [4]byte + Ispeed uint64 + Ospeed uint64 } type Winsize struct { diff --git a/vendor/golang.org/x/sys/unix/ztypes_darwin_arm.go b/vendor/golang.org/x/sys/unix/ztypes_darwin_arm.go index 9749c9f7d15..2750ad76070 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_darwin_arm.go +++ b/vendor/golang.org/x/sys/unix/ztypes_darwin_arm.go @@ -137,13 +137,13 @@ type Fsid struct { } type Dirent struct { - Ino uint64 - Seekoff uint64 - Reclen uint16 - Namlen uint16 - Type uint8 - Name [1024]int8 - Pad_cgo_0 [3]byte + Ino uint64 + Seekoff uint64 + Reclen uint16 + Namlen uint16 + Type uint8 + Name [1024]int8 + _ [3]byte } type RawSockaddrInet4 struct { @@ -296,14 +296,14 @@ const ( ) type IfMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Data IfData + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Data IfData } type IfData struct { @@ -339,51 +339,51 @@ type IfData struct { } type IfaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Metric int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Metric int32 } type IfmaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte } type IfmaMsghdr2 struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Refcount int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Refcount int32 } type RtMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Index uint16 - Pad_cgo_0 [2]byte - Flags int32 - Addrs int32 - Pid int32 - Seq int32 - Errno int32 - Use int32 - Inits uint32 - Rmx RtMetrics + Msglen uint16 + Version uint8 + Type uint8 + Index uint16 + _ [2]byte + Flags int32 + Addrs int32 + Pid int32 + Seq int32 + Errno int32 + Use int32 + Inits uint32 + Rmx RtMetrics } type RtMetrics struct { @@ -431,11 +431,11 @@ type BpfInsn struct { } type BpfHdr struct { - Tstamp Timeval - Caplen uint32 - Datalen uint32 - Hdrlen uint16 - Pad_cgo_0 [2]byte + Tstamp Timeval + Caplen uint32 + Datalen uint32 + Hdrlen uint16 + _ [2]byte } type Termios struct { diff --git a/vendor/golang.org/x/sys/unix/ztypes_darwin_arm64.go b/vendor/golang.org/x/sys/unix/ztypes_darwin_arm64.go index 810b0bd4f6c..8cead0996c8 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_darwin_arm64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_darwin_arm64.go @@ -26,9 +26,9 @@ type Timespec struct { } type Timeval struct { - Sec int64 - Usec int32 - Pad_cgo_0 [4]byte + Sec int64 + Usec int32 + _ [4]byte } type Timeval32 struct { @@ -70,7 +70,7 @@ type Stat_t struct { Uid uint32 Gid uint32 Rdev int32 - Pad_cgo_0 [4]byte + _ [4]byte Atimespec Timespec Mtimespec Timespec Ctimespec Timespec @@ -120,9 +120,9 @@ type Fstore_t struct { } type Radvisory_t struct { - Offset int64 - Count int32 - Pad_cgo_0 [4]byte + Offset int64 + Count int32 + _ [4]byte } type Fbootstraptransfer_t struct { @@ -132,9 +132,9 @@ type Fbootstraptransfer_t struct { } type Log2phys_t struct { - Flags uint32 - Pad_cgo_0 [8]byte - Pad_cgo_1 [8]byte + Flags uint32 + _ [8]byte + _ [8]byte } type Fsid struct { @@ -142,13 +142,13 @@ type Fsid struct { } type Dirent struct { - Ino uint64 - Seekoff uint64 - Reclen uint16 - Namlen uint16 - Type uint8 - Name [1024]int8 - Pad_cgo_0 [3]byte + Ino uint64 + Seekoff uint64 + Reclen uint16 + Namlen uint16 + Type uint8 + Name [1024]int8 + _ [3]byte } type RawSockaddrInet4 struct { @@ -221,10 +221,10 @@ type IPv6Mreq struct { type Msghdr struct { Name *byte Namelen uint32 - Pad_cgo_0 [4]byte + _ [4]byte Iov *Iovec Iovlen int32 - Pad_cgo_1 [4]byte + _ [4]byte Control *byte Controllen uint32 Flags int32 @@ -303,14 +303,14 @@ const ( ) type IfMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Data IfData + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Data IfData } type IfData struct { @@ -346,51 +346,51 @@ type IfData struct { } type IfaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Metric int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Metric int32 } type IfmaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte } type IfmaMsghdr2 struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Refcount int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Refcount int32 } type RtMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Index uint16 - Pad_cgo_0 [2]byte - Flags int32 - Addrs int32 - Pid int32 - Seq int32 - Errno int32 - Use int32 - Inits uint32 - Rmx RtMetrics + Msglen uint16 + Version uint8 + Type uint8 + Index uint16 + _ [2]byte + Flags int32 + Addrs int32 + Pid int32 + Seq int32 + Errno int32 + Use int32 + Inits uint32 + Rmx RtMetrics } type RtMetrics struct { @@ -426,9 +426,9 @@ type BpfStat struct { } type BpfProgram struct { - Len uint32 - Pad_cgo_0 [4]byte - Insns *BpfInsn + Len uint32 + _ [4]byte + Insns *BpfInsn } type BpfInsn struct { @@ -439,22 +439,22 @@ type BpfInsn struct { } type BpfHdr struct { - Tstamp Timeval32 - Caplen uint32 - Datalen uint32 - Hdrlen uint16 - Pad_cgo_0 [2]byte + Tstamp Timeval32 + Caplen uint32 + Datalen uint32 + Hdrlen uint16 + _ [2]byte } type Termios struct { - Iflag uint64 - Oflag uint64 - Cflag uint64 - Lflag uint64 - Cc [20]uint8 - Pad_cgo_0 [4]byte - Ispeed uint64 - Ospeed uint64 + Iflag uint64 + Oflag uint64 + Cflag uint64 + Lflag uint64 + Cc [20]uint8 + _ [4]byte + Ispeed uint64 + Ospeed uint64 } type Winsize struct { diff --git a/vendor/golang.org/x/sys/unix/ztypes_dragonfly_amd64.go b/vendor/golang.org/x/sys/unix/ztypes_dragonfly_amd64.go index e3b8ebb0169..315a553bd5b 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_dragonfly_amd64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_dragonfly_amd64.go @@ -108,7 +108,7 @@ type Statfs_t struct { Owner uint32 Type int32 Flags int32 - Pad_cgo_0 [4]byte + _ [4]byte Syncwrites int64 Asyncwrites int64 Fstypename [16]int8 @@ -118,7 +118,7 @@ type Statfs_t struct { Spares1 int16 Mntfromname [80]int8 Spares2 int16 - Pad_cgo_1 [4]byte + _ [4]byte Spare [2]int64 } @@ -219,10 +219,10 @@ type IPv6Mreq struct { type Msghdr struct { Name *byte Namelen uint32 - Pad_cgo_0 [4]byte + _ [4]byte Iov *Iovec Iovlen int32 - Pad_cgo_1 [4]byte + _ [4]byte Control *byte Controllen uint32 Flags int32 @@ -294,14 +294,14 @@ const ( ) type IfMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Data IfData + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Data IfData } type IfData struct { @@ -311,7 +311,7 @@ type IfData struct { Hdrlen uint8 Recvquota uint8 Xmitquota uint8 - Pad_cgo_0 [2]byte + _ [2]byte Mtu uint64 Metric uint64 Link_state uint64 @@ -333,24 +333,24 @@ type IfData struct { } type IfaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Metric int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Metric int32 } type IfmaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte } type IfAnnounceMsghdr struct { @@ -363,19 +363,19 @@ type IfAnnounceMsghdr struct { } type RtMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Index uint16 - Pad_cgo_0 [2]byte - Flags int32 - Addrs int32 - Pid int32 - Seq int32 - Errno int32 - Use int32 - Inits uint64 - Rmx RtMetrics + Msglen uint16 + Version uint8 + Type uint8 + Index uint16 + _ [2]byte + Flags int32 + Addrs int32 + Pid int32 + Seq int32 + Errno int32 + Use int32 + Inits uint64 + Rmx RtMetrics } type RtMetrics struct { @@ -391,7 +391,7 @@ type RtMetrics struct { Hopcount uint64 Mssopt uint16 Pad uint16 - Pad_cgo_0 [4]byte + _ [4]byte Msl uint64 Iwmaxsegs uint64 Iwcapsegs uint64 @@ -416,9 +416,9 @@ type BpfStat struct { } type BpfProgram struct { - Len uint32 - Pad_cgo_0 [4]byte - Insns *BpfInsn + Len uint32 + _ [4]byte + Insns *BpfInsn } type BpfInsn struct { @@ -429,11 +429,11 @@ type BpfInsn struct { } type BpfHdr struct { - Tstamp Timeval - Caplen uint32 - Datalen uint32 - Hdrlen uint16 - Pad_cgo_0 [6]byte + Tstamp Timeval + Caplen uint32 + Datalen uint32 + Hdrlen uint16 + _ [6]byte } type Termios struct { diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_386.go b/vendor/golang.org/x/sys/unix/ztypes_linux_386.go index f9a99358a41..40474620810 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_386.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_386.go @@ -96,45 +96,30 @@ type Rlimit struct { type _Gid_t uint32 type Stat_t struct { - Dev uint64 - X__pad1 uint16 - _ [2]byte - X__st_ino uint32 - Mode uint32 - Nlink uint32 - Uid uint32 - Gid uint32 - Rdev uint64 - X__pad2 uint16 - _ [2]byte - Size int64 - Blksize int32 - Blocks int64 - Atim Timespec - Mtim Timespec - Ctim Timespec - Ino uint64 -} - -type Statfs_t struct { - Type int32 - Bsize int32 - Blocks uint64 - Bfree uint64 - Bavail uint64 - Files uint64 - Ffree uint64 - Fsid Fsid - Namelen int32 - Frsize int32 - Flags int32 - Spare [4]int32 + Dev uint64 + _ uint16 + _ [2]byte + _ uint32 + Mode uint32 + Nlink uint32 + Uid uint32 + Gid uint32 + Rdev uint64 + _ uint16 + _ [2]byte + Size int64 + Blksize int32 + Blocks int64 + Atim Timespec + Mtim Timespec + Ctim Timespec + Ino uint64 } type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -171,7 +156,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -491,7 +476,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -583,12 +568,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -683,7 +668,7 @@ type Sysinfo_t struct { Totalhigh uint32 Freehigh uint32 Unit uint32 - X_f [8]int8 + _ [8]int8 } type Utsname struct { @@ -739,7 +724,7 @@ const ( ) type Sigset_t struct { - X__val [32]uint32 + Val [32]uint32 } const RNDGETENTCNT = 0x80045200 @@ -895,3 +880,936 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x1 + CBitFieldMaskBit1 = 0x2 + CBitFieldMaskBit2 = 0x4 + CBitFieldMaskBit3 = 0x8 + CBitFieldMaskBit4 = 0x10 + CBitFieldMaskBit5 = 0x20 + CBitFieldMaskBit6 = 0x40 + CBitFieldMaskBit7 = 0x80 + CBitFieldMaskBit8 = 0x100 + CBitFieldMaskBit9 = 0x200 + CBitFieldMaskBit10 = 0x400 + CBitFieldMaskBit11 = 0x800 + CBitFieldMaskBit12 = 0x1000 + CBitFieldMaskBit13 = 0x2000 + CBitFieldMaskBit14 = 0x4000 + CBitFieldMaskBit15 = 0x8000 + CBitFieldMaskBit16 = 0x10000 + CBitFieldMaskBit17 = 0x20000 + CBitFieldMaskBit18 = 0x40000 + CBitFieldMaskBit19 = 0x80000 + CBitFieldMaskBit20 = 0x100000 + CBitFieldMaskBit21 = 0x200000 + CBitFieldMaskBit22 = 0x400000 + CBitFieldMaskBit23 = 0x800000 + CBitFieldMaskBit24 = 0x1000000 + CBitFieldMaskBit25 = 0x2000000 + CBitFieldMaskBit26 = 0x4000000 + CBitFieldMaskBit27 = 0x8000000 + CBitFieldMaskBit28 = 0x10000000 + CBitFieldMaskBit29 = 0x20000000 + CBitFieldMaskBit30 = 0x40000000 + CBitFieldMaskBit31 = 0x80000000 + CBitFieldMaskBit32 = 0x100000000 + CBitFieldMaskBit33 = 0x200000000 + CBitFieldMaskBit34 = 0x400000000 + CBitFieldMaskBit35 = 0x800000000 + CBitFieldMaskBit36 = 0x1000000000 + CBitFieldMaskBit37 = 0x2000000000 + CBitFieldMaskBit38 = 0x4000000000 + CBitFieldMaskBit39 = 0x8000000000 + CBitFieldMaskBit40 = 0x10000000000 + CBitFieldMaskBit41 = 0x20000000000 + CBitFieldMaskBit42 = 0x40000000000 + CBitFieldMaskBit43 = 0x80000000000 + CBitFieldMaskBit44 = 0x100000000000 + CBitFieldMaskBit45 = 0x200000000000 + CBitFieldMaskBit46 = 0x400000000000 + CBitFieldMaskBit47 = 0x800000000000 + CBitFieldMaskBit48 = 0x1000000000000 + CBitFieldMaskBit49 = 0x2000000000000 + CBitFieldMaskBit50 = 0x4000000000000 + CBitFieldMaskBit51 = 0x8000000000000 + CBitFieldMaskBit52 = 0x10000000000000 + CBitFieldMaskBit53 = 0x20000000000000 + CBitFieldMaskBit54 = 0x40000000000000 + CBitFieldMaskBit55 = 0x80000000000000 + CBitFieldMaskBit56 = 0x100000000000000 + CBitFieldMaskBit57 = 0x200000000000000 + CBitFieldMaskBit58 = 0x400000000000000 + CBitFieldMaskBit59 = 0x800000000000000 + CBitFieldMaskBit60 = 0x1000000000000000 + CBitFieldMaskBit61 = 0x2000000000000000 + CBitFieldMaskBit62 = 0x4000000000000000 + CBitFieldMaskBit63 = 0x8000000000000000 +) + +type SockaddrStorage struct { + Family uint16 + _ [122]int8 + _ uint32 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + Start uint32 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int32 + Bsize int32 + Blocks uint64 + Bfree uint64 + Bavail uint64 + Files uint64 + Ffree uint64 + Fsid Fsid + Namelen int32 + Frsize int32 + Flags int32 + Spare [4]int32 +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x18 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_amd64.go b/vendor/golang.org/x/sys/unix/ztypes_linux_amd64.go index 4df7088d40a..2ab0cb9e79b 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_amd64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_amd64.go @@ -105,7 +105,7 @@ type Stat_t struct { Mode uint32 Uid uint32 Gid uint32 - X__pad0 int32 + _ int32 Rdev uint64 Size int64 Blksize int64 @@ -116,25 +116,10 @@ type Stat_t struct { _ [3]int64 } -type Statfs_t struct { - Type int64 - Bsize int64 - Blocks uint64 - Bfree uint64 - Bavail uint64 - Files uint64 - Ffree uint64 - Fsid Fsid - Namelen int64 - Frsize int64 - Flags int64 - Spare [4]int64 -} - type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -171,7 +156,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -495,7 +480,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -587,12 +572,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -698,7 +683,7 @@ type Sysinfo_t struct { Totalhigh uint64 Freehigh uint64 Unit uint32 - X_f [0]int8 + _ [0]int8 _ [4]byte } @@ -757,7 +742,7 @@ const ( ) type Sigset_t struct { - X__val [16]uint64 + Val [16]uint64 } const RNDGETENTCNT = 0x80045200 @@ -913,3 +898,938 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x1 + CBitFieldMaskBit1 = 0x2 + CBitFieldMaskBit2 = 0x4 + CBitFieldMaskBit3 = 0x8 + CBitFieldMaskBit4 = 0x10 + CBitFieldMaskBit5 = 0x20 + CBitFieldMaskBit6 = 0x40 + CBitFieldMaskBit7 = 0x80 + CBitFieldMaskBit8 = 0x100 + CBitFieldMaskBit9 = 0x200 + CBitFieldMaskBit10 = 0x400 + CBitFieldMaskBit11 = 0x800 + CBitFieldMaskBit12 = 0x1000 + CBitFieldMaskBit13 = 0x2000 + CBitFieldMaskBit14 = 0x4000 + CBitFieldMaskBit15 = 0x8000 + CBitFieldMaskBit16 = 0x10000 + CBitFieldMaskBit17 = 0x20000 + CBitFieldMaskBit18 = 0x40000 + CBitFieldMaskBit19 = 0x80000 + CBitFieldMaskBit20 = 0x100000 + CBitFieldMaskBit21 = 0x200000 + CBitFieldMaskBit22 = 0x400000 + CBitFieldMaskBit23 = 0x800000 + CBitFieldMaskBit24 = 0x1000000 + CBitFieldMaskBit25 = 0x2000000 + CBitFieldMaskBit26 = 0x4000000 + CBitFieldMaskBit27 = 0x8000000 + CBitFieldMaskBit28 = 0x10000000 + CBitFieldMaskBit29 = 0x20000000 + CBitFieldMaskBit30 = 0x40000000 + CBitFieldMaskBit31 = 0x80000000 + CBitFieldMaskBit32 = 0x100000000 + CBitFieldMaskBit33 = 0x200000000 + CBitFieldMaskBit34 = 0x400000000 + CBitFieldMaskBit35 = 0x800000000 + CBitFieldMaskBit36 = 0x1000000000 + CBitFieldMaskBit37 = 0x2000000000 + CBitFieldMaskBit38 = 0x4000000000 + CBitFieldMaskBit39 = 0x8000000000 + CBitFieldMaskBit40 = 0x10000000000 + CBitFieldMaskBit41 = 0x20000000000 + CBitFieldMaskBit42 = 0x40000000000 + CBitFieldMaskBit43 = 0x80000000000 + CBitFieldMaskBit44 = 0x100000000000 + CBitFieldMaskBit45 = 0x200000000000 + CBitFieldMaskBit46 = 0x400000000000 + CBitFieldMaskBit47 = 0x800000000000 + CBitFieldMaskBit48 = 0x1000000000000 + CBitFieldMaskBit49 = 0x2000000000000 + CBitFieldMaskBit50 = 0x4000000000000 + CBitFieldMaskBit51 = 0x8000000000000 + CBitFieldMaskBit52 = 0x10000000000000 + CBitFieldMaskBit53 = 0x20000000000000 + CBitFieldMaskBit54 = 0x40000000000000 + CBitFieldMaskBit55 = 0x80000000000000 + CBitFieldMaskBit56 = 0x100000000000000 + CBitFieldMaskBit57 = 0x200000000000000 + CBitFieldMaskBit58 = 0x400000000000000 + CBitFieldMaskBit59 = 0x800000000000000 + CBitFieldMaskBit60 = 0x1000000000000000 + CBitFieldMaskBit61 = 0x2000000000000000 + CBitFieldMaskBit62 = 0x4000000000000000 + CBitFieldMaskBit63 = 0x8000000000000000 +) + +type SockaddrStorage struct { + Family uint16 + _ [118]int8 + _ uint64 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + _ [4]byte + Start uint64 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int64 + Bsize int64 + Blocks uint64 + Bfree uint64 + Bavail uint64 + Files uint64 + Ffree uint64 + Fsid Fsid + Namelen int64 + Frsize int64 + Flags int64 + Spare [4]int64 +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint64 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 + _ [4]byte +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x20 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_arm.go b/vendor/golang.org/x/sys/unix/ztypes_linux_arm.go index a181469ca1b..18d577b9125 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_arm.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_arm.go @@ -96,47 +96,31 @@ type Rlimit struct { type _Gid_t uint32 type Stat_t struct { - Dev uint64 - X__pad1 uint16 - _ [2]byte - X__st_ino uint32 - Mode uint32 - Nlink uint32 - Uid uint32 - Gid uint32 - Rdev uint64 - X__pad2 uint16 - _ [6]byte - Size int64 - Blksize int32 - _ [4]byte - Blocks int64 - Atim Timespec - Mtim Timespec - Ctim Timespec - Ino uint64 -} - -type Statfs_t struct { - Type int32 - Bsize int32 - Blocks uint64 - Bfree uint64 - Bavail uint64 - Files uint64 - Ffree uint64 - Fsid Fsid - Namelen int32 - Frsize int32 - Flags int32 - Spare [4]int32 + Dev uint64 + _ uint16 + _ [2]byte + _ uint32 + Mode uint32 + Nlink uint32 + Uid uint32 + Gid uint32 + Rdev uint64 + _ uint16 + _ [6]byte + Size int64 + Blksize int32 _ [4]byte + Blocks int64 + Atim Timespec + Mtim Timespec + Ctim Timespec + Ino uint64 } type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -173,7 +157,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -495,7 +479,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -587,12 +571,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -671,7 +655,7 @@ type Sysinfo_t struct { Totalhigh uint32 Freehigh uint32 Unit uint32 - X_f [8]uint8 + _ [8]uint8 } type Utsname struct { @@ -728,7 +712,7 @@ const ( ) type Sigset_t struct { - X__val [32]uint32 + Val [32]uint32 } const RNDGETENTCNT = 0x80045200 @@ -884,3 +868,937 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x1 + CBitFieldMaskBit1 = 0x2 + CBitFieldMaskBit2 = 0x4 + CBitFieldMaskBit3 = 0x8 + CBitFieldMaskBit4 = 0x10 + CBitFieldMaskBit5 = 0x20 + CBitFieldMaskBit6 = 0x40 + CBitFieldMaskBit7 = 0x80 + CBitFieldMaskBit8 = 0x100 + CBitFieldMaskBit9 = 0x200 + CBitFieldMaskBit10 = 0x400 + CBitFieldMaskBit11 = 0x800 + CBitFieldMaskBit12 = 0x1000 + CBitFieldMaskBit13 = 0x2000 + CBitFieldMaskBit14 = 0x4000 + CBitFieldMaskBit15 = 0x8000 + CBitFieldMaskBit16 = 0x10000 + CBitFieldMaskBit17 = 0x20000 + CBitFieldMaskBit18 = 0x40000 + CBitFieldMaskBit19 = 0x80000 + CBitFieldMaskBit20 = 0x100000 + CBitFieldMaskBit21 = 0x200000 + CBitFieldMaskBit22 = 0x400000 + CBitFieldMaskBit23 = 0x800000 + CBitFieldMaskBit24 = 0x1000000 + CBitFieldMaskBit25 = 0x2000000 + CBitFieldMaskBit26 = 0x4000000 + CBitFieldMaskBit27 = 0x8000000 + CBitFieldMaskBit28 = 0x10000000 + CBitFieldMaskBit29 = 0x20000000 + CBitFieldMaskBit30 = 0x40000000 + CBitFieldMaskBit31 = 0x80000000 + CBitFieldMaskBit32 = 0x100000000 + CBitFieldMaskBit33 = 0x200000000 + CBitFieldMaskBit34 = 0x400000000 + CBitFieldMaskBit35 = 0x800000000 + CBitFieldMaskBit36 = 0x1000000000 + CBitFieldMaskBit37 = 0x2000000000 + CBitFieldMaskBit38 = 0x4000000000 + CBitFieldMaskBit39 = 0x8000000000 + CBitFieldMaskBit40 = 0x10000000000 + CBitFieldMaskBit41 = 0x20000000000 + CBitFieldMaskBit42 = 0x40000000000 + CBitFieldMaskBit43 = 0x80000000000 + CBitFieldMaskBit44 = 0x100000000000 + CBitFieldMaskBit45 = 0x200000000000 + CBitFieldMaskBit46 = 0x400000000000 + CBitFieldMaskBit47 = 0x800000000000 + CBitFieldMaskBit48 = 0x1000000000000 + CBitFieldMaskBit49 = 0x2000000000000 + CBitFieldMaskBit50 = 0x4000000000000 + CBitFieldMaskBit51 = 0x8000000000000 + CBitFieldMaskBit52 = 0x10000000000000 + CBitFieldMaskBit53 = 0x20000000000000 + CBitFieldMaskBit54 = 0x40000000000000 + CBitFieldMaskBit55 = 0x80000000000000 + CBitFieldMaskBit56 = 0x100000000000000 + CBitFieldMaskBit57 = 0x200000000000000 + CBitFieldMaskBit58 = 0x400000000000000 + CBitFieldMaskBit59 = 0x800000000000000 + CBitFieldMaskBit60 = 0x1000000000000000 + CBitFieldMaskBit61 = 0x2000000000000000 + CBitFieldMaskBit62 = 0x4000000000000000 + CBitFieldMaskBit63 = 0x8000000000000000 +) + +type SockaddrStorage struct { + Family uint16 + _ [122]uint8 + _ uint32 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + Start uint32 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int32 + Bsize int32 + Blocks uint64 + Bfree uint64 + Bavail uint64 + Files uint64 + Ffree uint64 + Fsid Fsid + Namelen int32 + Frsize int32 + Flags int32 + Spare [4]int32 + _ [4]byte +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x18 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_arm64.go b/vendor/golang.org/x/sys/unix/ztypes_linux_arm64.go index cff50c3d3e5..6ea80563f12 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_arm64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_arm64.go @@ -106,10 +106,10 @@ type Stat_t struct { Uid uint32 Gid uint32 Rdev uint64 - X__pad1 uint64 + _ uint64 Size int64 Blksize int32 - X__pad2 int32 + _ int32 Blocks int64 Atim Timespec Mtim Timespec @@ -117,25 +117,10 @@ type Stat_t struct { _ [2]int32 } -type Statfs_t struct { - Type int64 - Bsize int64 - Blocks uint64 - Bfree uint64 - Bavail uint64 - Files uint64 - Ffree uint64 - Fsid Fsid - Namelen int64 - Frsize int64 - Flags int64 - Spare [4]int64 -} - type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -172,7 +157,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -496,7 +481,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -588,12 +573,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -676,7 +661,7 @@ type Sysinfo_t struct { Totalhigh uint64 Freehigh uint64 Unit uint32 - X_f [0]int8 + _ [0]int8 _ [4]byte } @@ -736,7 +721,7 @@ const ( ) type Sigset_t struct { - X__val [16]uint64 + Val [16]uint64 } const RNDGETENTCNT = 0x80045200 @@ -892,3 +877,938 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x1 + CBitFieldMaskBit1 = 0x2 + CBitFieldMaskBit2 = 0x4 + CBitFieldMaskBit3 = 0x8 + CBitFieldMaskBit4 = 0x10 + CBitFieldMaskBit5 = 0x20 + CBitFieldMaskBit6 = 0x40 + CBitFieldMaskBit7 = 0x80 + CBitFieldMaskBit8 = 0x100 + CBitFieldMaskBit9 = 0x200 + CBitFieldMaskBit10 = 0x400 + CBitFieldMaskBit11 = 0x800 + CBitFieldMaskBit12 = 0x1000 + CBitFieldMaskBit13 = 0x2000 + CBitFieldMaskBit14 = 0x4000 + CBitFieldMaskBit15 = 0x8000 + CBitFieldMaskBit16 = 0x10000 + CBitFieldMaskBit17 = 0x20000 + CBitFieldMaskBit18 = 0x40000 + CBitFieldMaskBit19 = 0x80000 + CBitFieldMaskBit20 = 0x100000 + CBitFieldMaskBit21 = 0x200000 + CBitFieldMaskBit22 = 0x400000 + CBitFieldMaskBit23 = 0x800000 + CBitFieldMaskBit24 = 0x1000000 + CBitFieldMaskBit25 = 0x2000000 + CBitFieldMaskBit26 = 0x4000000 + CBitFieldMaskBit27 = 0x8000000 + CBitFieldMaskBit28 = 0x10000000 + CBitFieldMaskBit29 = 0x20000000 + CBitFieldMaskBit30 = 0x40000000 + CBitFieldMaskBit31 = 0x80000000 + CBitFieldMaskBit32 = 0x100000000 + CBitFieldMaskBit33 = 0x200000000 + CBitFieldMaskBit34 = 0x400000000 + CBitFieldMaskBit35 = 0x800000000 + CBitFieldMaskBit36 = 0x1000000000 + CBitFieldMaskBit37 = 0x2000000000 + CBitFieldMaskBit38 = 0x4000000000 + CBitFieldMaskBit39 = 0x8000000000 + CBitFieldMaskBit40 = 0x10000000000 + CBitFieldMaskBit41 = 0x20000000000 + CBitFieldMaskBit42 = 0x40000000000 + CBitFieldMaskBit43 = 0x80000000000 + CBitFieldMaskBit44 = 0x100000000000 + CBitFieldMaskBit45 = 0x200000000000 + CBitFieldMaskBit46 = 0x400000000000 + CBitFieldMaskBit47 = 0x800000000000 + CBitFieldMaskBit48 = 0x1000000000000 + CBitFieldMaskBit49 = 0x2000000000000 + CBitFieldMaskBit50 = 0x4000000000000 + CBitFieldMaskBit51 = 0x8000000000000 + CBitFieldMaskBit52 = 0x10000000000000 + CBitFieldMaskBit53 = 0x20000000000000 + CBitFieldMaskBit54 = 0x40000000000000 + CBitFieldMaskBit55 = 0x80000000000000 + CBitFieldMaskBit56 = 0x100000000000000 + CBitFieldMaskBit57 = 0x200000000000000 + CBitFieldMaskBit58 = 0x400000000000000 + CBitFieldMaskBit59 = 0x800000000000000 + CBitFieldMaskBit60 = 0x1000000000000000 + CBitFieldMaskBit61 = 0x2000000000000000 + CBitFieldMaskBit62 = 0x4000000000000000 + CBitFieldMaskBit63 = 0x8000000000000000 +) + +type SockaddrStorage struct { + Family uint16 + _ [118]int8 + _ uint64 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + _ [4]byte + Start uint64 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int64 + Bsize int64 + Blocks uint64 + Bfree uint64 + Bavail uint64 + Files uint64 + Ffree uint64 + Fsid Fsid + Namelen int64 + Frsize int64 + Flags int64 + Spare [4]int64 +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint64 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 + _ [4]byte +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x20 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_mips.go b/vendor/golang.org/x/sys/unix/ztypes_linux_mips.go index 87d0a8b1b08..e0a3932232e 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_mips.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_mips.go @@ -115,27 +115,10 @@ type Stat_t struct { Pad5 [14]int32 } -type Statfs_t struct { - Type int32 - Bsize int32 - Frsize int32 - _ [4]byte - Blocks uint64 - Bfree uint64 - Files uint64 - Ffree uint64 - Bavail uint64 - Fsid Fsid - Namelen int32 - Flags int32 - Spare [5]int32 - _ [4]byte -} - type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -172,7 +155,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -494,7 +477,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -586,12 +569,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -676,7 +659,7 @@ type Sysinfo_t struct { Totalhigh uint32 Freehigh uint32 Unit uint32 - X_f [8]int8 + _ [8]int8 } type Utsname struct { @@ -733,7 +716,7 @@ const ( ) type Sigset_t struct { - X__val [32]uint32 + Val [32]uint32 } const RNDGETENTCNT = 0x40045200 @@ -889,3 +872,938 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x8000000000000000 + CBitFieldMaskBit1 = 0x4000000000000000 + CBitFieldMaskBit2 = 0x2000000000000000 + CBitFieldMaskBit3 = 0x1000000000000000 + CBitFieldMaskBit4 = 0x800000000000000 + CBitFieldMaskBit5 = 0x400000000000000 + CBitFieldMaskBit6 = 0x200000000000000 + CBitFieldMaskBit7 = 0x100000000000000 + CBitFieldMaskBit8 = 0x80000000000000 + CBitFieldMaskBit9 = 0x40000000000000 + CBitFieldMaskBit10 = 0x20000000000000 + CBitFieldMaskBit11 = 0x10000000000000 + CBitFieldMaskBit12 = 0x8000000000000 + CBitFieldMaskBit13 = 0x4000000000000 + CBitFieldMaskBit14 = 0x2000000000000 + CBitFieldMaskBit15 = 0x1000000000000 + CBitFieldMaskBit16 = 0x800000000000 + CBitFieldMaskBit17 = 0x400000000000 + CBitFieldMaskBit18 = 0x200000000000 + CBitFieldMaskBit19 = 0x100000000000 + CBitFieldMaskBit20 = 0x80000000000 + CBitFieldMaskBit21 = 0x40000000000 + CBitFieldMaskBit22 = 0x20000000000 + CBitFieldMaskBit23 = 0x10000000000 + CBitFieldMaskBit24 = 0x8000000000 + CBitFieldMaskBit25 = 0x4000000000 + CBitFieldMaskBit26 = 0x2000000000 + CBitFieldMaskBit27 = 0x1000000000 + CBitFieldMaskBit28 = 0x800000000 + CBitFieldMaskBit29 = 0x400000000 + CBitFieldMaskBit30 = 0x200000000 + CBitFieldMaskBit31 = 0x100000000 + CBitFieldMaskBit32 = 0x80000000 + CBitFieldMaskBit33 = 0x40000000 + CBitFieldMaskBit34 = 0x20000000 + CBitFieldMaskBit35 = 0x10000000 + CBitFieldMaskBit36 = 0x8000000 + CBitFieldMaskBit37 = 0x4000000 + CBitFieldMaskBit38 = 0x2000000 + CBitFieldMaskBit39 = 0x1000000 + CBitFieldMaskBit40 = 0x800000 + CBitFieldMaskBit41 = 0x400000 + CBitFieldMaskBit42 = 0x200000 + CBitFieldMaskBit43 = 0x100000 + CBitFieldMaskBit44 = 0x80000 + CBitFieldMaskBit45 = 0x40000 + CBitFieldMaskBit46 = 0x20000 + CBitFieldMaskBit47 = 0x10000 + CBitFieldMaskBit48 = 0x8000 + CBitFieldMaskBit49 = 0x4000 + CBitFieldMaskBit50 = 0x2000 + CBitFieldMaskBit51 = 0x1000 + CBitFieldMaskBit52 = 0x800 + CBitFieldMaskBit53 = 0x400 + CBitFieldMaskBit54 = 0x200 + CBitFieldMaskBit55 = 0x100 + CBitFieldMaskBit56 = 0x80 + CBitFieldMaskBit57 = 0x40 + CBitFieldMaskBit58 = 0x20 + CBitFieldMaskBit59 = 0x10 + CBitFieldMaskBit60 = 0x8 + CBitFieldMaskBit61 = 0x4 + CBitFieldMaskBit62 = 0x2 + CBitFieldMaskBit63 = 0x1 +) + +type SockaddrStorage struct { + Family uint16 + _ [122]int8 + _ uint32 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + Start uint32 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int32 + Bsize int32 + Frsize int32 + _ [4]byte + Blocks uint64 + Bfree uint64 + Files uint64 + Ffree uint64 + Bavail uint64 + Fsid Fsid + Namelen int32 + Flags int32 + Spare [5]int32 + _ [4]byte +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x18 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_mips64.go b/vendor/golang.org/x/sys/unix/ztypes_linux_mips64.go index cf4e2bd297f..838135e24b7 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_mips64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_mips64.go @@ -117,25 +117,10 @@ type Stat_t struct { Blocks int64 } -type Statfs_t struct { - Type int64 - Bsize int64 - Frsize int64 - Blocks uint64 - Bfree uint64 - Files uint64 - Ffree uint64 - Bavail uint64 - Fsid Fsid - Namelen int64 - Flags int64 - Spare [5]int64 -} - type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -172,7 +157,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -496,7 +481,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -588,12 +573,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -679,7 +664,7 @@ type Sysinfo_t struct { Totalhigh uint64 Freehigh uint64 Unit uint32 - X_f [0]int8 + _ [0]int8 _ [4]byte } @@ -738,7 +723,7 @@ const ( ) type Sigset_t struct { - X__val [16]uint64 + Val [16]uint64 } const RNDGETENTCNT = 0x40045200 @@ -894,3 +879,938 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x8000000000000000 + CBitFieldMaskBit1 = 0x4000000000000000 + CBitFieldMaskBit2 = 0x2000000000000000 + CBitFieldMaskBit3 = 0x1000000000000000 + CBitFieldMaskBit4 = 0x800000000000000 + CBitFieldMaskBit5 = 0x400000000000000 + CBitFieldMaskBit6 = 0x200000000000000 + CBitFieldMaskBit7 = 0x100000000000000 + CBitFieldMaskBit8 = 0x80000000000000 + CBitFieldMaskBit9 = 0x40000000000000 + CBitFieldMaskBit10 = 0x20000000000000 + CBitFieldMaskBit11 = 0x10000000000000 + CBitFieldMaskBit12 = 0x8000000000000 + CBitFieldMaskBit13 = 0x4000000000000 + CBitFieldMaskBit14 = 0x2000000000000 + CBitFieldMaskBit15 = 0x1000000000000 + CBitFieldMaskBit16 = 0x800000000000 + CBitFieldMaskBit17 = 0x400000000000 + CBitFieldMaskBit18 = 0x200000000000 + CBitFieldMaskBit19 = 0x100000000000 + CBitFieldMaskBit20 = 0x80000000000 + CBitFieldMaskBit21 = 0x40000000000 + CBitFieldMaskBit22 = 0x20000000000 + CBitFieldMaskBit23 = 0x10000000000 + CBitFieldMaskBit24 = 0x8000000000 + CBitFieldMaskBit25 = 0x4000000000 + CBitFieldMaskBit26 = 0x2000000000 + CBitFieldMaskBit27 = 0x1000000000 + CBitFieldMaskBit28 = 0x800000000 + CBitFieldMaskBit29 = 0x400000000 + CBitFieldMaskBit30 = 0x200000000 + CBitFieldMaskBit31 = 0x100000000 + CBitFieldMaskBit32 = 0x80000000 + CBitFieldMaskBit33 = 0x40000000 + CBitFieldMaskBit34 = 0x20000000 + CBitFieldMaskBit35 = 0x10000000 + CBitFieldMaskBit36 = 0x8000000 + CBitFieldMaskBit37 = 0x4000000 + CBitFieldMaskBit38 = 0x2000000 + CBitFieldMaskBit39 = 0x1000000 + CBitFieldMaskBit40 = 0x800000 + CBitFieldMaskBit41 = 0x400000 + CBitFieldMaskBit42 = 0x200000 + CBitFieldMaskBit43 = 0x100000 + CBitFieldMaskBit44 = 0x80000 + CBitFieldMaskBit45 = 0x40000 + CBitFieldMaskBit46 = 0x20000 + CBitFieldMaskBit47 = 0x10000 + CBitFieldMaskBit48 = 0x8000 + CBitFieldMaskBit49 = 0x4000 + CBitFieldMaskBit50 = 0x2000 + CBitFieldMaskBit51 = 0x1000 + CBitFieldMaskBit52 = 0x800 + CBitFieldMaskBit53 = 0x400 + CBitFieldMaskBit54 = 0x200 + CBitFieldMaskBit55 = 0x100 + CBitFieldMaskBit56 = 0x80 + CBitFieldMaskBit57 = 0x40 + CBitFieldMaskBit58 = 0x20 + CBitFieldMaskBit59 = 0x10 + CBitFieldMaskBit60 = 0x8 + CBitFieldMaskBit61 = 0x4 + CBitFieldMaskBit62 = 0x2 + CBitFieldMaskBit63 = 0x1 +) + +type SockaddrStorage struct { + Family uint16 + _ [118]int8 + _ uint64 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + _ [4]byte + Start uint64 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int64 + Bsize int64 + Frsize int64 + Blocks uint64 + Bfree uint64 + Files uint64 + Ffree uint64 + Bavail uint64 + Fsid Fsid + Namelen int64 + Flags int64 + Spare [5]int64 +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint64 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 + _ [4]byte +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x20 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_mips64le.go b/vendor/golang.org/x/sys/unix/ztypes_linux_mips64le.go index b8da482ca73..a9d0131f2ee 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_mips64le.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_mips64le.go @@ -117,25 +117,10 @@ type Stat_t struct { Blocks int64 } -type Statfs_t struct { - Type int64 - Bsize int64 - Frsize int64 - Blocks uint64 - Bfree uint64 - Files uint64 - Ffree uint64 - Bavail uint64 - Fsid Fsid - Namelen int64 - Flags int64 - Spare [5]int64 -} - type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -172,7 +157,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -496,7 +481,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -588,12 +573,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -679,7 +664,7 @@ type Sysinfo_t struct { Totalhigh uint64 Freehigh uint64 Unit uint32 - X_f [0]int8 + _ [0]int8 _ [4]byte } @@ -738,7 +723,7 @@ const ( ) type Sigset_t struct { - X__val [16]uint64 + Val [16]uint64 } const RNDGETENTCNT = 0x40045200 @@ -894,3 +879,938 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x1 + CBitFieldMaskBit1 = 0x2 + CBitFieldMaskBit2 = 0x4 + CBitFieldMaskBit3 = 0x8 + CBitFieldMaskBit4 = 0x10 + CBitFieldMaskBit5 = 0x20 + CBitFieldMaskBit6 = 0x40 + CBitFieldMaskBit7 = 0x80 + CBitFieldMaskBit8 = 0x100 + CBitFieldMaskBit9 = 0x200 + CBitFieldMaskBit10 = 0x400 + CBitFieldMaskBit11 = 0x800 + CBitFieldMaskBit12 = 0x1000 + CBitFieldMaskBit13 = 0x2000 + CBitFieldMaskBit14 = 0x4000 + CBitFieldMaskBit15 = 0x8000 + CBitFieldMaskBit16 = 0x10000 + CBitFieldMaskBit17 = 0x20000 + CBitFieldMaskBit18 = 0x40000 + CBitFieldMaskBit19 = 0x80000 + CBitFieldMaskBit20 = 0x100000 + CBitFieldMaskBit21 = 0x200000 + CBitFieldMaskBit22 = 0x400000 + CBitFieldMaskBit23 = 0x800000 + CBitFieldMaskBit24 = 0x1000000 + CBitFieldMaskBit25 = 0x2000000 + CBitFieldMaskBit26 = 0x4000000 + CBitFieldMaskBit27 = 0x8000000 + CBitFieldMaskBit28 = 0x10000000 + CBitFieldMaskBit29 = 0x20000000 + CBitFieldMaskBit30 = 0x40000000 + CBitFieldMaskBit31 = 0x80000000 + CBitFieldMaskBit32 = 0x100000000 + CBitFieldMaskBit33 = 0x200000000 + CBitFieldMaskBit34 = 0x400000000 + CBitFieldMaskBit35 = 0x800000000 + CBitFieldMaskBit36 = 0x1000000000 + CBitFieldMaskBit37 = 0x2000000000 + CBitFieldMaskBit38 = 0x4000000000 + CBitFieldMaskBit39 = 0x8000000000 + CBitFieldMaskBit40 = 0x10000000000 + CBitFieldMaskBit41 = 0x20000000000 + CBitFieldMaskBit42 = 0x40000000000 + CBitFieldMaskBit43 = 0x80000000000 + CBitFieldMaskBit44 = 0x100000000000 + CBitFieldMaskBit45 = 0x200000000000 + CBitFieldMaskBit46 = 0x400000000000 + CBitFieldMaskBit47 = 0x800000000000 + CBitFieldMaskBit48 = 0x1000000000000 + CBitFieldMaskBit49 = 0x2000000000000 + CBitFieldMaskBit50 = 0x4000000000000 + CBitFieldMaskBit51 = 0x8000000000000 + CBitFieldMaskBit52 = 0x10000000000000 + CBitFieldMaskBit53 = 0x20000000000000 + CBitFieldMaskBit54 = 0x40000000000000 + CBitFieldMaskBit55 = 0x80000000000000 + CBitFieldMaskBit56 = 0x100000000000000 + CBitFieldMaskBit57 = 0x200000000000000 + CBitFieldMaskBit58 = 0x400000000000000 + CBitFieldMaskBit59 = 0x800000000000000 + CBitFieldMaskBit60 = 0x1000000000000000 + CBitFieldMaskBit61 = 0x2000000000000000 + CBitFieldMaskBit62 = 0x4000000000000000 + CBitFieldMaskBit63 = 0x8000000000000000 +) + +type SockaddrStorage struct { + Family uint16 + _ [118]int8 + _ uint64 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + _ [4]byte + Start uint64 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int64 + Bsize int64 + Frsize int64 + Blocks uint64 + Bfree uint64 + Files uint64 + Ffree uint64 + Bavail uint64 + Fsid Fsid + Namelen int64 + Flags int64 + Spare [5]int64 +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint64 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 + _ [4]byte +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x20 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_mipsle.go b/vendor/golang.org/x/sys/unix/ztypes_linux_mipsle.go index 7106b512d44..4f6f1455568 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_mipsle.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_mipsle.go @@ -115,27 +115,10 @@ type Stat_t struct { Pad5 [14]int32 } -type Statfs_t struct { - Type int32 - Bsize int32 - Frsize int32 - _ [4]byte - Blocks uint64 - Bfree uint64 - Files uint64 - Ffree uint64 - Bavail uint64 - Fsid Fsid - Namelen int32 - Flags int32 - Spare [5]int32 - _ [4]byte -} - type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -172,7 +155,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -494,7 +477,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -586,12 +569,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -676,7 +659,7 @@ type Sysinfo_t struct { Totalhigh uint32 Freehigh uint32 Unit uint32 - X_f [8]int8 + _ [8]int8 } type Utsname struct { @@ -733,7 +716,7 @@ const ( ) type Sigset_t struct { - X__val [32]uint32 + Val [32]uint32 } const RNDGETENTCNT = 0x40045200 @@ -889,3 +872,938 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x1 + CBitFieldMaskBit1 = 0x2 + CBitFieldMaskBit2 = 0x4 + CBitFieldMaskBit3 = 0x8 + CBitFieldMaskBit4 = 0x10 + CBitFieldMaskBit5 = 0x20 + CBitFieldMaskBit6 = 0x40 + CBitFieldMaskBit7 = 0x80 + CBitFieldMaskBit8 = 0x100 + CBitFieldMaskBit9 = 0x200 + CBitFieldMaskBit10 = 0x400 + CBitFieldMaskBit11 = 0x800 + CBitFieldMaskBit12 = 0x1000 + CBitFieldMaskBit13 = 0x2000 + CBitFieldMaskBit14 = 0x4000 + CBitFieldMaskBit15 = 0x8000 + CBitFieldMaskBit16 = 0x10000 + CBitFieldMaskBit17 = 0x20000 + CBitFieldMaskBit18 = 0x40000 + CBitFieldMaskBit19 = 0x80000 + CBitFieldMaskBit20 = 0x100000 + CBitFieldMaskBit21 = 0x200000 + CBitFieldMaskBit22 = 0x400000 + CBitFieldMaskBit23 = 0x800000 + CBitFieldMaskBit24 = 0x1000000 + CBitFieldMaskBit25 = 0x2000000 + CBitFieldMaskBit26 = 0x4000000 + CBitFieldMaskBit27 = 0x8000000 + CBitFieldMaskBit28 = 0x10000000 + CBitFieldMaskBit29 = 0x20000000 + CBitFieldMaskBit30 = 0x40000000 + CBitFieldMaskBit31 = 0x80000000 + CBitFieldMaskBit32 = 0x100000000 + CBitFieldMaskBit33 = 0x200000000 + CBitFieldMaskBit34 = 0x400000000 + CBitFieldMaskBit35 = 0x800000000 + CBitFieldMaskBit36 = 0x1000000000 + CBitFieldMaskBit37 = 0x2000000000 + CBitFieldMaskBit38 = 0x4000000000 + CBitFieldMaskBit39 = 0x8000000000 + CBitFieldMaskBit40 = 0x10000000000 + CBitFieldMaskBit41 = 0x20000000000 + CBitFieldMaskBit42 = 0x40000000000 + CBitFieldMaskBit43 = 0x80000000000 + CBitFieldMaskBit44 = 0x100000000000 + CBitFieldMaskBit45 = 0x200000000000 + CBitFieldMaskBit46 = 0x400000000000 + CBitFieldMaskBit47 = 0x800000000000 + CBitFieldMaskBit48 = 0x1000000000000 + CBitFieldMaskBit49 = 0x2000000000000 + CBitFieldMaskBit50 = 0x4000000000000 + CBitFieldMaskBit51 = 0x8000000000000 + CBitFieldMaskBit52 = 0x10000000000000 + CBitFieldMaskBit53 = 0x20000000000000 + CBitFieldMaskBit54 = 0x40000000000000 + CBitFieldMaskBit55 = 0x80000000000000 + CBitFieldMaskBit56 = 0x100000000000000 + CBitFieldMaskBit57 = 0x200000000000000 + CBitFieldMaskBit58 = 0x400000000000000 + CBitFieldMaskBit59 = 0x800000000000000 + CBitFieldMaskBit60 = 0x1000000000000000 + CBitFieldMaskBit61 = 0x2000000000000000 + CBitFieldMaskBit62 = 0x4000000000000000 + CBitFieldMaskBit63 = 0x8000000000000000 +) + +type SockaddrStorage struct { + Family uint16 + _ [122]int8 + _ uint32 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + Start uint32 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int32 + Bsize int32 + Frsize int32 + _ [4]byte + Blocks uint64 + Bfree uint64 + Files uint64 + Ffree uint64 + Bavail uint64 + Fsid Fsid + Namelen int32 + Flags int32 + Spare [5]int32 + _ [4]byte +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x18 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_ppc64.go b/vendor/golang.org/x/sys/unix/ztypes_linux_ppc64.go index 319071c8b66..9ddd47015e3 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_ppc64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_ppc64.go @@ -105,7 +105,7 @@ type Stat_t struct { Mode uint32 Uid uint32 Gid uint32 - X__pad2 int32 + _ int32 Rdev uint64 Size int64 Blksize int64 @@ -118,25 +118,10 @@ type Stat_t struct { _ uint64 } -type Statfs_t struct { - Type int64 - Bsize int64 - Blocks uint64 - Bfree uint64 - Bavail uint64 - Files uint64 - Ffree uint64 - Fsid Fsid - Namelen int64 - Frsize int64 - Flags int64 - Spare [4]int64 -} - type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -173,7 +158,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -497,7 +482,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -589,12 +574,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -686,7 +671,7 @@ type Sysinfo_t struct { Totalhigh uint64 Freehigh uint64 Unit uint32 - X_f [0]uint8 + _ [0]uint8 _ [4]byte } @@ -709,10 +694,10 @@ type Ustat_t struct { } type EpollEvent struct { - Events uint32 - X_padFd int32 - Fd int32 - Pad int32 + Events uint32 + _ int32 + Fd int32 + Pad int32 } const ( @@ -746,7 +731,7 @@ const ( ) type Sigset_t struct { - X__val [16]uint64 + Val [16]uint64 } const RNDGETENTCNT = 0x40045200 @@ -902,3 +887,938 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x8000000000000000 + CBitFieldMaskBit1 = 0x4000000000000000 + CBitFieldMaskBit2 = 0x2000000000000000 + CBitFieldMaskBit3 = 0x1000000000000000 + CBitFieldMaskBit4 = 0x800000000000000 + CBitFieldMaskBit5 = 0x400000000000000 + CBitFieldMaskBit6 = 0x200000000000000 + CBitFieldMaskBit7 = 0x100000000000000 + CBitFieldMaskBit8 = 0x80000000000000 + CBitFieldMaskBit9 = 0x40000000000000 + CBitFieldMaskBit10 = 0x20000000000000 + CBitFieldMaskBit11 = 0x10000000000000 + CBitFieldMaskBit12 = 0x8000000000000 + CBitFieldMaskBit13 = 0x4000000000000 + CBitFieldMaskBit14 = 0x2000000000000 + CBitFieldMaskBit15 = 0x1000000000000 + CBitFieldMaskBit16 = 0x800000000000 + CBitFieldMaskBit17 = 0x400000000000 + CBitFieldMaskBit18 = 0x200000000000 + CBitFieldMaskBit19 = 0x100000000000 + CBitFieldMaskBit20 = 0x80000000000 + CBitFieldMaskBit21 = 0x40000000000 + CBitFieldMaskBit22 = 0x20000000000 + CBitFieldMaskBit23 = 0x10000000000 + CBitFieldMaskBit24 = 0x8000000000 + CBitFieldMaskBit25 = 0x4000000000 + CBitFieldMaskBit26 = 0x2000000000 + CBitFieldMaskBit27 = 0x1000000000 + CBitFieldMaskBit28 = 0x800000000 + CBitFieldMaskBit29 = 0x400000000 + CBitFieldMaskBit30 = 0x200000000 + CBitFieldMaskBit31 = 0x100000000 + CBitFieldMaskBit32 = 0x80000000 + CBitFieldMaskBit33 = 0x40000000 + CBitFieldMaskBit34 = 0x20000000 + CBitFieldMaskBit35 = 0x10000000 + CBitFieldMaskBit36 = 0x8000000 + CBitFieldMaskBit37 = 0x4000000 + CBitFieldMaskBit38 = 0x2000000 + CBitFieldMaskBit39 = 0x1000000 + CBitFieldMaskBit40 = 0x800000 + CBitFieldMaskBit41 = 0x400000 + CBitFieldMaskBit42 = 0x200000 + CBitFieldMaskBit43 = 0x100000 + CBitFieldMaskBit44 = 0x80000 + CBitFieldMaskBit45 = 0x40000 + CBitFieldMaskBit46 = 0x20000 + CBitFieldMaskBit47 = 0x10000 + CBitFieldMaskBit48 = 0x8000 + CBitFieldMaskBit49 = 0x4000 + CBitFieldMaskBit50 = 0x2000 + CBitFieldMaskBit51 = 0x1000 + CBitFieldMaskBit52 = 0x800 + CBitFieldMaskBit53 = 0x400 + CBitFieldMaskBit54 = 0x200 + CBitFieldMaskBit55 = 0x100 + CBitFieldMaskBit56 = 0x80 + CBitFieldMaskBit57 = 0x40 + CBitFieldMaskBit58 = 0x20 + CBitFieldMaskBit59 = 0x10 + CBitFieldMaskBit60 = 0x8 + CBitFieldMaskBit61 = 0x4 + CBitFieldMaskBit62 = 0x2 + CBitFieldMaskBit63 = 0x1 +) + +type SockaddrStorage struct { + Family uint16 + _ [118]uint8 + _ uint64 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + _ [4]byte + Start uint64 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int64 + Bsize int64 + Blocks uint64 + Bfree uint64 + Bavail uint64 + Files uint64 + Ffree uint64 + Fsid Fsid + Namelen int64 + Frsize int64 + Flags int64 + Spare [4]int64 +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint64 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 + _ [4]byte +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x20 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_ppc64le.go b/vendor/golang.org/x/sys/unix/ztypes_linux_ppc64le.go index ef00ed498ae..3a5cc696ec3 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_ppc64le.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_ppc64le.go @@ -105,7 +105,7 @@ type Stat_t struct { Mode uint32 Uid uint32 Gid uint32 - X__pad2 int32 + _ int32 Rdev uint64 Size int64 Blksize int64 @@ -118,25 +118,10 @@ type Stat_t struct { _ uint64 } -type Statfs_t struct { - Type int64 - Bsize int64 - Blocks uint64 - Bfree uint64 - Bavail uint64 - Files uint64 - Ffree uint64 - Fsid Fsid - Namelen int64 - Frsize int64 - Flags int64 - Spare [4]int64 -} - type StatxTimestamp struct { - Sec int64 - Nsec uint32 - X__reserved int32 + Sec int64 + Nsec uint32 + _ int32 } type Statx_t struct { @@ -173,7 +158,7 @@ type Dirent struct { } type Fsid struct { - X__val [2]int32 + Val [2]int32 } type Flock_t struct { @@ -497,7 +482,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -589,12 +574,12 @@ type RtAttr struct { } type IfInfomsg struct { - Family uint8 - X__ifi_pad uint8 - Type uint16 - Index int32 - Flags uint32 - Change uint32 + Family uint8 + _ uint8 + Type uint16 + Index int32 + Flags uint32 + Change uint32 } type IfAddrmsg struct { @@ -686,7 +671,7 @@ type Sysinfo_t struct { Totalhigh uint64 Freehigh uint64 Unit uint32 - X_f [0]uint8 + _ [0]uint8 _ [4]byte } @@ -709,10 +694,10 @@ type Ustat_t struct { } type EpollEvent struct { - Events uint32 - X_padFd int32 - Fd int32 - Pad int32 + Events uint32 + _ int32 + Fd int32 + Pad int32 } const ( @@ -746,7 +731,7 @@ const ( ) type Sigset_t struct { - X__val [16]uint64 + Val [16]uint64 } const RNDGETENTCNT = 0x40045200 @@ -902,3 +887,938 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x1 + CBitFieldMaskBit1 = 0x2 + CBitFieldMaskBit2 = 0x4 + CBitFieldMaskBit3 = 0x8 + CBitFieldMaskBit4 = 0x10 + CBitFieldMaskBit5 = 0x20 + CBitFieldMaskBit6 = 0x40 + CBitFieldMaskBit7 = 0x80 + CBitFieldMaskBit8 = 0x100 + CBitFieldMaskBit9 = 0x200 + CBitFieldMaskBit10 = 0x400 + CBitFieldMaskBit11 = 0x800 + CBitFieldMaskBit12 = 0x1000 + CBitFieldMaskBit13 = 0x2000 + CBitFieldMaskBit14 = 0x4000 + CBitFieldMaskBit15 = 0x8000 + CBitFieldMaskBit16 = 0x10000 + CBitFieldMaskBit17 = 0x20000 + CBitFieldMaskBit18 = 0x40000 + CBitFieldMaskBit19 = 0x80000 + CBitFieldMaskBit20 = 0x100000 + CBitFieldMaskBit21 = 0x200000 + CBitFieldMaskBit22 = 0x400000 + CBitFieldMaskBit23 = 0x800000 + CBitFieldMaskBit24 = 0x1000000 + CBitFieldMaskBit25 = 0x2000000 + CBitFieldMaskBit26 = 0x4000000 + CBitFieldMaskBit27 = 0x8000000 + CBitFieldMaskBit28 = 0x10000000 + CBitFieldMaskBit29 = 0x20000000 + CBitFieldMaskBit30 = 0x40000000 + CBitFieldMaskBit31 = 0x80000000 + CBitFieldMaskBit32 = 0x100000000 + CBitFieldMaskBit33 = 0x200000000 + CBitFieldMaskBit34 = 0x400000000 + CBitFieldMaskBit35 = 0x800000000 + CBitFieldMaskBit36 = 0x1000000000 + CBitFieldMaskBit37 = 0x2000000000 + CBitFieldMaskBit38 = 0x4000000000 + CBitFieldMaskBit39 = 0x8000000000 + CBitFieldMaskBit40 = 0x10000000000 + CBitFieldMaskBit41 = 0x20000000000 + CBitFieldMaskBit42 = 0x40000000000 + CBitFieldMaskBit43 = 0x80000000000 + CBitFieldMaskBit44 = 0x100000000000 + CBitFieldMaskBit45 = 0x200000000000 + CBitFieldMaskBit46 = 0x400000000000 + CBitFieldMaskBit47 = 0x800000000000 + CBitFieldMaskBit48 = 0x1000000000000 + CBitFieldMaskBit49 = 0x2000000000000 + CBitFieldMaskBit50 = 0x4000000000000 + CBitFieldMaskBit51 = 0x8000000000000 + CBitFieldMaskBit52 = 0x10000000000000 + CBitFieldMaskBit53 = 0x20000000000000 + CBitFieldMaskBit54 = 0x40000000000000 + CBitFieldMaskBit55 = 0x80000000000000 + CBitFieldMaskBit56 = 0x100000000000000 + CBitFieldMaskBit57 = 0x200000000000000 + CBitFieldMaskBit58 = 0x400000000000000 + CBitFieldMaskBit59 = 0x800000000000000 + CBitFieldMaskBit60 = 0x1000000000000000 + CBitFieldMaskBit61 = 0x2000000000000000 + CBitFieldMaskBit62 = 0x4000000000000000 + CBitFieldMaskBit63 = 0x8000000000000000 +) + +type SockaddrStorage struct { + Family uint16 + _ [118]uint8 + _ uint64 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + _ [4]byte + Start uint64 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type int64 + Bsize int64 + Blocks uint64 + Bfree uint64 + Bavail uint64 + Files uint64 + Ffree uint64 + Fsid Fsid + Namelen int64 + Frsize int64 + Flags int64 + Spare [4]int64 +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint64 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 + _ [4]byte +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x20 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_s390x.go b/vendor/golang.org/x/sys/unix/ztypes_linux_s390x.go index e9ee4970604..032a71bbfe3 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_s390x.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_s390x.go @@ -116,22 +116,6 @@ type Stat_t struct { _ [3]int64 } -type Statfs_t struct { - Type uint32 - Bsize uint32 - Blocks uint64 - Bfree uint64 - Bavail uint64 - Files uint64 - Ffree uint64 - Fsid Fsid - Namelen uint32 - Frsize uint32 - Flags uint32 - Spare [4]uint32 - _ [4]byte -} - type StatxTimestamp struct { Sec int64 Nsec uint32 @@ -172,7 +156,7 @@ type Dirent struct { } type Fsid struct { - _ [2]int32 + Val [2]int32 } type Flock_t struct { @@ -496,7 +480,7 @@ const ( IFLA_EVENT = 0x2c IFLA_NEW_NETNSID = 0x2d IFLA_IF_NETNSID = 0x2e - IFLA_MAX = 0x2e + IFLA_MAX = 0x31 RT_SCOPE_UNIVERSE = 0x0 RT_SCOPE_SITE = 0xc8 RT_SCOPE_LINK = 0xfd @@ -763,7 +747,7 @@ const ( ) type Sigset_t struct { - _ [16]uint64 + Val [16]uint64 } const RNDGETENTCNT = 0x80045200 @@ -919,3 +903,939 @@ const ( BDADDR_LE_PUBLIC = 0x1 BDADDR_LE_RANDOM = 0x2 ) + +type PerfEventAttr struct { + Type uint32 + Size uint32 + Config uint64 + Sample uint64 + Sample_type uint64 + Read_format uint64 + Bits uint64 + Wakeup uint32 + Bp_type uint32 + Ext1 uint64 + Ext2 uint64 + Branch_sample_type uint64 + Sample_regs_user uint64 + Sample_stack_user uint32 + Clockid int32 + Sample_regs_intr uint64 + Aux_watermark uint32 + _ uint32 +} + +type PerfEventMmapPage struct { + Version uint32 + Compat_version uint32 + Lock uint32 + Index uint32 + Offset int64 + Time_enabled uint64 + Time_running uint64 + Capabilities uint64 + Pmc_width uint16 + Time_shift uint16 + Time_mult uint32 + Time_offset uint64 + Time_zero uint64 + Size uint32 + _ [948]uint8 + Data_head uint64 + Data_tail uint64 + Data_offset uint64 + Data_size uint64 + Aux_head uint64 + Aux_tail uint64 + Aux_offset uint64 + Aux_size uint64 +} + +const ( + PerfBitDisabled uint64 = CBitFieldMaskBit0 + PerfBitInherit = CBitFieldMaskBit1 + PerfBitPinned = CBitFieldMaskBit2 + PerfBitExclusive = CBitFieldMaskBit3 + PerfBitExcludeUser = CBitFieldMaskBit4 + PerfBitExcludeKernel = CBitFieldMaskBit5 + PerfBitExcludeHv = CBitFieldMaskBit6 + PerfBitExcludeIdle = CBitFieldMaskBit7 + PerfBitMmap = CBitFieldMaskBit8 + PerfBitComm = CBitFieldMaskBit9 + PerfBitFreq = CBitFieldMaskBit10 + PerfBitInheritStat = CBitFieldMaskBit11 + PerfBitEnableOnExec = CBitFieldMaskBit12 + PerfBitTask = CBitFieldMaskBit13 + PerfBitWatermark = CBitFieldMaskBit14 + PerfBitPreciseIPBit1 = CBitFieldMaskBit15 + PerfBitPreciseIPBit2 = CBitFieldMaskBit16 + PerfBitMmapData = CBitFieldMaskBit17 + PerfBitSampleIDAll = CBitFieldMaskBit18 + PerfBitExcludeHost = CBitFieldMaskBit19 + PerfBitExcludeGuest = CBitFieldMaskBit20 + PerfBitExcludeCallchainKernel = CBitFieldMaskBit21 + PerfBitExcludeCallchainUser = CBitFieldMaskBit22 + PerfBitMmap2 = CBitFieldMaskBit23 + PerfBitCommExec = CBitFieldMaskBit24 + PerfBitUseClockID = CBitFieldMaskBit25 + PerfBitContextSwitch = CBitFieldMaskBit26 +) + +const ( + PERF_TYPE_HARDWARE = 0x0 + PERF_TYPE_SOFTWARE = 0x1 + PERF_TYPE_TRACEPOINT = 0x2 + PERF_TYPE_HW_CACHE = 0x3 + PERF_TYPE_RAW = 0x4 + PERF_TYPE_BREAKPOINT = 0x5 + + PERF_COUNT_HW_CPU_CYCLES = 0x0 + PERF_COUNT_HW_INSTRUCTIONS = 0x1 + PERF_COUNT_HW_CACHE_REFERENCES = 0x2 + PERF_COUNT_HW_CACHE_MISSES = 0x3 + PERF_COUNT_HW_BRANCH_INSTRUCTIONS = 0x4 + PERF_COUNT_HW_BRANCH_MISSES = 0x5 + PERF_COUNT_HW_BUS_CYCLES = 0x6 + PERF_COUNT_HW_STALLED_CYCLES_FRONTEND = 0x7 + PERF_COUNT_HW_STALLED_CYCLES_BACKEND = 0x8 + PERF_COUNT_HW_REF_CPU_CYCLES = 0x9 + + PERF_COUNT_HW_CACHE_L1D = 0x0 + PERF_COUNT_HW_CACHE_L1I = 0x1 + PERF_COUNT_HW_CACHE_LL = 0x2 + PERF_COUNT_HW_CACHE_DTLB = 0x3 + PERF_COUNT_HW_CACHE_ITLB = 0x4 + PERF_COUNT_HW_CACHE_BPU = 0x5 + PERF_COUNT_HW_CACHE_NODE = 0x6 + + PERF_COUNT_HW_CACHE_OP_READ = 0x0 + PERF_COUNT_HW_CACHE_OP_WRITE = 0x1 + PERF_COUNT_HW_CACHE_OP_PREFETCH = 0x2 + + PERF_COUNT_HW_CACHE_RESULT_ACCESS = 0x0 + PERF_COUNT_HW_CACHE_RESULT_MISS = 0x1 + + PERF_COUNT_SW_CPU_CLOCK = 0x0 + PERF_COUNT_SW_TASK_CLOCK = 0x1 + PERF_COUNT_SW_PAGE_FAULTS = 0x2 + PERF_COUNT_SW_CONTEXT_SWITCHES = 0x3 + PERF_COUNT_SW_CPU_MIGRATIONS = 0x4 + PERF_COUNT_SW_PAGE_FAULTS_MIN = 0x5 + PERF_COUNT_SW_PAGE_FAULTS_MAJ = 0x6 + PERF_COUNT_SW_ALIGNMENT_FAULTS = 0x7 + PERF_COUNT_SW_EMULATION_FAULTS = 0x8 + PERF_COUNT_SW_DUMMY = 0x9 + + PERF_SAMPLE_IP = 0x1 + PERF_SAMPLE_TID = 0x2 + PERF_SAMPLE_TIME = 0x4 + PERF_SAMPLE_ADDR = 0x8 + PERF_SAMPLE_READ = 0x10 + PERF_SAMPLE_CALLCHAIN = 0x20 + PERF_SAMPLE_ID = 0x40 + PERF_SAMPLE_CPU = 0x80 + PERF_SAMPLE_PERIOD = 0x100 + PERF_SAMPLE_STREAM_ID = 0x200 + PERF_SAMPLE_RAW = 0x400 + PERF_SAMPLE_BRANCH_STACK = 0x800 + + PERF_SAMPLE_BRANCH_USER = 0x1 + PERF_SAMPLE_BRANCH_KERNEL = 0x2 + PERF_SAMPLE_BRANCH_HV = 0x4 + PERF_SAMPLE_BRANCH_ANY = 0x8 + PERF_SAMPLE_BRANCH_ANY_CALL = 0x10 + PERF_SAMPLE_BRANCH_ANY_RETURN = 0x20 + PERF_SAMPLE_BRANCH_IND_CALL = 0x40 + + PERF_FORMAT_TOTAL_TIME_ENABLED = 0x1 + PERF_FORMAT_TOTAL_TIME_RUNNING = 0x2 + PERF_FORMAT_ID = 0x4 + PERF_FORMAT_GROUP = 0x8 + + PERF_RECORD_MMAP = 0x1 + PERF_RECORD_LOST = 0x2 + PERF_RECORD_COMM = 0x3 + PERF_RECORD_EXIT = 0x4 + PERF_RECORD_THROTTLE = 0x5 + PERF_RECORD_UNTHROTTLE = 0x6 + PERF_RECORD_FORK = 0x7 + PERF_RECORD_READ = 0x8 + PERF_RECORD_SAMPLE = 0x9 + + PERF_CONTEXT_HV = -0x20 + PERF_CONTEXT_KERNEL = -0x80 + PERF_CONTEXT_USER = -0x200 + + PERF_CONTEXT_GUEST = -0x800 + PERF_CONTEXT_GUEST_KERNEL = -0x880 + PERF_CONTEXT_GUEST_USER = -0xa00 + + PERF_FLAG_FD_NO_GROUP = 0x1 + PERF_FLAG_FD_OUTPUT = 0x2 + PERF_FLAG_PID_CGROUP = 0x4 +) + +const ( + CBitFieldMaskBit0 = 0x8000000000000000 + CBitFieldMaskBit1 = 0x4000000000000000 + CBitFieldMaskBit2 = 0x2000000000000000 + CBitFieldMaskBit3 = 0x1000000000000000 + CBitFieldMaskBit4 = 0x800000000000000 + CBitFieldMaskBit5 = 0x400000000000000 + CBitFieldMaskBit6 = 0x200000000000000 + CBitFieldMaskBit7 = 0x100000000000000 + CBitFieldMaskBit8 = 0x80000000000000 + CBitFieldMaskBit9 = 0x40000000000000 + CBitFieldMaskBit10 = 0x20000000000000 + CBitFieldMaskBit11 = 0x10000000000000 + CBitFieldMaskBit12 = 0x8000000000000 + CBitFieldMaskBit13 = 0x4000000000000 + CBitFieldMaskBit14 = 0x2000000000000 + CBitFieldMaskBit15 = 0x1000000000000 + CBitFieldMaskBit16 = 0x800000000000 + CBitFieldMaskBit17 = 0x400000000000 + CBitFieldMaskBit18 = 0x200000000000 + CBitFieldMaskBit19 = 0x100000000000 + CBitFieldMaskBit20 = 0x80000000000 + CBitFieldMaskBit21 = 0x40000000000 + CBitFieldMaskBit22 = 0x20000000000 + CBitFieldMaskBit23 = 0x10000000000 + CBitFieldMaskBit24 = 0x8000000000 + CBitFieldMaskBit25 = 0x4000000000 + CBitFieldMaskBit26 = 0x2000000000 + CBitFieldMaskBit27 = 0x1000000000 + CBitFieldMaskBit28 = 0x800000000 + CBitFieldMaskBit29 = 0x400000000 + CBitFieldMaskBit30 = 0x200000000 + CBitFieldMaskBit31 = 0x100000000 + CBitFieldMaskBit32 = 0x80000000 + CBitFieldMaskBit33 = 0x40000000 + CBitFieldMaskBit34 = 0x20000000 + CBitFieldMaskBit35 = 0x10000000 + CBitFieldMaskBit36 = 0x8000000 + CBitFieldMaskBit37 = 0x4000000 + CBitFieldMaskBit38 = 0x2000000 + CBitFieldMaskBit39 = 0x1000000 + CBitFieldMaskBit40 = 0x800000 + CBitFieldMaskBit41 = 0x400000 + CBitFieldMaskBit42 = 0x200000 + CBitFieldMaskBit43 = 0x100000 + CBitFieldMaskBit44 = 0x80000 + CBitFieldMaskBit45 = 0x40000 + CBitFieldMaskBit46 = 0x20000 + CBitFieldMaskBit47 = 0x10000 + CBitFieldMaskBit48 = 0x8000 + CBitFieldMaskBit49 = 0x4000 + CBitFieldMaskBit50 = 0x2000 + CBitFieldMaskBit51 = 0x1000 + CBitFieldMaskBit52 = 0x800 + CBitFieldMaskBit53 = 0x400 + CBitFieldMaskBit54 = 0x200 + CBitFieldMaskBit55 = 0x100 + CBitFieldMaskBit56 = 0x80 + CBitFieldMaskBit57 = 0x40 + CBitFieldMaskBit58 = 0x20 + CBitFieldMaskBit59 = 0x10 + CBitFieldMaskBit60 = 0x8 + CBitFieldMaskBit61 = 0x4 + CBitFieldMaskBit62 = 0x2 + CBitFieldMaskBit63 = 0x1 +) + +type SockaddrStorage struct { + Family uint16 + _ [118]int8 + _ uint64 +} + +type TCPMD5Sig struct { + Addr SockaddrStorage + Flags uint8 + Prefixlen uint8 + Keylen uint16 + _ uint32 + Key [80]uint8 +} + +type HDDriveCmdHdr struct { + Command uint8 + Number uint8 + Feature uint8 + Count uint8 +} + +type HDGeometry struct { + Heads uint8 + Sectors uint8 + Cylinders uint16 + _ [4]byte + Start uint64 +} + +type HDDriveID struct { + Config uint16 + Cyls uint16 + Reserved2 uint16 + Heads uint16 + Track_bytes uint16 + Sector_bytes uint16 + Sectors uint16 + Vendor0 uint16 + Vendor1 uint16 + Vendor2 uint16 + Serial_no [20]uint8 + Buf_type uint16 + Buf_size uint16 + Ecc_bytes uint16 + Fw_rev [8]uint8 + Model [40]uint8 + Max_multsect uint8 + Vendor3 uint8 + Dword_io uint16 + Vendor4 uint8 + Capability uint8 + Reserved50 uint16 + Vendor5 uint8 + TPIO uint8 + Vendor6 uint8 + TDMA uint8 + Field_valid uint16 + Cur_cyls uint16 + Cur_heads uint16 + Cur_sectors uint16 + Cur_capacity0 uint16 + Cur_capacity1 uint16 + Multsect uint8 + Multsect_valid uint8 + Lba_capacity uint32 + Dma_1word uint16 + Dma_mword uint16 + Eide_pio_modes uint16 + Eide_dma_min uint16 + Eide_dma_time uint16 + Eide_pio uint16 + Eide_pio_iordy uint16 + Words69_70 [2]uint16 + Words71_74 [4]uint16 + Queue_depth uint16 + Words76_79 [4]uint16 + Major_rev_num uint16 + Minor_rev_num uint16 + Command_set_1 uint16 + Command_set_2 uint16 + Cfsse uint16 + Cfs_enable_1 uint16 + Cfs_enable_2 uint16 + Csf_default uint16 + Dma_ultra uint16 + Trseuc uint16 + TrsEuc uint16 + CurAPMvalues uint16 + Mprc uint16 + Hw_config uint16 + Acoustic uint16 + Msrqs uint16 + Sxfert uint16 + Sal uint16 + Spg uint32 + Lba_capacity_2 uint64 + Words104_125 [22]uint16 + Last_lun uint16 + Word127 uint16 + Dlf uint16 + Csfo uint16 + Words130_155 [26]uint16 + Word156 uint16 + Words157_159 [3]uint16 + Cfa_power uint16 + Words161_175 [15]uint16 + Words176_205 [30]uint16 + Words206_254 [49]uint16 + Integrity_word uint16 +} + +type Statfs_t struct { + Type uint32 + Bsize uint32 + Blocks uint64 + Bfree uint64 + Bavail uint64 + Files uint64 + Ffree uint64 + Fsid Fsid + Namelen uint32 + Frsize uint32 + Flags uint32 + Spare [4]uint32 + _ [4]byte +} + +const ( + ST_MANDLOCK = 0x40 + ST_NOATIME = 0x400 + ST_NODEV = 0x4 + ST_NODIRATIME = 0x800 + ST_NOEXEC = 0x8 + ST_NOSUID = 0x2 + ST_RDONLY = 0x1 + ST_RELATIME = 0x1000 + ST_SYNCHRONOUS = 0x10 +) + +type TpacketHdr struct { + Status uint64 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Usec uint32 + _ [4]byte +} + +type Tpacket2Hdr struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Sec uint32 + Nsec uint32 + Vlan_tci uint16 + Vlan_tpid uint16 + _ [4]uint8 +} + +type Tpacket3Hdr struct { + Next_offset uint32 + Sec uint32 + Nsec uint32 + Snaplen uint32 + Len uint32 + Status uint32 + Mac uint16 + Net uint16 + Hv1 TpacketHdrVariant1 + _ [8]uint8 +} + +type TpacketHdrVariant1 struct { + Rxhash uint32 + Vlan_tci uint32 + Vlan_tpid uint16 + _ uint16 +} + +type TpacketBlockDesc struct { + Version uint32 + To_priv uint32 + Hdr [40]byte +} + +type TpacketReq struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 +} + +type TpacketReq3 struct { + Block_size uint32 + Block_nr uint32 + Frame_size uint32 + Frame_nr uint32 + Retire_blk_tov uint32 + Sizeof_priv uint32 + Feature_req_word uint32 +} + +type TpacketStats struct { + Packets uint32 + Drops uint32 +} + +type TpacketStatsV3 struct { + Packets uint32 + Drops uint32 + Freeze_q_cnt uint32 +} + +type TpacketAuxdata struct { + Status uint32 + Len uint32 + Snaplen uint32 + Mac uint16 + Net uint16 + Vlan_tci uint16 + Vlan_tpid uint16 +} + +const ( + TPACKET_V1 = 0x0 + TPACKET_V2 = 0x1 + TPACKET_V3 = 0x2 +) + +const ( + SizeofTpacketHdr = 0x20 + SizeofTpacket2Hdr = 0x20 + SizeofTpacket3Hdr = 0x30 +) + +const ( + NF_INET_PRE_ROUTING = 0x0 + NF_INET_LOCAL_IN = 0x1 + NF_INET_FORWARD = 0x2 + NF_INET_LOCAL_OUT = 0x3 + NF_INET_POST_ROUTING = 0x4 + NF_INET_NUMHOOKS = 0x5 +) + +const ( + NF_NETDEV_INGRESS = 0x0 + NF_NETDEV_NUMHOOKS = 0x1 +) + +const ( + NFPROTO_UNSPEC = 0x0 + NFPROTO_INET = 0x1 + NFPROTO_IPV4 = 0x2 + NFPROTO_ARP = 0x3 + NFPROTO_NETDEV = 0x5 + NFPROTO_BRIDGE = 0x7 + NFPROTO_IPV6 = 0xa + NFPROTO_DECNET = 0xc + NFPROTO_NUMPROTO = 0xd +) + +type Nfgenmsg struct { + Nfgen_family uint8 + Version uint8 + Res_id uint16 +} + +const ( + NFNL_BATCH_UNSPEC = 0x0 + NFNL_BATCH_GENID = 0x1 +) + +const ( + NFT_REG_VERDICT = 0x0 + NFT_REG_1 = 0x1 + NFT_REG_2 = 0x2 + NFT_REG_3 = 0x3 + NFT_REG_4 = 0x4 + NFT_REG32_00 = 0x8 + NFT_REG32_01 = 0x9 + NFT_REG32_02 = 0xa + NFT_REG32_03 = 0xb + NFT_REG32_04 = 0xc + NFT_REG32_05 = 0xd + NFT_REG32_06 = 0xe + NFT_REG32_07 = 0xf + NFT_REG32_08 = 0x10 + NFT_REG32_09 = 0x11 + NFT_REG32_10 = 0x12 + NFT_REG32_11 = 0x13 + NFT_REG32_12 = 0x14 + NFT_REG32_13 = 0x15 + NFT_REG32_14 = 0x16 + NFT_REG32_15 = 0x17 + NFT_CONTINUE = -0x1 + NFT_BREAK = -0x2 + NFT_JUMP = -0x3 + NFT_GOTO = -0x4 + NFT_RETURN = -0x5 + NFT_MSG_NEWTABLE = 0x0 + NFT_MSG_GETTABLE = 0x1 + NFT_MSG_DELTABLE = 0x2 + NFT_MSG_NEWCHAIN = 0x3 + NFT_MSG_GETCHAIN = 0x4 + NFT_MSG_DELCHAIN = 0x5 + NFT_MSG_NEWRULE = 0x6 + NFT_MSG_GETRULE = 0x7 + NFT_MSG_DELRULE = 0x8 + NFT_MSG_NEWSET = 0x9 + NFT_MSG_GETSET = 0xa + NFT_MSG_DELSET = 0xb + NFT_MSG_NEWSETELEM = 0xc + NFT_MSG_GETSETELEM = 0xd + NFT_MSG_DELSETELEM = 0xe + NFT_MSG_NEWGEN = 0xf + NFT_MSG_GETGEN = 0x10 + NFT_MSG_TRACE = 0x11 + NFT_MSG_NEWOBJ = 0x12 + NFT_MSG_GETOBJ = 0x13 + NFT_MSG_DELOBJ = 0x14 + NFT_MSG_GETOBJ_RESET = 0x15 + NFT_MSG_MAX = 0x19 + NFTA_LIST_UNPEC = 0x0 + NFTA_LIST_ELEM = 0x1 + NFTA_HOOK_UNSPEC = 0x0 + NFTA_HOOK_HOOKNUM = 0x1 + NFTA_HOOK_PRIORITY = 0x2 + NFTA_HOOK_DEV = 0x3 + NFT_TABLE_F_DORMANT = 0x1 + NFTA_TABLE_UNSPEC = 0x0 + NFTA_TABLE_NAME = 0x1 + NFTA_TABLE_FLAGS = 0x2 + NFTA_TABLE_USE = 0x3 + NFTA_CHAIN_UNSPEC = 0x0 + NFTA_CHAIN_TABLE = 0x1 + NFTA_CHAIN_HANDLE = 0x2 + NFTA_CHAIN_NAME = 0x3 + NFTA_CHAIN_HOOK = 0x4 + NFTA_CHAIN_POLICY = 0x5 + NFTA_CHAIN_USE = 0x6 + NFTA_CHAIN_TYPE = 0x7 + NFTA_CHAIN_COUNTERS = 0x8 + NFTA_CHAIN_PAD = 0x9 + NFTA_RULE_UNSPEC = 0x0 + NFTA_RULE_TABLE = 0x1 + NFTA_RULE_CHAIN = 0x2 + NFTA_RULE_HANDLE = 0x3 + NFTA_RULE_EXPRESSIONS = 0x4 + NFTA_RULE_COMPAT = 0x5 + NFTA_RULE_POSITION = 0x6 + NFTA_RULE_USERDATA = 0x7 + NFTA_RULE_PAD = 0x8 + NFTA_RULE_ID = 0x9 + NFT_RULE_COMPAT_F_INV = 0x2 + NFT_RULE_COMPAT_F_MASK = 0x2 + NFTA_RULE_COMPAT_UNSPEC = 0x0 + NFTA_RULE_COMPAT_PROTO = 0x1 + NFTA_RULE_COMPAT_FLAGS = 0x2 + NFT_SET_ANONYMOUS = 0x1 + NFT_SET_CONSTANT = 0x2 + NFT_SET_INTERVAL = 0x4 + NFT_SET_MAP = 0x8 + NFT_SET_TIMEOUT = 0x10 + NFT_SET_EVAL = 0x20 + NFT_SET_OBJECT = 0x40 + NFT_SET_POL_PERFORMANCE = 0x0 + NFT_SET_POL_MEMORY = 0x1 + NFTA_SET_DESC_UNSPEC = 0x0 + NFTA_SET_DESC_SIZE = 0x1 + NFTA_SET_UNSPEC = 0x0 + NFTA_SET_TABLE = 0x1 + NFTA_SET_NAME = 0x2 + NFTA_SET_FLAGS = 0x3 + NFTA_SET_KEY_TYPE = 0x4 + NFTA_SET_KEY_LEN = 0x5 + NFTA_SET_DATA_TYPE = 0x6 + NFTA_SET_DATA_LEN = 0x7 + NFTA_SET_POLICY = 0x8 + NFTA_SET_DESC = 0x9 + NFTA_SET_ID = 0xa + NFTA_SET_TIMEOUT = 0xb + NFTA_SET_GC_INTERVAL = 0xc + NFTA_SET_USERDATA = 0xd + NFTA_SET_PAD = 0xe + NFTA_SET_OBJ_TYPE = 0xf + NFT_SET_ELEM_INTERVAL_END = 0x1 + NFTA_SET_ELEM_UNSPEC = 0x0 + NFTA_SET_ELEM_KEY = 0x1 + NFTA_SET_ELEM_DATA = 0x2 + NFTA_SET_ELEM_FLAGS = 0x3 + NFTA_SET_ELEM_TIMEOUT = 0x4 + NFTA_SET_ELEM_EXPIRATION = 0x5 + NFTA_SET_ELEM_USERDATA = 0x6 + NFTA_SET_ELEM_EXPR = 0x7 + NFTA_SET_ELEM_PAD = 0x8 + NFTA_SET_ELEM_OBJREF = 0x9 + NFTA_SET_ELEM_LIST_UNSPEC = 0x0 + NFTA_SET_ELEM_LIST_TABLE = 0x1 + NFTA_SET_ELEM_LIST_SET = 0x2 + NFTA_SET_ELEM_LIST_ELEMENTS = 0x3 + NFTA_SET_ELEM_LIST_SET_ID = 0x4 + NFT_DATA_VALUE = 0x0 + NFT_DATA_VERDICT = 0xffffff00 + NFTA_DATA_UNSPEC = 0x0 + NFTA_DATA_VALUE = 0x1 + NFTA_DATA_VERDICT = 0x2 + NFTA_VERDICT_UNSPEC = 0x0 + NFTA_VERDICT_CODE = 0x1 + NFTA_VERDICT_CHAIN = 0x2 + NFTA_EXPR_UNSPEC = 0x0 + NFTA_EXPR_NAME = 0x1 + NFTA_EXPR_DATA = 0x2 + NFTA_IMMEDIATE_UNSPEC = 0x0 + NFTA_IMMEDIATE_DREG = 0x1 + NFTA_IMMEDIATE_DATA = 0x2 + NFTA_BITWISE_UNSPEC = 0x0 + NFTA_BITWISE_SREG = 0x1 + NFTA_BITWISE_DREG = 0x2 + NFTA_BITWISE_LEN = 0x3 + NFTA_BITWISE_MASK = 0x4 + NFTA_BITWISE_XOR = 0x5 + NFT_BYTEORDER_NTOH = 0x0 + NFT_BYTEORDER_HTON = 0x1 + NFTA_BYTEORDER_UNSPEC = 0x0 + NFTA_BYTEORDER_SREG = 0x1 + NFTA_BYTEORDER_DREG = 0x2 + NFTA_BYTEORDER_OP = 0x3 + NFTA_BYTEORDER_LEN = 0x4 + NFTA_BYTEORDER_SIZE = 0x5 + NFT_CMP_EQ = 0x0 + NFT_CMP_NEQ = 0x1 + NFT_CMP_LT = 0x2 + NFT_CMP_LTE = 0x3 + NFT_CMP_GT = 0x4 + NFT_CMP_GTE = 0x5 + NFTA_CMP_UNSPEC = 0x0 + NFTA_CMP_SREG = 0x1 + NFTA_CMP_OP = 0x2 + NFTA_CMP_DATA = 0x3 + NFT_RANGE_EQ = 0x0 + NFT_RANGE_NEQ = 0x1 + NFTA_RANGE_UNSPEC = 0x0 + NFTA_RANGE_SREG = 0x1 + NFTA_RANGE_OP = 0x2 + NFTA_RANGE_FROM_DATA = 0x3 + NFTA_RANGE_TO_DATA = 0x4 + NFT_LOOKUP_F_INV = 0x1 + NFTA_LOOKUP_UNSPEC = 0x0 + NFTA_LOOKUP_SET = 0x1 + NFTA_LOOKUP_SREG = 0x2 + NFTA_LOOKUP_DREG = 0x3 + NFTA_LOOKUP_SET_ID = 0x4 + NFTA_LOOKUP_FLAGS = 0x5 + NFT_DYNSET_OP_ADD = 0x0 + NFT_DYNSET_OP_UPDATE = 0x1 + NFT_DYNSET_F_INV = 0x1 + NFTA_DYNSET_UNSPEC = 0x0 + NFTA_DYNSET_SET_NAME = 0x1 + NFTA_DYNSET_SET_ID = 0x2 + NFTA_DYNSET_OP = 0x3 + NFTA_DYNSET_SREG_KEY = 0x4 + NFTA_DYNSET_SREG_DATA = 0x5 + NFTA_DYNSET_TIMEOUT = 0x6 + NFTA_DYNSET_EXPR = 0x7 + NFTA_DYNSET_PAD = 0x8 + NFTA_DYNSET_FLAGS = 0x9 + NFT_PAYLOAD_LL_HEADER = 0x0 + NFT_PAYLOAD_NETWORK_HEADER = 0x1 + NFT_PAYLOAD_TRANSPORT_HEADER = 0x2 + NFT_PAYLOAD_CSUM_NONE = 0x0 + NFT_PAYLOAD_CSUM_INET = 0x1 + NFT_PAYLOAD_L4CSUM_PSEUDOHDR = 0x1 + NFTA_PAYLOAD_UNSPEC = 0x0 + NFTA_PAYLOAD_DREG = 0x1 + NFTA_PAYLOAD_BASE = 0x2 + NFTA_PAYLOAD_OFFSET = 0x3 + NFTA_PAYLOAD_LEN = 0x4 + NFTA_PAYLOAD_SREG = 0x5 + NFTA_PAYLOAD_CSUM_TYPE = 0x6 + NFTA_PAYLOAD_CSUM_OFFSET = 0x7 + NFTA_PAYLOAD_CSUM_FLAGS = 0x8 + NFT_EXTHDR_F_PRESENT = 0x1 + NFT_EXTHDR_OP_IPV6 = 0x0 + NFT_EXTHDR_OP_TCPOPT = 0x1 + NFTA_EXTHDR_UNSPEC = 0x0 + NFTA_EXTHDR_DREG = 0x1 + NFTA_EXTHDR_TYPE = 0x2 + NFTA_EXTHDR_OFFSET = 0x3 + NFTA_EXTHDR_LEN = 0x4 + NFTA_EXTHDR_FLAGS = 0x5 + NFTA_EXTHDR_OP = 0x6 + NFTA_EXTHDR_SREG = 0x7 + NFT_META_LEN = 0x0 + NFT_META_PROTOCOL = 0x1 + NFT_META_PRIORITY = 0x2 + NFT_META_MARK = 0x3 + NFT_META_IIF = 0x4 + NFT_META_OIF = 0x5 + NFT_META_IIFNAME = 0x6 + NFT_META_OIFNAME = 0x7 + NFT_META_IIFTYPE = 0x8 + NFT_META_OIFTYPE = 0x9 + NFT_META_SKUID = 0xa + NFT_META_SKGID = 0xb + NFT_META_NFTRACE = 0xc + NFT_META_RTCLASSID = 0xd + NFT_META_SECMARK = 0xe + NFT_META_NFPROTO = 0xf + NFT_META_L4PROTO = 0x10 + NFT_META_BRI_IIFNAME = 0x11 + NFT_META_BRI_OIFNAME = 0x12 + NFT_META_PKTTYPE = 0x13 + NFT_META_CPU = 0x14 + NFT_META_IIFGROUP = 0x15 + NFT_META_OIFGROUP = 0x16 + NFT_META_CGROUP = 0x17 + NFT_META_PRANDOM = 0x18 + NFT_RT_CLASSID = 0x0 + NFT_RT_NEXTHOP4 = 0x1 + NFT_RT_NEXTHOP6 = 0x2 + NFT_RT_TCPMSS = 0x3 + NFT_HASH_JENKINS = 0x0 + NFT_HASH_SYM = 0x1 + NFTA_HASH_UNSPEC = 0x0 + NFTA_HASH_SREG = 0x1 + NFTA_HASH_DREG = 0x2 + NFTA_HASH_LEN = 0x3 + NFTA_HASH_MODULUS = 0x4 + NFTA_HASH_SEED = 0x5 + NFTA_HASH_OFFSET = 0x6 + NFTA_HASH_TYPE = 0x7 + NFTA_META_UNSPEC = 0x0 + NFTA_META_DREG = 0x1 + NFTA_META_KEY = 0x2 + NFTA_META_SREG = 0x3 + NFTA_RT_UNSPEC = 0x0 + NFTA_RT_DREG = 0x1 + NFTA_RT_KEY = 0x2 + NFT_CT_STATE = 0x0 + NFT_CT_DIRECTION = 0x1 + NFT_CT_STATUS = 0x2 + NFT_CT_MARK = 0x3 + NFT_CT_SECMARK = 0x4 + NFT_CT_EXPIRATION = 0x5 + NFT_CT_HELPER = 0x6 + NFT_CT_L3PROTOCOL = 0x7 + NFT_CT_SRC = 0x8 + NFT_CT_DST = 0x9 + NFT_CT_PROTOCOL = 0xa + NFT_CT_PROTO_SRC = 0xb + NFT_CT_PROTO_DST = 0xc + NFT_CT_LABELS = 0xd + NFT_CT_PKTS = 0xe + NFT_CT_BYTES = 0xf + NFT_CT_AVGPKT = 0x10 + NFT_CT_ZONE = 0x11 + NFT_CT_EVENTMASK = 0x12 + NFTA_CT_UNSPEC = 0x0 + NFTA_CT_DREG = 0x1 + NFTA_CT_KEY = 0x2 + NFTA_CT_DIRECTION = 0x3 + NFTA_CT_SREG = 0x4 + NFT_LIMIT_PKTS = 0x0 + NFT_LIMIT_PKT_BYTES = 0x1 + NFT_LIMIT_F_INV = 0x1 + NFTA_LIMIT_UNSPEC = 0x0 + NFTA_LIMIT_RATE = 0x1 + NFTA_LIMIT_UNIT = 0x2 + NFTA_LIMIT_BURST = 0x3 + NFTA_LIMIT_TYPE = 0x4 + NFTA_LIMIT_FLAGS = 0x5 + NFTA_LIMIT_PAD = 0x6 + NFTA_COUNTER_UNSPEC = 0x0 + NFTA_COUNTER_BYTES = 0x1 + NFTA_COUNTER_PACKETS = 0x2 + NFTA_COUNTER_PAD = 0x3 + NFTA_LOG_UNSPEC = 0x0 + NFTA_LOG_GROUP = 0x1 + NFTA_LOG_PREFIX = 0x2 + NFTA_LOG_SNAPLEN = 0x3 + NFTA_LOG_QTHRESHOLD = 0x4 + NFTA_LOG_LEVEL = 0x5 + NFTA_LOG_FLAGS = 0x6 + NFTA_QUEUE_UNSPEC = 0x0 + NFTA_QUEUE_NUM = 0x1 + NFTA_QUEUE_TOTAL = 0x2 + NFTA_QUEUE_FLAGS = 0x3 + NFTA_QUEUE_SREG_QNUM = 0x4 + NFT_QUOTA_F_INV = 0x1 + NFT_QUOTA_F_DEPLETED = 0x2 + NFTA_QUOTA_UNSPEC = 0x0 + NFTA_QUOTA_BYTES = 0x1 + NFTA_QUOTA_FLAGS = 0x2 + NFTA_QUOTA_PAD = 0x3 + NFTA_QUOTA_CONSUMED = 0x4 + NFT_REJECT_ICMP_UNREACH = 0x0 + NFT_REJECT_TCP_RST = 0x1 + NFT_REJECT_ICMPX_UNREACH = 0x2 + NFT_REJECT_ICMPX_NO_ROUTE = 0x0 + NFT_REJECT_ICMPX_PORT_UNREACH = 0x1 + NFT_REJECT_ICMPX_HOST_UNREACH = 0x2 + NFT_REJECT_ICMPX_ADMIN_PROHIBITED = 0x3 + NFTA_REJECT_UNSPEC = 0x0 + NFTA_REJECT_TYPE = 0x1 + NFTA_REJECT_ICMP_CODE = 0x2 + NFT_NAT_SNAT = 0x0 + NFT_NAT_DNAT = 0x1 + NFTA_NAT_UNSPEC = 0x0 + NFTA_NAT_TYPE = 0x1 + NFTA_NAT_FAMILY = 0x2 + NFTA_NAT_REG_ADDR_MIN = 0x3 + NFTA_NAT_REG_ADDR_MAX = 0x4 + NFTA_NAT_REG_PROTO_MIN = 0x5 + NFTA_NAT_REG_PROTO_MAX = 0x6 + NFTA_NAT_FLAGS = 0x7 + NFTA_MASQ_UNSPEC = 0x0 + NFTA_MASQ_FLAGS = 0x1 + NFTA_MASQ_REG_PROTO_MIN = 0x2 + NFTA_MASQ_REG_PROTO_MAX = 0x3 + NFTA_REDIR_UNSPEC = 0x0 + NFTA_REDIR_REG_PROTO_MIN = 0x1 + NFTA_REDIR_REG_PROTO_MAX = 0x2 + NFTA_REDIR_FLAGS = 0x3 + NFTA_DUP_UNSPEC = 0x0 + NFTA_DUP_SREG_ADDR = 0x1 + NFTA_DUP_SREG_DEV = 0x2 + NFTA_FWD_UNSPEC = 0x0 + NFTA_FWD_SREG_DEV = 0x1 + NFTA_OBJREF_UNSPEC = 0x0 + NFTA_OBJREF_IMM_TYPE = 0x1 + NFTA_OBJREF_IMM_NAME = 0x2 + NFTA_OBJREF_SET_SREG = 0x3 + NFTA_OBJREF_SET_NAME = 0x4 + NFTA_OBJREF_SET_ID = 0x5 + NFTA_GEN_UNSPEC = 0x0 + NFTA_GEN_ID = 0x1 + NFTA_GEN_PROC_PID = 0x2 + NFTA_GEN_PROC_NAME = 0x3 + NFTA_FIB_UNSPEC = 0x0 + NFTA_FIB_DREG = 0x1 + NFTA_FIB_RESULT = 0x2 + NFTA_FIB_FLAGS = 0x3 + NFT_FIB_RESULT_UNSPEC = 0x0 + NFT_FIB_RESULT_OIF = 0x1 + NFT_FIB_RESULT_OIFNAME = 0x2 + NFT_FIB_RESULT_ADDRTYPE = 0x3 + NFTA_FIB_F_SADDR = 0x1 + NFTA_FIB_F_DADDR = 0x2 + NFTA_FIB_F_MARK = 0x4 + NFTA_FIB_F_IIF = 0x8 + NFTA_FIB_F_OIF = 0x10 + NFTA_FIB_F_PRESENT = 0x20 + NFTA_CT_HELPER_UNSPEC = 0x0 + NFTA_CT_HELPER_NAME = 0x1 + NFTA_CT_HELPER_L3PROTO = 0x2 + NFTA_CT_HELPER_L4PROTO = 0x3 + NFTA_OBJ_UNSPEC = 0x0 + NFTA_OBJ_TABLE = 0x1 + NFTA_OBJ_NAME = 0x2 + NFTA_OBJ_TYPE = 0x3 + NFTA_OBJ_DATA = 0x4 + NFTA_OBJ_USE = 0x5 + NFTA_TRACE_UNSPEC = 0x0 + NFTA_TRACE_TABLE = 0x1 + NFTA_TRACE_CHAIN = 0x2 + NFTA_TRACE_RULE_HANDLE = 0x3 + NFTA_TRACE_TYPE = 0x4 + NFTA_TRACE_VERDICT = 0x5 + NFTA_TRACE_ID = 0x6 + NFTA_TRACE_LL_HEADER = 0x7 + NFTA_TRACE_NETWORK_HEADER = 0x8 + NFTA_TRACE_TRANSPORT_HEADER = 0x9 + NFTA_TRACE_IIF = 0xa + NFTA_TRACE_IIFTYPE = 0xb + NFTA_TRACE_OIF = 0xc + NFTA_TRACE_OIFTYPE = 0xd + NFTA_TRACE_MARK = 0xe + NFTA_TRACE_NFPROTO = 0xf + NFTA_TRACE_POLICY = 0x10 + NFTA_TRACE_PAD = 0x11 + NFT_TRACETYPE_UNSPEC = 0x0 + NFT_TRACETYPE_POLICY = 0x1 + NFT_TRACETYPE_RETURN = 0x2 + NFT_TRACETYPE_RULE = 0x3 + NFTA_NG_UNSPEC = 0x0 + NFTA_NG_DREG = 0x1 + NFTA_NG_MODULUS = 0x2 + NFTA_NG_TYPE = 0x3 + NFTA_NG_OFFSET = 0x4 + NFT_NG_INCREMENTAL = 0x0 + NFT_NG_RANDOM = 0x1 +) diff --git a/vendor/golang.org/x/sys/unix/ztypes_linux_sparc64.go b/vendor/golang.org/x/sys/unix/ztypes_linux_sparc64.go index 9dbbb1ce525..8e7384b89ca 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_linux_sparc64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_linux_sparc64.go @@ -376,97 +376,123 @@ const ( ) const ( - IFA_UNSPEC = 0x0 - IFA_ADDRESS = 0x1 - IFA_LOCAL = 0x2 - IFA_LABEL = 0x3 - IFA_BROADCAST = 0x4 - IFA_ANYCAST = 0x5 - IFA_CACHEINFO = 0x6 - IFA_MULTICAST = 0x7 - IFLA_UNSPEC = 0x0 - IFLA_ADDRESS = 0x1 - IFLA_BROADCAST = 0x2 - IFLA_IFNAME = 0x3 - IFLA_MTU = 0x4 - IFLA_LINK = 0x5 - IFLA_QDISC = 0x6 - IFLA_STATS = 0x7 - IFLA_COST = 0x8 - IFLA_PRIORITY = 0x9 - IFLA_MASTER = 0xa - IFLA_WIRELESS = 0xb - IFLA_PROTINFO = 0xc - IFLA_TXQLEN = 0xd - IFLA_MAP = 0xe - IFLA_WEIGHT = 0xf - IFLA_OPERSTATE = 0x10 - IFLA_LINKMODE = 0x11 - IFLA_LINKINFO = 0x12 - IFLA_NET_NS_PID = 0x13 - IFLA_IFALIAS = 0x14 - IFLA_MAX = 0x2a - RT_SCOPE_UNIVERSE = 0x0 - RT_SCOPE_SITE = 0xc8 - RT_SCOPE_LINK = 0xfd - RT_SCOPE_HOST = 0xfe - RT_SCOPE_NOWHERE = 0xff - RT_TABLE_UNSPEC = 0x0 - RT_TABLE_COMPAT = 0xfc - RT_TABLE_DEFAULT = 0xfd - RT_TABLE_MAIN = 0xfe - RT_TABLE_LOCAL = 0xff - RT_TABLE_MAX = 0xffffffff - RTA_UNSPEC = 0x0 - RTA_DST = 0x1 - RTA_SRC = 0x2 - RTA_IIF = 0x3 - RTA_OIF = 0x4 - RTA_GATEWAY = 0x5 - RTA_PRIORITY = 0x6 - RTA_PREFSRC = 0x7 - RTA_METRICS = 0x8 - RTA_MULTIPATH = 0x9 - RTA_FLOW = 0xb - RTA_CACHEINFO = 0xc - RTA_TABLE = 0xf - RTN_UNSPEC = 0x0 - RTN_UNICAST = 0x1 - RTN_LOCAL = 0x2 - RTN_BROADCAST = 0x3 - RTN_ANYCAST = 0x4 - RTN_MULTICAST = 0x5 - RTN_BLACKHOLE = 0x6 - RTN_UNREACHABLE = 0x7 - RTN_PROHIBIT = 0x8 - RTN_THROW = 0x9 - RTN_NAT = 0xa - RTN_XRESOLVE = 0xb - RTNLGRP_NONE = 0x0 - RTNLGRP_LINK = 0x1 - RTNLGRP_NOTIFY = 0x2 - RTNLGRP_NEIGH = 0x3 - RTNLGRP_TC = 0x4 - RTNLGRP_IPV4_IFADDR = 0x5 - RTNLGRP_IPV4_MROUTE = 0x6 - RTNLGRP_IPV4_ROUTE = 0x7 - RTNLGRP_IPV4_RULE = 0x8 - RTNLGRP_IPV6_IFADDR = 0x9 - RTNLGRP_IPV6_MROUTE = 0xa - RTNLGRP_IPV6_ROUTE = 0xb - RTNLGRP_IPV6_IFINFO = 0xc - RTNLGRP_IPV6_PREFIX = 0x12 - RTNLGRP_IPV6_RULE = 0x13 - RTNLGRP_ND_USEROPT = 0x14 - SizeofNlMsghdr = 0x10 - SizeofNlMsgerr = 0x14 - SizeofRtGenmsg = 0x1 - SizeofNlAttr = 0x4 - SizeofRtAttr = 0x4 - SizeofIfInfomsg = 0x10 - SizeofIfAddrmsg = 0x8 - SizeofRtMsg = 0xc - SizeofRtNexthop = 0x8 + IFA_UNSPEC = 0x0 + IFA_ADDRESS = 0x1 + IFA_LOCAL = 0x2 + IFA_LABEL = 0x3 + IFA_BROADCAST = 0x4 + IFA_ANYCAST = 0x5 + IFA_CACHEINFO = 0x6 + IFA_MULTICAST = 0x7 + IFLA_UNSPEC = 0x0 + IFLA_ADDRESS = 0x1 + IFLA_BROADCAST = 0x2 + IFLA_IFNAME = 0x3 + IFLA_MTU = 0x4 + IFLA_LINK = 0x5 + IFLA_QDISC = 0x6 + IFLA_STATS = 0x7 + IFLA_COST = 0x8 + IFLA_PRIORITY = 0x9 + IFLA_MASTER = 0xa + IFLA_WIRELESS = 0xb + IFLA_PROTINFO = 0xc + IFLA_TXQLEN = 0xd + IFLA_MAP = 0xe + IFLA_WEIGHT = 0xf + IFLA_OPERSTATE = 0x10 + IFLA_LINKMODE = 0x11 + IFLA_LINKINFO = 0x12 + IFLA_NET_NS_PID = 0x13 + IFLA_IFALIAS = 0x14 + IFLA_NUM_VF = 0x15 + IFLA_VFINFO_LIST = 0x16 + IFLA_STATS64 = 0x17 + IFLA_VF_PORTS = 0x18 + IFLA_PORT_SELF = 0x19 + IFLA_AF_SPEC = 0x1a + IFLA_GROUP = 0x1b + IFLA_NET_NS_FD = 0x1c + IFLA_EXT_MASK = 0x1d + IFLA_PROMISCUITY = 0x1e + IFLA_NUM_TX_QUEUES = 0x1f + IFLA_NUM_RX_QUEUES = 0x20 + IFLA_CARRIER = 0x21 + IFLA_PHYS_PORT_ID = 0x22 + IFLA_CARRIER_CHANGES = 0x23 + IFLA_PHYS_SWITCH_ID = 0x24 + IFLA_LINK_NETNSID = 0x25 + IFLA_PHYS_PORT_NAME = 0x26 + IFLA_PROTO_DOWN = 0x27 + IFLA_GSO_MAX_SEGS = 0x28 + IFLA_GSO_MAX_SIZE = 0x29 + IFLA_PAD = 0x2a + IFLA_XDP = 0x2b + IFLA_EVENT = 0x2c + IFLA_NEW_NETNSID = 0x2d + IFLA_IF_NETNSID = 0x2e + IFLA_MAX = 0x2e + RT_SCOPE_UNIVERSE = 0x0 + RT_SCOPE_SITE = 0xc8 + RT_SCOPE_LINK = 0xfd + RT_SCOPE_HOST = 0xfe + RT_SCOPE_NOWHERE = 0xff + RT_TABLE_UNSPEC = 0x0 + RT_TABLE_COMPAT = 0xfc + RT_TABLE_DEFAULT = 0xfd + RT_TABLE_MAIN = 0xfe + RT_TABLE_LOCAL = 0xff + RT_TABLE_MAX = 0xffffffff + RTA_UNSPEC = 0x0 + RTA_DST = 0x1 + RTA_SRC = 0x2 + RTA_IIF = 0x3 + RTA_OIF = 0x4 + RTA_GATEWAY = 0x5 + RTA_PRIORITY = 0x6 + RTA_PREFSRC = 0x7 + RTA_METRICS = 0x8 + RTA_MULTIPATH = 0x9 + RTA_FLOW = 0xb + RTA_CACHEINFO = 0xc + RTA_TABLE = 0xf + RTN_UNSPEC = 0x0 + RTN_UNICAST = 0x1 + RTN_LOCAL = 0x2 + RTN_BROADCAST = 0x3 + RTN_ANYCAST = 0x4 + RTN_MULTICAST = 0x5 + RTN_BLACKHOLE = 0x6 + RTN_UNREACHABLE = 0x7 + RTN_PROHIBIT = 0x8 + RTN_THROW = 0x9 + RTN_NAT = 0xa + RTN_XRESOLVE = 0xb + RTNLGRP_NONE = 0x0 + RTNLGRP_LINK = 0x1 + RTNLGRP_NOTIFY = 0x2 + RTNLGRP_NEIGH = 0x3 + RTNLGRP_TC = 0x4 + RTNLGRP_IPV4_IFADDR = 0x5 + RTNLGRP_IPV4_MROUTE = 0x6 + RTNLGRP_IPV4_ROUTE = 0x7 + RTNLGRP_IPV4_RULE = 0x8 + RTNLGRP_IPV6_IFADDR = 0x9 + RTNLGRP_IPV6_MROUTE = 0xa + RTNLGRP_IPV6_ROUTE = 0xb + RTNLGRP_IPV6_IFINFO = 0xc + RTNLGRP_IPV6_PREFIX = 0x12 + RTNLGRP_IPV6_RULE = 0x13 + RTNLGRP_ND_USEROPT = 0x14 + SizeofNlMsghdr = 0x10 + SizeofNlMsgerr = 0x14 + SizeofRtGenmsg = 0x1 + SizeofNlAttr = 0x4 + SizeofRtAttr = 0x4 + SizeofIfInfomsg = 0x10 + SizeofIfAddrmsg = 0x8 + SizeofRtMsg = 0xc + SizeofRtNexthop = 0x8 ) type NlMsghdr struct { diff --git a/vendor/golang.org/x/sys/unix/ztypes_netbsd_386.go b/vendor/golang.org/x/sys/unix/ztypes_netbsd_386.go index da70faa82d3..4b86fb2b332 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_netbsd_386.go +++ b/vendor/golang.org/x/sys/unix/ztypes_netbsd_386.go @@ -103,6 +103,15 @@ const ( PathMax = 0x400 ) +const ( + FADV_NORMAL = 0x0 + FADV_RANDOM = 0x1 + FADV_SEQUENTIAL = 0x2 + FADV_WILLNEED = 0x3 + FADV_DONTNEED = 0x4 + FADV_NOREUSE = 0x5 +) + type RawSockaddrInet4 struct { Len uint8 Family uint8 diff --git a/vendor/golang.org/x/sys/unix/ztypes_netbsd_amd64.go b/vendor/golang.org/x/sys/unix/ztypes_netbsd_amd64.go index 0963ab8c436..9048a509d08 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_netbsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_netbsd_amd64.go @@ -107,6 +107,15 @@ const ( PathMax = 0x400 ) +const ( + FADV_NORMAL = 0x0 + FADV_RANDOM = 0x1 + FADV_SEQUENTIAL = 0x2 + FADV_WILLNEED = 0x3 + FADV_DONTNEED = 0x4 + FADV_NOREUSE = 0x5 +) + type RawSockaddrInet4 struct { Len uint8 Family uint8 diff --git a/vendor/golang.org/x/sys/unix/ztypes_netbsd_arm.go b/vendor/golang.org/x/sys/unix/ztypes_netbsd_arm.go index 211f6419344..00525e7b029 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_netbsd_arm.go +++ b/vendor/golang.org/x/sys/unix/ztypes_netbsd_arm.go @@ -108,6 +108,15 @@ const ( PathMax = 0x400 ) +const ( + FADV_NORMAL = 0x0 + FADV_RANDOM = 0x1 + FADV_SEQUENTIAL = 0x2 + FADV_WILLNEED = 0x3 + FADV_DONTNEED = 0x4 + FADV_NOREUSE = 0x5 +) + type RawSockaddrInet4 struct { Len uint8 Family uint8 diff --git a/vendor/golang.org/x/sys/unix/ztypes_openbsd_amd64.go b/vendor/golang.org/x/sys/unix/ztypes_openbsd_amd64.go index d53141085ac..5a9c8184859 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_openbsd_amd64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_openbsd_amd64.go @@ -74,30 +74,30 @@ const ( ) type Stat_t struct { - Mode uint32 - Dev int32 - Ino uint64 - Nlink uint32 - Uid uint32 - Gid uint32 - Rdev int32 - Atim Timespec - Mtim Timespec - Ctim Timespec - Size int64 - Blocks int64 - Blksize uint32 - Flags uint32 - Gen uint32 - Pad_cgo_0 [4]byte - X__st_birthtim Timespec + Mode uint32 + Dev int32 + Ino uint64 + Nlink uint32 + Uid uint32 + Gid uint32 + Rdev int32 + Atim Timespec + Mtim Timespec + Ctim Timespec + Size int64 + Blocks int64 + Blksize int32 + Flags uint32 + Gen uint32 + _ [4]byte + _ Timespec } type Statfs_t struct { F_flags uint32 F_bsize uint32 F_iosize uint32 - Pad_cgo_0 [4]byte + _ [4]byte F_blocks uint64 F_bfree uint64 F_bavail int64 @@ -116,7 +116,7 @@ type Statfs_t struct { F_mntonname [90]int8 F_mntfromname [90]int8 F_mntfromspec [90]int8 - Pad_cgo_1 [2]byte + _ [2]byte Mount_info [160]byte } @@ -129,13 +129,13 @@ type Flock_t struct { } type Dirent struct { - Fileno uint64 - Off int64 - Reclen uint16 - Type uint8 - Namlen uint8 - X__d_padding [4]uint8 - Name [256]int8 + Fileno uint64 + Off int64 + Reclen uint16 + Type uint8 + Namlen uint8 + _ [4]uint8 + Name [256]int8 } type Fsid struct { @@ -216,10 +216,10 @@ type IPv6Mreq struct { type Msghdr struct { Name *byte Namelen uint32 - Pad_cgo_0 [4]byte + _ [4]byte Iov *Iovec Iovlen uint32 - Pad_cgo_1 [4]byte + _ [4]byte Control *byte Controllen uint32 Flags int32 @@ -281,8 +281,8 @@ type FdSet struct { } const ( - SizeofIfMsghdr = 0xf8 - SizeofIfData = 0xe0 + SizeofIfMsghdr = 0xa8 + SizeofIfData = 0x90 SizeofIfaMsghdr = 0x18 SizeofIfAnnounceMsghdr = 0x1a SizeofRtMsghdr = 0x60 @@ -311,7 +311,7 @@ type IfData struct { Link_state uint8 Mtu uint32 Metric uint32 - Pad uint32 + Rdomain uint32 Baudrate uint64 Ipackets uint64 Ierrors uint64 @@ -323,12 +323,11 @@ type IfData struct { Imcasts uint64 Omcasts uint64 Iqdrops uint64 + Oqdrops uint64 Noproto uint64 Capabilities uint32 - Pad_cgo_0 [4]byte + _ [4]byte Lastchange Timeval - Mclpool [7]Mclpool - Pad_cgo_1 [4]byte } type IfaMsghdr struct { @@ -389,13 +388,7 @@ type RtMetrics struct { Pad uint32 } -type Mclpool struct { - Grown int32 - Alive uint16 - Hwm uint16 - Cwm uint16 - Lwm uint16 -} +type Mclpool struct{} const ( SizeofBpfVersion = 0x4 @@ -416,9 +409,9 @@ type BpfStat struct { } type BpfProgram struct { - Len uint32 - Pad_cgo_0 [4]byte - Insns *BpfInsn + Len uint32 + _ [4]byte + Insns *BpfInsn } type BpfInsn struct { @@ -429,11 +422,11 @@ type BpfInsn struct { } type BpfHdr struct { - Tstamp BpfTimeval - Caplen uint32 - Datalen uint32 - Hdrlen uint16 - Pad_cgo_0 [2]byte + Tstamp BpfTimeval + Caplen uint32 + Datalen uint32 + Hdrlen uint16 + _ [2]byte } type BpfTimeval struct { diff --git a/vendor/golang.org/x/sys/unix/ztypes_solaris_amd64.go b/vendor/golang.org/x/sys/unix/ztypes_solaris_amd64.go index d4454524867..2248598d03f 100644 --- a/vendor/golang.org/x/sys/unix/ztypes_solaris_amd64.go +++ b/vendor/golang.org/x/sys/unix/ztypes_solaris_amd64.go @@ -93,40 +93,40 @@ const ( ) type Stat_t struct { - Dev uint64 - Ino uint64 - Mode uint32 - Nlink uint32 - Uid uint32 - Gid uint32 - Rdev uint64 - Size int64 - Atim Timespec - Mtim Timespec - Ctim Timespec - Blksize int32 - Pad_cgo_0 [4]byte - Blocks int64 - Fstype [16]int8 + Dev uint64 + Ino uint64 + Mode uint32 + Nlink uint32 + Uid uint32 + Gid uint32 + Rdev uint64 + Size int64 + Atim Timespec + Mtim Timespec + Ctim Timespec + Blksize int32 + _ [4]byte + Blocks int64 + Fstype [16]int8 } type Flock_t struct { - Type int16 - Whence int16 - Pad_cgo_0 [4]byte - Start int64 - Len int64 - Sysid int32 - Pid int32 - Pad [4]int64 + Type int16 + Whence int16 + _ [4]byte + Start int64 + Len int64 + Sysid int32 + Pid int32 + Pad [4]int64 } type Dirent struct { - Ino uint64 - Off int64 - Reclen uint16 - Name [1]int8 - Pad_cgo_0 [5]byte + Ino uint64 + Off int64 + Reclen uint16 + Name [1]int8 + _ [5]byte } type _Fsblkcnt_t uint64 @@ -213,13 +213,13 @@ type IPv6Mreq struct { type Msghdr struct { Name *byte Namelen uint32 - Pad_cgo_0 [4]byte + _ [4]byte Iov *Iovec Iovlen int32 - Pad_cgo_1 [4]byte + _ [4]byte Accrights *int8 Accrightslen int32 - Pad_cgo_2 [4]byte + _ [4]byte } type Cmsghdr struct { @@ -271,11 +271,11 @@ type Utsname struct { } type Ustat_t struct { - Tfree int64 - Tinode uint64 - Fname [6]int8 - Fpack [6]int8 - Pad_cgo_0 [4]byte + Tfree int64 + Tinode uint64 + Fname [6]int8 + Fpack [6]int8 + _ [4]byte } const ( @@ -295,21 +295,21 @@ const ( ) type IfMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Data IfData + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Data IfData } type IfData struct { Type uint8 Addrlen uint8 Hdrlen uint8 - Pad_cgo_0 [1]byte + _ [1]byte Mtu uint32 Metric uint32 Baudrate uint32 @@ -328,30 +328,30 @@ type IfData struct { } type IfaMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Addrs int32 - Flags int32 - Index uint16 - Pad_cgo_0 [2]byte - Metric int32 + Msglen uint16 + Version uint8 + Type uint8 + Addrs int32 + Flags int32 + Index uint16 + _ [2]byte + Metric int32 } type RtMsghdr struct { - Msglen uint16 - Version uint8 - Type uint8 - Index uint16 - Pad_cgo_0 [2]byte - Flags int32 - Addrs int32 - Pid int32 - Seq int32 - Errno int32 - Use int32 - Inits uint32 - Rmx RtMetrics + Msglen uint16 + Version uint8 + Type uint8 + Index uint16 + _ [2]byte + Flags int32 + Addrs int32 + Pid int32 + Seq int32 + Errno int32 + Use int32 + Inits uint32 + Rmx RtMetrics } type RtMetrics struct { @@ -388,9 +388,9 @@ type BpfStat struct { } type BpfProgram struct { - Len uint32 - Pad_cgo_0 [4]byte - Insns *BpfInsn + Len uint32 + _ [4]byte + Insns *BpfInsn } type BpfInsn struct { @@ -406,30 +406,30 @@ type BpfTimeval struct { } type BpfHdr struct { - Tstamp BpfTimeval - Caplen uint32 - Datalen uint32 - Hdrlen uint16 - Pad_cgo_0 [2]byte + Tstamp BpfTimeval + Caplen uint32 + Datalen uint32 + Hdrlen uint16 + _ [2]byte } type Termios struct { - Iflag uint32 - Oflag uint32 - Cflag uint32 - Lflag uint32 - Cc [19]uint8 - Pad_cgo_0 [1]byte + Iflag uint32 + Oflag uint32 + Cflag uint32 + Lflag uint32 + Cc [19]uint8 + _ [1]byte } type Termio struct { - Iflag uint16 - Oflag uint16 - Cflag uint16 - Lflag uint16 - Line int8 - Cc [8]uint8 - Pad_cgo_0 [1]byte + Iflag uint16 + Oflag uint16 + Cflag uint16 + Lflag uint16 + Line int8 + Cc [8]uint8 + _ [1]byte } type Winsize struct { diff --git a/vendor/golang.org/x/sys/windows/asm_windows_386.s b/vendor/golang.org/x/sys/windows/asm_windows_386.s index 1c20dd2f897..21d994d318a 100644 --- a/vendor/golang.org/x/sys/windows/asm_windows_386.s +++ b/vendor/golang.org/x/sys/windows/asm_windows_386.s @@ -6,8 +6,8 @@ // System calls for 386, Windows are implemented in runtime/syscall_windows.goc // -TEXT ·getprocaddress(SB), 7, $0-8 +TEXT ·getprocaddress(SB), 7, $0-16 JMP syscall·getprocaddress(SB) -TEXT ·loadlibrary(SB), 7, $0-4 +TEXT ·loadlibrary(SB), 7, $0-12 JMP syscall·loadlibrary(SB) diff --git a/vendor/golang.org/x/sys/windows/asm_windows_amd64.s b/vendor/golang.org/x/sys/windows/asm_windows_amd64.s index 4d025ab556d..5bfdf797414 100644 --- a/vendor/golang.org/x/sys/windows/asm_windows_amd64.s +++ b/vendor/golang.org/x/sys/windows/asm_windows_amd64.s @@ -9,5 +9,5 @@ TEXT ·getprocaddress(SB), 7, $0-32 JMP syscall·getprocaddress(SB) -TEXT ·loadlibrary(SB), 7, $0-8 +TEXT ·loadlibrary(SB), 7, $0-24 JMP syscall·loadlibrary(SB) diff --git a/vendor/golang.org/x/sys/windows/service.go b/vendor/golang.org/x/sys/windows/service.go index a500dd7dfcf..24aa90bbbe1 100644 --- a/vendor/golang.org/x/sys/windows/service.go +++ b/vendor/golang.org/x/sys/windows/service.go @@ -162,3 +162,4 @@ type ENUM_SERVICE_STATUS_PROCESS struct { //sys ChangeServiceConfig2(service Handle, infoLevel uint32, info *byte) (err error) = advapi32.ChangeServiceConfig2W //sys QueryServiceConfig2(service Handle, infoLevel uint32, buff *byte, buffSize uint32, bytesNeeded *uint32) (err error) = advapi32.QueryServiceConfig2W //sys EnumServicesStatusEx(mgr Handle, infoLevel uint32, serviceType uint32, serviceState uint32, services *byte, bufSize uint32, bytesNeeded *uint32, servicesReturned *uint32, resumeHandle *uint32, groupName *uint16) (err error) = advapi32.EnumServicesStatusExW +//sys QueryServiceStatusEx(service Handle, infoLevel uint32, buff *byte, buffSize uint32, bytesNeeded *uint32) (err error) = advapi32.QueryServiceStatusEx diff --git a/vendor/golang.org/x/sys/windows/syscall.go b/vendor/golang.org/x/sys/windows/syscall.go index b07bc2305d3..af828a91bcf 100644 --- a/vendor/golang.org/x/sys/windows/syscall.go +++ b/vendor/golang.org/x/sys/windows/syscall.go @@ -11,11 +11,14 @@ // system, set $GOOS and $GOARCH to the desired system. For example, if // you want to view documentation for freebsd/arm on linux/amd64, set $GOOS // to freebsd and $GOARCH to arm. +// // The primary use of this package is inside other packages that provide a more // portable interface to the system, such as "os", "time" and "net". Use // those packages rather than this one if you can. +// // For details of the functions and data types in this package consult // the manuals for the appropriate operating system. +// // These calls return err == nil to indicate success; otherwise // err represents an operating system error describing the failure and // holds a value of type syscall.Errno. diff --git a/vendor/golang.org/x/sys/windows/zsyscall_windows.go b/vendor/golang.org/x/sys/windows/zsyscall_windows.go index c7b3b15eadb..318c61634e1 100644 --- a/vendor/golang.org/x/sys/windows/zsyscall_windows.go +++ b/vendor/golang.org/x/sys/windows/zsyscall_windows.go @@ -65,6 +65,7 @@ var ( procChangeServiceConfig2W = modadvapi32.NewProc("ChangeServiceConfig2W") procQueryServiceConfig2W = modadvapi32.NewProc("QueryServiceConfig2W") procEnumServicesStatusExW = modadvapi32.NewProc("EnumServicesStatusExW") + procQueryServiceStatusEx = modadvapi32.NewProc("QueryServiceStatusEx") procGetLastError = modkernel32.NewProc("GetLastError") procLoadLibraryW = modkernel32.NewProc("LoadLibraryW") procLoadLibraryExW = modkernel32.NewProc("LoadLibraryExW") @@ -472,6 +473,18 @@ func EnumServicesStatusEx(mgr Handle, infoLevel uint32, serviceType uint32, serv return } +func QueryServiceStatusEx(service Handle, infoLevel uint32, buff *byte, buffSize uint32, bytesNeeded *uint32) (err error) { + r1, _, e1 := syscall.Syscall6(procQueryServiceStatusEx.Addr(), 5, uintptr(service), uintptr(infoLevel), uintptr(unsafe.Pointer(buff)), uintptr(buffSize), uintptr(unsafe.Pointer(bytesNeeded)), 0) + if r1 == 0 { + if e1 != 0 { + err = errnoErr(e1) + } else { + err = syscall.EINVAL + } + } + return +} + func GetLastError() (lasterr error) { r0, _, _ := syscall.Syscall(procGetLastError.Addr(), 0, 0, 0, 0) if r0 != 0 { diff --git a/vendor/google.golang.org/genproto/LICENSE b/vendor/google.golang.org/genproto/LICENSE new file mode 100644 index 00000000000..d6456956733 --- /dev/null +++ b/vendor/google.golang.org/genproto/LICENSE @@ -0,0 +1,202 @@ + + 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/google.golang.org/genproto/googleapis/rpc/status/status.pb.go b/vendor/google.golang.org/genproto/googleapis/rpc/status/status.pb.go new file mode 100644 index 00000000000..fb104e6dfb8 --- /dev/null +++ b/vendor/google.golang.org/genproto/googleapis/rpc/status/status.pb.go @@ -0,0 +1,156 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: google/rpc/status.proto + +package status // import "google.golang.org/genproto/googleapis/rpc/status" + +import proto "github.com/golang/protobuf/proto" +import fmt "fmt" +import math "math" +import any "github.com/golang/protobuf/ptypes/any" + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package + +// The `Status` type defines a logical error model that is suitable for different +// programming environments, including REST APIs and RPC APIs. It is used by +// [gRPC](https://github.com/grpc). The error model is designed to be: +// +// - Simple to use and understand for most users +// - Flexible enough to meet unexpected needs +// +// # Overview +// +// The `Status` message contains three pieces of data: error code, error message, +// and error details. The error code should be an enum value of +// [google.rpc.Code][google.rpc.Code], but it may accept additional error codes if needed. The +// error message should be a developer-facing English message that helps +// developers *understand* and *resolve* the error. If a localized user-facing +// error message is needed, put the localized message in the error details or +// localize it in the client. The optional error details may contain arbitrary +// information about the error. There is a predefined set of error detail types +// in the package `google.rpc` that can be used for common error conditions. +// +// # Language mapping +// +// The `Status` message is the logical representation of the error model, but it +// is not necessarily the actual wire format. When the `Status` message is +// exposed in different client libraries and different wire protocols, it can be +// mapped differently. For example, it will likely be mapped to some exceptions +// in Java, but more likely mapped to some error codes in C. +// +// # Other uses +// +// The error model and the `Status` message can be used in a variety of +// environments, either with or without APIs, to provide a +// consistent developer experience across different environments. +// +// Example uses of this error model include: +// +// - Partial errors. If a service needs to return partial errors to the client, +// it may embed the `Status` in the normal response to indicate the partial +// errors. +// +// - Workflow errors. A typical workflow has multiple steps. Each step may +// have a `Status` message for error reporting. +// +// - Batch operations. If a client uses batch request and batch response, the +// `Status` message should be used directly inside batch response, one for +// each error sub-response. +// +// - Asynchronous operations. If an API call embeds asynchronous operation +// results in its response, the status of those operations should be +// represented directly using the `Status` message. +// +// - Logging. If some API errors are stored in logs, the message `Status` could +// be used directly after any stripping needed for security/privacy reasons. +type Status struct { + // The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. + Code int32 `protobuf:"varint,1,opt,name=code" json:"code,omitempty"` + // A developer-facing error message, which should be in English. Any + // user-facing error message should be localized and sent in the + // [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client. + Message string `protobuf:"bytes,2,opt,name=message" json:"message,omitempty"` + // A list of messages that carry the error details. There is a common set of + // message types for APIs to use. + Details []*any.Any `protobuf:"bytes,3,rep,name=details" json:"details,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *Status) Reset() { *m = Status{} } +func (m *Status) String() string { return proto.CompactTextString(m) } +func (*Status) ProtoMessage() {} +func (*Status) Descriptor() ([]byte, []int) { + return fileDescriptor_status_c656c685916bdf47, []int{0} +} +func (m *Status) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_Status.Unmarshal(m, b) +} +func (m *Status) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_Status.Marshal(b, m, deterministic) +} +func (dst *Status) XXX_Merge(src proto.Message) { + xxx_messageInfo_Status.Merge(dst, src) +} +func (m *Status) XXX_Size() int { + return xxx_messageInfo_Status.Size(m) +} +func (m *Status) XXX_DiscardUnknown() { + xxx_messageInfo_Status.DiscardUnknown(m) +} + +var xxx_messageInfo_Status proto.InternalMessageInfo + +func (m *Status) GetCode() int32 { + if m != nil { + return m.Code + } + return 0 +} + +func (m *Status) GetMessage() string { + if m != nil { + return m.Message + } + return "" +} + +func (m *Status) GetDetails() []*any.Any { + if m != nil { + return m.Details + } + return nil +} + +func init() { + proto.RegisterType((*Status)(nil), "google.rpc.Status") +} + +func init() { proto.RegisterFile("google/rpc/status.proto", fileDescriptor_status_c656c685916bdf47) } + +var fileDescriptor_status_c656c685916bdf47 = []byte{ + // 209 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x12, 0x4f, 0xcf, 0xcf, 0x4f, + 0xcf, 0x49, 0xd5, 0x2f, 0x2a, 0x48, 0xd6, 0x2f, 0x2e, 0x49, 0x2c, 0x29, 0x2d, 0xd6, 0x2b, 0x28, + 0xca, 0x2f, 0xc9, 0x17, 0xe2, 0x82, 0x48, 0xe8, 0x15, 0x15, 0x24, 0x4b, 0x49, 0x42, 0x15, 0x81, + 0x65, 0x92, 0x4a, 0xd3, 0xf4, 0x13, 0xf3, 0x2a, 0x21, 0xca, 0x94, 0xd2, 0xb8, 0xd8, 0x82, 0xc1, + 0xda, 0x84, 0x84, 0xb8, 0x58, 0x92, 0xf3, 0x53, 0x52, 0x25, 0x18, 0x15, 0x18, 0x35, 0x58, 0x83, + 0xc0, 0x6c, 0x21, 0x09, 0x2e, 0xf6, 0xdc, 0xd4, 0xe2, 0xe2, 0xc4, 0xf4, 0x54, 0x09, 0x26, 0x05, + 0x46, 0x0d, 0xce, 0x20, 0x18, 0x57, 0x48, 0x8f, 0x8b, 0x3d, 0x25, 0xb5, 0x24, 0x31, 0x33, 0xa7, + 0x58, 0x82, 0x59, 0x81, 0x59, 0x83, 0xdb, 0x48, 0x44, 0x0f, 0x6a, 0x21, 0xcc, 0x12, 0x3d, 0xc7, + 0xbc, 0xca, 0x20, 0x98, 0x22, 0xa7, 0x38, 0x2e, 0xbe, 0xe4, 0xfc, 0x5c, 0x3d, 0x84, 0xa3, 0x9c, + 0xb8, 0x21, 0xf6, 0x06, 0x80, 0x94, 0x07, 0x30, 0x46, 0x99, 0x43, 0xa5, 0xd2, 0xf3, 0x73, 0x12, + 0xf3, 0xd2, 0xf5, 0xf2, 0x8b, 0xd2, 0xf5, 0xd3, 0x53, 0xf3, 0xc0, 0x86, 0xe9, 0x43, 0xa4, 0x12, + 0x0b, 0x32, 0x8b, 0x91, 0xfc, 0x69, 0x0d, 0xa1, 0x16, 0x31, 0x31, 0x07, 0x05, 0x38, 0x27, 0xb1, + 0x81, 0x55, 0x1a, 0x03, 0x02, 0x00, 0x00, 0xff, 0xff, 0xa4, 0x53, 0xf0, 0x7c, 0x10, 0x01, 0x00, + 0x00, +} diff --git a/vendor/google.golang.org/grpc/.travis.yml b/vendor/google.golang.org/grpc/.travis.yml new file mode 100644 index 00000000000..3c2621ab750 --- /dev/null +++ b/vendor/google.golang.org/grpc/.travis.yml @@ -0,0 +1,24 @@ +language: go + +go: + - 1.6.x + - 1.7.x + - 1.8.x + - 1.9.x + - 1.10.x + +matrix: + include: + - go: 1.10.x + env: RUN386=1 + +go_import_path: google.golang.org/grpc + +before_install: + - if [[ -n "$RUN386" ]]; then export GOARCH=386; fi + - if [[ "$TRAVIS_GO_VERSION" = 1.10* && "$GOARCH" != "386" ]]; then ./vet.sh -install || exit 1; fi + +script: + - if [[ "$TRAVIS_GO_VERSION" = 1.10* && "$GOARCH" != "386" ]]; then ./vet.sh || exit 1; fi + - make test || exit 1 + - if [[ "$GOARCH" != "386" ]]; then make testrace; fi diff --git a/vendor/google.golang.org/grpc/AUTHORS b/vendor/google.golang.org/grpc/AUTHORS new file mode 100644 index 00000000000..e491a9e7f78 --- /dev/null +++ b/vendor/google.golang.org/grpc/AUTHORS @@ -0,0 +1 @@ +Google Inc. diff --git a/vendor/google.golang.org/grpc/CONTRIBUTING.md b/vendor/google.golang.org/grpc/CONTRIBUTING.md new file mode 100644 index 00000000000..0863eb26b60 --- /dev/null +++ b/vendor/google.golang.org/grpc/CONTRIBUTING.md @@ -0,0 +1,36 @@ +# How to contribute + +We definitely welcome your patches and contributions to gRPC! + +If you are new to github, please start by reading [Pull Request howto](https://help.github.com/articles/about-pull-requests/) + +## Legal requirements + +In order to protect both you and ourselves, you will need to sign the +[Contributor License Agreement](https://identity.linuxfoundation.org/projects/cncf). + +## Guidelines for Pull Requests +How to get your contributions merged smoothly and quickly. + +- Create **small PRs** that are narrowly focused on **addressing a single concern**. We often times receive PRs that are trying to fix several things at a time, but only one fix is considered acceptable, nothing gets merged and both author's & review's time is wasted. Create more PRs to address different concerns and everyone will be happy. + +- For speculative changes, consider opening an issue and discussing it first. If you are suggesting a behavioral or API change, consider starting with a [gRFC proposal](https://github.com/grpc/proposal). + +- Provide a good **PR description** as a record of **what** change is being made and **why** it was made. Link to a github issue if it exists. + +- Don't fix code style and formatting unless you are already changing that line to address an issue. PRs with irrelevant changes won't be merged. If you do want to fix formatting or style, do that in a separate PR. + +- Unless your PR is trivial, you should expect there will be reviewer comments that you'll need to address before merging. We expect you to be reasonably responsive to those comments, otherwise the PR will be closed after 2-3 weeks of inactivity. + +- Maintain **clean commit history** and use **meaningful commit messages**. PRs with messy commit history are difficult to review and won't be merged. Use `rebase -i upstream/master` to curate your commit history and/or to bring in latest changes from master (but avoid rebasing in the middle of a code review). + +- Keep your PR up to date with upstream/master (if there are merge conflicts, we can't really merge your change). + +- **All tests need to be passing** before your change can be merged. We recommend you **run tests locally** before creating your PR to catch breakages early on. + - `make all` to test everything, OR + - `make vet` to catch vet errors + - `make test` to run the tests + - `make testrace` to run tests in race mode + +- Exceptions to the rules can be made if there's a compelling reason for doing so. + diff --git a/vendor/google.golang.org/grpc/LICENSE b/vendor/google.golang.org/grpc/LICENSE new file mode 100644 index 00000000000..d6456956733 --- /dev/null +++ b/vendor/google.golang.org/grpc/LICENSE @@ -0,0 +1,202 @@ + + 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/google.golang.org/grpc/Makefile b/vendor/google.golang.org/grpc/Makefile new file mode 100644 index 00000000000..6f393a808df --- /dev/null +++ b/vendor/google.golang.org/grpc/Makefile @@ -0,0 +1,48 @@ +all: vet test testrace + +deps: + go get -d -v google.golang.org/grpc/... + +updatedeps: + go get -d -v -u -f google.golang.org/grpc/... + +testdeps: + go get -d -v -t google.golang.org/grpc/... + +updatetestdeps: + go get -d -v -t -u -f google.golang.org/grpc/... + +build: deps + go build google.golang.org/grpc/... + +proto: + @ if ! which protoc > /dev/null; then \ + echo "error: protoc not installed" >&2; \ + exit 1; \ + fi + go generate google.golang.org/grpc/... + +vet: + ./vet.sh + +test: testdeps + go test -cpu 1,4 -timeout 5m google.golang.org/grpc/... + +testrace: testdeps + go test -race -cpu 1,4 -timeout 7m google.golang.org/grpc/... + +clean: + go clean -i google.golang.org/grpc/... + +.PHONY: \ + all \ + deps \ + updatedeps \ + testdeps \ + updatetestdeps \ + build \ + proto \ + vet \ + test \ + testrace \ + clean diff --git a/vendor/google.golang.org/grpc/README.md b/vendor/google.golang.org/grpc/README.md new file mode 100644 index 00000000000..789adfd6536 --- /dev/null +++ b/vendor/google.golang.org/grpc/README.md @@ -0,0 +1,45 @@ +# gRPC-Go + +[![Build Status](https://travis-ci.org/grpc/grpc-go.svg)](https://travis-ci.org/grpc/grpc-go) [![GoDoc](https://godoc.org/google.golang.org/grpc?status.svg)](https://godoc.org/google.golang.org/grpc) [![GoReportCard](https://goreportcard.com/badge/grpc/grpc-go)](https://goreportcard.com/report/github.com/grpc/grpc-go) + +The Go implementation of [gRPC](https://grpc.io/): A high performance, open source, general RPC framework that puts mobile and HTTP/2 first. For more information see the [gRPC Quick Start: Go](https://grpc.io/docs/quickstart/go.html) guide. + +Installation +------------ + +To install this package, you need to install Go and setup your Go workspace on your computer. The simplest way to install the library is to run: + +``` +$ go get -u google.golang.org/grpc +``` + +Prerequisites +------------- + +This requires Go 1.6 or later. Go 1.7 will be required soon. + +Constraints +----------- +The grpc package should only depend on standard Go packages and a small number of exceptions. If your contribution introduces new dependencies which are NOT in the [list](http://godoc.org/google.golang.org/grpc?imports), you need a discussion with gRPC-Go authors and consultants. + +Documentation +------------- +See [API documentation](https://godoc.org/google.golang.org/grpc) for package and API descriptions and find examples in the [examples directory](examples/). + +Performance +----------- +See the current benchmarks for some of the languages supported in [this dashboard](https://performance-dot-grpc-testing.appspot.com/explore?dashboard=5652536396611584&widget=490377658&container=1286539696). + +Status +------ +General Availability [Google Cloud Platform Launch Stages](https://cloud.google.com/terms/launch-stages). + +FAQ +--- + +#### Compiling error, undefined: grpc.SupportPackageIsVersion + +Please update proto package, gRPC package and rebuild the proto files: + - `go get -u github.com/golang/protobuf/{proto,protoc-gen-go}` + - `go get -u google.golang.org/grpc` + - `protoc --go_out=plugins=grpc:. *.proto` diff --git a/vendor/google.golang.org/grpc/backoff.go b/vendor/google.golang.org/grpc/backoff.go new file mode 100644 index 00000000000..c40facce510 --- /dev/null +++ b/vendor/google.golang.org/grpc/backoff.go @@ -0,0 +1,96 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "math/rand" + "time" +) + +// DefaultBackoffConfig uses values specified for backoff in +// https://github.com/grpc/grpc/blob/master/doc/connection-backoff.md. +var DefaultBackoffConfig = BackoffConfig{ + MaxDelay: 120 * time.Second, + baseDelay: 1.0 * time.Second, + factor: 1.6, + jitter: 0.2, +} + +// backoffStrategy defines the methodology for backing off after a grpc +// connection failure. +// +// This is unexported until the gRPC project decides whether or not to allow +// alternative backoff strategies. Once a decision is made, this type and its +// method may be exported. +type backoffStrategy interface { + // backoff returns the amount of time to wait before the next retry given + // the number of consecutive failures. + backoff(retries int) time.Duration +} + +// BackoffConfig defines the parameters for the default gRPC backoff strategy. +type BackoffConfig struct { + // MaxDelay is the upper bound of backoff delay. + MaxDelay time.Duration + + // TODO(stevvooe): The following fields are not exported, as allowing + // changes would violate the current gRPC specification for backoff. If + // gRPC decides to allow more interesting backoff strategies, these fields + // may be opened up in the future. + + // baseDelay is the amount of time to wait before retrying after the first + // failure. + baseDelay time.Duration + + // factor is applied to the backoff after each retry. + factor float64 + + // jitter provides a range to randomize backoff delays. + jitter float64 +} + +func setDefaults(bc *BackoffConfig) { + md := bc.MaxDelay + *bc = DefaultBackoffConfig + + if md > 0 { + bc.MaxDelay = md + } +} + +func (bc BackoffConfig) backoff(retries int) time.Duration { + if retries == 0 { + return bc.baseDelay + } + backoff, max := float64(bc.baseDelay), float64(bc.MaxDelay) + for backoff < max && retries > 0 { + backoff *= bc.factor + retries-- + } + if backoff > max { + backoff = max + } + // Randomize backoff delays so that if a cluster of requests start at + // the same time, they won't operate in lockstep. + backoff *= 1 + bc.jitter*(rand.Float64()*2-1) + if backoff < 0 { + return 0 + } + return time.Duration(backoff) +} diff --git a/vendor/google.golang.org/grpc/balancer.go b/vendor/google.golang.org/grpc/balancer.go new file mode 100644 index 00000000000..e1730166cde --- /dev/null +++ b/vendor/google.golang.org/grpc/balancer.go @@ -0,0 +1,416 @@ +/* + * + * Copyright 2016 gRPC 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 grpc + +import ( + "fmt" + "net" + "sync" + + "golang.org/x/net/context" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/naming" + "google.golang.org/grpc/status" +) + +// Address represents a server the client connects to. +// +// Deprecated: please use package balancer. +type Address struct { + // Addr is the server address on which a connection will be established. + Addr string + // Metadata is the information associated with Addr, which may be used + // to make load balancing decision. + Metadata interface{} +} + +// BalancerConfig specifies the configurations for Balancer. +// +// Deprecated: please use package balancer. +type BalancerConfig struct { + // DialCreds is the transport credential the Balancer implementation can + // use to dial to a remote load balancer server. The Balancer implementations + // can ignore this if it does not need to talk to another party securely. + DialCreds credentials.TransportCredentials + // Dialer is the custom dialer the Balancer implementation can use to dial + // to a remote load balancer server. The Balancer implementations + // can ignore this if it doesn't need to talk to remote balancer. + Dialer func(context.Context, string) (net.Conn, error) +} + +// BalancerGetOptions configures a Get call. +// +// Deprecated: please use package balancer. +type BalancerGetOptions struct { + // BlockingWait specifies whether Get should block when there is no + // connected address. + BlockingWait bool +} + +// Balancer chooses network addresses for RPCs. +// +// Deprecated: please use package balancer. +type Balancer interface { + // Start does the initialization work to bootstrap a Balancer. For example, + // this function may start the name resolution and watch the updates. It will + // be called when dialing. + Start(target string, config BalancerConfig) error + // Up informs the Balancer that gRPC has a connection to the server at + // addr. It returns down which is called once the connection to addr gets + // lost or closed. + // TODO: It is not clear how to construct and take advantage of the meaningful error + // parameter for down. Need realistic demands to guide. + Up(addr Address) (down func(error)) + // Get gets the address of a server for the RPC corresponding to ctx. + // i) If it returns a connected address, gRPC internals issues the RPC on the + // connection to this address; + // ii) If it returns an address on which the connection is under construction + // (initiated by Notify(...)) but not connected, gRPC internals + // * fails RPC if the RPC is fail-fast and connection is in the TransientFailure or + // Shutdown state; + // or + // * issues RPC on the connection otherwise. + // iii) If it returns an address on which the connection does not exist, gRPC + // internals treats it as an error and will fail the corresponding RPC. + // + // Therefore, the following is the recommended rule when writing a custom Balancer. + // If opts.BlockingWait is true, it should return a connected address or + // block if there is no connected address. It should respect the timeout or + // cancellation of ctx when blocking. If opts.BlockingWait is false (for fail-fast + // RPCs), it should return an address it has notified via Notify(...) immediately + // instead of blocking. + // + // The function returns put which is called once the rpc has completed or failed. + // put can collect and report RPC stats to a remote load balancer. + // + // This function should only return the errors Balancer cannot recover by itself. + // gRPC internals will fail the RPC if an error is returned. + Get(ctx context.Context, opts BalancerGetOptions) (addr Address, put func(), err error) + // Notify returns a channel that is used by gRPC internals to watch the addresses + // gRPC needs to connect. The addresses might be from a name resolver or remote + // load balancer. gRPC internals will compare it with the existing connected + // addresses. If the address Balancer notified is not in the existing connected + // addresses, gRPC starts to connect the address. If an address in the existing + // connected addresses is not in the notification list, the corresponding connection + // is shutdown gracefully. Otherwise, there are no operations to take. Note that + // the Address slice must be the full list of the Addresses which should be connected. + // It is NOT delta. + Notify() <-chan []Address + // Close shuts down the balancer. + Close() error +} + +// downErr implements net.Error. It is constructed by gRPC internals and passed to the down +// call of Balancer. +type downErr struct { + timeout bool + temporary bool + desc string +} + +func (e downErr) Error() string { return e.desc } +func (e downErr) Timeout() bool { return e.timeout } +func (e downErr) Temporary() bool { return e.temporary } + +func downErrorf(timeout, temporary bool, format string, a ...interface{}) downErr { + return downErr{ + timeout: timeout, + temporary: temporary, + desc: fmt.Sprintf(format, a...), + } +} + +// RoundRobin returns a Balancer that selects addresses round-robin. It uses r to watch +// the name resolution updates and updates the addresses available correspondingly. +// +// Deprecated: please use package balancer/roundrobin. +func RoundRobin(r naming.Resolver) Balancer { + return &roundRobin{r: r} +} + +type addrInfo struct { + addr Address + connected bool +} + +type roundRobin struct { + r naming.Resolver + w naming.Watcher + addrs []*addrInfo // all the addresses the client should potentially connect + mu sync.Mutex + addrCh chan []Address // the channel to notify gRPC internals the list of addresses the client should connect to. + next int // index of the next address to return for Get() + waitCh chan struct{} // the channel to block when there is no connected address available + done bool // The Balancer is closed. +} + +func (rr *roundRobin) watchAddrUpdates() error { + updates, err := rr.w.Next() + if err != nil { + grpclog.Warningf("grpc: the naming watcher stops working due to %v.", err) + return err + } + rr.mu.Lock() + defer rr.mu.Unlock() + for _, update := range updates { + addr := Address{ + Addr: update.Addr, + Metadata: update.Metadata, + } + switch update.Op { + case naming.Add: + var exist bool + for _, v := range rr.addrs { + if addr == v.addr { + exist = true + grpclog.Infoln("grpc: The name resolver wanted to add an existing address: ", addr) + break + } + } + if exist { + continue + } + rr.addrs = append(rr.addrs, &addrInfo{addr: addr}) + case naming.Delete: + for i, v := range rr.addrs { + if addr == v.addr { + copy(rr.addrs[i:], rr.addrs[i+1:]) + rr.addrs = rr.addrs[:len(rr.addrs)-1] + break + } + } + default: + grpclog.Errorln("Unknown update.Op ", update.Op) + } + } + // Make a copy of rr.addrs and write it onto rr.addrCh so that gRPC internals gets notified. + open := make([]Address, len(rr.addrs)) + for i, v := range rr.addrs { + open[i] = v.addr + } + if rr.done { + return ErrClientConnClosing + } + select { + case <-rr.addrCh: + default: + } + rr.addrCh <- open + return nil +} + +func (rr *roundRobin) Start(target string, config BalancerConfig) error { + rr.mu.Lock() + defer rr.mu.Unlock() + if rr.done { + return ErrClientConnClosing + } + if rr.r == nil { + // If there is no name resolver installed, it is not needed to + // do name resolution. In this case, target is added into rr.addrs + // as the only address available and rr.addrCh stays nil. + rr.addrs = append(rr.addrs, &addrInfo{addr: Address{Addr: target}}) + return nil + } + w, err := rr.r.Resolve(target) + if err != nil { + return err + } + rr.w = w + rr.addrCh = make(chan []Address, 1) + go func() { + for { + if err := rr.watchAddrUpdates(); err != nil { + return + } + } + }() + return nil +} + +// Up sets the connected state of addr and sends notification if there are pending +// Get() calls. +func (rr *roundRobin) Up(addr Address) func(error) { + rr.mu.Lock() + defer rr.mu.Unlock() + var cnt int + for _, a := range rr.addrs { + if a.addr == addr { + if a.connected { + return nil + } + a.connected = true + } + if a.connected { + cnt++ + } + } + // addr is only one which is connected. Notify the Get() callers who are blocking. + if cnt == 1 && rr.waitCh != nil { + close(rr.waitCh) + rr.waitCh = nil + } + return func(err error) { + rr.down(addr, err) + } +} + +// down unsets the connected state of addr. +func (rr *roundRobin) down(addr Address, err error) { + rr.mu.Lock() + defer rr.mu.Unlock() + for _, a := range rr.addrs { + if addr == a.addr { + a.connected = false + break + } + } +} + +// Get returns the next addr in the rotation. +func (rr *roundRobin) Get(ctx context.Context, opts BalancerGetOptions) (addr Address, put func(), err error) { + var ch chan struct{} + rr.mu.Lock() + if rr.done { + rr.mu.Unlock() + err = ErrClientConnClosing + return + } + + if len(rr.addrs) > 0 { + if rr.next >= len(rr.addrs) { + rr.next = 0 + } + next := rr.next + for { + a := rr.addrs[next] + next = (next + 1) % len(rr.addrs) + if a.connected { + addr = a.addr + rr.next = next + rr.mu.Unlock() + return + } + if next == rr.next { + // Has iterated all the possible address but none is connected. + break + } + } + } + if !opts.BlockingWait { + if len(rr.addrs) == 0 { + rr.mu.Unlock() + err = status.Errorf(codes.Unavailable, "there is no address available") + return + } + // Returns the next addr on rr.addrs for failfast RPCs. + addr = rr.addrs[rr.next].addr + rr.next++ + rr.mu.Unlock() + return + } + // Wait on rr.waitCh for non-failfast RPCs. + if rr.waitCh == nil { + ch = make(chan struct{}) + rr.waitCh = ch + } else { + ch = rr.waitCh + } + rr.mu.Unlock() + for { + select { + case <-ctx.Done(): + err = ctx.Err() + return + case <-ch: + rr.mu.Lock() + if rr.done { + rr.mu.Unlock() + err = ErrClientConnClosing + return + } + + if len(rr.addrs) > 0 { + if rr.next >= len(rr.addrs) { + rr.next = 0 + } + next := rr.next + for { + a := rr.addrs[next] + next = (next + 1) % len(rr.addrs) + if a.connected { + addr = a.addr + rr.next = next + rr.mu.Unlock() + return + } + if next == rr.next { + // Has iterated all the possible address but none is connected. + break + } + } + } + // The newly added addr got removed by Down() again. + if rr.waitCh == nil { + ch = make(chan struct{}) + rr.waitCh = ch + } else { + ch = rr.waitCh + } + rr.mu.Unlock() + } + } +} + +func (rr *roundRobin) Notify() <-chan []Address { + return rr.addrCh +} + +func (rr *roundRobin) Close() error { + rr.mu.Lock() + defer rr.mu.Unlock() + if rr.done { + return errBalancerClosed + } + rr.done = true + if rr.w != nil { + rr.w.Close() + } + if rr.waitCh != nil { + close(rr.waitCh) + rr.waitCh = nil + } + if rr.addrCh != nil { + close(rr.addrCh) + } + return nil +} + +// pickFirst is used to test multi-addresses in one addrConn in which all addresses share the same addrConn. +// It is a wrapper around roundRobin balancer. The logic of all methods works fine because balancer.Get() +// returns the only address Up by resetTransport(). +type pickFirst struct { + *roundRobin +} + +func pickFirstBalancerV1(r naming.Resolver) Balancer { + return &pickFirst{&roundRobin{r: r}} +} diff --git a/vendor/google.golang.org/grpc/balancer/balancer.go b/vendor/google.golang.org/grpc/balancer/balancer.go new file mode 100644 index 00000000000..63b8d71371e --- /dev/null +++ b/vendor/google.golang.org/grpc/balancer/balancer.go @@ -0,0 +1,228 @@ +/* + * + * Copyright 2017 gRPC 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 balancer defines APIs for load balancing in gRPC. +// All APIs in this package are experimental. +package balancer + +import ( + "errors" + "net" + "strings" + + "golang.org/x/net/context" + "google.golang.org/grpc/connectivity" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/resolver" +) + +var ( + // m is a map from name to balancer builder. + m = make(map[string]Builder) +) + +// Register registers the balancer builder to the balancer map. b.Name +// (lowercased) will be used as the name registered with this builder. +// +// NOTE: this function must only be called during initialization time (i.e. in +// an init() function), and is not thread-safe. If multiple Balancers are +// registered with the same name, the one registered last will take effect. +func Register(b Builder) { + m[strings.ToLower(b.Name())] = b +} + +// Get returns the resolver builder registered with the given name. +// Note that the compare is done in a case-insenstive fashion. +// If no builder is register with the name, nil will be returned. +func Get(name string) Builder { + if b, ok := m[strings.ToLower(name)]; ok { + return b + } + return nil +} + +// SubConn represents a gRPC sub connection. +// Each sub connection contains a list of addresses. gRPC will +// try to connect to them (in sequence), and stop trying the +// remainder once one connection is successful. +// +// The reconnect backoff will be applied on the list, not a single address. +// For example, try_on_all_addresses -> backoff -> try_on_all_addresses. +// +// All SubConns start in IDLE, and will not try to connect. To trigger +// the connecting, Balancers must call Connect. +// When the connection encounters an error, it will reconnect immediately. +// When the connection becomes IDLE, it will not reconnect unless Connect is +// called. +// +// This interface is to be implemented by gRPC. Users should not need a +// brand new implementation of this interface. For the situations like +// testing, the new implementation should embed this interface. This allows +// gRPC to add new methods to this interface. +type SubConn interface { + // UpdateAddresses updates the addresses used in this SubConn. + // gRPC checks if currently-connected address is still in the new list. + // If it's in the list, the connection will be kept. + // If it's not in the list, the connection will gracefully closed, and + // a new connection will be created. + // + // This will trigger a state transition for the SubConn. + UpdateAddresses([]resolver.Address) + // Connect starts the connecting for this SubConn. + Connect() +} + +// NewSubConnOptions contains options to create new SubConn. +type NewSubConnOptions struct{} + +// ClientConn represents a gRPC ClientConn. +// +// This interface is to be implemented by gRPC. Users should not need a +// brand new implementation of this interface. For the situations like +// testing, the new implementation should embed this interface. This allows +// gRPC to add new methods to this interface. +type ClientConn interface { + // NewSubConn is called by balancer to create a new SubConn. + // It doesn't block and wait for the connections to be established. + // Behaviors of the SubConn can be controlled by options. + NewSubConn([]resolver.Address, NewSubConnOptions) (SubConn, error) + // RemoveSubConn removes the SubConn from ClientConn. + // The SubConn will be shutdown. + RemoveSubConn(SubConn) + + // UpdateBalancerState is called by balancer to nofity gRPC that some internal + // state in balancer has changed. + // + // gRPC will update the connectivity state of the ClientConn, and will call pick + // on the new picker to pick new SubConn. + UpdateBalancerState(s connectivity.State, p Picker) + + // ResolveNow is called by balancer to notify gRPC to do a name resolving. + ResolveNow(resolver.ResolveNowOption) + + // Target returns the dial target for this ClientConn. + Target() string +} + +// BuildOptions contains additional information for Build. +type BuildOptions struct { + // DialCreds is the transport credential the Balancer implementation can + // use to dial to a remote load balancer server. The Balancer implementations + // can ignore this if it does not need to talk to another party securely. + DialCreds credentials.TransportCredentials + // Dialer is the custom dialer the Balancer implementation can use to dial + // to a remote load balancer server. The Balancer implementations + // can ignore this if it doesn't need to talk to remote balancer. + Dialer func(context.Context, string) (net.Conn, error) + // ChannelzParentID is the entity parent's channelz unique identification number. + ChannelzParentID int64 +} + +// Builder creates a balancer. +type Builder interface { + // Build creates a new balancer with the ClientConn. + Build(cc ClientConn, opts BuildOptions) Balancer + // Name returns the name of balancers built by this builder. + // It will be used to pick balancers (for example in service config). + Name() string +} + +// PickOptions contains addition information for the Pick operation. +type PickOptions struct{} + +// DoneInfo contains additional information for done. +type DoneInfo struct { + // Err is the rpc error the RPC finished with. It could be nil. + Err error + // BytesSent indicates if any bytes have been sent to the server. + BytesSent bool + // BytesReceived indicates if any byte has been received from the server. + BytesReceived bool +} + +var ( + // ErrNoSubConnAvailable indicates no SubConn is available for pick(). + // gRPC will block the RPC until a new picker is available via UpdateBalancerState(). + ErrNoSubConnAvailable = errors.New("no SubConn is available") + // ErrTransientFailure indicates all SubConns are in TransientFailure. + // WaitForReady RPCs will block, non-WaitForReady RPCs will fail. + ErrTransientFailure = errors.New("all SubConns are in TransientFailure") +) + +// Picker is used by gRPC to pick a SubConn to send an RPC. +// Balancer is expected to generate a new picker from its snapshot every time its +// internal state has changed. +// +// The pickers used by gRPC can be updated by ClientConn.UpdateBalancerState(). +type Picker interface { + // Pick returns the SubConn to be used to send the RPC. + // The returned SubConn must be one returned by NewSubConn(). + // + // This functions is expected to return: + // - a SubConn that is known to be READY; + // - ErrNoSubConnAvailable if no SubConn is available, but progress is being + // made (for example, some SubConn is in CONNECTING mode); + // - other errors if no active connecting is happening (for example, all SubConn + // are in TRANSIENT_FAILURE mode). + // + // If a SubConn is returned: + // - If it is READY, gRPC will send the RPC on it; + // - If it is not ready, or becomes not ready after it's returned, gRPC will block + // until UpdateBalancerState() is called and will call pick on the new picker. + // + // If the returned error is not nil: + // - If the error is ErrNoSubConnAvailable, gRPC will block until UpdateBalancerState() + // - If the error is ErrTransientFailure: + // - If the RPC is wait-for-ready, gRPC will block until UpdateBalancerState() + // is called to pick again; + // - Otherwise, RPC will fail with unavailable error. + // - Else (error is other non-nil error): + // - The RPC will fail with unavailable error. + // + // The returned done() function will be called once the rpc has finished, with the + // final status of that RPC. + // done may be nil if balancer doesn't care about the RPC status. + Pick(ctx context.Context, opts PickOptions) (conn SubConn, done func(DoneInfo), err error) +} + +// Balancer takes input from gRPC, manages SubConns, and collects and aggregates +// the connectivity states. +// +// It also generates and updates the Picker used by gRPC to pick SubConns for RPCs. +// +// HandleSubConnectionStateChange, HandleResolvedAddrs and Close are guaranteed +// to be called synchronously from the same goroutine. +// There's no guarantee on picker.Pick, it may be called anytime. +type Balancer interface { + // HandleSubConnStateChange is called by gRPC when the connectivity state + // of sc has changed. + // Balancer is expected to aggregate all the state of SubConn and report + // that back to gRPC. + // Balancer should also generate and update Pickers when its internal state has + // been changed by the new state. + HandleSubConnStateChange(sc SubConn, state connectivity.State) + // HandleResolvedAddrs is called by gRPC to send updated resolved addresses to + // balancers. + // Balancer can create new SubConn or remove SubConn with the addresses. + // An empty address slice and a non-nil error will be passed if the resolver returns + // non-nil error to gRPC. + HandleResolvedAddrs([]resolver.Address, error) + // Close closes the balancer. The balancer is not required to call + // ClientConn.RemoveSubConn for its existing SubConns. + Close() +} diff --git a/vendor/google.golang.org/grpc/balancer/base/balancer.go b/vendor/google.golang.org/grpc/balancer/base/balancer.go new file mode 100644 index 00000000000..23d13511bb2 --- /dev/null +++ b/vendor/google.golang.org/grpc/balancer/base/balancer.go @@ -0,0 +1,208 @@ +/* + * + * Copyright 2017 gRPC 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 base + +import ( + "golang.org/x/net/context" + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/connectivity" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/resolver" +) + +type baseBuilder struct { + name string + pickerBuilder PickerBuilder +} + +func (bb *baseBuilder) Build(cc balancer.ClientConn, opt balancer.BuildOptions) balancer.Balancer { + return &baseBalancer{ + cc: cc, + pickerBuilder: bb.pickerBuilder, + + subConns: make(map[resolver.Address]balancer.SubConn), + scStates: make(map[balancer.SubConn]connectivity.State), + csEvltr: &connectivityStateEvaluator{}, + // Initialize picker to a picker that always return + // ErrNoSubConnAvailable, because when state of a SubConn changes, we + // may call UpdateBalancerState with this picker. + picker: NewErrPicker(balancer.ErrNoSubConnAvailable), + } +} + +func (bb *baseBuilder) Name() string { + return bb.name +} + +type baseBalancer struct { + cc balancer.ClientConn + pickerBuilder PickerBuilder + + csEvltr *connectivityStateEvaluator + state connectivity.State + + subConns map[resolver.Address]balancer.SubConn + scStates map[balancer.SubConn]connectivity.State + picker balancer.Picker +} + +func (b *baseBalancer) HandleResolvedAddrs(addrs []resolver.Address, err error) { + if err != nil { + grpclog.Infof("base.baseBalancer: HandleResolvedAddrs called with error %v", err) + return + } + grpclog.Infoln("base.baseBalancer: got new resolved addresses: ", addrs) + // addrsSet is the set converted from addrs, it's used for quick lookup of an address. + addrsSet := make(map[resolver.Address]struct{}) + for _, a := range addrs { + addrsSet[a] = struct{}{} + if _, ok := b.subConns[a]; !ok { + // a is a new address (not existing in b.subConns). + sc, err := b.cc.NewSubConn([]resolver.Address{a}, balancer.NewSubConnOptions{}) + if err != nil { + grpclog.Warningf("base.baseBalancer: failed to create new SubConn: %v", err) + continue + } + b.subConns[a] = sc + b.scStates[sc] = connectivity.Idle + sc.Connect() + } + } + for a, sc := range b.subConns { + // a was removed by resolver. + if _, ok := addrsSet[a]; !ok { + b.cc.RemoveSubConn(sc) + delete(b.subConns, a) + // Keep the state of this sc in b.scStates until sc's state becomes Shutdown. + // The entry will be deleted in HandleSubConnStateChange. + } + } +} + +// regeneratePicker takes a snapshot of the balancer, and generates a picker +// from it. The picker is +// - errPicker with ErrTransientFailure if the balancer is in TransientFailure, +// - built by the pickerBuilder with all READY SubConns otherwise. +func (b *baseBalancer) regeneratePicker() { + if b.state == connectivity.TransientFailure { + b.picker = NewErrPicker(balancer.ErrTransientFailure) + return + } + readySCs := make(map[resolver.Address]balancer.SubConn) + + // Filter out all ready SCs from full subConn map. + for addr, sc := range b.subConns { + if st, ok := b.scStates[sc]; ok && st == connectivity.Ready { + readySCs[addr] = sc + } + } + b.picker = b.pickerBuilder.Build(readySCs) +} + +func (b *baseBalancer) HandleSubConnStateChange(sc balancer.SubConn, s connectivity.State) { + grpclog.Infof("base.baseBalancer: handle SubConn state change: %p, %v", sc, s) + oldS, ok := b.scStates[sc] + if !ok { + grpclog.Infof("base.baseBalancer: got state changes for an unknown SubConn: %p, %v", sc, s) + return + } + b.scStates[sc] = s + switch s { + case connectivity.Idle: + sc.Connect() + case connectivity.Shutdown: + // When an address was removed by resolver, b called RemoveSubConn but + // kept the sc's state in scStates. Remove state for this sc here. + delete(b.scStates, sc) + } + + oldAggrState := b.state + b.state = b.csEvltr.recordTransition(oldS, s) + + // Regenerate picker when one of the following happens: + // - this sc became ready from not-ready + // - this sc became not-ready from ready + // - the aggregated state of balancer became TransientFailure from non-TransientFailure + // - the aggregated state of balancer became non-TransientFailure from TransientFailure + if (s == connectivity.Ready) != (oldS == connectivity.Ready) || + (b.state == connectivity.TransientFailure) != (oldAggrState == connectivity.TransientFailure) { + b.regeneratePicker() + } + + b.cc.UpdateBalancerState(b.state, b.picker) +} + +// Close is a nop because base balancer doesn't have internal state to clean up, +// and it doesn't need to call RemoveSubConn for the SubConns. +func (b *baseBalancer) Close() { +} + +// NewErrPicker returns a picker that always returns err on Pick(). +func NewErrPicker(err error) balancer.Picker { + return &errPicker{err: err} +} + +type errPicker struct { + err error // Pick() always returns this err. +} + +func (p *errPicker) Pick(ctx context.Context, opts balancer.PickOptions) (balancer.SubConn, func(balancer.DoneInfo), error) { + return nil, nil, p.err +} + +// connectivityStateEvaluator gets updated by addrConns when their +// states transition, based on which it evaluates the state of +// ClientConn. +type connectivityStateEvaluator struct { + numReady uint64 // Number of addrConns in ready state. + numConnecting uint64 // Number of addrConns in connecting state. + numTransientFailure uint64 // Number of addrConns in transientFailure. +} + +// recordTransition records state change happening in every subConn and based on +// that it evaluates what aggregated state should be. +// It can only transition between Ready, Connecting and TransientFailure. Other states, +// Idle and Shutdown are transitioned into by ClientConn; in the beginning of the connection +// before any subConn is created ClientConn is in idle state. In the end when ClientConn +// closes it is in Shutdown state. +// +// recordTransition should only be called synchronously from the same goroutine. +func (cse *connectivityStateEvaluator) recordTransition(oldState, newState connectivity.State) connectivity.State { + // Update counters. + for idx, state := range []connectivity.State{oldState, newState} { + updateVal := 2*uint64(idx) - 1 // -1 for oldState and +1 for new. + switch state { + case connectivity.Ready: + cse.numReady += updateVal + case connectivity.Connecting: + cse.numConnecting += updateVal + case connectivity.TransientFailure: + cse.numTransientFailure += updateVal + } + } + + // Evaluate. + if cse.numReady > 0 { + return connectivity.Ready + } + if cse.numConnecting > 0 { + return connectivity.Connecting + } + return connectivity.TransientFailure +} diff --git a/vendor/google.golang.org/grpc/balancer/base/base.go b/vendor/google.golang.org/grpc/balancer/base/base.go new file mode 100644 index 00000000000..012ace2f2f7 --- /dev/null +++ b/vendor/google.golang.org/grpc/balancer/base/base.go @@ -0,0 +1,52 @@ +/* + * + * Copyright 2017 gRPC 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 base defines a balancer base that can be used to build balancers with +// different picking algorithms. +// +// The base balancer creates a new SubConn for each resolved address. The +// provided picker will only be notified about READY SubConns. +// +// This package is the base of round_robin balancer, its purpose is to be used +// to build round_robin like balancers with complex picking algorithms. +// Balancers with more complicated logic should try to implement a balancer +// builder from scratch. +// +// All APIs in this package are experimental. +package base + +import ( + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/resolver" +) + +// PickerBuilder creates balancer.Picker. +type PickerBuilder interface { + // Build takes a slice of ready SubConns, and returns a picker that will be + // used by gRPC to pick a SubConn. + Build(readySCs map[resolver.Address]balancer.SubConn) balancer.Picker +} + +// NewBalancerBuilder returns a balancer builder. The balancers +// built by this builder will use the picker builder to build pickers. +func NewBalancerBuilder(name string, pb PickerBuilder) balancer.Builder { + return &baseBuilder{ + name: name, + pickerBuilder: pb, + } +} diff --git a/vendor/google.golang.org/grpc/balancer/roundrobin/roundrobin.go b/vendor/google.golang.org/grpc/balancer/roundrobin/roundrobin.go new file mode 100644 index 00000000000..2eda0a1c210 --- /dev/null +++ b/vendor/google.golang.org/grpc/balancer/roundrobin/roundrobin.go @@ -0,0 +1,79 @@ +/* + * + * Copyright 2017 gRPC 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 roundrobin defines a roundrobin balancer. Roundrobin balancer is +// installed as one of the default balancers in gRPC, users don't need to +// explicitly install this balancer. +package roundrobin + +import ( + "sync" + + "golang.org/x/net/context" + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/balancer/base" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/resolver" +) + +// Name is the name of round_robin balancer. +const Name = "round_robin" + +// newBuilder creates a new roundrobin balancer builder. +func newBuilder() balancer.Builder { + return base.NewBalancerBuilder(Name, &rrPickerBuilder{}) +} + +func init() { + balancer.Register(newBuilder()) +} + +type rrPickerBuilder struct{} + +func (*rrPickerBuilder) Build(readySCs map[resolver.Address]balancer.SubConn) balancer.Picker { + grpclog.Infof("roundrobinPicker: newPicker called with readySCs: %v", readySCs) + var scs []balancer.SubConn + for _, sc := range readySCs { + scs = append(scs, sc) + } + return &rrPicker{ + subConns: scs, + } +} + +type rrPicker struct { + // subConns is the snapshot of the roundrobin balancer when this picker was + // created. The slice is immutable. Each Get() will do a round robin + // selection from it and return the selected SubConn. + subConns []balancer.SubConn + + mu sync.Mutex + next int +} + +func (p *rrPicker) Pick(ctx context.Context, opts balancer.PickOptions) (balancer.SubConn, func(balancer.DoneInfo), error) { + if len(p.subConns) <= 0 { + return nil, nil, balancer.ErrNoSubConnAvailable + } + + p.mu.Lock() + sc := p.subConns[p.next] + p.next = (p.next + 1) % len(p.subConns) + p.mu.Unlock() + return sc, nil, nil +} diff --git a/vendor/google.golang.org/grpc/balancer_conn_wrappers.go b/vendor/google.golang.org/grpc/balancer_conn_wrappers.go new file mode 100644 index 00000000000..c23f81706fb --- /dev/null +++ b/vendor/google.golang.org/grpc/balancer_conn_wrappers.go @@ -0,0 +1,300 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "fmt" + "sync" + + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/connectivity" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/resolver" +) + +// scStateUpdate contains the subConn and the new state it changed to. +type scStateUpdate struct { + sc balancer.SubConn + state connectivity.State +} + +// scStateUpdateBuffer is an unbounded channel for scStateChangeTuple. +// TODO make a general purpose buffer that uses interface{}. +type scStateUpdateBuffer struct { + c chan *scStateUpdate + mu sync.Mutex + backlog []*scStateUpdate +} + +func newSCStateUpdateBuffer() *scStateUpdateBuffer { + return &scStateUpdateBuffer{ + c: make(chan *scStateUpdate, 1), + } +} + +func (b *scStateUpdateBuffer) put(t *scStateUpdate) { + b.mu.Lock() + defer b.mu.Unlock() + if len(b.backlog) == 0 { + select { + case b.c <- t: + return + default: + } + } + b.backlog = append(b.backlog, t) +} + +func (b *scStateUpdateBuffer) load() { + b.mu.Lock() + defer b.mu.Unlock() + if len(b.backlog) > 0 { + select { + case b.c <- b.backlog[0]: + b.backlog[0] = nil + b.backlog = b.backlog[1:] + default: + } + } +} + +// get returns the channel that the scStateUpdate will be sent to. +// +// Upon receiving, the caller should call load to send another +// scStateChangeTuple onto the channel if there is any. +func (b *scStateUpdateBuffer) get() <-chan *scStateUpdate { + return b.c +} + +// resolverUpdate contains the new resolved addresses or error if there's +// any. +type resolverUpdate struct { + addrs []resolver.Address + err error +} + +// ccBalancerWrapper is a wrapper on top of cc for balancers. +// It implements balancer.ClientConn interface. +type ccBalancerWrapper struct { + cc *ClientConn + balancer balancer.Balancer + stateChangeQueue *scStateUpdateBuffer + resolverUpdateCh chan *resolverUpdate + done chan struct{} + + mu sync.Mutex + subConns map[*acBalancerWrapper]struct{} +} + +func newCCBalancerWrapper(cc *ClientConn, b balancer.Builder, bopts balancer.BuildOptions) *ccBalancerWrapper { + ccb := &ccBalancerWrapper{ + cc: cc, + stateChangeQueue: newSCStateUpdateBuffer(), + resolverUpdateCh: make(chan *resolverUpdate, 1), + done: make(chan struct{}), + subConns: make(map[*acBalancerWrapper]struct{}), + } + go ccb.watcher() + ccb.balancer = b.Build(ccb, bopts) + return ccb +} + +// watcher balancer functions sequentially, so the balancer can be implemented +// lock-free. +func (ccb *ccBalancerWrapper) watcher() { + for { + select { + case t := <-ccb.stateChangeQueue.get(): + ccb.stateChangeQueue.load() + select { + case <-ccb.done: + ccb.balancer.Close() + return + default: + } + ccb.balancer.HandleSubConnStateChange(t.sc, t.state) + case t := <-ccb.resolverUpdateCh: + select { + case <-ccb.done: + ccb.balancer.Close() + return + default: + } + ccb.balancer.HandleResolvedAddrs(t.addrs, t.err) + case <-ccb.done: + } + + select { + case <-ccb.done: + ccb.balancer.Close() + ccb.mu.Lock() + scs := ccb.subConns + ccb.subConns = nil + ccb.mu.Unlock() + for acbw := range scs { + ccb.cc.removeAddrConn(acbw.getAddrConn(), errConnDrain) + } + return + default: + } + } +} + +func (ccb *ccBalancerWrapper) close() { + close(ccb.done) +} + +func (ccb *ccBalancerWrapper) handleSubConnStateChange(sc balancer.SubConn, s connectivity.State) { + // When updating addresses for a SubConn, if the address in use is not in + // the new addresses, the old ac will be tearDown() and a new ac will be + // created. tearDown() generates a state change with Shutdown state, we + // don't want the balancer to receive this state change. So before + // tearDown() on the old ac, ac.acbw (acWrapper) will be set to nil, and + // this function will be called with (nil, Shutdown). We don't need to call + // balancer method in this case. + if sc == nil { + return + } + ccb.stateChangeQueue.put(&scStateUpdate{ + sc: sc, + state: s, + }) +} + +func (ccb *ccBalancerWrapper) handleResolvedAddrs(addrs []resolver.Address, err error) { + select { + case <-ccb.resolverUpdateCh: + default: + } + ccb.resolverUpdateCh <- &resolverUpdate{ + addrs: addrs, + err: err, + } +} + +func (ccb *ccBalancerWrapper) NewSubConn(addrs []resolver.Address, opts balancer.NewSubConnOptions) (balancer.SubConn, error) { + if len(addrs) <= 0 { + return nil, fmt.Errorf("grpc: cannot create SubConn with empty address list") + } + ccb.mu.Lock() + defer ccb.mu.Unlock() + if ccb.subConns == nil { + return nil, fmt.Errorf("grpc: ClientConn balancer wrapper was closed") + } + ac, err := ccb.cc.newAddrConn(addrs) + if err != nil { + return nil, err + } + acbw := &acBalancerWrapper{ac: ac} + acbw.ac.mu.Lock() + ac.acbw = acbw + acbw.ac.mu.Unlock() + ccb.subConns[acbw] = struct{}{} + return acbw, nil +} + +func (ccb *ccBalancerWrapper) RemoveSubConn(sc balancer.SubConn) { + acbw, ok := sc.(*acBalancerWrapper) + if !ok { + return + } + ccb.mu.Lock() + defer ccb.mu.Unlock() + if ccb.subConns == nil { + return + } + delete(ccb.subConns, acbw) + ccb.cc.removeAddrConn(acbw.getAddrConn(), errConnDrain) +} + +func (ccb *ccBalancerWrapper) UpdateBalancerState(s connectivity.State, p balancer.Picker) { + ccb.mu.Lock() + defer ccb.mu.Unlock() + if ccb.subConns == nil { + return + } + ccb.cc.csMgr.updateState(s) + ccb.cc.blockingpicker.updatePicker(p) +} + +func (ccb *ccBalancerWrapper) ResolveNow(o resolver.ResolveNowOption) { + ccb.cc.resolveNow(o) +} + +func (ccb *ccBalancerWrapper) Target() string { + return ccb.cc.target +} + +// acBalancerWrapper is a wrapper on top of ac for balancers. +// It implements balancer.SubConn interface. +type acBalancerWrapper struct { + mu sync.Mutex + ac *addrConn +} + +func (acbw *acBalancerWrapper) UpdateAddresses(addrs []resolver.Address) { + acbw.mu.Lock() + defer acbw.mu.Unlock() + if len(addrs) <= 0 { + acbw.ac.tearDown(errConnDrain) + return + } + if !acbw.ac.tryUpdateAddrs(addrs) { + cc := acbw.ac.cc + acbw.ac.mu.Lock() + // Set old ac.acbw to nil so the Shutdown state update will be ignored + // by balancer. + // + // TODO(bar) the state transition could be wrong when tearDown() old ac + // and creating new ac, fix the transition. + acbw.ac.acbw = nil + acbw.ac.mu.Unlock() + acState := acbw.ac.getState() + acbw.ac.tearDown(errConnDrain) + + if acState == connectivity.Shutdown { + return + } + + ac, err := cc.newAddrConn(addrs) + if err != nil { + grpclog.Warningf("acBalancerWrapper: UpdateAddresses: failed to newAddrConn: %v", err) + return + } + acbw.ac = ac + ac.mu.Lock() + ac.acbw = acbw + ac.mu.Unlock() + if acState != connectivity.Idle { + ac.connect() + } + } +} + +func (acbw *acBalancerWrapper) Connect() { + acbw.mu.Lock() + defer acbw.mu.Unlock() + acbw.ac.connect() +} + +func (acbw *acBalancerWrapper) getAddrConn() *addrConn { + acbw.mu.Lock() + defer acbw.mu.Unlock() + return acbw.ac +} diff --git a/vendor/google.golang.org/grpc/balancer_v1_wrapper.go b/vendor/google.golang.org/grpc/balancer_v1_wrapper.go new file mode 100644 index 00000000000..b7abc6b7457 --- /dev/null +++ b/vendor/google.golang.org/grpc/balancer_v1_wrapper.go @@ -0,0 +1,372 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "strings" + "sync" + + "golang.org/x/net/context" + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/connectivity" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/resolver" + "google.golang.org/grpc/status" +) + +type balancerWrapperBuilder struct { + b Balancer // The v1 balancer. +} + +func (bwb *balancerWrapperBuilder) Build(cc balancer.ClientConn, opts balancer.BuildOptions) balancer.Balancer { + targetAddr := cc.Target() + targetSplitted := strings.Split(targetAddr, ":///") + if len(targetSplitted) >= 2 { + targetAddr = targetSplitted[1] + } + + bwb.b.Start(targetAddr, BalancerConfig{ + DialCreds: opts.DialCreds, + Dialer: opts.Dialer, + }) + _, pickfirst := bwb.b.(*pickFirst) + bw := &balancerWrapper{ + balancer: bwb.b, + pickfirst: pickfirst, + cc: cc, + targetAddr: targetAddr, + startCh: make(chan struct{}), + conns: make(map[resolver.Address]balancer.SubConn), + connSt: make(map[balancer.SubConn]*scState), + csEvltr: &connectivityStateEvaluator{}, + state: connectivity.Idle, + } + cc.UpdateBalancerState(connectivity.Idle, bw) + go bw.lbWatcher() + return bw +} + +func (bwb *balancerWrapperBuilder) Name() string { + return "wrapper" +} + +type scState struct { + addr Address // The v1 address type. + s connectivity.State + down func(error) +} + +type balancerWrapper struct { + balancer Balancer // The v1 balancer. + pickfirst bool + + cc balancer.ClientConn + targetAddr string // Target without the scheme. + + // To aggregate the connectivity state. + csEvltr *connectivityStateEvaluator + state connectivity.State + + mu sync.Mutex + conns map[resolver.Address]balancer.SubConn + connSt map[balancer.SubConn]*scState + // This channel is closed when handling the first resolver result. + // lbWatcher blocks until this is closed, to avoid race between + // - NewSubConn is created, cc wants to notify balancer of state changes; + // - Build hasn't return, cc doesn't have access to balancer. + startCh chan struct{} +} + +// lbWatcher watches the Notify channel of the balancer and manages +// connections accordingly. +func (bw *balancerWrapper) lbWatcher() { + <-bw.startCh + notifyCh := bw.balancer.Notify() + if notifyCh == nil { + // There's no resolver in the balancer. Connect directly. + a := resolver.Address{ + Addr: bw.targetAddr, + Type: resolver.Backend, + } + sc, err := bw.cc.NewSubConn([]resolver.Address{a}, balancer.NewSubConnOptions{}) + if err != nil { + grpclog.Warningf("Error creating connection to %v. Err: %v", a, err) + } else { + bw.mu.Lock() + bw.conns[a] = sc + bw.connSt[sc] = &scState{ + addr: Address{Addr: bw.targetAddr}, + s: connectivity.Idle, + } + bw.mu.Unlock() + sc.Connect() + } + return + } + + for addrs := range notifyCh { + grpclog.Infof("balancerWrapper: got update addr from Notify: %v\n", addrs) + if bw.pickfirst { + var ( + oldA resolver.Address + oldSC balancer.SubConn + ) + bw.mu.Lock() + for oldA, oldSC = range bw.conns { + break + } + bw.mu.Unlock() + if len(addrs) <= 0 { + if oldSC != nil { + // Teardown old sc. + bw.mu.Lock() + delete(bw.conns, oldA) + delete(bw.connSt, oldSC) + bw.mu.Unlock() + bw.cc.RemoveSubConn(oldSC) + } + continue + } + + var newAddrs []resolver.Address + for _, a := range addrs { + newAddr := resolver.Address{ + Addr: a.Addr, + Type: resolver.Backend, // All addresses from balancer are all backends. + ServerName: "", + Metadata: a.Metadata, + } + newAddrs = append(newAddrs, newAddr) + } + if oldSC == nil { + // Create new sc. + sc, err := bw.cc.NewSubConn(newAddrs, balancer.NewSubConnOptions{}) + if err != nil { + grpclog.Warningf("Error creating connection to %v. Err: %v", newAddrs, err) + } else { + bw.mu.Lock() + // For pickfirst, there should be only one SubConn, so the + // address doesn't matter. All states updating (up and down) + // and picking should all happen on that only SubConn. + bw.conns[resolver.Address{}] = sc + bw.connSt[sc] = &scState{ + addr: addrs[0], // Use the first address. + s: connectivity.Idle, + } + bw.mu.Unlock() + sc.Connect() + } + } else { + bw.mu.Lock() + bw.connSt[oldSC].addr = addrs[0] + bw.mu.Unlock() + oldSC.UpdateAddresses(newAddrs) + } + } else { + var ( + add []resolver.Address // Addresses need to setup connections. + del []balancer.SubConn // Connections need to tear down. + ) + resAddrs := make(map[resolver.Address]Address) + for _, a := range addrs { + resAddrs[resolver.Address{ + Addr: a.Addr, + Type: resolver.Backend, // All addresses from balancer are all backends. + ServerName: "", + Metadata: a.Metadata, + }] = a + } + bw.mu.Lock() + for a := range resAddrs { + if _, ok := bw.conns[a]; !ok { + add = append(add, a) + } + } + for a, c := range bw.conns { + if _, ok := resAddrs[a]; !ok { + del = append(del, c) + delete(bw.conns, a) + // Keep the state of this sc in bw.connSt until its state becomes Shutdown. + } + } + bw.mu.Unlock() + for _, a := range add { + sc, err := bw.cc.NewSubConn([]resolver.Address{a}, balancer.NewSubConnOptions{}) + if err != nil { + grpclog.Warningf("Error creating connection to %v. Err: %v", a, err) + } else { + bw.mu.Lock() + bw.conns[a] = sc + bw.connSt[sc] = &scState{ + addr: resAddrs[a], + s: connectivity.Idle, + } + bw.mu.Unlock() + sc.Connect() + } + } + for _, c := range del { + bw.cc.RemoveSubConn(c) + } + } + } +} + +func (bw *balancerWrapper) HandleSubConnStateChange(sc balancer.SubConn, s connectivity.State) { + bw.mu.Lock() + defer bw.mu.Unlock() + scSt, ok := bw.connSt[sc] + if !ok { + return + } + if s == connectivity.Idle { + sc.Connect() + } + oldS := scSt.s + scSt.s = s + if oldS != connectivity.Ready && s == connectivity.Ready { + scSt.down = bw.balancer.Up(scSt.addr) + } else if oldS == connectivity.Ready && s != connectivity.Ready { + if scSt.down != nil { + scSt.down(errConnClosing) + } + } + sa := bw.csEvltr.recordTransition(oldS, s) + if bw.state != sa { + bw.state = sa + } + bw.cc.UpdateBalancerState(bw.state, bw) + if s == connectivity.Shutdown { + // Remove state for this sc. + delete(bw.connSt, sc) + } +} + +func (bw *balancerWrapper) HandleResolvedAddrs([]resolver.Address, error) { + bw.mu.Lock() + defer bw.mu.Unlock() + select { + case <-bw.startCh: + default: + close(bw.startCh) + } + // There should be a resolver inside the balancer. + // All updates here, if any, are ignored. +} + +func (bw *balancerWrapper) Close() { + bw.mu.Lock() + defer bw.mu.Unlock() + select { + case <-bw.startCh: + default: + close(bw.startCh) + } + bw.balancer.Close() +} + +// The picker is the balancerWrapper itself. +// Pick should never return ErrNoSubConnAvailable. +// It either blocks or returns error, consistent with v1 balancer Get(). +func (bw *balancerWrapper) Pick(ctx context.Context, opts balancer.PickOptions) (balancer.SubConn, func(balancer.DoneInfo), error) { + failfast := true // Default failfast is true. + if ss, ok := rpcInfoFromContext(ctx); ok { + failfast = ss.failfast + } + a, p, err := bw.balancer.Get(ctx, BalancerGetOptions{BlockingWait: !failfast}) + if err != nil { + return nil, nil, err + } + var done func(balancer.DoneInfo) + if p != nil { + done = func(i balancer.DoneInfo) { p() } + } + var sc balancer.SubConn + bw.mu.Lock() + defer bw.mu.Unlock() + if bw.pickfirst { + // Get the first sc in conns. + for _, sc = range bw.conns { + break + } + } else { + var ok bool + sc, ok = bw.conns[resolver.Address{ + Addr: a.Addr, + Type: resolver.Backend, + ServerName: "", + Metadata: a.Metadata, + }] + if !ok && failfast { + return nil, nil, status.Errorf(codes.Unavailable, "there is no connection available") + } + if s, ok := bw.connSt[sc]; failfast && (!ok || s.s != connectivity.Ready) { + // If the returned sc is not ready and RPC is failfast, + // return error, and this RPC will fail. + return nil, nil, status.Errorf(codes.Unavailable, "there is no connection available") + } + } + + return sc, done, nil +} + +// connectivityStateEvaluator gets updated by addrConns when their +// states transition, based on which it evaluates the state of +// ClientConn. +type connectivityStateEvaluator struct { + mu sync.Mutex + numReady uint64 // Number of addrConns in ready state. + numConnecting uint64 // Number of addrConns in connecting state. + numTransientFailure uint64 // Number of addrConns in transientFailure. +} + +// recordTransition records state change happening in every subConn and based on +// that it evaluates what aggregated state should be. +// It can only transition between Ready, Connecting and TransientFailure. Other states, +// Idle and Shutdown are transitioned into by ClientConn; in the beginning of the connection +// before any subConn is created ClientConn is in idle state. In the end when ClientConn +// closes it is in Shutdown state. +// TODO Note that in later releases, a ClientConn with no activity will be put into an Idle state. +func (cse *connectivityStateEvaluator) recordTransition(oldState, newState connectivity.State) connectivity.State { + cse.mu.Lock() + defer cse.mu.Unlock() + + // Update counters. + for idx, state := range []connectivity.State{oldState, newState} { + updateVal := 2*uint64(idx) - 1 // -1 for oldState and +1 for new. + switch state { + case connectivity.Ready: + cse.numReady += updateVal + case connectivity.Connecting: + cse.numConnecting += updateVal + case connectivity.TransientFailure: + cse.numTransientFailure += updateVal + } + } + + // Evaluate. + if cse.numReady > 0 { + return connectivity.Ready + } + if cse.numConnecting > 0 { + return connectivity.Connecting + } + return connectivity.TransientFailure +} diff --git a/vendor/google.golang.org/grpc/call.go b/vendor/google.golang.org/grpc/call.go new file mode 100644 index 00000000000..f73b7d5528f --- /dev/null +++ b/vendor/google.golang.org/grpc/call.go @@ -0,0 +1,93 @@ +/* + * + * Copyright 2014 gRPC 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 grpc + +import ( + "golang.org/x/net/context" +) + +// Invoke sends the RPC request on the wire and returns after response is +// received. This is typically called by generated code. +// +// All errors returned by Invoke are compatible with the status package. +func (cc *ClientConn) Invoke(ctx context.Context, method string, args, reply interface{}, opts ...CallOption) error { + // allow interceptor to see all applicable call options, which means those + // configured as defaults from dial option as well as per-call options + opts = combine(cc.dopts.callOptions, opts) + + if cc.dopts.unaryInt != nil { + return cc.dopts.unaryInt(ctx, method, args, reply, cc, invoke, opts...) + } + return invoke(ctx, method, args, reply, cc, opts...) +} + +func combine(o1 []CallOption, o2 []CallOption) []CallOption { + // we don't use append because o1 could have extra capacity whose + // elements would be overwritten, which could cause inadvertent + // sharing (and race connditions) between concurrent calls + if len(o1) == 0 { + return o2 + } else if len(o2) == 0 { + return o1 + } + ret := make([]CallOption, len(o1)+len(o2)) + copy(ret, o1) + copy(ret[len(o1):], o2) + return ret +} + +// Invoke sends the RPC request on the wire and returns after response is +// received. This is typically called by generated code. +// +// DEPRECATED: Use ClientConn.Invoke instead. +func Invoke(ctx context.Context, method string, args, reply interface{}, cc *ClientConn, opts ...CallOption) error { + return cc.Invoke(ctx, method, args, reply, opts...) +} + +var unaryStreamDesc = &StreamDesc{ServerStreams: false, ClientStreams: false} + +func invoke(ctx context.Context, method string, req, reply interface{}, cc *ClientConn, opts ...CallOption) error { + // TODO: implement retries in clientStream and make this simply + // newClientStream, SendMsg, RecvMsg. + firstAttempt := true + for { + csInt, err := newClientStream(ctx, unaryStreamDesc, cc, method, opts...) + if err != nil { + return err + } + cs := csInt.(*clientStream) + if err := cs.SendMsg(req); err != nil { + if !cs.c.failFast && cs.attempt.s.Unprocessed() && firstAttempt { + // TODO: Add a field to header for grpc-transparent-retry-attempts + firstAttempt = false + continue + } + return err + } + if err := cs.RecvMsg(reply); err != nil { + if !cs.c.failFast && cs.attempt.s.Unprocessed() && firstAttempt { + // TODO: Add a field to header for grpc-transparent-retry-attempts + firstAttempt = false + continue + } + return err + } + return nil + } +} diff --git a/vendor/google.golang.org/grpc/channelz/funcs.go b/vendor/google.golang.org/grpc/channelz/funcs.go new file mode 100644 index 00000000000..586a0336b47 --- /dev/null +++ b/vendor/google.golang.org/grpc/channelz/funcs.go @@ -0,0 +1,573 @@ +/* + * + * Copyright 2018 gRPC 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 channelz defines APIs for enabling channelz service, entry +// registration/deletion, and accessing channelz data. It also defines channelz +// metric struct formats. +// +// All APIs in this package are experimental. +package channelz + +import ( + "sort" + "sync" + "sync/atomic" + + "google.golang.org/grpc/grpclog" +) + +var ( + db dbWrapper + idGen idGenerator + // EntryPerPage defines the number of channelz entries to be shown on a web page. + EntryPerPage = 50 + curState int32 +) + +// TurnOn turns on channelz data collection. +func TurnOn() { + if !IsOn() { + NewChannelzStorage() + atomic.StoreInt32(&curState, 1) + } +} + +// IsOn returns whether channelz data collection is on. +func IsOn() bool { + return atomic.CompareAndSwapInt32(&curState, 1, 1) +} + +// dbWarpper wraps around a reference to internal channelz data storage, and +// provide synchronized functionality to set and get the reference. +type dbWrapper struct { + mu sync.RWMutex + DB *channelMap +} + +func (d *dbWrapper) set(db *channelMap) { + d.mu.Lock() + d.DB = db + d.mu.Unlock() +} + +func (d *dbWrapper) get() *channelMap { + d.mu.RLock() + defer d.mu.RUnlock() + return d.DB +} + +// NewChannelzStorage initializes channelz data storage and id generator. +// +// Note: This function is exported for testing purpose only. User should not call +// it in most cases. +func NewChannelzStorage() { + db.set(&channelMap{ + topLevelChannels: make(map[int64]struct{}), + channels: make(map[int64]*channel), + listenSockets: make(map[int64]*listenSocket), + normalSockets: make(map[int64]*normalSocket), + servers: make(map[int64]*server), + subChannels: make(map[int64]*subChannel), + }) + idGen.reset() +} + +// GetTopChannels returns a slice of top channel's ChannelMetric, along with a +// boolean indicating whether there's more top channels to be queried for. +// +// The arg id specifies that only top channel with id at or above it will be included +// in the result. The returned slice is up to a length of EntryPerPage, and is +// sorted in ascending id order. +func GetTopChannels(id int64) ([]*ChannelMetric, bool) { + return db.get().GetTopChannels(id) +} + +// GetServers returns a slice of server's ServerMetric, along with a +// boolean indicating whether there's more servers to be queried for. +// +// The arg id specifies that only server with id at or above it will be included +// in the result. The returned slice is up to a length of EntryPerPage, and is +// sorted in ascending id order. +func GetServers(id int64) ([]*ServerMetric, bool) { + return db.get().GetServers(id) +} + +// GetServerSockets returns a slice of server's (identified by id) normal socket's +// SocketMetric, along with a boolean indicating whether there's more sockets to +// be queried for. +// +// The arg startID specifies that only sockets with id at or above it will be +// included in the result. The returned slice is up to a length of EntryPerPage, +// and is sorted in ascending id order. +func GetServerSockets(id int64, startID int64) ([]*SocketMetric, bool) { + return db.get().GetServerSockets(id, startID) +} + +// GetChannel returns the ChannelMetric for the channel (identified by id). +func GetChannel(id int64) *ChannelMetric { + return db.get().GetChannel(id) +} + +// GetSubChannel returns the SubChannelMetric for the subchannel (identified by id). +func GetSubChannel(id int64) *SubChannelMetric { + return db.get().GetSubChannel(id) +} + +// GetSocket returns the SocketInternalMetric for the socket (identified by id). +func GetSocket(id int64) *SocketMetric { + return db.get().GetSocket(id) +} + +// RegisterChannel registers the given channel c in channelz database with ref +// as its reference name, and add it to the child list of its parent (identified +// by pid). pid = 0 means no parent. It returns the unique channelz tracking id +// assigned to this channel. +func RegisterChannel(c Channel, pid int64, ref string) int64 { + id := idGen.genID() + cn := &channel{ + refName: ref, + c: c, + subChans: make(map[int64]string), + nestedChans: make(map[int64]string), + id: id, + pid: pid, + } + if pid == 0 { + db.get().addChannel(id, cn, true, pid, ref) + } else { + db.get().addChannel(id, cn, false, pid, ref) + } + return id +} + +// RegisterSubChannel registers the given channel c in channelz database with ref +// as its reference name, and add it to the child list of its parent (identified +// by pid). It returns the unique channelz tracking id assigned to this subchannel. +func RegisterSubChannel(c Channel, pid int64, ref string) int64 { + if pid == 0 { + grpclog.Error("a SubChannel's parent id cannot be 0") + return 0 + } + id := idGen.genID() + sc := &subChannel{ + refName: ref, + c: c, + sockets: make(map[int64]string), + id: id, + pid: pid, + } + db.get().addSubChannel(id, sc, pid, ref) + return id +} + +// RegisterServer registers the given server s in channelz database. It returns +// the unique channelz tracking id assigned to this server. +func RegisterServer(s Server, ref string) int64 { + id := idGen.genID() + svr := &server{ + refName: ref, + s: s, + sockets: make(map[int64]string), + listenSockets: make(map[int64]string), + id: id, + } + db.get().addServer(id, svr) + return id +} + +// RegisterListenSocket registers the given listen socket s in channelz database +// with ref as its reference name, and add it to the child list of its parent +// (identified by pid). It returns the unique channelz tracking id assigned to +// this listen socket. +func RegisterListenSocket(s Socket, pid int64, ref string) int64 { + if pid == 0 { + grpclog.Error("a ListenSocket's parent id cannot be 0") + return 0 + } + id := idGen.genID() + ls := &listenSocket{refName: ref, s: s, id: id, pid: pid} + db.get().addListenSocket(id, ls, pid, ref) + return id +} + +// RegisterNormalSocket registers the given normal socket s in channelz database +// with ref as its reference name, and add it to the child list of its parent +// (identified by pid). It returns the unique channelz tracking id assigned to +// this normal socket. +func RegisterNormalSocket(s Socket, pid int64, ref string) int64 { + if pid == 0 { + grpclog.Error("a NormalSocket's parent id cannot be 0") + return 0 + } + id := idGen.genID() + ns := &normalSocket{refName: ref, s: s, id: id, pid: pid} + db.get().addNormalSocket(id, ns, pid, ref) + return id +} + +// RemoveEntry removes an entry with unique channelz trakcing id to be id from +// channelz database. +func RemoveEntry(id int64) { + db.get().removeEntry(id) +} + +// channelMap is the storage data structure for channelz. +// Methods of channelMap can be divided in two two categories with respect to locking. +// 1. Methods acquire the global lock. +// 2. Methods that can only be called when global lock is held. +// A second type of method need always to be called inside a first type of method. +type channelMap struct { + mu sync.RWMutex + topLevelChannels map[int64]struct{} + servers map[int64]*server + channels map[int64]*channel + subChannels map[int64]*subChannel + listenSockets map[int64]*listenSocket + normalSockets map[int64]*normalSocket +} + +func (c *channelMap) addServer(id int64, s *server) { + c.mu.Lock() + s.cm = c + c.servers[id] = s + c.mu.Unlock() +} + +func (c *channelMap) addChannel(id int64, cn *channel, isTopChannel bool, pid int64, ref string) { + c.mu.Lock() + cn.cm = c + c.channels[id] = cn + if isTopChannel { + c.topLevelChannels[id] = struct{}{} + } else { + c.findEntry(pid).addChild(id, cn) + } + c.mu.Unlock() +} + +func (c *channelMap) addSubChannel(id int64, sc *subChannel, pid int64, ref string) { + c.mu.Lock() + sc.cm = c + c.subChannels[id] = sc + c.findEntry(pid).addChild(id, sc) + c.mu.Unlock() +} + +func (c *channelMap) addListenSocket(id int64, ls *listenSocket, pid int64, ref string) { + c.mu.Lock() + ls.cm = c + c.listenSockets[id] = ls + c.findEntry(pid).addChild(id, ls) + c.mu.Unlock() +} + +func (c *channelMap) addNormalSocket(id int64, ns *normalSocket, pid int64, ref string) { + c.mu.Lock() + ns.cm = c + c.normalSockets[id] = ns + c.findEntry(pid).addChild(id, ns) + c.mu.Unlock() +} + +// removeEntry triggers the removal of an entry, which may not indeed delete the +// entry, if it has to wait on the deletion of its children, or may lead to a chain +// of entry deletion. For example, deleting the last socket of a gracefully shutting +// down server will lead to the server being also deleted. +func (c *channelMap) removeEntry(id int64) { + c.mu.Lock() + c.findEntry(id).triggerDelete() + c.mu.Unlock() +} + +// c.mu must be held by the caller. +func (c *channelMap) findEntry(id int64) entry { + var v entry + var ok bool + if v, ok = c.channels[id]; ok { + return v + } + if v, ok = c.subChannels[id]; ok { + return v + } + if v, ok = c.servers[id]; ok { + return v + } + if v, ok = c.listenSockets[id]; ok { + return v + } + if v, ok = c.normalSockets[id]; ok { + return v + } + return &dummyEntry{idNotFound: id} +} + +// c.mu must be held by the caller +// deleteEntry simply deletes an entry from the channelMap. Before calling this +// method, caller must check this entry is ready to be deleted, i.e removeEntry() +// has been called on it, and no children still exist. +// Conditionals are ordered by the expected frequency of deletion of each entity +// type, in order to optimize performance. +func (c *channelMap) deleteEntry(id int64) { + var ok bool + if _, ok = c.normalSockets[id]; ok { + delete(c.normalSockets, id) + return + } + if _, ok = c.subChannels[id]; ok { + delete(c.subChannels, id) + return + } + if _, ok = c.channels[id]; ok { + delete(c.channels, id) + delete(c.topLevelChannels, id) + return + } + if _, ok = c.listenSockets[id]; ok { + delete(c.listenSockets, id) + return + } + if _, ok = c.servers[id]; ok { + delete(c.servers, id) + return + } +} + +type int64Slice []int64 + +func (s int64Slice) Len() int { return len(s) } +func (s int64Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] } +func (s int64Slice) Less(i, j int) bool { return s[i] < s[j] } + +func copyMap(m map[int64]string) map[int64]string { + n := make(map[int64]string) + for k, v := range m { + n[k] = v + } + return n +} + +func min(a, b int) int { + if a < b { + return a + } + return b +} + +func (c *channelMap) GetTopChannels(id int64) ([]*ChannelMetric, bool) { + c.mu.RLock() + l := len(c.topLevelChannels) + ids := make([]int64, 0, l) + cns := make([]*channel, 0, min(l, EntryPerPage)) + + for k := range c.topLevelChannels { + ids = append(ids, k) + } + sort.Sort(int64Slice(ids)) + idx := sort.Search(len(ids), func(i int) bool { return ids[i] >= id }) + count := 0 + var end bool + var t []*ChannelMetric + for i, v := range ids[idx:] { + if count == EntryPerPage { + break + } + if cn, ok := c.channels[v]; ok { + cns = append(cns, cn) + t = append(t, &ChannelMetric{ + NestedChans: copyMap(cn.nestedChans), + SubChans: copyMap(cn.subChans), + }) + count++ + } + if i == len(ids[idx:])-1 { + end = true + break + } + } + c.mu.RUnlock() + if count == 0 { + end = true + } + + for i, cn := range cns { + t[i].ChannelData = cn.c.ChannelzMetric() + t[i].ID = cn.id + t[i].RefName = cn.refName + } + return t, end +} + +func (c *channelMap) GetServers(id int64) ([]*ServerMetric, bool) { + c.mu.RLock() + l := len(c.servers) + ids := make([]int64, 0, l) + ss := make([]*server, 0, min(l, EntryPerPage)) + for k := range c.servers { + ids = append(ids, k) + } + sort.Sort(int64Slice(ids)) + idx := sort.Search(len(ids), func(i int) bool { return ids[i] >= id }) + count := 0 + var end bool + var s []*ServerMetric + for i, v := range ids[idx:] { + if count == EntryPerPage { + break + } + if svr, ok := c.servers[v]; ok { + ss = append(ss, svr) + s = append(s, &ServerMetric{ + ListenSockets: copyMap(svr.listenSockets), + }) + count++ + } + if i == len(ids[idx:])-1 { + end = true + break + } + } + c.mu.RUnlock() + if count == 0 { + end = true + } + + for i, svr := range ss { + s[i].ServerData = svr.s.ChannelzMetric() + s[i].ID = svr.id + s[i].RefName = svr.refName + } + return s, end +} + +func (c *channelMap) GetServerSockets(id int64, startID int64) ([]*SocketMetric, bool) { + var svr *server + var ok bool + c.mu.RLock() + if svr, ok = c.servers[id]; !ok { + // server with id doesn't exist. + c.mu.RUnlock() + return nil, true + } + svrskts := svr.sockets + l := len(svrskts) + ids := make([]int64, 0, l) + sks := make([]*normalSocket, 0, min(l, EntryPerPage)) + for k := range svrskts { + ids = append(ids, k) + } + sort.Sort((int64Slice(ids))) + idx := sort.Search(len(ids), func(i int) bool { return ids[i] >= id }) + count := 0 + var end bool + for i, v := range ids[idx:] { + if count == EntryPerPage { + break + } + if ns, ok := c.normalSockets[v]; ok { + sks = append(sks, ns) + count++ + } + if i == len(ids[idx:])-1 { + end = true + break + } + } + c.mu.RUnlock() + if count == 0 { + end = true + } + var s []*SocketMetric + for _, ns := range sks { + sm := &SocketMetric{} + sm.SocketData = ns.s.ChannelzMetric() + sm.ID = ns.id + sm.RefName = ns.refName + s = append(s, sm) + } + return s, end +} + +func (c *channelMap) GetChannel(id int64) *ChannelMetric { + cm := &ChannelMetric{} + var cn *channel + var ok bool + c.mu.RLock() + if cn, ok = c.channels[id]; !ok { + // channel with id doesn't exist. + c.mu.RUnlock() + return nil + } + cm.NestedChans = copyMap(cn.nestedChans) + cm.SubChans = copyMap(cn.subChans) + c.mu.RUnlock() + cm.ChannelData = cn.c.ChannelzMetric() + cm.ID = cn.id + cm.RefName = cn.refName + return cm +} + +func (c *channelMap) GetSubChannel(id int64) *SubChannelMetric { + cm := &SubChannelMetric{} + var sc *subChannel + var ok bool + c.mu.RLock() + if sc, ok = c.subChannels[id]; !ok { + // subchannel with id doesn't exist. + c.mu.RUnlock() + return nil + } + cm.Sockets = copyMap(sc.sockets) + c.mu.RUnlock() + cm.ChannelData = sc.c.ChannelzMetric() + cm.ID = sc.id + cm.RefName = sc.refName + return cm +} + +func (c *channelMap) GetSocket(id int64) *SocketMetric { + sm := &SocketMetric{} + c.mu.RLock() + if ls, ok := c.listenSockets[id]; ok { + c.mu.RUnlock() + sm.SocketData = ls.s.ChannelzMetric() + sm.ID = ls.id + sm.RefName = ls.refName + return sm + } + if ns, ok := c.normalSockets[id]; ok { + c.mu.RUnlock() + sm.SocketData = ns.s.ChannelzMetric() + sm.ID = ns.id + sm.RefName = ns.refName + return sm + } + c.mu.RUnlock() + return nil +} + +type idGenerator struct { + id int64 +} + +func (i *idGenerator) reset() { + atomic.StoreInt64(&i.id, 0) +} + +func (i *idGenerator) genID() int64 { + return atomic.AddInt64(&i.id, 1) +} diff --git a/vendor/google.golang.org/grpc/channelz/types.go b/vendor/google.golang.org/grpc/channelz/types.go new file mode 100644 index 00000000000..153d75340e4 --- /dev/null +++ b/vendor/google.golang.org/grpc/channelz/types.go @@ -0,0 +1,418 @@ +/* + * + * Copyright 2018 gRPC 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 channelz + +import ( + "net" + "time" + + "google.golang.org/grpc/connectivity" + "google.golang.org/grpc/grpclog" +) + +// entry represents a node in the channelz database. +type entry interface { + // addChild adds a child e, whose channelz id is id to child list + addChild(id int64, e entry) + // deleteChild deletes a child with channelz id to be id from child list + deleteChild(id int64) + // triggerDelete tries to delete self from channelz database. However, if child + // list is not empty, then deletion from the database is on hold until the last + // child is deleted from database. + triggerDelete() + // deleteSelfIfReady check whether triggerDelete() has been called before, and whether child + // list is now empty. If both conditions are met, then delete self from database. + deleteSelfIfReady() +} + +// dummyEntry is a fake entry to handle entry not found case. +type dummyEntry struct { + idNotFound int64 +} + +func (d *dummyEntry) addChild(id int64, e entry) { + // Note: It is possible for a normal program to reach here under race condition. + // For example, there could be a race between ClientConn.Close() info being propagated + // to addrConn and http2Client. ClientConn.Close() cancel the context and result + // in http2Client to error. The error info is then caught by transport monitor + // and before addrConn.tearDown() is called in side ClientConn.Close(). Therefore, + // the addrConn will create a new transport. And when registering the new transport in + // channelz, its parent addrConn could have already been torn down and deleted + // from channelz tracking, and thus reach the code here. + grpclog.Infof("attempt to add child of type %T with id %d to a parent (id=%d) that doesn't currently exist", e, id, d.idNotFound) +} + +func (d *dummyEntry) deleteChild(id int64) { + // It is possible for a normal program to reach here under race condition. + // Refer to the example described in addChild(). + grpclog.Infof("attempt to delete child with id %d from a parent (id=%d) that doesn't currently exist", id, d.idNotFound) +} + +func (d *dummyEntry) triggerDelete() { + grpclog.Warningf("attempt to delete an entry (id=%d) that doesn't currently exist", d.idNotFound) +} + +func (*dummyEntry) deleteSelfIfReady() { + // code should not reach here. deleteSelfIfReady is always called on an existing entry. +} + +// ChannelMetric defines the info channelz provides for a specific Channel, which +// includes ChannelInternalMetric and channelz-specific data, such as channelz id, +// child list, etc. +type ChannelMetric struct { + // ID is the channelz id of this channel. + ID int64 + // RefName is the human readable reference string of this channel. + RefName string + // ChannelData contains channel internal metric reported by the channel through + // ChannelzMetric(). + ChannelData *ChannelInternalMetric + // NestedChans tracks the nested channel type children of this channel in the format of + // a map from nested channel channelz id to corresponding reference string. + NestedChans map[int64]string + // SubChans tracks the subchannel type children of this channel in the format of a + // map from subchannel channelz id to corresponding reference string. + SubChans map[int64]string + // Sockets tracks the socket type children of this channel in the format of a map + // from socket channelz id to corresponding reference string. + // Note current grpc implementation doesn't allow channel having sockets directly, + // therefore, this is field is unused. + Sockets map[int64]string +} + +// SubChannelMetric defines the info channelz provides for a specific SubChannel, +// which includes ChannelInternalMetric and channelz-specific data, such as +// channelz id, child list, etc. +type SubChannelMetric struct { + // ID is the channelz id of this subchannel. + ID int64 + // RefName is the human readable reference string of this subchannel. + RefName string + // ChannelData contains subchannel internal metric reported by the subchannel + // through ChannelzMetric(). + ChannelData *ChannelInternalMetric + // NestedChans tracks the nested channel type children of this subchannel in the format of + // a map from nested channel channelz id to corresponding reference string. + // Note current grpc implementation doesn't allow subchannel to have nested channels + // as children, therefore, this field is unused. + NestedChans map[int64]string + // SubChans tracks the subchannel type children of this subchannel in the format of a + // map from subchannel channelz id to corresponding reference string. + // Note current grpc implementation doesn't allow subchannel to have subchannels + // as children, therefore, this field is unused. + SubChans map[int64]string + // Sockets tracks the socket type children of this subchannel in the format of a map + // from socket channelz id to corresponding reference string. + Sockets map[int64]string +} + +// ChannelInternalMetric defines the struct that the implementor of Channel interface +// should return from ChannelzMetric(). +type ChannelInternalMetric struct { + // current connectivity state of the channel. + State connectivity.State + // The target this channel originally tried to connect to. May be absent + Target string + // The number of calls started on the channel. + CallsStarted int64 + // The number of calls that have completed with an OK status. + CallsSucceeded int64 + // The number of calls that have a completed with a non-OK status. + CallsFailed int64 + // The last time a call was started on the channel. + LastCallStartedTimestamp time.Time + //TODO: trace +} + +// Channel is the interface that should be satisfied in order to be tracked by +// channelz as Channel or SubChannel. +type Channel interface { + ChannelzMetric() *ChannelInternalMetric +} + +type channel struct { + refName string + c Channel + closeCalled bool + nestedChans map[int64]string + subChans map[int64]string + id int64 + pid int64 + cm *channelMap +} + +func (c *channel) addChild(id int64, e entry) { + switch v := e.(type) { + case *subChannel: + c.subChans[id] = v.refName + case *channel: + c.nestedChans[id] = v.refName + default: + grpclog.Errorf("cannot add a child (id = %d) of type %T to a channel", id, e) + } +} + +func (c *channel) deleteChild(id int64) { + delete(c.subChans, id) + delete(c.nestedChans, id) + c.deleteSelfIfReady() +} + +func (c *channel) triggerDelete() { + c.closeCalled = true + c.deleteSelfIfReady() +} + +func (c *channel) deleteSelfIfReady() { + if !c.closeCalled || len(c.subChans)+len(c.nestedChans) != 0 { + return + } + c.cm.deleteEntry(c.id) + // not top channel + if c.pid != 0 { + c.cm.findEntry(c.pid).deleteChild(c.id) + } +} + +type subChannel struct { + refName string + c Channel + closeCalled bool + sockets map[int64]string + id int64 + pid int64 + cm *channelMap +} + +func (sc *subChannel) addChild(id int64, e entry) { + if v, ok := e.(*normalSocket); ok { + sc.sockets[id] = v.refName + } else { + grpclog.Errorf("cannot add a child (id = %d) of type %T to a subChannel", id, e) + } +} + +func (sc *subChannel) deleteChild(id int64) { + delete(sc.sockets, id) + sc.deleteSelfIfReady() +} + +func (sc *subChannel) triggerDelete() { + sc.closeCalled = true + sc.deleteSelfIfReady() +} + +func (sc *subChannel) deleteSelfIfReady() { + if !sc.closeCalled || len(sc.sockets) != 0 { + return + } + sc.cm.deleteEntry(sc.id) + sc.cm.findEntry(sc.pid).deleteChild(sc.id) +} + +// SocketMetric defines the info channelz provides for a specific Socket, which +// includes SocketInternalMetric and channelz-specific data, such as channelz id, etc. +type SocketMetric struct { + // ID is the channelz id of this socket. + ID int64 + // RefName is the human readable reference string of this socket. + RefName string + // SocketData contains socket internal metric reported by the socket through + // ChannelzMetric(). + SocketData *SocketInternalMetric +} + +// SocketInternalMetric defines the struct that the implementor of Socket interface +// should return from ChannelzMetric(). +type SocketInternalMetric struct { + // The number of streams that have been started. + StreamsStarted int64 + // The number of streams that have ended successfully: + // On client side, receiving frame with eos bit set. + // On server side, sending frame with eos bit set. + StreamsSucceeded int64 + // The number of streams that have ended unsuccessfully: + // On client side, termination without receiving frame with eos bit set. + // On server side, termination without sending frame with eos bit set. + StreamsFailed int64 + // The number of messages successfully sent on this socket. + MessagesSent int64 + MessagesReceived int64 + // The number of keep alives sent. This is typically implemented with HTTP/2 + // ping messages. + KeepAlivesSent int64 + // The last time a stream was created by this endpoint. Usually unset for + // servers. + LastLocalStreamCreatedTimestamp time.Time + // The last time a stream was created by the remote endpoint. Usually unset + // for clients. + LastRemoteStreamCreatedTimestamp time.Time + // The last time a message was sent by this endpoint. + LastMessageSentTimestamp time.Time + // The last time a message was received by this endpoint. + LastMessageReceivedTimestamp time.Time + // The amount of window, granted to the local endpoint by the remote endpoint. + // This may be slightly out of date due to network latency. This does NOT + // include stream level or TCP level flow control info. + LocalFlowControlWindow int64 + // The amount of window, granted to the remote endpoint by the local endpoint. + // This may be slightly out of date due to network latency. This does NOT + // include stream level or TCP level flow control info. + RemoteFlowControlWindow int64 + // The locally bound address. + LocalAddr net.Addr + // The remote bound address. May be absent. + RemoteAddr net.Addr + // Optional, represents the name of the remote endpoint, if different than + // the original target name. + RemoteName string + //TODO: socket options + //TODO: Security +} + +// Socket is the interface that should be satisfied in order to be tracked by +// channelz as Socket. +type Socket interface { + ChannelzMetric() *SocketInternalMetric +} + +type listenSocket struct { + refName string + s Socket + id int64 + pid int64 + cm *channelMap +} + +func (ls *listenSocket) addChild(id int64, e entry) { + grpclog.Errorf("cannot add a child (id = %d) of type %T to a listen socket", id, e) +} + +func (ls *listenSocket) deleteChild(id int64) { + grpclog.Errorf("cannot delete a child (id = %d) from a listen socket", id) +} + +func (ls *listenSocket) triggerDelete() { + ls.cm.deleteEntry(ls.id) + ls.cm.findEntry(ls.pid).deleteChild(ls.id) +} + +func (ls *listenSocket) deleteSelfIfReady() { + grpclog.Errorf("cannot call deleteSelfIfReady on a listen socket") +} + +type normalSocket struct { + refName string + s Socket + id int64 + pid int64 + cm *channelMap +} + +func (ns *normalSocket) addChild(id int64, e entry) { + grpclog.Errorf("cannot add a child (id = %d) of type %T to a normal socket", id, e) +} + +func (ns *normalSocket) deleteChild(id int64) { + grpclog.Errorf("cannot delete a child (id = %d) from a normal socket", id) +} + +func (ns *normalSocket) triggerDelete() { + ns.cm.deleteEntry(ns.id) + ns.cm.findEntry(ns.pid).deleteChild(ns.id) +} + +func (ns *normalSocket) deleteSelfIfReady() { + grpclog.Errorf("cannot call deleteSelfIfReady on a normal socket") +} + +// ServerMetric defines the info channelz provides for a specific Server, which +// includes ServerInternalMetric and channelz-specific data, such as channelz id, +// child list, etc. +type ServerMetric struct { + // ID is the channelz id of this server. + ID int64 + // RefName is the human readable reference string of this server. + RefName string + // ServerData contains server internal metric reported by the server through + // ChannelzMetric(). + ServerData *ServerInternalMetric + // ListenSockets tracks the listener socket type children of this server in the + // format of a map from socket channelz id to corresponding reference string. + ListenSockets map[int64]string +} + +// ServerInternalMetric defines the struct that the implementor of Server interface +// should return from ChannelzMetric(). +type ServerInternalMetric struct { + // The number of incoming calls started on the server. + CallsStarted int64 + // The number of incoming calls that have completed with an OK status. + CallsSucceeded int64 + // The number of incoming calls that have a completed with a non-OK status. + CallsFailed int64 + // The last time a call was started on the server. + LastCallStartedTimestamp time.Time + //TODO: trace +} + +// Server is the interface to be satisfied in order to be tracked by channelz as +// Server. +type Server interface { + ChannelzMetric() *ServerInternalMetric +} + +type server struct { + refName string + s Server + closeCalled bool + sockets map[int64]string + listenSockets map[int64]string + id int64 + cm *channelMap +} + +func (s *server) addChild(id int64, e entry) { + switch v := e.(type) { + case *normalSocket: + s.sockets[id] = v.refName + case *listenSocket: + s.listenSockets[id] = v.refName + default: + grpclog.Errorf("cannot add a child (id = %d) of type %T to a server", id, e) + } +} + +func (s *server) deleteChild(id int64) { + delete(s.sockets, id) + delete(s.listenSockets, id) + s.deleteSelfIfReady() +} + +func (s *server) triggerDelete() { + s.closeCalled = true + s.deleteSelfIfReady() +} + +func (s *server) deleteSelfIfReady() { + if !s.closeCalled || len(s.sockets)+len(s.listenSockets) != 0 { + return + } + s.cm.deleteEntry(s.id) +} diff --git a/vendor/google.golang.org/grpc/clientconn.go b/vendor/google.golang.org/grpc/clientconn.go new file mode 100644 index 00000000000..e8d95b43b74 --- /dev/null +++ b/vendor/google.golang.org/grpc/clientconn.go @@ -0,0 +1,1591 @@ +/* + * + * Copyright 2014 gRPC 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 grpc + +import ( + "errors" + "fmt" + "math" + "net" + "reflect" + "strings" + "sync" + "time" + + "golang.org/x/net/context" + "golang.org/x/net/trace" + "google.golang.org/grpc/balancer" + _ "google.golang.org/grpc/balancer/roundrobin" // To register roundrobin. + "google.golang.org/grpc/channelz" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/connectivity" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/keepalive" + "google.golang.org/grpc/resolver" + _ "google.golang.org/grpc/resolver/dns" // To register dns resolver. + _ "google.golang.org/grpc/resolver/passthrough" // To register passthrough resolver. + "google.golang.org/grpc/stats" + "google.golang.org/grpc/status" + "google.golang.org/grpc/transport" +) + +const ( + // minimum time to give a connection to complete + minConnectTimeout = 20 * time.Second +) + +var ( + // ErrClientConnClosing indicates that the operation is illegal because + // the ClientConn is closing. + // + // Deprecated: this error should not be relied upon by users; use the status + // code of Canceled instead. + ErrClientConnClosing = status.Error(codes.Canceled, "grpc: the client connection is closing") + // errConnDrain indicates that the connection starts to be drained and does not accept any new RPCs. + errConnDrain = errors.New("grpc: the connection is drained") + // errConnClosing indicates that the connection is closing. + errConnClosing = errors.New("grpc: the connection is closing") + // errConnUnavailable indicates that the connection is unavailable. + errConnUnavailable = errors.New("grpc: the connection is unavailable") + // errBalancerClosed indicates that the balancer is closed. + errBalancerClosed = errors.New("grpc: balancer is closed") + // We use an accessor so that minConnectTimeout can be + // atomically read and updated while testing. + getMinConnectTimeout = func() time.Duration { + return minConnectTimeout + } +) + +// The following errors are returned from Dial and DialContext +var ( + // errNoTransportSecurity indicates that there is no transport security + // being set for ClientConn. Users should either set one or explicitly + // call WithInsecure DialOption to disable security. + errNoTransportSecurity = errors.New("grpc: no transport security set (use grpc.WithInsecure() explicitly or set credentials)") + // errTransportCredentialsMissing indicates that users want to transmit security + // information (e.g., oauth2 token) which requires secure connection on an insecure + // connection. + errTransportCredentialsMissing = errors.New("grpc: the credentials require transport level security (use grpc.WithTransportCredentials() to set)") + // errCredentialsConflict indicates that grpc.WithTransportCredentials() + // and grpc.WithInsecure() are both called for a connection. + errCredentialsConflict = errors.New("grpc: transport credentials are set for an insecure connection (grpc.WithTransportCredentials() and grpc.WithInsecure() are both called)") + // errNetworkIO indicates that the connection is down due to some network I/O error. + errNetworkIO = errors.New("grpc: failed with network I/O error") +) + +// dialOptions configure a Dial call. dialOptions are set by the DialOption +// values passed to Dial. +type dialOptions struct { + unaryInt UnaryClientInterceptor + streamInt StreamClientInterceptor + cp Compressor + dc Decompressor + bs backoffStrategy + block bool + insecure bool + timeout time.Duration + scChan <-chan ServiceConfig + copts transport.ConnectOptions + callOptions []CallOption + // This is used by v1 balancer dial option WithBalancer to support v1 + // balancer, and also by WithBalancerName dial option. + balancerBuilder balancer.Builder + // This is to support grpclb. + resolverBuilder resolver.Builder + waitForHandshake bool + channelzParentID int64 + disableServiceConfig bool +} + +const ( + defaultClientMaxReceiveMessageSize = 1024 * 1024 * 4 + defaultClientMaxSendMessageSize = math.MaxInt32 +) + +// RegisterChannelz turns on channelz service. +// This is an EXPERIMENTAL API. +func RegisterChannelz() { + channelz.TurnOn() +} + +// DialOption configures how we set up the connection. +type DialOption func(*dialOptions) + +// WithWaitForHandshake blocks until the initial settings frame is received from the +// server before assigning RPCs to the connection. +// Experimental API. +func WithWaitForHandshake() DialOption { + return func(o *dialOptions) { + o.waitForHandshake = true + } +} + +// WithWriteBufferSize lets you set the size of write buffer, this determines how much data can be batched +// before doing a write on the wire. +func WithWriteBufferSize(s int) DialOption { + return func(o *dialOptions) { + o.copts.WriteBufferSize = s + } +} + +// WithReadBufferSize lets you set the size of read buffer, this determines how much data can be read at most +// for each read syscall. +func WithReadBufferSize(s int) DialOption { + return func(o *dialOptions) { + o.copts.ReadBufferSize = s + } +} + +// WithInitialWindowSize returns a DialOption which sets the value for initial window size on a stream. +// The lower bound for window size is 64K and any value smaller than that will be ignored. +func WithInitialWindowSize(s int32) DialOption { + return func(o *dialOptions) { + o.copts.InitialWindowSize = s + } +} + +// WithInitialConnWindowSize returns a DialOption which sets the value for initial window size on a connection. +// The lower bound for window size is 64K and any value smaller than that will be ignored. +func WithInitialConnWindowSize(s int32) DialOption { + return func(o *dialOptions) { + o.copts.InitialConnWindowSize = s + } +} + +// WithMaxMsgSize returns a DialOption which sets the maximum message size the client can receive. +// +// Deprecated: use WithDefaultCallOptions(MaxCallRecvMsgSize(s)) instead. +func WithMaxMsgSize(s int) DialOption { + return WithDefaultCallOptions(MaxCallRecvMsgSize(s)) +} + +// WithDefaultCallOptions returns a DialOption which sets the default CallOptions for calls over the connection. +func WithDefaultCallOptions(cos ...CallOption) DialOption { + return func(o *dialOptions) { + o.callOptions = append(o.callOptions, cos...) + } +} + +// WithCodec returns a DialOption which sets a codec for message marshaling and unmarshaling. +// +// Deprecated: use WithDefaultCallOptions(CallCustomCodec(c)) instead. +func WithCodec(c Codec) DialOption { + return WithDefaultCallOptions(CallCustomCodec(c)) +} + +// WithCompressor returns a DialOption which sets a Compressor to use for +// message compression. It has lower priority than the compressor set by +// the UseCompressor CallOption. +// +// Deprecated: use UseCompressor instead. +func WithCompressor(cp Compressor) DialOption { + return func(o *dialOptions) { + o.cp = cp + } +} + +// WithDecompressor returns a DialOption which sets a Decompressor to use for +// incoming message decompression. If incoming response messages are encoded +// using the decompressor's Type(), it will be used. Otherwise, the message +// encoding will be used to look up the compressor registered via +// encoding.RegisterCompressor, which will then be used to decompress the +// message. If no compressor is registered for the encoding, an Unimplemented +// status error will be returned. +// +// Deprecated: use encoding.RegisterCompressor instead. +func WithDecompressor(dc Decompressor) DialOption { + return func(o *dialOptions) { + o.dc = dc + } +} + +// WithBalancer returns a DialOption which sets a load balancer with the v1 API. +// Name resolver will be ignored if this DialOption is specified. +// +// Deprecated: use the new balancer APIs in balancer package and WithBalancerName. +func WithBalancer(b Balancer) DialOption { + return func(o *dialOptions) { + o.balancerBuilder = &balancerWrapperBuilder{ + b: b, + } + } +} + +// WithBalancerName sets the balancer that the ClientConn will be initialized +// with. Balancer registered with balancerName will be used. This function +// panics if no balancer was registered by balancerName. +// +// The balancer cannot be overridden by balancer option specified by service +// config. +// +// This is an EXPERIMENTAL API. +func WithBalancerName(balancerName string) DialOption { + builder := balancer.Get(balancerName) + if builder == nil { + panic(fmt.Sprintf("grpc.WithBalancerName: no balancer is registered for name %v", balancerName)) + } + return func(o *dialOptions) { + o.balancerBuilder = builder + } +} + +// withResolverBuilder is only for grpclb. +func withResolverBuilder(b resolver.Builder) DialOption { + return func(o *dialOptions) { + o.resolverBuilder = b + } +} + +// WithServiceConfig returns a DialOption which has a channel to read the service configuration. +// +// Deprecated: service config should be received through name resolver, as specified here. +// https://github.com/grpc/grpc/blob/master/doc/service_config.md +func WithServiceConfig(c <-chan ServiceConfig) DialOption { + return func(o *dialOptions) { + o.scChan = c + } +} + +// WithBackoffMaxDelay configures the dialer to use the provided maximum delay +// when backing off after failed connection attempts. +func WithBackoffMaxDelay(md time.Duration) DialOption { + return WithBackoffConfig(BackoffConfig{MaxDelay: md}) +} + +// WithBackoffConfig configures the dialer to use the provided backoff +// parameters after connection failures. +// +// Use WithBackoffMaxDelay until more parameters on BackoffConfig are opened up +// for use. +func WithBackoffConfig(b BackoffConfig) DialOption { + // Set defaults to ensure that provided BackoffConfig is valid and + // unexported fields get default values. + setDefaults(&b) + return withBackoff(b) +} + +// withBackoff sets the backoff strategy used for connectRetryNum after a +// failed connection attempt. +// +// This can be exported if arbitrary backoff strategies are allowed by gRPC. +func withBackoff(bs backoffStrategy) DialOption { + return func(o *dialOptions) { + o.bs = bs + } +} + +// WithBlock returns a DialOption which makes caller of Dial blocks until the underlying +// connection is up. Without this, Dial returns immediately and connecting the server +// happens in background. +func WithBlock() DialOption { + return func(o *dialOptions) { + o.block = true + } +} + +// WithInsecure returns a DialOption which disables transport security for this ClientConn. +// Note that transport security is required unless WithInsecure is set. +func WithInsecure() DialOption { + return func(o *dialOptions) { + o.insecure = true + } +} + +// WithTransportCredentials returns a DialOption which configures a +// connection level security credentials (e.g., TLS/SSL). +func WithTransportCredentials(creds credentials.TransportCredentials) DialOption { + return func(o *dialOptions) { + o.copts.TransportCredentials = creds + } +} + +// WithPerRPCCredentials returns a DialOption which sets +// credentials and places auth state on each outbound RPC. +func WithPerRPCCredentials(creds credentials.PerRPCCredentials) DialOption { + return func(o *dialOptions) { + o.copts.PerRPCCredentials = append(o.copts.PerRPCCredentials, creds) + } +} + +// WithTimeout returns a DialOption that configures a timeout for dialing a ClientConn +// initially. This is valid if and only if WithBlock() is present. +// +// Deprecated: use DialContext and context.WithTimeout instead. +func WithTimeout(d time.Duration) DialOption { + return func(o *dialOptions) { + o.timeout = d + } +} + +func withContextDialer(f func(context.Context, string) (net.Conn, error)) DialOption { + return func(o *dialOptions) { + o.copts.Dialer = f + } +} + +// WithDialer returns a DialOption that specifies a function to use for dialing network addresses. +// If FailOnNonTempDialError() is set to true, and an error is returned by f, gRPC checks the error's +// Temporary() method to decide if it should try to reconnect to the network address. +func WithDialer(f func(string, time.Duration) (net.Conn, error)) DialOption { + return withContextDialer( + func(ctx context.Context, addr string) (net.Conn, error) { + if deadline, ok := ctx.Deadline(); ok { + return f(addr, deadline.Sub(time.Now())) + } + return f(addr, 0) + }) +} + +// WithStatsHandler returns a DialOption that specifies the stats handler +// for all the RPCs and underlying network connections in this ClientConn. +func WithStatsHandler(h stats.Handler) DialOption { + return func(o *dialOptions) { + o.copts.StatsHandler = h + } +} + +// FailOnNonTempDialError returns a DialOption that specifies if gRPC fails on non-temporary dial errors. +// If f is true, and dialer returns a non-temporary error, gRPC will fail the connection to the network +// address and won't try to reconnect. +// The default value of FailOnNonTempDialError is false. +// This is an EXPERIMENTAL API. +func FailOnNonTempDialError(f bool) DialOption { + return func(o *dialOptions) { + o.copts.FailOnNonTempDialError = f + } +} + +// WithUserAgent returns a DialOption that specifies a user agent string for all the RPCs. +func WithUserAgent(s string) DialOption { + return func(o *dialOptions) { + o.copts.UserAgent = s + } +} + +// WithKeepaliveParams returns a DialOption that specifies keepalive parameters for the client transport. +func WithKeepaliveParams(kp keepalive.ClientParameters) DialOption { + return func(o *dialOptions) { + o.copts.KeepaliveParams = kp + } +} + +// WithUnaryInterceptor returns a DialOption that specifies the interceptor for unary RPCs. +func WithUnaryInterceptor(f UnaryClientInterceptor) DialOption { + return func(o *dialOptions) { + o.unaryInt = f + } +} + +// WithStreamInterceptor returns a DialOption that specifies the interceptor for streaming RPCs. +func WithStreamInterceptor(f StreamClientInterceptor) DialOption { + return func(o *dialOptions) { + o.streamInt = f + } +} + +// WithAuthority returns a DialOption that specifies the value to be used as +// the :authority pseudo-header. This value only works with WithInsecure and +// has no effect if TransportCredentials are present. +func WithAuthority(a string) DialOption { + return func(o *dialOptions) { + o.copts.Authority = a + } +} + +// WithChannelzParentID returns a DialOption that specifies the channelz ID of current ClientConn's +// parent. This function is used in nested channel creation (e.g. grpclb dial). +func WithChannelzParentID(id int64) DialOption { + return func(o *dialOptions) { + o.channelzParentID = id + } +} + +// WithDisableServiceConfig returns a DialOption that causes grpc to ignore any +// service config provided by the resolver and provides a hint to the resolver +// to not fetch service configs. +func WithDisableServiceConfig() DialOption { + return func(o *dialOptions) { + o.disableServiceConfig = true + } +} + +// Dial creates a client connection to the given target. +func Dial(target string, opts ...DialOption) (*ClientConn, error) { + return DialContext(context.Background(), target, opts...) +} + +// DialContext creates a client connection to the given target. By default, it's +// a non-blocking dial (the function won't wait for connections to be +// established, and connecting happens in the background). To make it a blocking +// dial, use WithBlock() dial option. +// +// In the non-blocking case, the ctx does not act against the connection. It +// only controls the setup steps. +// +// In the blocking case, ctx can be used to cancel or expire the pending +// connection. Once this function returns, the cancellation and expiration of +// ctx will be noop. Users should call ClientConn.Close to terminate all the +// pending operations after this function returns. +// +// The target name syntax is defined in +// https://github.com/grpc/grpc/blob/master/doc/naming.md. +// e.g. to use dns resolver, a "dns:///" prefix should be applied to the target. +func DialContext(ctx context.Context, target string, opts ...DialOption) (conn *ClientConn, err error) { + cc := &ClientConn{ + target: target, + csMgr: &connectivityStateManager{}, + conns: make(map[*addrConn]struct{}), + + blockingpicker: newPickerWrapper(), + } + cc.ctx, cc.cancel = context.WithCancel(context.Background()) + + for _, opt := range opts { + opt(&cc.dopts) + } + + if channelz.IsOn() { + if cc.dopts.channelzParentID != 0 { + cc.channelzID = channelz.RegisterChannel(cc, cc.dopts.channelzParentID, target) + } else { + cc.channelzID = channelz.RegisterChannel(cc, 0, target) + } + } + + if !cc.dopts.insecure { + if cc.dopts.copts.TransportCredentials == nil { + return nil, errNoTransportSecurity + } + } else { + if cc.dopts.copts.TransportCredentials != nil { + return nil, errCredentialsConflict + } + for _, cd := range cc.dopts.copts.PerRPCCredentials { + if cd.RequireTransportSecurity() { + return nil, errTransportCredentialsMissing + } + } + } + + cc.mkp = cc.dopts.copts.KeepaliveParams + + if cc.dopts.copts.Dialer == nil { + cc.dopts.copts.Dialer = newProxyDialer( + func(ctx context.Context, addr string) (net.Conn, error) { + network, addr := parseDialTarget(addr) + return dialContext(ctx, network, addr) + }, + ) + } + + if cc.dopts.copts.UserAgent != "" { + cc.dopts.copts.UserAgent += " " + grpcUA + } else { + cc.dopts.copts.UserAgent = grpcUA + } + + if cc.dopts.timeout > 0 { + var cancel context.CancelFunc + ctx, cancel = context.WithTimeout(ctx, cc.dopts.timeout) + defer cancel() + } + + defer func() { + select { + case <-ctx.Done(): + conn, err = nil, ctx.Err() + default: + } + + if err != nil { + cc.Close() + } + }() + + scSet := false + if cc.dopts.scChan != nil { + // Try to get an initial service config. + select { + case sc, ok := <-cc.dopts.scChan: + if ok { + cc.sc = sc + scSet = true + } + default: + } + } + if cc.dopts.bs == nil { + cc.dopts.bs = DefaultBackoffConfig + } + if cc.dopts.resolverBuilder == nil { + // Only try to parse target when resolver builder is not already set. + cc.parsedTarget = parseTarget(cc.target) + grpclog.Infof("parsed scheme: %q", cc.parsedTarget.Scheme) + cc.dopts.resolverBuilder = resolver.Get(cc.parsedTarget.Scheme) + if cc.dopts.resolverBuilder == nil { + // If resolver builder is still nil, the parse target's scheme is + // not registered. Fallback to default resolver and set Endpoint to + // the original unparsed target. + grpclog.Infof("scheme %q not registered, fallback to default scheme", cc.parsedTarget.Scheme) + cc.parsedTarget = resolver.Target{ + Scheme: resolver.GetDefaultScheme(), + Endpoint: target, + } + cc.dopts.resolverBuilder = resolver.Get(cc.parsedTarget.Scheme) + } + } else { + cc.parsedTarget = resolver.Target{Endpoint: target} + } + creds := cc.dopts.copts.TransportCredentials + if creds != nil && creds.Info().ServerName != "" { + cc.authority = creds.Info().ServerName + } else if cc.dopts.insecure && cc.dopts.copts.Authority != "" { + cc.authority = cc.dopts.copts.Authority + } else { + // Use endpoint from "scheme://authority/endpoint" as the default + // authority for ClientConn. + cc.authority = cc.parsedTarget.Endpoint + } + + if cc.dopts.scChan != nil && !scSet { + // Blocking wait for the initial service config. + select { + case sc, ok := <-cc.dopts.scChan: + if ok { + cc.sc = sc + } + case <-ctx.Done(): + return nil, ctx.Err() + } + } + if cc.dopts.scChan != nil { + go cc.scWatcher() + } + + var credsClone credentials.TransportCredentials + if creds := cc.dopts.copts.TransportCredentials; creds != nil { + credsClone = creds.Clone() + } + cc.balancerBuildOpts = balancer.BuildOptions{ + DialCreds: credsClone, + Dialer: cc.dopts.copts.Dialer, + ChannelzParentID: cc.channelzID, + } + + // Build the resolver. + cc.resolverWrapper, err = newCCResolverWrapper(cc) + if err != nil { + return nil, fmt.Errorf("failed to build resolver: %v", err) + } + // Start the resolver wrapper goroutine after resolverWrapper is created. + // + // If the goroutine is started before resolverWrapper is ready, the + // following may happen: The goroutine sends updates to cc. cc forwards + // those to balancer. Balancer creates new addrConn. addrConn fails to + // connect, and calls resolveNow(). resolveNow() tries to use the non-ready + // resolverWrapper. + cc.resolverWrapper.start() + + // A blocking dial blocks until the clientConn is ready. + if cc.dopts.block { + for { + s := cc.GetState() + if s == connectivity.Ready { + break + } + if !cc.WaitForStateChange(ctx, s) { + // ctx got timeout or canceled. + return nil, ctx.Err() + } + } + } + + return cc, nil +} + +// connectivityStateManager keeps the connectivity.State of ClientConn. +// This struct will eventually be exported so the balancers can access it. +type connectivityStateManager struct { + mu sync.Mutex + state connectivity.State + notifyChan chan struct{} +} + +// updateState updates the connectivity.State of ClientConn. +// If there's a change it notifies goroutines waiting on state change to +// happen. +func (csm *connectivityStateManager) updateState(state connectivity.State) { + csm.mu.Lock() + defer csm.mu.Unlock() + if csm.state == connectivity.Shutdown { + return + } + if csm.state == state { + return + } + csm.state = state + if csm.notifyChan != nil { + // There are other goroutines waiting on this channel. + close(csm.notifyChan) + csm.notifyChan = nil + } +} + +func (csm *connectivityStateManager) getState() connectivity.State { + csm.mu.Lock() + defer csm.mu.Unlock() + return csm.state +} + +func (csm *connectivityStateManager) getNotifyChan() <-chan struct{} { + csm.mu.Lock() + defer csm.mu.Unlock() + if csm.notifyChan == nil { + csm.notifyChan = make(chan struct{}) + } + return csm.notifyChan +} + +// ClientConn represents a client connection to an RPC server. +type ClientConn struct { + ctx context.Context + cancel context.CancelFunc + + target string + parsedTarget resolver.Target + authority string + dopts dialOptions + csMgr *connectivityStateManager + + balancerBuildOpts balancer.BuildOptions + resolverWrapper *ccResolverWrapper + blockingpicker *pickerWrapper + + mu sync.RWMutex + sc ServiceConfig + scRaw string + conns map[*addrConn]struct{} + // Keepalive parameter can be updated if a GoAway is received. + mkp keepalive.ClientParameters + curBalancerName string + preBalancerName string // previous balancer name. + curAddresses []resolver.Address + balancerWrapper *ccBalancerWrapper + + channelzID int64 // channelz unique identification number + czmu sync.RWMutex + callsStarted int64 + callsSucceeded int64 + callsFailed int64 + lastCallStartedTime time.Time +} + +// WaitForStateChange waits until the connectivity.State of ClientConn changes from sourceState or +// ctx expires. A true value is returned in former case and false in latter. +// This is an EXPERIMENTAL API. +func (cc *ClientConn) WaitForStateChange(ctx context.Context, sourceState connectivity.State) bool { + ch := cc.csMgr.getNotifyChan() + if cc.csMgr.getState() != sourceState { + return true + } + select { + case <-ctx.Done(): + return false + case <-ch: + return true + } +} + +// GetState returns the connectivity.State of ClientConn. +// This is an EXPERIMENTAL API. +func (cc *ClientConn) GetState() connectivity.State { + return cc.csMgr.getState() +} + +func (cc *ClientConn) scWatcher() { + for { + select { + case sc, ok := <-cc.dopts.scChan: + if !ok { + return + } + cc.mu.Lock() + // TODO: load balance policy runtime change is ignored. + // We may revist this decision in the future. + cc.sc = sc + cc.scRaw = "" + cc.mu.Unlock() + case <-cc.ctx.Done(): + return + } + } +} + +func (cc *ClientConn) handleResolvedAddrs(addrs []resolver.Address, err error) { + cc.mu.Lock() + defer cc.mu.Unlock() + if cc.conns == nil { + // cc was closed. + return + } + + if reflect.DeepEqual(cc.curAddresses, addrs) { + return + } + + cc.curAddresses = addrs + + if cc.dopts.balancerBuilder == nil { + // Only look at balancer types and switch balancer if balancer dial + // option is not set. + var isGRPCLB bool + for _, a := range addrs { + if a.Type == resolver.GRPCLB { + isGRPCLB = true + break + } + } + var newBalancerName string + if isGRPCLB { + newBalancerName = grpclbName + } else { + // Address list doesn't contain grpclb address. Try to pick a + // non-grpclb balancer. + newBalancerName = cc.curBalancerName + // If current balancer is grpclb, switch to the previous one. + if newBalancerName == grpclbName { + newBalancerName = cc.preBalancerName + } + // The following could be true in two cases: + // - the first time handling resolved addresses + // (curBalancerName="") + // - the first time handling non-grpclb addresses + // (curBalancerName="grpclb", preBalancerName="") + if newBalancerName == "" { + newBalancerName = PickFirstBalancerName + } + } + cc.switchBalancer(newBalancerName) + } else if cc.balancerWrapper == nil { + // Balancer dial option was set, and this is the first time handling + // resolved addresses. Build a balancer with dopts.balancerBuilder. + cc.balancerWrapper = newCCBalancerWrapper(cc, cc.dopts.balancerBuilder, cc.balancerBuildOpts) + } + + cc.balancerWrapper.handleResolvedAddrs(addrs, nil) +} + +// switchBalancer starts the switching from current balancer to the balancer +// with the given name. +// +// It will NOT send the current address list to the new balancer. If needed, +// caller of this function should send address list to the new balancer after +// this function returns. +// +// Caller must hold cc.mu. +func (cc *ClientConn) switchBalancer(name string) { + if cc.conns == nil { + return + } + + if strings.ToLower(cc.curBalancerName) == strings.ToLower(name) { + return + } + + grpclog.Infof("ClientConn switching balancer to %q", name) + if cc.dopts.balancerBuilder != nil { + grpclog.Infoln("ignoring balancer switching: Balancer DialOption used instead") + return + } + // TODO(bar switching) change this to two steps: drain and close. + // Keep track of sc in wrapper. + if cc.balancerWrapper != nil { + cc.balancerWrapper.close() + } + // Clear all stickiness state. + cc.blockingpicker.clearStickinessState() + + builder := balancer.Get(name) + if builder == nil { + grpclog.Infof("failed to get balancer builder for: %v, using pick_first instead", name) + builder = newPickfirstBuilder() + } + cc.preBalancerName = cc.curBalancerName + cc.curBalancerName = builder.Name() + cc.balancerWrapper = newCCBalancerWrapper(cc, builder, cc.balancerBuildOpts) +} + +func (cc *ClientConn) handleSubConnStateChange(sc balancer.SubConn, s connectivity.State) { + cc.mu.Lock() + if cc.conns == nil { + cc.mu.Unlock() + return + } + // TODO(bar switching) send updates to all balancer wrappers when balancer + // gracefully switching is supported. + cc.balancerWrapper.handleSubConnStateChange(sc, s) + cc.mu.Unlock() +} + +// newAddrConn creates an addrConn for addrs and adds it to cc.conns. +// +// Caller needs to make sure len(addrs) > 0. +func (cc *ClientConn) newAddrConn(addrs []resolver.Address) (*addrConn, error) { + ac := &addrConn{ + cc: cc, + addrs: addrs, + dopts: cc.dopts, + } + ac.ctx, ac.cancel = context.WithCancel(cc.ctx) + // Track ac in cc. This needs to be done before any getTransport(...) is called. + cc.mu.Lock() + if cc.conns == nil { + cc.mu.Unlock() + return nil, ErrClientConnClosing + } + if channelz.IsOn() { + ac.channelzID = channelz.RegisterSubChannel(ac, cc.channelzID, "") + } + cc.conns[ac] = struct{}{} + cc.mu.Unlock() + return ac, nil +} + +// removeAddrConn removes the addrConn in the subConn from clientConn. +// It also tears down the ac with the given error. +func (cc *ClientConn) removeAddrConn(ac *addrConn, err error) { + cc.mu.Lock() + if cc.conns == nil { + cc.mu.Unlock() + return + } + delete(cc.conns, ac) + cc.mu.Unlock() + ac.tearDown(err) +} + +// ChannelzMetric returns ChannelInternalMetric of current ClientConn. +// This is an EXPERIMENTAL API. +func (cc *ClientConn) ChannelzMetric() *channelz.ChannelInternalMetric { + state := cc.GetState() + cc.czmu.RLock() + defer cc.czmu.RUnlock() + return &channelz.ChannelInternalMetric{ + State: state, + Target: cc.target, + CallsStarted: cc.callsStarted, + CallsSucceeded: cc.callsSucceeded, + CallsFailed: cc.callsFailed, + LastCallStartedTimestamp: cc.lastCallStartedTime, + } +} + +func (cc *ClientConn) incrCallsStarted() { + cc.czmu.Lock() + cc.callsStarted++ + // TODO(yuxuanli): will make this a time.Time pointer improve performance? + cc.lastCallStartedTime = time.Now() + cc.czmu.Unlock() +} + +func (cc *ClientConn) incrCallsSucceeded() { + cc.czmu.Lock() + cc.callsSucceeded++ + cc.czmu.Unlock() +} + +func (cc *ClientConn) incrCallsFailed() { + cc.czmu.Lock() + cc.callsFailed++ + cc.czmu.Unlock() +} + +// connect starts to creating transport and also starts the transport monitor +// goroutine for this ac. +// It does nothing if the ac is not IDLE. +// TODO(bar) Move this to the addrConn section. +// This was part of resetAddrConn, keep it here to make the diff look clean. +func (ac *addrConn) connect() error { + ac.mu.Lock() + if ac.state == connectivity.Shutdown { + ac.mu.Unlock() + return errConnClosing + } + if ac.state != connectivity.Idle { + ac.mu.Unlock() + return nil + } + ac.state = connectivity.Connecting + ac.cc.handleSubConnStateChange(ac.acbw, ac.state) + ac.mu.Unlock() + + // Start a goroutine connecting to the server asynchronously. + go func() { + if err := ac.resetTransport(); err != nil { + grpclog.Warningf("Failed to dial %s: %v; please retry.", ac.addrs[0].Addr, err) + if err != errConnClosing { + // Keep this ac in cc.conns, to get the reason it's torn down. + ac.tearDown(err) + } + return + } + ac.transportMonitor() + }() + return nil +} + +// tryUpdateAddrs tries to update ac.addrs with the new addresses list. +// +// It checks whether current connected address of ac is in the new addrs list. +// - If true, it updates ac.addrs and returns true. The ac will keep using +// the existing connection. +// - If false, it does nothing and returns false. +func (ac *addrConn) tryUpdateAddrs(addrs []resolver.Address) bool { + ac.mu.Lock() + defer ac.mu.Unlock() + grpclog.Infof("addrConn: tryUpdateAddrs curAddr: %v, addrs: %v", ac.curAddr, addrs) + if ac.state == connectivity.Shutdown { + ac.addrs = addrs + return true + } + + var curAddrFound bool + for _, a := range addrs { + if reflect.DeepEqual(ac.curAddr, a) { + curAddrFound = true + break + } + } + grpclog.Infof("addrConn: tryUpdateAddrs curAddrFound: %v", curAddrFound) + if curAddrFound { + ac.addrs = addrs + ac.reconnectIdx = 0 // Start reconnecting from beginning in the new list. + } + + return curAddrFound +} + +// GetMethodConfig gets the method config of the input method. +// If there's an exact match for input method (i.e. /service/method), we return +// the corresponding MethodConfig. +// If there isn't an exact match for the input method, we look for the default config +// under the service (i.e /service/). If there is a default MethodConfig for +// the service, we return it. +// Otherwise, we return an empty MethodConfig. +func (cc *ClientConn) GetMethodConfig(method string) MethodConfig { + // TODO: Avoid the locking here. + cc.mu.RLock() + defer cc.mu.RUnlock() + m, ok := cc.sc.Methods[method] + if !ok { + i := strings.LastIndex(method, "/") + m = cc.sc.Methods[method[:i+1]] + } + return m +} + +func (cc *ClientConn) getTransport(ctx context.Context, failfast bool) (transport.ClientTransport, func(balancer.DoneInfo), error) { + t, done, err := cc.blockingpicker.pick(ctx, failfast, balancer.PickOptions{}) + if err != nil { + return nil, nil, toRPCErr(err) + } + return t, done, nil +} + +// handleServiceConfig parses the service config string in JSON format to Go native +// struct ServiceConfig, and store both the struct and the JSON string in ClientConn. +func (cc *ClientConn) handleServiceConfig(js string) error { + if cc.dopts.disableServiceConfig { + return nil + } + sc, err := parseServiceConfig(js) + if err != nil { + return err + } + cc.mu.Lock() + cc.scRaw = js + cc.sc = sc + if sc.LB != nil && *sc.LB != grpclbName { // "grpclb" is not a valid balancer option in service config. + if cc.curBalancerName == grpclbName { + // If current balancer is grpclb, there's at least one grpclb + // balancer address in the resolved list. Don't switch the balancer, + // but change the previous balancer name, so if a new resolved + // address list doesn't contain grpclb address, balancer will be + // switched to *sc.LB. + cc.preBalancerName = *sc.LB + } else { + cc.switchBalancer(*sc.LB) + cc.balancerWrapper.handleResolvedAddrs(cc.curAddresses, nil) + } + } + + if envConfigStickinessOn { + var newStickinessMDKey string + if sc.stickinessMetadataKey != nil && *sc.stickinessMetadataKey != "" { + newStickinessMDKey = *sc.stickinessMetadataKey + } + // newStickinessMDKey is "" if one of the following happens: + // - stickinessMetadataKey is set to "" + // - stickinessMetadataKey field doesn't exist in service config + cc.blockingpicker.updateStickinessMDKey(strings.ToLower(newStickinessMDKey)) + } + + cc.mu.Unlock() + return nil +} + +func (cc *ClientConn) resolveNow(o resolver.ResolveNowOption) { + cc.mu.Lock() + r := cc.resolverWrapper + cc.mu.Unlock() + if r == nil { + return + } + go r.resolveNow(o) +} + +// Close tears down the ClientConn and all underlying connections. +func (cc *ClientConn) Close() error { + defer cc.cancel() + + cc.mu.Lock() + if cc.conns == nil { + cc.mu.Unlock() + return ErrClientConnClosing + } + conns := cc.conns + cc.conns = nil + cc.csMgr.updateState(connectivity.Shutdown) + + rWrapper := cc.resolverWrapper + cc.resolverWrapper = nil + bWrapper := cc.balancerWrapper + cc.balancerWrapper = nil + cc.mu.Unlock() + + cc.blockingpicker.close() + + if rWrapper != nil { + rWrapper.close() + } + if bWrapper != nil { + bWrapper.close() + } + + for ac := range conns { + ac.tearDown(ErrClientConnClosing) + } + if channelz.IsOn() { + channelz.RemoveEntry(cc.channelzID) + } + return nil +} + +// addrConn is a network connection to a given address. +type addrConn struct { + ctx context.Context + cancel context.CancelFunc + + cc *ClientConn + addrs []resolver.Address + dopts dialOptions + events trace.EventLog + acbw balancer.SubConn + + mu sync.Mutex + curAddr resolver.Address + reconnectIdx int // The index in addrs list to start reconnecting from. + state connectivity.State + // ready is closed and becomes nil when a new transport is up or failed + // due to timeout. + ready chan struct{} + transport transport.ClientTransport + + // The reason this addrConn is torn down. + tearDownErr error + + connectRetryNum int + // backoffDeadline is the time until which resetTransport needs to + // wait before increasing connectRetryNum count. + backoffDeadline time.Time + // connectDeadline is the time by which all connection + // negotiations must complete. + connectDeadline time.Time + + channelzID int64 // channelz unique identification number + czmu sync.RWMutex + callsStarted int64 + callsSucceeded int64 + callsFailed int64 + lastCallStartedTime time.Time +} + +// adjustParams updates parameters used to create transports upon +// receiving a GoAway. +func (ac *addrConn) adjustParams(r transport.GoAwayReason) { + switch r { + case transport.GoAwayTooManyPings: + v := 2 * ac.dopts.copts.KeepaliveParams.Time + ac.cc.mu.Lock() + if v > ac.cc.mkp.Time { + ac.cc.mkp.Time = v + } + ac.cc.mu.Unlock() + } +} + +// printf records an event in ac's event log, unless ac has been closed. +// REQUIRES ac.mu is held. +func (ac *addrConn) printf(format string, a ...interface{}) { + if ac.events != nil { + ac.events.Printf(format, a...) + } +} + +// errorf records an error in ac's event log, unless ac has been closed. +// REQUIRES ac.mu is held. +func (ac *addrConn) errorf(format string, a ...interface{}) { + if ac.events != nil { + ac.events.Errorf(format, a...) + } +} + +// resetTransport recreates a transport to the address for ac. The old +// transport will close itself on error or when the clientconn is closed. +// The created transport must receive initial settings frame from the server. +// In case that doesn't happen, transportMonitor will kill the newly created +// transport after connectDeadline has expired. +// In case there was an error on the transport before the settings frame was +// received, resetTransport resumes connecting to backends after the one that +// was previously connected to. In case end of the list is reached, resetTransport +// backs off until the original deadline. +// If the DialOption WithWaitForHandshake was set, resetTrasport returns +// successfully only after server settings are received. +// +// TODO(bar) make sure all state transitions are valid. +func (ac *addrConn) resetTransport() error { + ac.mu.Lock() + if ac.state == connectivity.Shutdown { + ac.mu.Unlock() + return errConnClosing + } + if ac.ready != nil { + close(ac.ready) + ac.ready = nil + } + ac.transport = nil + ridx := ac.reconnectIdx + ac.mu.Unlock() + ac.cc.mu.RLock() + ac.dopts.copts.KeepaliveParams = ac.cc.mkp + ac.cc.mu.RUnlock() + var backoffDeadline, connectDeadline time.Time + for connectRetryNum := 0; ; connectRetryNum++ { + ac.mu.Lock() + if ac.backoffDeadline.IsZero() { + // This means either a successful HTTP2 connection was established + // or this is the first time this addrConn is trying to establish a + // connection. + backoffFor := ac.dopts.bs.backoff(connectRetryNum) // time.Duration. + // This will be the duration that dial gets to finish. + dialDuration := getMinConnectTimeout() + if backoffFor > dialDuration { + // Give dial more time as we keep failing to connect. + dialDuration = backoffFor + } + start := time.Now() + backoffDeadline = start.Add(backoffFor) + connectDeadline = start.Add(dialDuration) + ridx = 0 // Start connecting from the beginning. + } else { + // Continue trying to connect with the same deadlines. + connectRetryNum = ac.connectRetryNum + backoffDeadline = ac.backoffDeadline + connectDeadline = ac.connectDeadline + ac.backoffDeadline = time.Time{} + ac.connectDeadline = time.Time{} + ac.connectRetryNum = 0 + } + if ac.state == connectivity.Shutdown { + ac.mu.Unlock() + return errConnClosing + } + ac.printf("connecting") + if ac.state != connectivity.Connecting { + ac.state = connectivity.Connecting + ac.cc.handleSubConnStateChange(ac.acbw, ac.state) + } + // copy ac.addrs in case of race + addrsIter := make([]resolver.Address, len(ac.addrs)) + copy(addrsIter, ac.addrs) + copts := ac.dopts.copts + ac.mu.Unlock() + connected, err := ac.createTransport(connectRetryNum, ridx, backoffDeadline, connectDeadline, addrsIter, copts) + if err != nil { + return err + } + if connected { + return nil + } + } +} + +// createTransport creates a connection to one of the backends in addrs. +// It returns true if a connection was established. +func (ac *addrConn) createTransport(connectRetryNum, ridx int, backoffDeadline, connectDeadline time.Time, addrs []resolver.Address, copts transport.ConnectOptions) (bool, error) { + for i := ridx; i < len(addrs); i++ { + addr := addrs[i] + target := transport.TargetInfo{ + Addr: addr.Addr, + Metadata: addr.Metadata, + Authority: ac.cc.authority, + } + done := make(chan struct{}) + onPrefaceReceipt := func() { + ac.mu.Lock() + close(done) + if !ac.backoffDeadline.IsZero() { + // If we haven't already started reconnecting to + // other backends. + // Note, this can happen when writer notices an error + // and triggers resetTransport while at the same time + // reader receives the preface and invokes this closure. + ac.backoffDeadline = time.Time{} + ac.connectDeadline = time.Time{} + ac.connectRetryNum = 0 + } + ac.mu.Unlock() + } + // Do not cancel in the success path because of + // this issue in Go1.6: https://github.com/golang/go/issues/15078. + connectCtx, cancel := context.WithDeadline(ac.ctx, connectDeadline) + if channelz.IsOn() { + copts.ChannelzParentID = ac.channelzID + } + newTr, err := transport.NewClientTransport(connectCtx, ac.cc.ctx, target, copts, onPrefaceReceipt) + if err != nil { + cancel() + ac.cc.blockingpicker.updateConnectionError(err) + ac.mu.Lock() + if ac.state == connectivity.Shutdown { + // ac.tearDown(...) has been invoked. + ac.mu.Unlock() + return false, errConnClosing + } + ac.mu.Unlock() + grpclog.Warningf("grpc: addrConn.createTransport failed to connect to %v. Err :%v. Reconnecting...", addr, err) + continue + } + if ac.dopts.waitForHandshake { + select { + case <-done: + case <-connectCtx.Done(): + // Didn't receive server preface, must kill this new transport now. + grpclog.Warningf("grpc: addrConn.createTransport failed to receive server preface before deadline.") + newTr.Close() + break + case <-ac.ctx.Done(): + } + } + ac.mu.Lock() + if ac.state == connectivity.Shutdown { + ac.mu.Unlock() + // ac.tearDonn(...) has been invoked. + newTr.Close() + return false, errConnClosing + } + ac.printf("ready") + ac.state = connectivity.Ready + ac.cc.handleSubConnStateChange(ac.acbw, ac.state) + ac.transport = newTr + ac.curAddr = addr + if ac.ready != nil { + close(ac.ready) + ac.ready = nil + } + select { + case <-done: + // If the server has responded back with preface already, + // don't set the reconnect parameters. + default: + ac.connectRetryNum = connectRetryNum + ac.backoffDeadline = backoffDeadline + ac.connectDeadline = connectDeadline + ac.reconnectIdx = i + 1 // Start reconnecting from the next backend in the list. + } + ac.mu.Unlock() + return true, nil + } + ac.mu.Lock() + if ac.state == connectivity.Shutdown { + ac.mu.Unlock() + return false, errConnClosing + } + ac.state = connectivity.TransientFailure + ac.cc.handleSubConnStateChange(ac.acbw, ac.state) + ac.cc.resolveNow(resolver.ResolveNowOption{}) + if ac.ready != nil { + close(ac.ready) + ac.ready = nil + } + ac.mu.Unlock() + timer := time.NewTimer(backoffDeadline.Sub(time.Now())) + select { + case <-timer.C: + case <-ac.ctx.Done(): + timer.Stop() + return false, ac.ctx.Err() + } + return false, nil +} + +// Run in a goroutine to track the error in transport and create the +// new transport if an error happens. It returns when the channel is closing. +func (ac *addrConn) transportMonitor() { + for { + var timer *time.Timer + var cdeadline <-chan time.Time + ac.mu.Lock() + t := ac.transport + if !ac.connectDeadline.IsZero() { + timer = time.NewTimer(ac.connectDeadline.Sub(time.Now())) + cdeadline = timer.C + } + ac.mu.Unlock() + // Block until we receive a goaway or an error occurs. + select { + case <-t.GoAway(): + done := t.Error() + cleanup := t.Close + // Since this transport will be orphaned (won't have a transportMonitor) + // we need to launch a goroutine to keep track of clientConn.Close() + // happening since it might not be noticed by any other goroutine for a while. + go func() { + <-done + cleanup() + }() + case <-t.Error(): + // In case this is triggered because clientConn.Close() + // was called, we want to immeditately close the transport + // since no other goroutine might notice it for a while. + t.Close() + case <-cdeadline: + ac.mu.Lock() + // This implies that client received server preface. + if ac.backoffDeadline.IsZero() { + ac.mu.Unlock() + continue + } + ac.mu.Unlock() + timer = nil + // No server preface received until deadline. + // Kill the connection. + grpclog.Warningf("grpc: addrConn.transportMonitor didn't get server preface after waiting. Closing the new transport now.") + t.Close() + } + if timer != nil { + timer.Stop() + } + // If a GoAway happened, regardless of error, adjust our keepalive + // parameters as appropriate. + select { + case <-t.GoAway(): + ac.adjustParams(t.GetGoAwayReason()) + default: + } + ac.mu.Lock() + if ac.state == connectivity.Shutdown { + ac.mu.Unlock() + return + } + // Set connectivity state to TransientFailure before calling + // resetTransport. Transition READY->CONNECTING is not valid. + ac.state = connectivity.TransientFailure + ac.cc.handleSubConnStateChange(ac.acbw, ac.state) + ac.cc.resolveNow(resolver.ResolveNowOption{}) + ac.curAddr = resolver.Address{} + ac.mu.Unlock() + if err := ac.resetTransport(); err != nil { + ac.mu.Lock() + ac.printf("transport exiting: %v", err) + ac.mu.Unlock() + grpclog.Warningf("grpc: addrConn.transportMonitor exits due to: %v", err) + if err != errConnClosing { + // Keep this ac in cc.conns, to get the reason it's torn down. + ac.tearDown(err) + } + return + } + } +} + +// wait blocks until i) the new transport is up or ii) ctx is done or iii) ac is closed or +// iv) transport is in connectivity.TransientFailure and there is a balancer/failfast is true. +func (ac *addrConn) wait(ctx context.Context, hasBalancer, failfast bool) (transport.ClientTransport, error) { + for { + ac.mu.Lock() + switch { + case ac.state == connectivity.Shutdown: + if failfast || !hasBalancer { + // RPC is failfast or balancer is nil. This RPC should fail with ac.tearDownErr. + err := ac.tearDownErr + ac.mu.Unlock() + return nil, err + } + ac.mu.Unlock() + return nil, errConnClosing + case ac.state == connectivity.Ready: + ct := ac.transport + ac.mu.Unlock() + return ct, nil + case ac.state == connectivity.TransientFailure: + if failfast || hasBalancer { + ac.mu.Unlock() + return nil, errConnUnavailable + } + } + ready := ac.ready + if ready == nil { + ready = make(chan struct{}) + ac.ready = ready + } + ac.mu.Unlock() + select { + case <-ctx.Done(): + return nil, toRPCErr(ctx.Err()) + // Wait until the new transport is ready or failed. + case <-ready: + } + } +} + +// getReadyTransport returns the transport if ac's state is READY. +// Otherwise it returns nil, false. +// If ac's state is IDLE, it will trigger ac to connect. +func (ac *addrConn) getReadyTransport() (transport.ClientTransport, bool) { + ac.mu.Lock() + if ac.state == connectivity.Ready { + t := ac.transport + ac.mu.Unlock() + return t, true + } + var idle bool + if ac.state == connectivity.Idle { + idle = true + } + ac.mu.Unlock() + // Trigger idle ac to connect. + if idle { + ac.connect() + } + return nil, false +} + +// tearDown starts to tear down the addrConn. +// TODO(zhaoq): Make this synchronous to avoid unbounded memory consumption in +// some edge cases (e.g., the caller opens and closes many addrConn's in a +// tight loop. +// tearDown doesn't remove ac from ac.cc.conns. +func (ac *addrConn) tearDown(err error) { + ac.cancel() + ac.mu.Lock() + defer ac.mu.Unlock() + if ac.state == connectivity.Shutdown { + return + } + ac.curAddr = resolver.Address{} + if err == errConnDrain && ac.transport != nil { + // GracefulClose(...) may be executed multiple times when + // i) receiving multiple GoAway frames from the server; or + // ii) there are concurrent name resolver/Balancer triggered + // address removal and GoAway. + ac.transport.GracefulClose() + } + ac.state = connectivity.Shutdown + ac.tearDownErr = err + ac.cc.handleSubConnStateChange(ac.acbw, ac.state) + if ac.events != nil { + ac.events.Finish() + ac.events = nil + } + if ac.ready != nil { + close(ac.ready) + ac.ready = nil + } + if channelz.IsOn() { + channelz.RemoveEntry(ac.channelzID) + } +} + +func (ac *addrConn) getState() connectivity.State { + ac.mu.Lock() + defer ac.mu.Unlock() + return ac.state +} + +func (ac *addrConn) getCurAddr() (ret resolver.Address) { + ac.mu.Lock() + ret = ac.curAddr + ac.mu.Unlock() + return +} + +func (ac *addrConn) ChannelzMetric() *channelz.ChannelInternalMetric { + ac.mu.Lock() + addr := ac.curAddr.Addr + ac.mu.Unlock() + state := ac.getState() + ac.czmu.RLock() + defer ac.czmu.RUnlock() + return &channelz.ChannelInternalMetric{ + State: state, + Target: addr, + CallsStarted: ac.callsStarted, + CallsSucceeded: ac.callsSucceeded, + CallsFailed: ac.callsFailed, + LastCallStartedTimestamp: ac.lastCallStartedTime, + } +} + +func (ac *addrConn) incrCallsStarted() { + ac.czmu.Lock() + ac.callsStarted++ + ac.lastCallStartedTime = time.Now() + ac.czmu.Unlock() +} + +func (ac *addrConn) incrCallsSucceeded() { + ac.czmu.Lock() + ac.callsSucceeded++ + ac.czmu.Unlock() +} + +func (ac *addrConn) incrCallsFailed() { + ac.czmu.Lock() + ac.callsFailed++ + ac.czmu.Unlock() +} + +// ErrClientConnTimeout indicates that the ClientConn cannot establish the +// underlying connections within the specified timeout. +// +// Deprecated: This error is never returned by grpc and should not be +// referenced by users. +var ErrClientConnTimeout = errors.New("grpc: timed out when dialing") diff --git a/vendor/google.golang.org/grpc/codec.go b/vendor/google.golang.org/grpc/codec.go new file mode 100644 index 00000000000..12977654781 --- /dev/null +++ b/vendor/google.golang.org/grpc/codec.go @@ -0,0 +1,50 @@ +/* + * + * Copyright 2014 gRPC 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 grpc + +import ( + "google.golang.org/grpc/encoding" + _ "google.golang.org/grpc/encoding/proto" // to register the Codec for "proto" +) + +// baseCodec contains the functionality of both Codec and encoding.Codec, but +// omits the name/string, which vary between the two and are not needed for +// anything besides the registry in the encoding package. +type baseCodec interface { + Marshal(v interface{}) ([]byte, error) + Unmarshal(data []byte, v interface{}) error +} + +var _ baseCodec = Codec(nil) +var _ baseCodec = encoding.Codec(nil) + +// Codec defines the interface gRPC uses to encode and decode messages. +// Note that implementations of this interface must be thread safe; +// a Codec's methods can be called from concurrent goroutines. +// +// Deprecated: use encoding.Codec instead. +type Codec interface { + // Marshal returns the wire format of v. + Marshal(v interface{}) ([]byte, error) + // Unmarshal parses the wire format into v. + Unmarshal(data []byte, v interface{}) error + // String returns the name of the Codec implementation. This is unused by + // gRPC. + String() string +} diff --git a/vendor/google.golang.org/grpc/codegen.sh b/vendor/google.golang.org/grpc/codegen.sh new file mode 100755 index 00000000000..4cdc6ba7c09 --- /dev/null +++ b/vendor/google.golang.org/grpc/codegen.sh @@ -0,0 +1,17 @@ +#!/usr/bin/env bash + +# This script serves as an example to demonstrate how to generate the gRPC-Go +# interface and the related messages from .proto file. +# +# It assumes the installation of i) Google proto buffer compiler at +# https://github.com/google/protobuf (after v2.6.1) and ii) the Go codegen +# plugin at https://github.com/golang/protobuf (after 2015-02-20). If you have +# not, please install them first. +# +# We recommend running this script at $GOPATH/src. +# +# If this is not what you need, feel free to make your own scripts. Again, this +# script is for demonstration purpose. +# +proto=$1 +protoc --go_out=plugins=grpc:. $proto diff --git a/vendor/google.golang.org/grpc/codes/code_string.go b/vendor/google.golang.org/grpc/codes/code_string.go new file mode 100644 index 00000000000..0b206a57822 --- /dev/null +++ b/vendor/google.golang.org/grpc/codes/code_string.go @@ -0,0 +1,62 @@ +/* + * + * Copyright 2017 gRPC 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 codes + +import "strconv" + +func (c Code) String() string { + switch c { + case OK: + return "OK" + case Canceled: + return "Canceled" + case Unknown: + return "Unknown" + case InvalidArgument: + return "InvalidArgument" + case DeadlineExceeded: + return "DeadlineExceeded" + case NotFound: + return "NotFound" + case AlreadyExists: + return "AlreadyExists" + case PermissionDenied: + return "PermissionDenied" + case ResourceExhausted: + return "ResourceExhausted" + case FailedPrecondition: + return "FailedPrecondition" + case Aborted: + return "Aborted" + case OutOfRange: + return "OutOfRange" + case Unimplemented: + return "Unimplemented" + case Internal: + return "Internal" + case Unavailable: + return "Unavailable" + case DataLoss: + return "DataLoss" + case Unauthenticated: + return "Unauthenticated" + default: + return "Code(" + strconv.FormatInt(int64(c), 10) + ")" + } +} diff --git a/vendor/google.golang.org/grpc/codes/codes.go b/vendor/google.golang.org/grpc/codes/codes.go new file mode 100644 index 00000000000..a8280ae660d --- /dev/null +++ b/vendor/google.golang.org/grpc/codes/codes.go @@ -0,0 +1,184 @@ +/* + * + * Copyright 2014 gRPC 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 codes defines the canonical error codes used by gRPC. It is +// consistent across various languages. +package codes // import "google.golang.org/grpc/codes" + +import ( + "fmt" +) + +// A Code is an unsigned 32-bit error code as defined in the gRPC spec. +type Code uint32 + +const ( + // OK is returned on success. + OK Code = 0 + + // Canceled indicates the operation was canceled (typically by the caller). + Canceled Code = 1 + + // Unknown error. An example of where this error may be returned is + // if a Status value received from another address space belongs to + // an error-space that is not known in this address space. Also + // errors raised by APIs that do not return enough error information + // may be converted to this error. + Unknown Code = 2 + + // InvalidArgument indicates client specified an invalid argument. + // Note that this differs from FailedPrecondition. It indicates arguments + // that are problematic regardless of the state of the system + // (e.g., a malformed file name). + InvalidArgument Code = 3 + + // DeadlineExceeded means operation expired before completion. + // For operations that change the state of the system, this error may be + // returned even if the operation has completed successfully. For + // example, a successful response from a server could have been delayed + // long enough for the deadline to expire. + DeadlineExceeded Code = 4 + + // NotFound means some requested entity (e.g., file or directory) was + // not found. + NotFound Code = 5 + + // AlreadyExists means an attempt to create an entity failed because one + // already exists. + AlreadyExists Code = 6 + + // PermissionDenied indicates the caller does not have permission to + // execute the specified operation. It must not be used for rejections + // caused by exhausting some resource (use ResourceExhausted + // instead for those errors). It must not be + // used if the caller cannot be identified (use Unauthenticated + // instead for those errors). + PermissionDenied Code = 7 + + // ResourceExhausted indicates some resource has been exhausted, perhaps + // a per-user quota, or perhaps the entire file system is out of space. + ResourceExhausted Code = 8 + + // FailedPrecondition indicates operation was rejected because the + // system is not in a state required for the operation's execution. + // For example, directory to be deleted may be non-empty, an rmdir + // operation is applied to a non-directory, etc. + // + // A litmus test that may help a service implementor in deciding + // between FailedPrecondition, Aborted, and Unavailable: + // (a) Use Unavailable if the client can retry just the failing call. + // (b) Use Aborted if the client should retry at a higher-level + // (e.g., restarting a read-modify-write sequence). + // (c) Use FailedPrecondition if the client should not retry until + // the system state has been explicitly fixed. E.g., if an "rmdir" + // fails because the directory is non-empty, FailedPrecondition + // should be returned since the client should not retry unless + // they have first fixed up the directory by deleting files from it. + // (d) Use FailedPrecondition if the client performs conditional + // REST Get/Update/Delete on a resource and the resource on the + // server does not match the condition. E.g., conflicting + // read-modify-write on the same resource. + FailedPrecondition Code = 9 + + // Aborted indicates the operation was aborted, typically due to a + // concurrency issue like sequencer check failures, transaction aborts, + // etc. + // + // See litmus test above for deciding between FailedPrecondition, + // Aborted, and Unavailable. + Aborted Code = 10 + + // OutOfRange means operation was attempted past the valid range. + // E.g., seeking or reading past end of file. + // + // Unlike InvalidArgument, this error indicates a problem that may + // be fixed if the system state changes. For example, a 32-bit file + // system will generate InvalidArgument if asked to read at an + // offset that is not in the range [0,2^32-1], but it will generate + // OutOfRange if asked to read from an offset past the current + // file size. + // + // There is a fair bit of overlap between FailedPrecondition and + // OutOfRange. We recommend using OutOfRange (the more specific + // error) when it applies so that callers who are iterating through + // a space can easily look for an OutOfRange error to detect when + // they are done. + OutOfRange Code = 11 + + // Unimplemented indicates operation is not implemented or not + // supported/enabled in this service. + Unimplemented Code = 12 + + // Internal errors. Means some invariants expected by underlying + // system has been broken. If you see one of these errors, + // something is very broken. + Internal Code = 13 + + // Unavailable indicates the service is currently unavailable. + // This is a most likely a transient condition and may be corrected + // by retrying with a backoff. + // + // See litmus test above for deciding between FailedPrecondition, + // Aborted, and Unavailable. + Unavailable Code = 14 + + // DataLoss indicates unrecoverable data loss or corruption. + DataLoss Code = 15 + + // Unauthenticated indicates the request does not have valid + // authentication credentials for the operation. + Unauthenticated Code = 16 +) + +var strToCode = map[string]Code{ + `"OK"`: OK, + `"CANCELLED"`:/* [sic] */ Canceled, + `"UNKNOWN"`: Unknown, + `"INVALID_ARGUMENT"`: InvalidArgument, + `"DEADLINE_EXCEEDED"`: DeadlineExceeded, + `"NOT_FOUND"`: NotFound, + `"ALREADY_EXISTS"`: AlreadyExists, + `"PERMISSION_DENIED"`: PermissionDenied, + `"RESOURCE_EXHAUSTED"`: ResourceExhausted, + `"FAILED_PRECONDITION"`: FailedPrecondition, + `"ABORTED"`: Aborted, + `"OUT_OF_RANGE"`: OutOfRange, + `"UNIMPLEMENTED"`: Unimplemented, + `"INTERNAL"`: Internal, + `"UNAVAILABLE"`: Unavailable, + `"DATA_LOSS"`: DataLoss, + `"UNAUTHENTICATED"`: Unauthenticated, +} + +// UnmarshalJSON unmarshals b into the Code. +func (c *Code) UnmarshalJSON(b []byte) error { + // From json.Unmarshaler: By convention, to approximate the behavior of + // Unmarshal itself, Unmarshalers implement UnmarshalJSON([]byte("null")) as + // a no-op. + if string(b) == "null" { + return nil + } + if c == nil { + return fmt.Errorf("nil receiver passed to UnmarshalJSON") + } + if jc, ok := strToCode[string(b)]; ok { + *c = jc + return nil + } + return fmt.Errorf("invalid code: %q", string(b)) +} diff --git a/vendor/google.golang.org/grpc/connectivity/connectivity.go b/vendor/google.golang.org/grpc/connectivity/connectivity.go new file mode 100644 index 00000000000..568ef5dc68b --- /dev/null +++ b/vendor/google.golang.org/grpc/connectivity/connectivity.go @@ -0,0 +1,72 @@ +/* + * + * Copyright 2017 gRPC 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 connectivity defines connectivity semantics. +// For details, see https://github.com/grpc/grpc/blob/master/doc/connectivity-semantics-and-api.md. +// All APIs in this package are experimental. +package connectivity + +import ( + "golang.org/x/net/context" + "google.golang.org/grpc/grpclog" +) + +// State indicates the state of connectivity. +// It can be the state of a ClientConn or SubConn. +type State int + +func (s State) String() string { + switch s { + case Idle: + return "IDLE" + case Connecting: + return "CONNECTING" + case Ready: + return "READY" + case TransientFailure: + return "TRANSIENT_FAILURE" + case Shutdown: + return "SHUTDOWN" + default: + grpclog.Errorf("unknown connectivity state: %d", s) + return "Invalid-State" + } +} + +const ( + // Idle indicates the ClientConn is idle. + Idle State = iota + // Connecting indicates the ClienConn is connecting. + Connecting + // Ready indicates the ClientConn is ready for work. + Ready + // TransientFailure indicates the ClientConn has seen a failure but expects to recover. + TransientFailure + // Shutdown indicates the ClientConn has started shutting down. + Shutdown +) + +// Reporter reports the connectivity states. +type Reporter interface { + // CurrentState returns the current state of the reporter. + CurrentState() State + // WaitForStateChange blocks until the reporter's state is different from the given state, + // and returns true. + // It returns false if <-ctx.Done() can proceed (ctx got timeout or got canceled). + WaitForStateChange(context.Context, State) bool +} diff --git a/vendor/google.golang.org/grpc/credentials/credentials.go b/vendor/google.golang.org/grpc/credentials/credentials.go new file mode 100644 index 00000000000..3351bf0ee5f --- /dev/null +++ b/vendor/google.golang.org/grpc/credentials/credentials.go @@ -0,0 +1,220 @@ +/* + * + * Copyright 2014 gRPC 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 credentials implements various credentials supported by gRPC library, +// which encapsulate all the state needed by a client to authenticate with a +// server and make various assertions, e.g., about the client's identity, role, +// or whether it is authorized to make a particular call. +package credentials // import "google.golang.org/grpc/credentials" + +import ( + "crypto/tls" + "crypto/x509" + "errors" + "fmt" + "io/ioutil" + "net" + "strings" + + "golang.org/x/net/context" +) + +// alpnProtoStr are the specified application level protocols for gRPC. +var alpnProtoStr = []string{"h2"} + +// PerRPCCredentials defines the common interface for the credentials which need to +// attach security information to every RPC (e.g., oauth2). +type PerRPCCredentials interface { + // GetRequestMetadata gets the current request metadata, refreshing + // tokens if required. This should be called by the transport layer on + // each request, and the data should be populated in headers or other + // context. If a status code is returned, it will be used as the status + // for the RPC. uri is the URI of the entry point for the request. + // When supported by the underlying implementation, ctx can be used for + // timeout and cancellation. + // TODO(zhaoq): Define the set of the qualified keys instead of leaving + // it as an arbitrary string. + GetRequestMetadata(ctx context.Context, uri ...string) (map[string]string, error) + // RequireTransportSecurity indicates whether the credentials requires + // transport security. + RequireTransportSecurity() bool +} + +// ProtocolInfo provides information regarding the gRPC wire protocol version, +// security protocol, security protocol version in use, server name, etc. +type ProtocolInfo struct { + // ProtocolVersion is the gRPC wire protocol version. + ProtocolVersion string + // SecurityProtocol is the security protocol in use. + SecurityProtocol string + // SecurityVersion is the security protocol version. + SecurityVersion string + // ServerName is the user-configured server name. + ServerName string +} + +// AuthInfo defines the common interface for the auth information the users are interested in. +type AuthInfo interface { + AuthType() string +} + +// ErrConnDispatched indicates that rawConn has been dispatched out of gRPC +// and the caller should not close rawConn. +var ErrConnDispatched = errors.New("credentials: rawConn is dispatched out of gRPC") + +// TransportCredentials defines the common interface for all the live gRPC wire +// protocols and supported transport security protocols (e.g., TLS, SSL). +type TransportCredentials interface { + // ClientHandshake does the authentication handshake specified by the corresponding + // authentication protocol on rawConn for clients. It returns the authenticated + // connection and the corresponding auth information about the connection. + // Implementations must use the provided context to implement timely cancellation. + // gRPC will try to reconnect if the error returned is a temporary error + // (io.EOF, context.DeadlineExceeded or err.Temporary() == true). + // If the returned error is a wrapper error, implementations should make sure that + // the error implements Temporary() to have the correct retry behaviors. + // + // If the returned net.Conn is closed, it MUST close the net.Conn provided. + ClientHandshake(context.Context, string, net.Conn) (net.Conn, AuthInfo, error) + // ServerHandshake does the authentication handshake for servers. It returns + // the authenticated connection and the corresponding auth information about + // the connection. + // + // If the returned net.Conn is closed, it MUST close the net.Conn provided. + ServerHandshake(net.Conn) (net.Conn, AuthInfo, error) + // Info provides the ProtocolInfo of this TransportCredentials. + Info() ProtocolInfo + // Clone makes a copy of this TransportCredentials. + Clone() TransportCredentials + // OverrideServerName overrides the server name used to verify the hostname on the returned certificates from the server. + // gRPC internals also use it to override the virtual hosting name if it is set. + // It must be called before dialing. Currently, this is only used by grpclb. + OverrideServerName(string) error +} + +// TLSInfo contains the auth information for a TLS authenticated connection. +// It implements the AuthInfo interface. +type TLSInfo struct { + State tls.ConnectionState +} + +// AuthType returns the type of TLSInfo as a string. +func (t TLSInfo) AuthType() string { + return "tls" +} + +// tlsCreds is the credentials required for authenticating a connection using TLS. +type tlsCreds struct { + // TLS configuration + config *tls.Config +} + +func (c tlsCreds) Info() ProtocolInfo { + return ProtocolInfo{ + SecurityProtocol: "tls", + SecurityVersion: "1.2", + ServerName: c.config.ServerName, + } +} + +func (c *tlsCreds) ClientHandshake(ctx context.Context, authority string, rawConn net.Conn) (_ net.Conn, _ AuthInfo, err error) { + // use local cfg to avoid clobbering ServerName if using multiple endpoints + cfg := cloneTLSConfig(c.config) + if cfg.ServerName == "" { + colonPos := strings.LastIndex(authority, ":") + if colonPos == -1 { + colonPos = len(authority) + } + cfg.ServerName = authority[:colonPos] + } + conn := tls.Client(rawConn, cfg) + errChannel := make(chan error, 1) + go func() { + errChannel <- conn.Handshake() + }() + select { + case err := <-errChannel: + if err != nil { + return nil, nil, err + } + case <-ctx.Done(): + return nil, nil, ctx.Err() + } + return conn, TLSInfo{conn.ConnectionState()}, nil +} + +func (c *tlsCreds) ServerHandshake(rawConn net.Conn) (net.Conn, AuthInfo, error) { + conn := tls.Server(rawConn, c.config) + if err := conn.Handshake(); err != nil { + return nil, nil, err + } + return conn, TLSInfo{conn.ConnectionState()}, nil +} + +func (c *tlsCreds) Clone() TransportCredentials { + return NewTLS(c.config) +} + +func (c *tlsCreds) OverrideServerName(serverNameOverride string) error { + c.config.ServerName = serverNameOverride + return nil +} + +// NewTLS uses c to construct a TransportCredentials based on TLS. +func NewTLS(c *tls.Config) TransportCredentials { + tc := &tlsCreds{cloneTLSConfig(c)} + tc.config.NextProtos = alpnProtoStr + return tc +} + +// NewClientTLSFromCert constructs TLS credentials from the input certificate for client. +// serverNameOverride is for testing only. If set to a non empty string, +// it will override the virtual host name of authority (e.g. :authority header field) in requests. +func NewClientTLSFromCert(cp *x509.CertPool, serverNameOverride string) TransportCredentials { + return NewTLS(&tls.Config{ServerName: serverNameOverride, RootCAs: cp}) +} + +// NewClientTLSFromFile constructs TLS credentials from the input certificate file for client. +// serverNameOverride is for testing only. If set to a non empty string, +// it will override the virtual host name of authority (e.g. :authority header field) in requests. +func NewClientTLSFromFile(certFile, serverNameOverride string) (TransportCredentials, error) { + b, err := ioutil.ReadFile(certFile) + if err != nil { + return nil, err + } + cp := x509.NewCertPool() + if !cp.AppendCertsFromPEM(b) { + return nil, fmt.Errorf("credentials: failed to append certificates") + } + return NewTLS(&tls.Config{ServerName: serverNameOverride, RootCAs: cp}), nil +} + +// NewServerTLSFromCert constructs TLS credentials from the input certificate for server. +func NewServerTLSFromCert(cert *tls.Certificate) TransportCredentials { + return NewTLS(&tls.Config{Certificates: []tls.Certificate{*cert}}) +} + +// NewServerTLSFromFile constructs TLS credentials from the input certificate file and key +// file for server. +func NewServerTLSFromFile(certFile, keyFile string) (TransportCredentials, error) { + cert, err := tls.LoadX509KeyPair(certFile, keyFile) + if err != nil { + return nil, err + } + return NewTLS(&tls.Config{Certificates: []tls.Certificate{cert}}), nil +} diff --git a/vendor/google.golang.org/grpc/credentials/credentials_util_go17.go b/vendor/google.golang.org/grpc/credentials/credentials_util_go17.go new file mode 100644 index 00000000000..60409aac0fb --- /dev/null +++ b/vendor/google.golang.org/grpc/credentials/credentials_util_go17.go @@ -0,0 +1,60 @@ +// +build go1.7 +// +build !go1.8 + +/* + * + * Copyright 2016 gRPC 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 credentials + +import ( + "crypto/tls" +) + +// cloneTLSConfig returns a shallow clone of the exported +// fields of cfg, ignoring the unexported sync.Once, which +// contains a mutex and must not be copied. +// +// If cfg is nil, a new zero tls.Config is returned. +func cloneTLSConfig(cfg *tls.Config) *tls.Config { + if cfg == nil { + return &tls.Config{} + } + return &tls.Config{ + Rand: cfg.Rand, + Time: cfg.Time, + Certificates: cfg.Certificates, + NameToCertificate: cfg.NameToCertificate, + GetCertificate: cfg.GetCertificate, + RootCAs: cfg.RootCAs, + NextProtos: cfg.NextProtos, + ServerName: cfg.ServerName, + ClientAuth: cfg.ClientAuth, + ClientCAs: cfg.ClientCAs, + InsecureSkipVerify: cfg.InsecureSkipVerify, + CipherSuites: cfg.CipherSuites, + PreferServerCipherSuites: cfg.PreferServerCipherSuites, + SessionTicketsDisabled: cfg.SessionTicketsDisabled, + SessionTicketKey: cfg.SessionTicketKey, + ClientSessionCache: cfg.ClientSessionCache, + MinVersion: cfg.MinVersion, + MaxVersion: cfg.MaxVersion, + CurvePreferences: cfg.CurvePreferences, + DynamicRecordSizingDisabled: cfg.DynamicRecordSizingDisabled, + Renegotiation: cfg.Renegotiation, + } +} diff --git a/vendor/google.golang.org/grpc/credentials/credentials_util_go18.go b/vendor/google.golang.org/grpc/credentials/credentials_util_go18.go new file mode 100644 index 00000000000..93f0e1d8de2 --- /dev/null +++ b/vendor/google.golang.org/grpc/credentials/credentials_util_go18.go @@ -0,0 +1,38 @@ +// +build go1.8 + +/* + * + * Copyright 2017 gRPC 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 credentials + +import ( + "crypto/tls" +) + +// cloneTLSConfig returns a shallow clone of the exported +// fields of cfg, ignoring the unexported sync.Once, which +// contains a mutex and must not be copied. +// +// If cfg is nil, a new zero tls.Config is returned. +func cloneTLSConfig(cfg *tls.Config) *tls.Config { + if cfg == nil { + return &tls.Config{} + } + + return cfg.Clone() +} diff --git a/vendor/google.golang.org/grpc/credentials/credentials_util_pre_go17.go b/vendor/google.golang.org/grpc/credentials/credentials_util_pre_go17.go new file mode 100644 index 00000000000..d6bbcc9fdd9 --- /dev/null +++ b/vendor/google.golang.org/grpc/credentials/credentials_util_pre_go17.go @@ -0,0 +1,57 @@ +// +build !go1.7 + +/* + * + * Copyright 2016 gRPC 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 credentials + +import ( + "crypto/tls" +) + +// cloneTLSConfig returns a shallow clone of the exported +// fields of cfg, ignoring the unexported sync.Once, which +// contains a mutex and must not be copied. +// +// If cfg is nil, a new zero tls.Config is returned. +func cloneTLSConfig(cfg *tls.Config) *tls.Config { + if cfg == nil { + return &tls.Config{} + } + return &tls.Config{ + Rand: cfg.Rand, + Time: cfg.Time, + Certificates: cfg.Certificates, + NameToCertificate: cfg.NameToCertificate, + GetCertificate: cfg.GetCertificate, + RootCAs: cfg.RootCAs, + NextProtos: cfg.NextProtos, + ServerName: cfg.ServerName, + ClientAuth: cfg.ClientAuth, + ClientCAs: cfg.ClientCAs, + InsecureSkipVerify: cfg.InsecureSkipVerify, + CipherSuites: cfg.CipherSuites, + PreferServerCipherSuites: cfg.PreferServerCipherSuites, + SessionTicketsDisabled: cfg.SessionTicketsDisabled, + SessionTicketKey: cfg.SessionTicketKey, + ClientSessionCache: cfg.ClientSessionCache, + MinVersion: cfg.MinVersion, + MaxVersion: cfg.MaxVersion, + CurvePreferences: cfg.CurvePreferences, + } +} diff --git a/vendor/google.golang.org/grpc/doc.go b/vendor/google.golang.org/grpc/doc.go new file mode 100644 index 00000000000..187adbb117f --- /dev/null +++ b/vendor/google.golang.org/grpc/doc.go @@ -0,0 +1,24 @@ +/* + * + * Copyright 2015 gRPC 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 grpc implements an RPC system called gRPC. + +See grpc.io for more information about gRPC. +*/ +package grpc // import "google.golang.org/grpc" diff --git a/vendor/google.golang.org/grpc/encoding/encoding.go b/vendor/google.golang.org/grpc/encoding/encoding.go new file mode 100644 index 00000000000..ade8b7cec73 --- /dev/null +++ b/vendor/google.golang.org/grpc/encoding/encoding.go @@ -0,0 +1,118 @@ +/* + * + * Copyright 2017 gRPC 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 encoding defines the interface for the compressor and codec, and +// functions to register and retrieve compressors and codecs. +// +// This package is EXPERIMENTAL. +package encoding + +import ( + "io" + "strings" +) + +// Identity specifies the optional encoding for uncompressed streams. +// It is intended for grpc internal use only. +const Identity = "identity" + +// Compressor is used for compressing and decompressing when sending or +// receiving messages. +type Compressor interface { + // Compress writes the data written to wc to w after compressing it. If an + // error occurs while initializing the compressor, that error is returned + // instead. + Compress(w io.Writer) (io.WriteCloser, error) + // Decompress reads data from r, decompresses it, and provides the + // uncompressed data via the returned io.Reader. If an error occurs while + // initializing the decompressor, that error is returned instead. + Decompress(r io.Reader) (io.Reader, error) + // Name is the name of the compression codec and is used to set the content + // coding header. The result must be static; the result cannot change + // between calls. + Name() string +} + +var registeredCompressor = make(map[string]Compressor) + +// RegisterCompressor registers the compressor with gRPC by its name. It can +// be activated when sending an RPC via grpc.UseCompressor(). It will be +// automatically accessed when receiving a message based on the content coding +// header. Servers also use it to send a response with the same encoding as +// the request. +// +// NOTE: this function must only be called during initialization time (i.e. in +// an init() function), and is not thread-safe. If multiple Compressors are +// registered with the same name, the one registered last will take effect. +func RegisterCompressor(c Compressor) { + registeredCompressor[c.Name()] = c +} + +// GetCompressor returns Compressor for the given compressor name. +func GetCompressor(name string) Compressor { + return registeredCompressor[name] +} + +// Codec defines the interface gRPC uses to encode and decode messages. Note +// that implementations of this interface must be thread safe; a Codec's +// methods can be called from concurrent goroutines. +type Codec interface { + // Marshal returns the wire format of v. + Marshal(v interface{}) ([]byte, error) + // Unmarshal parses the wire format into v. + Unmarshal(data []byte, v interface{}) error + // Name returns the name of the Codec implementation. The returned string + // will be used as part of content type in transmission. The result must be + // static; the result cannot change between calls. + Name() string +} + +var registeredCodecs = make(map[string]Codec) + +// RegisterCodec registers the provided Codec for use with all gRPC clients and +// servers. +// +// The Codec will be stored and looked up by result of its Name() method, which +// should match the content-subtype of the encoding handled by the Codec. This +// is case-insensitive, and is stored and looked up as lowercase. If the +// result of calling Name() is an empty string, RegisterCodec will panic. See +// Content-Type on +// https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#requests for +// more details. +// +// NOTE: this function must only be called during initialization time (i.e. in +// an init() function), and is not thread-safe. If multiple Compressors are +// registered with the same name, the one registered last will take effect. +func RegisterCodec(codec Codec) { + if codec == nil { + panic("cannot register a nil Codec") + } + contentSubtype := strings.ToLower(codec.Name()) + if contentSubtype == "" { + panic("cannot register Codec with empty string result for String()") + } + registeredCodecs[contentSubtype] = codec +} + +// GetCodec gets a registered Codec by content-subtype, or nil if no Codec is +// registered for the content-subtype. +// +// The content-subtype is expected to be lowercase. +func GetCodec(contentSubtype string) Codec { + return registeredCodecs[contentSubtype] +} diff --git a/vendor/google.golang.org/grpc/encoding/proto/proto.go b/vendor/google.golang.org/grpc/encoding/proto/proto.go new file mode 100644 index 00000000000..66b97a6f692 --- /dev/null +++ b/vendor/google.golang.org/grpc/encoding/proto/proto.go @@ -0,0 +1,110 @@ +/* + * + * Copyright 2018 gRPC 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 proto defines the protobuf codec. Importing this package will +// register the codec. +package proto + +import ( + "math" + "sync" + + "github.com/golang/protobuf/proto" + "google.golang.org/grpc/encoding" +) + +// Name is the name registered for the proto compressor. +const Name = "proto" + +func init() { + encoding.RegisterCodec(codec{}) +} + +// codec is a Codec implementation with protobuf. It is the default codec for gRPC. +type codec struct{} + +type cachedProtoBuffer struct { + lastMarshaledSize uint32 + proto.Buffer +} + +func capToMaxInt32(val int) uint32 { + if val > math.MaxInt32 { + return uint32(math.MaxInt32) + } + return uint32(val) +} + +func marshal(v interface{}, cb *cachedProtoBuffer) ([]byte, error) { + protoMsg := v.(proto.Message) + newSlice := make([]byte, 0, cb.lastMarshaledSize) + + cb.SetBuf(newSlice) + cb.Reset() + if err := cb.Marshal(protoMsg); err != nil { + return nil, err + } + out := cb.Bytes() + cb.lastMarshaledSize = capToMaxInt32(len(out)) + return out, nil +} + +func (codec) Marshal(v interface{}) ([]byte, error) { + if pm, ok := v.(proto.Marshaler); ok { + // object can marshal itself, no need for buffer + return pm.Marshal() + } + + cb := protoBufferPool.Get().(*cachedProtoBuffer) + out, err := marshal(v, cb) + + // put back buffer and lose the ref to the slice + cb.SetBuf(nil) + protoBufferPool.Put(cb) + return out, err +} + +func (codec) Unmarshal(data []byte, v interface{}) error { + protoMsg := v.(proto.Message) + protoMsg.Reset() + + if pu, ok := protoMsg.(proto.Unmarshaler); ok { + // object can unmarshal itself, no need for buffer + return pu.Unmarshal(data) + } + + cb := protoBufferPool.Get().(*cachedProtoBuffer) + cb.SetBuf(data) + err := cb.Unmarshal(protoMsg) + cb.SetBuf(nil) + protoBufferPool.Put(cb) + return err +} + +func (codec) Name() string { + return Name +} + +var protoBufferPool = &sync.Pool{ + New: func() interface{} { + return &cachedProtoBuffer{ + Buffer: proto.Buffer{}, + lastMarshaledSize: 16, + } + }, +} diff --git a/vendor/google.golang.org/grpc/envconfig.go b/vendor/google.golang.org/grpc/envconfig.go new file mode 100644 index 00000000000..d50178e5171 --- /dev/null +++ b/vendor/google.golang.org/grpc/envconfig.go @@ -0,0 +1,37 @@ +/* + * + * Copyright 2018 gRPC 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 grpc + +import ( + "os" + "strings" +) + +const ( + envConfigPrefix = "GRPC_GO_" + envConfigStickinessStr = envConfigPrefix + "STICKINESS" +) + +var ( + envConfigStickinessOn bool +) + +func init() { + envConfigStickinessOn = strings.EqualFold(os.Getenv(envConfigStickinessStr), "on") +} diff --git a/vendor/google.golang.org/grpc/go16.go b/vendor/google.golang.org/grpc/go16.go new file mode 100644 index 00000000000..535ee9356f3 --- /dev/null +++ b/vendor/google.golang.org/grpc/go16.go @@ -0,0 +1,70 @@ +// +build go1.6,!go1.7 + +/* + * + * Copyright 2016 gRPC 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 grpc + +import ( + "fmt" + "io" + "net" + "net/http" + + "golang.org/x/net/context" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/status" + "google.golang.org/grpc/transport" +) + +// dialContext connects to the address on the named network. +func dialContext(ctx context.Context, network, address string) (net.Conn, error) { + return (&net.Dialer{Cancel: ctx.Done()}).Dial(network, address) +} + +func sendHTTPRequest(ctx context.Context, req *http.Request, conn net.Conn) error { + req.Cancel = ctx.Done() + if err := req.Write(conn); err != nil { + return fmt.Errorf("failed to write the HTTP request: %v", err) + } + return nil +} + +// toRPCErr converts an error into an error from the status package. +func toRPCErr(err error) error { + if err == nil || err == io.EOF { + return err + } + if _, ok := status.FromError(err); ok { + return err + } + switch e := err.(type) { + case transport.StreamError: + return status.Error(e.Code, e.Desc) + case transport.ConnectionError: + return status.Error(codes.Unavailable, e.Desc) + default: + switch err { + case context.DeadlineExceeded: + return status.Error(codes.DeadlineExceeded, err.Error()) + case context.Canceled: + return status.Error(codes.Canceled, err.Error()) + } + } + return status.Error(codes.Unknown, err.Error()) +} diff --git a/vendor/google.golang.org/grpc/go17.go b/vendor/google.golang.org/grpc/go17.go new file mode 100644 index 00000000000..ec676a93c39 --- /dev/null +++ b/vendor/google.golang.org/grpc/go17.go @@ -0,0 +1,71 @@ +// +build go1.7 + +/* + * + * Copyright 2016 gRPC 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 grpc + +import ( + "context" + "fmt" + "io" + "net" + "net/http" + + netctx "golang.org/x/net/context" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/status" + "google.golang.org/grpc/transport" +) + +// dialContext connects to the address on the named network. +func dialContext(ctx context.Context, network, address string) (net.Conn, error) { + return (&net.Dialer{}).DialContext(ctx, network, address) +} + +func sendHTTPRequest(ctx context.Context, req *http.Request, conn net.Conn) error { + req = req.WithContext(ctx) + if err := req.Write(conn); err != nil { + return fmt.Errorf("failed to write the HTTP request: %v", err) + } + return nil +} + +// toRPCErr converts an error into an error from the status package. +func toRPCErr(err error) error { + if err == nil || err == io.EOF { + return err + } + if _, ok := status.FromError(err); ok { + return err + } + switch e := err.(type) { + case transport.StreamError: + return status.Error(e.Code, e.Desc) + case transport.ConnectionError: + return status.Error(codes.Unavailable, e.Desc) + default: + switch err { + case context.DeadlineExceeded, netctx.DeadlineExceeded: + return status.Error(codes.DeadlineExceeded, err.Error()) + case context.Canceled, netctx.Canceled: + return status.Error(codes.Canceled, err.Error()) + } + } + return status.Error(codes.Unknown, err.Error()) +} diff --git a/vendor/google.golang.org/grpc/grpclb.go b/vendor/google.golang.org/grpc/grpclb.go new file mode 100644 index 00000000000..bc2b4452558 --- /dev/null +++ b/vendor/google.golang.org/grpc/grpclb.go @@ -0,0 +1,341 @@ +/* + * + * Copyright 2016 gRPC 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 grpc + +import ( + "strconv" + "strings" + "sync" + "time" + + "golang.org/x/net/context" + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/connectivity" + lbpb "google.golang.org/grpc/grpclb/grpc_lb_v1/messages" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/resolver" +) + +const ( + lbTokeyKey = "lb-token" + defaultFallbackTimeout = 10 * time.Second + grpclbName = "grpclb" +) + +func convertDuration(d *lbpb.Duration) time.Duration { + if d == nil { + return 0 + } + return time.Duration(d.Seconds)*time.Second + time.Duration(d.Nanos)*time.Nanosecond +} + +// Client API for LoadBalancer service. +// Mostly copied from generated pb.go file. +// To avoid circular dependency. +type loadBalancerClient struct { + cc *ClientConn +} + +func (c *loadBalancerClient) BalanceLoad(ctx context.Context, opts ...CallOption) (*balanceLoadClientStream, error) { + desc := &StreamDesc{ + StreamName: "BalanceLoad", + ServerStreams: true, + ClientStreams: true, + } + stream, err := c.cc.NewStream(ctx, desc, "/grpc.lb.v1.LoadBalancer/BalanceLoad", opts...) + if err != nil { + return nil, err + } + x := &balanceLoadClientStream{stream} + return x, nil +} + +type balanceLoadClientStream struct { + ClientStream +} + +func (x *balanceLoadClientStream) Send(m *lbpb.LoadBalanceRequest) error { + return x.ClientStream.SendMsg(m) +} + +func (x *balanceLoadClientStream) Recv() (*lbpb.LoadBalanceResponse, error) { + m := new(lbpb.LoadBalanceResponse) + if err := x.ClientStream.RecvMsg(m); err != nil { + return nil, err + } + return m, nil +} + +func init() { + balancer.Register(newLBBuilder()) +} + +// newLBBuilder creates a builder for grpclb. +func newLBBuilder() balancer.Builder { + return NewLBBuilderWithFallbackTimeout(defaultFallbackTimeout) +} + +// NewLBBuilderWithFallbackTimeout creates a grpclb builder with the given +// fallbackTimeout. If no response is received from the remote balancer within +// fallbackTimeout, the backend addresses from the resolved address list will be +// used. +// +// Only call this function when a non-default fallback timeout is needed. +func NewLBBuilderWithFallbackTimeout(fallbackTimeout time.Duration) balancer.Builder { + return &lbBuilder{ + fallbackTimeout: fallbackTimeout, + } +} + +type lbBuilder struct { + fallbackTimeout time.Duration +} + +func (b *lbBuilder) Name() string { + return grpclbName +} + +func (b *lbBuilder) Build(cc balancer.ClientConn, opt balancer.BuildOptions) balancer.Balancer { + // This generates a manual resolver builder with a random scheme. This + // scheme will be used to dial to remote LB, so we can send filtered address + // updates to remote LB ClientConn using this manual resolver. + scheme := "grpclb_internal_" + strconv.FormatInt(time.Now().UnixNano(), 36) + r := &lbManualResolver{scheme: scheme, ccb: cc} + + var target string + targetSplitted := strings.Split(cc.Target(), ":///") + if len(targetSplitted) < 2 { + target = cc.Target() + } else { + target = targetSplitted[1] + } + + lb := &lbBalancer{ + cc: newLBCacheClientConn(cc), + target: target, + opt: opt, + fallbackTimeout: b.fallbackTimeout, + doneCh: make(chan struct{}), + + manualResolver: r, + csEvltr: &connectivityStateEvaluator{}, + subConns: make(map[resolver.Address]balancer.SubConn), + scStates: make(map[balancer.SubConn]connectivity.State), + picker: &errPicker{err: balancer.ErrNoSubConnAvailable}, + clientStats: &rpcStats{}, + } + + return lb +} + +type lbBalancer struct { + cc *lbCacheClientConn + target string + opt balancer.BuildOptions + fallbackTimeout time.Duration + doneCh chan struct{} + + // manualResolver is used in the remote LB ClientConn inside grpclb. When + // resolved address updates are received by grpclb, filtered updates will be + // send to remote LB ClientConn through this resolver. + manualResolver *lbManualResolver + // The ClientConn to talk to the remote balancer. + ccRemoteLB *ClientConn + + // Support client side load reporting. Each picker gets a reference to this, + // and will update its content. + clientStats *rpcStats + + mu sync.Mutex // guards everything following. + // The full server list including drops, used to check if the newly received + // serverList contains anything new. Each generate picker will also have + // reference to this list to do the first layer pick. + fullServerList []*lbpb.Server + // All backends addresses, with metadata set to nil. This list contains all + // backend addresses in the same order and with the same duplicates as in + // serverlist. When generating picker, a SubConn slice with the same order + // but with only READY SCs will be gerenated. + backendAddrs []resolver.Address + // Roundrobin functionalities. + csEvltr *connectivityStateEvaluator + state connectivity.State + subConns map[resolver.Address]balancer.SubConn // Used to new/remove SubConn. + scStates map[balancer.SubConn]connectivity.State // Used to filter READY SubConns. + picker balancer.Picker + // Support fallback to resolved backend addresses if there's no response + // from remote balancer within fallbackTimeout. + fallbackTimerExpired bool + serverListReceived bool + // resolvedBackendAddrs is resolvedAddrs minus remote balancers. It's set + // when resolved address updates are received, and read in the goroutine + // handling fallback. + resolvedBackendAddrs []resolver.Address +} + +// regeneratePicker takes a snapshot of the balancer, and generates a picker from +// it. The picker +// - always returns ErrTransientFailure if the balancer is in TransientFailure, +// - does two layer roundrobin pick otherwise. +// Caller must hold lb.mu. +func (lb *lbBalancer) regeneratePicker() { + if lb.state == connectivity.TransientFailure { + lb.picker = &errPicker{err: balancer.ErrTransientFailure} + return + } + var readySCs []balancer.SubConn + for _, a := range lb.backendAddrs { + if sc, ok := lb.subConns[a]; ok { + if st, ok := lb.scStates[sc]; ok && st == connectivity.Ready { + readySCs = append(readySCs, sc) + } + } + } + + if len(lb.fullServerList) <= 0 { + if len(readySCs) <= 0 { + lb.picker = &errPicker{err: balancer.ErrNoSubConnAvailable} + return + } + lb.picker = &rrPicker{subConns: readySCs} + return + } + lb.picker = &lbPicker{ + serverList: lb.fullServerList, + subConns: readySCs, + stats: lb.clientStats, + } +} + +func (lb *lbBalancer) HandleSubConnStateChange(sc balancer.SubConn, s connectivity.State) { + grpclog.Infof("lbBalancer: handle SubConn state change: %p, %v", sc, s) + lb.mu.Lock() + defer lb.mu.Unlock() + + oldS, ok := lb.scStates[sc] + if !ok { + grpclog.Infof("lbBalancer: got state changes for an unknown SubConn: %p, %v", sc, s) + return + } + lb.scStates[sc] = s + switch s { + case connectivity.Idle: + sc.Connect() + case connectivity.Shutdown: + // When an address was removed by resolver, b called RemoveSubConn but + // kept the sc's state in scStates. Remove state for this sc here. + delete(lb.scStates, sc) + } + + oldAggrState := lb.state + lb.state = lb.csEvltr.recordTransition(oldS, s) + + // Regenerate picker when one of the following happens: + // - this sc became ready from not-ready + // - this sc became not-ready from ready + // - the aggregated state of balancer became TransientFailure from non-TransientFailure + // - the aggregated state of balancer became non-TransientFailure from TransientFailure + if (oldS == connectivity.Ready) != (s == connectivity.Ready) || + (lb.state == connectivity.TransientFailure) != (oldAggrState == connectivity.TransientFailure) { + lb.regeneratePicker() + } + + lb.cc.UpdateBalancerState(lb.state, lb.picker) +} + +// fallbackToBackendsAfter blocks for fallbackTimeout and falls back to use +// resolved backends (backends received from resolver, not from remote balancer) +// if no connection to remote balancers was successful. +func (lb *lbBalancer) fallbackToBackendsAfter(fallbackTimeout time.Duration) { + timer := time.NewTimer(fallbackTimeout) + defer timer.Stop() + select { + case <-timer.C: + case <-lb.doneCh: + return + } + lb.mu.Lock() + if lb.serverListReceived { + lb.mu.Unlock() + return + } + lb.fallbackTimerExpired = true + lb.refreshSubConns(lb.resolvedBackendAddrs) + lb.mu.Unlock() +} + +// HandleResolvedAddrs sends the updated remoteLB addresses to remoteLB +// clientConn. The remoteLB clientConn will handle creating/removing remoteLB +// connections. +func (lb *lbBalancer) HandleResolvedAddrs(addrs []resolver.Address, err error) { + grpclog.Infof("lbBalancer: handleResolvedResult: %+v", addrs) + if len(addrs) <= 0 { + return + } + + var remoteBalancerAddrs, backendAddrs []resolver.Address + for _, a := range addrs { + if a.Type == resolver.GRPCLB { + remoteBalancerAddrs = append(remoteBalancerAddrs, a) + } else { + backendAddrs = append(backendAddrs, a) + } + } + + if lb.ccRemoteLB == nil { + if len(remoteBalancerAddrs) <= 0 { + grpclog.Errorf("grpclb: no remote balancer address is available, should never happen") + return + } + // First time receiving resolved addresses, create a cc to remote + // balancers. + lb.dialRemoteLB(remoteBalancerAddrs[0].ServerName) + // Start the fallback goroutine. + go lb.fallbackToBackendsAfter(lb.fallbackTimeout) + } + + // cc to remote balancers uses lb.manualResolver. Send the updated remote + // balancer addresses to it through manualResolver. + lb.manualResolver.NewAddress(remoteBalancerAddrs) + + lb.mu.Lock() + lb.resolvedBackendAddrs = backendAddrs + // If serverListReceived is true, connection to remote balancer was + // successful and there's no need to do fallback anymore. + // If fallbackTimerExpired is false, fallback hasn't happened yet. + if !lb.serverListReceived && lb.fallbackTimerExpired { + // This means we received a new list of resolved backends, and we are + // still in fallback mode. Need to update the list of backends we are + // using to the new list of backends. + lb.refreshSubConns(lb.resolvedBackendAddrs) + } + lb.mu.Unlock() +} + +func (lb *lbBalancer) Close() { + select { + case <-lb.doneCh: + return + default: + } + close(lb.doneCh) + if lb.ccRemoteLB != nil { + lb.ccRemoteLB.Close() + } + lb.cc.close() +} diff --git a/vendor/google.golang.org/grpc/grpclb/grpc_lb_v1/messages/messages.pb.go b/vendor/google.golang.org/grpc/grpclb/grpc_lb_v1/messages/messages.pb.go new file mode 100644 index 00000000000..b3b32b48e86 --- /dev/null +++ b/vendor/google.golang.org/grpc/grpclb/grpc_lb_v1/messages/messages.pb.go @@ -0,0 +1,799 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: grpc_lb_v1/messages/messages.proto + +package messages // import "google.golang.org/grpc/grpclb/grpc_lb_v1/messages" + +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 + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package + +type Duration struct { + // Signed seconds of the span of time. Must be from -315,576,000,000 + // to +315,576,000,000 inclusive. + Seconds int64 `protobuf:"varint,1,opt,name=seconds" json:"seconds,omitempty"` + // Signed fractions of a second at nanosecond resolution of the span + // of time. Durations less than one second are represented with a 0 + // `seconds` field and a positive or negative `nanos` field. For durations + // of one second or more, a non-zero value for the `nanos` field must be + // of the same sign as the `seconds` field. Must be from -999,999,999 + // to +999,999,999 inclusive. + Nanos int32 `protobuf:"varint,2,opt,name=nanos" json:"nanos,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *Duration) Reset() { *m = Duration{} } +func (m *Duration) String() string { return proto.CompactTextString(m) } +func (*Duration) ProtoMessage() {} +func (*Duration) Descriptor() ([]byte, []int) { + return fileDescriptor_messages_b81c731f0e83edbd, []int{0} +} +func (m *Duration) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_Duration.Unmarshal(m, b) +} +func (m *Duration) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_Duration.Marshal(b, m, deterministic) +} +func (dst *Duration) XXX_Merge(src proto.Message) { + xxx_messageInfo_Duration.Merge(dst, src) +} +func (m *Duration) XXX_Size() int { + return xxx_messageInfo_Duration.Size(m) +} +func (m *Duration) XXX_DiscardUnknown() { + xxx_messageInfo_Duration.DiscardUnknown(m) +} + +var xxx_messageInfo_Duration proto.InternalMessageInfo + +func (m *Duration) GetSeconds() int64 { + if m != nil { + return m.Seconds + } + return 0 +} + +func (m *Duration) GetNanos() int32 { + if m != nil { + return m.Nanos + } + return 0 +} + +type Timestamp struct { + // Represents seconds of UTC time since Unix epoch + // 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to + // 9999-12-31T23:59:59Z inclusive. + Seconds int64 `protobuf:"varint,1,opt,name=seconds" json:"seconds,omitempty"` + // Non-negative fractions of a second at nanosecond resolution. Negative + // second values with fractions must still have non-negative nanos values + // that count forward in time. Must be from 0 to 999,999,999 + // inclusive. + Nanos int32 `protobuf:"varint,2,opt,name=nanos" json:"nanos,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *Timestamp) Reset() { *m = Timestamp{} } +func (m *Timestamp) String() string { return proto.CompactTextString(m) } +func (*Timestamp) ProtoMessage() {} +func (*Timestamp) Descriptor() ([]byte, []int) { + return fileDescriptor_messages_b81c731f0e83edbd, []int{1} +} +func (m *Timestamp) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_Timestamp.Unmarshal(m, b) +} +func (m *Timestamp) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_Timestamp.Marshal(b, m, deterministic) +} +func (dst *Timestamp) XXX_Merge(src proto.Message) { + xxx_messageInfo_Timestamp.Merge(dst, src) +} +func (m *Timestamp) XXX_Size() int { + return xxx_messageInfo_Timestamp.Size(m) +} +func (m *Timestamp) XXX_DiscardUnknown() { + xxx_messageInfo_Timestamp.DiscardUnknown(m) +} + +var xxx_messageInfo_Timestamp proto.InternalMessageInfo + +func (m *Timestamp) GetSeconds() int64 { + if m != nil { + return m.Seconds + } + return 0 +} + +func (m *Timestamp) GetNanos() int32 { + if m != nil { + return m.Nanos + } + return 0 +} + +type LoadBalanceRequest struct { + // Types that are valid to be assigned to LoadBalanceRequestType: + // *LoadBalanceRequest_InitialRequest + // *LoadBalanceRequest_ClientStats + LoadBalanceRequestType isLoadBalanceRequest_LoadBalanceRequestType `protobuf_oneof:"load_balance_request_type"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *LoadBalanceRequest) Reset() { *m = LoadBalanceRequest{} } +func (m *LoadBalanceRequest) String() string { return proto.CompactTextString(m) } +func (*LoadBalanceRequest) ProtoMessage() {} +func (*LoadBalanceRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_messages_b81c731f0e83edbd, []int{2} +} +func (m *LoadBalanceRequest) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_LoadBalanceRequest.Unmarshal(m, b) +} +func (m *LoadBalanceRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_LoadBalanceRequest.Marshal(b, m, deterministic) +} +func (dst *LoadBalanceRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_LoadBalanceRequest.Merge(dst, src) +} +func (m *LoadBalanceRequest) XXX_Size() int { + return xxx_messageInfo_LoadBalanceRequest.Size(m) +} +func (m *LoadBalanceRequest) XXX_DiscardUnknown() { + xxx_messageInfo_LoadBalanceRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_LoadBalanceRequest proto.InternalMessageInfo + +type isLoadBalanceRequest_LoadBalanceRequestType interface { + isLoadBalanceRequest_LoadBalanceRequestType() +} + +type LoadBalanceRequest_InitialRequest struct { + InitialRequest *InitialLoadBalanceRequest `protobuf:"bytes,1,opt,name=initial_request,json=initialRequest,oneof"` +} +type LoadBalanceRequest_ClientStats struct { + ClientStats *ClientStats `protobuf:"bytes,2,opt,name=client_stats,json=clientStats,oneof"` +} + +func (*LoadBalanceRequest_InitialRequest) isLoadBalanceRequest_LoadBalanceRequestType() {} +func (*LoadBalanceRequest_ClientStats) isLoadBalanceRequest_LoadBalanceRequestType() {} + +func (m *LoadBalanceRequest) GetLoadBalanceRequestType() isLoadBalanceRequest_LoadBalanceRequestType { + if m != nil { + return m.LoadBalanceRequestType + } + return nil +} + +func (m *LoadBalanceRequest) GetInitialRequest() *InitialLoadBalanceRequest { + if x, ok := m.GetLoadBalanceRequestType().(*LoadBalanceRequest_InitialRequest); ok { + return x.InitialRequest + } + return nil +} + +func (m *LoadBalanceRequest) GetClientStats() *ClientStats { + if x, ok := m.GetLoadBalanceRequestType().(*LoadBalanceRequest_ClientStats); ok { + return x.ClientStats + } + return nil +} + +// XXX_OneofFuncs is for the internal use of the proto package. +func (*LoadBalanceRequest) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { + return _LoadBalanceRequest_OneofMarshaler, _LoadBalanceRequest_OneofUnmarshaler, _LoadBalanceRequest_OneofSizer, []interface{}{ + (*LoadBalanceRequest_InitialRequest)(nil), + (*LoadBalanceRequest_ClientStats)(nil), + } +} + +func _LoadBalanceRequest_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { + m := msg.(*LoadBalanceRequest) + // load_balance_request_type + switch x := m.LoadBalanceRequestType.(type) { + case *LoadBalanceRequest_InitialRequest: + b.EncodeVarint(1<<3 | proto.WireBytes) + if err := b.EncodeMessage(x.InitialRequest); err != nil { + return err + } + case *LoadBalanceRequest_ClientStats: + b.EncodeVarint(2<<3 | proto.WireBytes) + if err := b.EncodeMessage(x.ClientStats); err != nil { + return err + } + case nil: + default: + return fmt.Errorf("LoadBalanceRequest.LoadBalanceRequestType has unexpected type %T", x) + } + return nil +} + +func _LoadBalanceRequest_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error) { + m := msg.(*LoadBalanceRequest) + switch tag { + case 1: // load_balance_request_type.initial_request + if wire != proto.WireBytes { + return true, proto.ErrInternalBadWireType + } + msg := new(InitialLoadBalanceRequest) + err := b.DecodeMessage(msg) + m.LoadBalanceRequestType = &LoadBalanceRequest_InitialRequest{msg} + return true, err + case 2: // load_balance_request_type.client_stats + if wire != proto.WireBytes { + return true, proto.ErrInternalBadWireType + } + msg := new(ClientStats) + err := b.DecodeMessage(msg) + m.LoadBalanceRequestType = &LoadBalanceRequest_ClientStats{msg} + return true, err + default: + return false, nil + } +} + +func _LoadBalanceRequest_OneofSizer(msg proto.Message) (n int) { + m := msg.(*LoadBalanceRequest) + // load_balance_request_type + switch x := m.LoadBalanceRequestType.(type) { + case *LoadBalanceRequest_InitialRequest: + s := proto.Size(x.InitialRequest) + n += 1 // tag and wire + n += proto.SizeVarint(uint64(s)) + n += s + case *LoadBalanceRequest_ClientStats: + s := proto.Size(x.ClientStats) + n += 1 // tag and wire + n += proto.SizeVarint(uint64(s)) + n += s + case nil: + default: + panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) + } + return n +} + +type InitialLoadBalanceRequest struct { + // Name of load balanced service (IE, balancer.service.com) + // length should be less than 256 bytes. + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *InitialLoadBalanceRequest) Reset() { *m = InitialLoadBalanceRequest{} } +func (m *InitialLoadBalanceRequest) String() string { return proto.CompactTextString(m) } +func (*InitialLoadBalanceRequest) ProtoMessage() {} +func (*InitialLoadBalanceRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_messages_b81c731f0e83edbd, []int{3} +} +func (m *InitialLoadBalanceRequest) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_InitialLoadBalanceRequest.Unmarshal(m, b) +} +func (m *InitialLoadBalanceRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_InitialLoadBalanceRequest.Marshal(b, m, deterministic) +} +func (dst *InitialLoadBalanceRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_InitialLoadBalanceRequest.Merge(dst, src) +} +func (m *InitialLoadBalanceRequest) XXX_Size() int { + return xxx_messageInfo_InitialLoadBalanceRequest.Size(m) +} +func (m *InitialLoadBalanceRequest) XXX_DiscardUnknown() { + xxx_messageInfo_InitialLoadBalanceRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_InitialLoadBalanceRequest proto.InternalMessageInfo + +func (m *InitialLoadBalanceRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +// Contains client level statistics that are useful to load balancing. Each +// count except the timestamp should be reset to zero after reporting the stats. +type ClientStats struct { + // The timestamp of generating the report. + Timestamp *Timestamp `protobuf:"bytes,1,opt,name=timestamp" json:"timestamp,omitempty"` + // The total number of RPCs that started. + NumCallsStarted int64 `protobuf:"varint,2,opt,name=num_calls_started,json=numCallsStarted" json:"num_calls_started,omitempty"` + // The total number of RPCs that finished. + NumCallsFinished int64 `protobuf:"varint,3,opt,name=num_calls_finished,json=numCallsFinished" json:"num_calls_finished,omitempty"` + // The total number of RPCs that were dropped by the client because of rate + // limiting. + NumCallsFinishedWithDropForRateLimiting int64 `protobuf:"varint,4,opt,name=num_calls_finished_with_drop_for_rate_limiting,json=numCallsFinishedWithDropForRateLimiting" json:"num_calls_finished_with_drop_for_rate_limiting,omitempty"` + // The total number of RPCs that were dropped by the client because of load + // balancing. + NumCallsFinishedWithDropForLoadBalancing int64 `protobuf:"varint,5,opt,name=num_calls_finished_with_drop_for_load_balancing,json=numCallsFinishedWithDropForLoadBalancing" json:"num_calls_finished_with_drop_for_load_balancing,omitempty"` + // The total number of RPCs that failed to reach a server except dropped RPCs. + NumCallsFinishedWithClientFailedToSend int64 `protobuf:"varint,6,opt,name=num_calls_finished_with_client_failed_to_send,json=numCallsFinishedWithClientFailedToSend" json:"num_calls_finished_with_client_failed_to_send,omitempty"` + // The total number of RPCs that finished and are known to have been received + // by a server. + NumCallsFinishedKnownReceived int64 `protobuf:"varint,7,opt,name=num_calls_finished_known_received,json=numCallsFinishedKnownReceived" json:"num_calls_finished_known_received,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ClientStats) Reset() { *m = ClientStats{} } +func (m *ClientStats) String() string { return proto.CompactTextString(m) } +func (*ClientStats) ProtoMessage() {} +func (*ClientStats) Descriptor() ([]byte, []int) { + return fileDescriptor_messages_b81c731f0e83edbd, []int{4} +} +func (m *ClientStats) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_ClientStats.Unmarshal(m, b) +} +func (m *ClientStats) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_ClientStats.Marshal(b, m, deterministic) +} +func (dst *ClientStats) XXX_Merge(src proto.Message) { + xxx_messageInfo_ClientStats.Merge(dst, src) +} +func (m *ClientStats) XXX_Size() int { + return xxx_messageInfo_ClientStats.Size(m) +} +func (m *ClientStats) XXX_DiscardUnknown() { + xxx_messageInfo_ClientStats.DiscardUnknown(m) +} + +var xxx_messageInfo_ClientStats proto.InternalMessageInfo + +func (m *ClientStats) GetTimestamp() *Timestamp { + if m != nil { + return m.Timestamp + } + return nil +} + +func (m *ClientStats) GetNumCallsStarted() int64 { + if m != nil { + return m.NumCallsStarted + } + return 0 +} + +func (m *ClientStats) GetNumCallsFinished() int64 { + if m != nil { + return m.NumCallsFinished + } + return 0 +} + +func (m *ClientStats) GetNumCallsFinishedWithDropForRateLimiting() int64 { + if m != nil { + return m.NumCallsFinishedWithDropForRateLimiting + } + return 0 +} + +func (m *ClientStats) GetNumCallsFinishedWithDropForLoadBalancing() int64 { + if m != nil { + return m.NumCallsFinishedWithDropForLoadBalancing + } + return 0 +} + +func (m *ClientStats) GetNumCallsFinishedWithClientFailedToSend() int64 { + if m != nil { + return m.NumCallsFinishedWithClientFailedToSend + } + return 0 +} + +func (m *ClientStats) GetNumCallsFinishedKnownReceived() int64 { + if m != nil { + return m.NumCallsFinishedKnownReceived + } + return 0 +} + +type LoadBalanceResponse struct { + // Types that are valid to be assigned to LoadBalanceResponseType: + // *LoadBalanceResponse_InitialResponse + // *LoadBalanceResponse_ServerList + LoadBalanceResponseType isLoadBalanceResponse_LoadBalanceResponseType `protobuf_oneof:"load_balance_response_type"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *LoadBalanceResponse) Reset() { *m = LoadBalanceResponse{} } +func (m *LoadBalanceResponse) String() string { return proto.CompactTextString(m) } +func (*LoadBalanceResponse) ProtoMessage() {} +func (*LoadBalanceResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_messages_b81c731f0e83edbd, []int{5} +} +func (m *LoadBalanceResponse) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_LoadBalanceResponse.Unmarshal(m, b) +} +func (m *LoadBalanceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_LoadBalanceResponse.Marshal(b, m, deterministic) +} +func (dst *LoadBalanceResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_LoadBalanceResponse.Merge(dst, src) +} +func (m *LoadBalanceResponse) XXX_Size() int { + return xxx_messageInfo_LoadBalanceResponse.Size(m) +} +func (m *LoadBalanceResponse) XXX_DiscardUnknown() { + xxx_messageInfo_LoadBalanceResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_LoadBalanceResponse proto.InternalMessageInfo + +type isLoadBalanceResponse_LoadBalanceResponseType interface { + isLoadBalanceResponse_LoadBalanceResponseType() +} + +type LoadBalanceResponse_InitialResponse struct { + InitialResponse *InitialLoadBalanceResponse `protobuf:"bytes,1,opt,name=initial_response,json=initialResponse,oneof"` +} +type LoadBalanceResponse_ServerList struct { + ServerList *ServerList `protobuf:"bytes,2,opt,name=server_list,json=serverList,oneof"` +} + +func (*LoadBalanceResponse_InitialResponse) isLoadBalanceResponse_LoadBalanceResponseType() {} +func (*LoadBalanceResponse_ServerList) isLoadBalanceResponse_LoadBalanceResponseType() {} + +func (m *LoadBalanceResponse) GetLoadBalanceResponseType() isLoadBalanceResponse_LoadBalanceResponseType { + if m != nil { + return m.LoadBalanceResponseType + } + return nil +} + +func (m *LoadBalanceResponse) GetInitialResponse() *InitialLoadBalanceResponse { + if x, ok := m.GetLoadBalanceResponseType().(*LoadBalanceResponse_InitialResponse); ok { + return x.InitialResponse + } + return nil +} + +func (m *LoadBalanceResponse) GetServerList() *ServerList { + if x, ok := m.GetLoadBalanceResponseType().(*LoadBalanceResponse_ServerList); ok { + return x.ServerList + } + return nil +} + +// XXX_OneofFuncs is for the internal use of the proto package. +func (*LoadBalanceResponse) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { + return _LoadBalanceResponse_OneofMarshaler, _LoadBalanceResponse_OneofUnmarshaler, _LoadBalanceResponse_OneofSizer, []interface{}{ + (*LoadBalanceResponse_InitialResponse)(nil), + (*LoadBalanceResponse_ServerList)(nil), + } +} + +func _LoadBalanceResponse_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { + m := msg.(*LoadBalanceResponse) + // load_balance_response_type + switch x := m.LoadBalanceResponseType.(type) { + case *LoadBalanceResponse_InitialResponse: + b.EncodeVarint(1<<3 | proto.WireBytes) + if err := b.EncodeMessage(x.InitialResponse); err != nil { + return err + } + case *LoadBalanceResponse_ServerList: + b.EncodeVarint(2<<3 | proto.WireBytes) + if err := b.EncodeMessage(x.ServerList); err != nil { + return err + } + case nil: + default: + return fmt.Errorf("LoadBalanceResponse.LoadBalanceResponseType has unexpected type %T", x) + } + return nil +} + +func _LoadBalanceResponse_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error) { + m := msg.(*LoadBalanceResponse) + switch tag { + case 1: // load_balance_response_type.initial_response + if wire != proto.WireBytes { + return true, proto.ErrInternalBadWireType + } + msg := new(InitialLoadBalanceResponse) + err := b.DecodeMessage(msg) + m.LoadBalanceResponseType = &LoadBalanceResponse_InitialResponse{msg} + return true, err + case 2: // load_balance_response_type.server_list + if wire != proto.WireBytes { + return true, proto.ErrInternalBadWireType + } + msg := new(ServerList) + err := b.DecodeMessage(msg) + m.LoadBalanceResponseType = &LoadBalanceResponse_ServerList{msg} + return true, err + default: + return false, nil + } +} + +func _LoadBalanceResponse_OneofSizer(msg proto.Message) (n int) { + m := msg.(*LoadBalanceResponse) + // load_balance_response_type + switch x := m.LoadBalanceResponseType.(type) { + case *LoadBalanceResponse_InitialResponse: + s := proto.Size(x.InitialResponse) + n += 1 // tag and wire + n += proto.SizeVarint(uint64(s)) + n += s + case *LoadBalanceResponse_ServerList: + s := proto.Size(x.ServerList) + n += 1 // tag and wire + n += proto.SizeVarint(uint64(s)) + n += s + case nil: + default: + panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) + } + return n +} + +type InitialLoadBalanceResponse struct { + // This is an application layer redirect that indicates the client should use + // the specified server for load balancing. When this field is non-empty in + // the response, the client should open a separate connection to the + // load_balancer_delegate and call the BalanceLoad method. Its length should + // be less than 64 bytes. + LoadBalancerDelegate string `protobuf:"bytes,1,opt,name=load_balancer_delegate,json=loadBalancerDelegate" json:"load_balancer_delegate,omitempty"` + // This interval defines how often the client should send the client stats + // to the load balancer. Stats should only be reported when the duration is + // positive. + ClientStatsReportInterval *Duration `protobuf:"bytes,2,opt,name=client_stats_report_interval,json=clientStatsReportInterval" json:"client_stats_report_interval,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *InitialLoadBalanceResponse) Reset() { *m = InitialLoadBalanceResponse{} } +func (m *InitialLoadBalanceResponse) String() string { return proto.CompactTextString(m) } +func (*InitialLoadBalanceResponse) ProtoMessage() {} +func (*InitialLoadBalanceResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_messages_b81c731f0e83edbd, []int{6} +} +func (m *InitialLoadBalanceResponse) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_InitialLoadBalanceResponse.Unmarshal(m, b) +} +func (m *InitialLoadBalanceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_InitialLoadBalanceResponse.Marshal(b, m, deterministic) +} +func (dst *InitialLoadBalanceResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_InitialLoadBalanceResponse.Merge(dst, src) +} +func (m *InitialLoadBalanceResponse) XXX_Size() int { + return xxx_messageInfo_InitialLoadBalanceResponse.Size(m) +} +func (m *InitialLoadBalanceResponse) XXX_DiscardUnknown() { + xxx_messageInfo_InitialLoadBalanceResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_InitialLoadBalanceResponse proto.InternalMessageInfo + +func (m *InitialLoadBalanceResponse) GetLoadBalancerDelegate() string { + if m != nil { + return m.LoadBalancerDelegate + } + return "" +} + +func (m *InitialLoadBalanceResponse) GetClientStatsReportInterval() *Duration { + if m != nil { + return m.ClientStatsReportInterval + } + return nil +} + +type ServerList struct { + // Contains a list of servers selected by the load balancer. The list will + // be updated when server resolutions change or as needed to balance load + // across more servers. The client should consume the server list in order + // unless instructed otherwise via the client_config. + Servers []*Server `protobuf:"bytes,1,rep,name=servers" json:"servers,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ServerList) Reset() { *m = ServerList{} } +func (m *ServerList) String() string { return proto.CompactTextString(m) } +func (*ServerList) ProtoMessage() {} +func (*ServerList) Descriptor() ([]byte, []int) { + return fileDescriptor_messages_b81c731f0e83edbd, []int{7} +} +func (m *ServerList) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_ServerList.Unmarshal(m, b) +} +func (m *ServerList) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_ServerList.Marshal(b, m, deterministic) +} +func (dst *ServerList) XXX_Merge(src proto.Message) { + xxx_messageInfo_ServerList.Merge(dst, src) +} +func (m *ServerList) XXX_Size() int { + return xxx_messageInfo_ServerList.Size(m) +} +func (m *ServerList) XXX_DiscardUnknown() { + xxx_messageInfo_ServerList.DiscardUnknown(m) +} + +var xxx_messageInfo_ServerList proto.InternalMessageInfo + +func (m *ServerList) GetServers() []*Server { + if m != nil { + return m.Servers + } + return nil +} + +// Contains server information. When none of the [drop_for_*] fields are true, +// use the other fields. When drop_for_rate_limiting is true, ignore all other +// fields. Use drop_for_load_balancing only when it is true and +// drop_for_rate_limiting is false. +type Server struct { + // A resolved address for the server, serialized in network-byte-order. It may + // either be an IPv4 or IPv6 address. + IpAddress []byte `protobuf:"bytes,1,opt,name=ip_address,json=ipAddress,proto3" json:"ip_address,omitempty"` + // A resolved port number for the server. + Port int32 `protobuf:"varint,2,opt,name=port" json:"port,omitempty"` + // An opaque but printable token given to the frontend for each pick. All + // frontend requests for that pick must include the token in its initial + // metadata. The token is used by the backend to verify the request and to + // allow the backend to report load to the gRPC LB system. + // + // Its length is variable but less than 50 bytes. + LoadBalanceToken string `protobuf:"bytes,3,opt,name=load_balance_token,json=loadBalanceToken" json:"load_balance_token,omitempty"` + // Indicates whether this particular request should be dropped by the client + // for rate limiting. + DropForRateLimiting bool `protobuf:"varint,4,opt,name=drop_for_rate_limiting,json=dropForRateLimiting" json:"drop_for_rate_limiting,omitempty"` + // Indicates whether this particular request should be dropped by the client + // for load balancing. + DropForLoadBalancing bool `protobuf:"varint,5,opt,name=drop_for_load_balancing,json=dropForLoadBalancing" json:"drop_for_load_balancing,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *Server) Reset() { *m = Server{} } +func (m *Server) String() string { return proto.CompactTextString(m) } +func (*Server) ProtoMessage() {} +func (*Server) Descriptor() ([]byte, []int) { + return fileDescriptor_messages_b81c731f0e83edbd, []int{8} +} +func (m *Server) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_Server.Unmarshal(m, b) +} +func (m *Server) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_Server.Marshal(b, m, deterministic) +} +func (dst *Server) XXX_Merge(src proto.Message) { + xxx_messageInfo_Server.Merge(dst, src) +} +func (m *Server) XXX_Size() int { + return xxx_messageInfo_Server.Size(m) +} +func (m *Server) XXX_DiscardUnknown() { + xxx_messageInfo_Server.DiscardUnknown(m) +} + +var xxx_messageInfo_Server proto.InternalMessageInfo + +func (m *Server) GetIpAddress() []byte { + if m != nil { + return m.IpAddress + } + return nil +} + +func (m *Server) GetPort() int32 { + if m != nil { + return m.Port + } + return 0 +} + +func (m *Server) GetLoadBalanceToken() string { + if m != nil { + return m.LoadBalanceToken + } + return "" +} + +func (m *Server) GetDropForRateLimiting() bool { + if m != nil { + return m.DropForRateLimiting + } + return false +} + +func (m *Server) GetDropForLoadBalancing() bool { + if m != nil { + return m.DropForLoadBalancing + } + return false +} + +func init() { + proto.RegisterType((*Duration)(nil), "grpc.lb.v1.Duration") + proto.RegisterType((*Timestamp)(nil), "grpc.lb.v1.Timestamp") + proto.RegisterType((*LoadBalanceRequest)(nil), "grpc.lb.v1.LoadBalanceRequest") + proto.RegisterType((*InitialLoadBalanceRequest)(nil), "grpc.lb.v1.InitialLoadBalanceRequest") + proto.RegisterType((*ClientStats)(nil), "grpc.lb.v1.ClientStats") + proto.RegisterType((*LoadBalanceResponse)(nil), "grpc.lb.v1.LoadBalanceResponse") + proto.RegisterType((*InitialLoadBalanceResponse)(nil), "grpc.lb.v1.InitialLoadBalanceResponse") + proto.RegisterType((*ServerList)(nil), "grpc.lb.v1.ServerList") + proto.RegisterType((*Server)(nil), "grpc.lb.v1.Server") +} + +func init() { + proto.RegisterFile("grpc_lb_v1/messages/messages.proto", fileDescriptor_messages_b81c731f0e83edbd) +} + +var fileDescriptor_messages_b81c731f0e83edbd = []byte{ + // 731 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x94, 0x55, 0xdd, 0x4e, 0x1b, 0x39, + 0x14, 0x26, 0x9b, 0x00, 0xc9, 0x09, 0x5a, 0xb2, 0x26, 0x0b, 0x81, 0x05, 0x89, 0x1d, 0x69, 0xd9, + 0x68, 0xc5, 0x4e, 0x04, 0xd9, 0xbd, 0xe8, 0xcf, 0x45, 0x1b, 0x10, 0x0a, 0x2d, 0x17, 0x95, 0x43, + 0x55, 0xa9, 0x52, 0x65, 0x39, 0x19, 0x33, 0x58, 0x38, 0xf6, 0xd4, 0x76, 0x82, 0xfa, 0x08, 0x7d, + 0x94, 0x3e, 0x46, 0xd5, 0x67, 0xe8, 0xfb, 0x54, 0xe3, 0x99, 0xc9, 0x0c, 0x10, 0x40, 0xbd, 0x89, + 0xec, 0xe3, 0xef, 0x7c, 0xdf, 0xf1, 0x89, 0xbf, 0x33, 0xe0, 0x85, 0x3a, 0x1a, 0x11, 0x31, 0x24, + 0xd3, 0x83, 0xce, 0x98, 0x19, 0x43, 0x43, 0x66, 0x66, 0x0b, 0x3f, 0xd2, 0xca, 0x2a, 0x04, 0x31, + 0xc6, 0x17, 0x43, 0x7f, 0x7a, 0xe0, 0x3d, 0x85, 0xea, 0xf1, 0x44, 0x53, 0xcb, 0x95, 0x44, 0x2d, + 0x58, 0x36, 0x6c, 0xa4, 0x64, 0x60, 0x5a, 0xa5, 0xdd, 0x52, 0xbb, 0x8c, 0xb3, 0x2d, 0x6a, 0xc2, + 0xa2, 0xa4, 0x52, 0x99, 0xd6, 0x2f, 0xbb, 0xa5, 0xf6, 0x22, 0x4e, 0x36, 0xde, 0x33, 0xa8, 0x9d, + 0xf3, 0x31, 0x33, 0x96, 0x8e, 0xa3, 0x9f, 0x4e, 0xfe, 0x5a, 0x02, 0x74, 0xa6, 0x68, 0xd0, 0xa3, + 0x82, 0xca, 0x11, 0xc3, 0xec, 0xe3, 0x84, 0x19, 0x8b, 0xde, 0xc0, 0x2a, 0x97, 0xdc, 0x72, 0x2a, + 0x88, 0x4e, 0x42, 0x8e, 0xae, 0x7e, 0xf8, 0x97, 0x9f, 0x57, 0xed, 0x9f, 0x26, 0x90, 0xbb, 0xf9, + 0xfd, 0x05, 0xfc, 0x6b, 0x9a, 0x9f, 0x31, 0x3e, 0x87, 0x95, 0x91, 0xe0, 0x4c, 0x5a, 0x62, 0x2c, + 0xb5, 0x49, 0x15, 0xf5, 0xc3, 0x8d, 0x22, 0xdd, 0x91, 0x3b, 0x1f, 0xc4, 0xc7, 0xfd, 0x05, 0x5c, + 0x1f, 0xe5, 0xdb, 0xde, 0x1f, 0xb0, 0x29, 0x14, 0x0d, 0xc8, 0x30, 0x91, 0xc9, 0x8a, 0x22, 0xf6, + 0x53, 0xc4, 0xbc, 0x0e, 0x6c, 0xde, 0x5b, 0x09, 0x42, 0x50, 0x91, 0x74, 0xcc, 0x5c, 0xf9, 0x35, + 0xec, 0xd6, 0xde, 0xe7, 0x0a, 0xd4, 0x0b, 0x62, 0xa8, 0x0b, 0x35, 0x9b, 0x75, 0x30, 0xbd, 0xe7, + 0xef, 0xc5, 0xc2, 0x66, 0xed, 0xc5, 0x39, 0x0e, 0xfd, 0x03, 0xbf, 0xc9, 0xc9, 0x98, 0x8c, 0xa8, + 0x10, 0x26, 0xbe, 0x93, 0xb6, 0x2c, 0x70, 0xb7, 0x2a, 0xe3, 0x55, 0x39, 0x19, 0x1f, 0xc5, 0xf1, + 0x41, 0x12, 0x46, 0xfb, 0x80, 0x72, 0xec, 0x05, 0x97, 0xdc, 0x5c, 0xb2, 0xa0, 0x55, 0x76, 0xe0, + 0x46, 0x06, 0x3e, 0x49, 0xe3, 0x88, 0x80, 0x7f, 0x17, 0x4d, 0xae, 0xb9, 0xbd, 0x24, 0x81, 0x56, + 0x11, 0xb9, 0x50, 0x9a, 0x68, 0x6a, 0x19, 0x11, 0x7c, 0xcc, 0x2d, 0x97, 0x61, 0xab, 0xe2, 0x98, + 0xfe, 0xbe, 0xcd, 0xf4, 0x8e, 0xdb, 0xcb, 0x63, 0xad, 0xa2, 0x13, 0xa5, 0x31, 0xb5, 0xec, 0x2c, + 0x85, 0x23, 0x0a, 0x9d, 0x47, 0x05, 0x0a, 0xed, 0x8e, 0x15, 0x16, 0x9d, 0x42, 0xfb, 0x01, 0x85, + 0xbc, 0xf7, 0xb1, 0xc4, 0x07, 0xf8, 0xf7, 0x3e, 0x89, 0xf4, 0x19, 0x5c, 0x50, 0x2e, 0x58, 0x40, + 0xac, 0x22, 0x86, 0xc9, 0xa0, 0xb5, 0xe4, 0x04, 0xf6, 0xe6, 0x09, 0x24, 0x7f, 0xd5, 0x89, 0xc3, + 0x9f, 0xab, 0x01, 0x93, 0x01, 0xea, 0xc3, 0x9f, 0x73, 0xe8, 0xaf, 0xa4, 0xba, 0x96, 0x44, 0xb3, + 0x11, 0xe3, 0x53, 0x16, 0xb4, 0x96, 0x1d, 0xe5, 0xce, 0x6d, 0xca, 0xd7, 0x31, 0x0a, 0xa7, 0x20, + 0xef, 0x5b, 0x09, 0xd6, 0x6e, 0x3c, 0x1b, 0x13, 0x29, 0x69, 0x18, 0x1a, 0x40, 0x23, 0x77, 0x40, + 0x12, 0x4b, 0x9f, 0xc6, 0xde, 0x63, 0x16, 0x48, 0xd0, 0xfd, 0x05, 0xbc, 0x3a, 0xf3, 0x40, 0x4a, + 0xfa, 0x04, 0xea, 0x86, 0xe9, 0x29, 0xd3, 0x44, 0x70, 0x63, 0x53, 0x0f, 0xac, 0x17, 0xf9, 0x06, + 0xee, 0xf8, 0x8c, 0x3b, 0x0f, 0x81, 0x99, 0xed, 0x7a, 0xdb, 0xb0, 0x75, 0xcb, 0x01, 0x09, 0x67, + 0x62, 0x81, 0x2f, 0x25, 0xd8, 0xba, 0xbf, 0x14, 0xf4, 0x1f, 0xac, 0x17, 0x93, 0x35, 0x09, 0x98, + 0x60, 0x21, 0xb5, 0x99, 0x2d, 0x9a, 0x22, 0x4f, 0xd2, 0xc7, 0xe9, 0x19, 0x7a, 0x0b, 0xdb, 0x45, + 0xcb, 0x12, 0xcd, 0x22, 0xa5, 0x2d, 0xe1, 0xd2, 0x32, 0x3d, 0xa5, 0x22, 0x2d, 0xbf, 0x59, 0x2c, + 0x3f, 0x1b, 0x62, 0x78, 0xb3, 0xe0, 0x5e, 0xec, 0xf2, 0x4e, 0xd3, 0x34, 0xef, 0x05, 0x40, 0x7e, + 0x4b, 0xb4, 0x1f, 0x0f, 0xac, 0x78, 0x17, 0x0f, 0xac, 0x72, 0xbb, 0x7e, 0x88, 0xee, 0xb6, 0x03, + 0x67, 0x90, 0x57, 0x95, 0x6a, 0xb9, 0x51, 0xf1, 0xbe, 0x97, 0x60, 0x29, 0x39, 0x41, 0x3b, 0x00, + 0x3c, 0x22, 0x34, 0x08, 0x34, 0x33, 0xc9, 0xc8, 0x5b, 0xc1, 0x35, 0x1e, 0xbd, 0x4c, 0x02, 0xb1, + 0xfb, 0x63, 0xed, 0x74, 0xe6, 0xb9, 0x75, 0x6c, 0xc6, 0x1b, 0x9d, 0xb4, 0xea, 0x8a, 0x49, 0x67, + 0xc6, 0x1a, 0x6e, 0x14, 0x1a, 0x71, 0x1e, 0xc7, 0x51, 0x17, 0xd6, 0x1f, 0x30, 0x5d, 0x15, 0xaf, + 0x05, 0x73, 0x0c, 0xf6, 0x3f, 0x6c, 0x3c, 0x64, 0xa4, 0x2a, 0x6e, 0x06, 0x73, 0x4c, 0xd3, 0xeb, + 0xbe, 0x3f, 0x08, 0x95, 0x0a, 0x05, 0xf3, 0x43, 0x25, 0xa8, 0x0c, 0x7d, 0xa5, 0xc3, 0x4e, 0xdc, + 0x0d, 0xf7, 0x23, 0x86, 0x9d, 0x39, 0x5f, 0x95, 0xe1, 0x92, 0xfb, 0x9a, 0x74, 0x7f, 0x04, 0x00, + 0x00, 0xff, 0xff, 0x8e, 0xd0, 0x70, 0xb7, 0x73, 0x06, 0x00, 0x00, +} diff --git a/vendor/google.golang.org/grpc/grpclb/grpc_lb_v1/messages/messages.proto b/vendor/google.golang.org/grpc/grpclb/grpc_lb_v1/messages/messages.proto new file mode 100644 index 00000000000..42d99c109fe --- /dev/null +++ b/vendor/google.golang.org/grpc/grpclb/grpc_lb_v1/messages/messages.proto @@ -0,0 +1,155 @@ +// Copyright 2016 gRPC 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. + +syntax = "proto3"; + +package grpc.lb.v1; +option go_package = "google.golang.org/grpc/grpclb/grpc_lb_v1/messages"; + +message Duration { + // Signed seconds of the span of time. Must be from -315,576,000,000 + // to +315,576,000,000 inclusive. + int64 seconds = 1; + + // Signed fractions of a second at nanosecond resolution of the span + // of time. Durations less than one second are represented with a 0 + // `seconds` field and a positive or negative `nanos` field. For durations + // of one second or more, a non-zero value for the `nanos` field must be + // of the same sign as the `seconds` field. Must be from -999,999,999 + // to +999,999,999 inclusive. + int32 nanos = 2; +} + +message Timestamp { + // Represents seconds of UTC time since Unix epoch + // 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to + // 9999-12-31T23:59:59Z inclusive. + int64 seconds = 1; + + // Non-negative fractions of a second at nanosecond resolution. Negative + // second values with fractions must still have non-negative nanos values + // that count forward in time. Must be from 0 to 999,999,999 + // inclusive. + int32 nanos = 2; +} + +message LoadBalanceRequest { + oneof load_balance_request_type { + // This message should be sent on the first request to the load balancer. + InitialLoadBalanceRequest initial_request = 1; + + // The client stats should be periodically reported to the load balancer + // based on the duration defined in the InitialLoadBalanceResponse. + ClientStats client_stats = 2; + } +} + +message InitialLoadBalanceRequest { + // Name of load balanced service (IE, balancer.service.com) + // length should be less than 256 bytes. + string name = 1; +} + +// Contains client level statistics that are useful to load balancing. Each +// count except the timestamp should be reset to zero after reporting the stats. +message ClientStats { + // The timestamp of generating the report. + Timestamp timestamp = 1; + + // The total number of RPCs that started. + int64 num_calls_started = 2; + + // The total number of RPCs that finished. + int64 num_calls_finished = 3; + + // The total number of RPCs that were dropped by the client because of rate + // limiting. + int64 num_calls_finished_with_drop_for_rate_limiting = 4; + + // The total number of RPCs that were dropped by the client because of load + // balancing. + int64 num_calls_finished_with_drop_for_load_balancing = 5; + + // The total number of RPCs that failed to reach a server except dropped RPCs. + int64 num_calls_finished_with_client_failed_to_send = 6; + + // The total number of RPCs that finished and are known to have been received + // by a server. + int64 num_calls_finished_known_received = 7; +} + +message LoadBalanceResponse { + oneof load_balance_response_type { + // This message should be sent on the first response to the client. + InitialLoadBalanceResponse initial_response = 1; + + // Contains the list of servers selected by the load balancer. The client + // should send requests to these servers in the specified order. + ServerList server_list = 2; + } +} + +message InitialLoadBalanceResponse { + // This is an application layer redirect that indicates the client should use + // the specified server for load balancing. When this field is non-empty in + // the response, the client should open a separate connection to the + // load_balancer_delegate and call the BalanceLoad method. Its length should + // be less than 64 bytes. + string load_balancer_delegate = 1; + + // This interval defines how often the client should send the client stats + // to the load balancer. Stats should only be reported when the duration is + // positive. + Duration client_stats_report_interval = 2; +} + +message ServerList { + // Contains a list of servers selected by the load balancer. The list will + // be updated when server resolutions change or as needed to balance load + // across more servers. The client should consume the server list in order + // unless instructed otherwise via the client_config. + repeated Server servers = 1; + + // Was google.protobuf.Duration expiration_interval. + reserved 3; +} + +// Contains server information. When none of the [drop_for_*] fields are true, +// use the other fields. When drop_for_rate_limiting is true, ignore all other +// fields. Use drop_for_load_balancing only when it is true and +// drop_for_rate_limiting is false. +message Server { + // A resolved address for the server, serialized in network-byte-order. It may + // either be an IPv4 or IPv6 address. + bytes ip_address = 1; + + // A resolved port number for the server. + int32 port = 2; + + // An opaque but printable token given to the frontend for each pick. All + // frontend requests for that pick must include the token in its initial + // metadata. The token is used by the backend to verify the request and to + // allow the backend to report load to the gRPC LB system. + // + // Its length is variable but less than 50 bytes. + string load_balance_token = 3; + + // Indicates whether this particular request should be dropped by the client + // for rate limiting. + bool drop_for_rate_limiting = 4; + + // Indicates whether this particular request should be dropped by the client + // for load balancing. + bool drop_for_load_balancing = 5; +} diff --git a/vendor/google.golang.org/grpc/grpclb_picker.go b/vendor/google.golang.org/grpc/grpclb_picker.go new file mode 100644 index 00000000000..872c7ccea0e --- /dev/null +++ b/vendor/google.golang.org/grpc/grpclb_picker.go @@ -0,0 +1,159 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "sync" + "sync/atomic" + + "golang.org/x/net/context" + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/codes" + lbpb "google.golang.org/grpc/grpclb/grpc_lb_v1/messages" + "google.golang.org/grpc/status" +) + +type rpcStats struct { + NumCallsStarted int64 + NumCallsFinished int64 + NumCallsFinishedWithDropForRateLimiting int64 + NumCallsFinishedWithDropForLoadBalancing int64 + NumCallsFinishedWithClientFailedToSend int64 + NumCallsFinishedKnownReceived int64 +} + +// toClientStats converts rpcStats to lbpb.ClientStats, and clears rpcStats. +func (s *rpcStats) toClientStats() *lbpb.ClientStats { + stats := &lbpb.ClientStats{ + NumCallsStarted: atomic.SwapInt64(&s.NumCallsStarted, 0), + NumCallsFinished: atomic.SwapInt64(&s.NumCallsFinished, 0), + NumCallsFinishedWithDropForRateLimiting: atomic.SwapInt64(&s.NumCallsFinishedWithDropForRateLimiting, 0), + NumCallsFinishedWithDropForLoadBalancing: atomic.SwapInt64(&s.NumCallsFinishedWithDropForLoadBalancing, 0), + NumCallsFinishedWithClientFailedToSend: atomic.SwapInt64(&s.NumCallsFinishedWithClientFailedToSend, 0), + NumCallsFinishedKnownReceived: atomic.SwapInt64(&s.NumCallsFinishedKnownReceived, 0), + } + return stats +} + +func (s *rpcStats) dropForRateLimiting() { + atomic.AddInt64(&s.NumCallsStarted, 1) + atomic.AddInt64(&s.NumCallsFinishedWithDropForRateLimiting, 1) + atomic.AddInt64(&s.NumCallsFinished, 1) +} + +func (s *rpcStats) dropForLoadBalancing() { + atomic.AddInt64(&s.NumCallsStarted, 1) + atomic.AddInt64(&s.NumCallsFinishedWithDropForLoadBalancing, 1) + atomic.AddInt64(&s.NumCallsFinished, 1) +} + +func (s *rpcStats) failedToSend() { + atomic.AddInt64(&s.NumCallsStarted, 1) + atomic.AddInt64(&s.NumCallsFinishedWithClientFailedToSend, 1) + atomic.AddInt64(&s.NumCallsFinished, 1) +} + +func (s *rpcStats) knownReceived() { + atomic.AddInt64(&s.NumCallsStarted, 1) + atomic.AddInt64(&s.NumCallsFinishedKnownReceived, 1) + atomic.AddInt64(&s.NumCallsFinished, 1) +} + +type errPicker struct { + // Pick always returns this err. + err error +} + +func (p *errPicker) Pick(ctx context.Context, opts balancer.PickOptions) (balancer.SubConn, func(balancer.DoneInfo), error) { + return nil, nil, p.err +} + +// rrPicker does roundrobin on subConns. It's typically used when there's no +// response from remote balancer, and grpclb falls back to the resolved +// backends. +// +// It guaranteed that len(subConns) > 0. +type rrPicker struct { + mu sync.Mutex + subConns []balancer.SubConn // The subConns that were READY when taking the snapshot. + subConnsNext int +} + +func (p *rrPicker) Pick(ctx context.Context, opts balancer.PickOptions) (balancer.SubConn, func(balancer.DoneInfo), error) { + p.mu.Lock() + defer p.mu.Unlock() + sc := p.subConns[p.subConnsNext] + p.subConnsNext = (p.subConnsNext + 1) % len(p.subConns) + return sc, nil, nil +} + +// lbPicker does two layers of picks: +// +// First layer: roundrobin on all servers in serverList, including drops and backends. +// - If it picks a drop, the RPC will fail as being dropped. +// - If it picks a backend, do a second layer pick to pick the real backend. +// +// Second layer: roundrobin on all READY backends. +// +// It's guaranteed that len(serverList) > 0. +type lbPicker struct { + mu sync.Mutex + serverList []*lbpb.Server + serverListNext int + subConns []balancer.SubConn // The subConns that were READY when taking the snapshot. + subConnsNext int + + stats *rpcStats +} + +func (p *lbPicker) Pick(ctx context.Context, opts balancer.PickOptions) (balancer.SubConn, func(balancer.DoneInfo), error) { + p.mu.Lock() + defer p.mu.Unlock() + + // Layer one roundrobin on serverList. + s := p.serverList[p.serverListNext] + p.serverListNext = (p.serverListNext + 1) % len(p.serverList) + + // If it's a drop, return an error and fail the RPC. + if s.DropForRateLimiting { + p.stats.dropForRateLimiting() + return nil, nil, status.Errorf(codes.Unavailable, "request dropped by grpclb") + } + if s.DropForLoadBalancing { + p.stats.dropForLoadBalancing() + return nil, nil, status.Errorf(codes.Unavailable, "request dropped by grpclb") + } + + // If not a drop but there's no ready subConns. + if len(p.subConns) <= 0 { + return nil, nil, balancer.ErrNoSubConnAvailable + } + + // Return the next ready subConn in the list, also collect rpc stats. + sc := p.subConns[p.subConnsNext] + p.subConnsNext = (p.subConnsNext + 1) % len(p.subConns) + done := func(info balancer.DoneInfo) { + if !info.BytesSent { + p.stats.failedToSend() + } else if info.BytesReceived { + p.stats.knownReceived() + } + } + return sc, done, nil +} diff --git a/vendor/google.golang.org/grpc/grpclb_remote_balancer.go b/vendor/google.golang.org/grpc/grpclb_remote_balancer.go new file mode 100644 index 00000000000..b8dd4f18ce5 --- /dev/null +++ b/vendor/google.golang.org/grpc/grpclb_remote_balancer.go @@ -0,0 +1,266 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "fmt" + "net" + "reflect" + "time" + + "golang.org/x/net/context" + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/channelz" + + "google.golang.org/grpc/connectivity" + lbpb "google.golang.org/grpc/grpclb/grpc_lb_v1/messages" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/metadata" + "google.golang.org/grpc/resolver" +) + +// processServerList updates balaner's internal state, create/remove SubConns +// and regenerates picker using the received serverList. +func (lb *lbBalancer) processServerList(l *lbpb.ServerList) { + grpclog.Infof("lbBalancer: processing server list: %+v", l) + lb.mu.Lock() + defer lb.mu.Unlock() + + // Set serverListReceived to true so fallback will not take effect if it has + // not hit timeout. + lb.serverListReceived = true + + // If the new server list == old server list, do nothing. + if reflect.DeepEqual(lb.fullServerList, l.Servers) { + grpclog.Infof("lbBalancer: new serverlist same as the previous one, ignoring") + return + } + lb.fullServerList = l.Servers + + var backendAddrs []resolver.Address + for _, s := range l.Servers { + if s.DropForLoadBalancing || s.DropForRateLimiting { + continue + } + + md := metadata.Pairs(lbTokeyKey, s.LoadBalanceToken) + ip := net.IP(s.IpAddress) + ipStr := ip.String() + if ip.To4() == nil { + // Add square brackets to ipv6 addresses, otherwise net.Dial() and + // net.SplitHostPort() will return too many colons error. + ipStr = fmt.Sprintf("[%s]", ipStr) + } + addr := resolver.Address{ + Addr: fmt.Sprintf("%s:%d", ipStr, s.Port), + Metadata: &md, + } + + backendAddrs = append(backendAddrs, addr) + } + + // Call refreshSubConns to create/remove SubConns. + lb.refreshSubConns(backendAddrs) + // Regenerate and update picker no matter if there's update on backends (if + // any SubConn will be newed/removed). Because since the full serverList was + // different, there might be updates in drops or pick weights(different + // number of duplicates). We need to update picker with the fulllist. + // + // Now with cache, even if SubConn was newed/removed, there might be no + // state changes. + lb.regeneratePicker() + lb.cc.UpdateBalancerState(lb.state, lb.picker) +} + +// refreshSubConns creates/removes SubConns with backendAddrs. It returns a bool +// indicating whether the backendAddrs are different from the cached +// backendAddrs (whether any SubConn was newed/removed). +// Caller must hold lb.mu. +func (lb *lbBalancer) refreshSubConns(backendAddrs []resolver.Address) bool { + lb.backendAddrs = nil + var backendsUpdated bool + // addrsSet is the set converted from backendAddrs, it's used to quick + // lookup for an address. + addrsSet := make(map[resolver.Address]struct{}) + // Create new SubConns. + for _, addr := range backendAddrs { + addrWithoutMD := addr + addrWithoutMD.Metadata = nil + addrsSet[addrWithoutMD] = struct{}{} + lb.backendAddrs = append(lb.backendAddrs, addrWithoutMD) + + if _, ok := lb.subConns[addrWithoutMD]; !ok { + backendsUpdated = true + + // Use addrWithMD to create the SubConn. + sc, err := lb.cc.NewSubConn([]resolver.Address{addr}, balancer.NewSubConnOptions{}) + if err != nil { + grpclog.Warningf("roundrobinBalancer: failed to create new SubConn: %v", err) + continue + } + lb.subConns[addrWithoutMD] = sc // Use the addr without MD as key for the map. + if _, ok := lb.scStates[sc]; !ok { + // Only set state of new sc to IDLE. The state could already be + // READY for cached SubConns. + lb.scStates[sc] = connectivity.Idle + } + sc.Connect() + } + } + + for a, sc := range lb.subConns { + // a was removed by resolver. + if _, ok := addrsSet[a]; !ok { + backendsUpdated = true + + lb.cc.RemoveSubConn(sc) + delete(lb.subConns, a) + // Keep the state of this sc in b.scStates until sc's state becomes Shutdown. + // The entry will be deleted in HandleSubConnStateChange. + } + } + + return backendsUpdated +} + +func (lb *lbBalancer) readServerList(s *balanceLoadClientStream) error { + for { + reply, err := s.Recv() + if err != nil { + return fmt.Errorf("grpclb: failed to recv server list: %v", err) + } + if serverList := reply.GetServerList(); serverList != nil { + lb.processServerList(serverList) + } + } +} + +func (lb *lbBalancer) sendLoadReport(s *balanceLoadClientStream, interval time.Duration) { + ticker := time.NewTicker(interval) + defer ticker.Stop() + for { + select { + case <-ticker.C: + case <-s.Context().Done(): + return + } + stats := lb.clientStats.toClientStats() + t := time.Now() + stats.Timestamp = &lbpb.Timestamp{ + Seconds: t.Unix(), + Nanos: int32(t.Nanosecond()), + } + if err := s.Send(&lbpb.LoadBalanceRequest{ + LoadBalanceRequestType: &lbpb.LoadBalanceRequest_ClientStats{ + ClientStats: stats, + }, + }); err != nil { + return + } + } +} + +func (lb *lbBalancer) callRemoteBalancer() error { + lbClient := &loadBalancerClient{cc: lb.ccRemoteLB} + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + stream, err := lbClient.BalanceLoad(ctx, FailFast(false)) + if err != nil { + return fmt.Errorf("grpclb: failed to perform RPC to the remote balancer %v", err) + } + + // grpclb handshake on the stream. + initReq := &lbpb.LoadBalanceRequest{ + LoadBalanceRequestType: &lbpb.LoadBalanceRequest_InitialRequest{ + InitialRequest: &lbpb.InitialLoadBalanceRequest{ + Name: lb.target, + }, + }, + } + if err := stream.Send(initReq); err != nil { + return fmt.Errorf("grpclb: failed to send init request: %v", err) + } + reply, err := stream.Recv() + if err != nil { + return fmt.Errorf("grpclb: failed to recv init response: %v", err) + } + initResp := reply.GetInitialResponse() + if initResp == nil { + return fmt.Errorf("grpclb: reply from remote balancer did not include initial response") + } + if initResp.LoadBalancerDelegate != "" { + return fmt.Errorf("grpclb: Delegation is not supported") + } + + go func() { + if d := convertDuration(initResp.ClientStatsReportInterval); d > 0 { + lb.sendLoadReport(stream, d) + } + }() + return lb.readServerList(stream) +} + +func (lb *lbBalancer) watchRemoteBalancer() { + for { + err := lb.callRemoteBalancer() + select { + case <-lb.doneCh: + return + default: + if err != nil { + grpclog.Error(err) + } + } + + } +} + +func (lb *lbBalancer) dialRemoteLB(remoteLBName string) { + var dopts []DialOption + if creds := lb.opt.DialCreds; creds != nil { + if err := creds.OverrideServerName(remoteLBName); err == nil { + dopts = append(dopts, WithTransportCredentials(creds)) + } else { + grpclog.Warningf("grpclb: failed to override the server name in the credentials: %v, using Insecure", err) + dopts = append(dopts, WithInsecure()) + } + } else { + dopts = append(dopts, WithInsecure()) + } + if lb.opt.Dialer != nil { + // WithDialer takes a different type of function, so we instead use a + // special DialOption here. + dopts = append(dopts, withContextDialer(lb.opt.Dialer)) + } + // Explicitly set pickfirst as the balancer. + dopts = append(dopts, WithBalancerName(PickFirstBalancerName)) + dopts = append(dopts, withResolverBuilder(lb.manualResolver)) + if channelz.IsOn() { + dopts = append(dopts, WithChannelzParentID(lb.opt.ChannelzParentID)) + } + + // DialContext using manualResolver.Scheme, which is a random scheme generated + // when init grpclb. The target name is not important. + cc, err := DialContext(context.Background(), "grpclb:///grpclb.server", dopts...) + if err != nil { + grpclog.Fatalf("failed to dial: %v", err) + } + lb.ccRemoteLB = cc + go lb.watchRemoteBalancer() +} diff --git a/vendor/google.golang.org/grpc/grpclb_util.go b/vendor/google.golang.org/grpc/grpclb_util.go new file mode 100644 index 00000000000..063ba9d8590 --- /dev/null +++ b/vendor/google.golang.org/grpc/grpclb_util.go @@ -0,0 +1,214 @@ +/* + * + * Copyright 2016 gRPC 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 grpc + +import ( + "fmt" + "sync" + "time" + + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/connectivity" + "google.golang.org/grpc/resolver" +) + +// The parent ClientConn should re-resolve when grpclb loses connection to the +// remote balancer. When the ClientConn inside grpclb gets a TransientFailure, +// it calls lbManualResolver.ResolveNow(), which calls parent ClientConn's +// ResolveNow, and eventually results in re-resolve happening in parent +// ClientConn's resolver (DNS for example). +// +// parent +// ClientConn +// +-----------------------------------------------------------------+ +// | parent +---------------------------------+ | +// | DNS ClientConn | grpclb | | +// | resolver balancerWrapper | | | +// | + + | grpclb grpclb | | +// | | | | ManualResolver ClientConn | | +// | | | | + + | | +// | | | | | | Transient | | +// | | | | | | Failure | | +// | | | | | <--------- | | | +// | | | <--------------- | ResolveNow | | | +// | | <--------- | ResolveNow | | | | | +// | | ResolveNow | | | | | | +// | | | | | | | | +// | + + | + + | | +// | +---------------------------------+ | +// +-----------------------------------------------------------------+ + +// lbManualResolver is used by the ClientConn inside grpclb. It's a manual +// resolver with a special ResolveNow() function. +// +// When ResolveNow() is called, it calls ResolveNow() on the parent ClientConn, +// so when grpclb client lose contact with remote balancers, the parent +// ClientConn's resolver will re-resolve. +type lbManualResolver struct { + scheme string + ccr resolver.ClientConn + + ccb balancer.ClientConn +} + +func (r *lbManualResolver) Build(_ resolver.Target, cc resolver.ClientConn, _ resolver.BuildOption) (resolver.Resolver, error) { + r.ccr = cc + return r, nil +} + +func (r *lbManualResolver) Scheme() string { + return r.scheme +} + +// ResolveNow calls resolveNow on the parent ClientConn. +func (r *lbManualResolver) ResolveNow(o resolver.ResolveNowOption) { + r.ccb.ResolveNow(o) +} + +// Close is a noop for Resolver. +func (*lbManualResolver) Close() {} + +// NewAddress calls cc.NewAddress. +func (r *lbManualResolver) NewAddress(addrs []resolver.Address) { + r.ccr.NewAddress(addrs) +} + +// NewServiceConfig calls cc.NewServiceConfig. +func (r *lbManualResolver) NewServiceConfig(sc string) { + r.ccr.NewServiceConfig(sc) +} + +const subConnCacheTime = time.Second * 10 + +// lbCacheClientConn is a wrapper balancer.ClientConn with a SubConn cache. +// SubConns will be kept in cache for subConnCacheTime before being removed. +// +// Its new and remove methods are updated to do cache first. +type lbCacheClientConn struct { + cc balancer.ClientConn + timeout time.Duration + + mu sync.Mutex + // subConnCache only keeps subConns that are being deleted. + subConnCache map[resolver.Address]*subConnCacheEntry + subConnToAddr map[balancer.SubConn]resolver.Address +} + +type subConnCacheEntry struct { + sc balancer.SubConn + + cancel func() + abortDeleting bool +} + +func newLBCacheClientConn(cc balancer.ClientConn) *lbCacheClientConn { + return &lbCacheClientConn{ + cc: cc, + timeout: subConnCacheTime, + subConnCache: make(map[resolver.Address]*subConnCacheEntry), + subConnToAddr: make(map[balancer.SubConn]resolver.Address), + } +} + +func (ccc *lbCacheClientConn) NewSubConn(addrs []resolver.Address, opts balancer.NewSubConnOptions) (balancer.SubConn, error) { + if len(addrs) != 1 { + return nil, fmt.Errorf("grpclb calling NewSubConn with addrs of length %v", len(addrs)) + } + addrWithoutMD := addrs[0] + addrWithoutMD.Metadata = nil + + ccc.mu.Lock() + defer ccc.mu.Unlock() + if entry, ok := ccc.subConnCache[addrWithoutMD]; ok { + // If entry is in subConnCache, the SubConn was being deleted. + // cancel function will never be nil. + entry.cancel() + delete(ccc.subConnCache, addrWithoutMD) + return entry.sc, nil + } + + scNew, err := ccc.cc.NewSubConn(addrs, opts) + if err != nil { + return nil, err + } + + ccc.subConnToAddr[scNew] = addrWithoutMD + return scNew, nil +} + +func (ccc *lbCacheClientConn) RemoveSubConn(sc balancer.SubConn) { + ccc.mu.Lock() + defer ccc.mu.Unlock() + addr, ok := ccc.subConnToAddr[sc] + if !ok { + return + } + + if entry, ok := ccc.subConnCache[addr]; ok { + if entry.sc != sc { + // This could happen if NewSubConn was called multiple times for the + // same address, and those SubConns are all removed. We remove sc + // immediately here. + delete(ccc.subConnToAddr, sc) + ccc.cc.RemoveSubConn(sc) + } + return + } + + entry := &subConnCacheEntry{ + sc: sc, + } + ccc.subConnCache[addr] = entry + + timer := time.AfterFunc(ccc.timeout, func() { + ccc.mu.Lock() + if entry.abortDeleting { + return + } + ccc.cc.RemoveSubConn(sc) + delete(ccc.subConnToAddr, sc) + delete(ccc.subConnCache, addr) + ccc.mu.Unlock() + }) + entry.cancel = func() { + if !timer.Stop() { + // If stop was not successful, the timer has fired (this can only + // happen in a race). But the deleting function is blocked on ccc.mu + // because the mutex was held by the caller of this function. + // + // Set abortDeleting to true to abort the deleting function. When + // the lock is released, the deleting function will acquire the + // lock, check the value of abortDeleting and return. + entry.abortDeleting = true + } + } +} + +func (ccc *lbCacheClientConn) UpdateBalancerState(s connectivity.State, p balancer.Picker) { + ccc.cc.UpdateBalancerState(s, p) +} + +func (ccc *lbCacheClientConn) close() { + ccc.mu.Lock() + // Only cancel all existing timers. There's no need to remove SubConns. + for _, entry := range ccc.subConnCache { + entry.cancel() + } + ccc.mu.Unlock() +} diff --git a/vendor/google.golang.org/grpc/grpclog/grpclog.go b/vendor/google.golang.org/grpc/grpclog/grpclog.go new file mode 100644 index 00000000000..1fabb11e1ba --- /dev/null +++ b/vendor/google.golang.org/grpc/grpclog/grpclog.go @@ -0,0 +1,126 @@ +/* + * + * Copyright 2017 gRPC 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 grpclog defines logging for grpc. +// +// All logs in transport package only go to verbose level 2. +// All logs in other packages in grpc are logged in spite of the verbosity level. +// +// In the default logger, +// severity level can be set by environment variable GRPC_GO_LOG_SEVERITY_LEVEL, +// verbosity level can be set by GRPC_GO_LOG_VERBOSITY_LEVEL. +package grpclog // import "google.golang.org/grpc/grpclog" + +import "os" + +var logger = newLoggerV2() + +// V reports whether verbosity level l is at least the requested verbose level. +func V(l int) bool { + return logger.V(l) +} + +// Info logs to the INFO log. +func Info(args ...interface{}) { + logger.Info(args...) +} + +// Infof logs to the INFO log. Arguments are handled in the manner of fmt.Printf. +func Infof(format string, args ...interface{}) { + logger.Infof(format, args...) +} + +// Infoln logs to the INFO log. Arguments are handled in the manner of fmt.Println. +func Infoln(args ...interface{}) { + logger.Infoln(args...) +} + +// Warning logs to the WARNING log. +func Warning(args ...interface{}) { + logger.Warning(args...) +} + +// Warningf logs to the WARNING log. Arguments are handled in the manner of fmt.Printf. +func Warningf(format string, args ...interface{}) { + logger.Warningf(format, args...) +} + +// Warningln logs to the WARNING log. Arguments are handled in the manner of fmt.Println. +func Warningln(args ...interface{}) { + logger.Warningln(args...) +} + +// Error logs to the ERROR log. +func Error(args ...interface{}) { + logger.Error(args...) +} + +// Errorf logs to the ERROR log. Arguments are handled in the manner of fmt.Printf. +func Errorf(format string, args ...interface{}) { + logger.Errorf(format, args...) +} + +// Errorln logs to the ERROR log. Arguments are handled in the manner of fmt.Println. +func Errorln(args ...interface{}) { + logger.Errorln(args...) +} + +// Fatal logs to the FATAL log. Arguments are handled in the manner of fmt.Print. +// It calls os.Exit() with exit code 1. +func Fatal(args ...interface{}) { + logger.Fatal(args...) + // Make sure fatal logs will exit. + os.Exit(1) +} + +// Fatalf logs to the FATAL log. Arguments are handled in the manner of fmt.Printf. +// It calles os.Exit() with exit code 1. +func Fatalf(format string, args ...interface{}) { + logger.Fatalf(format, args...) + // Make sure fatal logs will exit. + os.Exit(1) +} + +// Fatalln logs to the FATAL log. Arguments are handled in the manner of fmt.Println. +// It calle os.Exit()) with exit code 1. +func Fatalln(args ...interface{}) { + logger.Fatalln(args...) + // Make sure fatal logs will exit. + os.Exit(1) +} + +// Print prints to the logger. Arguments are handled in the manner of fmt.Print. +// +// Deprecated: use Info. +func Print(args ...interface{}) { + logger.Info(args...) +} + +// Printf prints to the logger. Arguments are handled in the manner of fmt.Printf. +// +// Deprecated: use Infof. +func Printf(format string, args ...interface{}) { + logger.Infof(format, args...) +} + +// Println prints to the logger. Arguments are handled in the manner of fmt.Println. +// +// Deprecated: use Infoln. +func Println(args ...interface{}) { + logger.Infoln(args...) +} diff --git a/vendor/google.golang.org/grpc/grpclog/logger.go b/vendor/google.golang.org/grpc/grpclog/logger.go new file mode 100644 index 00000000000..097494f710f --- /dev/null +++ b/vendor/google.golang.org/grpc/grpclog/logger.go @@ -0,0 +1,85 @@ +/* + * + * Copyright 2015 gRPC 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 grpclog + +// Logger mimics golang's standard Logger as an interface. +// +// Deprecated: use LoggerV2. +type Logger interface { + Fatal(args ...interface{}) + Fatalf(format string, args ...interface{}) + Fatalln(args ...interface{}) + Print(args ...interface{}) + Printf(format string, args ...interface{}) + Println(args ...interface{}) +} + +// SetLogger sets the logger that is used in grpc. Call only from +// init() functions. +// +// Deprecated: use SetLoggerV2. +func SetLogger(l Logger) { + logger = &loggerWrapper{Logger: l} +} + +// loggerWrapper wraps Logger into a LoggerV2. +type loggerWrapper struct { + Logger +} + +func (g *loggerWrapper) Info(args ...interface{}) { + g.Logger.Print(args...) +} + +func (g *loggerWrapper) Infoln(args ...interface{}) { + g.Logger.Println(args...) +} + +func (g *loggerWrapper) Infof(format string, args ...interface{}) { + g.Logger.Printf(format, args...) +} + +func (g *loggerWrapper) Warning(args ...interface{}) { + g.Logger.Print(args...) +} + +func (g *loggerWrapper) Warningln(args ...interface{}) { + g.Logger.Println(args...) +} + +func (g *loggerWrapper) Warningf(format string, args ...interface{}) { + g.Logger.Printf(format, args...) +} + +func (g *loggerWrapper) Error(args ...interface{}) { + g.Logger.Print(args...) +} + +func (g *loggerWrapper) Errorln(args ...interface{}) { + g.Logger.Println(args...) +} + +func (g *loggerWrapper) Errorf(format string, args ...interface{}) { + g.Logger.Printf(format, args...) +} + +func (g *loggerWrapper) V(l int) bool { + // Returns true for all verbose level. + return true +} diff --git a/vendor/google.golang.org/grpc/grpclog/loggerv2.go b/vendor/google.golang.org/grpc/grpclog/loggerv2.go new file mode 100644 index 00000000000..d4932577695 --- /dev/null +++ b/vendor/google.golang.org/grpc/grpclog/loggerv2.go @@ -0,0 +1,195 @@ +/* + * + * Copyright 2017 gRPC 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 grpclog + +import ( + "io" + "io/ioutil" + "log" + "os" + "strconv" +) + +// LoggerV2 does underlying logging work for grpclog. +type LoggerV2 interface { + // Info logs to INFO log. Arguments are handled in the manner of fmt.Print. + Info(args ...interface{}) + // Infoln logs to INFO log. Arguments are handled in the manner of fmt.Println. + Infoln(args ...interface{}) + // Infof logs to INFO log. Arguments are handled in the manner of fmt.Printf. + Infof(format string, args ...interface{}) + // Warning logs to WARNING log. Arguments are handled in the manner of fmt.Print. + Warning(args ...interface{}) + // Warningln logs to WARNING log. Arguments are handled in the manner of fmt.Println. + Warningln(args ...interface{}) + // Warningf logs to WARNING log. Arguments are handled in the manner of fmt.Printf. + Warningf(format string, args ...interface{}) + // Error logs to ERROR log. Arguments are handled in the manner of fmt.Print. + Error(args ...interface{}) + // Errorln logs to ERROR log. Arguments are handled in the manner of fmt.Println. + Errorln(args ...interface{}) + // Errorf logs to ERROR log. Arguments are handled in the manner of fmt.Printf. + Errorf(format string, args ...interface{}) + // Fatal logs to ERROR log. Arguments are handled in the manner of fmt.Print. + // gRPC ensures that all Fatal logs will exit with os.Exit(1). + // Implementations may also call os.Exit() with a non-zero exit code. + Fatal(args ...interface{}) + // Fatalln logs to ERROR log. Arguments are handled in the manner of fmt.Println. + // gRPC ensures that all Fatal logs will exit with os.Exit(1). + // Implementations may also call os.Exit() with a non-zero exit code. + Fatalln(args ...interface{}) + // Fatalf logs to ERROR log. Arguments are handled in the manner of fmt.Printf. + // gRPC ensures that all Fatal logs will exit with os.Exit(1). + // Implementations may also call os.Exit() with a non-zero exit code. + Fatalf(format string, args ...interface{}) + // V reports whether verbosity level l is at least the requested verbose level. + V(l int) bool +} + +// SetLoggerV2 sets logger that is used in grpc to a V2 logger. +// Not mutex-protected, should be called before any gRPC functions. +func SetLoggerV2(l LoggerV2) { + logger = l +} + +const ( + // infoLog indicates Info severity. + infoLog int = iota + // warningLog indicates Warning severity. + warningLog + // errorLog indicates Error severity. + errorLog + // fatalLog indicates Fatal severity. + fatalLog +) + +// severityName contains the string representation of each severity. +var severityName = []string{ + infoLog: "INFO", + warningLog: "WARNING", + errorLog: "ERROR", + fatalLog: "FATAL", +} + +// loggerT is the default logger used by grpclog. +type loggerT struct { + m []*log.Logger + v int +} + +// NewLoggerV2 creates a loggerV2 with the provided writers. +// Fatal logs will be written to errorW, warningW, infoW, followed by exit(1). +// Error logs will be written to errorW, warningW and infoW. +// Warning logs will be written to warningW and infoW. +// Info logs will be written to infoW. +func NewLoggerV2(infoW, warningW, errorW io.Writer) LoggerV2 { + return NewLoggerV2WithVerbosity(infoW, warningW, errorW, 0) +} + +// NewLoggerV2WithVerbosity creates a loggerV2 with the provided writers and +// verbosity level. +func NewLoggerV2WithVerbosity(infoW, warningW, errorW io.Writer, v int) LoggerV2 { + var m []*log.Logger + m = append(m, log.New(infoW, severityName[infoLog]+": ", log.LstdFlags)) + m = append(m, log.New(io.MultiWriter(infoW, warningW), severityName[warningLog]+": ", log.LstdFlags)) + ew := io.MultiWriter(infoW, warningW, errorW) // ew will be used for error and fatal. + m = append(m, log.New(ew, severityName[errorLog]+": ", log.LstdFlags)) + m = append(m, log.New(ew, severityName[fatalLog]+": ", log.LstdFlags)) + return &loggerT{m: m, v: v} +} + +// newLoggerV2 creates a loggerV2 to be used as default logger. +// All logs are written to stderr. +func newLoggerV2() LoggerV2 { + errorW := ioutil.Discard + warningW := ioutil.Discard + infoW := ioutil.Discard + + logLevel := os.Getenv("GRPC_GO_LOG_SEVERITY_LEVEL") + switch logLevel { + case "", "ERROR", "error": // If env is unset, set level to ERROR. + errorW = os.Stderr + case "WARNING", "warning": + warningW = os.Stderr + case "INFO", "info": + infoW = os.Stderr + } + + var v int + vLevel := os.Getenv("GRPC_GO_LOG_VERBOSITY_LEVEL") + if vl, err := strconv.Atoi(vLevel); err == nil { + v = vl + } + return NewLoggerV2WithVerbosity(infoW, warningW, errorW, v) +} + +func (g *loggerT) Info(args ...interface{}) { + g.m[infoLog].Print(args...) +} + +func (g *loggerT) Infoln(args ...interface{}) { + g.m[infoLog].Println(args...) +} + +func (g *loggerT) Infof(format string, args ...interface{}) { + g.m[infoLog].Printf(format, args...) +} + +func (g *loggerT) Warning(args ...interface{}) { + g.m[warningLog].Print(args...) +} + +func (g *loggerT) Warningln(args ...interface{}) { + g.m[warningLog].Println(args...) +} + +func (g *loggerT) Warningf(format string, args ...interface{}) { + g.m[warningLog].Printf(format, args...) +} + +func (g *loggerT) Error(args ...interface{}) { + g.m[errorLog].Print(args...) +} + +func (g *loggerT) Errorln(args ...interface{}) { + g.m[errorLog].Println(args...) +} + +func (g *loggerT) Errorf(format string, args ...interface{}) { + g.m[errorLog].Printf(format, args...) +} + +func (g *loggerT) Fatal(args ...interface{}) { + g.m[fatalLog].Fatal(args...) + // No need to call os.Exit() again because log.Logger.Fatal() calls os.Exit(). +} + +func (g *loggerT) Fatalln(args ...interface{}) { + g.m[fatalLog].Fatalln(args...) + // No need to call os.Exit() again because log.Logger.Fatal() calls os.Exit(). +} + +func (g *loggerT) Fatalf(format string, args ...interface{}) { + g.m[fatalLog].Fatalf(format, args...) + // No need to call os.Exit() again because log.Logger.Fatal() calls os.Exit(). +} + +func (g *loggerT) V(l int) bool { + return l <= g.v +} diff --git a/vendor/google.golang.org/grpc/health/grpc_health_v1/health.pb.go b/vendor/google.golang.org/grpc/health/grpc_health_v1/health.pb.go new file mode 100644 index 00000000000..e5906de7d43 --- /dev/null +++ b/vendor/google.golang.org/grpc/health/grpc_health_v1/health.pb.go @@ -0,0 +1,227 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: grpc_health_v1/health.proto + +package grpc_health_v1 // import "google.golang.org/grpc/health/grpc_health_v1" + +import proto "github.com/golang/protobuf/proto" +import fmt "fmt" +import math "math" + +import ( + context "golang.org/x/net/context" + grpc "google.golang.org/grpc" +) + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package + +type HealthCheckResponse_ServingStatus int32 + +const ( + HealthCheckResponse_UNKNOWN HealthCheckResponse_ServingStatus = 0 + HealthCheckResponse_SERVING HealthCheckResponse_ServingStatus = 1 + HealthCheckResponse_NOT_SERVING HealthCheckResponse_ServingStatus = 2 +) + +var HealthCheckResponse_ServingStatus_name = map[int32]string{ + 0: "UNKNOWN", + 1: "SERVING", + 2: "NOT_SERVING", +} +var HealthCheckResponse_ServingStatus_value = map[string]int32{ + "UNKNOWN": 0, + "SERVING": 1, + "NOT_SERVING": 2, +} + +func (x HealthCheckResponse_ServingStatus) String() string { + return proto.EnumName(HealthCheckResponse_ServingStatus_name, int32(x)) +} +func (HealthCheckResponse_ServingStatus) EnumDescriptor() ([]byte, []int) { + return fileDescriptor_health_8e5b8a3074428511, []int{1, 0} +} + +type HealthCheckRequest struct { + Service string `protobuf:"bytes,1,opt,name=service" json:"service,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *HealthCheckRequest) Reset() { *m = HealthCheckRequest{} } +func (m *HealthCheckRequest) String() string { return proto.CompactTextString(m) } +func (*HealthCheckRequest) ProtoMessage() {} +func (*HealthCheckRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_health_8e5b8a3074428511, []int{0} +} +func (m *HealthCheckRequest) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_HealthCheckRequest.Unmarshal(m, b) +} +func (m *HealthCheckRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_HealthCheckRequest.Marshal(b, m, deterministic) +} +func (dst *HealthCheckRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_HealthCheckRequest.Merge(dst, src) +} +func (m *HealthCheckRequest) XXX_Size() int { + return xxx_messageInfo_HealthCheckRequest.Size(m) +} +func (m *HealthCheckRequest) XXX_DiscardUnknown() { + xxx_messageInfo_HealthCheckRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_HealthCheckRequest proto.InternalMessageInfo + +func (m *HealthCheckRequest) GetService() string { + if m != nil { + return m.Service + } + return "" +} + +type HealthCheckResponse struct { + Status HealthCheckResponse_ServingStatus `protobuf:"varint,1,opt,name=status,enum=grpc.health.v1.HealthCheckResponse_ServingStatus" json:"status,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *HealthCheckResponse) Reset() { *m = HealthCheckResponse{} } +func (m *HealthCheckResponse) String() string { return proto.CompactTextString(m) } +func (*HealthCheckResponse) ProtoMessage() {} +func (*HealthCheckResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_health_8e5b8a3074428511, []int{1} +} +func (m *HealthCheckResponse) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_HealthCheckResponse.Unmarshal(m, b) +} +func (m *HealthCheckResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_HealthCheckResponse.Marshal(b, m, deterministic) +} +func (dst *HealthCheckResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_HealthCheckResponse.Merge(dst, src) +} +func (m *HealthCheckResponse) XXX_Size() int { + return xxx_messageInfo_HealthCheckResponse.Size(m) +} +func (m *HealthCheckResponse) XXX_DiscardUnknown() { + xxx_messageInfo_HealthCheckResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_HealthCheckResponse proto.InternalMessageInfo + +func (m *HealthCheckResponse) GetStatus() HealthCheckResponse_ServingStatus { + if m != nil { + return m.Status + } + return HealthCheckResponse_UNKNOWN +} + +func init() { + proto.RegisterType((*HealthCheckRequest)(nil), "grpc.health.v1.HealthCheckRequest") + proto.RegisterType((*HealthCheckResponse)(nil), "grpc.health.v1.HealthCheckResponse") + proto.RegisterEnum("grpc.health.v1.HealthCheckResponse_ServingStatus", HealthCheckResponse_ServingStatus_name, HealthCheckResponse_ServingStatus_value) +} + +// Reference imports to suppress errors if they are not otherwise used. +var _ context.Context +var _ grpc.ClientConn + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the grpc package it is being compiled against. +const _ = grpc.SupportPackageIsVersion4 + +// Client API for Health service + +type HealthClient interface { + Check(ctx context.Context, in *HealthCheckRequest, opts ...grpc.CallOption) (*HealthCheckResponse, error) +} + +type healthClient struct { + cc *grpc.ClientConn +} + +func NewHealthClient(cc *grpc.ClientConn) HealthClient { + return &healthClient{cc} +} + +func (c *healthClient) Check(ctx context.Context, in *HealthCheckRequest, opts ...grpc.CallOption) (*HealthCheckResponse, error) { + out := new(HealthCheckResponse) + err := grpc.Invoke(ctx, "/grpc.health.v1.Health/Check", in, out, c.cc, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +// Server API for Health service + +type HealthServer interface { + Check(context.Context, *HealthCheckRequest) (*HealthCheckResponse, error) +} + +func RegisterHealthServer(s *grpc.Server, srv HealthServer) { + s.RegisterService(&_Health_serviceDesc, srv) +} + +func _Health_Check_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(HealthCheckRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(HealthServer).Check(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/grpc.health.v1.Health/Check", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(HealthServer).Check(ctx, req.(*HealthCheckRequest)) + } + return interceptor(ctx, in, info, handler) +} + +var _Health_serviceDesc = grpc.ServiceDesc{ + ServiceName: "grpc.health.v1.Health", + HandlerType: (*HealthServer)(nil), + Methods: []grpc.MethodDesc{ + { + MethodName: "Check", + Handler: _Health_Check_Handler, + }, + }, + Streams: []grpc.StreamDesc{}, + Metadata: "grpc_health_v1/health.proto", +} + +func init() { proto.RegisterFile("grpc_health_v1/health.proto", fileDescriptor_health_8e5b8a3074428511) } + +var fileDescriptor_health_8e5b8a3074428511 = []byte{ + // 269 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x92, 0x4e, 0x2f, 0x2a, 0x48, + 0x8e, 0xcf, 0x48, 0x4d, 0xcc, 0x29, 0xc9, 0x88, 0x2f, 0x33, 0xd4, 0x87, 0xb0, 0xf4, 0x0a, 0x8a, + 0xf2, 0x4b, 0xf2, 0x85, 0xf8, 0x40, 0x92, 0x7a, 0x50, 0xa1, 0x32, 0x43, 0x25, 0x3d, 0x2e, 0x21, + 0x0f, 0x30, 0xc7, 0x39, 0x23, 0x35, 0x39, 0x3b, 0x28, 0xb5, 0xb0, 0x34, 0xb5, 0xb8, 0x44, 0x48, + 0x82, 0x8b, 0xbd, 0x38, 0xb5, 0xa8, 0x2c, 0x33, 0x39, 0x55, 0x82, 0x51, 0x81, 0x51, 0x83, 0x33, + 0x08, 0xc6, 0x55, 0x9a, 0xc3, 0xc8, 0x25, 0x8c, 0xa2, 0xa1, 0xb8, 0x20, 0x3f, 0xaf, 0x38, 0x55, + 0xc8, 0x93, 0x8b, 0xad, 0xb8, 0x24, 0xb1, 0xa4, 0xb4, 0x18, 0xac, 0x81, 0xcf, 0xc8, 0x50, 0x0f, + 0xd5, 0x22, 0x3d, 0x2c, 0x9a, 0xf4, 0x82, 0x41, 0x86, 0xe6, 0xa5, 0x07, 0x83, 0x35, 0x06, 0x41, + 0x0d, 0x50, 0xb2, 0xe2, 0xe2, 0x45, 0x91, 0x10, 0xe2, 0xe6, 0x62, 0x0f, 0xf5, 0xf3, 0xf6, 0xf3, + 0x0f, 0xf7, 0x13, 0x60, 0x00, 0x71, 0x82, 0x5d, 0x83, 0xc2, 0x3c, 0xfd, 0xdc, 0x05, 0x18, 0x85, + 0xf8, 0xb9, 0xb8, 0xfd, 0xfc, 0x43, 0xe2, 0x61, 0x02, 0x4c, 0x46, 0x51, 0x5c, 0x6c, 0x10, 0x8b, + 0x84, 0x02, 0xb8, 0x58, 0xc1, 0x96, 0x09, 0x29, 0xe1, 0x75, 0x09, 0xd8, 0xbf, 0x52, 0xca, 0x44, + 0xb8, 0xd6, 0x29, 0x91, 0x4b, 0x30, 0x33, 0x1f, 0x4d, 0xa1, 0x13, 0x37, 0x44, 0x65, 0x00, 0x28, + 0x70, 0x03, 0x18, 0xa3, 0x74, 0xd2, 0xf3, 0xf3, 0xd3, 0x73, 0x52, 0xf5, 0xd2, 0xf3, 0x73, 0x12, + 0xf3, 0xd2, 0xf5, 0xf2, 0x8b, 0xd2, 0xf5, 0x41, 0x1a, 0xa0, 0x71, 0xa0, 0x8f, 0x1a, 0x33, 0xab, + 0x98, 0xf8, 0xdc, 0x41, 0xa6, 0x41, 0x8c, 0xd0, 0x0b, 0x33, 0x4c, 0x62, 0x03, 0x47, 0x92, 0x31, + 0x20, 0x00, 0x00, 0xff, 0xff, 0xb7, 0x70, 0xc4, 0xa7, 0xc3, 0x01, 0x00, 0x00, +} diff --git a/vendor/google.golang.org/grpc/health/grpc_health_v1/health.proto b/vendor/google.golang.org/grpc/health/grpc_health_v1/health.proto new file mode 100644 index 00000000000..bcc02f8ac83 --- /dev/null +++ b/vendor/google.golang.org/grpc/health/grpc_health_v1/health.proto @@ -0,0 +1,44 @@ +// Copyright 2015, gRPC Authors +// 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. + +// The canonical version of this proto can be found at +// https://github.com/grpc/grpc-proto/blob/master/grpc/health/v1/health.proto + +syntax = "proto3"; + +package grpc.health.v1; + +option csharp_namespace = "Grpc.Health.V1"; +option go_package = "google.golang.org/grpc/health/grpc_health_v1"; +option java_multiple_files = true; +option java_outer_classname = "HealthProto"; +option java_package = "io.grpc.health.v1"; + +message HealthCheckRequest { + string service = 1; +} + +message HealthCheckResponse { + enum ServingStatus { + UNKNOWN = 0; + SERVING = 1; + NOT_SERVING = 2; + } + ServingStatus status = 1; +} + +service Health { + rpc Check(HealthCheckRequest) returns (HealthCheckResponse); +} diff --git a/vendor/google.golang.org/grpc/interceptor.go b/vendor/google.golang.org/grpc/interceptor.go new file mode 100644 index 00000000000..1f6ef678035 --- /dev/null +++ b/vendor/google.golang.org/grpc/interceptor.go @@ -0,0 +1,77 @@ +/* + * + * Copyright 2016 gRPC 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 grpc + +import ( + "golang.org/x/net/context" +) + +// UnaryInvoker is called by UnaryClientInterceptor to complete RPCs. +type UnaryInvoker func(ctx context.Context, method string, req, reply interface{}, cc *ClientConn, opts ...CallOption) error + +// UnaryClientInterceptor intercepts the execution of a unary RPC on the client. invoker is the handler to complete the RPC +// and it is the responsibility of the interceptor to call it. +// This is an EXPERIMENTAL API. +type UnaryClientInterceptor func(ctx context.Context, method string, req, reply interface{}, cc *ClientConn, invoker UnaryInvoker, opts ...CallOption) error + +// Streamer is called by StreamClientInterceptor to create a ClientStream. +type Streamer func(ctx context.Context, desc *StreamDesc, cc *ClientConn, method string, opts ...CallOption) (ClientStream, error) + +// StreamClientInterceptor intercepts the creation of ClientStream. It may return a custom ClientStream to intercept all I/O +// operations. streamer is the handler to create a ClientStream and it is the responsibility of the interceptor to call it. +// This is an EXPERIMENTAL API. +type StreamClientInterceptor func(ctx context.Context, desc *StreamDesc, cc *ClientConn, method string, streamer Streamer, opts ...CallOption) (ClientStream, error) + +// UnaryServerInfo consists of various information about a unary RPC on +// server side. All per-rpc information may be mutated by the interceptor. +type UnaryServerInfo struct { + // Server is the service implementation the user provides. This is read-only. + Server interface{} + // FullMethod is the full RPC method string, i.e., /package.service/method. + FullMethod string +} + +// UnaryHandler defines the handler invoked by UnaryServerInterceptor to complete the normal +// execution of a unary RPC. If a UnaryHandler returns an error, it should be produced by the +// status package, or else gRPC will use codes.Unknown as the status code and err.Error() as +// the status message of the RPC. +type UnaryHandler func(ctx context.Context, req interface{}) (interface{}, error) + +// UnaryServerInterceptor provides a hook to intercept the execution of a unary RPC on the server. info +// contains all the information of this RPC the interceptor can operate on. And handler is the wrapper +// of the service method implementation. It is the responsibility of the interceptor to invoke handler +// to complete the RPC. +type UnaryServerInterceptor func(ctx context.Context, req interface{}, info *UnaryServerInfo, handler UnaryHandler) (resp interface{}, err error) + +// StreamServerInfo consists of various information about a streaming RPC on +// server side. All per-rpc information may be mutated by the interceptor. +type StreamServerInfo struct { + // FullMethod is the full RPC method string, i.e., /package.service/method. + FullMethod string + // IsClientStream indicates whether the RPC is a client streaming RPC. + IsClientStream bool + // IsServerStream indicates whether the RPC is a server streaming RPC. + IsServerStream bool +} + +// StreamServerInterceptor provides a hook to intercept the execution of a streaming RPC on the server. +// info contains all the information of this RPC the interceptor can operate on. And handler is the +// service method implementation. It is the responsibility of the interceptor to invoke handler to +// complete the RPC. +type StreamServerInterceptor func(srv interface{}, ss ServerStream, info *StreamServerInfo, handler StreamHandler) error diff --git a/vendor/google.golang.org/grpc/internal/internal.go b/vendor/google.golang.org/grpc/internal/internal.go new file mode 100644 index 00000000000..53f1775201c --- /dev/null +++ b/vendor/google.golang.org/grpc/internal/internal.go @@ -0,0 +1,27 @@ +/* + * Copyright 2016 gRPC 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 internal contains gRPC-internal code for testing, to avoid polluting +// the godoc of the top-level grpc package. +package internal + +// TestingUseHandlerImpl enables the http.Handler-based server implementation. +// It must be called before Serve and requires TLS credentials. +// +// The provided grpcServer must be of type *grpc.Server. It is untyped +// for circular dependency reasons. +var TestingUseHandlerImpl func(grpcServer interface{}) diff --git a/vendor/google.golang.org/grpc/keepalive/keepalive.go b/vendor/google.golang.org/grpc/keepalive/keepalive.go new file mode 100644 index 00000000000..f8adc7e6d4f --- /dev/null +++ b/vendor/google.golang.org/grpc/keepalive/keepalive.go @@ -0,0 +1,65 @@ +/* + * + * Copyright 2017 gRPC 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 keepalive defines configurable parameters for point-to-point healthcheck. +package keepalive + +import ( + "time" +) + +// ClientParameters is used to set keepalive parameters on the client-side. +// These configure how the client will actively probe to notice when a connection is broken +// and send pings so intermediaries will be aware of the liveness of the connection. +// Make sure these parameters are set in coordination with the keepalive policy on the server, +// as incompatible settings can result in closing of connection. +type ClientParameters struct { + // After a duration of this time if the client doesn't see any activity it pings the server to see if the transport is still alive. + Time time.Duration // The current default value is infinity. + // After having pinged for keepalive check, the client waits for a duration of Timeout and if no activity is seen even after that + // the connection is closed. + Timeout time.Duration // The current default value is 20 seconds. + // If true, client runs keepalive checks even with no active RPCs. + PermitWithoutStream bool // false by default. +} + +// ServerParameters is used to set keepalive and max-age parameters on the server-side. +type ServerParameters struct { + // MaxConnectionIdle is a duration for the amount of time after which an idle connection would be closed by sending a GoAway. + // Idleness duration is defined since the most recent time the number of outstanding RPCs became zero or the connection establishment. + MaxConnectionIdle time.Duration // The current default value is infinity. + // MaxConnectionAge is a duration for the maximum amount of time a connection may exist before it will be closed by sending a GoAway. + // A random jitter of +/-10% will be added to MaxConnectionAge to spread out connection storms. + MaxConnectionAge time.Duration // The current default value is infinity. + // MaxConnectinoAgeGrace is an additive period after MaxConnectionAge after which the connection will be forcibly closed. + MaxConnectionAgeGrace time.Duration // The current default value is infinity. + // After a duration of this time if the server doesn't see any activity it pings the client to see if the transport is still alive. + Time time.Duration // The current default value is 2 hours. + // After having pinged for keepalive check, the server waits for a duration of Timeout and if no activity is seen even after that + // the connection is closed. + Timeout time.Duration // The current default value is 20 seconds. +} + +// EnforcementPolicy is used to set keepalive enforcement policy on the server-side. +// Server will close connection with a client that violates this policy. +type EnforcementPolicy struct { + // MinTime is the minimum amount of time a client should wait before sending a keepalive ping. + MinTime time.Duration // The current default value is 5 minutes. + // If true, server expects keepalive pings even when there are no active streams(RPCs). + PermitWithoutStream bool // false by default. +} diff --git a/vendor/google.golang.org/grpc/metadata/metadata.go b/vendor/google.golang.org/grpc/metadata/metadata.go new file mode 100644 index 00000000000..bd2eaf40837 --- /dev/null +++ b/vendor/google.golang.org/grpc/metadata/metadata.go @@ -0,0 +1,210 @@ +/* + * + * Copyright 2014 gRPC 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 metadata define the structure of the metadata supported by gRPC library. +// Please refer to https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md +// for more information about custom-metadata. +package metadata // import "google.golang.org/grpc/metadata" + +import ( + "fmt" + "strings" + + "golang.org/x/net/context" +) + +// DecodeKeyValue returns k, v, nil. +// +// Deprecated: use k and v directly instead. +func DecodeKeyValue(k, v string) (string, string, error) { + return k, v, nil +} + +// MD is a mapping from metadata keys to values. Users should use the following +// two convenience functions New and Pairs to generate MD. +type MD map[string][]string + +// New creates an MD from a given key-value map. +// +// Only the following ASCII characters are allowed in keys: +// - digits: 0-9 +// - uppercase letters: A-Z (normalized to lower) +// - lowercase letters: a-z +// - special characters: -_. +// Uppercase letters are automatically converted to lowercase. +// +// Keys beginning with "grpc-" are reserved for grpc-internal use only and may +// result in errors if set in metadata. +func New(m map[string]string) MD { + md := MD{} + for k, val := range m { + key := strings.ToLower(k) + md[key] = append(md[key], val) + } + return md +} + +// Pairs returns an MD formed by the mapping of key, value ... +// Pairs panics if len(kv) is odd. +// +// Only the following ASCII characters are allowed in keys: +// - digits: 0-9 +// - uppercase letters: A-Z (normalized to lower) +// - lowercase letters: a-z +// - special characters: -_. +// Uppercase letters are automatically converted to lowercase. +// +// Keys beginning with "grpc-" are reserved for grpc-internal use only and may +// result in errors if set in metadata. +func Pairs(kv ...string) MD { + if len(kv)%2 == 1 { + panic(fmt.Sprintf("metadata: Pairs got the odd number of input pairs for metadata: %d", len(kv))) + } + md := MD{} + var key string + for i, s := range kv { + if i%2 == 0 { + key = strings.ToLower(s) + continue + } + md[key] = append(md[key], s) + } + return md +} + +// Len returns the number of items in md. +func (md MD) Len() int { + return len(md) +} + +// Copy returns a copy of md. +func (md MD) Copy() MD { + return Join(md) +} + +// Get obtains the values for a given key. +func (md MD) Get(k string) []string { + k = strings.ToLower(k) + return md[k] +} + +// Set sets the value of a given key with a slice of values. +func (md MD) Set(k string, vals ...string) { + if len(vals) == 0 { + return + } + k = strings.ToLower(k) + md[k] = vals +} + +// Append adds the values to key k, not overwriting what was already stored at that key. +func (md MD) Append(k string, vals ...string) { + if len(vals) == 0 { + return + } + k = strings.ToLower(k) + md[k] = append(md[k], vals...) +} + +// Join joins any number of mds into a single MD. +// The order of values for each key is determined by the order in which +// the mds containing those values are presented to Join. +func Join(mds ...MD) MD { + out := MD{} + for _, md := range mds { + for k, v := range md { + out[k] = append(out[k], v...) + } + } + return out +} + +type mdIncomingKey struct{} +type mdOutgoingKey struct{} + +// NewIncomingContext creates a new context with incoming md attached. +func NewIncomingContext(ctx context.Context, md MD) context.Context { + return context.WithValue(ctx, mdIncomingKey{}, md) +} + +// NewOutgoingContext creates a new context with outgoing md attached. If used +// in conjunction with AppendToOutgoingContext, NewOutgoingContext will +// overwrite any previously-appended metadata. +func NewOutgoingContext(ctx context.Context, md MD) context.Context { + return context.WithValue(ctx, mdOutgoingKey{}, rawMD{md: md}) +} + +// AppendToOutgoingContext returns a new context with the provided kv merged +// with any existing metadata in the context. Please refer to the +// documentation of Pairs for a description of kv. +func AppendToOutgoingContext(ctx context.Context, kv ...string) context.Context { + if len(kv)%2 == 1 { + panic(fmt.Sprintf("metadata: AppendToOutgoingContext got an odd number of input pairs for metadata: %d", len(kv))) + } + md, _ := ctx.Value(mdOutgoingKey{}).(rawMD) + added := make([][]string, len(md.added)+1) + copy(added, md.added) + added[len(added)-1] = make([]string, len(kv)) + copy(added[len(added)-1], kv) + return context.WithValue(ctx, mdOutgoingKey{}, rawMD{md: md.md, added: added}) +} + +// FromIncomingContext returns the incoming metadata in ctx if it exists. The +// returned MD should not be modified. Writing to it may cause races. +// Modification should be made to copies of the returned MD. +func FromIncomingContext(ctx context.Context) (md MD, ok bool) { + md, ok = ctx.Value(mdIncomingKey{}).(MD) + return +} + +// FromOutgoingContextRaw returns the un-merged, intermediary contents +// of rawMD. Remember to perform strings.ToLower on the keys. The returned +// MD should not be modified. Writing to it may cause races. Modification +// should be made to copies of the returned MD. +// +// This is intended for gRPC-internal use ONLY. +func FromOutgoingContextRaw(ctx context.Context) (MD, [][]string, bool) { + raw, ok := ctx.Value(mdOutgoingKey{}).(rawMD) + if !ok { + return nil, nil, false + } + + return raw.md, raw.added, true +} + +// FromOutgoingContext returns the outgoing metadata in ctx if it exists. The +// returned MD should not be modified. Writing to it may cause races. +// Modification should be made to copies of the returned MD. +func FromOutgoingContext(ctx context.Context) (MD, bool) { + raw, ok := ctx.Value(mdOutgoingKey{}).(rawMD) + if !ok { + return nil, false + } + + mds := make([]MD, 0, len(raw.added)+1) + mds = append(mds, raw.md) + for _, vv := range raw.added { + mds = append(mds, Pairs(vv...)) + } + return Join(mds...), ok +} + +type rawMD struct { + md MD + added [][]string +} diff --git a/vendor/google.golang.org/grpc/naming/dns_resolver.go b/vendor/google.golang.org/grpc/naming/dns_resolver.go new file mode 100644 index 00000000000..0f8a908ea9c --- /dev/null +++ b/vendor/google.golang.org/grpc/naming/dns_resolver.go @@ -0,0 +1,290 @@ +/* + * + * Copyright 2017 gRPC 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 naming + +import ( + "errors" + "fmt" + "net" + "strconv" + "time" + + "golang.org/x/net/context" + "google.golang.org/grpc/grpclog" +) + +const ( + defaultPort = "443" + defaultFreq = time.Minute * 30 +) + +var ( + errMissingAddr = errors.New("missing address") + errWatcherClose = errors.New("watcher has been closed") +) + +// NewDNSResolverWithFreq creates a DNS Resolver that can resolve DNS names, and +// create watchers that poll the DNS server using the frequency set by freq. +func NewDNSResolverWithFreq(freq time.Duration) (Resolver, error) { + return &dnsResolver{freq: freq}, nil +} + +// NewDNSResolver creates a DNS Resolver that can resolve DNS names, and create +// watchers that poll the DNS server using the default frequency defined by defaultFreq. +func NewDNSResolver() (Resolver, error) { + return NewDNSResolverWithFreq(defaultFreq) +} + +// dnsResolver handles name resolution for names following the DNS scheme +type dnsResolver struct { + // frequency of polling the DNS server that the watchers created by this resolver will use. + freq time.Duration +} + +// formatIP returns ok = false if addr is not a valid textual representation of an IP address. +// If addr is an IPv4 address, return the addr and ok = true. +// If addr is an IPv6 address, return the addr enclosed in square brackets and ok = true. +func formatIP(addr string) (addrIP string, ok bool) { + ip := net.ParseIP(addr) + if ip == nil { + return "", false + } + if ip.To4() != nil { + return addr, true + } + return "[" + addr + "]", true +} + +// parseTarget takes the user input target string, returns formatted host and port info. +// If target doesn't specify a port, set the port to be the defaultPort. +// If target is in IPv6 format and host-name is enclosed in sqarue brackets, brackets +// are strippd when setting the host. +// examples: +// target: "www.google.com" returns host: "www.google.com", port: "443" +// target: "ipv4-host:80" returns host: "ipv4-host", port: "80" +// target: "[ipv6-host]" returns host: "ipv6-host", port: "443" +// target: ":80" returns host: "localhost", port: "80" +// target: ":" returns host: "localhost", port: "443" +func parseTarget(target string) (host, port string, err error) { + if target == "" { + return "", "", errMissingAddr + } + + if ip := net.ParseIP(target); ip != nil { + // target is an IPv4 or IPv6(without brackets) address + return target, defaultPort, nil + } + if host, port, err := net.SplitHostPort(target); err == nil { + // target has port, i.e ipv4-host:port, [ipv6-host]:port, host-name:port + if host == "" { + // Keep consistent with net.Dial(): If the host is empty, as in ":80", the local system is assumed. + host = "localhost" + } + if port == "" { + // If the port field is empty(target ends with colon), e.g. "[::1]:", defaultPort is used. + port = defaultPort + } + return host, port, nil + } + if host, port, err := net.SplitHostPort(target + ":" + defaultPort); err == nil { + // target doesn't have port + return host, port, nil + } + return "", "", fmt.Errorf("invalid target address %v", target) +} + +// Resolve creates a watcher that watches the name resolution of the target. +func (r *dnsResolver) Resolve(target string) (Watcher, error) { + host, port, err := parseTarget(target) + if err != nil { + return nil, err + } + + if net.ParseIP(host) != nil { + ipWatcher := &ipWatcher{ + updateChan: make(chan *Update, 1), + } + host, _ = formatIP(host) + ipWatcher.updateChan <- &Update{Op: Add, Addr: host + ":" + port} + return ipWatcher, nil + } + + ctx, cancel := context.WithCancel(context.Background()) + return &dnsWatcher{ + r: r, + host: host, + port: port, + ctx: ctx, + cancel: cancel, + t: time.NewTimer(0), + }, nil +} + +// dnsWatcher watches for the name resolution update for a specific target +type dnsWatcher struct { + r *dnsResolver + host string + port string + // The latest resolved address set + curAddrs map[string]*Update + ctx context.Context + cancel context.CancelFunc + t *time.Timer +} + +// ipWatcher watches for the name resolution update for an IP address. +type ipWatcher struct { + updateChan chan *Update +} + +// Next returns the address resolution Update for the target. For IP address, +// the resolution is itself, thus polling name server is unnecessary. Therefore, +// Next() will return an Update the first time it is called, and will be blocked +// for all following calls as no Update exists until watcher is closed. +func (i *ipWatcher) Next() ([]*Update, error) { + u, ok := <-i.updateChan + if !ok { + return nil, errWatcherClose + } + return []*Update{u}, nil +} + +// Close closes the ipWatcher. +func (i *ipWatcher) Close() { + close(i.updateChan) +} + +// AddressType indicates the address type returned by name resolution. +type AddressType uint8 + +const ( + // Backend indicates the server is a backend server. + Backend AddressType = iota + // GRPCLB indicates the server is a grpclb load balancer. + GRPCLB +) + +// AddrMetadataGRPCLB contains the information the name resolver for grpclb should provide. The +// name resolver used by the grpclb balancer is required to provide this type of metadata in +// its address updates. +type AddrMetadataGRPCLB struct { + // AddrType is the type of server (grpc load balancer or backend). + AddrType AddressType + // ServerName is the name of the grpc load balancer. Used for authentication. + ServerName string +} + +// compileUpdate compares the old resolved addresses and newly resolved addresses, +// and generates an update list +func (w *dnsWatcher) compileUpdate(newAddrs map[string]*Update) []*Update { + var res []*Update + for a, u := range w.curAddrs { + if _, ok := newAddrs[a]; !ok { + u.Op = Delete + res = append(res, u) + } + } + for a, u := range newAddrs { + if _, ok := w.curAddrs[a]; !ok { + res = append(res, u) + } + } + return res +} + +func (w *dnsWatcher) lookupSRV() map[string]*Update { + newAddrs := make(map[string]*Update) + _, srvs, err := lookupSRV(w.ctx, "grpclb", "tcp", w.host) + if err != nil { + grpclog.Infof("grpc: failed dns SRV record lookup due to %v.\n", err) + return nil + } + for _, s := range srvs { + lbAddrs, err := lookupHost(w.ctx, s.Target) + if err != nil { + grpclog.Warningf("grpc: failed load banlacer address dns lookup due to %v.\n", err) + continue + } + for _, a := range lbAddrs { + a, ok := formatIP(a) + if !ok { + grpclog.Errorf("grpc: failed IP parsing due to %v.\n", err) + continue + } + addr := a + ":" + strconv.Itoa(int(s.Port)) + newAddrs[addr] = &Update{Addr: addr, + Metadata: AddrMetadataGRPCLB{AddrType: GRPCLB, ServerName: s.Target}} + } + } + return newAddrs +} + +func (w *dnsWatcher) lookupHost() map[string]*Update { + newAddrs := make(map[string]*Update) + addrs, err := lookupHost(w.ctx, w.host) + if err != nil { + grpclog.Warningf("grpc: failed dns A record lookup due to %v.\n", err) + return nil + } + for _, a := range addrs { + a, ok := formatIP(a) + if !ok { + grpclog.Errorf("grpc: failed IP parsing due to %v.\n", err) + continue + } + addr := a + ":" + w.port + newAddrs[addr] = &Update{Addr: addr} + } + return newAddrs +} + +func (w *dnsWatcher) lookup() []*Update { + newAddrs := w.lookupSRV() + if newAddrs == nil { + // If failed to get any balancer address (either no corresponding SRV for the + // target, or caused by failure during resolution/parsing of the balancer target), + // return any A record info available. + newAddrs = w.lookupHost() + } + result := w.compileUpdate(newAddrs) + w.curAddrs = newAddrs + return result +} + +// Next returns the resolved address update(delta) for the target. If there's no +// change, it will sleep for 30 mins and try to resolve again after that. +func (w *dnsWatcher) Next() ([]*Update, error) { + for { + select { + case <-w.ctx.Done(): + return nil, errWatcherClose + case <-w.t.C: + } + result := w.lookup() + // Next lookup should happen after an interval defined by w.r.freq. + w.t.Reset(w.r.freq) + if len(result) > 0 { + return result, nil + } + } +} + +func (w *dnsWatcher) Close() { + w.cancel() +} diff --git a/vendor/google.golang.org/grpc/naming/go17.go b/vendor/google.golang.org/grpc/naming/go17.go new file mode 100644 index 00000000000..57b65d7b889 --- /dev/null +++ b/vendor/google.golang.org/grpc/naming/go17.go @@ -0,0 +1,34 @@ +// +build go1.6,!go1.8 + +/* + * + * Copyright 2017 gRPC 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 naming + +import ( + "net" + + "golang.org/x/net/context" +) + +var ( + lookupHost = func(ctx context.Context, host string) ([]string, error) { return net.LookupHost(host) } + lookupSRV = func(ctx context.Context, service, proto, name string) (string, []*net.SRV, error) { + return net.LookupSRV(service, proto, name) + } +) diff --git a/vendor/google.golang.org/grpc/naming/go18.go b/vendor/google.golang.org/grpc/naming/go18.go new file mode 100644 index 00000000000..b5a0f842748 --- /dev/null +++ b/vendor/google.golang.org/grpc/naming/go18.go @@ -0,0 +1,28 @@ +// +build go1.8 + +/* + * + * Copyright 2017 gRPC 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 naming + +import "net" + +var ( + lookupHost = net.DefaultResolver.LookupHost + lookupSRV = net.DefaultResolver.LookupSRV +) diff --git a/vendor/google.golang.org/grpc/naming/naming.go b/vendor/google.golang.org/grpc/naming/naming.go new file mode 100644 index 00000000000..8cc39e93758 --- /dev/null +++ b/vendor/google.golang.org/grpc/naming/naming.go @@ -0,0 +1,69 @@ +/* + * + * Copyright 2014 gRPC 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 naming defines the naming API and related data structures for gRPC. +// The interface is EXPERIMENTAL and may be suject to change. +// +// Deprecated: please use package resolver. +package naming + +// Operation defines the corresponding operations for a name resolution change. +// +// Deprecated: please use package resolver. +type Operation uint8 + +const ( + // Add indicates a new address is added. + Add Operation = iota + // Delete indicates an existing address is deleted. + Delete +) + +// Update defines a name resolution update. Notice that it is not valid having both +// empty string Addr and nil Metadata in an Update. +// +// Deprecated: please use package resolver. +type Update struct { + // Op indicates the operation of the update. + Op Operation + // Addr is the updated address. It is empty string if there is no address update. + Addr string + // Metadata is the updated metadata. It is nil if there is no metadata update. + // Metadata is not required for a custom naming implementation. + Metadata interface{} +} + +// Resolver creates a Watcher for a target to track its resolution changes. +// +// Deprecated: please use package resolver. +type Resolver interface { + // Resolve creates a Watcher for target. + Resolve(target string) (Watcher, error) +} + +// Watcher watches for the updates on the specified target. +// +// Deprecated: please use package resolver. +type Watcher interface { + // Next blocks until an update or error happens. It may return one or more + // updates. The first call should get the full set of the results. It should + // return an error if and only if Watcher cannot recover. + Next() ([]*Update, error) + // Close closes the Watcher. + Close() +} diff --git a/vendor/google.golang.org/grpc/peer/peer.go b/vendor/google.golang.org/grpc/peer/peer.go new file mode 100644 index 00000000000..317b8b9d09a --- /dev/null +++ b/vendor/google.golang.org/grpc/peer/peer.go @@ -0,0 +1,51 @@ +/* + * + * Copyright 2014 gRPC 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 peer defines various peer information associated with RPCs and +// corresponding utils. +package peer + +import ( + "net" + + "golang.org/x/net/context" + "google.golang.org/grpc/credentials" +) + +// Peer contains the information of the peer for an RPC, such as the address +// and authentication information. +type Peer struct { + // Addr is the peer address. + Addr net.Addr + // AuthInfo is the authentication information of the transport. + // It is nil if there is no transport security being used. + AuthInfo credentials.AuthInfo +} + +type peerKey struct{} + +// NewContext creates a new context with peer information attached. +func NewContext(ctx context.Context, p *Peer) context.Context { + return context.WithValue(ctx, peerKey{}, p) +} + +// FromContext returns the peer information in ctx if it exists. +func FromContext(ctx context.Context) (p *Peer, ok bool) { + p, ok = ctx.Value(peerKey{}).(*Peer) + return +} diff --git a/vendor/google.golang.org/grpc/picker_wrapper.go b/vendor/google.golang.org/grpc/picker_wrapper.go new file mode 100644 index 00000000000..0a984e6c8af --- /dev/null +++ b/vendor/google.golang.org/grpc/picker_wrapper.go @@ -0,0 +1,331 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "io" + "sync" + "sync/atomic" + + "golang.org/x/net/context" + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/channelz" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/metadata" + "google.golang.org/grpc/resolver" + "google.golang.org/grpc/status" + "google.golang.org/grpc/transport" +) + +// pickerWrapper is a wrapper of balancer.Picker. It blocks on certain pick +// actions and unblock when there's a picker update. +type pickerWrapper struct { + mu sync.Mutex + done bool + blockingCh chan struct{} + picker balancer.Picker + + // The latest connection happened. + connErrMu sync.Mutex + connErr error + + stickinessMDKey atomic.Value + stickiness *stickyStore +} + +func newPickerWrapper() *pickerWrapper { + bp := &pickerWrapper{ + blockingCh: make(chan struct{}), + stickiness: newStickyStore(), + } + return bp +} + +func (bp *pickerWrapper) updateConnectionError(err error) { + bp.connErrMu.Lock() + bp.connErr = err + bp.connErrMu.Unlock() +} + +func (bp *pickerWrapper) connectionError() error { + bp.connErrMu.Lock() + err := bp.connErr + bp.connErrMu.Unlock() + return err +} + +func (bp *pickerWrapper) updateStickinessMDKey(newKey string) { + // No need to check ok because mdKey == "" if ok == false. + if oldKey, _ := bp.stickinessMDKey.Load().(string); oldKey != newKey { + bp.stickinessMDKey.Store(newKey) + bp.stickiness.reset(newKey) + } +} + +func (bp *pickerWrapper) getStickinessMDKey() string { + // No need to check ok because mdKey == "" if ok == false. + mdKey, _ := bp.stickinessMDKey.Load().(string) + return mdKey +} + +func (bp *pickerWrapper) clearStickinessState() { + if oldKey := bp.getStickinessMDKey(); oldKey != "" { + // There's no need to reset store if mdKey was "". + bp.stickiness.reset(oldKey) + } +} + +// updatePicker is called by UpdateBalancerState. It unblocks all blocked pick. +func (bp *pickerWrapper) updatePicker(p balancer.Picker) { + bp.mu.Lock() + if bp.done { + bp.mu.Unlock() + return + } + bp.picker = p + // bp.blockingCh should never be nil. + close(bp.blockingCh) + bp.blockingCh = make(chan struct{}) + bp.mu.Unlock() +} + +func doneChannelzWrapper(acw *acBalancerWrapper, done func(balancer.DoneInfo)) func(balancer.DoneInfo) { + acw.mu.Lock() + ac := acw.ac + acw.mu.Unlock() + ac.incrCallsStarted() + return func(b balancer.DoneInfo) { + if b.Err != nil && b.Err != io.EOF { + ac.incrCallsFailed() + } else { + ac.incrCallsSucceeded() + } + if done != nil { + done(b) + } + } +} + +// pick returns the transport that will be used for the RPC. +// It may block in the following cases: +// - there's no picker +// - the current picker returns ErrNoSubConnAvailable +// - the current picker returns other errors and failfast is false. +// - the subConn returned by the current picker is not READY +// When one of these situations happens, pick blocks until the picker gets updated. +func (bp *pickerWrapper) pick(ctx context.Context, failfast bool, opts balancer.PickOptions) (transport.ClientTransport, func(balancer.DoneInfo), error) { + + mdKey := bp.getStickinessMDKey() + stickyKey, isSticky := stickyKeyFromContext(ctx, mdKey) + + // Potential race here: if stickinessMDKey is updated after the above two + // lines, and this pick is a sticky pick, the following put could add an + // entry to sticky store with an outdated sticky key. + // + // The solution: keep the current md key in sticky store, and at the + // beginning of each get/put, check the mdkey against store.curMDKey. + // - Cons: one more string comparing for each get/put. + // - Pros: the string matching happens inside get/put, so the overhead for + // non-sticky RPCs will be minimal. + + if isSticky { + if t, ok := bp.stickiness.get(mdKey, stickyKey); ok { + // Done function returned is always nil. + return t, nil, nil + } + } + + var ( + p balancer.Picker + ch chan struct{} + ) + + for { + bp.mu.Lock() + if bp.done { + bp.mu.Unlock() + return nil, nil, ErrClientConnClosing + } + + if bp.picker == nil { + ch = bp.blockingCh + } + if ch == bp.blockingCh { + // This could happen when either: + // - bp.picker is nil (the previous if condition), or + // - has called pick on the current picker. + bp.mu.Unlock() + select { + case <-ctx.Done(): + return nil, nil, ctx.Err() + case <-ch: + } + continue + } + + ch = bp.blockingCh + p = bp.picker + bp.mu.Unlock() + + subConn, done, err := p.Pick(ctx, opts) + + if err != nil { + switch err { + case balancer.ErrNoSubConnAvailable: + continue + case balancer.ErrTransientFailure: + if !failfast { + continue + } + return nil, nil, status.Errorf(codes.Unavailable, "%v, latest connection error: %v", err, bp.connectionError()) + default: + // err is some other error. + return nil, nil, toRPCErr(err) + } + } + + acw, ok := subConn.(*acBalancerWrapper) + if !ok { + grpclog.Infof("subconn returned from pick is not *acBalancerWrapper") + continue + } + if t, ok := acw.getAddrConn().getReadyTransport(); ok { + if isSticky { + bp.stickiness.put(mdKey, stickyKey, acw) + } + if channelz.IsOn() { + return t, doneChannelzWrapper(acw, done), nil + } + return t, done, nil + } + grpclog.Infof("blockingPicker: the picked transport is not ready, loop back to repick") + // If ok == false, ac.state is not READY. + // A valid picker always returns READY subConn. This means the state of ac + // just changed, and picker will be updated shortly. + // continue back to the beginning of the for loop to repick. + } +} + +func (bp *pickerWrapper) close() { + bp.mu.Lock() + defer bp.mu.Unlock() + if bp.done { + return + } + bp.done = true + close(bp.blockingCh) +} + +type stickyStoreEntry struct { + acw *acBalancerWrapper + addr resolver.Address +} + +type stickyStore struct { + mu sync.Mutex + // curMDKey is check before every get/put to avoid races. The operation will + // abort immediately when the given mdKey is different from the curMDKey. + curMDKey string + store map[string]*stickyStoreEntry +} + +func newStickyStore() *stickyStore { + return &stickyStore{ + store: make(map[string]*stickyStoreEntry), + } +} + +// reset clears the map in stickyStore, and set the currentMDKey to newMDKey. +func (ss *stickyStore) reset(newMDKey string) { + ss.mu.Lock() + ss.curMDKey = newMDKey + ss.store = make(map[string]*stickyStoreEntry) + ss.mu.Unlock() +} + +// stickyKey is the key to look up in store. mdKey will be checked against +// curMDKey to avoid races. +func (ss *stickyStore) put(mdKey, stickyKey string, acw *acBalancerWrapper) { + ss.mu.Lock() + defer ss.mu.Unlock() + if mdKey != ss.curMDKey { + return + } + // TODO(stickiness): limit the total number of entries. + ss.store[stickyKey] = &stickyStoreEntry{ + acw: acw, + addr: acw.getAddrConn().getCurAddr(), + } +} + +// stickyKey is the key to look up in store. mdKey will be checked against +// curMDKey to avoid races. +func (ss *stickyStore) get(mdKey, stickyKey string) (transport.ClientTransport, bool) { + ss.mu.Lock() + defer ss.mu.Unlock() + if mdKey != ss.curMDKey { + return nil, false + } + entry, ok := ss.store[stickyKey] + if !ok { + return nil, false + } + ac := entry.acw.getAddrConn() + if ac.getCurAddr() != entry.addr { + delete(ss.store, stickyKey) + return nil, false + } + t, ok := ac.getReadyTransport() + if !ok { + delete(ss.store, stickyKey) + return nil, false + } + return t, true +} + +// Get one value from metadata in ctx with key stickinessMDKey. +// +// It returns "", false if stickinessMDKey is an empty string. +func stickyKeyFromContext(ctx context.Context, stickinessMDKey string) (string, bool) { + if stickinessMDKey == "" { + return "", false + } + + md, added, ok := metadata.FromOutgoingContextRaw(ctx) + if !ok { + return "", false + } + + if vv, ok := md[stickinessMDKey]; ok { + if len(vv) > 0 { + return vv[0], true + } + } + + for _, ss := range added { + for i := 0; i < len(ss)-1; i += 2 { + if ss[i] == stickinessMDKey { + return ss[i+1], true + } + } + } + + return "", false +} diff --git a/vendor/google.golang.org/grpc/pickfirst.go b/vendor/google.golang.org/grpc/pickfirst.go new file mode 100644 index 00000000000..bf659d49d2f --- /dev/null +++ b/vendor/google.golang.org/grpc/pickfirst.go @@ -0,0 +1,108 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "golang.org/x/net/context" + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/connectivity" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/resolver" +) + +// PickFirstBalancerName is the name of the pick_first balancer. +const PickFirstBalancerName = "pick_first" + +func newPickfirstBuilder() balancer.Builder { + return &pickfirstBuilder{} +} + +type pickfirstBuilder struct{} + +func (*pickfirstBuilder) Build(cc balancer.ClientConn, opt balancer.BuildOptions) balancer.Balancer { + return &pickfirstBalancer{cc: cc} +} + +func (*pickfirstBuilder) Name() string { + return PickFirstBalancerName +} + +type pickfirstBalancer struct { + cc balancer.ClientConn + sc balancer.SubConn +} + +func (b *pickfirstBalancer) HandleResolvedAddrs(addrs []resolver.Address, err error) { + if err != nil { + grpclog.Infof("pickfirstBalancer: HandleResolvedAddrs called with error %v", err) + return + } + if b.sc == nil { + b.sc, err = b.cc.NewSubConn(addrs, balancer.NewSubConnOptions{}) + if err != nil { + grpclog.Errorf("pickfirstBalancer: failed to NewSubConn: %v", err) + return + } + b.cc.UpdateBalancerState(connectivity.Idle, &picker{sc: b.sc}) + b.sc.Connect() + } else { + b.sc.UpdateAddresses(addrs) + b.sc.Connect() + } +} + +func (b *pickfirstBalancer) HandleSubConnStateChange(sc balancer.SubConn, s connectivity.State) { + grpclog.Infof("pickfirstBalancer: HandleSubConnStateChange: %p, %v", sc, s) + if b.sc != sc { + grpclog.Infof("pickfirstBalancer: ignored state change because sc is not recognized") + return + } + if s == connectivity.Shutdown { + b.sc = nil + return + } + + switch s { + case connectivity.Ready, connectivity.Idle: + b.cc.UpdateBalancerState(s, &picker{sc: sc}) + case connectivity.Connecting: + b.cc.UpdateBalancerState(s, &picker{err: balancer.ErrNoSubConnAvailable}) + case connectivity.TransientFailure: + b.cc.UpdateBalancerState(s, &picker{err: balancer.ErrTransientFailure}) + } +} + +func (b *pickfirstBalancer) Close() { +} + +type picker struct { + err error + sc balancer.SubConn +} + +func (p *picker) Pick(ctx context.Context, opts balancer.PickOptions) (balancer.SubConn, func(balancer.DoneInfo), error) { + if p.err != nil { + return nil, nil, p.err + } + return p.sc, nil, nil +} + +func init() { + balancer.Register(newPickfirstBuilder()) +} diff --git a/vendor/google.golang.org/grpc/proxy.go b/vendor/google.golang.org/grpc/proxy.go new file mode 100644 index 00000000000..2d40236e218 --- /dev/null +++ b/vendor/google.golang.org/grpc/proxy.go @@ -0,0 +1,130 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "bufio" + "errors" + "fmt" + "io" + "net" + "net/http" + "net/http/httputil" + "net/url" + + "golang.org/x/net/context" +) + +var ( + // errDisabled indicates that proxy is disabled for the address. + errDisabled = errors.New("proxy is disabled for the address") + // The following variable will be overwritten in the tests. + httpProxyFromEnvironment = http.ProxyFromEnvironment +) + +func mapAddress(ctx context.Context, address string) (string, error) { + req := &http.Request{ + URL: &url.URL{ + Scheme: "https", + Host: address, + }, + } + url, err := httpProxyFromEnvironment(req) + if err != nil { + return "", err + } + if url == nil { + return "", errDisabled + } + return url.Host, nil +} + +// To read a response from a net.Conn, http.ReadResponse() takes a bufio.Reader. +// It's possible that this reader reads more than what's need for the response and stores +// those bytes in the buffer. +// bufConn wraps the original net.Conn and the bufio.Reader to make sure we don't lose the +// bytes in the buffer. +type bufConn struct { + net.Conn + r io.Reader +} + +func (c *bufConn) Read(b []byte) (int, error) { + return c.r.Read(b) +} + +func doHTTPConnectHandshake(ctx context.Context, conn net.Conn, addr string) (_ net.Conn, err error) { + defer func() { + if err != nil { + conn.Close() + } + }() + + req := (&http.Request{ + Method: http.MethodConnect, + URL: &url.URL{Host: addr}, + Header: map[string][]string{"User-Agent": {grpcUA}}, + }) + + if err := sendHTTPRequest(ctx, req, conn); err != nil { + return nil, fmt.Errorf("failed to write the HTTP request: %v", err) + } + + r := bufio.NewReader(conn) + resp, err := http.ReadResponse(r, req) + if err != nil { + return nil, fmt.Errorf("reading server HTTP response: %v", err) + } + defer resp.Body.Close() + if resp.StatusCode != http.StatusOK { + dump, err := httputil.DumpResponse(resp, true) + if err != nil { + return nil, fmt.Errorf("failed to do connect handshake, status code: %s", resp.Status) + } + return nil, fmt.Errorf("failed to do connect handshake, response: %q", dump) + } + + return &bufConn{Conn: conn, r: r}, nil +} + +// newProxyDialer returns a dialer that connects to proxy first if necessary. +// The returned dialer checks if a proxy is necessary, dial to the proxy with the +// provided dialer, does HTTP CONNECT handshake and returns the connection. +func newProxyDialer(dialer func(context.Context, string) (net.Conn, error)) func(context.Context, string) (net.Conn, error) { + return func(ctx context.Context, addr string) (conn net.Conn, err error) { + var skipHandshake bool + newAddr, err := mapAddress(ctx, addr) + if err != nil { + if err != errDisabled { + return nil, err + } + skipHandshake = true + newAddr = addr + } + + conn, err = dialer(ctx, newAddr) + if err != nil { + return + } + if !skipHandshake { + conn, err = doHTTPConnectHandshake(ctx, conn, addr) + } + return + } +} diff --git a/vendor/google.golang.org/grpc/resolver/dns/dns_resolver.go b/vendor/google.golang.org/grpc/resolver/dns/dns_resolver.go new file mode 100644 index 00000000000..c1cabfc995f --- /dev/null +++ b/vendor/google.golang.org/grpc/resolver/dns/dns_resolver.go @@ -0,0 +1,379 @@ +/* + * + * Copyright 2017 gRPC 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 dns implements a dns resolver to be installed as the default resolver +// in grpc. +package dns + +import ( + "encoding/json" + "errors" + "fmt" + "math/rand" + "net" + "os" + "strconv" + "strings" + "sync" + "time" + + "golang.org/x/net/context" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/resolver" +) + +func init() { + resolver.Register(NewBuilder()) +} + +const ( + defaultPort = "443" + defaultFreq = time.Minute * 30 + golang = "GO" + // In DNS, service config is encoded in a TXT record via the mechanism + // described in RFC-1464 using the attribute name grpc_config. + txtAttribute = "grpc_config=" +) + +var ( + errMissingAddr = errors.New("missing address") + randomGen = rand.New(rand.NewSource(time.Now().UnixNano())) +) + +// NewBuilder creates a dnsBuilder which is used to factory DNS resolvers. +func NewBuilder() resolver.Builder { + return &dnsBuilder{freq: defaultFreq} +} + +type dnsBuilder struct { + // frequency of polling the DNS server. + freq time.Duration +} + +// Build creates and starts a DNS resolver that watches the name resolution of the target. +func (b *dnsBuilder) Build(target resolver.Target, cc resolver.ClientConn, opts resolver.BuildOption) (resolver.Resolver, error) { + host, port, err := parseTarget(target.Endpoint) + if err != nil { + return nil, err + } + + // IP address. + if net.ParseIP(host) != nil { + host, _ = formatIP(host) + addr := []resolver.Address{{Addr: host + ":" + port}} + i := &ipResolver{ + cc: cc, + ip: addr, + rn: make(chan struct{}, 1), + q: make(chan struct{}), + } + cc.NewAddress(addr) + go i.watcher() + return i, nil + } + + // DNS address (non-IP). + ctx, cancel := context.WithCancel(context.Background()) + d := &dnsResolver{ + freq: b.freq, + host: host, + port: port, + ctx: ctx, + cancel: cancel, + cc: cc, + t: time.NewTimer(0), + rn: make(chan struct{}, 1), + disableServiceConfig: opts.DisableServiceConfig, + } + + d.wg.Add(1) + go d.watcher() + return d, nil +} + +// Scheme returns the naming scheme of this resolver builder, which is "dns". +func (b *dnsBuilder) Scheme() string { + return "dns" +} + +// ipResolver watches for the name resolution update for an IP address. +type ipResolver struct { + cc resolver.ClientConn + ip []resolver.Address + // rn channel is used by ResolveNow() to force an immediate resolution of the target. + rn chan struct{} + q chan struct{} +} + +// ResolveNow resend the address it stores, no resolution is needed. +func (i *ipResolver) ResolveNow(opt resolver.ResolveNowOption) { + select { + case i.rn <- struct{}{}: + default: + } +} + +// Close closes the ipResolver. +func (i *ipResolver) Close() { + close(i.q) +} + +func (i *ipResolver) watcher() { + for { + select { + case <-i.rn: + i.cc.NewAddress(i.ip) + case <-i.q: + return + } + } +} + +// dnsResolver watches for the name resolution update for a non-IP target. +type dnsResolver struct { + freq time.Duration + host string + port string + ctx context.Context + cancel context.CancelFunc + cc resolver.ClientConn + // rn channel is used by ResolveNow() to force an immediate resolution of the target. + rn chan struct{} + t *time.Timer + // wg is used to enforce Close() to return after the watcher() goroutine has finished. + // Otherwise, data race will be possible. [Race Example] in dns_resolver_test we + // replace the real lookup functions with mocked ones to facilitate testing. + // If Close() doesn't wait for watcher() goroutine finishes, race detector sometimes + // will warns lookup (READ the lookup function pointers) inside watcher() goroutine + // has data race with replaceNetFunc (WRITE the lookup function pointers). + wg sync.WaitGroup + disableServiceConfig bool +} + +// ResolveNow invoke an immediate resolution of the target that this dnsResolver watches. +func (d *dnsResolver) ResolveNow(opt resolver.ResolveNowOption) { + select { + case d.rn <- struct{}{}: + default: + } +} + +// Close closes the dnsResolver. +func (d *dnsResolver) Close() { + d.cancel() + d.wg.Wait() + d.t.Stop() +} + +func (d *dnsResolver) watcher() { + defer d.wg.Done() + for { + select { + case <-d.ctx.Done(): + return + case <-d.t.C: + case <-d.rn: + } + result, sc := d.lookup() + // Next lookup should happen after an interval defined by d.freq. + d.t.Reset(d.freq) + d.cc.NewServiceConfig(sc) + d.cc.NewAddress(result) + } +} + +func (d *dnsResolver) lookupSRV() []resolver.Address { + var newAddrs []resolver.Address + _, srvs, err := lookupSRV(d.ctx, "grpclb", "tcp", d.host) + if err != nil { + grpclog.Infof("grpc: failed dns SRV record lookup due to %v.\n", err) + return nil + } + for _, s := range srvs { + lbAddrs, err := lookupHost(d.ctx, s.Target) + if err != nil { + grpclog.Infof("grpc: failed load balancer address dns lookup due to %v.\n", err) + continue + } + for _, a := range lbAddrs { + a, ok := formatIP(a) + if !ok { + grpclog.Errorf("grpc: failed IP parsing due to %v.\n", err) + continue + } + addr := a + ":" + strconv.Itoa(int(s.Port)) + newAddrs = append(newAddrs, resolver.Address{Addr: addr, Type: resolver.GRPCLB, ServerName: s.Target}) + } + } + return newAddrs +} + +func (d *dnsResolver) lookupTXT() string { + ss, err := lookupTXT(d.ctx, d.host) + if err != nil { + grpclog.Infof("grpc: failed dns TXT record lookup due to %v.\n", err) + return "" + } + var res string + for _, s := range ss { + res += s + } + + // TXT record must have "grpc_config=" attribute in order to be used as service config. + if !strings.HasPrefix(res, txtAttribute) { + grpclog.Warningf("grpc: TXT record %v missing %v attribute", res, txtAttribute) + return "" + } + return strings.TrimPrefix(res, txtAttribute) +} + +func (d *dnsResolver) lookupHost() []resolver.Address { + var newAddrs []resolver.Address + addrs, err := lookupHost(d.ctx, d.host) + if err != nil { + grpclog.Warningf("grpc: failed dns A record lookup due to %v.\n", err) + return nil + } + for _, a := range addrs { + a, ok := formatIP(a) + if !ok { + grpclog.Errorf("grpc: failed IP parsing due to %v.\n", err) + continue + } + addr := a + ":" + d.port + newAddrs = append(newAddrs, resolver.Address{Addr: addr}) + } + return newAddrs +} + +func (d *dnsResolver) lookup() ([]resolver.Address, string) { + newAddrs := d.lookupSRV() + // Support fallback to non-balancer address. + newAddrs = append(newAddrs, d.lookupHost()...) + if d.disableServiceConfig { + return newAddrs, "" + } + sc := d.lookupTXT() + return newAddrs, canaryingSC(sc) +} + +// formatIP returns ok = false if addr is not a valid textual representation of an IP address. +// If addr is an IPv4 address, return the addr and ok = true. +// If addr is an IPv6 address, return the addr enclosed in square brackets and ok = true. +func formatIP(addr string) (addrIP string, ok bool) { + ip := net.ParseIP(addr) + if ip == nil { + return "", false + } + if ip.To4() != nil { + return addr, true + } + return "[" + addr + "]", true +} + +// parseTarget takes the user input target string, returns formatted host and port info. +// If target doesn't specify a port, set the port to be the defaultPort. +// If target is in IPv6 format and host-name is enclosed in sqarue brackets, brackets +// are strippd when setting the host. +// examples: +// target: "www.google.com" returns host: "www.google.com", port: "443" +// target: "ipv4-host:80" returns host: "ipv4-host", port: "80" +// target: "[ipv6-host]" returns host: "ipv6-host", port: "443" +// target: ":80" returns host: "localhost", port: "80" +// target: ":" returns host: "localhost", port: "443" +func parseTarget(target string) (host, port string, err error) { + if target == "" { + return "", "", errMissingAddr + } + if ip := net.ParseIP(target); ip != nil { + // target is an IPv4 or IPv6(without brackets) address + return target, defaultPort, nil + } + if host, port, err = net.SplitHostPort(target); err == nil { + // target has port, i.e ipv4-host:port, [ipv6-host]:port, host-name:port + if host == "" { + // Keep consistent with net.Dial(): If the host is empty, as in ":80", the local system is assumed. + host = "localhost" + } + if port == "" { + // If the port field is empty(target ends with colon), e.g. "[::1]:", defaultPort is used. + port = defaultPort + } + return host, port, nil + } + if host, port, err = net.SplitHostPort(target + ":" + defaultPort); err == nil { + // target doesn't have port + return host, port, nil + } + return "", "", fmt.Errorf("invalid target address %v, error info: %v", target, err) +} + +type rawChoice struct { + ClientLanguage *[]string `json:"clientLanguage,omitempty"` + Percentage *int `json:"percentage,omitempty"` + ClientHostName *[]string `json:"clientHostName,omitempty"` + ServiceConfig *json.RawMessage `json:"serviceConfig,omitempty"` +} + +func containsString(a *[]string, b string) bool { + if a == nil { + return true + } + for _, c := range *a { + if c == b { + return true + } + } + return false +} + +func chosenByPercentage(a *int) bool { + if a == nil { + return true + } + return randomGen.Intn(100)+1 <= *a +} + +func canaryingSC(js string) string { + if js == "" { + return "" + } + var rcs []rawChoice + err := json.Unmarshal([]byte(js), &rcs) + if err != nil { + grpclog.Warningf("grpc: failed to parse service config json string due to %v.\n", err) + return "" + } + cliHostname, err := os.Hostname() + if err != nil { + grpclog.Warningf("grpc: failed to get client hostname due to %v.\n", err) + return "" + } + var sc string + for _, c := range rcs { + if !containsString(c.ClientLanguage, golang) || + !chosenByPercentage(c.Percentage) || + !containsString(c.ClientHostName, cliHostname) || + c.ServiceConfig == nil { + continue + } + sc = string(*c.ServiceConfig) + break + } + return sc +} diff --git a/vendor/google.golang.org/grpc/resolver/dns/go17.go b/vendor/google.golang.org/grpc/resolver/dns/go17.go new file mode 100644 index 00000000000..b466bc8f6d4 --- /dev/null +++ b/vendor/google.golang.org/grpc/resolver/dns/go17.go @@ -0,0 +1,35 @@ +// +build go1.6, !go1.8 + +/* + * + * Copyright 2017 gRPC 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 dns + +import ( + "net" + + "golang.org/x/net/context" +) + +var ( + lookupHost = func(ctx context.Context, host string) ([]string, error) { return net.LookupHost(host) } + lookupSRV = func(ctx context.Context, service, proto, name string) (string, []*net.SRV, error) { + return net.LookupSRV(service, proto, name) + } + lookupTXT = func(ctx context.Context, name string) ([]string, error) { return net.LookupTXT(name) } +) diff --git a/vendor/google.golang.org/grpc/resolver/dns/go18.go b/vendor/google.golang.org/grpc/resolver/dns/go18.go new file mode 100644 index 00000000000..fa34f14cad4 --- /dev/null +++ b/vendor/google.golang.org/grpc/resolver/dns/go18.go @@ -0,0 +1,29 @@ +// +build go1.8 + +/* + * + * Copyright 2017 gRPC 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 dns + +import "net" + +var ( + lookupHost = net.DefaultResolver.LookupHost + lookupSRV = net.DefaultResolver.LookupSRV + lookupTXT = net.DefaultResolver.LookupTXT +) diff --git a/vendor/google.golang.org/grpc/resolver/passthrough/passthrough.go b/vendor/google.golang.org/grpc/resolver/passthrough/passthrough.go new file mode 100644 index 00000000000..b76010d74d1 --- /dev/null +++ b/vendor/google.golang.org/grpc/resolver/passthrough/passthrough.go @@ -0,0 +1,57 @@ +/* + * + * Copyright 2017 gRPC 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 passthrough implements a pass-through resolver. It sends the target +// name without scheme back to gRPC as resolved address. +package passthrough + +import "google.golang.org/grpc/resolver" + +const scheme = "passthrough" + +type passthroughBuilder struct{} + +func (*passthroughBuilder) Build(target resolver.Target, cc resolver.ClientConn, opts resolver.BuildOption) (resolver.Resolver, error) { + r := &passthroughResolver{ + target: target, + cc: cc, + } + r.start() + return r, nil +} + +func (*passthroughBuilder) Scheme() string { + return scheme +} + +type passthroughResolver struct { + target resolver.Target + cc resolver.ClientConn +} + +func (r *passthroughResolver) start() { + r.cc.NewAddress([]resolver.Address{{Addr: r.target.Endpoint}}) +} + +func (*passthroughResolver) ResolveNow(o resolver.ResolveNowOption) {} + +func (*passthroughResolver) Close() {} + +func init() { + resolver.Register(&passthroughBuilder{}) +} diff --git a/vendor/google.golang.org/grpc/resolver/resolver.go b/vendor/google.golang.org/grpc/resolver/resolver.go new file mode 100644 index 00000000000..506afac88ae --- /dev/null +++ b/vendor/google.golang.org/grpc/resolver/resolver.go @@ -0,0 +1,154 @@ +/* + * + * Copyright 2017 gRPC 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 resolver defines APIs for name resolution in gRPC. +// All APIs in this package are experimental. +package resolver + +var ( + // m is a map from scheme to resolver builder. + m = make(map[string]Builder) + // defaultScheme is the default scheme to use. + defaultScheme = "passthrough" +) + +// TODO(bar) install dns resolver in init(){}. + +// Register registers the resolver builder to the resolver map. b.Scheme will be +// used as the scheme registered with this builder. +// +// NOTE: this function must only be called during initialization time (i.e. in +// an init() function), and is not thread-safe. If multiple Resolvers are +// registered with the same name, the one registered last will take effect. +func Register(b Builder) { + m[b.Scheme()] = b +} + +// Get returns the resolver builder registered with the given scheme. +// +// If no builder is register with the scheme, nil will be returned. +func Get(scheme string) Builder { + if b, ok := m[scheme]; ok { + return b + } + return nil +} + +// SetDefaultScheme sets the default scheme that will be used. +// The default default scheme is "passthrough". +func SetDefaultScheme(scheme string) { + defaultScheme = scheme +} + +// GetDefaultScheme gets the default scheme that will be used. +func GetDefaultScheme() string { + return defaultScheme +} + +// AddressType indicates the address type returned by name resolution. +type AddressType uint8 + +const ( + // Backend indicates the address is for a backend server. + Backend AddressType = iota + // GRPCLB indicates the address is for a grpclb load balancer. + GRPCLB +) + +// Address represents a server the client connects to. +// This is the EXPERIMENTAL API and may be changed or extended in the future. +type Address struct { + // Addr is the server address on which a connection will be established. + Addr string + // Type is the type of this address. + Type AddressType + // ServerName is the name of this address. + // + // e.g. if Type is GRPCLB, ServerName should be the name of the remote load + // balancer, not the name of the backend. + ServerName string + // Metadata is the information associated with Addr, which may be used + // to make load balancing decision. + Metadata interface{} +} + +// BuildOption includes additional information for the builder to create +// the resolver. +type BuildOption struct { + // DisableServiceConfig indicates whether resolver should fetch service config data. + DisableServiceConfig bool +} + +// ClientConn contains the callbacks for resolver to notify any updates +// to the gRPC ClientConn. +// +// This interface is to be implemented by gRPC. Users should not need a +// brand new implementation of this interface. For the situations like +// testing, the new implementation should embed this interface. This allows +// gRPC to add new methods to this interface. +type ClientConn interface { + // NewAddress is called by resolver to notify ClientConn a new list + // of resolved addresses. + // The address list should be the complete list of resolved addresses. + NewAddress(addresses []Address) + // NewServiceConfig is called by resolver to notify ClientConn a new + // service config. The service config should be provided as a json string. + NewServiceConfig(serviceConfig string) +} + +// Target represents a target for gRPC, as specified in: +// https://github.com/grpc/grpc/blob/master/doc/naming.md. +type Target struct { + Scheme string + Authority string + Endpoint string +} + +// Builder creates a resolver that will be used to watch name resolution updates. +type Builder interface { + // Build creates a new resolver for the given target. + // + // gRPC dial calls Build synchronously, and fails if the returned error is + // not nil. + Build(target Target, cc ClientConn, opts BuildOption) (Resolver, error) + // Scheme returns the scheme supported by this resolver. + // Scheme is defined at https://github.com/grpc/grpc/blob/master/doc/naming.md. + Scheme() string +} + +// ResolveNowOption includes additional information for ResolveNow. +type ResolveNowOption struct{} + +// Resolver watches for the updates on the specified target. +// Updates include address updates and service config updates. +type Resolver interface { + // ResolveNow will be called by gRPC to try to resolve the target name + // again. It's just a hint, resolver can ignore this if it's not necessary. + // + // It could be called multiple times concurrently. + ResolveNow(ResolveNowOption) + // Close closes the resolver. + Close() +} + +// UnregisterForTesting removes the resolver builder with the given scheme from the +// resolver map. +// This function is for testing only. +func UnregisterForTesting(scheme string) { + delete(m, scheme) +} diff --git a/vendor/google.golang.org/grpc/resolver_conn_wrapper.go b/vendor/google.golang.org/grpc/resolver_conn_wrapper.go new file mode 100644 index 00000000000..1b493db2e6c --- /dev/null +++ b/vendor/google.golang.org/grpc/resolver_conn_wrapper.go @@ -0,0 +1,158 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "fmt" + "strings" + + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/resolver" +) + +// ccResolverWrapper is a wrapper on top of cc for resolvers. +// It implements resolver.ClientConnection interface. +type ccResolverWrapper struct { + cc *ClientConn + resolver resolver.Resolver + addrCh chan []resolver.Address + scCh chan string + done chan struct{} +} + +// split2 returns the values from strings.SplitN(s, sep, 2). +// If sep is not found, it returns ("", s, false) instead. +func split2(s, sep string) (string, string, bool) { + spl := strings.SplitN(s, sep, 2) + if len(spl) < 2 { + return "", "", false + } + return spl[0], spl[1], true +} + +// parseTarget splits target into a struct containing scheme, authority and +// endpoint. +// +// If target is not a valid scheme://authority/endpoint, it returns {Endpoint: +// target}. +func parseTarget(target string) (ret resolver.Target) { + var ok bool + ret.Scheme, ret.Endpoint, ok = split2(target, "://") + if !ok { + return resolver.Target{Endpoint: target} + } + ret.Authority, ret.Endpoint, ok = split2(ret.Endpoint, "/") + if !ok { + return resolver.Target{Endpoint: target} + } + return ret +} + +// newCCResolverWrapper parses cc.target for scheme and gets the resolver +// builder for this scheme. It then builds the resolver and starts the +// monitoring goroutine for it. +// +// If withResolverBuilder dial option is set, the specified resolver will be +// used instead. +func newCCResolverWrapper(cc *ClientConn) (*ccResolverWrapper, error) { + rb := cc.dopts.resolverBuilder + if rb == nil { + return nil, fmt.Errorf("could not get resolver for scheme: %q", cc.parsedTarget.Scheme) + } + + ccr := &ccResolverWrapper{ + cc: cc, + addrCh: make(chan []resolver.Address, 1), + scCh: make(chan string, 1), + done: make(chan struct{}), + } + + var err error + ccr.resolver, err = rb.Build(cc.parsedTarget, ccr, resolver.BuildOption{DisableServiceConfig: cc.dopts.disableServiceConfig}) + if err != nil { + return nil, err + } + return ccr, nil +} + +func (ccr *ccResolverWrapper) start() { + go ccr.watcher() +} + +// watcher processes address updates and service config updates sequentially. +// Otherwise, we need to resolve possible races between address and service +// config (e.g. they specify different balancer types). +func (ccr *ccResolverWrapper) watcher() { + for { + select { + case <-ccr.done: + return + default: + } + + select { + case addrs := <-ccr.addrCh: + select { + case <-ccr.done: + return + default: + } + grpclog.Infof("ccResolverWrapper: sending new addresses to cc: %v", addrs) + ccr.cc.handleResolvedAddrs(addrs, nil) + case sc := <-ccr.scCh: + select { + case <-ccr.done: + return + default: + } + grpclog.Infof("ccResolverWrapper: got new service config: %v", sc) + ccr.cc.handleServiceConfig(sc) + case <-ccr.done: + return + } + } +} + +func (ccr *ccResolverWrapper) resolveNow(o resolver.ResolveNowOption) { + ccr.resolver.ResolveNow(o) +} + +func (ccr *ccResolverWrapper) close() { + ccr.resolver.Close() + close(ccr.done) +} + +// NewAddress is called by the resolver implemenetion to send addresses to gRPC. +func (ccr *ccResolverWrapper) NewAddress(addrs []resolver.Address) { + select { + case <-ccr.addrCh: + default: + } + ccr.addrCh <- addrs +} + +// NewServiceConfig is called by the resolver implemenetion to send service +// configs to gPRC. +func (ccr *ccResolverWrapper) NewServiceConfig(sc string) { + select { + case <-ccr.scCh: + default: + } + ccr.scCh <- sc +} diff --git a/vendor/google.golang.org/grpc/rpc_util.go b/vendor/google.golang.org/grpc/rpc_util.go new file mode 100644 index 00000000000..5de1b031ec2 --- /dev/null +++ b/vendor/google.golang.org/grpc/rpc_util.go @@ -0,0 +1,727 @@ +/* + * + * Copyright 2014 gRPC 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 grpc + +import ( + "bytes" + "compress/gzip" + "encoding/binary" + "fmt" + "io" + "io/ioutil" + "math" + "net/url" + "strings" + "sync" + "time" + + "golang.org/x/net/context" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/encoding" + "google.golang.org/grpc/encoding/proto" + "google.golang.org/grpc/metadata" + "google.golang.org/grpc/peer" + "google.golang.org/grpc/stats" + "google.golang.org/grpc/status" + "google.golang.org/grpc/transport" +) + +// Compressor defines the interface gRPC uses to compress a message. +// +// Deprecated: use package encoding. +type Compressor interface { + // Do compresses p into w. + Do(w io.Writer, p []byte) error + // Type returns the compression algorithm the Compressor uses. + Type() string +} + +type gzipCompressor struct { + pool sync.Pool +} + +// NewGZIPCompressor creates a Compressor based on GZIP. +// +// Deprecated: use package encoding/gzip. +func NewGZIPCompressor() Compressor { + c, _ := NewGZIPCompressorWithLevel(gzip.DefaultCompression) + return c +} + +// NewGZIPCompressorWithLevel is like NewGZIPCompressor but specifies the gzip compression level instead +// of assuming DefaultCompression. +// +// The error returned will be nil if the level is valid. +// +// Deprecated: use package encoding/gzip. +func NewGZIPCompressorWithLevel(level int) (Compressor, error) { + if level < gzip.DefaultCompression || level > gzip.BestCompression { + return nil, fmt.Errorf("grpc: invalid compression level: %d", level) + } + return &gzipCompressor{ + pool: sync.Pool{ + New: func() interface{} { + w, err := gzip.NewWriterLevel(ioutil.Discard, level) + if err != nil { + panic(err) + } + return w + }, + }, + }, nil +} + +func (c *gzipCompressor) Do(w io.Writer, p []byte) error { + z := c.pool.Get().(*gzip.Writer) + defer c.pool.Put(z) + z.Reset(w) + if _, err := z.Write(p); err != nil { + return err + } + return z.Close() +} + +func (c *gzipCompressor) Type() string { + return "gzip" +} + +// Decompressor defines the interface gRPC uses to decompress a message. +// +// Deprecated: use package encoding. +type Decompressor interface { + // Do reads the data from r and uncompress them. + Do(r io.Reader) ([]byte, error) + // Type returns the compression algorithm the Decompressor uses. + Type() string +} + +type gzipDecompressor struct { + pool sync.Pool +} + +// NewGZIPDecompressor creates a Decompressor based on GZIP. +// +// Deprecated: use package encoding/gzip. +func NewGZIPDecompressor() Decompressor { + return &gzipDecompressor{} +} + +func (d *gzipDecompressor) Do(r io.Reader) ([]byte, error) { + var z *gzip.Reader + switch maybeZ := d.pool.Get().(type) { + case nil: + newZ, err := gzip.NewReader(r) + if err != nil { + return nil, err + } + z = newZ + case *gzip.Reader: + z = maybeZ + if err := z.Reset(r); err != nil { + d.pool.Put(z) + return nil, err + } + } + + defer func() { + z.Close() + d.pool.Put(z) + }() + return ioutil.ReadAll(z) +} + +func (d *gzipDecompressor) Type() string { + return "gzip" +} + +// callInfo contains all related configuration and information about an RPC. +type callInfo struct { + compressorType string + failFast bool + stream *clientStream + traceInfo traceInfo // in trace.go + maxReceiveMessageSize *int + maxSendMessageSize *int + creds credentials.PerRPCCredentials + contentSubtype string + codec baseCodec +} + +func defaultCallInfo() *callInfo { + return &callInfo{failFast: true} +} + +// CallOption configures a Call before it starts or extracts information from +// a Call after it completes. +type CallOption interface { + // before is called before the call is sent to any server. If before + // returns a non-nil error, the RPC fails with that error. + before(*callInfo) error + + // after is called after the call has completed. after cannot return an + // error, so any failures should be reported via output parameters. + after(*callInfo) +} + +// EmptyCallOption does not alter the Call configuration. +// It can be embedded in another structure to carry satellite data for use +// by interceptors. +type EmptyCallOption struct{} + +func (EmptyCallOption) before(*callInfo) error { return nil } +func (EmptyCallOption) after(*callInfo) {} + +// Header returns a CallOptions that retrieves the header metadata +// for a unary RPC. +func Header(md *metadata.MD) CallOption { + return HeaderCallOption{HeaderAddr: md} +} + +// HeaderCallOption is a CallOption for collecting response header metadata. +// The metadata field will be populated *after* the RPC completes. +// This is an EXPERIMENTAL API. +type HeaderCallOption struct { + HeaderAddr *metadata.MD +} + +func (o HeaderCallOption) before(c *callInfo) error { return nil } +func (o HeaderCallOption) after(c *callInfo) { + if c.stream != nil { + *o.HeaderAddr, _ = c.stream.Header() + } +} + +// Trailer returns a CallOptions that retrieves the trailer metadata +// for a unary RPC. +func Trailer(md *metadata.MD) CallOption { + return TrailerCallOption{TrailerAddr: md} +} + +// TrailerCallOption is a CallOption for collecting response trailer metadata. +// The metadata field will be populated *after* the RPC completes. +// This is an EXPERIMENTAL API. +type TrailerCallOption struct { + TrailerAddr *metadata.MD +} + +func (o TrailerCallOption) before(c *callInfo) error { return nil } +func (o TrailerCallOption) after(c *callInfo) { + if c.stream != nil { + *o.TrailerAddr = c.stream.Trailer() + } +} + +// Peer returns a CallOption that retrieves peer information for a unary RPC. +// The peer field will be populated *after* the RPC completes. +func Peer(p *peer.Peer) CallOption { + return PeerCallOption{PeerAddr: p} +} + +// PeerCallOption is a CallOption for collecting the identity of the remote +// peer. The peer field will be populated *after* the RPC completes. +// This is an EXPERIMENTAL API. +type PeerCallOption struct { + PeerAddr *peer.Peer +} + +func (o PeerCallOption) before(c *callInfo) error { return nil } +func (o PeerCallOption) after(c *callInfo) { + if c.stream != nil { + if x, ok := peer.FromContext(c.stream.Context()); ok { + *o.PeerAddr = *x + } + } +} + +// FailFast configures the action to take when an RPC is attempted on broken +// connections or unreachable servers. If failFast is true, the RPC will fail +// immediately. Otherwise, the RPC client will block the call until a +// connection is available (or the call is canceled or times out) and will +// retry the call if it fails due to a transient error. gRPC will not retry if +// data was written to the wire unless the server indicates it did not process +// the data. Please refer to +// https://github.com/grpc/grpc/blob/master/doc/wait-for-ready.md. +// +// By default, RPCs are "Fail Fast". +func FailFast(failFast bool) CallOption { + return FailFastCallOption{FailFast: failFast} +} + +// FailFastCallOption is a CallOption for indicating whether an RPC should fail +// fast or not. +// This is an EXPERIMENTAL API. +type FailFastCallOption struct { + FailFast bool +} + +func (o FailFastCallOption) before(c *callInfo) error { + c.failFast = o.FailFast + return nil +} +func (o FailFastCallOption) after(c *callInfo) {} + +// MaxCallRecvMsgSize returns a CallOption which sets the maximum message size the client can receive. +func MaxCallRecvMsgSize(s int) CallOption { + return MaxRecvMsgSizeCallOption{MaxRecvMsgSize: s} +} + +// MaxRecvMsgSizeCallOption is a CallOption that indicates the maximum message +// size the client can receive. +// This is an EXPERIMENTAL API. +type MaxRecvMsgSizeCallOption struct { + MaxRecvMsgSize int +} + +func (o MaxRecvMsgSizeCallOption) before(c *callInfo) error { + c.maxReceiveMessageSize = &o.MaxRecvMsgSize + return nil +} +func (o MaxRecvMsgSizeCallOption) after(c *callInfo) {} + +// MaxCallSendMsgSize returns a CallOption which sets the maximum message size the client can send. +func MaxCallSendMsgSize(s int) CallOption { + return MaxSendMsgSizeCallOption{MaxSendMsgSize: s} +} + +// MaxSendMsgSizeCallOption is a CallOption that indicates the maximum message +// size the client can send. +// This is an EXPERIMENTAL API. +type MaxSendMsgSizeCallOption struct { + MaxSendMsgSize int +} + +func (o MaxSendMsgSizeCallOption) before(c *callInfo) error { + c.maxSendMessageSize = &o.MaxSendMsgSize + return nil +} +func (o MaxSendMsgSizeCallOption) after(c *callInfo) {} + +// PerRPCCredentials returns a CallOption that sets credentials.PerRPCCredentials +// for a call. +func PerRPCCredentials(creds credentials.PerRPCCredentials) CallOption { + return PerRPCCredsCallOption{Creds: creds} +} + +// PerRPCCredsCallOption is a CallOption that indicates the per-RPC +// credentials to use for the call. +// This is an EXPERIMENTAL API. +type PerRPCCredsCallOption struct { + Creds credentials.PerRPCCredentials +} + +func (o PerRPCCredsCallOption) before(c *callInfo) error { + c.creds = o.Creds + return nil +} +func (o PerRPCCredsCallOption) after(c *callInfo) {} + +// UseCompressor returns a CallOption which sets the compressor used when +// sending the request. If WithCompressor is also set, UseCompressor has +// higher priority. +// +// This API is EXPERIMENTAL. +func UseCompressor(name string) CallOption { + return CompressorCallOption{CompressorType: name} +} + +// CompressorCallOption is a CallOption that indicates the compressor to use. +// This is an EXPERIMENTAL API. +type CompressorCallOption struct { + CompressorType string +} + +func (o CompressorCallOption) before(c *callInfo) error { + c.compressorType = o.CompressorType + return nil +} +func (o CompressorCallOption) after(c *callInfo) {} + +// CallContentSubtype returns a CallOption that will set the content-subtype +// for a call. For example, if content-subtype is "json", the Content-Type over +// the wire will be "application/grpc+json". The content-subtype is converted +// to lowercase before being included in Content-Type. See Content-Type on +// https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#requests for +// more details. +// +// If CallCustomCodec is not also used, the content-subtype will be used to +// look up the Codec to use in the registry controlled by RegisterCodec. See +// the documentation on RegisterCodec for details on registration. The lookup +// of content-subtype is case-insensitive. If no such Codec is found, the call +// will result in an error with code codes.Internal. +// +// If CallCustomCodec is also used, that Codec will be used for all request and +// response messages, with the content-subtype set to the given contentSubtype +// here for requests. +func CallContentSubtype(contentSubtype string) CallOption { + return ContentSubtypeCallOption{ContentSubtype: strings.ToLower(contentSubtype)} +} + +// ContentSubtypeCallOption is a CallOption that indicates the content-subtype +// used for marshaling messages. +// This is an EXPERIMENTAL API. +type ContentSubtypeCallOption struct { + ContentSubtype string +} + +func (o ContentSubtypeCallOption) before(c *callInfo) error { + c.contentSubtype = o.ContentSubtype + return nil +} +func (o ContentSubtypeCallOption) after(c *callInfo) {} + +// CallCustomCodec returns a CallOption that will set the given Codec to be +// used for all request and response messages for a call. The result of calling +// String() will be used as the content-subtype in a case-insensitive manner. +// +// See Content-Type on +// https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#requests for +// more details. Also see the documentation on RegisterCodec and +// CallContentSubtype for more details on the interaction between Codec and +// content-subtype. +// +// This function is provided for advanced users; prefer to use only +// CallContentSubtype to select a registered codec instead. +func CallCustomCodec(codec Codec) CallOption { + return CustomCodecCallOption{Codec: codec} +} + +// CustomCodecCallOption is a CallOption that indicates the codec used for +// marshaling messages. +// This is an EXPERIMENTAL API. +type CustomCodecCallOption struct { + Codec Codec +} + +func (o CustomCodecCallOption) before(c *callInfo) error { + c.codec = o.Codec + return nil +} +func (o CustomCodecCallOption) after(c *callInfo) {} + +// The format of the payload: compressed or not? +type payloadFormat uint8 + +const ( + compressionNone payloadFormat = iota // no compression + compressionMade +) + +// parser reads complete gRPC messages from the underlying reader. +type parser struct { + // r is the underlying reader. + // See the comment on recvMsg for the permissible + // error types. + r io.Reader + + // The header of a gRPC message. Find more detail at + // https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md + header [5]byte +} + +// recvMsg reads a complete gRPC message from the stream. +// +// It returns the message and its payload (compression/encoding) +// format. The caller owns the returned msg memory. +// +// If there is an error, possible values are: +// * io.EOF, when no messages remain +// * io.ErrUnexpectedEOF +// * of type transport.ConnectionError +// * of type transport.StreamError +// No other error values or types must be returned, which also means +// that the underlying io.Reader must not return an incompatible +// error. +func (p *parser) recvMsg(maxReceiveMessageSize int) (pf payloadFormat, msg []byte, err error) { + if _, err := p.r.Read(p.header[:]); err != nil { + return 0, nil, err + } + + pf = payloadFormat(p.header[0]) + length := binary.BigEndian.Uint32(p.header[1:]) + + if length == 0 { + return pf, nil, nil + } + if int64(length) > int64(maxInt) { + return 0, nil, status.Errorf(codes.ResourceExhausted, "grpc: received message larger than max length allowed on current machine (%d vs. %d)", length, maxInt) + } + if int(length) > maxReceiveMessageSize { + return 0, nil, status.Errorf(codes.ResourceExhausted, "grpc: received message larger than max (%d vs. %d)", length, maxReceiveMessageSize) + } + // TODO(bradfitz,zhaoq): garbage. reuse buffer after proto decoding instead + // of making it for each message: + msg = make([]byte, int(length)) + if _, err := p.r.Read(msg); err != nil { + if err == io.EOF { + err = io.ErrUnexpectedEOF + } + return 0, nil, err + } + return pf, msg, nil +} + +// encode serializes msg and returns a buffer of message header and a buffer of msg. +// If msg is nil, it generates the message header and an empty msg buffer. +// TODO(ddyihai): eliminate extra Compressor parameter. +func encode(c baseCodec, msg interface{}, cp Compressor, outPayload *stats.OutPayload, compressor encoding.Compressor) ([]byte, []byte, error) { + var ( + b []byte + cbuf *bytes.Buffer + ) + const ( + payloadLen = 1 + sizeLen = 4 + ) + if msg != nil { + var err error + b, err = c.Marshal(msg) + if err != nil { + return nil, nil, status.Errorf(codes.Internal, "grpc: error while marshaling: %v", err.Error()) + } + if outPayload != nil { + outPayload.Payload = msg + // TODO truncate large payload. + outPayload.Data = b + outPayload.Length = len(b) + } + if compressor != nil || cp != nil { + cbuf = new(bytes.Buffer) + // Has compressor, check Compressor is set by UseCompressor first. + if compressor != nil { + z, _ := compressor.Compress(cbuf) + if _, err := z.Write(b); err != nil { + return nil, nil, status.Errorf(codes.Internal, "grpc: error while compressing: %v", err.Error()) + } + z.Close() + } else { + // If Compressor is not set by UseCompressor, use default Compressor + if err := cp.Do(cbuf, b); err != nil { + return nil, nil, status.Errorf(codes.Internal, "grpc: error while compressing: %v", err.Error()) + } + } + b = cbuf.Bytes() + } + } + if uint(len(b)) > math.MaxUint32 { + return nil, nil, status.Errorf(codes.ResourceExhausted, "grpc: message too large (%d bytes)", len(b)) + } + + bufHeader := make([]byte, payloadLen+sizeLen) + if compressor != nil || cp != nil { + bufHeader[0] = byte(compressionMade) + } else { + bufHeader[0] = byte(compressionNone) + } + + // Write length of b into buf + binary.BigEndian.PutUint32(bufHeader[payloadLen:], uint32(len(b))) + if outPayload != nil { + outPayload.WireLength = payloadLen + sizeLen + len(b) + } + return bufHeader, b, nil +} + +func checkRecvPayload(pf payloadFormat, recvCompress string, haveCompressor bool) *status.Status { + switch pf { + case compressionNone: + case compressionMade: + if recvCompress == "" || recvCompress == encoding.Identity { + return status.New(codes.Internal, "grpc: compressed flag set with identity or empty encoding") + } + if !haveCompressor { + return status.Newf(codes.Unimplemented, "grpc: Decompressor is not installed for grpc-encoding %q", recvCompress) + } + default: + return status.Newf(codes.Internal, "grpc: received unexpected payload format %d", pf) + } + return nil +} + +// For the two compressor parameters, both should not be set, but if they are, +// dc takes precedence over compressor. +// TODO(dfawley): wrap the old compressor/decompressor using the new API? +func recv(p *parser, c baseCodec, s *transport.Stream, dc Decompressor, m interface{}, maxReceiveMessageSize int, inPayload *stats.InPayload, compressor encoding.Compressor) error { + pf, d, err := p.recvMsg(maxReceiveMessageSize) + if err != nil { + return err + } + if inPayload != nil { + inPayload.WireLength = len(d) + } + + if st := checkRecvPayload(pf, s.RecvCompress(), compressor != nil || dc != nil); st != nil { + return st.Err() + } + + if pf == compressionMade { + // To match legacy behavior, if the decompressor is set by WithDecompressor or RPCDecompressor, + // use this decompressor as the default. + if dc != nil { + d, err = dc.Do(bytes.NewReader(d)) + if err != nil { + return status.Errorf(codes.Internal, "grpc: failed to decompress the received message %v", err) + } + } else { + dcReader, err := compressor.Decompress(bytes.NewReader(d)) + if err != nil { + return status.Errorf(codes.Internal, "grpc: failed to decompress the received message %v", err) + } + d, err = ioutil.ReadAll(dcReader) + if err != nil { + return status.Errorf(codes.Internal, "grpc: failed to decompress the received message %v", err) + } + } + } + if len(d) > maxReceiveMessageSize { + // TODO: Revisit the error code. Currently keep it consistent with java + // implementation. + return status.Errorf(codes.ResourceExhausted, "grpc: received message larger than max (%d vs. %d)", len(d), maxReceiveMessageSize) + } + if err := c.Unmarshal(d, m); err != nil { + return status.Errorf(codes.Internal, "grpc: failed to unmarshal the received message %v", err) + } + if inPayload != nil { + inPayload.RecvTime = time.Now() + inPayload.Payload = m + // TODO truncate large payload. + inPayload.Data = d + inPayload.Length = len(d) + } + return nil +} + +type rpcInfo struct { + failfast bool +} + +type rpcInfoContextKey struct{} + +func newContextWithRPCInfo(ctx context.Context, failfast bool) context.Context { + return context.WithValue(ctx, rpcInfoContextKey{}, &rpcInfo{failfast: failfast}) +} + +func rpcInfoFromContext(ctx context.Context) (s *rpcInfo, ok bool) { + s, ok = ctx.Value(rpcInfoContextKey{}).(*rpcInfo) + return +} + +// Code returns the error code for err if it was produced by the rpc system. +// Otherwise, it returns codes.Unknown. +// +// Deprecated: use status.FromError and Code method instead. +func Code(err error) codes.Code { + if s, ok := status.FromError(err); ok { + return s.Code() + } + return codes.Unknown +} + +// ErrorDesc returns the error description of err if it was produced by the rpc system. +// Otherwise, it returns err.Error() or empty string when err is nil. +// +// Deprecated: use status.FromError and Message method instead. +func ErrorDesc(err error) string { + if s, ok := status.FromError(err); ok { + return s.Message() + } + return err.Error() +} + +// Errorf returns an error containing an error code and a description; +// Errorf returns nil if c is OK. +// +// Deprecated: use status.Errorf instead. +func Errorf(c codes.Code, format string, a ...interface{}) error { + return status.Errorf(c, format, a...) +} + +// setCallInfoCodec should only be called after CallOptions have been applied. +func setCallInfoCodec(c *callInfo) error { + if c.codec != nil { + // codec was already set by a CallOption; use it. + return nil + } + + if c.contentSubtype == "" { + // No codec specified in CallOptions; use proto by default. + c.codec = encoding.GetCodec(proto.Name) + return nil + } + + // c.contentSubtype is already lowercased in CallContentSubtype + c.codec = encoding.GetCodec(c.contentSubtype) + if c.codec == nil { + return status.Errorf(codes.Internal, "no codec registered for content-subtype %s", c.contentSubtype) + } + return nil +} + +// parseDialTarget returns the network and address to pass to dialer +func parseDialTarget(target string) (net string, addr string) { + net = "tcp" + + m1 := strings.Index(target, ":") + m2 := strings.Index(target, ":/") + + // handle unix:addr which will fail with url.Parse + if m1 >= 0 && m2 < 0 { + if n := target[0:m1]; n == "unix" { + net = n + addr = target[m1+1:] + return net, addr + } + } + if m2 >= 0 { + t, err := url.Parse(target) + if err != nil { + return net, target + } + scheme := t.Scheme + addr = t.Path + if scheme == "unix" { + net = scheme + if addr == "" { + addr = t.Host + } + return net, addr + } + } + + return net, target +} + +// The SupportPackageIsVersion variables are referenced from generated protocol +// buffer files to ensure compatibility with the gRPC version used. The latest +// support package version is 5. +// +// Older versions are kept for compatibility. They may be removed if +// compatibility cannot be maintained. +// +// These constants should not be referenced from any other code. +const ( + SupportPackageIsVersion3 = true + SupportPackageIsVersion4 = true + SupportPackageIsVersion5 = true +) + +// Version is the current grpc version. +const Version = "1.12.2" + +const grpcUA = "grpc-go/" + Version diff --git a/vendor/google.golang.org/grpc/server.go b/vendor/google.golang.org/grpc/server.go new file mode 100644 index 00000000000..4969331cb3d --- /dev/null +++ b/vendor/google.golang.org/grpc/server.go @@ -0,0 +1,1486 @@ +/* + * + * Copyright 2014 gRPC 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 grpc + +import ( + "bytes" + "errors" + "fmt" + "io" + "math" + "net" + "net/http" + "reflect" + "runtime" + "strings" + "sync" + "time" + + "io/ioutil" + + "golang.org/x/net/context" + "golang.org/x/net/http2" + "golang.org/x/net/trace" + + "google.golang.org/grpc/channelz" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/encoding" + "google.golang.org/grpc/encoding/proto" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/internal" + "google.golang.org/grpc/keepalive" + "google.golang.org/grpc/metadata" + "google.golang.org/grpc/stats" + "google.golang.org/grpc/status" + "google.golang.org/grpc/tap" + "google.golang.org/grpc/transport" +) + +const ( + defaultServerMaxReceiveMessageSize = 1024 * 1024 * 4 + defaultServerMaxSendMessageSize = math.MaxInt32 +) + +type methodHandler func(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor UnaryServerInterceptor) (interface{}, error) + +// MethodDesc represents an RPC service's method specification. +type MethodDesc struct { + MethodName string + Handler methodHandler +} + +// ServiceDesc represents an RPC service's specification. +type ServiceDesc struct { + ServiceName string + // The pointer to the service interface. Used to check whether the user + // provided implementation satisfies the interface requirements. + HandlerType interface{} + Methods []MethodDesc + Streams []StreamDesc + Metadata interface{} +} + +// service consists of the information of the server serving this service and +// the methods in this service. +type service struct { + server interface{} // the server for service methods + md map[string]*MethodDesc + sd map[string]*StreamDesc + mdata interface{} +} + +// Server is a gRPC server to serve RPC requests. +type Server struct { + opts options + + mu sync.Mutex // guards following + lis map[net.Listener]bool + conns map[io.Closer]bool + serve bool + drain bool + cv *sync.Cond // signaled when connections close for GracefulStop + m map[string]*service // service name -> service info + events trace.EventLog + + quit chan struct{} + done chan struct{} + quitOnce sync.Once + doneOnce sync.Once + channelzRemoveOnce sync.Once + serveWG sync.WaitGroup // counts active Serve goroutines for GracefulStop + + channelzID int64 // channelz unique identification number + czmu sync.RWMutex + callsStarted int64 + callsFailed int64 + callsSucceeded int64 + lastCallStartedTime time.Time +} + +type options struct { + creds credentials.TransportCredentials + codec baseCodec + cp Compressor + dc Decompressor + unaryInt UnaryServerInterceptor + streamInt StreamServerInterceptor + inTapHandle tap.ServerInHandle + statsHandler stats.Handler + maxConcurrentStreams uint32 + maxReceiveMessageSize int + maxSendMessageSize int + useHandlerImpl bool // use http.Handler-based server + unknownStreamDesc *StreamDesc + keepaliveParams keepalive.ServerParameters + keepalivePolicy keepalive.EnforcementPolicy + initialWindowSize int32 + initialConnWindowSize int32 + writeBufferSize int + readBufferSize int + connectionTimeout time.Duration +} + +var defaultServerOptions = options{ + maxReceiveMessageSize: defaultServerMaxReceiveMessageSize, + maxSendMessageSize: defaultServerMaxSendMessageSize, + connectionTimeout: 120 * time.Second, +} + +// A ServerOption sets options such as credentials, codec and keepalive parameters, etc. +type ServerOption func(*options) + +// WriteBufferSize lets you set the size of write buffer, this determines how much data can be batched +// before doing a write on the wire. +func WriteBufferSize(s int) ServerOption { + return func(o *options) { + o.writeBufferSize = s + } +} + +// ReadBufferSize lets you set the size of read buffer, this determines how much data can be read at most +// for one read syscall. +func ReadBufferSize(s int) ServerOption { + return func(o *options) { + o.readBufferSize = s + } +} + +// InitialWindowSize returns a ServerOption that sets window size for stream. +// The lower bound for window size is 64K and any value smaller than that will be ignored. +func InitialWindowSize(s int32) ServerOption { + return func(o *options) { + o.initialWindowSize = s + } +} + +// InitialConnWindowSize returns a ServerOption that sets window size for a connection. +// The lower bound for window size is 64K and any value smaller than that will be ignored. +func InitialConnWindowSize(s int32) ServerOption { + return func(o *options) { + o.initialConnWindowSize = s + } +} + +// KeepaliveParams returns a ServerOption that sets keepalive and max-age parameters for the server. +func KeepaliveParams(kp keepalive.ServerParameters) ServerOption { + return func(o *options) { + o.keepaliveParams = kp + } +} + +// KeepaliveEnforcementPolicy returns a ServerOption that sets keepalive enforcement policy for the server. +func KeepaliveEnforcementPolicy(kep keepalive.EnforcementPolicy) ServerOption { + return func(o *options) { + o.keepalivePolicy = kep + } +} + +// CustomCodec returns a ServerOption that sets a codec for message marshaling and unmarshaling. +// +// This will override any lookups by content-subtype for Codecs registered with RegisterCodec. +func CustomCodec(codec Codec) ServerOption { + return func(o *options) { + o.codec = codec + } +} + +// RPCCompressor returns a ServerOption that sets a compressor for outbound +// messages. For backward compatibility, all outbound messages will be sent +// using this compressor, regardless of incoming message compression. By +// default, server messages will be sent using the same compressor with which +// request messages were sent. +// +// Deprecated: use encoding.RegisterCompressor instead. +func RPCCompressor(cp Compressor) ServerOption { + return func(o *options) { + o.cp = cp + } +} + +// RPCDecompressor returns a ServerOption that sets a decompressor for inbound +// messages. It has higher priority than decompressors registered via +// encoding.RegisterCompressor. +// +// Deprecated: use encoding.RegisterCompressor instead. +func RPCDecompressor(dc Decompressor) ServerOption { + return func(o *options) { + o.dc = dc + } +} + +// MaxMsgSize returns a ServerOption to set the max message size in bytes the server can receive. +// If this is not set, gRPC uses the default limit. +// +// Deprecated: use MaxRecvMsgSize instead. +func MaxMsgSize(m int) ServerOption { + return MaxRecvMsgSize(m) +} + +// MaxRecvMsgSize returns a ServerOption to set the max message size in bytes the server can receive. +// If this is not set, gRPC uses the default 4MB. +func MaxRecvMsgSize(m int) ServerOption { + return func(o *options) { + o.maxReceiveMessageSize = m + } +} + +// MaxSendMsgSize returns a ServerOption to set the max message size in bytes the server can send. +// If this is not set, gRPC uses the default 4MB. +func MaxSendMsgSize(m int) ServerOption { + return func(o *options) { + o.maxSendMessageSize = m + } +} + +// MaxConcurrentStreams returns a ServerOption that will apply a limit on the number +// of concurrent streams to each ServerTransport. +func MaxConcurrentStreams(n uint32) ServerOption { + return func(o *options) { + o.maxConcurrentStreams = n + } +} + +// Creds returns a ServerOption that sets credentials for server connections. +func Creds(c credentials.TransportCredentials) ServerOption { + return func(o *options) { + o.creds = c + } +} + +// UnaryInterceptor returns a ServerOption that sets the UnaryServerInterceptor for the +// server. Only one unary interceptor can be installed. The construction of multiple +// interceptors (e.g., chaining) can be implemented at the caller. +func UnaryInterceptor(i UnaryServerInterceptor) ServerOption { + return func(o *options) { + if o.unaryInt != nil { + panic("The unary server interceptor was already set and may not be reset.") + } + o.unaryInt = i + } +} + +// StreamInterceptor returns a ServerOption that sets the StreamServerInterceptor for the +// server. Only one stream interceptor can be installed. +func StreamInterceptor(i StreamServerInterceptor) ServerOption { + return func(o *options) { + if o.streamInt != nil { + panic("The stream server interceptor was already set and may not be reset.") + } + o.streamInt = i + } +} + +// InTapHandle returns a ServerOption that sets the tap handle for all the server +// transport to be created. Only one can be installed. +func InTapHandle(h tap.ServerInHandle) ServerOption { + return func(o *options) { + if o.inTapHandle != nil { + panic("The tap handle was already set and may not be reset.") + } + o.inTapHandle = h + } +} + +// StatsHandler returns a ServerOption that sets the stats handler for the server. +func StatsHandler(h stats.Handler) ServerOption { + return func(o *options) { + o.statsHandler = h + } +} + +// UnknownServiceHandler returns a ServerOption that allows for adding a custom +// unknown service handler. The provided method is a bidi-streaming RPC service +// handler that will be invoked instead of returning the "unimplemented" gRPC +// error whenever a request is received for an unregistered service or method. +// The handling function has full access to the Context of the request and the +// stream, and the invocation bypasses interceptors. +func UnknownServiceHandler(streamHandler StreamHandler) ServerOption { + return func(o *options) { + o.unknownStreamDesc = &StreamDesc{ + StreamName: "unknown_service_handler", + Handler: streamHandler, + // We need to assume that the users of the streamHandler will want to use both. + ClientStreams: true, + ServerStreams: true, + } + } +} + +// ConnectionTimeout returns a ServerOption that sets the timeout for +// connection establishment (up to and including HTTP/2 handshaking) for all +// new connections. If this is not set, the default is 120 seconds. A zero or +// negative value will result in an immediate timeout. +// +// This API is EXPERIMENTAL. +func ConnectionTimeout(d time.Duration) ServerOption { + return func(o *options) { + o.connectionTimeout = d + } +} + +// NewServer creates a gRPC server which has no service registered and has not +// started to accept requests yet. +func NewServer(opt ...ServerOption) *Server { + opts := defaultServerOptions + for _, o := range opt { + o(&opts) + } + s := &Server{ + lis: make(map[net.Listener]bool), + opts: opts, + conns: make(map[io.Closer]bool), + m: make(map[string]*service), + quit: make(chan struct{}), + done: make(chan struct{}), + } + s.cv = sync.NewCond(&s.mu) + if EnableTracing { + _, file, line, _ := runtime.Caller(1) + s.events = trace.NewEventLog("grpc.Server", fmt.Sprintf("%s:%d", file, line)) + } + + if channelz.IsOn() { + s.channelzID = channelz.RegisterServer(s, "") + } + return s +} + +// printf records an event in s's event log, unless s has been stopped. +// REQUIRES s.mu is held. +func (s *Server) printf(format string, a ...interface{}) { + if s.events != nil { + s.events.Printf(format, a...) + } +} + +// errorf records an error in s's event log, unless s has been stopped. +// REQUIRES s.mu is held. +func (s *Server) errorf(format string, a ...interface{}) { + if s.events != nil { + s.events.Errorf(format, a...) + } +} + +// RegisterService registers a service and its implementation to the gRPC +// server. It is called from the IDL generated code. This must be called before +// invoking Serve. +func (s *Server) RegisterService(sd *ServiceDesc, ss interface{}) { + ht := reflect.TypeOf(sd.HandlerType).Elem() + st := reflect.TypeOf(ss) + if !st.Implements(ht) { + grpclog.Fatalf("grpc: Server.RegisterService found the handler of type %v that does not satisfy %v", st, ht) + } + s.register(sd, ss) +} + +func (s *Server) register(sd *ServiceDesc, ss interface{}) { + s.mu.Lock() + defer s.mu.Unlock() + s.printf("RegisterService(%q)", sd.ServiceName) + if s.serve { + grpclog.Fatalf("grpc: Server.RegisterService after Server.Serve for %q", sd.ServiceName) + } + if _, ok := s.m[sd.ServiceName]; ok { + grpclog.Fatalf("grpc: Server.RegisterService found duplicate service registration for %q", sd.ServiceName) + } + srv := &service{ + server: ss, + md: make(map[string]*MethodDesc), + sd: make(map[string]*StreamDesc), + mdata: sd.Metadata, + } + for i := range sd.Methods { + d := &sd.Methods[i] + srv.md[d.MethodName] = d + } + for i := range sd.Streams { + d := &sd.Streams[i] + srv.sd[d.StreamName] = d + } + s.m[sd.ServiceName] = srv +} + +// MethodInfo contains the information of an RPC including its method name and type. +type MethodInfo struct { + // Name is the method name only, without the service name or package name. + Name string + // IsClientStream indicates whether the RPC is a client streaming RPC. + IsClientStream bool + // IsServerStream indicates whether the RPC is a server streaming RPC. + IsServerStream bool +} + +// ServiceInfo contains unary RPC method info, streaming RPC method info and metadata for a service. +type ServiceInfo struct { + Methods []MethodInfo + // Metadata is the metadata specified in ServiceDesc when registering service. + Metadata interface{} +} + +// GetServiceInfo returns a map from service names to ServiceInfo. +// Service names include the package names, in the form of .. +func (s *Server) GetServiceInfo() map[string]ServiceInfo { + ret := make(map[string]ServiceInfo) + for n, srv := range s.m { + methods := make([]MethodInfo, 0, len(srv.md)+len(srv.sd)) + for m := range srv.md { + methods = append(methods, MethodInfo{ + Name: m, + IsClientStream: false, + IsServerStream: false, + }) + } + for m, d := range srv.sd { + methods = append(methods, MethodInfo{ + Name: m, + IsClientStream: d.ClientStreams, + IsServerStream: d.ServerStreams, + }) + } + + ret[n] = ServiceInfo{ + Methods: methods, + Metadata: srv.mdata, + } + } + return ret +} + +// ErrServerStopped indicates that the operation is now illegal because of +// the server being stopped. +var ErrServerStopped = errors.New("grpc: the server has been stopped") + +func (s *Server) useTransportAuthenticator(rawConn net.Conn) (net.Conn, credentials.AuthInfo, error) { + if s.opts.creds == nil { + return rawConn, nil, nil + } + return s.opts.creds.ServerHandshake(rawConn) +} + +type listenSocket struct { + net.Listener + channelzID int64 +} + +func (l *listenSocket) ChannelzMetric() *channelz.SocketInternalMetric { + return &channelz.SocketInternalMetric{ + LocalAddr: l.Listener.Addr(), + } +} + +func (l *listenSocket) Close() error { + err := l.Listener.Close() + if channelz.IsOn() { + channelz.RemoveEntry(l.channelzID) + } + return err +} + +// Serve accepts incoming connections on the listener lis, creating a new +// ServerTransport and service goroutine for each. The service goroutines +// read gRPC requests and then call the registered handlers to reply to them. +// Serve returns when lis.Accept fails with fatal errors. lis will be closed when +// this method returns. +// Serve will return a non-nil error unless Stop or GracefulStop is called. +func (s *Server) Serve(lis net.Listener) error { + s.mu.Lock() + s.printf("serving") + s.serve = true + if s.lis == nil { + // Serve called after Stop or GracefulStop. + s.mu.Unlock() + lis.Close() + return ErrServerStopped + } + + s.serveWG.Add(1) + defer func() { + s.serveWG.Done() + select { + // Stop or GracefulStop called; block until done and return nil. + case <-s.quit: + <-s.done + default: + } + }() + + ls := &listenSocket{Listener: lis} + s.lis[ls] = true + + if channelz.IsOn() { + ls.channelzID = channelz.RegisterListenSocket(ls, s.channelzID, "") + } + s.mu.Unlock() + + defer func() { + s.mu.Lock() + if s.lis != nil && s.lis[ls] { + ls.Close() + delete(s.lis, ls) + } + s.mu.Unlock() + }() + + var tempDelay time.Duration // how long to sleep on accept failure + + for { + rawConn, err := lis.Accept() + if err != nil { + if ne, ok := err.(interface { + Temporary() bool + }); ok && ne.Temporary() { + if tempDelay == 0 { + tempDelay = 5 * time.Millisecond + } else { + tempDelay *= 2 + } + if max := 1 * time.Second; tempDelay > max { + tempDelay = max + } + s.mu.Lock() + s.printf("Accept error: %v; retrying in %v", err, tempDelay) + s.mu.Unlock() + timer := time.NewTimer(tempDelay) + select { + case <-timer.C: + case <-s.quit: + timer.Stop() + return nil + } + continue + } + s.mu.Lock() + s.printf("done serving; Accept = %v", err) + s.mu.Unlock() + + select { + case <-s.quit: + return nil + default: + } + return err + } + tempDelay = 0 + // Start a new goroutine to deal with rawConn so we don't stall this Accept + // loop goroutine. + // + // Make sure we account for the goroutine so GracefulStop doesn't nil out + // s.conns before this conn can be added. + s.serveWG.Add(1) + go func() { + s.handleRawConn(rawConn) + s.serveWG.Done() + }() + } +} + +// handleRawConn forks a goroutine to handle a just-accepted connection that +// has not had any I/O performed on it yet. +func (s *Server) handleRawConn(rawConn net.Conn) { + rawConn.SetDeadline(time.Now().Add(s.opts.connectionTimeout)) + conn, authInfo, err := s.useTransportAuthenticator(rawConn) + if err != nil { + s.mu.Lock() + s.errorf("ServerHandshake(%q) failed: %v", rawConn.RemoteAddr(), err) + s.mu.Unlock() + grpclog.Warningf("grpc: Server.Serve failed to complete security handshake from %q: %v", rawConn.RemoteAddr(), err) + // If serverHandshake returns ErrConnDispatched, keep rawConn open. + if err != credentials.ErrConnDispatched { + rawConn.Close() + } + rawConn.SetDeadline(time.Time{}) + return + } + + s.mu.Lock() + if s.conns == nil { + s.mu.Unlock() + conn.Close() + return + } + s.mu.Unlock() + + var serve func() + c := conn.(io.Closer) + if s.opts.useHandlerImpl { + serve = func() { s.serveUsingHandler(conn) } + } else { + // Finish handshaking (HTTP2) + st := s.newHTTP2Transport(conn, authInfo) + if st == nil { + return + } + c = st + serve = func() { s.serveStreams(st) } + } + + rawConn.SetDeadline(time.Time{}) + if !s.addConn(c) { + return + } + go func() { + serve() + s.removeConn(c) + }() +} + +// newHTTP2Transport sets up a http/2 transport (using the +// gRPC http2 server transport in transport/http2_server.go). +func (s *Server) newHTTP2Transport(c net.Conn, authInfo credentials.AuthInfo) transport.ServerTransport { + config := &transport.ServerConfig{ + MaxStreams: s.opts.maxConcurrentStreams, + AuthInfo: authInfo, + InTapHandle: s.opts.inTapHandle, + StatsHandler: s.opts.statsHandler, + KeepaliveParams: s.opts.keepaliveParams, + KeepalivePolicy: s.opts.keepalivePolicy, + InitialWindowSize: s.opts.initialWindowSize, + InitialConnWindowSize: s.opts.initialConnWindowSize, + WriteBufferSize: s.opts.writeBufferSize, + ReadBufferSize: s.opts.readBufferSize, + ChannelzParentID: s.channelzID, + } + st, err := transport.NewServerTransport("http2", c, config) + if err != nil { + s.mu.Lock() + s.errorf("NewServerTransport(%q) failed: %v", c.RemoteAddr(), err) + s.mu.Unlock() + c.Close() + grpclog.Warningln("grpc: Server.Serve failed to create ServerTransport: ", err) + return nil + } + + return st +} + +func (s *Server) serveStreams(st transport.ServerTransport) { + defer st.Close() + var wg sync.WaitGroup + st.HandleStreams(func(stream *transport.Stream) { + wg.Add(1) + go func() { + defer wg.Done() + s.handleStream(st, stream, s.traceInfo(st, stream)) + }() + }, func(ctx context.Context, method string) context.Context { + if !EnableTracing { + return ctx + } + tr := trace.New("grpc.Recv."+methodFamily(method), method) + return trace.NewContext(ctx, tr) + }) + wg.Wait() +} + +var _ http.Handler = (*Server)(nil) + +// serveUsingHandler is called from handleRawConn when s is configured +// to handle requests via the http.Handler interface. It sets up a +// net/http.Server to handle the just-accepted conn. The http.Server +// is configured to route all incoming requests (all HTTP/2 streams) +// to ServeHTTP, which creates a new ServerTransport for each stream. +// serveUsingHandler blocks until conn closes. +// +// This codepath is only used when Server.TestingUseHandlerImpl has +// been configured. This lets the end2end tests exercise the ServeHTTP +// method as one of the environment types. +// +// conn is the *tls.Conn that's already been authenticated. +func (s *Server) serveUsingHandler(conn net.Conn) { + h2s := &http2.Server{ + MaxConcurrentStreams: s.opts.maxConcurrentStreams, + } + h2s.ServeConn(conn, &http2.ServeConnOpts{ + Handler: s, + }) +} + +// ServeHTTP implements the Go standard library's http.Handler +// interface by responding to the gRPC request r, by looking up +// the requested gRPC method in the gRPC server s. +// +// The provided HTTP request must have arrived on an HTTP/2 +// connection. When using the Go standard library's server, +// practically this means that the Request must also have arrived +// over TLS. +// +// To share one port (such as 443 for https) between gRPC and an +// existing http.Handler, use a root http.Handler such as: +// +// if r.ProtoMajor == 2 && strings.HasPrefix( +// r.Header.Get("Content-Type"), "application/grpc") { +// grpcServer.ServeHTTP(w, r) +// } else { +// yourMux.ServeHTTP(w, r) +// } +// +// Note that ServeHTTP uses Go's HTTP/2 server implementation which is totally +// separate from grpc-go's HTTP/2 server. Performance and features may vary +// between the two paths. ServeHTTP does not support some gRPC features +// available through grpc-go's HTTP/2 server, and it is currently EXPERIMENTAL +// and subject to change. +func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) { + st, err := transport.NewServerHandlerTransport(w, r, s.opts.statsHandler) + if err != nil { + http.Error(w, err.Error(), http.StatusInternalServerError) + return + } + if !s.addConn(st) { + return + } + defer s.removeConn(st) + s.serveStreams(st) +} + +// traceInfo returns a traceInfo and associates it with stream, if tracing is enabled. +// If tracing is not enabled, it returns nil. +func (s *Server) traceInfo(st transport.ServerTransport, stream *transport.Stream) (trInfo *traceInfo) { + tr, ok := trace.FromContext(stream.Context()) + if !ok { + return nil + } + + trInfo = &traceInfo{ + tr: tr, + } + trInfo.firstLine.client = false + trInfo.firstLine.remoteAddr = st.RemoteAddr() + + if dl, ok := stream.Context().Deadline(); ok { + trInfo.firstLine.deadline = dl.Sub(time.Now()) + } + return trInfo +} + +func (s *Server) addConn(c io.Closer) bool { + s.mu.Lock() + defer s.mu.Unlock() + if s.conns == nil { + c.Close() + return false + } + if s.drain { + // Transport added after we drained our existing conns: drain it + // immediately. + c.(transport.ServerTransport).Drain() + } + s.conns[c] = true + return true +} + +func (s *Server) removeConn(c io.Closer) { + s.mu.Lock() + defer s.mu.Unlock() + if s.conns != nil { + delete(s.conns, c) + s.cv.Broadcast() + } +} + +// ChannelzMetric returns ServerInternalMetric of current server. +// This is an EXPERIMENTAL API. +func (s *Server) ChannelzMetric() *channelz.ServerInternalMetric { + s.czmu.RLock() + defer s.czmu.RUnlock() + return &channelz.ServerInternalMetric{ + CallsStarted: s.callsStarted, + CallsSucceeded: s.callsSucceeded, + CallsFailed: s.callsFailed, + LastCallStartedTimestamp: s.lastCallStartedTime, + } +} + +func (s *Server) incrCallsStarted() { + s.czmu.Lock() + s.callsStarted++ + s.lastCallStartedTime = time.Now() + s.czmu.Unlock() +} + +func (s *Server) incrCallsSucceeded() { + s.czmu.Lock() + s.callsSucceeded++ + s.czmu.Unlock() +} + +func (s *Server) incrCallsFailed() { + s.czmu.Lock() + s.callsFailed++ + s.czmu.Unlock() +} + +func (s *Server) sendResponse(t transport.ServerTransport, stream *transport.Stream, msg interface{}, cp Compressor, opts *transport.Options, comp encoding.Compressor) error { + var ( + outPayload *stats.OutPayload + ) + if s.opts.statsHandler != nil { + outPayload = &stats.OutPayload{} + } + hdr, data, err := encode(s.getCodec(stream.ContentSubtype()), msg, cp, outPayload, comp) + if err != nil { + grpclog.Errorln("grpc: server failed to encode response: ", err) + return err + } + if len(data) > s.opts.maxSendMessageSize { + return status.Errorf(codes.ResourceExhausted, "grpc: trying to send message larger than max (%d vs. %d)", len(data), s.opts.maxSendMessageSize) + } + err = t.Write(stream, hdr, data, opts) + if err == nil && outPayload != nil { + outPayload.SentTime = time.Now() + s.opts.statsHandler.HandleRPC(stream.Context(), outPayload) + } + return err +} + +func (s *Server) processUnaryRPC(t transport.ServerTransport, stream *transport.Stream, srv *service, md *MethodDesc, trInfo *traceInfo) (err error) { + if channelz.IsOn() { + s.incrCallsStarted() + defer func() { + if err != nil && err != io.EOF { + s.incrCallsFailed() + } else { + s.incrCallsSucceeded() + } + }() + } + sh := s.opts.statsHandler + if sh != nil { + beginTime := time.Now() + begin := &stats.Begin{ + BeginTime: beginTime, + } + sh.HandleRPC(stream.Context(), begin) + defer func() { + end := &stats.End{ + BeginTime: beginTime, + EndTime: time.Now(), + } + if err != nil && err != io.EOF { + end.Error = toRPCErr(err) + } + sh.HandleRPC(stream.Context(), end) + }() + } + if trInfo != nil { + defer trInfo.tr.Finish() + trInfo.firstLine.client = false + trInfo.tr.LazyLog(&trInfo.firstLine, false) + defer func() { + if err != nil && err != io.EOF { + trInfo.tr.LazyLog(&fmtStringer{"%v", []interface{}{err}}, true) + trInfo.tr.SetError() + } + }() + } + + // comp and cp are used for compression. decomp and dc are used for + // decompression. If comp and decomp are both set, they are the same; + // however they are kept separate to ensure that at most one of the + // compressor/decompressor variable pairs are set for use later. + var comp, decomp encoding.Compressor + var cp Compressor + var dc Decompressor + + // If dc is set and matches the stream's compression, use it. Otherwise, try + // to find a matching registered compressor for decomp. + if rc := stream.RecvCompress(); s.opts.dc != nil && s.opts.dc.Type() == rc { + dc = s.opts.dc + } else if rc != "" && rc != encoding.Identity { + decomp = encoding.GetCompressor(rc) + if decomp == nil { + st := status.Newf(codes.Unimplemented, "grpc: Decompressor is not installed for grpc-encoding %q", rc) + t.WriteStatus(stream, st) + return st.Err() + } + } + + // If cp is set, use it. Otherwise, attempt to compress the response using + // the incoming message compression method. + // + // NOTE: this needs to be ahead of all handling, https://github.com/grpc/grpc-go/issues/686. + if s.opts.cp != nil { + cp = s.opts.cp + stream.SetSendCompress(cp.Type()) + } else if rc := stream.RecvCompress(); rc != "" && rc != encoding.Identity { + // Legacy compressor not specified; attempt to respond with same encoding. + comp = encoding.GetCompressor(rc) + if comp != nil { + stream.SetSendCompress(rc) + } + } + + p := &parser{r: stream} + pf, req, err := p.recvMsg(s.opts.maxReceiveMessageSize) + if err == io.EOF { + // The entire stream is done (for unary RPC only). + return err + } + if err == io.ErrUnexpectedEOF { + err = status.Errorf(codes.Internal, io.ErrUnexpectedEOF.Error()) + } + if err != nil { + if st, ok := status.FromError(err); ok { + if e := t.WriteStatus(stream, st); e != nil { + grpclog.Warningf("grpc: Server.processUnaryRPC failed to write status %v", e) + } + } else { + switch st := err.(type) { + case transport.ConnectionError: + // Nothing to do here. + case transport.StreamError: + if e := t.WriteStatus(stream, status.New(st.Code, st.Desc)); e != nil { + grpclog.Warningf("grpc: Server.processUnaryRPC failed to write status %v", e) + } + default: + panic(fmt.Sprintf("grpc: Unexpected error (%T) from recvMsg: %v", st, st)) + } + } + return err + } + if channelz.IsOn() { + t.IncrMsgRecv() + } + if st := checkRecvPayload(pf, stream.RecvCompress(), dc != nil || decomp != nil); st != nil { + if e := t.WriteStatus(stream, st); e != nil { + grpclog.Warningf("grpc: Server.processUnaryRPC failed to write status %v", e) + } + return st.Err() + } + var inPayload *stats.InPayload + if sh != nil { + inPayload = &stats.InPayload{ + RecvTime: time.Now(), + } + } + df := func(v interface{}) error { + if inPayload != nil { + inPayload.WireLength = len(req) + } + if pf == compressionMade { + var err error + if dc != nil { + req, err = dc.Do(bytes.NewReader(req)) + if err != nil { + return status.Errorf(codes.Internal, err.Error()) + } + } else { + tmp, _ := decomp.Decompress(bytes.NewReader(req)) + req, err = ioutil.ReadAll(tmp) + if err != nil { + return status.Errorf(codes.Internal, "grpc: failed to decompress the received message %v", err) + } + } + } + if len(req) > s.opts.maxReceiveMessageSize { + // TODO: Revisit the error code. Currently keep it consistent with + // java implementation. + return status.Errorf(codes.ResourceExhausted, "grpc: received message larger than max (%d vs. %d)", len(req), s.opts.maxReceiveMessageSize) + } + if err := s.getCodec(stream.ContentSubtype()).Unmarshal(req, v); err != nil { + return status.Errorf(codes.Internal, "grpc: error unmarshalling request: %v", err) + } + if inPayload != nil { + inPayload.Payload = v + inPayload.Data = req + inPayload.Length = len(req) + sh.HandleRPC(stream.Context(), inPayload) + } + if trInfo != nil { + trInfo.tr.LazyLog(&payload{sent: false, msg: v}, true) + } + return nil + } + ctx := NewContextWithServerTransportStream(stream.Context(), stream) + reply, appErr := md.Handler(srv.server, ctx, df, s.opts.unaryInt) + if appErr != nil { + appStatus, ok := status.FromError(appErr) + if !ok { + // Convert appErr if it is not a grpc status error. + appErr = status.Error(codes.Unknown, appErr.Error()) + appStatus, _ = status.FromError(appErr) + } + if trInfo != nil { + trInfo.tr.LazyLog(stringer(appStatus.Message()), true) + trInfo.tr.SetError() + } + if e := t.WriteStatus(stream, appStatus); e != nil { + grpclog.Warningf("grpc: Server.processUnaryRPC failed to write status: %v", e) + } + return appErr + } + if trInfo != nil { + trInfo.tr.LazyLog(stringer("OK"), false) + } + opts := &transport.Options{ + Last: true, + Delay: false, + } + + if err := s.sendResponse(t, stream, reply, cp, opts, comp); err != nil { + if err == io.EOF { + // The entire stream is done (for unary RPC only). + return err + } + if s, ok := status.FromError(err); ok { + if e := t.WriteStatus(stream, s); e != nil { + grpclog.Warningf("grpc: Server.processUnaryRPC failed to write status: %v", e) + } + } else { + switch st := err.(type) { + case transport.ConnectionError: + // Nothing to do here. + case transport.StreamError: + if e := t.WriteStatus(stream, status.New(st.Code, st.Desc)); e != nil { + grpclog.Warningf("grpc: Server.processUnaryRPC failed to write status %v", e) + } + default: + panic(fmt.Sprintf("grpc: Unexpected error (%T) from sendResponse: %v", st, st)) + } + } + return err + } + if channelz.IsOn() { + t.IncrMsgSent() + } + if trInfo != nil { + trInfo.tr.LazyLog(&payload{sent: true, msg: reply}, true) + } + // TODO: Should we be logging if writing status failed here, like above? + // Should the logging be in WriteStatus? Should we ignore the WriteStatus + // error or allow the stats handler to see it? + return t.WriteStatus(stream, status.New(codes.OK, "")) +} + +func (s *Server) processStreamingRPC(t transport.ServerTransport, stream *transport.Stream, srv *service, sd *StreamDesc, trInfo *traceInfo) (err error) { + if channelz.IsOn() { + s.incrCallsStarted() + defer func() { + if err != nil && err != io.EOF { + s.incrCallsFailed() + } else { + s.incrCallsSucceeded() + } + }() + } + sh := s.opts.statsHandler + if sh != nil { + beginTime := time.Now() + begin := &stats.Begin{ + BeginTime: beginTime, + } + sh.HandleRPC(stream.Context(), begin) + defer func() { + end := &stats.End{ + BeginTime: beginTime, + EndTime: time.Now(), + } + if err != nil && err != io.EOF { + end.Error = toRPCErr(err) + } + sh.HandleRPC(stream.Context(), end) + }() + } + ctx := NewContextWithServerTransportStream(stream.Context(), stream) + ss := &serverStream{ + ctx: ctx, + t: t, + s: stream, + p: &parser{r: stream}, + codec: s.getCodec(stream.ContentSubtype()), + maxReceiveMessageSize: s.opts.maxReceiveMessageSize, + maxSendMessageSize: s.opts.maxSendMessageSize, + trInfo: trInfo, + statsHandler: sh, + } + + // If dc is set and matches the stream's compression, use it. Otherwise, try + // to find a matching registered compressor for decomp. + if rc := stream.RecvCompress(); s.opts.dc != nil && s.opts.dc.Type() == rc { + ss.dc = s.opts.dc + } else if rc != "" && rc != encoding.Identity { + ss.decomp = encoding.GetCompressor(rc) + if ss.decomp == nil { + st := status.Newf(codes.Unimplemented, "grpc: Decompressor is not installed for grpc-encoding %q", rc) + t.WriteStatus(ss.s, st) + return st.Err() + } + } + + // If cp is set, use it. Otherwise, attempt to compress the response using + // the incoming message compression method. + // + // NOTE: this needs to be ahead of all handling, https://github.com/grpc/grpc-go/issues/686. + if s.opts.cp != nil { + ss.cp = s.opts.cp + stream.SetSendCompress(s.opts.cp.Type()) + } else if rc := stream.RecvCompress(); rc != "" && rc != encoding.Identity { + // Legacy compressor not specified; attempt to respond with same encoding. + ss.comp = encoding.GetCompressor(rc) + if ss.comp != nil { + stream.SetSendCompress(rc) + } + } + + if trInfo != nil { + trInfo.tr.LazyLog(&trInfo.firstLine, false) + defer func() { + ss.mu.Lock() + if err != nil && err != io.EOF { + ss.trInfo.tr.LazyLog(&fmtStringer{"%v", []interface{}{err}}, true) + ss.trInfo.tr.SetError() + } + ss.trInfo.tr.Finish() + ss.trInfo.tr = nil + ss.mu.Unlock() + }() + } + var appErr error + var server interface{} + if srv != nil { + server = srv.server + } + if s.opts.streamInt == nil { + appErr = sd.Handler(server, ss) + } else { + info := &StreamServerInfo{ + FullMethod: stream.Method(), + IsClientStream: sd.ClientStreams, + IsServerStream: sd.ServerStreams, + } + appErr = s.opts.streamInt(server, ss, info, sd.Handler) + } + if appErr != nil { + appStatus, ok := status.FromError(appErr) + if !ok { + switch err := appErr.(type) { + case transport.StreamError: + appStatus = status.New(err.Code, err.Desc) + default: + appStatus = status.New(codes.Unknown, appErr.Error()) + } + appErr = appStatus.Err() + } + if trInfo != nil { + ss.mu.Lock() + ss.trInfo.tr.LazyLog(stringer(appStatus.Message()), true) + ss.trInfo.tr.SetError() + ss.mu.Unlock() + } + t.WriteStatus(ss.s, appStatus) + // TODO: Should we log an error from WriteStatus here and below? + return appErr + } + if trInfo != nil { + ss.mu.Lock() + ss.trInfo.tr.LazyLog(stringer("OK"), false) + ss.mu.Unlock() + } + return t.WriteStatus(ss.s, status.New(codes.OK, "")) +} + +func (s *Server) handleStream(t transport.ServerTransport, stream *transport.Stream, trInfo *traceInfo) { + sm := stream.Method() + if sm != "" && sm[0] == '/' { + sm = sm[1:] + } + pos := strings.LastIndex(sm, "/") + if pos == -1 { + if trInfo != nil { + trInfo.tr.LazyLog(&fmtStringer{"Malformed method name %q", []interface{}{sm}}, true) + trInfo.tr.SetError() + } + errDesc := fmt.Sprintf("malformed method name: %q", stream.Method()) + if err := t.WriteStatus(stream, status.New(codes.ResourceExhausted, errDesc)); err != nil { + if trInfo != nil { + trInfo.tr.LazyLog(&fmtStringer{"%v", []interface{}{err}}, true) + trInfo.tr.SetError() + } + grpclog.Warningf("grpc: Server.handleStream failed to write status: %v", err) + } + if trInfo != nil { + trInfo.tr.Finish() + } + return + } + service := sm[:pos] + method := sm[pos+1:] + srv, ok := s.m[service] + if !ok { + if unknownDesc := s.opts.unknownStreamDesc; unknownDesc != nil { + s.processStreamingRPC(t, stream, nil, unknownDesc, trInfo) + return + } + if trInfo != nil { + trInfo.tr.LazyLog(&fmtStringer{"Unknown service %v", []interface{}{service}}, true) + trInfo.tr.SetError() + } + errDesc := fmt.Sprintf("unknown service %v", service) + if err := t.WriteStatus(stream, status.New(codes.Unimplemented, errDesc)); err != nil { + if trInfo != nil { + trInfo.tr.LazyLog(&fmtStringer{"%v", []interface{}{err}}, true) + trInfo.tr.SetError() + } + grpclog.Warningf("grpc: Server.handleStream failed to write status: %v", err) + } + if trInfo != nil { + trInfo.tr.Finish() + } + return + } + // Unary RPC or Streaming RPC? + if md, ok := srv.md[method]; ok { + s.processUnaryRPC(t, stream, srv, md, trInfo) + return + } + if sd, ok := srv.sd[method]; ok { + s.processStreamingRPC(t, stream, srv, sd, trInfo) + return + } + if trInfo != nil { + trInfo.tr.LazyLog(&fmtStringer{"Unknown method %v", []interface{}{method}}, true) + trInfo.tr.SetError() + } + if unknownDesc := s.opts.unknownStreamDesc; unknownDesc != nil { + s.processStreamingRPC(t, stream, nil, unknownDesc, trInfo) + return + } + errDesc := fmt.Sprintf("unknown method %v", method) + if err := t.WriteStatus(stream, status.New(codes.Unimplemented, errDesc)); err != nil { + if trInfo != nil { + trInfo.tr.LazyLog(&fmtStringer{"%v", []interface{}{err}}, true) + trInfo.tr.SetError() + } + grpclog.Warningf("grpc: Server.handleStream failed to write status: %v", err) + } + if trInfo != nil { + trInfo.tr.Finish() + } +} + +// The key to save ServerTransportStream in the context. +type streamKey struct{} + +// NewContextWithServerTransportStream creates a new context from ctx and +// attaches stream to it. +// +// This API is EXPERIMENTAL. +func NewContextWithServerTransportStream(ctx context.Context, stream ServerTransportStream) context.Context { + return context.WithValue(ctx, streamKey{}, stream) +} + +// ServerTransportStream is a minimal interface that a transport stream must +// implement. This can be used to mock an actual transport stream for tests of +// handler code that use, for example, grpc.SetHeader (which requires some +// stream to be in context). +// +// See also NewContextWithServerTransportStream. +// +// This API is EXPERIMENTAL. +type ServerTransportStream interface { + Method() string + SetHeader(md metadata.MD) error + SendHeader(md metadata.MD) error + SetTrailer(md metadata.MD) error +} + +// ServerTransportStreamFromContext returns the ServerTransportStream saved in +// ctx. Returns nil if the given context has no stream associated with it +// (which implies it is not an RPC invocation context). +// +// This API is EXPERIMENTAL. +func ServerTransportStreamFromContext(ctx context.Context) ServerTransportStream { + s, _ := ctx.Value(streamKey{}).(ServerTransportStream) + return s +} + +// Stop stops the gRPC server. It immediately closes all open +// connections and listeners. +// It cancels all active RPCs on the server side and the corresponding +// pending RPCs on the client side will get notified by connection +// errors. +func (s *Server) Stop() { + s.quitOnce.Do(func() { + close(s.quit) + }) + + defer func() { + s.serveWG.Wait() + s.doneOnce.Do(func() { + close(s.done) + }) + }() + + s.channelzRemoveOnce.Do(func() { + if channelz.IsOn() { + channelz.RemoveEntry(s.channelzID) + } + }) + + s.mu.Lock() + listeners := s.lis + s.lis = nil + st := s.conns + s.conns = nil + // interrupt GracefulStop if Stop and GracefulStop are called concurrently. + s.cv.Broadcast() + s.mu.Unlock() + + for lis := range listeners { + lis.Close() + } + for c := range st { + c.Close() + } + + s.mu.Lock() + if s.events != nil { + s.events.Finish() + s.events = nil + } + s.mu.Unlock() +} + +// GracefulStop stops the gRPC server gracefully. It stops the server from +// accepting new connections and RPCs and blocks until all the pending RPCs are +// finished. +func (s *Server) GracefulStop() { + s.quitOnce.Do(func() { + close(s.quit) + }) + + defer func() { + s.doneOnce.Do(func() { + close(s.done) + }) + }() + + s.channelzRemoveOnce.Do(func() { + if channelz.IsOn() { + channelz.RemoveEntry(s.channelzID) + } + }) + s.mu.Lock() + if s.conns == nil { + s.mu.Unlock() + return + } + + for lis := range s.lis { + lis.Close() + } + s.lis = nil + if !s.drain { + for c := range s.conns { + c.(transport.ServerTransport).Drain() + } + s.drain = true + } + + // Wait for serving threads to be ready to exit. Only then can we be sure no + // new conns will be created. + s.mu.Unlock() + s.serveWG.Wait() + s.mu.Lock() + + for len(s.conns) != 0 { + s.cv.Wait() + } + s.conns = nil + if s.events != nil { + s.events.Finish() + s.events = nil + } + s.mu.Unlock() +} + +func init() { + internal.TestingUseHandlerImpl = func(arg interface{}) { + arg.(*Server).opts.useHandlerImpl = true + } +} + +// contentSubtype must be lowercase +// cannot return nil +func (s *Server) getCodec(contentSubtype string) baseCodec { + if s.opts.codec != nil { + return s.opts.codec + } + if contentSubtype == "" { + return encoding.GetCodec(proto.Name) + } + codec := encoding.GetCodec(contentSubtype) + if codec == nil { + return encoding.GetCodec(proto.Name) + } + return codec +} + +// SetHeader sets the header metadata. +// When called multiple times, all the provided metadata will be merged. +// All the metadata will be sent out when one of the following happens: +// - grpc.SendHeader() is called; +// - The first response is sent out; +// - An RPC status is sent out (error or success). +func SetHeader(ctx context.Context, md metadata.MD) error { + if md.Len() == 0 { + return nil + } + stream := ServerTransportStreamFromContext(ctx) + if stream == nil { + return status.Errorf(codes.Internal, "grpc: failed to fetch the stream from the context %v", ctx) + } + return stream.SetHeader(md) +} + +// SendHeader sends header metadata. It may be called at most once. +// The provided md and headers set by SetHeader() will be sent. +func SendHeader(ctx context.Context, md metadata.MD) error { + stream := ServerTransportStreamFromContext(ctx) + if stream == nil { + return status.Errorf(codes.Internal, "grpc: failed to fetch the stream from the context %v", ctx) + } + if err := stream.SendHeader(md); err != nil { + return toRPCErr(err) + } + return nil +} + +// SetTrailer sets the trailer metadata that will be sent when an RPC returns. +// When called more than once, all the provided metadata will be merged. +func SetTrailer(ctx context.Context, md metadata.MD) error { + if md.Len() == 0 { + return nil + } + stream := ServerTransportStreamFromContext(ctx) + if stream == nil { + return status.Errorf(codes.Internal, "grpc: failed to fetch the stream from the context %v", ctx) + } + return stream.SetTrailer(md) +} + +// Method returns the method string for the server context. The returned +// string is in the format of "/service/method". +func Method(ctx context.Context) (string, bool) { + s := ServerTransportStreamFromContext(ctx) + if s == nil { + return "", false + } + return s.Method(), true +} diff --git a/vendor/google.golang.org/grpc/service_config.go b/vendor/google.golang.org/grpc/service_config.go new file mode 100644 index 00000000000..015631d8d38 --- /dev/null +++ b/vendor/google.golang.org/grpc/service_config.go @@ -0,0 +1,233 @@ +/* + * + * Copyright 2017 gRPC 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 grpc + +import ( + "encoding/json" + "fmt" + "strconv" + "strings" + "time" + + "google.golang.org/grpc/grpclog" +) + +const maxInt = int(^uint(0) >> 1) + +// MethodConfig defines the configuration recommended by the service providers for a +// particular method. +// +// Deprecated: Users should not use this struct. Service config should be received +// through name resolver, as specified here +// https://github.com/grpc/grpc/blob/master/doc/service_config.md +type MethodConfig struct { + // WaitForReady indicates whether RPCs sent to this method should wait until + // the connection is ready by default (!failfast). The value specified via the + // gRPC client API will override the value set here. + WaitForReady *bool + // Timeout is the default timeout for RPCs sent to this method. The actual + // deadline used will be the minimum of the value specified here and the value + // set by the application via the gRPC client API. If either one is not set, + // then the other will be used. If neither is set, then the RPC has no deadline. + Timeout *time.Duration + // MaxReqSize is the maximum allowed payload size for an individual request in a + // stream (client->server) in bytes. The size which is measured is the serialized + // payload after per-message compression (but before stream compression) in bytes. + // The actual value used is the minimum of the value specified here and the value set + // by the application via the gRPC client API. If either one is not set, then the other + // will be used. If neither is set, then the built-in default is used. + MaxReqSize *int + // MaxRespSize is the maximum allowed payload size for an individual response in a + // stream (server->client) in bytes. + MaxRespSize *int +} + +// ServiceConfig is provided by the service provider and contains parameters for how +// clients that connect to the service should behave. +// +// Deprecated: Users should not use this struct. Service config should be received +// through name resolver, as specified here +// https://github.com/grpc/grpc/blob/master/doc/service_config.md +type ServiceConfig struct { + // LB is the load balancer the service providers recommends. The balancer specified + // via grpc.WithBalancer will override this. + LB *string + // Methods contains a map for the methods in this service. + // If there is an exact match for a method (i.e. /service/method) in the map, use the corresponding MethodConfig. + // If there's no exact match, look for the default config for the service (/service/) and use the corresponding MethodConfig if it exists. + // Otherwise, the method has no MethodConfig to use. + Methods map[string]MethodConfig + + stickinessMetadataKey *string +} + +func parseDuration(s *string) (*time.Duration, error) { + if s == nil { + return nil, nil + } + if !strings.HasSuffix(*s, "s") { + return nil, fmt.Errorf("malformed duration %q", *s) + } + ss := strings.SplitN((*s)[:len(*s)-1], ".", 3) + if len(ss) > 2 { + return nil, fmt.Errorf("malformed duration %q", *s) + } + // hasDigits is set if either the whole or fractional part of the number is + // present, since both are optional but one is required. + hasDigits := false + var d time.Duration + if len(ss[0]) > 0 { + i, err := strconv.ParseInt(ss[0], 10, 32) + if err != nil { + return nil, fmt.Errorf("malformed duration %q: %v", *s, err) + } + d = time.Duration(i) * time.Second + hasDigits = true + } + if len(ss) == 2 && len(ss[1]) > 0 { + if len(ss[1]) > 9 { + return nil, fmt.Errorf("malformed duration %q", *s) + } + f, err := strconv.ParseInt(ss[1], 10, 64) + if err != nil { + return nil, fmt.Errorf("malformed duration %q: %v", *s, err) + } + for i := 9; i > len(ss[1]); i-- { + f *= 10 + } + d += time.Duration(f) + hasDigits = true + } + if !hasDigits { + return nil, fmt.Errorf("malformed duration %q", *s) + } + + return &d, nil +} + +type jsonName struct { + Service *string + Method *string +} + +func (j jsonName) generatePath() (string, bool) { + if j.Service == nil { + return "", false + } + res := "/" + *j.Service + "/" + if j.Method != nil { + res += *j.Method + } + return res, true +} + +// TODO(lyuxuan): delete this struct after cleaning up old service config implementation. +type jsonMC struct { + Name *[]jsonName + WaitForReady *bool + Timeout *string + MaxRequestMessageBytes *int64 + MaxResponseMessageBytes *int64 +} + +// TODO(lyuxuan): delete this struct after cleaning up old service config implementation. +type jsonSC struct { + LoadBalancingPolicy *string + StickinessMetadataKey *string + MethodConfig *[]jsonMC +} + +func parseServiceConfig(js string) (ServiceConfig, error) { + var rsc jsonSC + err := json.Unmarshal([]byte(js), &rsc) + if err != nil { + grpclog.Warningf("grpc: parseServiceConfig error unmarshaling %s due to %v", js, err) + return ServiceConfig{}, err + } + sc := ServiceConfig{ + LB: rsc.LoadBalancingPolicy, + Methods: make(map[string]MethodConfig), + + stickinessMetadataKey: rsc.StickinessMetadataKey, + } + if rsc.MethodConfig == nil { + return sc, nil + } + + for _, m := range *rsc.MethodConfig { + if m.Name == nil { + continue + } + d, err := parseDuration(m.Timeout) + if err != nil { + grpclog.Warningf("grpc: parseServiceConfig error unmarshaling %s due to %v", js, err) + return ServiceConfig{}, err + } + + mc := MethodConfig{ + WaitForReady: m.WaitForReady, + Timeout: d, + } + if m.MaxRequestMessageBytes != nil { + if *m.MaxRequestMessageBytes > int64(maxInt) { + mc.MaxReqSize = newInt(maxInt) + } else { + mc.MaxReqSize = newInt(int(*m.MaxRequestMessageBytes)) + } + } + if m.MaxResponseMessageBytes != nil { + if *m.MaxResponseMessageBytes > int64(maxInt) { + mc.MaxRespSize = newInt(maxInt) + } else { + mc.MaxRespSize = newInt(int(*m.MaxResponseMessageBytes)) + } + } + for _, n := range *m.Name { + if path, valid := n.generatePath(); valid { + sc.Methods[path] = mc + } + } + } + + return sc, nil +} + +func min(a, b *int) *int { + if *a < *b { + return a + } + return b +} + +func getMaxSize(mcMax, doptMax *int, defaultVal int) *int { + if mcMax == nil && doptMax == nil { + return &defaultVal + } + if mcMax != nil && doptMax != nil { + return min(mcMax, doptMax) + } + if mcMax != nil { + return mcMax + } + return doptMax +} + +func newInt(b int) *int { + return &b +} diff --git a/vendor/google.golang.org/grpc/stats/handlers.go b/vendor/google.golang.org/grpc/stats/handlers.go new file mode 100644 index 00000000000..05b384c6931 --- /dev/null +++ b/vendor/google.golang.org/grpc/stats/handlers.go @@ -0,0 +1,64 @@ +/* + * + * Copyright 2016 gRPC 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 stats + +import ( + "net" + + "golang.org/x/net/context" +) + +// ConnTagInfo defines the relevant information needed by connection context tagger. +type ConnTagInfo struct { + // RemoteAddr is the remote address of the corresponding connection. + RemoteAddr net.Addr + // LocalAddr is the local address of the corresponding connection. + LocalAddr net.Addr +} + +// RPCTagInfo defines the relevant information needed by RPC context tagger. +type RPCTagInfo struct { + // FullMethodName is the RPC method in the format of /package.service/method. + FullMethodName string + // FailFast indicates if this RPC is failfast. + // This field is only valid on client side, it's always false on server side. + FailFast bool +} + +// Handler defines the interface for the related stats handling (e.g., RPCs, connections). +type Handler interface { + // TagRPC can attach some information to the given context. + // The context used for the rest lifetime of the RPC will be derived from + // the returned context. + TagRPC(context.Context, *RPCTagInfo) context.Context + // HandleRPC processes the RPC stats. + HandleRPC(context.Context, RPCStats) + + // TagConn can attach some information to the given context. + // The returned context will be used for stats handling. + // For conn stats handling, the context used in HandleConn for this + // connection will be derived from the context returned. + // For RPC stats handling, + // - On server side, the context used in HandleRPC for all RPCs on this + // connection will be derived from the context returned. + // - On client side, the context is not derived from the context returned. + TagConn(context.Context, *ConnTagInfo) context.Context + // HandleConn processes the Conn stats. + HandleConn(context.Context, ConnStats) +} diff --git a/vendor/google.golang.org/grpc/stats/stats.go b/vendor/google.golang.org/grpc/stats/stats.go new file mode 100644 index 00000000000..3f13190a0ac --- /dev/null +++ b/vendor/google.golang.org/grpc/stats/stats.go @@ -0,0 +1,296 @@ +/* + * + * Copyright 2016 gRPC 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. + * + */ + +//go:generate protoc --go_out=plugins=grpc:. grpc_testing/test.proto + +// Package stats is for collecting and reporting various network and RPC stats. +// This package is for monitoring purpose only. All fields are read-only. +// All APIs are experimental. +package stats // import "google.golang.org/grpc/stats" + +import ( + "net" + "time" + + "golang.org/x/net/context" +) + +// RPCStats contains stats information about RPCs. +type RPCStats interface { + isRPCStats() + // IsClient returns true if this RPCStats is from client side. + IsClient() bool +} + +// Begin contains stats when an RPC begins. +// FailFast is only valid if this Begin is from client side. +type Begin struct { + // Client is true if this Begin is from client side. + Client bool + // BeginTime is the time when the RPC begins. + BeginTime time.Time + // FailFast indicates if this RPC is failfast. + FailFast bool +} + +// IsClient indicates if the stats information is from client side. +func (s *Begin) IsClient() bool { return s.Client } + +func (s *Begin) isRPCStats() {} + +// InPayload contains the information for an incoming payload. +type InPayload struct { + // Client is true if this InPayload is from client side. + Client bool + // Payload is the payload with original type. + Payload interface{} + // Data is the serialized message payload. + Data []byte + // Length is the length of uncompressed data. + Length int + // WireLength is the length of data on wire (compressed, signed, encrypted). + WireLength int + // RecvTime is the time when the payload is received. + RecvTime time.Time +} + +// IsClient indicates if the stats information is from client side. +func (s *InPayload) IsClient() bool { return s.Client } + +func (s *InPayload) isRPCStats() {} + +// InHeader contains stats when a header is received. +type InHeader struct { + // Client is true if this InHeader is from client side. + Client bool + // WireLength is the wire length of header. + WireLength int + + // The following fields are valid only if Client is false. + // FullMethod is the full RPC method string, i.e., /package.service/method. + FullMethod string + // RemoteAddr is the remote address of the corresponding connection. + RemoteAddr net.Addr + // LocalAddr is the local address of the corresponding connection. + LocalAddr net.Addr + // Compression is the compression algorithm used for the RPC. + Compression string +} + +// IsClient indicates if the stats information is from client side. +func (s *InHeader) IsClient() bool { return s.Client } + +func (s *InHeader) isRPCStats() {} + +// InTrailer contains stats when a trailer is received. +type InTrailer struct { + // Client is true if this InTrailer is from client side. + Client bool + // WireLength is the wire length of trailer. + WireLength int +} + +// IsClient indicates if the stats information is from client side. +func (s *InTrailer) IsClient() bool { return s.Client } + +func (s *InTrailer) isRPCStats() {} + +// OutPayload contains the information for an outgoing payload. +type OutPayload struct { + // Client is true if this OutPayload is from client side. + Client bool + // Payload is the payload with original type. + Payload interface{} + // Data is the serialized message payload. + Data []byte + // Length is the length of uncompressed data. + Length int + // WireLength is the length of data on wire (compressed, signed, encrypted). + WireLength int + // SentTime is the time when the payload is sent. + SentTime time.Time +} + +// IsClient indicates if this stats information is from client side. +func (s *OutPayload) IsClient() bool { return s.Client } + +func (s *OutPayload) isRPCStats() {} + +// OutHeader contains stats when a header is sent. +type OutHeader struct { + // Client is true if this OutHeader is from client side. + Client bool + + // The following fields are valid only if Client is true. + // FullMethod is the full RPC method string, i.e., /package.service/method. + FullMethod string + // RemoteAddr is the remote address of the corresponding connection. + RemoteAddr net.Addr + // LocalAddr is the local address of the corresponding connection. + LocalAddr net.Addr + // Compression is the compression algorithm used for the RPC. + Compression string +} + +// IsClient indicates if this stats information is from client side. +func (s *OutHeader) IsClient() bool { return s.Client } + +func (s *OutHeader) isRPCStats() {} + +// OutTrailer contains stats when a trailer is sent. +type OutTrailer struct { + // Client is true if this OutTrailer is from client side. + Client bool + // WireLength is the wire length of trailer. + WireLength int +} + +// IsClient indicates if this stats information is from client side. +func (s *OutTrailer) IsClient() bool { return s.Client } + +func (s *OutTrailer) isRPCStats() {} + +// End contains stats when an RPC ends. +type End struct { + // Client is true if this End is from client side. + Client bool + // BeginTime is the time when the RPC began. + BeginTime time.Time + // EndTime is the time when the RPC ends. + EndTime time.Time + // Error is the error the RPC ended with. It is an error generated from + // status.Status and can be converted back to status.Status using + // status.FromError if non-nil. + Error error +} + +// IsClient indicates if this is from client side. +func (s *End) IsClient() bool { return s.Client } + +func (s *End) isRPCStats() {} + +// ConnStats contains stats information about connections. +type ConnStats interface { + isConnStats() + // IsClient returns true if this ConnStats is from client side. + IsClient() bool +} + +// ConnBegin contains the stats of a connection when it is established. +type ConnBegin struct { + // Client is true if this ConnBegin is from client side. + Client bool +} + +// IsClient indicates if this is from client side. +func (s *ConnBegin) IsClient() bool { return s.Client } + +func (s *ConnBegin) isConnStats() {} + +// ConnEnd contains the stats of a connection when it ends. +type ConnEnd struct { + // Client is true if this ConnEnd is from client side. + Client bool +} + +// IsClient indicates if this is from client side. +func (s *ConnEnd) IsClient() bool { return s.Client } + +func (s *ConnEnd) isConnStats() {} + +type incomingTagsKey struct{} +type outgoingTagsKey struct{} + +// SetTags attaches stats tagging data to the context, which will be sent in +// the outgoing RPC with the header grpc-tags-bin. Subsequent calls to +// SetTags will overwrite the values from earlier calls. +// +// NOTE: this is provided only for backward compatibility with existing clients +// and will likely be removed in an upcoming release. New uses should transmit +// this type of data using metadata with a different, non-reserved (i.e. does +// not begin with "grpc-") header name. +func SetTags(ctx context.Context, b []byte) context.Context { + return context.WithValue(ctx, outgoingTagsKey{}, b) +} + +// Tags returns the tags from the context for the inbound RPC. +// +// NOTE: this is provided only for backward compatibility with existing clients +// and will likely be removed in an upcoming release. New uses should transmit +// this type of data using metadata with a different, non-reserved (i.e. does +// not begin with "grpc-") header name. +func Tags(ctx context.Context) []byte { + b, _ := ctx.Value(incomingTagsKey{}).([]byte) + return b +} + +// SetIncomingTags attaches stats tagging data to the context, to be read by +// the application (not sent in outgoing RPCs). +// +// This is intended for gRPC-internal use ONLY. +func SetIncomingTags(ctx context.Context, b []byte) context.Context { + return context.WithValue(ctx, incomingTagsKey{}, b) +} + +// OutgoingTags returns the tags from the context for the outbound RPC. +// +// This is intended for gRPC-internal use ONLY. +func OutgoingTags(ctx context.Context) []byte { + b, _ := ctx.Value(outgoingTagsKey{}).([]byte) + return b +} + +type incomingTraceKey struct{} +type outgoingTraceKey struct{} + +// SetTrace attaches stats tagging data to the context, which will be sent in +// the outgoing RPC with the header grpc-trace-bin. Subsequent calls to +// SetTrace will overwrite the values from earlier calls. +// +// NOTE: this is provided only for backward compatibility with existing clients +// and will likely be removed in an upcoming release. New uses should transmit +// this type of data using metadata with a different, non-reserved (i.e. does +// not begin with "grpc-") header name. +func SetTrace(ctx context.Context, b []byte) context.Context { + return context.WithValue(ctx, outgoingTraceKey{}, b) +} + +// Trace returns the trace from the context for the inbound RPC. +// +// NOTE: this is provided only for backward compatibility with existing clients +// and will likely be removed in an upcoming release. New uses should transmit +// this type of data using metadata with a different, non-reserved (i.e. does +// not begin with "grpc-") header name. +func Trace(ctx context.Context) []byte { + b, _ := ctx.Value(incomingTraceKey{}).([]byte) + return b +} + +// SetIncomingTrace attaches stats tagging data to the context, to be read by +// the application (not sent in outgoing RPCs). It is intended for +// gRPC-internal use. +func SetIncomingTrace(ctx context.Context, b []byte) context.Context { + return context.WithValue(ctx, incomingTraceKey{}, b) +} + +// OutgoingTrace returns the trace from the context for the outbound RPC. It is +// intended for gRPC-internal use. +func OutgoingTrace(ctx context.Context) []byte { + b, _ := ctx.Value(outgoingTraceKey{}).([]byte) + return b +} diff --git a/vendor/google.golang.org/grpc/status/status.go b/vendor/google.golang.org/grpc/status/status.go new file mode 100644 index 00000000000..9c61b094508 --- /dev/null +++ b/vendor/google.golang.org/grpc/status/status.go @@ -0,0 +1,189 @@ +/* + * + * Copyright 2017 gRPC 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 status implements errors returned by gRPC. These errors are +// serialized and transmitted on the wire between server and client, and allow +// for additional data to be transmitted via the Details field in the status +// proto. gRPC service handlers should return an error created by this +// package, and gRPC clients should expect a corresponding error to be +// returned from the RPC call. +// +// This package upholds the invariants that a non-nil error may not +// contain an OK code, and an OK code must result in a nil error. +package status + +import ( + "errors" + "fmt" + + "github.com/golang/protobuf/proto" + "github.com/golang/protobuf/ptypes" + spb "google.golang.org/genproto/googleapis/rpc/status" + "google.golang.org/grpc/codes" +) + +// statusError is an alias of a status proto. It implements error and Status, +// and a nil statusError should never be returned by this package. +type statusError spb.Status + +func (se *statusError) Error() string { + p := (*spb.Status)(se) + return fmt.Sprintf("rpc error: code = %s desc = %s", codes.Code(p.GetCode()), p.GetMessage()) +} + +func (se *statusError) GRPCStatus() *Status { + return &Status{s: (*spb.Status)(se)} +} + +// Status represents an RPC status code, message, and details. It is immutable +// and should be created with New, Newf, or FromProto. +type Status struct { + s *spb.Status +} + +// Code returns the status code contained in s. +func (s *Status) Code() codes.Code { + if s == nil || s.s == nil { + return codes.OK + } + return codes.Code(s.s.Code) +} + +// Message returns the message contained in s. +func (s *Status) Message() string { + if s == nil || s.s == nil { + return "" + } + return s.s.Message +} + +// Proto returns s's status as an spb.Status proto message. +func (s *Status) Proto() *spb.Status { + if s == nil { + return nil + } + return proto.Clone(s.s).(*spb.Status) +} + +// Err returns an immutable error representing s; returns nil if s.Code() is +// OK. +func (s *Status) Err() error { + if s.Code() == codes.OK { + return nil + } + return (*statusError)(s.s) +} + +// New returns a Status representing c and msg. +func New(c codes.Code, msg string) *Status { + return &Status{s: &spb.Status{Code: int32(c), Message: msg}} +} + +// Newf returns New(c, fmt.Sprintf(format, a...)). +func Newf(c codes.Code, format string, a ...interface{}) *Status { + return New(c, fmt.Sprintf(format, a...)) +} + +// Error returns an error representing c and msg. If c is OK, returns nil. +func Error(c codes.Code, msg string) error { + return New(c, msg).Err() +} + +// Errorf returns Error(c, fmt.Sprintf(format, a...)). +func Errorf(c codes.Code, format string, a ...interface{}) error { + return Error(c, fmt.Sprintf(format, a...)) +} + +// ErrorProto returns an error representing s. If s.Code is OK, returns nil. +func ErrorProto(s *spb.Status) error { + return FromProto(s).Err() +} + +// FromProto returns a Status representing s. +func FromProto(s *spb.Status) *Status { + return &Status{s: proto.Clone(s).(*spb.Status)} +} + +// FromError returns a Status representing err if it was produced from this +// package or has a method `GRPCStatus() *Status`. Otherwise, ok is false and a +// Status is returned with codes.Unknown and the original error message. +func FromError(err error) (s *Status, ok bool) { + if err == nil { + return &Status{s: &spb.Status{Code: int32(codes.OK)}}, true + } + if se, ok := err.(interface{ GRPCStatus() *Status }); ok { + return se.GRPCStatus(), true + } + return New(codes.Unknown, err.Error()), false +} + +// Convert is a convenience function which removes the need to handle the +// boolean return value from FromError. +func Convert(err error) *Status { + s, _ := FromError(err) + return s +} + +// WithDetails returns a new status with the provided details messages appended to the status. +// If any errors are encountered, it returns nil and the first error encountered. +func (s *Status) WithDetails(details ...proto.Message) (*Status, error) { + if s.Code() == codes.OK { + return nil, errors.New("no error details for status with code OK") + } + // s.Code() != OK implies that s.Proto() != nil. + p := s.Proto() + for _, detail := range details { + any, err := ptypes.MarshalAny(detail) + if err != nil { + return nil, err + } + p.Details = append(p.Details, any) + } + return &Status{s: p}, nil +} + +// Details returns a slice of details messages attached to the status. +// If a detail cannot be decoded, the error is returned in place of the detail. +func (s *Status) Details() []interface{} { + if s == nil || s.s == nil { + return nil + } + details := make([]interface{}, 0, len(s.s.Details)) + for _, any := range s.s.Details { + detail := &ptypes.DynamicAny{} + if err := ptypes.UnmarshalAny(any, detail); err != nil { + details = append(details, err) + continue + } + details = append(details, detail.Message) + } + return details +} + +// Code returns the Code of the error if it is a Status error, codes.OK if err +// is nil, or codes.Unknown otherwise. +func Code(err error) codes.Code { + // Don't use FromError to avoid allocation of OK status. + if err == nil { + return codes.OK + } + if se, ok := err.(interface{ GRPCStatus() *Status }); ok { + return se.GRPCStatus().Code() + } + return codes.Unknown +} diff --git a/vendor/google.golang.org/grpc/stream.go b/vendor/google.golang.org/grpc/stream.go new file mode 100644 index 00000000000..82921a15a3a --- /dev/null +++ b/vendor/google.golang.org/grpc/stream.go @@ -0,0 +1,765 @@ +/* + * + * Copyright 2014 gRPC 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 grpc + +import ( + "errors" + "io" + "sync" + "time" + + "golang.org/x/net/context" + "golang.org/x/net/trace" + "google.golang.org/grpc/balancer" + "google.golang.org/grpc/channelz" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/encoding" + "google.golang.org/grpc/metadata" + "google.golang.org/grpc/stats" + "google.golang.org/grpc/status" + "google.golang.org/grpc/transport" +) + +// StreamHandler defines the handler called by gRPC server to complete the +// execution of a streaming RPC. If a StreamHandler returns an error, it +// should be produced by the status package, or else gRPC will use +// codes.Unknown as the status code and err.Error() as the status message +// of the RPC. +type StreamHandler func(srv interface{}, stream ServerStream) error + +// StreamDesc represents a streaming RPC service's method specification. +type StreamDesc struct { + StreamName string + Handler StreamHandler + + // At least one of these is true. + ServerStreams bool + ClientStreams bool +} + +// Stream defines the common interface a client or server stream has to satisfy. +// +// All errors returned from Stream are compatible with the status package. +type Stream interface { + // Context returns the context for this stream. + Context() context.Context + // SendMsg blocks until it sends m, the stream is done or the stream + // breaks. + // On error, it aborts the stream and returns an RPC status on client + // side. On server side, it simply returns the error to the caller. + // SendMsg is called by generated code. Also Users can call SendMsg + // directly when it is really needed in their use cases. + // It's safe to have a goroutine calling SendMsg and another goroutine calling + // recvMsg on the same stream at the same time. + // But it is not safe to call SendMsg on the same stream in different goroutines. + SendMsg(m interface{}) error + // RecvMsg blocks until it receives a message or the stream is + // done. On client side, it returns io.EOF when the stream is done. On + // any other error, it aborts the stream and returns an RPC status. On + // server side, it simply returns the error to the caller. + // It's safe to have a goroutine calling SendMsg and another goroutine calling + // recvMsg on the same stream at the same time. + // But it is not safe to call RecvMsg on the same stream in different goroutines. + RecvMsg(m interface{}) error +} + +// ClientStream defines the interface a client stream has to satisfy. +type ClientStream interface { + // Header returns the header metadata received from the server if there + // is any. It blocks if the metadata is not ready to read. + Header() (metadata.MD, error) + // Trailer returns the trailer metadata from the server, if there is any. + // It must only be called after stream.CloseAndRecv has returned, or + // stream.Recv has returned a non-nil error (including io.EOF). + Trailer() metadata.MD + // CloseSend closes the send direction of the stream. It closes the stream + // when non-nil error is met. + CloseSend() error + // Stream.SendMsg() may return a non-nil error when something wrong happens sending + // the request. The returned error indicates the status of this sending, not the final + // status of the RPC. + // + // Always call Stream.RecvMsg() to drain the stream and get the final + // status, otherwise there could be leaked resources. + Stream +} + +// NewStream creates a new Stream for the client side. This is typically +// called by generated code. +func (cc *ClientConn) NewStream(ctx context.Context, desc *StreamDesc, method string, opts ...CallOption) (ClientStream, error) { + // allow interceptor to see all applicable call options, which means those + // configured as defaults from dial option as well as per-call options + opts = combine(cc.dopts.callOptions, opts) + + if cc.dopts.streamInt != nil { + return cc.dopts.streamInt(ctx, desc, cc, method, newClientStream, opts...) + } + return newClientStream(ctx, desc, cc, method, opts...) +} + +// NewClientStream creates a new Stream for the client side. This is typically +// called by generated code. +// +// DEPRECATED: Use ClientConn.NewStream instead. +func NewClientStream(ctx context.Context, desc *StreamDesc, cc *ClientConn, method string, opts ...CallOption) (ClientStream, error) { + return cc.NewStream(ctx, desc, method, opts...) +} + +func newClientStream(ctx context.Context, desc *StreamDesc, cc *ClientConn, method string, opts ...CallOption) (_ ClientStream, err error) { + if channelz.IsOn() { + cc.incrCallsStarted() + defer func() { + if err != nil { + cc.incrCallsFailed() + } + }() + } + c := defaultCallInfo() + mc := cc.GetMethodConfig(method) + if mc.WaitForReady != nil { + c.failFast = !*mc.WaitForReady + } + + // Possible context leak: + // The cancel function for the child context we create will only be called + // when RecvMsg returns a non-nil error, if the ClientConn is closed, or if + // an error is generated by SendMsg. + // https://github.com/grpc/grpc-go/issues/1818. + var cancel context.CancelFunc + if mc.Timeout != nil && *mc.Timeout >= 0 { + ctx, cancel = context.WithTimeout(ctx, *mc.Timeout) + } else { + ctx, cancel = context.WithCancel(ctx) + } + defer func() { + if err != nil { + cancel() + } + }() + + for _, o := range opts { + if err := o.before(c); err != nil { + return nil, toRPCErr(err) + } + } + c.maxSendMessageSize = getMaxSize(mc.MaxReqSize, c.maxSendMessageSize, defaultClientMaxSendMessageSize) + c.maxReceiveMessageSize = getMaxSize(mc.MaxRespSize, c.maxReceiveMessageSize, defaultClientMaxReceiveMessageSize) + if err := setCallInfoCodec(c); err != nil { + return nil, err + } + + callHdr := &transport.CallHdr{ + Host: cc.authority, + Method: method, + // If it's not client streaming, we should already have the request to be sent, + // so we don't flush the header. + // If it's client streaming, the user may never send a request or send it any + // time soon, so we ask the transport to flush the header. + Flush: desc.ClientStreams, + ContentSubtype: c.contentSubtype, + } + + // Set our outgoing compression according to the UseCompressor CallOption, if + // set. In that case, also find the compressor from the encoding package. + // Otherwise, use the compressor configured by the WithCompressor DialOption, + // if set. + var cp Compressor + var comp encoding.Compressor + if ct := c.compressorType; ct != "" { + callHdr.SendCompress = ct + if ct != encoding.Identity { + comp = encoding.GetCompressor(ct) + if comp == nil { + return nil, status.Errorf(codes.Internal, "grpc: Compressor is not installed for requested grpc-encoding %q", ct) + } + } + } else if cc.dopts.cp != nil { + callHdr.SendCompress = cc.dopts.cp.Type() + cp = cc.dopts.cp + } + if c.creds != nil { + callHdr.Creds = c.creds + } + var trInfo traceInfo + if EnableTracing { + trInfo.tr = trace.New("grpc.Sent."+methodFamily(method), method) + trInfo.firstLine.client = true + if deadline, ok := ctx.Deadline(); ok { + trInfo.firstLine.deadline = deadline.Sub(time.Now()) + } + trInfo.tr.LazyLog(&trInfo.firstLine, false) + ctx = trace.NewContext(ctx, trInfo.tr) + defer func() { + if err != nil { + // Need to call tr.finish() if error is returned. + // Because tr will not be returned to caller. + trInfo.tr.LazyPrintf("RPC: [%v]", err) + trInfo.tr.SetError() + trInfo.tr.Finish() + } + }() + } + ctx = newContextWithRPCInfo(ctx, c.failFast) + sh := cc.dopts.copts.StatsHandler + var beginTime time.Time + if sh != nil { + ctx = sh.TagRPC(ctx, &stats.RPCTagInfo{FullMethodName: method, FailFast: c.failFast}) + beginTime = time.Now() + begin := &stats.Begin{ + Client: true, + BeginTime: beginTime, + FailFast: c.failFast, + } + sh.HandleRPC(ctx, begin) + defer func() { + if err != nil { + // Only handle end stats if err != nil. + end := &stats.End{ + Client: true, + Error: err, + BeginTime: beginTime, + EndTime: time.Now(), + } + sh.HandleRPC(ctx, end) + } + }() + } + + var ( + t transport.ClientTransport + s *transport.Stream + done func(balancer.DoneInfo) + ) + for { + // Check to make sure the context has expired. This will prevent us from + // looping forever if an error occurs for wait-for-ready RPCs where no data + // is sent on the wire. + select { + case <-ctx.Done(): + return nil, toRPCErr(ctx.Err()) + default: + } + + t, done, err = cc.getTransport(ctx, c.failFast) + if err != nil { + return nil, err + } + + s, err = t.NewStream(ctx, callHdr) + if err != nil { + if done != nil { + done(balancer.DoneInfo{Err: err}) + done = nil + } + // In the event of any error from NewStream, we never attempted to write + // anything to the wire, so we can retry indefinitely for non-fail-fast + // RPCs. + if !c.failFast { + continue + } + return nil, toRPCErr(err) + } + break + } + + cs := &clientStream{ + opts: opts, + c: c, + cc: cc, + desc: desc, + codec: c.codec, + cp: cp, + comp: comp, + cancel: cancel, + attempt: &csAttempt{ + t: t, + s: s, + p: &parser{r: s}, + done: done, + dc: cc.dopts.dc, + ctx: ctx, + trInfo: trInfo, + statsHandler: sh, + beginTime: beginTime, + }, + } + cs.c.stream = cs + cs.attempt.cs = cs + if desc != unaryStreamDesc { + // Listen on cc and stream contexts to cleanup when the user closes the + // ClientConn or cancels the stream context. In all other cases, an error + // should already be injected into the recv buffer by the transport, which + // the client will eventually receive, and then we will cancel the stream's + // context in clientStream.finish. + go func() { + select { + case <-cc.ctx.Done(): + cs.finish(ErrClientConnClosing) + case <-ctx.Done(): + cs.finish(toRPCErr(ctx.Err())) + } + }() + } + return cs, nil +} + +// clientStream implements a client side Stream. +type clientStream struct { + opts []CallOption + c *callInfo + cc *ClientConn + desc *StreamDesc + + codec baseCodec + cp Compressor + comp encoding.Compressor + + cancel context.CancelFunc // cancels all attempts + + sentLast bool // sent an end stream + + mu sync.Mutex // guards finished + finished bool // TODO: replace with atomic cmpxchg or sync.Once? + + attempt *csAttempt // the active client stream attempt + // TODO(hedging): hedging will have multiple attempts simultaneously. +} + +// csAttempt implements a single transport stream attempt within a +// clientStream. +type csAttempt struct { + cs *clientStream + t transport.ClientTransport + s *transport.Stream + p *parser + done func(balancer.DoneInfo) + + dc Decompressor + decomp encoding.Compressor + decompSet bool + + ctx context.Context // the application's context, wrapped by stats/tracing + + mu sync.Mutex // guards trInfo.tr + // trInfo.tr is set when created (if EnableTracing is true), + // and cleared when the finish method is called. + trInfo traceInfo + + statsHandler stats.Handler + beginTime time.Time +} + +func (cs *clientStream) Context() context.Context { + // TODO(retry): commit the current attempt (the context has peer-aware data). + return cs.attempt.context() +} + +func (cs *clientStream) Header() (metadata.MD, error) { + m, err := cs.attempt.header() + if err != nil { + // TODO(retry): maybe retry on error or commit attempt on success. + err = toRPCErr(err) + cs.finish(err) + } + return m, err +} + +func (cs *clientStream) Trailer() metadata.MD { + // TODO(retry): on error, maybe retry (trailers-only). + return cs.attempt.trailer() +} + +func (cs *clientStream) SendMsg(m interface{}) (err error) { + // TODO(retry): buffer message for replaying if not committed. + return cs.attempt.sendMsg(m) +} + +func (cs *clientStream) RecvMsg(m interface{}) (err error) { + // TODO(retry): maybe retry on error or commit attempt on success. + return cs.attempt.recvMsg(m) +} + +func (cs *clientStream) CloseSend() error { + cs.attempt.closeSend() + return nil +} + +func (cs *clientStream) finish(err error) { + if err == io.EOF { + // Ending a stream with EOF indicates a success. + err = nil + } + cs.mu.Lock() + if cs.finished { + cs.mu.Unlock() + return + } + cs.finished = true + cs.mu.Unlock() + if channelz.IsOn() { + if err != nil { + cs.cc.incrCallsFailed() + } else { + cs.cc.incrCallsSucceeded() + } + } + // TODO(retry): commit current attempt if necessary. + cs.attempt.finish(err) + for _, o := range cs.opts { + o.after(cs.c) + } + cs.cancel() +} + +func (a *csAttempt) context() context.Context { + return a.s.Context() +} + +func (a *csAttempt) header() (metadata.MD, error) { + return a.s.Header() +} + +func (a *csAttempt) trailer() metadata.MD { + return a.s.Trailer() +} + +func (a *csAttempt) sendMsg(m interface{}) (err error) { + // TODO Investigate how to signal the stats handling party. + // generate error stats if err != nil && err != io.EOF? + cs := a.cs + defer func() { + // For non-client-streaming RPCs, we return nil instead of EOF on success + // because the generated code requires it. finish is not called; RecvMsg() + // will call it with the stream's status independently. + if err == io.EOF && !cs.desc.ClientStreams { + err = nil + } + if err != nil && err != io.EOF { + // Call finish on the client stream for errors generated by this SendMsg + // call, as these indicate problems created by this client. (Transport + // errors are converted to an io.EOF error below; the real error will be + // returned from RecvMsg eventually in that case, or be retried.) + cs.finish(err) + } + }() + // TODO: Check cs.sentLast and error if we already ended the stream. + if EnableTracing { + a.mu.Lock() + if a.trInfo.tr != nil { + a.trInfo.tr.LazyLog(&payload{sent: true, msg: m}, true) + } + a.mu.Unlock() + } + var outPayload *stats.OutPayload + if a.statsHandler != nil { + outPayload = &stats.OutPayload{ + Client: true, + } + } + hdr, data, err := encode(cs.codec, m, cs.cp, outPayload, cs.comp) + if err != nil { + return err + } + if len(data) > *cs.c.maxSendMessageSize { + return status.Errorf(codes.ResourceExhausted, "trying to send message larger than max (%d vs. %d)", len(data), *cs.c.maxSendMessageSize) + } + if !cs.desc.ClientStreams { + cs.sentLast = true + } + err = a.t.Write(a.s, hdr, data, &transport.Options{Last: !cs.desc.ClientStreams}) + if err == nil { + if outPayload != nil { + outPayload.SentTime = time.Now() + a.statsHandler.HandleRPC(a.ctx, outPayload) + } + if channelz.IsOn() { + a.t.IncrMsgSent() + } + return nil + } + return io.EOF +} + +func (a *csAttempt) recvMsg(m interface{}) (err error) { + cs := a.cs + defer func() { + if err != nil || !cs.desc.ServerStreams { + // err != nil or non-server-streaming indicates end of stream. + cs.finish(err) + } + }() + var inPayload *stats.InPayload + if a.statsHandler != nil { + inPayload = &stats.InPayload{ + Client: true, + } + } + if !a.decompSet { + // Block until we receive headers containing received message encoding. + if ct := a.s.RecvCompress(); ct != "" && ct != encoding.Identity { + if a.dc == nil || a.dc.Type() != ct { + // No configured decompressor, or it does not match the incoming + // message encoding; attempt to find a registered compressor that does. + a.dc = nil + a.decomp = encoding.GetCompressor(ct) + } + } else { + // No compression is used; disable our decompressor. + a.dc = nil + } + // Only initialize this state once per stream. + a.decompSet = true + } + err = recv(a.p, cs.codec, a.s, a.dc, m, *cs.c.maxReceiveMessageSize, inPayload, a.decomp) + if err != nil { + if err == io.EOF { + if statusErr := a.s.Status().Err(); statusErr != nil { + return statusErr + } + return io.EOF // indicates successful end of stream. + } + return toRPCErr(err) + } + if EnableTracing { + a.mu.Lock() + if a.trInfo.tr != nil { + a.trInfo.tr.LazyLog(&payload{sent: false, msg: m}, true) + } + a.mu.Unlock() + } + if inPayload != nil { + a.statsHandler.HandleRPC(a.ctx, inPayload) + } + if channelz.IsOn() { + a.t.IncrMsgRecv() + } + if cs.desc.ServerStreams { + // Subsequent messages should be received by subsequent RecvMsg calls. + return nil + } + + // Special handling for non-server-stream rpcs. + // This recv expects EOF or errors, so we don't collect inPayload. + err = recv(a.p, cs.codec, a.s, a.dc, m, *cs.c.maxReceiveMessageSize, nil, a.decomp) + if err == nil { + return toRPCErr(errors.New("grpc: client streaming protocol violation: get , want ")) + } + if err == io.EOF { + return a.s.Status().Err() // non-server streaming Recv returns nil on success + } + return toRPCErr(err) +} + +func (a *csAttempt) closeSend() { + cs := a.cs + if cs.sentLast { + return + } + cs.sentLast = true + cs.attempt.t.Write(cs.attempt.s, nil, nil, &transport.Options{Last: true}) + // We ignore errors from Write. Any error it would return would also be + // returned by a subsequent RecvMsg call, and the user is supposed to always + // finish the stream by calling RecvMsg until it returns err != nil. +} + +func (a *csAttempt) finish(err error) { + a.mu.Lock() + a.t.CloseStream(a.s, err) + + if a.done != nil { + a.done(balancer.DoneInfo{ + Err: err, + BytesSent: true, + BytesReceived: a.s.BytesReceived(), + }) + } + if a.statsHandler != nil { + end := &stats.End{ + Client: true, + BeginTime: a.beginTime, + EndTime: time.Now(), + Error: err, + } + a.statsHandler.HandleRPC(a.ctx, end) + } + if a.trInfo.tr != nil { + if err == nil { + a.trInfo.tr.LazyPrintf("RPC: [OK]") + } else { + a.trInfo.tr.LazyPrintf("RPC: [%v]", err) + a.trInfo.tr.SetError() + } + a.trInfo.tr.Finish() + a.trInfo.tr = nil + } + a.mu.Unlock() +} + +// ServerStream defines the interface a server stream has to satisfy. +type ServerStream interface { + // SetHeader sets the header metadata. It may be called multiple times. + // When call multiple times, all the provided metadata will be merged. + // All the metadata will be sent out when one of the following happens: + // - ServerStream.SendHeader() is called; + // - The first response is sent out; + // - An RPC status is sent out (error or success). + SetHeader(metadata.MD) error + // SendHeader sends the header metadata. + // The provided md and headers set by SetHeader() will be sent. + // It fails if called multiple times. + SendHeader(metadata.MD) error + // SetTrailer sets the trailer metadata which will be sent with the RPC status. + // When called more than once, all the provided metadata will be merged. + SetTrailer(metadata.MD) + Stream +} + +// serverStream implements a server side Stream. +type serverStream struct { + ctx context.Context + t transport.ServerTransport + s *transport.Stream + p *parser + codec baseCodec + + cp Compressor + dc Decompressor + comp encoding.Compressor + decomp encoding.Compressor + + maxReceiveMessageSize int + maxSendMessageSize int + trInfo *traceInfo + + statsHandler stats.Handler + + mu sync.Mutex // protects trInfo.tr after the service handler runs. +} + +func (ss *serverStream) Context() context.Context { + return ss.ctx +} + +func (ss *serverStream) SetHeader(md metadata.MD) error { + if md.Len() == 0 { + return nil + } + return ss.s.SetHeader(md) +} + +func (ss *serverStream) SendHeader(md metadata.MD) error { + return ss.t.WriteHeader(ss.s, md) +} + +func (ss *serverStream) SetTrailer(md metadata.MD) { + if md.Len() == 0 { + return + } + ss.s.SetTrailer(md) +} + +func (ss *serverStream) SendMsg(m interface{}) (err error) { + defer func() { + if ss.trInfo != nil { + ss.mu.Lock() + if ss.trInfo.tr != nil { + if err == nil { + ss.trInfo.tr.LazyLog(&payload{sent: true, msg: m}, true) + } else { + ss.trInfo.tr.LazyLog(&fmtStringer{"%v", []interface{}{err}}, true) + ss.trInfo.tr.SetError() + } + } + ss.mu.Unlock() + } + if err != nil && err != io.EOF { + st, _ := status.FromError(toRPCErr(err)) + ss.t.WriteStatus(ss.s, st) + } + if channelz.IsOn() && err == nil { + ss.t.IncrMsgSent() + } + }() + var outPayload *stats.OutPayload + if ss.statsHandler != nil { + outPayload = &stats.OutPayload{} + } + hdr, data, err := encode(ss.codec, m, ss.cp, outPayload, ss.comp) + if err != nil { + return err + } + if len(data) > ss.maxSendMessageSize { + return status.Errorf(codes.ResourceExhausted, "trying to send message larger than max (%d vs. %d)", len(data), ss.maxSendMessageSize) + } + if err := ss.t.Write(ss.s, hdr, data, &transport.Options{Last: false}); err != nil { + return toRPCErr(err) + } + if outPayload != nil { + outPayload.SentTime = time.Now() + ss.statsHandler.HandleRPC(ss.s.Context(), outPayload) + } + return nil +} + +func (ss *serverStream) RecvMsg(m interface{}) (err error) { + defer func() { + if ss.trInfo != nil { + ss.mu.Lock() + if ss.trInfo.tr != nil { + if err == nil { + ss.trInfo.tr.LazyLog(&payload{sent: false, msg: m}, true) + } else if err != io.EOF { + ss.trInfo.tr.LazyLog(&fmtStringer{"%v", []interface{}{err}}, true) + ss.trInfo.tr.SetError() + } + } + ss.mu.Unlock() + } + if err != nil && err != io.EOF { + st, _ := status.FromError(toRPCErr(err)) + ss.t.WriteStatus(ss.s, st) + } + if channelz.IsOn() && err == nil { + ss.t.IncrMsgRecv() + } + }() + var inPayload *stats.InPayload + if ss.statsHandler != nil { + inPayload = &stats.InPayload{} + } + if err := recv(ss.p, ss.codec, ss.s, ss.dc, m, ss.maxReceiveMessageSize, inPayload, ss.decomp); err != nil { + if err == io.EOF { + return err + } + if err == io.ErrUnexpectedEOF { + err = status.Errorf(codes.Internal, io.ErrUnexpectedEOF.Error()) + } + return toRPCErr(err) + } + if inPayload != nil { + ss.statsHandler.HandleRPC(ss.s.Context(), inPayload) + } + return nil +} + +// MethodFromServerStream returns the method string for the input stream. +// The returned string is in the format of "/service/method". +func MethodFromServerStream(stream ServerStream) (string, bool) { + return Method(stream.Context()) +} diff --git a/vendor/google.golang.org/grpc/tap/tap.go b/vendor/google.golang.org/grpc/tap/tap.go new file mode 100644 index 00000000000..22b8fb50dea --- /dev/null +++ b/vendor/google.golang.org/grpc/tap/tap.go @@ -0,0 +1,51 @@ +/* + * + * Copyright 2016 gRPC 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 tap defines the function handles which are executed on the transport +// layer of gRPC-Go and related information. Everything here is EXPERIMENTAL. +package tap + +import ( + "golang.org/x/net/context" +) + +// Info defines the relevant information needed by the handles. +type Info struct { + // FullMethodName is the string of grpc method (in the format of + // /package.service/method). + FullMethodName string + // TODO: More to be added. +} + +// ServerInHandle defines the function which runs before a new stream is created +// on the server side. If it returns a non-nil error, the stream will not be +// created and a RST_STREAM will be sent back to the client with REFUSED_STREAM. +// The client will receive an RPC error "code = Unavailable, desc = stream +// terminated by RST_STREAM with error code: REFUSED_STREAM". +// +// It's intended to be used in situations where you don't want to waste the +// resources to accept the new stream (e.g. rate-limiting). And the content of +// the error will be ignored and won't be sent back to the client. For other +// general usages, please use interceptors. +// +// Note that it is executed in the per-connection I/O goroutine(s) instead of +// per-RPC goroutine. Therefore, users should NOT have any +// blocking/time-consuming work in this handle. Otherwise all the RPCs would +// slow down. Also, for the same reason, this handle won't be called +// concurrently by gRPC. +type ServerInHandle func(ctx context.Context, info *Info) (context.Context, error) diff --git a/vendor/google.golang.org/grpc/trace.go b/vendor/google.golang.org/grpc/trace.go new file mode 100644 index 00000000000..c1c96dedcb7 --- /dev/null +++ b/vendor/google.golang.org/grpc/trace.go @@ -0,0 +1,113 @@ +/* + * + * Copyright 2015 gRPC 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 grpc + +import ( + "bytes" + "fmt" + "io" + "net" + "strings" + "time" + + "golang.org/x/net/trace" +) + +// EnableTracing controls whether to trace RPCs using the golang.org/x/net/trace package. +// This should only be set before any RPCs are sent or received by this program. +var EnableTracing bool + +// methodFamily returns the trace family for the given method. +// It turns "/pkg.Service/GetFoo" into "pkg.Service". +func methodFamily(m string) string { + m = strings.TrimPrefix(m, "/") // remove leading slash + if i := strings.Index(m, "/"); i >= 0 { + m = m[:i] // remove everything from second slash + } + if i := strings.LastIndex(m, "."); i >= 0 { + m = m[i+1:] // cut down to last dotted component + } + return m +} + +// traceInfo contains tracing information for an RPC. +type traceInfo struct { + tr trace.Trace + firstLine firstLine +} + +// firstLine is the first line of an RPC trace. +type firstLine struct { + client bool // whether this is a client (outgoing) RPC + remoteAddr net.Addr + deadline time.Duration // may be zero +} + +func (f *firstLine) String() string { + var line bytes.Buffer + io.WriteString(&line, "RPC: ") + if f.client { + io.WriteString(&line, "to") + } else { + io.WriteString(&line, "from") + } + fmt.Fprintf(&line, " %v deadline:", f.remoteAddr) + if f.deadline != 0 { + fmt.Fprint(&line, f.deadline) + } else { + io.WriteString(&line, "none") + } + return line.String() +} + +const truncateSize = 100 + +func truncate(x string, l int) string { + if l > len(x) { + return x + } + return x[:l] +} + +// payload represents an RPC request or response payload. +type payload struct { + sent bool // whether this is an outgoing payload + msg interface{} // e.g. a proto.Message + // TODO(dsymonds): add stringifying info to codec, and limit how much we hold here? +} + +func (p payload) String() string { + if p.sent { + return truncate(fmt.Sprintf("sent: %v", p.msg), truncateSize) + } + return truncate(fmt.Sprintf("recv: %v", p.msg), truncateSize) +} + +type fmtStringer struct { + format string + a []interface{} +} + +func (f *fmtStringer) String() string { + return fmt.Sprintf(f.format, f.a...) +} + +type stringer string + +func (s stringer) String() string { return string(s) } diff --git a/vendor/google.golang.org/grpc/transport/bdp_estimator.go b/vendor/google.golang.org/grpc/transport/bdp_estimator.go new file mode 100644 index 00000000000..63cd2627c87 --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/bdp_estimator.go @@ -0,0 +1,140 @@ +/* + * + * Copyright 2017 gRPC 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 transport + +import ( + "sync" + "time" +) + +const ( + // bdpLimit is the maximum value the flow control windows + // will be increased to. + bdpLimit = (1 << 20) * 4 + // alpha is a constant factor used to keep a moving average + // of RTTs. + alpha = 0.9 + // If the current bdp sample is greater than or equal to + // our beta * our estimated bdp and the current bandwidth + // sample is the maximum bandwidth observed so far, we + // increase our bbp estimate by a factor of gamma. + beta = 0.66 + // To put our bdp to be smaller than or equal to twice the real BDP, + // we should multiply our current sample with 4/3, however to round things out + // we use 2 as the multiplication factor. + gamma = 2 +) + +// Adding arbitrary data to ping so that its ack can be identified. +// Easter-egg: what does the ping message say? +var bdpPing = &ping{data: [8]byte{2, 4, 16, 16, 9, 14, 7, 7}} + +type bdpEstimator struct { + // sentAt is the time when the ping was sent. + sentAt time.Time + + mu sync.Mutex + // bdp is the current bdp estimate. + bdp uint32 + // sample is the number of bytes received in one measurement cycle. + sample uint32 + // bwMax is the maximum bandwidth noted so far (bytes/sec). + bwMax float64 + // bool to keep track of the beginning of a new measurement cycle. + isSent bool + // Callback to update the window sizes. + updateFlowControl func(n uint32) + // sampleCount is the number of samples taken so far. + sampleCount uint64 + // round trip time (seconds) + rtt float64 +} + +// timesnap registers the time bdp ping was sent out so that +// network rtt can be calculated when its ack is received. +// It is called (by controller) when the bdpPing is +// being written on the wire. +func (b *bdpEstimator) timesnap(d [8]byte) { + if bdpPing.data != d { + return + } + b.sentAt = time.Now() +} + +// add adds bytes to the current sample for calculating bdp. +// It returns true only if a ping must be sent. This can be used +// by the caller (handleData) to make decision about batching +// a window update with it. +func (b *bdpEstimator) add(n uint32) bool { + b.mu.Lock() + defer b.mu.Unlock() + if b.bdp == bdpLimit { + return false + } + if !b.isSent { + b.isSent = true + b.sample = n + b.sentAt = time.Time{} + b.sampleCount++ + return true + } + b.sample += n + return false +} + +// calculate is called when an ack for a bdp ping is received. +// Here we calculate the current bdp and bandwidth sample and +// decide if the flow control windows should go up. +func (b *bdpEstimator) calculate(d [8]byte) { + // Check if the ping acked for was the bdp ping. + if bdpPing.data != d { + return + } + b.mu.Lock() + rttSample := time.Since(b.sentAt).Seconds() + if b.sampleCount < 10 { + // Bootstrap rtt with an average of first 10 rtt samples. + b.rtt += (rttSample - b.rtt) / float64(b.sampleCount) + } else { + // Heed to the recent past more. + b.rtt += (rttSample - b.rtt) * float64(alpha) + } + b.isSent = false + // The number of bytes accumulated so far in the sample is smaller + // than or equal to 1.5 times the real BDP on a saturated connection. + bwCurrent := float64(b.sample) / (b.rtt * float64(1.5)) + if bwCurrent > b.bwMax { + b.bwMax = bwCurrent + } + // If the current sample (which is smaller than or equal to the 1.5 times the real BDP) is + // greater than or equal to 2/3rd our perceived bdp AND this is the maximum bandwidth seen so far, we + // should update our perception of the network BDP. + if float64(b.sample) >= beta*float64(b.bdp) && bwCurrent == b.bwMax && b.bdp != bdpLimit { + sampleFloat := float64(b.sample) + b.bdp = uint32(gamma * sampleFloat) + if b.bdp > bdpLimit { + b.bdp = bdpLimit + } + bdp := b.bdp + b.mu.Unlock() + b.updateFlowControl(bdp) + return + } + b.mu.Unlock() +} diff --git a/vendor/google.golang.org/grpc/transport/controlbuf.go b/vendor/google.golang.org/grpc/transport/controlbuf.go new file mode 100644 index 00000000000..e147cd51bf1 --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/controlbuf.go @@ -0,0 +1,769 @@ +/* + * + * Copyright 2014 gRPC 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 transport + +import ( + "bytes" + "fmt" + "runtime" + "sync" + + "golang.org/x/net/http2" + "golang.org/x/net/http2/hpack" +) + +type itemNode struct { + it interface{} + next *itemNode +} + +type itemList struct { + head *itemNode + tail *itemNode +} + +func (il *itemList) enqueue(i interface{}) { + n := &itemNode{it: i} + if il.tail == nil { + il.head, il.tail = n, n + return + } + il.tail.next = n + il.tail = n +} + +// peek returns the first item in the list without removing it from the +// list. +func (il *itemList) peek() interface{} { + return il.head.it +} + +func (il *itemList) dequeue() interface{} { + if il.head == nil { + return nil + } + i := il.head.it + il.head = il.head.next + if il.head == nil { + il.tail = nil + } + return i +} + +func (il *itemList) dequeueAll() *itemNode { + h := il.head + il.head, il.tail = nil, nil + return h +} + +func (il *itemList) isEmpty() bool { + return il.head == nil +} + +// The following defines various control items which could flow through +// the control buffer of transport. They represent different aspects of +// control tasks, e.g., flow control, settings, streaming resetting, etc. + +type headerFrame struct { + streamID uint32 + hf []hpack.HeaderField + endStream bool // Valid on server side. + initStream func(uint32) (bool, error) // Used only on the client side. + onWrite func() + wq *writeQuota // write quota for the stream created. + cleanup *cleanupStream // Valid on the server side. + onOrphaned func(error) // Valid on client-side +} + +type cleanupStream struct { + streamID uint32 + idPtr *uint32 + rst bool + rstCode http2.ErrCode + onWrite func() +} + +type dataFrame struct { + streamID uint32 + endStream bool + h []byte + d []byte + // onEachWrite is called every time + // a part of d is written out. + onEachWrite func() +} + +type incomingWindowUpdate struct { + streamID uint32 + increment uint32 +} + +type outgoingWindowUpdate struct { + streamID uint32 + increment uint32 +} + +type incomingSettings struct { + ss []http2.Setting +} + +type outgoingSettings struct { + ss []http2.Setting +} + +type settingsAck struct { +} + +type incomingGoAway struct { +} + +type goAway struct { + code http2.ErrCode + debugData []byte + headsUp bool + closeConn bool +} + +type ping struct { + ack bool + data [8]byte +} + +type outFlowControlSizeRequest struct { + resp chan uint32 +} + +type outStreamState int + +const ( + active outStreamState = iota + empty + waitingOnStreamQuota +) + +type outStream struct { + id uint32 + state outStreamState + itl *itemList + bytesOutStanding int + wq *writeQuota + + next *outStream + prev *outStream +} + +func (s *outStream) deleteSelf() { + if s.prev != nil { + s.prev.next = s.next + } + if s.next != nil { + s.next.prev = s.prev + } + s.next, s.prev = nil, nil +} + +type outStreamList struct { + // Following are sentinel objects that mark the + // beginning and end of the list. They do not + // contain any item lists. All valid objects are + // inserted in between them. + // This is needed so that an outStream object can + // deleteSelf() in O(1) time without knowing which + // list it belongs to. + head *outStream + tail *outStream +} + +func newOutStreamList() *outStreamList { + head, tail := new(outStream), new(outStream) + head.next = tail + tail.prev = head + return &outStreamList{ + head: head, + tail: tail, + } +} + +func (l *outStreamList) enqueue(s *outStream) { + e := l.tail.prev + e.next = s + s.prev = e + s.next = l.tail + l.tail.prev = s +} + +// remove from the beginning of the list. +func (l *outStreamList) dequeue() *outStream { + b := l.head.next + if b == l.tail { + return nil + } + b.deleteSelf() + return b +} + +type controlBuffer struct { + ch chan struct{} + done <-chan struct{} + mu sync.Mutex + consumerWaiting bool + list *itemList + err error +} + +func newControlBuffer(done <-chan struct{}) *controlBuffer { + return &controlBuffer{ + ch: make(chan struct{}, 1), + list: &itemList{}, + done: done, + } +} + +func (c *controlBuffer) put(it interface{}) error { + _, err := c.executeAndPut(nil, it) + return err +} + +func (c *controlBuffer) executeAndPut(f func(it interface{}) bool, it interface{}) (bool, error) { + var wakeUp bool + c.mu.Lock() + if c.err != nil { + c.mu.Unlock() + return false, c.err + } + if f != nil { + if !f(it) { // f wasn't successful + c.mu.Unlock() + return false, nil + } + } + if c.consumerWaiting { + wakeUp = true + c.consumerWaiting = false + } + c.list.enqueue(it) + c.mu.Unlock() + if wakeUp { + select { + case c.ch <- struct{}{}: + default: + } + } + return true, nil +} + +func (c *controlBuffer) get(block bool) (interface{}, error) { + for { + c.mu.Lock() + if c.err != nil { + c.mu.Unlock() + return nil, c.err + } + if !c.list.isEmpty() { + h := c.list.dequeue() + c.mu.Unlock() + return h, nil + } + if !block { + c.mu.Unlock() + return nil, nil + } + c.consumerWaiting = true + c.mu.Unlock() + select { + case <-c.ch: + case <-c.done: + c.finish() + return nil, ErrConnClosing + } + } +} + +func (c *controlBuffer) finish() { + c.mu.Lock() + if c.err != nil { + c.mu.Unlock() + return + } + c.err = ErrConnClosing + // There may be headers for streams in the control buffer. + // These streams need to be cleaned out since the transport + // is still not aware of these yet. + for head := c.list.dequeueAll(); head != nil; head = head.next { + hdr, ok := head.it.(*headerFrame) + if !ok { + continue + } + if hdr.onOrphaned != nil { // It will be nil on the server-side. + hdr.onOrphaned(ErrConnClosing) + } + } + c.mu.Unlock() +} + +type side int + +const ( + clientSide side = iota + serverSide +) + +type loopyWriter struct { + side side + cbuf *controlBuffer + sendQuota uint32 + oiws uint32 // outbound initial window size. + estdStreams map[uint32]*outStream // Established streams. + activeStreams *outStreamList // Streams that are sending data. + framer *framer + hBuf *bytes.Buffer // The buffer for HPACK encoding. + hEnc *hpack.Encoder // HPACK encoder. + bdpEst *bdpEstimator + draining bool + + // Side-specific handlers + ssGoAwayHandler func(*goAway) (bool, error) +} + +func newLoopyWriter(s side, fr *framer, cbuf *controlBuffer, bdpEst *bdpEstimator) *loopyWriter { + var buf bytes.Buffer + l := &loopyWriter{ + side: s, + cbuf: cbuf, + sendQuota: defaultWindowSize, + oiws: defaultWindowSize, + estdStreams: make(map[uint32]*outStream), + activeStreams: newOutStreamList(), + framer: fr, + hBuf: &buf, + hEnc: hpack.NewEncoder(&buf), + bdpEst: bdpEst, + } + return l +} + +const minBatchSize = 1000 + +// run should be run in a separate goroutine. +func (l *loopyWriter) run() { + var ( + it interface{} + err error + isEmpty bool + ) + defer func() { + errorf("transport: loopyWriter.run returning. Err: %v", err) + }() + for { + it, err = l.cbuf.get(true) + if err != nil { + return + } + if err = l.handle(it); err != nil { + return + } + if _, err = l.processData(); err != nil { + return + } + gosched := true + hasdata: + for { + it, err = l.cbuf.get(false) + if err != nil { + return + } + if it != nil { + if err = l.handle(it); err != nil { + return + } + if _, err = l.processData(); err != nil { + return + } + continue hasdata + } + if isEmpty, err = l.processData(); err != nil { + return + } + if !isEmpty { + continue hasdata + } + if gosched { + gosched = false + if l.framer.writer.offset < minBatchSize { + runtime.Gosched() + continue hasdata + } + } + l.framer.writer.Flush() + break hasdata + + } + } +} + +func (l *loopyWriter) outgoingWindowUpdateHandler(w *outgoingWindowUpdate) error { + return l.framer.fr.WriteWindowUpdate(w.streamID, w.increment) +} + +func (l *loopyWriter) incomingWindowUpdateHandler(w *incomingWindowUpdate) error { + // Otherwise update the quota. + if w.streamID == 0 { + l.sendQuota += w.increment + return nil + } + // Find the stream and update it. + if str, ok := l.estdStreams[w.streamID]; ok { + str.bytesOutStanding -= int(w.increment) + if strQuota := int(l.oiws) - str.bytesOutStanding; strQuota > 0 && str.state == waitingOnStreamQuota { + str.state = active + l.activeStreams.enqueue(str) + return nil + } + } + return nil +} + +func (l *loopyWriter) outgoingSettingsHandler(s *outgoingSettings) error { + return l.framer.fr.WriteSettings(s.ss...) +} + +func (l *loopyWriter) incomingSettingsHandler(s *incomingSettings) error { + if err := l.applySettings(s.ss); err != nil { + return err + } + return l.framer.fr.WriteSettingsAck() +} + +func (l *loopyWriter) headerHandler(h *headerFrame) error { + if l.side == serverSide { + if h.endStream { // Case 1.A: Server wants to close stream. + // Make sure it's not a trailers only response. + if str, ok := l.estdStreams[h.streamID]; ok { + if str.state != empty { // either active or waiting on stream quota. + // add it str's list of items. + str.itl.enqueue(h) + return nil + } + } + if err := l.writeHeader(h.streamID, h.endStream, h.hf, h.onWrite); err != nil { + return err + } + return l.cleanupStreamHandler(h.cleanup) + } + // Case 1.B: Server is responding back with headers. + str := &outStream{ + state: empty, + itl: &itemList{}, + wq: h.wq, + } + l.estdStreams[h.streamID] = str + return l.writeHeader(h.streamID, h.endStream, h.hf, h.onWrite) + } + // Case 2: Client wants to originate stream. + str := &outStream{ + id: h.streamID, + state: empty, + itl: &itemList{}, + wq: h.wq, + } + str.itl.enqueue(h) + return l.originateStream(str) +} + +func (l *loopyWriter) originateStream(str *outStream) error { + hdr := str.itl.dequeue().(*headerFrame) + sendPing, err := hdr.initStream(str.id) + if err != nil { + if err == ErrConnClosing { + return err + } + // Other errors(errStreamDrain) need not close transport. + return nil + } + if err = l.writeHeader(str.id, hdr.endStream, hdr.hf, hdr.onWrite); err != nil { + return err + } + l.estdStreams[str.id] = str + if sendPing { + return l.pingHandler(&ping{data: [8]byte{}}) + } + return nil +} + +func (l *loopyWriter) writeHeader(streamID uint32, endStream bool, hf []hpack.HeaderField, onWrite func()) error { + if onWrite != nil { + onWrite() + } + l.hBuf.Reset() + for _, f := range hf { + if err := l.hEnc.WriteField(f); err != nil { + warningf("transport: loopyWriter.writeHeader encountered error while encoding headers:", err) + } + } + var ( + err error + endHeaders, first bool + ) + first = true + for !endHeaders { + size := l.hBuf.Len() + if size > http2MaxFrameLen { + size = http2MaxFrameLen + } else { + endHeaders = true + } + if first { + first = false + err = l.framer.fr.WriteHeaders(http2.HeadersFrameParam{ + StreamID: streamID, + BlockFragment: l.hBuf.Next(size), + EndStream: endStream, + EndHeaders: endHeaders, + }) + } else { + err = l.framer.fr.WriteContinuation( + streamID, + endHeaders, + l.hBuf.Next(size), + ) + } + if err != nil { + return err + } + } + return nil +} + +func (l *loopyWriter) preprocessData(df *dataFrame) error { + str, ok := l.estdStreams[df.streamID] + if !ok { + return nil + } + // If we got data for a stream it means that + // stream was originated and the headers were sent out. + str.itl.enqueue(df) + if str.state == empty { + str.state = active + l.activeStreams.enqueue(str) + } + return nil +} + +func (l *loopyWriter) pingHandler(p *ping) error { + if !p.ack { + l.bdpEst.timesnap(p.data) + } + return l.framer.fr.WritePing(p.ack, p.data) + +} + +func (l *loopyWriter) outFlowControlSizeRequestHandler(o *outFlowControlSizeRequest) error { + o.resp <- l.sendQuota + return nil +} + +func (l *loopyWriter) cleanupStreamHandler(c *cleanupStream) error { + c.onWrite() + if str, ok := l.estdStreams[c.streamID]; ok { + // On the server side it could be a trailers-only response or + // a RST_STREAM before stream initialization thus the stream might + // not be established yet. + delete(l.estdStreams, c.streamID) + str.deleteSelf() + } + if c.rst { // If RST_STREAM needs to be sent. + if err := l.framer.fr.WriteRSTStream(c.streamID, c.rstCode); err != nil { + return err + } + } + if l.side == clientSide && l.draining && len(l.estdStreams) == 0 { + return ErrConnClosing + } + return nil +} + +func (l *loopyWriter) incomingGoAwayHandler(*incomingGoAway) error { + if l.side == clientSide { + l.draining = true + if len(l.estdStreams) == 0 { + return ErrConnClosing + } + } + return nil +} + +func (l *loopyWriter) goAwayHandler(g *goAway) error { + // Handling of outgoing GoAway is very specific to side. + if l.ssGoAwayHandler != nil { + draining, err := l.ssGoAwayHandler(g) + if err != nil { + return err + } + l.draining = draining + } + return nil +} + +func (l *loopyWriter) handle(i interface{}) error { + switch i := i.(type) { + case *incomingWindowUpdate: + return l.incomingWindowUpdateHandler(i) + case *outgoingWindowUpdate: + return l.outgoingWindowUpdateHandler(i) + case *incomingSettings: + return l.incomingSettingsHandler(i) + case *outgoingSettings: + return l.outgoingSettingsHandler(i) + case *headerFrame: + return l.headerHandler(i) + case *cleanupStream: + return l.cleanupStreamHandler(i) + case *incomingGoAway: + return l.incomingGoAwayHandler(i) + case *dataFrame: + return l.preprocessData(i) + case *ping: + return l.pingHandler(i) + case *goAway: + return l.goAwayHandler(i) + case *outFlowControlSizeRequest: + return l.outFlowControlSizeRequestHandler(i) + default: + return fmt.Errorf("transport: unknown control message type %T", i) + } +} + +func (l *loopyWriter) applySettings(ss []http2.Setting) error { + for _, s := range ss { + switch s.ID { + case http2.SettingInitialWindowSize: + o := l.oiws + l.oiws = s.Val + if o < l.oiws { + // If the new limit is greater make all depleted streams active. + for _, stream := range l.estdStreams { + if stream.state == waitingOnStreamQuota { + stream.state = active + l.activeStreams.enqueue(stream) + } + } + } + } + } + return nil +} + +func (l *loopyWriter) processData() (bool, error) { + if l.sendQuota == 0 { + return true, nil + } + str := l.activeStreams.dequeue() + if str == nil { + return true, nil + } + dataItem := str.itl.peek().(*dataFrame) + if len(dataItem.h) == 0 && len(dataItem.d) == 0 { + // Client sends out empty data frame with endStream = true + if err := l.framer.fr.WriteData(dataItem.streamID, dataItem.endStream, nil); err != nil { + return false, err + } + str.itl.dequeue() + if str.itl.isEmpty() { + str.state = empty + } else if trailer, ok := str.itl.peek().(*headerFrame); ok { // the next item is trailers. + if err := l.writeHeader(trailer.streamID, trailer.endStream, trailer.hf, trailer.onWrite); err != nil { + return false, err + } + if err := l.cleanupStreamHandler(trailer.cleanup); err != nil { + return false, nil + } + } else { + l.activeStreams.enqueue(str) + } + return false, nil + } + var ( + idx int + buf []byte + ) + if len(dataItem.h) != 0 { // data header has not been written out yet. + buf = dataItem.h + } else { + idx = 1 + buf = dataItem.d + } + size := http2MaxFrameLen + if len(buf) < size { + size = len(buf) + } + if strQuota := int(l.oiws) - str.bytesOutStanding; strQuota <= 0 { + str.state = waitingOnStreamQuota + return false, nil + } else if strQuota < size { + size = strQuota + } + + if l.sendQuota < uint32(size) { + size = int(l.sendQuota) + } + // Now that outgoing flow controls are checked we can replenish str's write quota + str.wq.replenish(size) + var endStream bool + // This last data message on this stream and all + // of it can be written in this go. + if dataItem.endStream && size == len(buf) { + // buf contains either data or it contains header but data is empty. + if idx == 1 || len(dataItem.d) == 0 { + endStream = true + } + } + if dataItem.onEachWrite != nil { + dataItem.onEachWrite() + } + if err := l.framer.fr.WriteData(dataItem.streamID, endStream, buf[:size]); err != nil { + return false, err + } + buf = buf[size:] + str.bytesOutStanding += size + l.sendQuota -= uint32(size) + if idx == 0 { + dataItem.h = buf + } else { + dataItem.d = buf + } + + if len(dataItem.h) == 0 && len(dataItem.d) == 0 { // All the data from that message was written out. + str.itl.dequeue() + } + if str.itl.isEmpty() { + str.state = empty + } else if trailer, ok := str.itl.peek().(*headerFrame); ok { // The next item is trailers. + if err := l.writeHeader(trailer.streamID, trailer.endStream, trailer.hf, trailer.onWrite); err != nil { + return false, err + } + if err := l.cleanupStreamHandler(trailer.cleanup); err != nil { + return false, err + } + } else if int(l.oiws)-str.bytesOutStanding <= 0 { // Ran out of stream quota. + str.state = waitingOnStreamQuota + } else { // Otherwise add it back to the list of active streams. + l.activeStreams.enqueue(str) + } + return false, nil +} diff --git a/vendor/google.golang.org/grpc/transport/flowcontrol.go b/vendor/google.golang.org/grpc/transport/flowcontrol.go new file mode 100644 index 00000000000..378f5c4502c --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/flowcontrol.go @@ -0,0 +1,236 @@ +/* + * + * Copyright 2014 gRPC 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 transport + +import ( + "fmt" + "math" + "sync" + "sync/atomic" + "time" +) + +const ( + // The default value of flow control window size in HTTP2 spec. + defaultWindowSize = 65535 + // The initial window size for flow control. + initialWindowSize = defaultWindowSize // for an RPC + infinity = time.Duration(math.MaxInt64) + defaultClientKeepaliveTime = infinity + defaultClientKeepaliveTimeout = 20 * time.Second + defaultMaxStreamsClient = 100 + defaultMaxConnectionIdle = infinity + defaultMaxConnectionAge = infinity + defaultMaxConnectionAgeGrace = infinity + defaultServerKeepaliveTime = 2 * time.Hour + defaultServerKeepaliveTimeout = 20 * time.Second + defaultKeepalivePolicyMinTime = 5 * time.Minute + // max window limit set by HTTP2 Specs. + maxWindowSize = math.MaxInt32 + // defaultWriteQuota is the default value for number of data + // bytes that each stream can schedule before some of it being + // flushed out. + defaultWriteQuota = 64 * 1024 +) + +// writeQuota is a soft limit on the amount of data a stream can +// schedule before some of it is written out. +type writeQuota struct { + quota int32 + // get waits on read from when quota goes less than or equal to zero. + // replenish writes on it when quota goes positive again. + ch chan struct{} + // done is triggered in error case. + done <-chan struct{} +} + +func newWriteQuota(sz int32, done <-chan struct{}) *writeQuota { + return &writeQuota{ + quota: sz, + ch: make(chan struct{}, 1), + done: done, + } +} + +func (w *writeQuota) get(sz int32) error { + for { + if atomic.LoadInt32(&w.quota) > 0 { + atomic.AddInt32(&w.quota, -sz) + return nil + } + select { + case <-w.ch: + continue + case <-w.done: + return errStreamDone + } + } +} + +func (w *writeQuota) replenish(n int) { + sz := int32(n) + a := atomic.AddInt32(&w.quota, sz) + b := a - sz + if b <= 0 && a > 0 { + select { + case w.ch <- struct{}{}: + default: + } + } +} + +type trInFlow struct { + limit uint32 + unacked uint32 + effectiveWindowSize uint32 +} + +func (f *trInFlow) newLimit(n uint32) uint32 { + d := n - f.limit + f.limit = n + f.updateEffectiveWindowSize() + return d +} + +func (f *trInFlow) onData(n uint32) uint32 { + f.unacked += n + if f.unacked >= f.limit/4 { + w := f.unacked + f.unacked = 0 + f.updateEffectiveWindowSize() + return w + } + f.updateEffectiveWindowSize() + return 0 +} + +func (f *trInFlow) reset() uint32 { + w := f.unacked + f.unacked = 0 + f.updateEffectiveWindowSize() + return w +} + +func (f *trInFlow) updateEffectiveWindowSize() { + atomic.StoreUint32(&f.effectiveWindowSize, f.limit-f.unacked) +} + +func (f *trInFlow) getSize() uint32 { + return atomic.LoadUint32(&f.effectiveWindowSize) +} + +// TODO(mmukhi): Simplify this code. +// inFlow deals with inbound flow control +type inFlow struct { + mu sync.Mutex + // The inbound flow control limit for pending data. + limit uint32 + // pendingData is the overall data which have been received but not been + // consumed by applications. + pendingData uint32 + // The amount of data the application has consumed but grpc has not sent + // window update for them. Used to reduce window update frequency. + pendingUpdate uint32 + // delta is the extra window update given by receiver when an application + // is reading data bigger in size than the inFlow limit. + delta uint32 +} + +// newLimit updates the inflow window to a new value n. +// It assumes that n is always greater than the old limit. +func (f *inFlow) newLimit(n uint32) uint32 { + f.mu.Lock() + d := n - f.limit + f.limit = n + f.mu.Unlock() + return d +} + +func (f *inFlow) maybeAdjust(n uint32) uint32 { + if n > uint32(math.MaxInt32) { + n = uint32(math.MaxInt32) + } + f.mu.Lock() + // estSenderQuota is the receiver's view of the maximum number of bytes the sender + // can send without a window update. + estSenderQuota := int32(f.limit - (f.pendingData + f.pendingUpdate)) + // estUntransmittedData is the maximum number of bytes the sends might not have put + // on the wire yet. A value of 0 or less means that we have already received all or + // more bytes than the application is requesting to read. + estUntransmittedData := int32(n - f.pendingData) // Casting into int32 since it could be negative. + // This implies that unless we send a window update, the sender won't be able to send all the bytes + // for this message. Therefore we must send an update over the limit since there's an active read + // request from the application. + if estUntransmittedData > estSenderQuota { + // Sender's window shouldn't go more than 2^31 - 1 as specified in the HTTP spec. + if f.limit+n > maxWindowSize { + f.delta = maxWindowSize - f.limit + } else { + // Send a window update for the whole message and not just the difference between + // estUntransmittedData and estSenderQuota. This will be helpful in case the message + // is padded; We will fallback on the current available window(at least a 1/4th of the limit). + f.delta = n + } + f.mu.Unlock() + return f.delta + } + f.mu.Unlock() + return 0 +} + +// onData is invoked when some data frame is received. It updates pendingData. +func (f *inFlow) onData(n uint32) error { + f.mu.Lock() + f.pendingData += n + if f.pendingData+f.pendingUpdate > f.limit+f.delta { + limit := f.limit + rcvd := f.pendingData + f.pendingUpdate + f.mu.Unlock() + return fmt.Errorf("received %d-bytes data exceeding the limit %d bytes", rcvd, limit) + } + f.mu.Unlock() + return nil +} + +// onRead is invoked when the application reads the data. It returns the window size +// to be sent to the peer. +func (f *inFlow) onRead(n uint32) uint32 { + f.mu.Lock() + if f.pendingData == 0 { + f.mu.Unlock() + return 0 + } + f.pendingData -= n + if n > f.delta { + n -= f.delta + f.delta = 0 + } else { + f.delta -= n + n = 0 + } + f.pendingUpdate += n + if f.pendingUpdate >= f.limit/4 { + wu := f.pendingUpdate + f.pendingUpdate = 0 + f.mu.Unlock() + return wu + } + f.mu.Unlock() + return 0 +} diff --git a/vendor/google.golang.org/grpc/transport/go16.go b/vendor/google.golang.org/grpc/transport/go16.go new file mode 100644 index 00000000000..5babcf9b877 --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/go16.go @@ -0,0 +1,51 @@ +// +build go1.6,!go1.7 + +/* + * + * Copyright 2016 gRPC 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 transport + +import ( + "net" + "net/http" + + "google.golang.org/grpc/codes" + + "golang.org/x/net/context" +) + +// dialContext connects to the address on the named network. +func dialContext(ctx context.Context, network, address string) (net.Conn, error) { + return (&net.Dialer{Cancel: ctx.Done()}).Dial(network, address) +} + +// ContextErr converts the error from context package into a StreamError. +func ContextErr(err error) StreamError { + switch err { + case context.DeadlineExceeded: + return streamErrorf(codes.DeadlineExceeded, "%v", err) + case context.Canceled: + return streamErrorf(codes.Canceled, "%v", err) + } + return streamErrorf(codes.Internal, "Unexpected error from context packet: %v", err) +} + +// contextFromRequest returns a background context. +func contextFromRequest(r *http.Request) context.Context { + return context.Background() +} diff --git a/vendor/google.golang.org/grpc/transport/go17.go b/vendor/google.golang.org/grpc/transport/go17.go new file mode 100644 index 00000000000..b7fa6bdb9ca --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/go17.go @@ -0,0 +1,52 @@ +// +build go1.7 + +/* + * + * Copyright 2016 gRPC 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 transport + +import ( + "context" + "net" + "net/http" + + "google.golang.org/grpc/codes" + + netctx "golang.org/x/net/context" +) + +// dialContext connects to the address on the named network. +func dialContext(ctx context.Context, network, address string) (net.Conn, error) { + return (&net.Dialer{}).DialContext(ctx, network, address) +} + +// ContextErr converts the error from context package into a StreamError. +func ContextErr(err error) StreamError { + switch err { + case context.DeadlineExceeded, netctx.DeadlineExceeded: + return streamErrorf(codes.DeadlineExceeded, "%v", err) + case context.Canceled, netctx.Canceled: + return streamErrorf(codes.Canceled, "%v", err) + } + return streamErrorf(codes.Internal, "Unexpected error from context packet: %v", err) +} + +// contextFromRequest returns a context from the HTTP Request. +func contextFromRequest(r *http.Request) context.Context { + return r.Context() +} diff --git a/vendor/google.golang.org/grpc/transport/handler_server.go b/vendor/google.golang.org/grpc/transport/handler_server.go new file mode 100644 index 00000000000..f71b7482174 --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/handler_server.go @@ -0,0 +1,451 @@ +/* + * + * Copyright 2016 gRPC 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 is the implementation of a gRPC server using HTTP/2 which +// uses the standard Go http2 Server implementation (via the +// http.Handler interface), rather than speaking low-level HTTP/2 +// frames itself. It is the implementation of *grpc.Server.ServeHTTP. + +package transport + +import ( + "errors" + "fmt" + "io" + "net" + "net/http" + "strings" + "sync" + "time" + + "github.com/golang/protobuf/proto" + "golang.org/x/net/context" + "golang.org/x/net/http2" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/metadata" + "google.golang.org/grpc/peer" + "google.golang.org/grpc/stats" + "google.golang.org/grpc/status" +) + +// NewServerHandlerTransport returns a ServerTransport handling gRPC +// from inside an http.Handler. It requires that the http Server +// supports HTTP/2. +func NewServerHandlerTransport(w http.ResponseWriter, r *http.Request, stats stats.Handler) (ServerTransport, error) { + if r.ProtoMajor != 2 { + return nil, errors.New("gRPC requires HTTP/2") + } + if r.Method != "POST" { + return nil, errors.New("invalid gRPC request method") + } + contentType := r.Header.Get("Content-Type") + // TODO: do we assume contentType is lowercase? we did before + contentSubtype, validContentType := contentSubtype(contentType) + if !validContentType { + return nil, errors.New("invalid gRPC request content-type") + } + if _, ok := w.(http.Flusher); !ok { + return nil, errors.New("gRPC requires a ResponseWriter supporting http.Flusher") + } + if _, ok := w.(http.CloseNotifier); !ok { + return nil, errors.New("gRPC requires a ResponseWriter supporting http.CloseNotifier") + } + + st := &serverHandlerTransport{ + rw: w, + req: r, + closedCh: make(chan struct{}), + writes: make(chan func()), + contentType: contentType, + contentSubtype: contentSubtype, + stats: stats, + } + + if v := r.Header.Get("grpc-timeout"); v != "" { + to, err := decodeTimeout(v) + if err != nil { + return nil, streamErrorf(codes.Internal, "malformed time-out: %v", err) + } + st.timeoutSet = true + st.timeout = to + } + + metakv := []string{"content-type", contentType} + if r.Host != "" { + metakv = append(metakv, ":authority", r.Host) + } + for k, vv := range r.Header { + k = strings.ToLower(k) + if isReservedHeader(k) && !isWhitelistedHeader(k) { + continue + } + for _, v := range vv { + v, err := decodeMetadataHeader(k, v) + if err != nil { + return nil, streamErrorf(codes.Internal, "malformed binary metadata: %v", err) + } + metakv = append(metakv, k, v) + } + } + st.headerMD = metadata.Pairs(metakv...) + + return st, nil +} + +// serverHandlerTransport is an implementation of ServerTransport +// which replies to exactly one gRPC request (exactly one HTTP request), +// using the net/http.Handler interface. This http.Handler is guaranteed +// at this point to be speaking over HTTP/2, so it's able to speak valid +// gRPC. +type serverHandlerTransport struct { + rw http.ResponseWriter + req *http.Request + timeoutSet bool + timeout time.Duration + didCommonHeaders bool + + headerMD metadata.MD + + closeOnce sync.Once + closedCh chan struct{} // closed on Close + + // writes is a channel of code to run serialized in the + // ServeHTTP (HandleStreams) goroutine. The channel is closed + // when WriteStatus is called. + writes chan func() + + // block concurrent WriteStatus calls + // e.g. grpc/(*serverStream).SendMsg/RecvMsg + writeStatusMu sync.Mutex + + // we just mirror the request content-type + contentType string + // we store both contentType and contentSubtype so we don't keep recreating them + // TODO make sure this is consistent across handler_server and http2_server + contentSubtype string + + stats stats.Handler +} + +func (ht *serverHandlerTransport) Close() error { + ht.closeOnce.Do(ht.closeCloseChanOnce) + return nil +} + +func (ht *serverHandlerTransport) closeCloseChanOnce() { close(ht.closedCh) } + +func (ht *serverHandlerTransport) RemoteAddr() net.Addr { return strAddr(ht.req.RemoteAddr) } + +// strAddr is a net.Addr backed by either a TCP "ip:port" string, or +// the empty string if unknown. +type strAddr string + +func (a strAddr) Network() string { + if a != "" { + // Per the documentation on net/http.Request.RemoteAddr, if this is + // set, it's set to the IP:port of the peer (hence, TCP): + // https://golang.org/pkg/net/http/#Request + // + // If we want to support Unix sockets later, we can + // add our own grpc-specific convention within the + // grpc codebase to set RemoteAddr to a different + // format, or probably better: we can attach it to the + // context and use that from serverHandlerTransport.RemoteAddr. + return "tcp" + } + return "" +} + +func (a strAddr) String() string { return string(a) } + +// do runs fn in the ServeHTTP goroutine. +func (ht *serverHandlerTransport) do(fn func()) error { + // Avoid a panic writing to closed channel. Imperfect but maybe good enough. + select { + case <-ht.closedCh: + return ErrConnClosing + default: + select { + case ht.writes <- fn: + return nil + case <-ht.closedCh: + return ErrConnClosing + } + } +} + +func (ht *serverHandlerTransport) WriteStatus(s *Stream, st *status.Status) error { + ht.writeStatusMu.Lock() + defer ht.writeStatusMu.Unlock() + + err := ht.do(func() { + ht.writeCommonHeaders(s) + + // And flush, in case no header or body has been sent yet. + // This forces a separation of headers and trailers if this is the + // first call (for example, in end2end tests's TestNoService). + ht.rw.(http.Flusher).Flush() + + h := ht.rw.Header() + h.Set("Grpc-Status", fmt.Sprintf("%d", st.Code())) + if m := st.Message(); m != "" { + h.Set("Grpc-Message", encodeGrpcMessage(m)) + } + + if p := st.Proto(); p != nil && len(p.Details) > 0 { + stBytes, err := proto.Marshal(p) + if err != nil { + // TODO: return error instead, when callers are able to handle it. + panic(err) + } + + h.Set("Grpc-Status-Details-Bin", encodeBinHeader(stBytes)) + } + + if md := s.Trailer(); len(md) > 0 { + for k, vv := range md { + // Clients don't tolerate reading restricted headers after some non restricted ones were sent. + if isReservedHeader(k) { + continue + } + for _, v := range vv { + // http2 ResponseWriter mechanism to send undeclared Trailers after + // the headers have possibly been written. + h.Add(http2.TrailerPrefix+k, encodeMetadataHeader(k, v)) + } + } + } + }) + + if err == nil { // transport has not been closed + if ht.stats != nil { + ht.stats.HandleRPC(s.Context(), &stats.OutTrailer{}) + } + ht.Close() + close(ht.writes) + } + return err +} + +// writeCommonHeaders sets common headers on the first write +// call (Write, WriteHeader, or WriteStatus). +func (ht *serverHandlerTransport) writeCommonHeaders(s *Stream) { + if ht.didCommonHeaders { + return + } + ht.didCommonHeaders = true + + h := ht.rw.Header() + h["Date"] = nil // suppress Date to make tests happy; TODO: restore + h.Set("Content-Type", ht.contentType) + + // Predeclare trailers we'll set later in WriteStatus (after the body). + // This is a SHOULD in the HTTP RFC, and the way you add (known) + // Trailers per the net/http.ResponseWriter contract. + // See https://golang.org/pkg/net/http/#ResponseWriter + // and https://golang.org/pkg/net/http/#example_ResponseWriter_trailers + h.Add("Trailer", "Grpc-Status") + h.Add("Trailer", "Grpc-Message") + h.Add("Trailer", "Grpc-Status-Details-Bin") + + if s.sendCompress != "" { + h.Set("Grpc-Encoding", s.sendCompress) + } +} + +func (ht *serverHandlerTransport) Write(s *Stream, hdr []byte, data []byte, opts *Options) error { + return ht.do(func() { + ht.writeCommonHeaders(s) + ht.rw.Write(hdr) + ht.rw.Write(data) + if !opts.Delay { + ht.rw.(http.Flusher).Flush() + } + }) +} + +func (ht *serverHandlerTransport) WriteHeader(s *Stream, md metadata.MD) error { + err := ht.do(func() { + ht.writeCommonHeaders(s) + h := ht.rw.Header() + for k, vv := range md { + // Clients don't tolerate reading restricted headers after some non restricted ones were sent. + if isReservedHeader(k) { + continue + } + for _, v := range vv { + v = encodeMetadataHeader(k, v) + h.Add(k, v) + } + } + ht.rw.WriteHeader(200) + ht.rw.(http.Flusher).Flush() + }) + + if err == nil { + if ht.stats != nil { + ht.stats.HandleRPC(s.Context(), &stats.OutHeader{}) + } + } + return err +} + +func (ht *serverHandlerTransport) HandleStreams(startStream func(*Stream), traceCtx func(context.Context, string) context.Context) { + // With this transport type there will be exactly 1 stream: this HTTP request. + + ctx := contextFromRequest(ht.req) + var cancel context.CancelFunc + if ht.timeoutSet { + ctx, cancel = context.WithTimeout(ctx, ht.timeout) + } else { + ctx, cancel = context.WithCancel(ctx) + } + + // requestOver is closed when either the request's context is done + // or the status has been written via WriteStatus. + requestOver := make(chan struct{}) + + // clientGone receives a single value if peer is gone, either + // because the underlying connection is dead or because the + // peer sends an http2 RST_STREAM. + clientGone := ht.rw.(http.CloseNotifier).CloseNotify() + go func() { + select { + case <-requestOver: + return + case <-ht.closedCh: + case <-clientGone: + } + cancel() + }() + + req := ht.req + + s := &Stream{ + id: 0, // irrelevant + requestRead: func(int) {}, + cancel: cancel, + buf: newRecvBuffer(), + st: ht, + method: req.URL.Path, + recvCompress: req.Header.Get("grpc-encoding"), + contentSubtype: ht.contentSubtype, + } + pr := &peer.Peer{ + Addr: ht.RemoteAddr(), + } + if req.TLS != nil { + pr.AuthInfo = credentials.TLSInfo{State: *req.TLS} + } + ctx = metadata.NewIncomingContext(ctx, ht.headerMD) + s.ctx = peer.NewContext(ctx, pr) + if ht.stats != nil { + s.ctx = ht.stats.TagRPC(s.ctx, &stats.RPCTagInfo{FullMethodName: s.method}) + inHeader := &stats.InHeader{ + FullMethod: s.method, + RemoteAddr: ht.RemoteAddr(), + Compression: s.recvCompress, + } + ht.stats.HandleRPC(s.ctx, inHeader) + } + s.trReader = &transportReader{ + reader: &recvBufferReader{ctx: s.ctx, ctxDone: s.ctx.Done(), recv: s.buf}, + windowHandler: func(int) {}, + } + + // readerDone is closed when the Body.Read-ing goroutine exits. + readerDone := make(chan struct{}) + go func() { + defer close(readerDone) + + // TODO: minimize garbage, optimize recvBuffer code/ownership + const readSize = 8196 + for buf := make([]byte, readSize); ; { + n, err := req.Body.Read(buf) + if n > 0 { + s.buf.put(recvMsg{data: buf[:n:n]}) + buf = buf[n:] + } + if err != nil { + s.buf.put(recvMsg{err: mapRecvMsgError(err)}) + return + } + if len(buf) == 0 { + buf = make([]byte, readSize) + } + } + }() + + // startStream is provided by the *grpc.Server's serveStreams. + // It starts a goroutine serving s and exits immediately. + // The goroutine that is started is the one that then calls + // into ht, calling WriteHeader, Write, WriteStatus, Close, etc. + startStream(s) + + ht.runStream() + close(requestOver) + + // Wait for reading goroutine to finish. + req.Body.Close() + <-readerDone +} + +func (ht *serverHandlerTransport) runStream() { + for { + select { + case fn, ok := <-ht.writes: + if !ok { + return + } + fn() + case <-ht.closedCh: + return + } + } +} + +func (ht *serverHandlerTransport) IncrMsgSent() {} + +func (ht *serverHandlerTransport) IncrMsgRecv() {} + +func (ht *serverHandlerTransport) Drain() { + panic("Drain() is not implemented") +} + +// mapRecvMsgError returns the non-nil err into the appropriate +// error value as expected by callers of *grpc.parser.recvMsg. +// In particular, in can only be: +// * io.EOF +// * io.ErrUnexpectedEOF +// * of type transport.ConnectionError +// * of type transport.StreamError +func mapRecvMsgError(err error) error { + if err == io.EOF || err == io.ErrUnexpectedEOF { + return err + } + if se, ok := err.(http2.StreamError); ok { + if code, ok := http2ErrConvTab[se.Code]; ok { + return StreamError{ + Code: code, + Desc: se.Error(), + } + } + } + return connectionErrorf(true, err, err.Error()) +} diff --git a/vendor/google.golang.org/grpc/transport/http2_client.go b/vendor/google.golang.org/grpc/transport/http2_client.go new file mode 100644 index 00000000000..1fdabd954ef --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/http2_client.go @@ -0,0 +1,1284 @@ +/* + * + * Copyright 2014 gRPC 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 transport + +import ( + "io" + "math" + "net" + "strings" + "sync" + "sync/atomic" + "time" + + "golang.org/x/net/context" + "golang.org/x/net/http2" + "golang.org/x/net/http2/hpack" + + "google.golang.org/grpc/channelz" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/keepalive" + "google.golang.org/grpc/metadata" + "google.golang.org/grpc/peer" + "google.golang.org/grpc/stats" + "google.golang.org/grpc/status" +) + +// http2Client implements the ClientTransport interface with HTTP2. +type http2Client struct { + ctx context.Context + cancel context.CancelFunc + ctxDone <-chan struct{} // Cache the ctx.Done() chan. + userAgent string + md interface{} + conn net.Conn // underlying communication channel + loopy *loopyWriter + remoteAddr net.Addr + localAddr net.Addr + authInfo credentials.AuthInfo // auth info about the connection + + readerDone chan struct{} // sync point to enable testing. + writerDone chan struct{} // sync point to enable testing. + // goAway is closed to notify the upper layer (i.e., addrConn.transportMonitor) + // that the server sent GoAway on this transport. + goAway chan struct{} + // awakenKeepalive is used to wake up keepalive when after it has gone dormant. + awakenKeepalive chan struct{} + + framer *framer + // controlBuf delivers all the control related tasks (e.g., window + // updates, reset streams, and various settings) to the controller. + controlBuf *controlBuffer + fc *trInFlow + // The scheme used: https if TLS is on, http otherwise. + scheme string + + isSecure bool + + creds []credentials.PerRPCCredentials + + // Boolean to keep track of reading activity on transport. + // 1 is true and 0 is false. + activity uint32 // Accessed atomically. + kp keepalive.ClientParameters + + statsHandler stats.Handler + + initialWindowSize int32 + + bdpEst *bdpEstimator + // onSuccess is a callback that client transport calls upon + // receiving server preface to signal that a succefull HTTP2 + // connection was established. + onSuccess func() + + maxConcurrentStreams uint32 + streamQuota int64 + streamsQuotaAvailable chan struct{} + waitingStreams uint32 + nextID uint32 + + mu sync.Mutex // guard the following variables + state transportState + activeStreams map[uint32]*Stream + // prevGoAway ID records the Last-Stream-ID in the previous GOAway frame. + prevGoAwayID uint32 + // goAwayReason records the http2.ErrCode and debug data received with the + // GoAway frame. + goAwayReason GoAwayReason + + // Fields below are for channelz metric collection. + channelzID int64 // channelz unique identification number + czmu sync.RWMutex + kpCount int64 + // The number of streams that have started, including already finished ones. + streamsStarted int64 + // The number of streams that have ended successfully by receiving EoS bit set + // frame from server. + streamsSucceeded int64 + streamsFailed int64 + lastStreamCreated time.Time + msgSent int64 + msgRecv int64 + lastMsgSent time.Time + lastMsgRecv time.Time +} + +func dial(ctx context.Context, fn func(context.Context, string) (net.Conn, error), addr string) (net.Conn, error) { + if fn != nil { + return fn(ctx, addr) + } + return dialContext(ctx, "tcp", addr) +} + +func isTemporary(err error) bool { + switch err := err.(type) { + case interface { + Temporary() bool + }: + return err.Temporary() + case interface { + Timeout() bool + }: + // Timeouts may be resolved upon retry, and are thus treated as + // temporary. + return err.Timeout() + } + return true +} + +// newHTTP2Client constructs a connected ClientTransport to addr based on HTTP2 +// and starts to receive messages on it. Non-nil error returns if construction +// fails. +func newHTTP2Client(connectCtx, ctx context.Context, addr TargetInfo, opts ConnectOptions, onSuccess func()) (_ ClientTransport, err error) { + scheme := "http" + ctx, cancel := context.WithCancel(ctx) + defer func() { + if err != nil { + cancel() + } + }() + + conn, err := dial(connectCtx, opts.Dialer, addr.Addr) + if err != nil { + if opts.FailOnNonTempDialError { + return nil, connectionErrorf(isTemporary(err), err, "transport: error while dialing: %v", err) + } + return nil, connectionErrorf(true, err, "transport: Error while dialing %v", err) + } + // Any further errors will close the underlying connection + defer func(conn net.Conn) { + if err != nil { + conn.Close() + } + }(conn) + var ( + isSecure bool + authInfo credentials.AuthInfo + ) + if creds := opts.TransportCredentials; creds != nil { + scheme = "https" + conn, authInfo, err = creds.ClientHandshake(connectCtx, addr.Authority, conn) + if err != nil { + return nil, connectionErrorf(isTemporary(err), err, "transport: authentication handshake failed: %v", err) + } + isSecure = true + } + kp := opts.KeepaliveParams + // Validate keepalive parameters. + if kp.Time == 0 { + kp.Time = defaultClientKeepaliveTime + } + if kp.Timeout == 0 { + kp.Timeout = defaultClientKeepaliveTimeout + } + dynamicWindow := true + icwz := int32(initialWindowSize) + if opts.InitialConnWindowSize >= defaultWindowSize { + icwz = opts.InitialConnWindowSize + dynamicWindow = false + } + writeBufSize := defaultWriteBufSize + if opts.WriteBufferSize > 0 { + writeBufSize = opts.WriteBufferSize + } + readBufSize := defaultReadBufSize + if opts.ReadBufferSize > 0 { + readBufSize = opts.ReadBufferSize + } + t := &http2Client{ + ctx: ctx, + ctxDone: ctx.Done(), // Cache Done chan. + cancel: cancel, + userAgent: opts.UserAgent, + md: addr.Metadata, + conn: conn, + remoteAddr: conn.RemoteAddr(), + localAddr: conn.LocalAddr(), + authInfo: authInfo, + readerDone: make(chan struct{}), + writerDone: make(chan struct{}), + goAway: make(chan struct{}), + awakenKeepalive: make(chan struct{}, 1), + framer: newFramer(conn, writeBufSize, readBufSize), + fc: &trInFlow{limit: uint32(icwz)}, + scheme: scheme, + activeStreams: make(map[uint32]*Stream), + isSecure: isSecure, + creds: opts.PerRPCCredentials, + kp: kp, + statsHandler: opts.StatsHandler, + initialWindowSize: initialWindowSize, + onSuccess: onSuccess, + nextID: 1, + maxConcurrentStreams: defaultMaxStreamsClient, + streamQuota: defaultMaxStreamsClient, + streamsQuotaAvailable: make(chan struct{}, 1), + } + t.controlBuf = newControlBuffer(t.ctxDone) + if opts.InitialWindowSize >= defaultWindowSize { + t.initialWindowSize = opts.InitialWindowSize + dynamicWindow = false + } + if dynamicWindow { + t.bdpEst = &bdpEstimator{ + bdp: initialWindowSize, + updateFlowControl: t.updateFlowControl, + } + } + // Make sure awakenKeepalive can't be written upon. + // keepalive routine will make it writable, if need be. + t.awakenKeepalive <- struct{}{} + if t.statsHandler != nil { + t.ctx = t.statsHandler.TagConn(t.ctx, &stats.ConnTagInfo{ + RemoteAddr: t.remoteAddr, + LocalAddr: t.localAddr, + }) + connBegin := &stats.ConnBegin{ + Client: true, + } + t.statsHandler.HandleConn(t.ctx, connBegin) + } + if channelz.IsOn() { + t.channelzID = channelz.RegisterNormalSocket(t, opts.ChannelzParentID, "") + } + // Start the reader goroutine for incoming message. Each transport has + // a dedicated goroutine which reads HTTP2 frame from network. Then it + // dispatches the frame to the corresponding stream entity. + go t.reader() + // Send connection preface to server. + n, err := t.conn.Write(clientPreface) + if err != nil { + t.Close() + return nil, connectionErrorf(true, err, "transport: failed to write client preface: %v", err) + } + if n != len(clientPreface) { + t.Close() + return nil, connectionErrorf(true, err, "transport: preface mismatch, wrote %d bytes; want %d", n, len(clientPreface)) + } + if t.initialWindowSize != defaultWindowSize { + err = t.framer.fr.WriteSettings(http2.Setting{ + ID: http2.SettingInitialWindowSize, + Val: uint32(t.initialWindowSize), + }) + } else { + err = t.framer.fr.WriteSettings() + } + if err != nil { + t.Close() + return nil, connectionErrorf(true, err, "transport: failed to write initial settings frame: %v", err) + } + // Adjust the connection flow control window if needed. + if delta := uint32(icwz - defaultWindowSize); delta > 0 { + if err := t.framer.fr.WriteWindowUpdate(0, delta); err != nil { + t.Close() + return nil, connectionErrorf(true, err, "transport: failed to write window update: %v", err) + } + } + t.framer.writer.Flush() + go func() { + t.loopy = newLoopyWriter(clientSide, t.framer, t.controlBuf, t.bdpEst) + t.loopy.run() + t.conn.Close() + close(t.writerDone) + }() + if t.kp.Time != infinity { + go t.keepalive() + } + return t, nil +} + +func (t *http2Client) newStream(ctx context.Context, callHdr *CallHdr) *Stream { + // TODO(zhaoq): Handle uint32 overflow of Stream.id. + s := &Stream{ + done: make(chan struct{}), + method: callHdr.Method, + sendCompress: callHdr.SendCompress, + buf: newRecvBuffer(), + headerChan: make(chan struct{}), + contentSubtype: callHdr.ContentSubtype, + } + s.wq = newWriteQuota(defaultWriteQuota, s.done) + s.requestRead = func(n int) { + t.adjustWindow(s, uint32(n)) + } + // The client side stream context should have exactly the same life cycle with the user provided context. + // That means, s.ctx should be read-only. And s.ctx is done iff ctx is done. + // So we use the original context here instead of creating a copy. + s.ctx = ctx + s.trReader = &transportReader{ + reader: &recvBufferReader{ + ctx: s.ctx, + ctxDone: s.ctx.Done(), + recv: s.buf, + }, + windowHandler: func(n int) { + t.updateWindow(s, uint32(n)) + }, + } + return s +} + +func (t *http2Client) getPeer() *peer.Peer { + pr := &peer.Peer{ + Addr: t.remoteAddr, + } + // Attach Auth info if there is any. + if t.authInfo != nil { + pr.AuthInfo = t.authInfo + } + return pr +} + +func (t *http2Client) createHeaderFields(ctx context.Context, callHdr *CallHdr) ([]hpack.HeaderField, error) { + aud := t.createAudience(callHdr) + authData, err := t.getTrAuthData(ctx, aud) + if err != nil { + return nil, err + } + callAuthData, err := t.getCallAuthData(ctx, aud, callHdr) + if err != nil { + return nil, err + } + // TODO(mmukhi): Benchmark if the performance gets better if count the metadata and other header fields + // first and create a slice of that exact size. + // Make the slice of certain predictable size to reduce allocations made by append. + hfLen := 7 // :method, :scheme, :path, :authority, content-type, user-agent, te + hfLen += len(authData) + len(callAuthData) + headerFields := make([]hpack.HeaderField, 0, hfLen) + headerFields = append(headerFields, hpack.HeaderField{Name: ":method", Value: "POST"}) + headerFields = append(headerFields, hpack.HeaderField{Name: ":scheme", Value: t.scheme}) + headerFields = append(headerFields, hpack.HeaderField{Name: ":path", Value: callHdr.Method}) + headerFields = append(headerFields, hpack.HeaderField{Name: ":authority", Value: callHdr.Host}) + headerFields = append(headerFields, hpack.HeaderField{Name: "content-type", Value: contentType(callHdr.ContentSubtype)}) + headerFields = append(headerFields, hpack.HeaderField{Name: "user-agent", Value: t.userAgent}) + headerFields = append(headerFields, hpack.HeaderField{Name: "te", Value: "trailers"}) + + if callHdr.SendCompress != "" { + headerFields = append(headerFields, hpack.HeaderField{Name: "grpc-encoding", Value: callHdr.SendCompress}) + } + if dl, ok := ctx.Deadline(); ok { + // Send out timeout regardless its value. The server can detect timeout context by itself. + // TODO(mmukhi): Perhaps this field should be updated when actually writing out to the wire. + timeout := dl.Sub(time.Now()) + headerFields = append(headerFields, hpack.HeaderField{Name: "grpc-timeout", Value: encodeTimeout(timeout)}) + } + for k, v := range authData { + headerFields = append(headerFields, hpack.HeaderField{Name: k, Value: encodeMetadataHeader(k, v)}) + } + for k, v := range callAuthData { + headerFields = append(headerFields, hpack.HeaderField{Name: k, Value: encodeMetadataHeader(k, v)}) + } + if b := stats.OutgoingTags(ctx); b != nil { + headerFields = append(headerFields, hpack.HeaderField{Name: "grpc-tags-bin", Value: encodeBinHeader(b)}) + } + if b := stats.OutgoingTrace(ctx); b != nil { + headerFields = append(headerFields, hpack.HeaderField{Name: "grpc-trace-bin", Value: encodeBinHeader(b)}) + } + + if md, added, ok := metadata.FromOutgoingContextRaw(ctx); ok { + var k string + for _, vv := range added { + for i, v := range vv { + if i%2 == 0 { + k = v + continue + } + // HTTP doesn't allow you to set pseudoheaders after non pseudoheaders were set. + if isReservedHeader(k) { + continue + } + headerFields = append(headerFields, hpack.HeaderField{Name: strings.ToLower(k), Value: encodeMetadataHeader(k, v)}) + } + } + for k, vv := range md { + // HTTP doesn't allow you to set pseudoheaders after non pseudoheaders were set. + if isReservedHeader(k) { + continue + } + for _, v := range vv { + headerFields = append(headerFields, hpack.HeaderField{Name: k, Value: encodeMetadataHeader(k, v)}) + } + } + } + if md, ok := t.md.(*metadata.MD); ok { + for k, vv := range *md { + if isReservedHeader(k) { + continue + } + for _, v := range vv { + headerFields = append(headerFields, hpack.HeaderField{Name: k, Value: encodeMetadataHeader(k, v)}) + } + } + } + return headerFields, nil +} + +func (t *http2Client) createAudience(callHdr *CallHdr) string { + // Create an audience string only if needed. + if len(t.creds) == 0 && callHdr.Creds == nil { + return "" + } + // Construct URI required to get auth request metadata. + // Omit port if it is the default one. + host := strings.TrimSuffix(callHdr.Host, ":443") + pos := strings.LastIndex(callHdr.Method, "/") + if pos == -1 { + pos = len(callHdr.Method) + } + return "https://" + host + callHdr.Method[:pos] +} + +func (t *http2Client) getTrAuthData(ctx context.Context, audience string) (map[string]string, error) { + authData := map[string]string{} + for _, c := range t.creds { + data, err := c.GetRequestMetadata(ctx, audience) + if err != nil { + if _, ok := status.FromError(err); ok { + return nil, err + } + + return nil, streamErrorf(codes.Unauthenticated, "transport: %v", err) + } + for k, v := range data { + // Capital header names are illegal in HTTP/2. + k = strings.ToLower(k) + authData[k] = v + } + } + return authData, nil +} + +func (t *http2Client) getCallAuthData(ctx context.Context, audience string, callHdr *CallHdr) (map[string]string, error) { + callAuthData := map[string]string{} + // Check if credentials.PerRPCCredentials were provided via call options. + // Note: if these credentials are provided both via dial options and call + // options, then both sets of credentials will be applied. + if callCreds := callHdr.Creds; callCreds != nil { + if !t.isSecure && callCreds.RequireTransportSecurity() { + return nil, streamErrorf(codes.Unauthenticated, "transport: cannot send secure credentials on an insecure connection") + } + data, err := callCreds.GetRequestMetadata(ctx, audience) + if err != nil { + return nil, streamErrorf(codes.Internal, "transport: %v", err) + } + for k, v := range data { + // Capital header names are illegal in HTTP/2 + k = strings.ToLower(k) + callAuthData[k] = v + } + } + return callAuthData, nil +} + +// NewStream creates a stream and registers it into the transport as "active" +// streams. +func (t *http2Client) NewStream(ctx context.Context, callHdr *CallHdr) (_ *Stream, err error) { + ctx = peer.NewContext(ctx, t.getPeer()) + headerFields, err := t.createHeaderFields(ctx, callHdr) + if err != nil { + return nil, err + } + s := t.newStream(ctx, callHdr) + cleanup := func(err error) { + if s.swapState(streamDone) == streamDone { + // If it was already done, return. + return + } + // The stream was unprocessed by the server. + atomic.StoreUint32(&s.unprocessed, 1) + s.write(recvMsg{err: err}) + close(s.done) + // If headerChan isn't closed, then close it. + if atomic.SwapUint32(&s.headerDone, 1) == 0 { + close(s.headerChan) + } + + } + hdr := &headerFrame{ + hf: headerFields, + endStream: false, + initStream: func(id uint32) (bool, error) { + t.mu.Lock() + if state := t.state; state != reachable { + t.mu.Unlock() + // Do a quick cleanup. + err := error(errStreamDrain) + if state == closing { + err = ErrConnClosing + } + cleanup(err) + return false, err + } + t.activeStreams[id] = s + if channelz.IsOn() { + t.czmu.Lock() + t.streamsStarted++ + t.lastStreamCreated = time.Now() + t.czmu.Unlock() + } + var sendPing bool + // If the number of active streams change from 0 to 1, then check if keepalive + // has gone dormant. If so, wake it up. + if len(t.activeStreams) == 1 { + select { + case t.awakenKeepalive <- struct{}{}: + sendPing = true + // Fill the awakenKeepalive channel again as this channel must be + // kept non-writable except at the point that the keepalive() + // goroutine is waiting either to be awaken or shutdown. + t.awakenKeepalive <- struct{}{} + default: + } + } + t.mu.Unlock() + return sendPing, nil + }, + onOrphaned: cleanup, + wq: s.wq, + } + firstTry := true + var ch chan struct{} + checkForStreamQuota := func(it interface{}) bool { + if t.streamQuota <= 0 { // Can go negative if server decreases it. + if firstTry { + t.waitingStreams++ + } + ch = t.streamsQuotaAvailable + return false + } + if !firstTry { + t.waitingStreams-- + } + t.streamQuota-- + h := it.(*headerFrame) + h.streamID = t.nextID + t.nextID += 2 + s.id = h.streamID + s.fc = &inFlow{limit: uint32(t.initialWindowSize)} + if t.streamQuota > 0 && t.waitingStreams > 0 { + select { + case t.streamsQuotaAvailable <- struct{}{}: + default: + } + } + return true + } + for { + success, err := t.controlBuf.executeAndPut(checkForStreamQuota, hdr) + if err != nil { + return nil, err + } + if success { + break + } + firstTry = false + select { + case <-ch: + case <-s.ctx.Done(): + return nil, ContextErr(s.ctx.Err()) + case <-t.goAway: + return nil, errStreamDrain + case <-t.ctx.Done(): + return nil, ErrConnClosing + } + } + if t.statsHandler != nil { + outHeader := &stats.OutHeader{ + Client: true, + FullMethod: callHdr.Method, + RemoteAddr: t.remoteAddr, + LocalAddr: t.localAddr, + Compression: callHdr.SendCompress, + } + t.statsHandler.HandleRPC(s.ctx, outHeader) + } + return s, nil +} + +// CloseStream clears the footprint of a stream when the stream is not needed any more. +// This must not be executed in reader's goroutine. +func (t *http2Client) CloseStream(s *Stream, err error) { + var ( + rst bool + rstCode http2.ErrCode + ) + if err != nil { + rst = true + rstCode = http2.ErrCodeCancel + } + t.closeStream(s, err, rst, rstCode, nil, nil, false) +} + +func (t *http2Client) closeStream(s *Stream, err error, rst bool, rstCode http2.ErrCode, st *status.Status, mdata map[string][]string, eosReceived bool) { + // Set stream status to done. + if s.swapState(streamDone) == streamDone { + // If it was already done, return. + return + } + // status and trailers can be updated here without any synchronization because the stream goroutine will + // only read it after it sees an io.EOF error from read or write and we'll write those errors + // only after updating this. + s.status = st + if len(mdata) > 0 { + s.trailer = mdata + } + if err != nil { + // This will unblock reads eventually. + s.write(recvMsg{err: err}) + } + // This will unblock write. + close(s.done) + // If headerChan isn't closed, then close it. + if atomic.SwapUint32(&s.headerDone, 1) == 0 { + close(s.headerChan) + } + cleanup := &cleanupStream{ + streamID: s.id, + onWrite: func() { + t.mu.Lock() + if t.activeStreams != nil { + delete(t.activeStreams, s.id) + } + t.mu.Unlock() + if channelz.IsOn() { + t.czmu.Lock() + if eosReceived { + t.streamsSucceeded++ + } else { + t.streamsFailed++ + } + t.czmu.Unlock() + } + }, + rst: rst, + rstCode: rstCode, + } + addBackStreamQuota := func(interface{}) bool { + t.streamQuota++ + if t.streamQuota > 0 && t.waitingStreams > 0 { + select { + case t.streamsQuotaAvailable <- struct{}{}: + default: + } + } + return true + } + t.controlBuf.executeAndPut(addBackStreamQuota, cleanup) +} + +// Close kicks off the shutdown process of the transport. This should be called +// only once on a transport. Once it is called, the transport should not be +// accessed any more. +func (t *http2Client) Close() error { + t.mu.Lock() + // Make sure we only Close once. + if t.state == closing { + t.mu.Unlock() + return nil + } + t.state = closing + streams := t.activeStreams + t.activeStreams = nil + t.mu.Unlock() + t.controlBuf.finish() + t.cancel() + err := t.conn.Close() + if channelz.IsOn() { + channelz.RemoveEntry(t.channelzID) + } + // Notify all active streams. + for _, s := range streams { + t.closeStream(s, ErrConnClosing, false, http2.ErrCodeNo, nil, nil, false) + } + if t.statsHandler != nil { + connEnd := &stats.ConnEnd{ + Client: true, + } + t.statsHandler.HandleConn(t.ctx, connEnd) + } + return err +} + +// GracefulClose sets the state to draining, which prevents new streams from +// being created and causes the transport to be closed when the last active +// stream is closed. If there are no active streams, the transport is closed +// immediately. This does nothing if the transport is already draining or +// closing. +func (t *http2Client) GracefulClose() error { + t.mu.Lock() + // Make sure we move to draining only from active. + if t.state == draining || t.state == closing { + t.mu.Unlock() + return nil + } + t.state = draining + active := len(t.activeStreams) + t.mu.Unlock() + if active == 0 { + return t.Close() + } + return nil +} + +// Write formats the data into HTTP2 data frame(s) and sends it out. The caller +// should proceed only if Write returns nil. +func (t *http2Client) Write(s *Stream, hdr []byte, data []byte, opts *Options) error { + if opts.Last { + // If it's the last message, update stream state. + if !s.compareAndSwapState(streamActive, streamWriteDone) { + return errStreamDone + } + } else if s.getState() != streamActive { + return errStreamDone + } + df := &dataFrame{ + streamID: s.id, + endStream: opts.Last, + } + if hdr != nil || data != nil { // If it's not an empty data frame. + // Add some data to grpc message header so that we can equally + // distribute bytes across frames. + emptyLen := http2MaxFrameLen - len(hdr) + if emptyLen > len(data) { + emptyLen = len(data) + } + hdr = append(hdr, data[:emptyLen]...) + data = data[emptyLen:] + df.h, df.d = hdr, data + // TODO(mmukhi): The above logic in this if can be moved to loopyWriter's data handler. + if err := s.wq.get(int32(len(hdr) + len(data))); err != nil { + return err + } + } + return t.controlBuf.put(df) +} + +func (t *http2Client) getStream(f http2.Frame) (*Stream, bool) { + t.mu.Lock() + defer t.mu.Unlock() + s, ok := t.activeStreams[f.Header().StreamID] + return s, ok +} + +// adjustWindow sends out extra window update over the initial window size +// of stream if the application is requesting data larger in size than +// the window. +func (t *http2Client) adjustWindow(s *Stream, n uint32) { + if w := s.fc.maybeAdjust(n); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{streamID: s.id, increment: w}) + } +} + +// updateWindow adjusts the inbound quota for the stream. +// Window updates will be sent out when the cumulative quota +// exceeds the corresponding threshold. +func (t *http2Client) updateWindow(s *Stream, n uint32) { + if w := s.fc.onRead(n); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{streamID: s.id, increment: w}) + } +} + +// updateFlowControl updates the incoming flow control windows +// for the transport and the stream based on the current bdp +// estimation. +func (t *http2Client) updateFlowControl(n uint32) { + t.mu.Lock() + for _, s := range t.activeStreams { + s.fc.newLimit(n) + } + t.mu.Unlock() + updateIWS := func(interface{}) bool { + t.initialWindowSize = int32(n) + return true + } + t.controlBuf.executeAndPut(updateIWS, &outgoingWindowUpdate{streamID: 0, increment: t.fc.newLimit(n)}) + t.controlBuf.put(&outgoingSettings{ + ss: []http2.Setting{ + { + ID: http2.SettingInitialWindowSize, + Val: n, + }, + }, + }) +} + +func (t *http2Client) handleData(f *http2.DataFrame) { + size := f.Header().Length + var sendBDPPing bool + if t.bdpEst != nil { + sendBDPPing = t.bdpEst.add(size) + } + // Decouple connection's flow control from application's read. + // An update on connection's flow control should not depend on + // whether user application has read the data or not. Such a + // restriction is already imposed on the stream's flow control, + // and therefore the sender will be blocked anyways. + // Decoupling the connection flow control will prevent other + // active(fast) streams from starving in presence of slow or + // inactive streams. + // + if w := t.fc.onData(size); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{ + streamID: 0, + increment: w, + }) + } + if sendBDPPing { + // Avoid excessive ping detection (e.g. in an L7 proxy) + // by sending a window update prior to the BDP ping. + + if w := t.fc.reset(); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{ + streamID: 0, + increment: w, + }) + } + + t.controlBuf.put(bdpPing) + } + // Select the right stream to dispatch. + s, ok := t.getStream(f) + if !ok { + return + } + if size > 0 { + if err := s.fc.onData(size); err != nil { + t.closeStream(s, io.EOF, true, http2.ErrCodeFlowControl, status.New(codes.Internal, err.Error()), nil, false) + return + } + if f.Header().Flags.Has(http2.FlagDataPadded) { + if w := s.fc.onRead(size - uint32(len(f.Data()))); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{s.id, w}) + } + } + // TODO(bradfitz, zhaoq): A copy is required here because there is no + // guarantee f.Data() is consumed before the arrival of next frame. + // Can this copy be eliminated? + if len(f.Data()) > 0 { + data := make([]byte, len(f.Data())) + copy(data, f.Data()) + s.write(recvMsg{data: data}) + } + } + // The server has closed the stream without sending trailers. Record that + // the read direction is closed, and set the status appropriately. + if f.FrameHeader.Flags.Has(http2.FlagDataEndStream) { + t.closeStream(s, io.EOF, false, http2.ErrCodeNo, status.New(codes.Internal, "server closed the stream without sending trailers"), nil, true) + } +} + +func (t *http2Client) handleRSTStream(f *http2.RSTStreamFrame) { + s, ok := t.getStream(f) + if !ok { + return + } + if f.ErrCode == http2.ErrCodeRefusedStream { + // The stream was unprocessed by the server. + atomic.StoreUint32(&s.unprocessed, 1) + } + statusCode, ok := http2ErrConvTab[f.ErrCode] + if !ok { + warningf("transport: http2Client.handleRSTStream found no mapped gRPC status for the received http2 error %v", f.ErrCode) + statusCode = codes.Unknown + } + t.closeStream(s, io.EOF, false, http2.ErrCodeNo, status.Newf(statusCode, "stream terminated by RST_STREAM with error code: %v", f.ErrCode), nil, false) +} + +func (t *http2Client) handleSettings(f *http2.SettingsFrame, isFirst bool) { + if f.IsAck() { + return + } + var maxStreams *uint32 + var ss []http2.Setting + f.ForeachSetting(func(s http2.Setting) error { + if s.ID == http2.SettingMaxConcurrentStreams { + maxStreams = new(uint32) + *maxStreams = s.Val + return nil + } + ss = append(ss, s) + return nil + }) + if isFirst && maxStreams == nil { + maxStreams = new(uint32) + *maxStreams = math.MaxUint32 + } + sf := &incomingSettings{ + ss: ss, + } + if maxStreams == nil { + t.controlBuf.put(sf) + return + } + updateStreamQuota := func(interface{}) bool { + delta := int64(*maxStreams) - int64(t.maxConcurrentStreams) + t.maxConcurrentStreams = *maxStreams + t.streamQuota += delta + if delta > 0 && t.waitingStreams > 0 { + close(t.streamsQuotaAvailable) // wake all of them up. + t.streamsQuotaAvailable = make(chan struct{}, 1) + } + return true + } + t.controlBuf.executeAndPut(updateStreamQuota, sf) +} + +func (t *http2Client) handlePing(f *http2.PingFrame) { + if f.IsAck() { + // Maybe it's a BDP ping. + if t.bdpEst != nil { + t.bdpEst.calculate(f.Data) + } + return + } + pingAck := &ping{ack: true} + copy(pingAck.data[:], f.Data[:]) + t.controlBuf.put(pingAck) +} + +func (t *http2Client) handleGoAway(f *http2.GoAwayFrame) { + t.mu.Lock() + if t.state == closing { + t.mu.Unlock() + return + } + if f.ErrCode == http2.ErrCodeEnhanceYourCalm { + infof("Client received GoAway with http2.ErrCodeEnhanceYourCalm.") + } + id := f.LastStreamID + if id > 0 && id%2 != 1 { + t.mu.Unlock() + t.Close() + return + } + // A client can receive multiple GoAways from the server (see + // https://github.com/grpc/grpc-go/issues/1387). The idea is that the first + // GoAway will be sent with an ID of MaxInt32 and the second GoAway will be + // sent after an RTT delay with the ID of the last stream the server will + // process. + // + // Therefore, when we get the first GoAway we don't necessarily close any + // streams. While in case of second GoAway we close all streams created after + // the GoAwayId. This way streams that were in-flight while the GoAway from + // server was being sent don't get killed. + select { + case <-t.goAway: // t.goAway has been closed (i.e.,multiple GoAways). + // If there are multiple GoAways the first one should always have an ID greater than the following ones. + if id > t.prevGoAwayID { + t.mu.Unlock() + t.Close() + return + } + default: + t.setGoAwayReason(f) + close(t.goAway) + t.state = draining + t.controlBuf.put(&incomingGoAway{}) + } + // All streams with IDs greater than the GoAwayId + // and smaller than the previous GoAway ID should be killed. + upperLimit := t.prevGoAwayID + if upperLimit == 0 { // This is the first GoAway Frame. + upperLimit = math.MaxUint32 // Kill all streams after the GoAway ID. + } + for streamID, stream := range t.activeStreams { + if streamID > id && streamID <= upperLimit { + // The stream was unprocessed by the server. + atomic.StoreUint32(&stream.unprocessed, 1) + t.closeStream(stream, errStreamDrain, false, http2.ErrCodeNo, statusGoAway, nil, false) + } + } + t.prevGoAwayID = id + active := len(t.activeStreams) + t.mu.Unlock() + if active == 0 { + t.Close() + } +} + +// setGoAwayReason sets the value of t.goAwayReason based +// on the GoAway frame received. +// It expects a lock on transport's mutext to be held by +// the caller. +func (t *http2Client) setGoAwayReason(f *http2.GoAwayFrame) { + t.goAwayReason = GoAwayNoReason + switch f.ErrCode { + case http2.ErrCodeEnhanceYourCalm: + if string(f.DebugData()) == "too_many_pings" { + t.goAwayReason = GoAwayTooManyPings + } + } +} + +func (t *http2Client) GetGoAwayReason() GoAwayReason { + t.mu.Lock() + defer t.mu.Unlock() + return t.goAwayReason +} + +func (t *http2Client) handleWindowUpdate(f *http2.WindowUpdateFrame) { + t.controlBuf.put(&incomingWindowUpdate{ + streamID: f.Header().StreamID, + increment: f.Increment, + }) +} + +// operateHeaders takes action on the decoded headers. +func (t *http2Client) operateHeaders(frame *http2.MetaHeadersFrame) { + s, ok := t.getStream(frame) + if !ok { + return + } + atomic.StoreUint32(&s.bytesReceived, 1) + var state decodeState + if err := state.decodeResponseHeader(frame); err != nil { + t.closeStream(s, err, true, http2.ErrCodeProtocol, nil, nil, false) + // Something wrong. Stops reading even when there is remaining. + return + } + + endStream := frame.StreamEnded() + var isHeader bool + defer func() { + if t.statsHandler != nil { + if isHeader { + inHeader := &stats.InHeader{ + Client: true, + WireLength: int(frame.Header().Length), + } + t.statsHandler.HandleRPC(s.ctx, inHeader) + } else { + inTrailer := &stats.InTrailer{ + Client: true, + WireLength: int(frame.Header().Length), + } + t.statsHandler.HandleRPC(s.ctx, inTrailer) + } + } + }() + // If headers haven't been received yet. + if atomic.SwapUint32(&s.headerDone, 1) == 0 { + if !endStream { + // Headers frame is not actually a trailers-only frame. + isHeader = true + // These values can be set without any synchronization because + // stream goroutine will read it only after seeing a closed + // headerChan which we'll close after setting this. + s.recvCompress = state.encoding + if len(state.mdata) > 0 { + s.header = state.mdata + } + } + close(s.headerChan) + } + if !endStream { + return + } + t.closeStream(s, io.EOF, false, http2.ErrCodeNo, state.status(), state.mdata, true) +} + +// reader runs as a separate goroutine in charge of reading data from network +// connection. +// +// TODO(zhaoq): currently one reader per transport. Investigate whether this is +// optimal. +// TODO(zhaoq): Check the validity of the incoming frame sequence. +func (t *http2Client) reader() { + defer close(t.readerDone) + // Check the validity of server preface. + frame, err := t.framer.fr.ReadFrame() + if err != nil { + t.Close() + return + } + atomic.CompareAndSwapUint32(&t.activity, 0, 1) + sf, ok := frame.(*http2.SettingsFrame) + if !ok { + t.Close() + return + } + t.onSuccess() + t.handleSettings(sf, true) + + // loop to keep reading incoming messages on this transport. + for { + frame, err := t.framer.fr.ReadFrame() + atomic.CompareAndSwapUint32(&t.activity, 0, 1) + if err != nil { + // Abort an active stream if the http2.Framer returns a + // http2.StreamError. This can happen only if the server's response + // is malformed http2. + if se, ok := err.(http2.StreamError); ok { + t.mu.Lock() + s := t.activeStreams[se.StreamID] + t.mu.Unlock() + if s != nil { + // use error detail to provide better err message + t.closeStream(s, streamErrorf(http2ErrConvTab[se.Code], "%v", t.framer.fr.ErrorDetail()), true, http2.ErrCodeProtocol, nil, nil, false) + } + continue + } else { + // Transport error. + t.Close() + return + } + } + switch frame := frame.(type) { + case *http2.MetaHeadersFrame: + t.operateHeaders(frame) + case *http2.DataFrame: + t.handleData(frame) + case *http2.RSTStreamFrame: + t.handleRSTStream(frame) + case *http2.SettingsFrame: + t.handleSettings(frame, false) + case *http2.PingFrame: + t.handlePing(frame) + case *http2.GoAwayFrame: + t.handleGoAway(frame) + case *http2.WindowUpdateFrame: + t.handleWindowUpdate(frame) + default: + errorf("transport: http2Client.reader got unhandled frame type %v.", frame) + } + } +} + +// keepalive running in a separate goroutune makes sure the connection is alive by sending pings. +func (t *http2Client) keepalive() { + p := &ping{data: [8]byte{}} + timer := time.NewTimer(t.kp.Time) + for { + select { + case <-timer.C: + if atomic.CompareAndSwapUint32(&t.activity, 1, 0) { + timer.Reset(t.kp.Time) + continue + } + // Check if keepalive should go dormant. + t.mu.Lock() + if len(t.activeStreams) < 1 && !t.kp.PermitWithoutStream { + // Make awakenKeepalive writable. + <-t.awakenKeepalive + t.mu.Unlock() + select { + case <-t.awakenKeepalive: + // If the control gets here a ping has been sent + // need to reset the timer with keepalive.Timeout. + case <-t.ctx.Done(): + return + } + } else { + t.mu.Unlock() + if channelz.IsOn() { + t.czmu.Lock() + t.kpCount++ + t.czmu.Unlock() + } + // Send ping. + t.controlBuf.put(p) + } + + // By the time control gets here a ping has been sent one way or the other. + timer.Reset(t.kp.Timeout) + select { + case <-timer.C: + if atomic.CompareAndSwapUint32(&t.activity, 1, 0) { + timer.Reset(t.kp.Time) + continue + } + t.Close() + return + case <-t.ctx.Done(): + if !timer.Stop() { + <-timer.C + } + return + } + case <-t.ctx.Done(): + if !timer.Stop() { + <-timer.C + } + return + } + } +} + +func (t *http2Client) Error() <-chan struct{} { + return t.ctx.Done() +} + +func (t *http2Client) GoAway() <-chan struct{} { + return t.goAway +} + +func (t *http2Client) ChannelzMetric() *channelz.SocketInternalMetric { + t.czmu.RLock() + s := channelz.SocketInternalMetric{ + StreamsStarted: t.streamsStarted, + StreamsSucceeded: t.streamsSucceeded, + StreamsFailed: t.streamsFailed, + MessagesSent: t.msgSent, + MessagesReceived: t.msgRecv, + KeepAlivesSent: t.kpCount, + LastLocalStreamCreatedTimestamp: t.lastStreamCreated, + LastMessageSentTimestamp: t.lastMsgSent, + LastMessageReceivedTimestamp: t.lastMsgRecv, + LocalFlowControlWindow: int64(t.fc.getSize()), + //socket options + LocalAddr: t.localAddr, + RemoteAddr: t.remoteAddr, + // Security + // RemoteName : + } + t.czmu.RUnlock() + s.RemoteFlowControlWindow = t.getOutFlowWindow() + return &s +} + +func (t *http2Client) IncrMsgSent() { + t.czmu.Lock() + t.msgSent++ + t.lastMsgSent = time.Now() + t.czmu.Unlock() +} + +func (t *http2Client) IncrMsgRecv() { + t.czmu.Lock() + t.msgRecv++ + t.lastMsgRecv = time.Now() + t.czmu.Unlock() +} + +func (t *http2Client) getOutFlowWindow() int64 { + resp := make(chan uint32, 1) + timer := time.NewTimer(time.Second) + defer timer.Stop() + t.controlBuf.put(&outFlowControlSizeRequest{resp}) + select { + case sz := <-resp: + return int64(sz) + case <-t.ctxDone: + return -1 + case <-timer.C: + return -2 + } +} diff --git a/vendor/google.golang.org/grpc/transport/http2_server.go b/vendor/google.golang.org/grpc/transport/http2_server.go new file mode 100644 index 00000000000..ab356189050 --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/http2_server.go @@ -0,0 +1,1137 @@ +/* + * + * Copyright 2014 gRPC 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 transport + +import ( + "bytes" + "errors" + "fmt" + "io" + "math" + "math/rand" + "net" + "strconv" + "sync" + "sync/atomic" + "time" + + "github.com/golang/protobuf/proto" + "golang.org/x/net/context" + "golang.org/x/net/http2" + "golang.org/x/net/http2/hpack" + + "google.golang.org/grpc/channelz" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/keepalive" + "google.golang.org/grpc/metadata" + "google.golang.org/grpc/peer" + "google.golang.org/grpc/stats" + "google.golang.org/grpc/status" + "google.golang.org/grpc/tap" +) + +// ErrIllegalHeaderWrite indicates that setting header is illegal because of +// the stream's state. +var ErrIllegalHeaderWrite = errors.New("transport: the stream is done or WriteHeader was already called") + +// http2Server implements the ServerTransport interface with HTTP2. +type http2Server struct { + ctx context.Context + ctxDone <-chan struct{} // Cache the context.Done() chan + cancel context.CancelFunc + conn net.Conn + loopy *loopyWriter + readerDone chan struct{} // sync point to enable testing. + writerDone chan struct{} // sync point to enable testing. + remoteAddr net.Addr + localAddr net.Addr + maxStreamID uint32 // max stream ID ever seen + authInfo credentials.AuthInfo // auth info about the connection + inTapHandle tap.ServerInHandle + framer *framer + // The max number of concurrent streams. + maxStreams uint32 + // controlBuf delivers all the control related tasks (e.g., window + // updates, reset streams, and various settings) to the controller. + controlBuf *controlBuffer + fc *trInFlow + stats stats.Handler + // Flag to keep track of reading activity on transport. + // 1 is true and 0 is false. + activity uint32 // Accessed atomically. + // Keepalive and max-age parameters for the server. + kp keepalive.ServerParameters + + // Keepalive enforcement policy. + kep keepalive.EnforcementPolicy + // The time instance last ping was received. + lastPingAt time.Time + // Number of times the client has violated keepalive ping policy so far. + pingStrikes uint8 + // Flag to signify that number of ping strikes should be reset to 0. + // This is set whenever data or header frames are sent. + // 1 means yes. + resetPingStrikes uint32 // Accessed atomically. + initialWindowSize int32 + bdpEst *bdpEstimator + + mu sync.Mutex // guard the following + + // drainChan is initialized when drain(...) is called the first time. + // After which the server writes out the first GoAway(with ID 2^31-1) frame. + // Then an independent goroutine will be launched to later send the second GoAway. + // During this time we don't want to write another first GoAway(with ID 2^31 -1) frame. + // Thus call to drain(...) will be a no-op if drainChan is already initialized since draining is + // already underway. + drainChan chan struct{} + state transportState + activeStreams map[uint32]*Stream + // idle is the time instant when the connection went idle. + // This is either the beginning of the connection or when the number of + // RPCs go down to 0. + // When the connection is busy, this value is set to 0. + idle time.Time + + // Fields below are for channelz metric collection. + channelzID int64 // channelz unique identification number + czmu sync.RWMutex + kpCount int64 + // The number of streams that have started, including already finished ones. + streamsStarted int64 + // The number of streams that have ended successfully by sending frame with + // EoS bit set. + streamsSucceeded int64 + streamsFailed int64 + lastStreamCreated time.Time + msgSent int64 + msgRecv int64 + lastMsgSent time.Time + lastMsgRecv time.Time +} + +// newHTTP2Server constructs a ServerTransport based on HTTP2. ConnectionError is +// returned if something goes wrong. +func newHTTP2Server(conn net.Conn, config *ServerConfig) (_ ServerTransport, err error) { + writeBufSize := defaultWriteBufSize + if config.WriteBufferSize > 0 { + writeBufSize = config.WriteBufferSize + } + readBufSize := defaultReadBufSize + if config.ReadBufferSize > 0 { + readBufSize = config.ReadBufferSize + } + framer := newFramer(conn, writeBufSize, readBufSize) + // Send initial settings as connection preface to client. + var isettings []http2.Setting + // TODO(zhaoq): Have a better way to signal "no limit" because 0 is + // permitted in the HTTP2 spec. + maxStreams := config.MaxStreams + if maxStreams == 0 { + maxStreams = math.MaxUint32 + } else { + isettings = append(isettings, http2.Setting{ + ID: http2.SettingMaxConcurrentStreams, + Val: maxStreams, + }) + } + dynamicWindow := true + iwz := int32(initialWindowSize) + if config.InitialWindowSize >= defaultWindowSize { + iwz = config.InitialWindowSize + dynamicWindow = false + } + icwz := int32(initialWindowSize) + if config.InitialConnWindowSize >= defaultWindowSize { + icwz = config.InitialConnWindowSize + dynamicWindow = false + } + if iwz != defaultWindowSize { + isettings = append(isettings, http2.Setting{ + ID: http2.SettingInitialWindowSize, + Val: uint32(iwz)}) + } + if err := framer.fr.WriteSettings(isettings...); err != nil { + return nil, connectionErrorf(false, err, "transport: %v", err) + } + // Adjust the connection flow control window if needed. + if delta := uint32(icwz - defaultWindowSize); delta > 0 { + if err := framer.fr.WriteWindowUpdate(0, delta); err != nil { + return nil, connectionErrorf(false, err, "transport: %v", err) + } + } + kp := config.KeepaliveParams + if kp.MaxConnectionIdle == 0 { + kp.MaxConnectionIdle = defaultMaxConnectionIdle + } + if kp.MaxConnectionAge == 0 { + kp.MaxConnectionAge = defaultMaxConnectionAge + } + // Add a jitter to MaxConnectionAge. + kp.MaxConnectionAge += getJitter(kp.MaxConnectionAge) + if kp.MaxConnectionAgeGrace == 0 { + kp.MaxConnectionAgeGrace = defaultMaxConnectionAgeGrace + } + if kp.Time == 0 { + kp.Time = defaultServerKeepaliveTime + } + if kp.Timeout == 0 { + kp.Timeout = defaultServerKeepaliveTimeout + } + kep := config.KeepalivePolicy + if kep.MinTime == 0 { + kep.MinTime = defaultKeepalivePolicyMinTime + } + ctx, cancel := context.WithCancel(context.Background()) + t := &http2Server{ + ctx: ctx, + cancel: cancel, + ctxDone: ctx.Done(), + conn: conn, + remoteAddr: conn.RemoteAddr(), + localAddr: conn.LocalAddr(), + authInfo: config.AuthInfo, + framer: framer, + readerDone: make(chan struct{}), + writerDone: make(chan struct{}), + maxStreams: maxStreams, + inTapHandle: config.InTapHandle, + fc: &trInFlow{limit: uint32(icwz)}, + state: reachable, + activeStreams: make(map[uint32]*Stream), + stats: config.StatsHandler, + kp: kp, + idle: time.Now(), + kep: kep, + initialWindowSize: iwz, + } + t.controlBuf = newControlBuffer(t.ctxDone) + if dynamicWindow { + t.bdpEst = &bdpEstimator{ + bdp: initialWindowSize, + updateFlowControl: t.updateFlowControl, + } + } + if t.stats != nil { + t.ctx = t.stats.TagConn(t.ctx, &stats.ConnTagInfo{ + RemoteAddr: t.remoteAddr, + LocalAddr: t.localAddr, + }) + connBegin := &stats.ConnBegin{} + t.stats.HandleConn(t.ctx, connBegin) + } + if channelz.IsOn() { + t.channelzID = channelz.RegisterNormalSocket(t, config.ChannelzParentID, "") + } + t.framer.writer.Flush() + + defer func() { + if err != nil { + t.Close() + } + }() + + // Check the validity of client preface. + preface := make([]byte, len(clientPreface)) + if _, err := io.ReadFull(t.conn, preface); err != nil { + return nil, connectionErrorf(false, err, "transport: http2Server.HandleStreams failed to receive the preface from client: %v", err) + } + if !bytes.Equal(preface, clientPreface) { + return nil, connectionErrorf(false, nil, "transport: http2Server.HandleStreams received bogus greeting from client: %q", preface) + } + + frame, err := t.framer.fr.ReadFrame() + if err == io.EOF || err == io.ErrUnexpectedEOF { + return nil, err + } + if err != nil { + return nil, connectionErrorf(false, err, "transport: http2Server.HandleStreams failed to read initial settings frame: %v", err) + } + atomic.StoreUint32(&t.activity, 1) + sf, ok := frame.(*http2.SettingsFrame) + if !ok { + return nil, connectionErrorf(false, nil, "transport: http2Server.HandleStreams saw invalid preface type %T from client", frame) + } + t.handleSettings(sf) + + go func() { + t.loopy = newLoopyWriter(serverSide, t.framer, t.controlBuf, t.bdpEst) + t.loopy.ssGoAwayHandler = t.outgoingGoAwayHandler + t.loopy.run() + t.conn.Close() + close(t.writerDone) + }() + go t.keepalive() + return t, nil +} + +// operateHeader takes action on the decoded headers. +func (t *http2Server) operateHeaders(frame *http2.MetaHeadersFrame, handle func(*Stream), traceCtx func(context.Context, string) context.Context) (close bool) { + streamID := frame.Header().StreamID + var state decodeState + for _, hf := range frame.Fields { + if err := state.processHeaderField(hf); err != nil { + if se, ok := err.(StreamError); ok { + t.controlBuf.put(&cleanupStream{ + streamID: streamID, + rst: true, + rstCode: statusCodeConvTab[se.Code], + onWrite: func() {}, + }) + } + return + } + } + + buf := newRecvBuffer() + s := &Stream{ + id: streamID, + st: t, + buf: buf, + fc: &inFlow{limit: uint32(t.initialWindowSize)}, + recvCompress: state.encoding, + method: state.method, + contentSubtype: state.contentSubtype, + } + if frame.StreamEnded() { + // s is just created by the caller. No lock needed. + s.state = streamReadDone + } + if state.timeoutSet { + s.ctx, s.cancel = context.WithTimeout(t.ctx, state.timeout) + } else { + s.ctx, s.cancel = context.WithCancel(t.ctx) + } + pr := &peer.Peer{ + Addr: t.remoteAddr, + } + // Attach Auth info if there is any. + if t.authInfo != nil { + pr.AuthInfo = t.authInfo + } + s.ctx = peer.NewContext(s.ctx, pr) + // Attach the received metadata to the context. + if len(state.mdata) > 0 { + s.ctx = metadata.NewIncomingContext(s.ctx, state.mdata) + } + if state.statsTags != nil { + s.ctx = stats.SetIncomingTags(s.ctx, state.statsTags) + } + if state.statsTrace != nil { + s.ctx = stats.SetIncomingTrace(s.ctx, state.statsTrace) + } + if t.inTapHandle != nil { + var err error + info := &tap.Info{ + FullMethodName: state.method, + } + s.ctx, err = t.inTapHandle(s.ctx, info) + if err != nil { + warningf("transport: http2Server.operateHeaders got an error from InTapHandle: %v", err) + t.controlBuf.put(&cleanupStream{ + streamID: s.id, + rst: true, + rstCode: http2.ErrCodeRefusedStream, + onWrite: func() {}, + }) + return + } + } + t.mu.Lock() + if t.state != reachable { + t.mu.Unlock() + return + } + if uint32(len(t.activeStreams)) >= t.maxStreams { + t.mu.Unlock() + t.controlBuf.put(&cleanupStream{ + streamID: streamID, + rst: true, + rstCode: http2.ErrCodeRefusedStream, + onWrite: func() {}, + }) + return + } + if streamID%2 != 1 || streamID <= t.maxStreamID { + t.mu.Unlock() + // illegal gRPC stream id. + errorf("transport: http2Server.HandleStreams received an illegal stream id: %v", streamID) + return true + } + t.maxStreamID = streamID + t.activeStreams[streamID] = s + if len(t.activeStreams) == 1 { + t.idle = time.Time{} + } + t.mu.Unlock() + if channelz.IsOn() { + t.czmu.Lock() + t.streamsStarted++ + t.lastStreamCreated = time.Now() + t.czmu.Unlock() + } + s.requestRead = func(n int) { + t.adjustWindow(s, uint32(n)) + } + s.ctx = traceCtx(s.ctx, s.method) + if t.stats != nil { + s.ctx = t.stats.TagRPC(s.ctx, &stats.RPCTagInfo{FullMethodName: s.method}) + inHeader := &stats.InHeader{ + FullMethod: s.method, + RemoteAddr: t.remoteAddr, + LocalAddr: t.localAddr, + Compression: s.recvCompress, + WireLength: int(frame.Header().Length), + } + t.stats.HandleRPC(s.ctx, inHeader) + } + s.ctxDone = s.ctx.Done() + s.wq = newWriteQuota(defaultWriteQuota, s.ctxDone) + s.trReader = &transportReader{ + reader: &recvBufferReader{ + ctx: s.ctx, + ctxDone: s.ctxDone, + recv: s.buf, + }, + windowHandler: func(n int) { + t.updateWindow(s, uint32(n)) + }, + } + handle(s) + return +} + +// HandleStreams receives incoming streams using the given handler. This is +// typically run in a separate goroutine. +// traceCtx attaches trace to ctx and returns the new context. +func (t *http2Server) HandleStreams(handle func(*Stream), traceCtx func(context.Context, string) context.Context) { + defer close(t.readerDone) + for { + frame, err := t.framer.fr.ReadFrame() + atomic.StoreUint32(&t.activity, 1) + if err != nil { + if se, ok := err.(http2.StreamError); ok { + warningf("transport: http2Server.HandleStreams encountered http2.StreamError: %v", se) + t.mu.Lock() + s := t.activeStreams[se.StreamID] + t.mu.Unlock() + if s != nil { + t.closeStream(s, true, se.Code, nil, false) + } else { + t.controlBuf.put(&cleanupStream{ + streamID: se.StreamID, + rst: true, + rstCode: se.Code, + onWrite: func() {}, + }) + } + continue + } + if err == io.EOF || err == io.ErrUnexpectedEOF { + t.Close() + return + } + warningf("transport: http2Server.HandleStreams failed to read frame: %v", err) + t.Close() + return + } + switch frame := frame.(type) { + case *http2.MetaHeadersFrame: + if t.operateHeaders(frame, handle, traceCtx) { + t.Close() + break + } + case *http2.DataFrame: + t.handleData(frame) + case *http2.RSTStreamFrame: + t.handleRSTStream(frame) + case *http2.SettingsFrame: + t.handleSettings(frame) + case *http2.PingFrame: + t.handlePing(frame) + case *http2.WindowUpdateFrame: + t.handleWindowUpdate(frame) + case *http2.GoAwayFrame: + // TODO: Handle GoAway from the client appropriately. + default: + errorf("transport: http2Server.HandleStreams found unhandled frame type %v.", frame) + } + } +} + +func (t *http2Server) getStream(f http2.Frame) (*Stream, bool) { + t.mu.Lock() + defer t.mu.Unlock() + if t.activeStreams == nil { + // The transport is closing. + return nil, false + } + s, ok := t.activeStreams[f.Header().StreamID] + if !ok { + // The stream is already done. + return nil, false + } + return s, true +} + +// adjustWindow sends out extra window update over the initial window size +// of stream if the application is requesting data larger in size than +// the window. +func (t *http2Server) adjustWindow(s *Stream, n uint32) { + if w := s.fc.maybeAdjust(n); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{streamID: s.id, increment: w}) + } + +} + +// updateWindow adjusts the inbound quota for the stream and the transport. +// Window updates will deliver to the controller for sending when +// the cumulative quota exceeds the corresponding threshold. +func (t *http2Server) updateWindow(s *Stream, n uint32) { + if w := s.fc.onRead(n); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{streamID: s.id, + increment: w, + }) + } +} + +// updateFlowControl updates the incoming flow control windows +// for the transport and the stream based on the current bdp +// estimation. +func (t *http2Server) updateFlowControl(n uint32) { + t.mu.Lock() + for _, s := range t.activeStreams { + s.fc.newLimit(n) + } + t.initialWindowSize = int32(n) + t.mu.Unlock() + t.controlBuf.put(&outgoingWindowUpdate{ + streamID: 0, + increment: t.fc.newLimit(n), + }) + t.controlBuf.put(&outgoingSettings{ + ss: []http2.Setting{ + { + ID: http2.SettingInitialWindowSize, + Val: n, + }, + }, + }) + +} + +func (t *http2Server) handleData(f *http2.DataFrame) { + size := f.Header().Length + var sendBDPPing bool + if t.bdpEst != nil { + sendBDPPing = t.bdpEst.add(size) + } + // Decouple connection's flow control from application's read. + // An update on connection's flow control should not depend on + // whether user application has read the data or not. Such a + // restriction is already imposed on the stream's flow control, + // and therefore the sender will be blocked anyways. + // Decoupling the connection flow control will prevent other + // active(fast) streams from starving in presence of slow or + // inactive streams. + if w := t.fc.onData(size); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{ + streamID: 0, + increment: w, + }) + } + if sendBDPPing { + // Avoid excessive ping detection (e.g. in an L7 proxy) + // by sending a window update prior to the BDP ping. + if w := t.fc.reset(); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{ + streamID: 0, + increment: w, + }) + } + t.controlBuf.put(bdpPing) + } + // Select the right stream to dispatch. + s, ok := t.getStream(f) + if !ok { + return + } + if size > 0 { + if err := s.fc.onData(size); err != nil { + t.closeStream(s, true, http2.ErrCodeFlowControl, nil, false) + return + } + if f.Header().Flags.Has(http2.FlagDataPadded) { + if w := s.fc.onRead(size - uint32(len(f.Data()))); w > 0 { + t.controlBuf.put(&outgoingWindowUpdate{s.id, w}) + } + } + // TODO(bradfitz, zhaoq): A copy is required here because there is no + // guarantee f.Data() is consumed before the arrival of next frame. + // Can this copy be eliminated? + if len(f.Data()) > 0 { + data := make([]byte, len(f.Data())) + copy(data, f.Data()) + s.write(recvMsg{data: data}) + } + } + if f.Header().Flags.Has(http2.FlagDataEndStream) { + // Received the end of stream from the client. + s.compareAndSwapState(streamActive, streamReadDone) + s.write(recvMsg{err: io.EOF}) + } +} + +func (t *http2Server) handleRSTStream(f *http2.RSTStreamFrame) { + s, ok := t.getStream(f) + if !ok { + return + } + t.closeStream(s, false, 0, nil, false) +} + +func (t *http2Server) handleSettings(f *http2.SettingsFrame) { + if f.IsAck() { + return + } + var ss []http2.Setting + f.ForeachSetting(func(s http2.Setting) error { + ss = append(ss, s) + return nil + }) + t.controlBuf.put(&incomingSettings{ + ss: ss, + }) +} + +const ( + maxPingStrikes = 2 + defaultPingTimeout = 2 * time.Hour +) + +func (t *http2Server) handlePing(f *http2.PingFrame) { + if f.IsAck() { + if f.Data == goAwayPing.data && t.drainChan != nil { + close(t.drainChan) + return + } + // Maybe it's a BDP ping. + if t.bdpEst != nil { + t.bdpEst.calculate(f.Data) + } + return + } + pingAck := &ping{ack: true} + copy(pingAck.data[:], f.Data[:]) + t.controlBuf.put(pingAck) + + now := time.Now() + defer func() { + t.lastPingAt = now + }() + // A reset ping strikes means that we don't need to check for policy + // violation for this ping and the pingStrikes counter should be set + // to 0. + if atomic.CompareAndSwapUint32(&t.resetPingStrikes, 1, 0) { + t.pingStrikes = 0 + return + } + t.mu.Lock() + ns := len(t.activeStreams) + t.mu.Unlock() + if ns < 1 && !t.kep.PermitWithoutStream { + // Keepalive shouldn't be active thus, this new ping should + // have come after at least defaultPingTimeout. + if t.lastPingAt.Add(defaultPingTimeout).After(now) { + t.pingStrikes++ + } + } else { + // Check if keepalive policy is respected. + if t.lastPingAt.Add(t.kep.MinTime).After(now) { + t.pingStrikes++ + } + } + + if t.pingStrikes > maxPingStrikes { + // Send goaway and close the connection. + errorf("transport: Got too many pings from the client, closing the connection.") + t.controlBuf.put(&goAway{code: http2.ErrCodeEnhanceYourCalm, debugData: []byte("too_many_pings"), closeConn: true}) + } +} + +func (t *http2Server) handleWindowUpdate(f *http2.WindowUpdateFrame) { + t.controlBuf.put(&incomingWindowUpdate{ + streamID: f.Header().StreamID, + increment: f.Increment, + }) +} + +func appendHeaderFieldsFromMD(headerFields []hpack.HeaderField, md metadata.MD) []hpack.HeaderField { + for k, vv := range md { + if isReservedHeader(k) { + // Clients don't tolerate reading restricted headers after some non restricted ones were sent. + continue + } + for _, v := range vv { + headerFields = append(headerFields, hpack.HeaderField{Name: k, Value: encodeMetadataHeader(k, v)}) + } + } + return headerFields +} + +// WriteHeader sends the header metedata md back to the client. +func (t *http2Server) WriteHeader(s *Stream, md metadata.MD) error { + if s.updateHeaderSent() || s.getState() == streamDone { + return ErrIllegalHeaderWrite + } + s.hdrMu.Lock() + if md.Len() > 0 { + if s.header.Len() > 0 { + s.header = metadata.Join(s.header, md) + } else { + s.header = md + } + } + t.writeHeaderLocked(s) + s.hdrMu.Unlock() + return nil +} + +func (t *http2Server) writeHeaderLocked(s *Stream) { + // TODO(mmukhi): Benchmark if the performance gets better if count the metadata and other header fields + // first and create a slice of that exact size. + headerFields := make([]hpack.HeaderField, 0, 2) // at least :status, content-type will be there if none else. + headerFields = append(headerFields, hpack.HeaderField{Name: ":status", Value: "200"}) + headerFields = append(headerFields, hpack.HeaderField{Name: "content-type", Value: contentType(s.contentSubtype)}) + if s.sendCompress != "" { + headerFields = append(headerFields, hpack.HeaderField{Name: "grpc-encoding", Value: s.sendCompress}) + } + headerFields = appendHeaderFieldsFromMD(headerFields, s.header) + t.controlBuf.put(&headerFrame{ + streamID: s.id, + hf: headerFields, + endStream: false, + onWrite: func() { + atomic.StoreUint32(&t.resetPingStrikes, 1) + }, + wq: s.wq, + }) + if t.stats != nil { + // Note: WireLength is not set in outHeader. + // TODO(mmukhi): Revisit this later, if needed. + outHeader := &stats.OutHeader{} + t.stats.HandleRPC(s.Context(), outHeader) + } +} + +// WriteStatus sends stream status to the client and terminates the stream. +// There is no further I/O operations being able to perform on this stream. +// TODO(zhaoq): Now it indicates the end of entire stream. Revisit if early +// OK is adopted. +func (t *http2Server) WriteStatus(s *Stream, st *status.Status) error { + if s.getState() == streamDone { + return nil + } + s.hdrMu.Lock() + // TODO(mmukhi): Benchmark if the performance gets better if count the metadata and other header fields + // first and create a slice of that exact size. + headerFields := make([]hpack.HeaderField, 0, 2) // grpc-status and grpc-message will be there if none else. + if !s.updateHeaderSent() { // No headers have been sent. + if len(s.header) > 0 { // Send a separate header frame. + t.writeHeaderLocked(s) + } else { // Send a trailer only response. + headerFields = append(headerFields, hpack.HeaderField{Name: ":status", Value: "200"}) + headerFields = append(headerFields, hpack.HeaderField{Name: "content-type", Value: contentType(s.contentSubtype)}) + } + } + headerFields = append(headerFields, hpack.HeaderField{Name: "grpc-status", Value: strconv.Itoa(int(st.Code()))}) + headerFields = append(headerFields, hpack.HeaderField{Name: "grpc-message", Value: encodeGrpcMessage(st.Message())}) + + if p := st.Proto(); p != nil && len(p.Details) > 0 { + stBytes, err := proto.Marshal(p) + if err != nil { + // TODO: return error instead, when callers are able to handle it. + panic(err) + } + + headerFields = append(headerFields, hpack.HeaderField{Name: "grpc-status-details-bin", Value: encodeBinHeader(stBytes)}) + } + + // Attach the trailer metadata. + headerFields = appendHeaderFieldsFromMD(headerFields, s.trailer) + trailingHeader := &headerFrame{ + streamID: s.id, + hf: headerFields, + endStream: true, + onWrite: func() { + atomic.StoreUint32(&t.resetPingStrikes, 1) + }, + } + s.hdrMu.Unlock() + t.closeStream(s, false, 0, trailingHeader, true) + if t.stats != nil { + t.stats.HandleRPC(s.Context(), &stats.OutTrailer{}) + } + return nil +} + +// Write converts the data into HTTP2 data frame and sends it out. Non-nil error +// is returns if it fails (e.g., framing error, transport error). +func (t *http2Server) Write(s *Stream, hdr []byte, data []byte, opts *Options) error { + if !s.isHeaderSent() { // Headers haven't been written yet. + if err := t.WriteHeader(s, nil); err != nil { + // TODO(mmukhi, dfawley): Make sure this is the right code to return. + return streamErrorf(codes.Internal, "transport: %v", err) + } + } else { + // Writing headers checks for this condition. + if s.getState() == streamDone { + // TODO(mmukhi, dfawley): Should the server write also return io.EOF? + s.cancel() + select { + case <-t.ctx.Done(): + return ErrConnClosing + default: + } + return ContextErr(s.ctx.Err()) + } + } + // Add some data to header frame so that we can equally distribute bytes across frames. + emptyLen := http2MaxFrameLen - len(hdr) + if emptyLen > len(data) { + emptyLen = len(data) + } + hdr = append(hdr, data[:emptyLen]...) + data = data[emptyLen:] + df := &dataFrame{ + streamID: s.id, + h: hdr, + d: data, + onEachWrite: func() { + atomic.StoreUint32(&t.resetPingStrikes, 1) + }, + } + if err := s.wq.get(int32(len(hdr) + len(data))); err != nil { + select { + case <-t.ctx.Done(): + return ErrConnClosing + default: + } + return ContextErr(s.ctx.Err()) + } + return t.controlBuf.put(df) +} + +// keepalive running in a separate goroutine does the following: +// 1. Gracefully closes an idle connection after a duration of keepalive.MaxConnectionIdle. +// 2. Gracefully closes any connection after a duration of keepalive.MaxConnectionAge. +// 3. Forcibly closes a connection after an additive period of keepalive.MaxConnectionAgeGrace over keepalive.MaxConnectionAge. +// 4. Makes sure a connection is alive by sending pings with a frequency of keepalive.Time and closes a non-responsive connection +// after an additional duration of keepalive.Timeout. +func (t *http2Server) keepalive() { + p := &ping{} + var pingSent bool + maxIdle := time.NewTimer(t.kp.MaxConnectionIdle) + maxAge := time.NewTimer(t.kp.MaxConnectionAge) + keepalive := time.NewTimer(t.kp.Time) + // NOTE: All exit paths of this function should reset their + // respective timers. A failure to do so will cause the + // following clean-up to deadlock and eventually leak. + defer func() { + if !maxIdle.Stop() { + <-maxIdle.C + } + if !maxAge.Stop() { + <-maxAge.C + } + if !keepalive.Stop() { + <-keepalive.C + } + }() + for { + select { + case <-maxIdle.C: + t.mu.Lock() + idle := t.idle + if idle.IsZero() { // The connection is non-idle. + t.mu.Unlock() + maxIdle.Reset(t.kp.MaxConnectionIdle) + continue + } + val := t.kp.MaxConnectionIdle - time.Since(idle) + t.mu.Unlock() + if val <= 0 { + // The connection has been idle for a duration of keepalive.MaxConnectionIdle or more. + // Gracefully close the connection. + t.drain(http2.ErrCodeNo, []byte{}) + // Resetting the timer so that the clean-up doesn't deadlock. + maxIdle.Reset(infinity) + return + } + maxIdle.Reset(val) + case <-maxAge.C: + t.drain(http2.ErrCodeNo, []byte{}) + maxAge.Reset(t.kp.MaxConnectionAgeGrace) + select { + case <-maxAge.C: + // Close the connection after grace period. + t.Close() + // Resetting the timer so that the clean-up doesn't deadlock. + maxAge.Reset(infinity) + case <-t.ctx.Done(): + } + return + case <-keepalive.C: + if atomic.CompareAndSwapUint32(&t.activity, 1, 0) { + pingSent = false + keepalive.Reset(t.kp.Time) + continue + } + if pingSent { + t.Close() + // Resetting the timer so that the clean-up doesn't deadlock. + keepalive.Reset(infinity) + return + } + pingSent = true + if channelz.IsOn() { + t.czmu.Lock() + t.kpCount++ + t.czmu.Unlock() + } + t.controlBuf.put(p) + keepalive.Reset(t.kp.Timeout) + case <-t.ctx.Done(): + return + } + } +} + +// Close starts shutting down the http2Server transport. +// TODO(zhaoq): Now the destruction is not blocked on any pending streams. This +// could cause some resource issue. Revisit this later. +func (t *http2Server) Close() error { + t.mu.Lock() + if t.state == closing { + t.mu.Unlock() + return errors.New("transport: Close() was already called") + } + t.state = closing + streams := t.activeStreams + t.activeStreams = nil + t.mu.Unlock() + t.controlBuf.finish() + t.cancel() + err := t.conn.Close() + if channelz.IsOn() { + channelz.RemoveEntry(t.channelzID) + } + // Cancel all active streams. + for _, s := range streams { + s.cancel() + } + if t.stats != nil { + connEnd := &stats.ConnEnd{} + t.stats.HandleConn(t.ctx, connEnd) + } + return err +} + +// closeStream clears the footprint of a stream when the stream is not needed +// any more. +func (t *http2Server) closeStream(s *Stream, rst bool, rstCode http2.ErrCode, hdr *headerFrame, eosReceived bool) { + if s.swapState(streamDone) == streamDone { + // If the stream was already done, return. + return + } + // In case stream sending and receiving are invoked in separate + // goroutines (e.g., bi-directional streaming), cancel needs to be + // called to interrupt the potential blocking on other goroutines. + s.cancel() + cleanup := &cleanupStream{ + streamID: s.id, + rst: rst, + rstCode: rstCode, + onWrite: func() { + t.mu.Lock() + if t.activeStreams != nil { + delete(t.activeStreams, s.id) + if len(t.activeStreams) == 0 { + t.idle = time.Now() + } + } + t.mu.Unlock() + if channelz.IsOn() { + t.czmu.Lock() + if eosReceived { + t.streamsSucceeded++ + } else { + t.streamsFailed++ + } + t.czmu.Unlock() + } + }, + } + if hdr != nil { + hdr.cleanup = cleanup + t.controlBuf.put(hdr) + } else { + t.controlBuf.put(cleanup) + } +} + +func (t *http2Server) RemoteAddr() net.Addr { + return t.remoteAddr +} + +func (t *http2Server) Drain() { + t.drain(http2.ErrCodeNo, []byte{}) +} + +func (t *http2Server) drain(code http2.ErrCode, debugData []byte) { + t.mu.Lock() + defer t.mu.Unlock() + if t.drainChan != nil { + return + } + t.drainChan = make(chan struct{}) + t.controlBuf.put(&goAway{code: code, debugData: debugData, headsUp: true}) +} + +var goAwayPing = &ping{data: [8]byte{1, 6, 1, 8, 0, 3, 3, 9}} + +// Handles outgoing GoAway and returns true if loopy needs to put itself +// in draining mode. +func (t *http2Server) outgoingGoAwayHandler(g *goAway) (bool, error) { + t.mu.Lock() + if t.state == closing { // TODO(mmukhi): This seems unnecessary. + t.mu.Unlock() + // The transport is closing. + return false, ErrConnClosing + } + sid := t.maxStreamID + if !g.headsUp { + // Stop accepting more streams now. + t.state = draining + if len(t.activeStreams) == 0 { + g.closeConn = true + } + t.mu.Unlock() + if err := t.framer.fr.WriteGoAway(sid, g.code, g.debugData); err != nil { + return false, err + } + if g.closeConn { + // Abruptly close the connection following the GoAway (via + // loopywriter). But flush out what's inside the buffer first. + t.framer.writer.Flush() + return false, fmt.Errorf("transport: Connection closing") + } + return true, nil + } + t.mu.Unlock() + // For a graceful close, send out a GoAway with stream ID of MaxUInt32, + // Follow that with a ping and wait for the ack to come back or a timer + // to expire. During this time accept new streams since they might have + // originated before the GoAway reaches the client. + // After getting the ack or timer expiration send out another GoAway this + // time with an ID of the max stream server intends to process. + if err := t.framer.fr.WriteGoAway(math.MaxUint32, http2.ErrCodeNo, []byte{}); err != nil { + return false, err + } + if err := t.framer.fr.WritePing(false, goAwayPing.data); err != nil { + return false, err + } + go func() { + timer := time.NewTimer(time.Minute) + defer timer.Stop() + select { + case <-t.drainChan: + case <-timer.C: + case <-t.ctx.Done(): + return + } + t.controlBuf.put(&goAway{code: g.code, debugData: g.debugData}) + }() + return false, nil +} + +func (t *http2Server) ChannelzMetric() *channelz.SocketInternalMetric { + t.czmu.RLock() + s := channelz.SocketInternalMetric{ + StreamsStarted: t.streamsStarted, + StreamsSucceeded: t.streamsSucceeded, + StreamsFailed: t.streamsFailed, + MessagesSent: t.msgSent, + MessagesReceived: t.msgRecv, + KeepAlivesSent: t.kpCount, + LastRemoteStreamCreatedTimestamp: t.lastStreamCreated, + LastMessageSentTimestamp: t.lastMsgSent, + LastMessageReceivedTimestamp: t.lastMsgRecv, + LocalFlowControlWindow: int64(t.fc.getSize()), + //socket options + LocalAddr: t.localAddr, + RemoteAddr: t.remoteAddr, + // Security + // RemoteName : + } + t.czmu.RUnlock() + s.RemoteFlowControlWindow = t.getOutFlowWindow() + return &s +} + +func (t *http2Server) IncrMsgSent() { + t.czmu.Lock() + t.msgSent++ + t.lastMsgSent = time.Now() + t.czmu.Unlock() +} + +func (t *http2Server) IncrMsgRecv() { + t.czmu.Lock() + t.msgRecv++ + t.lastMsgRecv = time.Now() + t.czmu.Unlock() +} + +func (t *http2Server) getOutFlowWindow() int64 { + resp := make(chan uint32) + timer := time.NewTimer(time.Second) + defer timer.Stop() + t.controlBuf.put(&outFlowControlSizeRequest{resp}) + select { + case sz := <-resp: + return int64(sz) + case <-t.ctxDone: + return -1 + case <-timer.C: + return -2 + } +} + +var rgen = rand.New(rand.NewSource(time.Now().UnixNano())) + +func getJitter(v time.Duration) time.Duration { + if v == infinity { + return 0 + } + // Generate a jitter between +/- 10% of the value. + r := int64(v / 10) + j := rgen.Int63n(2*r) - r + return time.Duration(j) +} diff --git a/vendor/google.golang.org/grpc/transport/http_util.go b/vendor/google.golang.org/grpc/transport/http_util.go new file mode 100644 index 00000000000..835c8126946 --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/http_util.go @@ -0,0 +1,578 @@ +/* + * + * Copyright 2014 gRPC 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 transport + +import ( + "bufio" + "bytes" + "encoding/base64" + "fmt" + "net" + "net/http" + "strconv" + "strings" + "time" + + "github.com/golang/protobuf/proto" + "golang.org/x/net/http2" + "golang.org/x/net/http2/hpack" + spb "google.golang.org/genproto/googleapis/rpc/status" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/status" +) + +const ( + // http2MaxFrameLen specifies the max length of a HTTP2 frame. + http2MaxFrameLen = 16384 // 16KB frame + // http://http2.github.io/http2-spec/#SettingValues + http2InitHeaderTableSize = 4096 + // http2IOBufSize specifies the buffer size for sending frames. + defaultWriteBufSize = 32 * 1024 + defaultReadBufSize = 32 * 1024 + // baseContentType is the base content-type for gRPC. This is a valid + // content-type on it's own, but can also include a content-subtype such as + // "proto" as a suffix after "+" or ";". See + // https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#requests + // for more details. + baseContentType = "application/grpc" +) + +var ( + clientPreface = []byte(http2.ClientPreface) + http2ErrConvTab = map[http2.ErrCode]codes.Code{ + http2.ErrCodeNo: codes.Internal, + http2.ErrCodeProtocol: codes.Internal, + http2.ErrCodeInternal: codes.Internal, + http2.ErrCodeFlowControl: codes.ResourceExhausted, + http2.ErrCodeSettingsTimeout: codes.Internal, + http2.ErrCodeStreamClosed: codes.Internal, + http2.ErrCodeFrameSize: codes.Internal, + http2.ErrCodeRefusedStream: codes.Unavailable, + http2.ErrCodeCancel: codes.Canceled, + http2.ErrCodeCompression: codes.Internal, + http2.ErrCodeConnect: codes.Internal, + http2.ErrCodeEnhanceYourCalm: codes.ResourceExhausted, + http2.ErrCodeInadequateSecurity: codes.PermissionDenied, + http2.ErrCodeHTTP11Required: codes.Internal, + } + statusCodeConvTab = map[codes.Code]http2.ErrCode{ + codes.Internal: http2.ErrCodeInternal, + codes.Canceled: http2.ErrCodeCancel, + codes.Unavailable: http2.ErrCodeRefusedStream, + codes.ResourceExhausted: http2.ErrCodeEnhanceYourCalm, + codes.PermissionDenied: http2.ErrCodeInadequateSecurity, + } + httpStatusConvTab = map[int]codes.Code{ + // 400 Bad Request - INTERNAL. + http.StatusBadRequest: codes.Internal, + // 401 Unauthorized - UNAUTHENTICATED. + http.StatusUnauthorized: codes.Unauthenticated, + // 403 Forbidden - PERMISSION_DENIED. + http.StatusForbidden: codes.PermissionDenied, + // 404 Not Found - UNIMPLEMENTED. + http.StatusNotFound: codes.Unimplemented, + // 429 Too Many Requests - UNAVAILABLE. + http.StatusTooManyRequests: codes.Unavailable, + // 502 Bad Gateway - UNAVAILABLE. + http.StatusBadGateway: codes.Unavailable, + // 503 Service Unavailable - UNAVAILABLE. + http.StatusServiceUnavailable: codes.Unavailable, + // 504 Gateway timeout - UNAVAILABLE. + http.StatusGatewayTimeout: codes.Unavailable, + } +) + +// Records the states during HPACK decoding. Must be reset once the +// decoding of the entire headers are finished. +type decodeState struct { + encoding string + // statusGen caches the stream status received from the trailer the server + // sent. Client side only. Do not access directly. After all trailers are + // parsed, use the status method to retrieve the status. + statusGen *status.Status + // rawStatusCode and rawStatusMsg are set from the raw trailer fields and are not + // intended for direct access outside of parsing. + rawStatusCode *int + rawStatusMsg string + httpStatus *int + // Server side only fields. + timeoutSet bool + timeout time.Duration + method string + // key-value metadata map from the peer. + mdata map[string][]string + statsTags []byte + statsTrace []byte + contentSubtype string +} + +// isReservedHeader checks whether hdr belongs to HTTP2 headers +// reserved by gRPC protocol. Any other headers are classified as the +// user-specified metadata. +func isReservedHeader(hdr string) bool { + if hdr != "" && hdr[0] == ':' { + return true + } + switch hdr { + case "content-type", + "user-agent", + "grpc-message-type", + "grpc-encoding", + "grpc-message", + "grpc-status", + "grpc-timeout", + "grpc-status-details-bin", + "te": + return true + default: + return false + } +} + +// isWhitelistedHeader checks whether hdr should be propagated +// into metadata visible to users. +func isWhitelistedHeader(hdr string) bool { + switch hdr { + case ":authority", "user-agent": + return true + default: + return false + } +} + +// contentSubtype returns the content-subtype for the given content-type. The +// given content-type must be a valid content-type that starts with +// "application/grpc". A content-subtype will follow "application/grpc" after a +// "+" or ";". See +// https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#requests for +// more details. +// +// If contentType is not a valid content-type for gRPC, the boolean +// will be false, otherwise true. If content-type == "application/grpc", +// "application/grpc+", or "application/grpc;", the boolean will be true, +// but no content-subtype will be returned. +// +// contentType is assumed to be lowercase already. +func contentSubtype(contentType string) (string, bool) { + if contentType == baseContentType { + return "", true + } + if !strings.HasPrefix(contentType, baseContentType) { + return "", false + } + // guaranteed since != baseContentType and has baseContentType prefix + switch contentType[len(baseContentType)] { + case '+', ';': + // this will return true for "application/grpc+" or "application/grpc;" + // which the previous validContentType function tested to be valid, so we + // just say that no content-subtype is specified in this case + return contentType[len(baseContentType)+1:], true + default: + return "", false + } +} + +// contentSubtype is assumed to be lowercase +func contentType(contentSubtype string) string { + if contentSubtype == "" { + return baseContentType + } + return baseContentType + "+" + contentSubtype +} + +func (d *decodeState) status() *status.Status { + if d.statusGen == nil { + // No status-details were provided; generate status using code/msg. + d.statusGen = status.New(codes.Code(int32(*(d.rawStatusCode))), d.rawStatusMsg) + } + return d.statusGen +} + +const binHdrSuffix = "-bin" + +func encodeBinHeader(v []byte) string { + return base64.RawStdEncoding.EncodeToString(v) +} + +func decodeBinHeader(v string) ([]byte, error) { + if len(v)%4 == 0 { + // Input was padded, or padding was not necessary. + return base64.StdEncoding.DecodeString(v) + } + return base64.RawStdEncoding.DecodeString(v) +} + +func encodeMetadataHeader(k, v string) string { + if strings.HasSuffix(k, binHdrSuffix) { + return encodeBinHeader(([]byte)(v)) + } + return v +} + +func decodeMetadataHeader(k, v string) (string, error) { + if strings.HasSuffix(k, binHdrSuffix) { + b, err := decodeBinHeader(v) + return string(b), err + } + return v, nil +} + +func (d *decodeState) decodeResponseHeader(frame *http2.MetaHeadersFrame) error { + for _, hf := range frame.Fields { + if err := d.processHeaderField(hf); err != nil { + return err + } + } + + // If grpc status exists, no need to check further. + if d.rawStatusCode != nil || d.statusGen != nil { + return nil + } + + // If grpc status doesn't exist and http status doesn't exist, + // then it's a malformed header. + if d.httpStatus == nil { + return streamErrorf(codes.Internal, "malformed header: doesn't contain status(gRPC or HTTP)") + } + + if *(d.httpStatus) != http.StatusOK { + code, ok := httpStatusConvTab[*(d.httpStatus)] + if !ok { + code = codes.Unknown + } + return streamErrorf(code, http.StatusText(*(d.httpStatus))) + } + + // gRPC status doesn't exist and http status is OK. + // Set rawStatusCode to be unknown and return nil error. + // So that, if the stream has ended this Unknown status + // will be propagated to the user. + // Otherwise, it will be ignored. In which case, status from + // a later trailer, that has StreamEnded flag set, is propagated. + code := int(codes.Unknown) + d.rawStatusCode = &code + return nil + +} + +func (d *decodeState) addMetadata(k, v string) { + if d.mdata == nil { + d.mdata = make(map[string][]string) + } + d.mdata[k] = append(d.mdata[k], v) +} + +func (d *decodeState) processHeaderField(f hpack.HeaderField) error { + switch f.Name { + case "content-type": + contentSubtype, validContentType := contentSubtype(f.Value) + if !validContentType { + return streamErrorf(codes.Internal, "transport: received the unexpected content-type %q", f.Value) + } + d.contentSubtype = contentSubtype + // TODO: do we want to propagate the whole content-type in the metadata, + // or come up with a way to just propagate the content-subtype if it was set? + // ie {"content-type": "application/grpc+proto"} or {"content-subtype": "proto"} + // in the metadata? + d.addMetadata(f.Name, f.Value) + case "grpc-encoding": + d.encoding = f.Value + case "grpc-status": + code, err := strconv.Atoi(f.Value) + if err != nil { + return streamErrorf(codes.Internal, "transport: malformed grpc-status: %v", err) + } + d.rawStatusCode = &code + case "grpc-message": + d.rawStatusMsg = decodeGrpcMessage(f.Value) + case "grpc-status-details-bin": + v, err := decodeBinHeader(f.Value) + if err != nil { + return streamErrorf(codes.Internal, "transport: malformed grpc-status-details-bin: %v", err) + } + s := &spb.Status{} + if err := proto.Unmarshal(v, s); err != nil { + return streamErrorf(codes.Internal, "transport: malformed grpc-status-details-bin: %v", err) + } + d.statusGen = status.FromProto(s) + case "grpc-timeout": + d.timeoutSet = true + var err error + if d.timeout, err = decodeTimeout(f.Value); err != nil { + return streamErrorf(codes.Internal, "transport: malformed time-out: %v", err) + } + case ":path": + d.method = f.Value + case ":status": + code, err := strconv.Atoi(f.Value) + if err != nil { + return streamErrorf(codes.Internal, "transport: malformed http-status: %v", err) + } + d.httpStatus = &code + case "grpc-tags-bin": + v, err := decodeBinHeader(f.Value) + if err != nil { + return streamErrorf(codes.Internal, "transport: malformed grpc-tags-bin: %v", err) + } + d.statsTags = v + d.addMetadata(f.Name, string(v)) + case "grpc-trace-bin": + v, err := decodeBinHeader(f.Value) + if err != nil { + return streamErrorf(codes.Internal, "transport: malformed grpc-trace-bin: %v", err) + } + d.statsTrace = v + d.addMetadata(f.Name, string(v)) + default: + if isReservedHeader(f.Name) && !isWhitelistedHeader(f.Name) { + break + } + v, err := decodeMetadataHeader(f.Name, f.Value) + if err != nil { + errorf("Failed to decode metadata header (%q, %q): %v", f.Name, f.Value, err) + return nil + } + d.addMetadata(f.Name, v) + } + return nil +} + +type timeoutUnit uint8 + +const ( + hour timeoutUnit = 'H' + minute timeoutUnit = 'M' + second timeoutUnit = 'S' + millisecond timeoutUnit = 'm' + microsecond timeoutUnit = 'u' + nanosecond timeoutUnit = 'n' +) + +func timeoutUnitToDuration(u timeoutUnit) (d time.Duration, ok bool) { + switch u { + case hour: + return time.Hour, true + case minute: + return time.Minute, true + case second: + return time.Second, true + case millisecond: + return time.Millisecond, true + case microsecond: + return time.Microsecond, true + case nanosecond: + return time.Nanosecond, true + default: + } + return +} + +const maxTimeoutValue int64 = 100000000 - 1 + +// div does integer division and round-up the result. Note that this is +// equivalent to (d+r-1)/r but has less chance to overflow. +func div(d, r time.Duration) int64 { + if m := d % r; m > 0 { + return int64(d/r + 1) + } + return int64(d / r) +} + +// TODO(zhaoq): It is the simplistic and not bandwidth efficient. Improve it. +func encodeTimeout(t time.Duration) string { + if t <= 0 { + return "0n" + } + if d := div(t, time.Nanosecond); d <= maxTimeoutValue { + return strconv.FormatInt(d, 10) + "n" + } + if d := div(t, time.Microsecond); d <= maxTimeoutValue { + return strconv.FormatInt(d, 10) + "u" + } + if d := div(t, time.Millisecond); d <= maxTimeoutValue { + return strconv.FormatInt(d, 10) + "m" + } + if d := div(t, time.Second); d <= maxTimeoutValue { + return strconv.FormatInt(d, 10) + "S" + } + if d := div(t, time.Minute); d <= maxTimeoutValue { + return strconv.FormatInt(d, 10) + "M" + } + // Note that maxTimeoutValue * time.Hour > MaxInt64. + return strconv.FormatInt(div(t, time.Hour), 10) + "H" +} + +func decodeTimeout(s string) (time.Duration, error) { + size := len(s) + if size < 2 { + return 0, fmt.Errorf("transport: timeout string is too short: %q", s) + } + unit := timeoutUnit(s[size-1]) + d, ok := timeoutUnitToDuration(unit) + if !ok { + return 0, fmt.Errorf("transport: timeout unit is not recognized: %q", s) + } + t, err := strconv.ParseInt(s[:size-1], 10, 64) + if err != nil { + return 0, err + } + return d * time.Duration(t), nil +} + +const ( + spaceByte = ' ' + tildaByte = '~' + percentByte = '%' +) + +// encodeGrpcMessage is used to encode status code in header field +// "grpc-message". +// It checks to see if each individual byte in msg is an +// allowable byte, and then either percent encoding or passing it through. +// When percent encoding, the byte is converted into hexadecimal notation +// with a '%' prepended. +func encodeGrpcMessage(msg string) string { + if msg == "" { + return "" + } + lenMsg := len(msg) + for i := 0; i < lenMsg; i++ { + c := msg[i] + if !(c >= spaceByte && c < tildaByte && c != percentByte) { + return encodeGrpcMessageUnchecked(msg) + } + } + return msg +} + +func encodeGrpcMessageUnchecked(msg string) string { + var buf bytes.Buffer + lenMsg := len(msg) + for i := 0; i < lenMsg; i++ { + c := msg[i] + if c >= spaceByte && c < tildaByte && c != percentByte { + buf.WriteByte(c) + } else { + buf.WriteString(fmt.Sprintf("%%%02X", c)) + } + } + return buf.String() +} + +// decodeGrpcMessage decodes the msg encoded by encodeGrpcMessage. +func decodeGrpcMessage(msg string) string { + if msg == "" { + return "" + } + lenMsg := len(msg) + for i := 0; i < lenMsg; i++ { + if msg[i] == percentByte && i+2 < lenMsg { + return decodeGrpcMessageUnchecked(msg) + } + } + return msg +} + +func decodeGrpcMessageUnchecked(msg string) string { + var buf bytes.Buffer + lenMsg := len(msg) + for i := 0; i < lenMsg; i++ { + c := msg[i] + if c == percentByte && i+2 < lenMsg { + parsed, err := strconv.ParseUint(msg[i+1:i+3], 16, 8) + if err != nil { + buf.WriteByte(c) + } else { + buf.WriteByte(byte(parsed)) + i += 2 + } + } else { + buf.WriteByte(c) + } + } + return buf.String() +} + +type bufWriter struct { + buf []byte + offset int + batchSize int + conn net.Conn + err error + + onFlush func() +} + +func newBufWriter(conn net.Conn, batchSize int) *bufWriter { + return &bufWriter{ + buf: make([]byte, batchSize*2), + batchSize: batchSize, + conn: conn, + } +} + +func (w *bufWriter) Write(b []byte) (n int, err error) { + if w.err != nil { + return 0, w.err + } + for len(b) > 0 { + nn := copy(w.buf[w.offset:], b) + b = b[nn:] + w.offset += nn + n += nn + if w.offset >= w.batchSize { + err = w.Flush() + } + } + return n, err +} + +func (w *bufWriter) Flush() error { + if w.err != nil { + return w.err + } + if w.offset == 0 { + return nil + } + if w.onFlush != nil { + w.onFlush() + } + _, w.err = w.conn.Write(w.buf[:w.offset]) + w.offset = 0 + return w.err +} + +type framer struct { + writer *bufWriter + fr *http2.Framer +} + +func newFramer(conn net.Conn, writeBufferSize, readBufferSize int) *framer { + r := bufio.NewReaderSize(conn, readBufferSize) + w := newBufWriter(conn, writeBufferSize) + f := &framer{ + writer: w, + fr: http2.NewFramer(w, r), + } + // Opt-in to Frame reuse API on framer to reduce garbage. + // Frames aren't safe to read from after a subsequent call to ReadFrame. + f.fr.SetReuseFrames() + f.fr.ReadMetaHeaders = hpack.NewDecoder(http2InitHeaderTableSize, nil) + return f +} diff --git a/vendor/google.golang.org/grpc/transport/log.go b/vendor/google.golang.org/grpc/transport/log.go new file mode 100644 index 00000000000..ac8e358c5c8 --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/log.go @@ -0,0 +1,50 @@ +/* + * + * Copyright 2017 gRPC 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 contains wrappers for grpclog functions. +// The transport package only logs to verbose level 2 by default. + +package transport + +import "google.golang.org/grpc/grpclog" + +const logLevel = 2 + +func infof(format string, args ...interface{}) { + if grpclog.V(logLevel) { + grpclog.Infof(format, args...) + } +} + +func warningf(format string, args ...interface{}) { + if grpclog.V(logLevel) { + grpclog.Warningf(format, args...) + } +} + +func errorf(format string, args ...interface{}) { + if grpclog.V(logLevel) { + grpclog.Errorf(format, args...) + } +} + +func fatalf(format string, args ...interface{}) { + if grpclog.V(logLevel) { + grpclog.Fatalf(format, args...) + } +} diff --git a/vendor/google.golang.org/grpc/transport/transport.go b/vendor/google.golang.org/grpc/transport/transport.go new file mode 100644 index 00000000000..f51f878884d --- /dev/null +++ b/vendor/google.golang.org/grpc/transport/transport.go @@ -0,0 +1,708 @@ +/* + * + * Copyright 2014 gRPC 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 transport defines and implements message oriented communication +// channel to complete various transactions (e.g., an RPC). It is meant for +// grpc-internal usage and is not intended to be imported directly by users. +package transport // externally used as import "google.golang.org/grpc/transport" + +import ( + "errors" + "fmt" + "io" + "net" + "sync" + "sync/atomic" + + "golang.org/x/net/context" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/keepalive" + "google.golang.org/grpc/metadata" + "google.golang.org/grpc/stats" + "google.golang.org/grpc/status" + "google.golang.org/grpc/tap" +) + +// recvMsg represents the received msg from the transport. All transport +// protocol specific info has been removed. +type recvMsg struct { + data []byte + // nil: received some data + // io.EOF: stream is completed. data is nil. + // other non-nil error: transport failure. data is nil. + err error +} + +// recvBuffer is an unbounded channel of recvMsg structs. +// Note recvBuffer differs from controlBuffer only in that recvBuffer +// holds a channel of only recvMsg structs instead of objects implementing "item" interface. +// recvBuffer is written to much more often than +// controlBuffer and using strict recvMsg structs helps avoid allocation in "recvBuffer.put" +type recvBuffer struct { + c chan recvMsg + mu sync.Mutex + backlog []recvMsg + err error +} + +func newRecvBuffer() *recvBuffer { + b := &recvBuffer{ + c: make(chan recvMsg, 1), + } + return b +} + +func (b *recvBuffer) put(r recvMsg) { + b.mu.Lock() + if b.err != nil { + b.mu.Unlock() + // An error had occurred earlier, don't accept more + // data or errors. + return + } + b.err = r.err + if len(b.backlog) == 0 { + select { + case b.c <- r: + b.mu.Unlock() + return + default: + } + } + b.backlog = append(b.backlog, r) + b.mu.Unlock() +} + +func (b *recvBuffer) load() { + b.mu.Lock() + if len(b.backlog) > 0 { + select { + case b.c <- b.backlog[0]: + b.backlog[0] = recvMsg{} + b.backlog = b.backlog[1:] + default: + } + } + b.mu.Unlock() +} + +// get returns the channel that receives a recvMsg in the buffer. +// +// Upon receipt of a recvMsg, the caller should call load to send another +// recvMsg onto the channel if there is any. +func (b *recvBuffer) get() <-chan recvMsg { + return b.c +} + +// +// recvBufferReader implements io.Reader interface to read the data from +// recvBuffer. +type recvBufferReader struct { + ctx context.Context + ctxDone <-chan struct{} // cache of ctx.Done() (for performance). + recv *recvBuffer + last []byte // Stores the remaining data in the previous calls. + err error +} + +// Read reads the next len(p) bytes from last. If last is drained, it tries to +// read additional data from recv. It blocks if there no additional data available +// in recv. If Read returns any non-nil error, it will continue to return that error. +func (r *recvBufferReader) Read(p []byte) (n int, err error) { + if r.err != nil { + return 0, r.err + } + n, r.err = r.read(p) + return n, r.err +} + +func (r *recvBufferReader) read(p []byte) (n int, err error) { + if r.last != nil && len(r.last) > 0 { + // Read remaining data left in last call. + copied := copy(p, r.last) + r.last = r.last[copied:] + return copied, nil + } + select { + case <-r.ctxDone: + return 0, ContextErr(r.ctx.Err()) + case m := <-r.recv.get(): + r.recv.load() + if m.err != nil { + return 0, m.err + } + copied := copy(p, m.data) + r.last = m.data[copied:] + return copied, nil + } +} + +type streamState uint32 + +const ( + streamActive streamState = iota + streamWriteDone // EndStream sent + streamReadDone // EndStream received + streamDone // the entire stream is finished. +) + +// Stream represents an RPC in the transport layer. +type Stream struct { + id uint32 + st ServerTransport // nil for client side Stream + ctx context.Context // the associated context of the stream + cancel context.CancelFunc // always nil for client side Stream + done chan struct{} // closed at the end of stream to unblock writers. On the client side. + ctxDone <-chan struct{} // same as done chan but for server side. Cache of ctx.Done() (for performance) + method string // the associated RPC method of the stream + recvCompress string + sendCompress string + buf *recvBuffer + trReader io.Reader + fc *inFlow + recvQuota uint32 + wq *writeQuota + + // Callback to state application's intentions to read data. This + // is used to adjust flow control, if needed. + requestRead func(int) + + headerChan chan struct{} // closed to indicate the end of header metadata. + headerDone uint32 // set when headerChan is closed. Used to avoid closing headerChan multiple times. + + // hdrMu protects header and trailer metadata on the server-side. + hdrMu sync.Mutex + header metadata.MD // the received header metadata. + trailer metadata.MD // the key-value map of trailer metadata. + + // On the server-side, headerSent is atomically set to 1 when the headers are sent out. + headerSent uint32 + + state streamState + + // On client-side it is the status error received from the server. + // On server-side it is unused. + status *status.Status + + bytesReceived uint32 // indicates whether any bytes have been received on this stream + unprocessed uint32 // set if the server sends a refused stream or GOAWAY including this stream + + // contentSubtype is the content-subtype for requests. + // this must be lowercase or the behavior is undefined. + contentSubtype string +} + +// isHeaderSent is only valid on the server-side. +func (s *Stream) isHeaderSent() bool { + return atomic.LoadUint32(&s.headerSent) == 1 +} + +// updateHeaderSent updates headerSent and returns true +// if it was alreay set. It is valid only on server-side. +func (s *Stream) updateHeaderSent() bool { + return atomic.SwapUint32(&s.headerSent, 1) == 1 +} + +func (s *Stream) swapState(st streamState) streamState { + return streamState(atomic.SwapUint32((*uint32)(&s.state), uint32(st))) +} + +func (s *Stream) compareAndSwapState(oldState, newState streamState) bool { + return atomic.CompareAndSwapUint32((*uint32)(&s.state), uint32(oldState), uint32(newState)) +} + +func (s *Stream) getState() streamState { + return streamState(atomic.LoadUint32((*uint32)(&s.state))) +} + +func (s *Stream) waitOnHeader() error { + if s.headerChan == nil { + // On the server headerChan is always nil since a stream originates + // only after having received headers. + return nil + } + select { + case <-s.ctx.Done(): + return ContextErr(s.ctx.Err()) + case <-s.headerChan: + return nil + } +} + +// RecvCompress returns the compression algorithm applied to the inbound +// message. It is empty string if there is no compression applied. +func (s *Stream) RecvCompress() string { + if err := s.waitOnHeader(); err != nil { + return "" + } + return s.recvCompress +} + +// SetSendCompress sets the compression algorithm to the stream. +func (s *Stream) SetSendCompress(str string) { + s.sendCompress = str +} + +// Done returns a chanel which is closed when it receives the final status +// from the server. +func (s *Stream) Done() <-chan struct{} { + return s.done +} + +// Header acquires the key-value pairs of header metadata once it +// is available. It blocks until i) the metadata is ready or ii) there is no +// header metadata or iii) the stream is canceled/expired. +func (s *Stream) Header() (metadata.MD, error) { + err := s.waitOnHeader() + // Even if the stream is closed, header is returned if available. + select { + case <-s.headerChan: + if s.header == nil { + return nil, nil + } + return s.header.Copy(), nil + default: + } + return nil, err +} + +// Trailer returns the cached trailer metedata. Note that if it is not called +// after the entire stream is done, it could return an empty MD. Client +// side only. +// It can be safely read only after stream has ended that is either read +// or write have returned io.EOF. +func (s *Stream) Trailer() metadata.MD { + c := s.trailer.Copy() + return c +} + +// ServerTransport returns the underlying ServerTransport for the stream. +// The client side stream always returns nil. +func (s *Stream) ServerTransport() ServerTransport { + return s.st +} + +// ContentSubtype returns the content-subtype for a request. For example, a +// content-subtype of "proto" will result in a content-type of +// "application/grpc+proto". This will always be lowercase. See +// https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#requests for +// more details. +func (s *Stream) ContentSubtype() string { + return s.contentSubtype +} + +// Context returns the context of the stream. +func (s *Stream) Context() context.Context { + return s.ctx +} + +// Method returns the method for the stream. +func (s *Stream) Method() string { + return s.method +} + +// Status returns the status received from the server. +// Status can be read safely only after the stream has ended, +// that is, read or write has returned io.EOF. +func (s *Stream) Status() *status.Status { + return s.status +} + +// SetHeader sets the header metadata. This can be called multiple times. +// Server side only. +// This should not be called in parallel to other data writes. +func (s *Stream) SetHeader(md metadata.MD) error { + if md.Len() == 0 { + return nil + } + if s.isHeaderSent() || s.getState() == streamDone { + return ErrIllegalHeaderWrite + } + s.hdrMu.Lock() + s.header = metadata.Join(s.header, md) + s.hdrMu.Unlock() + return nil +} + +// SendHeader sends the given header metadata. The given metadata is +// combined with any metadata set by previous calls to SetHeader and +// then written to the transport stream. +func (s *Stream) SendHeader(md metadata.MD) error { + t := s.ServerTransport() + return t.WriteHeader(s, md) +} + +// SetTrailer sets the trailer metadata which will be sent with the RPC status +// by the server. This can be called multiple times. Server side only. +// This should not be called parallel to other data writes. +func (s *Stream) SetTrailer(md metadata.MD) error { + if md.Len() == 0 { + return nil + } + if s.getState() == streamDone { + return ErrIllegalHeaderWrite + } + s.hdrMu.Lock() + s.trailer = metadata.Join(s.trailer, md) + s.hdrMu.Unlock() + return nil +} + +func (s *Stream) write(m recvMsg) { + s.buf.put(m) +} + +// Read reads all p bytes from the wire for this stream. +func (s *Stream) Read(p []byte) (n int, err error) { + // Don't request a read if there was an error earlier + if er := s.trReader.(*transportReader).er; er != nil { + return 0, er + } + s.requestRead(len(p)) + return io.ReadFull(s.trReader, p) +} + +// tranportReader reads all the data available for this Stream from the transport and +// passes them into the decoder, which converts them into a gRPC message stream. +// The error is io.EOF when the stream is done or another non-nil error if +// the stream broke. +type transportReader struct { + reader io.Reader + // The handler to control the window update procedure for both this + // particular stream and the associated transport. + windowHandler func(int) + er error +} + +func (t *transportReader) Read(p []byte) (n int, err error) { + n, err = t.reader.Read(p) + if err != nil { + t.er = err + return + } + t.windowHandler(n) + return +} + +// BytesReceived indicates whether any bytes have been received on this stream. +func (s *Stream) BytesReceived() bool { + return atomic.LoadUint32(&s.bytesReceived) == 1 +} + +// Unprocessed indicates whether the server did not process this stream -- +// i.e. it sent a refused stream or GOAWAY including this stream ID. +func (s *Stream) Unprocessed() bool { + return atomic.LoadUint32(&s.unprocessed) == 1 +} + +// GoString is implemented by Stream so context.String() won't +// race when printing %#v. +func (s *Stream) GoString() string { + return fmt.Sprintf("", s, s.method) +} + +// state of transport +type transportState int + +const ( + reachable transportState = iota + closing + draining +) + +// ServerConfig consists of all the configurations to establish a server transport. +type ServerConfig struct { + MaxStreams uint32 + AuthInfo credentials.AuthInfo + InTapHandle tap.ServerInHandle + StatsHandler stats.Handler + KeepaliveParams keepalive.ServerParameters + KeepalivePolicy keepalive.EnforcementPolicy + InitialWindowSize int32 + InitialConnWindowSize int32 + WriteBufferSize int + ReadBufferSize int + ChannelzParentID int64 +} + +// NewServerTransport creates a ServerTransport with conn or non-nil error +// if it fails. +func NewServerTransport(protocol string, conn net.Conn, config *ServerConfig) (ServerTransport, error) { + return newHTTP2Server(conn, config) +} + +// ConnectOptions covers all relevant options for communicating with the server. +type ConnectOptions struct { + // UserAgent is the application user agent. + UserAgent string + // Authority is the :authority pseudo-header to use. This field has no effect if + // TransportCredentials is set. + Authority string + // Dialer specifies how to dial a network address. + Dialer func(context.Context, string) (net.Conn, error) + // FailOnNonTempDialError specifies if gRPC fails on non-temporary dial errors. + FailOnNonTempDialError bool + // PerRPCCredentials stores the PerRPCCredentials required to issue RPCs. + PerRPCCredentials []credentials.PerRPCCredentials + // TransportCredentials stores the Authenticator required to setup a client connection. + TransportCredentials credentials.TransportCredentials + // KeepaliveParams stores the keepalive parameters. + KeepaliveParams keepalive.ClientParameters + // StatsHandler stores the handler for stats. + StatsHandler stats.Handler + // InitialWindowSize sets the initial window size for a stream. + InitialWindowSize int32 + // InitialConnWindowSize sets the initial window size for a connection. + InitialConnWindowSize int32 + // WriteBufferSize sets the size of write buffer which in turn determines how much data can be batched before it's written on the wire. + WriteBufferSize int + // ReadBufferSize sets the size of read buffer, which in turn determines how much data can be read at most for one read syscall. + ReadBufferSize int + // ChannelzParentID sets the addrConn id which initiate the creation of this client transport. + ChannelzParentID int64 +} + +// TargetInfo contains the information of the target such as network address and metadata. +type TargetInfo struct { + Addr string + Metadata interface{} + Authority string +} + +// NewClientTransport establishes the transport with the required ConnectOptions +// and returns it to the caller. +func NewClientTransport(connectCtx, ctx context.Context, target TargetInfo, opts ConnectOptions, onSuccess func()) (ClientTransport, error) { + return newHTTP2Client(connectCtx, ctx, target, opts, onSuccess) +} + +// Options provides additional hints and information for message +// transmission. +type Options struct { + // Last indicates whether this write is the last piece for + // this stream. + Last bool + + // Delay is a hint to the transport implementation for whether + // the data could be buffered for a batching write. The + // transport implementation may ignore the hint. + Delay bool +} + +// CallHdr carries the information of a particular RPC. +type CallHdr struct { + // Host specifies the peer's host. + Host string + + // Method specifies the operation to perform. + Method string + + // SendCompress specifies the compression algorithm applied on + // outbound message. + SendCompress string + + // Creds specifies credentials.PerRPCCredentials for a call. + Creds credentials.PerRPCCredentials + + // Flush indicates whether a new stream command should be sent + // to the peer without waiting for the first data. This is + // only a hint. + // If it's true, the transport may modify the flush decision + // for performance purposes. + // If it's false, new stream will never be flushed. + Flush bool + + // ContentSubtype specifies the content-subtype for a request. For example, a + // content-subtype of "proto" will result in a content-type of + // "application/grpc+proto". The value of ContentSubtype must be all + // lowercase, otherwise the behavior is undefined. See + // https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#requests + // for more details. + ContentSubtype string +} + +// ClientTransport is the common interface for all gRPC client-side transport +// implementations. +type ClientTransport interface { + // Close tears down this transport. Once it returns, the transport + // should not be accessed any more. The caller must make sure this + // is called only once. + Close() error + + // GracefulClose starts to tear down the transport. It stops accepting + // new RPCs and wait the completion of the pending RPCs. + GracefulClose() error + + // Write sends the data for the given stream. A nil stream indicates + // the write is to be performed on the transport as a whole. + Write(s *Stream, hdr []byte, data []byte, opts *Options) error + + // NewStream creates a Stream for an RPC. + NewStream(ctx context.Context, callHdr *CallHdr) (*Stream, error) + + // CloseStream clears the footprint of a stream when the stream is + // not needed any more. The err indicates the error incurred when + // CloseStream is called. Must be called when a stream is finished + // unless the associated transport is closing. + CloseStream(stream *Stream, err error) + + // Error returns a channel that is closed when some I/O error + // happens. Typically the caller should have a goroutine to monitor + // this in order to take action (e.g., close the current transport + // and create a new one) in error case. It should not return nil + // once the transport is initiated. + Error() <-chan struct{} + + // GoAway returns a channel that is closed when ClientTransport + // receives the draining signal from the server (e.g., GOAWAY frame in + // HTTP/2). + GoAway() <-chan struct{} + + // GetGoAwayReason returns the reason why GoAway frame was received. + GetGoAwayReason() GoAwayReason + + // IncrMsgSent increments the number of message sent through this transport. + IncrMsgSent() + + // IncrMsgRecv increments the number of message received through this transport. + IncrMsgRecv() +} + +// ServerTransport is the common interface for all gRPC server-side transport +// implementations. +// +// Methods may be called concurrently from multiple goroutines, but +// Write methods for a given Stream will be called serially. +type ServerTransport interface { + // HandleStreams receives incoming streams using the given handler. + HandleStreams(func(*Stream), func(context.Context, string) context.Context) + + // WriteHeader sends the header metadata for the given stream. + // WriteHeader may not be called on all streams. + WriteHeader(s *Stream, md metadata.MD) error + + // Write sends the data for the given stream. + // Write may not be called on all streams. + Write(s *Stream, hdr []byte, data []byte, opts *Options) error + + // WriteStatus sends the status of a stream to the client. WriteStatus is + // the final call made on a stream and always occurs. + WriteStatus(s *Stream, st *status.Status) error + + // Close tears down the transport. Once it is called, the transport + // should not be accessed any more. All the pending streams and their + // handlers will be terminated asynchronously. + Close() error + + // RemoteAddr returns the remote network address. + RemoteAddr() net.Addr + + // Drain notifies the client this ServerTransport stops accepting new RPCs. + Drain() + + // IncrMsgSent increments the number of message sent through this transport. + IncrMsgSent() + + // IncrMsgRecv increments the number of message received through this transport. + IncrMsgRecv() +} + +// streamErrorf creates an StreamError with the specified error code and description. +func streamErrorf(c codes.Code, format string, a ...interface{}) StreamError { + return StreamError{ + Code: c, + Desc: fmt.Sprintf(format, a...), + } +} + +// connectionErrorf creates an ConnectionError with the specified error description. +func connectionErrorf(temp bool, e error, format string, a ...interface{}) ConnectionError { + return ConnectionError{ + Desc: fmt.Sprintf(format, a...), + temp: temp, + err: e, + } +} + +// ConnectionError is an error that results in the termination of the +// entire connection and the retry of all the active streams. +type ConnectionError struct { + Desc string + temp bool + err error +} + +func (e ConnectionError) Error() string { + return fmt.Sprintf("connection error: desc = %q", e.Desc) +} + +// Temporary indicates if this connection error is temporary or fatal. +func (e ConnectionError) Temporary() bool { + return e.temp +} + +// Origin returns the original error of this connection error. +func (e ConnectionError) Origin() error { + // Never return nil error here. + // If the original error is nil, return itself. + if e.err == nil { + return e + } + return e.err +} + +var ( + // ErrConnClosing indicates that the transport is closing. + ErrConnClosing = connectionErrorf(true, nil, "transport is closing") + // errStreamDrain indicates that the stream is rejected because the + // connection is draining. This could be caused by goaway or balancer + // removing the address. + errStreamDrain = streamErrorf(codes.Unavailable, "the connection is draining") + // errStreamDone is returned from write at the client side to indiacte application + // layer of an error. + errStreamDone = errors.New("the stream is done") + // StatusGoAway indicates that the server sent a GOAWAY that included this + // stream's ID in unprocessed RPCs. + statusGoAway = status.New(codes.Unavailable, "the stream is rejected because server is draining the connection") +) + +// TODO: See if we can replace StreamError with status package errors. + +// StreamError is an error that only affects one stream within a connection. +type StreamError struct { + Code codes.Code + Desc string +} + +func (e StreamError) Error() string { + return fmt.Sprintf("stream error: code = %s desc = %q", e.Code, e.Desc) +} + +// GoAwayReason contains the reason for the GoAway frame received. +type GoAwayReason uint8 + +const ( + // GoAwayInvalid indicates that no GoAway frame is received. + GoAwayInvalid GoAwayReason = 0 + // GoAwayNoReason is the default value when GoAway frame is received. + GoAwayNoReason GoAwayReason = 1 + // GoAwayTooManyPings indicates that a GoAway frame with + // ErrCodeEnhanceYourCalm was received and that the debug data said + // "too_many_pings". + GoAwayTooManyPings GoAwayReason = 2 +) diff --git a/vendor/google.golang.org/grpc/vet.sh b/vendor/google.golang.org/grpc/vet.sh new file mode 100755 index 00000000000..6126ab64bd1 --- /dev/null +++ b/vendor/google.golang.org/grpc/vet.sh @@ -0,0 +1,93 @@ +#!/bin/bash + +if [[ `uname -a` = *"Darwin"* ]]; then + echo "It seems you are running on Mac. This script does not work on Mac. See https://github.com/grpc/grpc-go/issues/2047" + exit 1 +fi + +set -ex # Exit on error; debugging enabled. +set -o pipefail # Fail a pipe if any sub-command fails. + +die() { + echo "$@" >&2 + exit 1 +} + +PATH="$GOPATH/bin:$GOROOT/bin:$PATH" + +# Check proto in manual runs or cron runs. +if [[ "$TRAVIS" != "true" || "$TRAVIS_EVENT_TYPE" = "cron" ]]; then + check_proto="true" +fi + +if [ "$1" = "-install" ]; then + go get -d \ + google.golang.org/grpc/... + go get -u \ + github.com/golang/lint/golint \ + golang.org/x/tools/cmd/goimports \ + honnef.co/go/tools/cmd/staticcheck \ + github.com/client9/misspell/cmd/misspell \ + github.com/golang/protobuf/protoc-gen-go + if [[ "$check_proto" = "true" ]]; then + if [[ "$TRAVIS" = "true" ]]; then + PROTOBUF_VERSION=3.3.0 + PROTOC_FILENAME=protoc-${PROTOBUF_VERSION}-linux-x86_64.zip + pushd /home/travis + wget https://github.com/google/protobuf/releases/download/v${PROTOBUF_VERSION}/${PROTOC_FILENAME} + unzip ${PROTOC_FILENAME} + bin/protoc --version + popd + elif ! which protoc > /dev/null; then + die "Please install protoc into your path" + fi + fi + exit 0 +elif [[ "$#" -ne 0 ]]; then + die "Unknown argument(s): $*" +fi + +# TODO: Remove this check and the mangling below once "context" is imported +# directly. +if git status --porcelain | read; then + die "Uncommitted or untracked files found; commit changes first" +fi + +git ls-files "*.go" | xargs grep -L "\(Copyright [0-9]\{4,\} gRPC authors\)\|DO NOT EDIT" 2>&1 | tee /dev/stderr | (! read) +git ls-files "*.go" | xargs grep -l "\"unsafe\"" 2>&1 | (! grep -v '_test.go') | tee /dev/stderr | (! read) +gofmt -s -d -l . 2>&1 | tee /dev/stderr | (! read) +goimports -l . 2>&1 | tee /dev/stderr | (! read) +golint ./... 2>&1 | (grep -vE "(_mock|\.pb)\.go:" || true) | tee /dev/stderr | (! read) + +# Undo any edits made by this script. +cleanup() { + git reset --hard HEAD +} +trap cleanup EXIT + +# Rewrite golang.org/x/net/context -> context imports (see grpc/grpc-go#1484). +# TODO: Remove this mangling once "context" is imported directly (grpc/grpc-go#711). +git ls-files "*.go" | xargs sed -i 's:"golang.org/x/net/context":"context":' +set +o pipefail +# TODO: Stop filtering pb.go files once golang/protobuf#214 is fixed. +go tool vet -all . 2>&1 | grep -vE '(clientconn|transport\/transport_test).go:.*cancel (function|var)' | grep -vF '.pb.go:' | tee /dev/stderr | (! read) +set -o pipefail +git reset --hard HEAD + +if [[ "$check_proto" = "true" ]]; then + PATH="/home/travis/bin:$PATH" make proto && \ + git status --porcelain 2>&1 | (! read) || \ + (git status; git --no-pager diff; exit 1) +fi + +# TODO(menghanl): fix errors in transport_test. +staticcheck -ignore ' +google.golang.org/grpc/transport/transport_test.go:SA2002 +google.golang.org/grpc/benchmark/benchmain/main.go:SA1019 +google.golang.org/grpc/stats/stats_test.go:SA1019 +google.golang.org/grpc/test/end2end_test.go:SA1019 +google.golang.org/grpc/balancer_test.go:SA1019 +google.golang.org/grpc/balancer.go:SA1019 +google.golang.org/grpc/clientconn_test.go:SA1019 +' ./... +misspell -error . diff --git a/vendor/gopkg.in/inf.v0/dec.go b/vendor/gopkg.in/inf.v0/dec.go index 3b4afedf1a3..26548b63cef 100644 --- a/vendor/gopkg.in/inf.v0/dec.go +++ b/vendor/gopkg.in/inf.v0/dec.go @@ -104,7 +104,7 @@ var bigInt = [...]*big.Int{ var exp10cache [64]big.Int = func() [64]big.Int { e10, e10i := [64]big.Int{}, bigInt[1] - for i, _ := range e10 { + for i := range e10 { e10[i].Set(e10i) e10i = new(big.Int).Mul(e10i, bigInt[10]) } diff --git a/vendor/gopkg.in/yaml.v2/README.md b/vendor/gopkg.in/yaml.v2/README.md index 2ed3314c739..b50c6e87755 100644 --- a/vendor/gopkg.in/yaml.v2/README.md +++ b/vendor/gopkg.in/yaml.v2/README.md @@ -48,8 +48,6 @@ The yaml package is licensed under the Apache License 2.0. Please see the LICENS Example ------- -Some more examples can be found in the "examples" folder. - ```Go package main diff --git a/vendor/gopkg.in/yaml.v2/apic.go b/vendor/gopkg.in/yaml.v2/apic.go index 3e24a0d7d27..1f7e87e6727 100644 --- a/vendor/gopkg.in/yaml.v2/apic.go +++ b/vendor/gopkg.in/yaml.v2/apic.go @@ -468,7 +468,7 @@ func yaml_event_delete(event *yaml_event_t) { // } context // tag_directive *yaml_tag_directive_t // -// context.error = YAML_NO_ERROR // Eliminate a compliler warning. +// context.error = YAML_NO_ERROR // Eliminate a compiler warning. // // assert(document) // Non-NULL document object is expected. // diff --git a/vendor/gopkg.in/yaml.v2/decode.go b/vendor/gopkg.in/yaml.v2/decode.go index c8eac164287..e4e56e28e0e 100644 --- a/vendor/gopkg.in/yaml.v2/decode.go +++ b/vendor/gopkg.in/yaml.v2/decode.go @@ -113,6 +113,10 @@ func (p *parser) fail() { var line int if p.parser.problem_mark.line != 0 { line = p.parser.problem_mark.line + // Scanner errors don't iterate line before returning error + if p.parser.error == yaml_SCANNER_ERROR { + line++ + } } else if p.parser.context_mark.line != 0 { line = p.parser.context_mark.line } @@ -430,6 +434,7 @@ func (d *decoder) scalar(n *node, out reflect.Value) bool { // reasons we set it as a string, so that code that unmarshals // timestamp-like values into interface{} will continue to // see a string and not a time.Time. + // TODO(v3) Drop this. out.Set(reflect.ValueOf(n.value)) } else { out.Set(reflect.ValueOf(resolved)) @@ -542,6 +547,10 @@ func (d *decoder) sequence(n *node, out reflect.Value) (good bool) { switch out.Kind() { case reflect.Slice: out.Set(reflect.MakeSlice(out.Type(), l, l)) + case reflect.Array: + if l != out.Len() { + failf("invalid array: want %d elements but got %d", out.Len(), l) + } case reflect.Interface: // No type hints. Will have to use a generic sequence. iface = out @@ -560,7 +569,9 @@ func (d *decoder) sequence(n *node, out reflect.Value) (good bool) { j++ } } - out.Set(out.Slice(0, j)) + if out.Kind() != reflect.Array { + out.Set(out.Slice(0, j)) + } if iface.IsValid() { iface.Set(out) } diff --git a/vendor/gopkg.in/yaml.v2/emitterc.go b/vendor/gopkg.in/yaml.v2/emitterc.go index cf0db118ac9..a1c2cc52627 100644 --- a/vendor/gopkg.in/yaml.v2/emitterc.go +++ b/vendor/gopkg.in/yaml.v2/emitterc.go @@ -843,7 +843,7 @@ func yaml_emitter_select_scalar_style(emitter *yaml_emitter_t, event *yaml_event return true } -// Write an achor. +// Write an anchor. func yaml_emitter_process_anchor(emitter *yaml_emitter_t) bool { if emitter.anchor_data.anchor == nil { return true diff --git a/vendor/gopkg.in/yaml.v2/encode.go b/vendor/gopkg.in/yaml.v2/encode.go index 1e730eff6a8..a14435e82f8 100644 --- a/vendor/gopkg.in/yaml.v2/encode.go +++ b/vendor/gopkg.in/yaml.v2/encode.go @@ -131,7 +131,7 @@ func (e *encoder) marshal(tag string, in reflect.Value) { } else { e.structv(tag, in) } - case reflect.Slice: + case reflect.Slice, reflect.Array: if in.Type().Elem() == mapItemType { e.itemsv(tag, in) } else { @@ -328,14 +328,18 @@ func (e *encoder) uintv(tag string, in reflect.Value) { func (e *encoder) timev(tag string, in reflect.Value) { t := in.Interface().(time.Time) - if tag == "" { - tag = yaml_TIMESTAMP_TAG - } - e.emitScalar(t.Format(time.RFC3339Nano), "", tag, yaml_PLAIN_SCALAR_STYLE) + s := t.Format(time.RFC3339Nano) + e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE) } func (e *encoder) floatv(tag string, in reflect.Value) { - s := strconv.FormatFloat(in.Float(), 'g', -1, 64) + // Issue #352: When formatting, use the precision of the underlying value + precision := 64 + if in.Kind() == reflect.Float32 { + precision = 32 + } + + s := strconv.FormatFloat(in.Float(), 'g', -1, precision) switch s { case "+Inf": s = ".inf" diff --git a/vendor/gopkg.in/yaml.v2/readerc.go b/vendor/gopkg.in/yaml.v2/readerc.go index f450791717b..7c1f5fac3db 100644 --- a/vendor/gopkg.in/yaml.v2/readerc.go +++ b/vendor/gopkg.in/yaml.v2/readerc.go @@ -93,9 +93,18 @@ func yaml_parser_update_buffer(parser *yaml_parser_t, length int) bool { panic("read handler must be set") } + // [Go] This function was changed to guarantee the requested length size at EOF. + // The fact we need to do this is pretty awful, but the description above implies + // for that to be the case, and there are tests + // 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 + // [Go] ACTUALLY! Read the documentation of this function above. + // This is just broken. To return true, we need to have the + // given length in the buffer. Not doing that means every single + // check that calls this function to make sure the buffer has a + // given length is Go) panicking; or C) accessing invalid memory. + //return true } // Return if the buffer contains enough characters. @@ -389,6 +398,15 @@ func yaml_parser_update_buffer(parser *yaml_parser_t, length int) bool { break } } + // [Go] Read the documentation of this function above. To return true, + // we need to have the given length in the buffer. Not doing that means + // every single check that calls this function to make sure the buffer + // has a given length is Go) panicking; or C) accessing invalid memory. + // This happens here due to the EOF above breaking early. + for buffer_len < length { + parser.buffer[buffer_len] = 0 + buffer_len++ + } parser.buffer = parser.buffer[:buffer_len] return true } diff --git a/vendor/gopkg.in/yaml.v2/resolve.go b/vendor/gopkg.in/yaml.v2/resolve.go index ea90bd5e0de..6c151db6fbd 100644 --- a/vendor/gopkg.in/yaml.v2/resolve.go +++ b/vendor/gopkg.in/yaml.v2/resolve.go @@ -92,6 +92,19 @@ func resolve(tag string, in string) (rtag string, out interface{}) { switch tag { case "", rtag, yaml_STR_TAG, yaml_BINARY_TAG: return + case yaml_FLOAT_TAG: + if rtag == yaml_INT_TAG { + switch v := out.(type) { + case int64: + rtag = yaml_FLOAT_TAG + out = float64(v) + return + case int: + rtag = yaml_FLOAT_TAG + out = float64(v) + return + } + } } failf("cannot decode %s `%s` as a %s", shortTag(rtag), in, shortTag(tag)) }() @@ -167,12 +180,12 @@ func resolve(tag string, in string) (rtag string, out interface{}) { return yaml_INT_TAG, uintv } } else if strings.HasPrefix(plain, "-0b") { - intv, err := strconv.ParseInt(plain[3:], 2, 64) + intv, err := strconv.ParseInt("-" + plain[3:], 2, 64) if err == nil { - if intv == int64(int(intv)) { - return yaml_INT_TAG, -int(intv) + if true || intv == int64(int(intv)) { + return yaml_INT_TAG, int(intv) } else { - return yaml_INT_TAG, -intv + return yaml_INT_TAG, intv } } } @@ -211,10 +224,10 @@ func encodeBase64(s string) string { // This is a subset of the formats allowed by the regular expression // defined at http://yaml.org/type/timestamp.html. var allowedTimestampFormats = []string{ - "2006-1-2T15:4:5Z07:00", - "2006-1-2t15:4:5Z07:00", // RFC3339 with lower-case "t". - "2006-1-2 15:4:5", // space separated with no time zone - "2006-1-2", // date only + "2006-1-2T15:4:5.999999999Z07:00", // RCF3339Nano with short date fields. + "2006-1-2t15:4:5.999999999Z07:00", // RFC3339Nano with short date fields and lower-case "t". + "2006-1-2 15:4:5.999999999", // space separated with no time zone + "2006-1-2", // date only // Notable exception: time.Parse cannot handle: "2001-12-14 21:59:43.10 -5" // from the set of examples. } diff --git a/vendor/gopkg.in/yaml.v2/scannerc.go b/vendor/gopkg.in/yaml.v2/scannerc.go index 492a9845dac..077fd1dd2d4 100644 --- a/vendor/gopkg.in/yaml.v2/scannerc.go +++ b/vendor/gopkg.in/yaml.v2/scannerc.go @@ -871,12 +871,6 @@ func yaml_parser_save_simple_key(parser *yaml_parser_t) bool { 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. // @@ -2475,6 +2469,10 @@ func yaml_parser_scan_flow_scalar(parser *yaml_parser_t, token *yaml_token_t, si } } + if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { + return false + } + // Check if we are at the end of the scalar. if single { if parser.buffer[parser.buffer_pos] == '\'' { @@ -2487,10 +2485,6 @@ func yaml_parser_scan_flow_scalar(parser *yaml_parser_t, token *yaml_token_t, si } // 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. @@ -2647,10 +2641,10 @@ func yaml_parser_scan_plain_scalar(parser *yaml_parser_t, token *yaml_token_t) b 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. + // Check for tab characters 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") + start_mark, "found a tab character that violates indentation") return false } diff --git a/vendor/gopkg.in/yaml.v2/sorter.go b/vendor/gopkg.in/yaml.v2/sorter.go index 5958822f9c6..4c45e660a8f 100644 --- a/vendor/gopkg.in/yaml.v2/sorter.go +++ b/vendor/gopkg.in/yaml.v2/sorter.go @@ -51,6 +51,15 @@ func (l keyList) Less(i, j int) bool { } var ai, bi int var an, bn int64 + if ar[i] == '0' || br[i] == '0' { + for j := i-1; j >= 0 && unicode.IsDigit(ar[j]); j-- { + if ar[j] != '0' { + an = 1 + bn = 1 + break + } + } + } for ai = i; ai < len(ar) && unicode.IsDigit(ar[ai]); ai++ { an = an*10 + int64(ar[ai]-'0') } diff --git a/vendor/gopkg.in/yaml.v2/yaml.go b/vendor/gopkg.in/yaml.v2/yaml.go index 483aae58781..de85aa4cdb7 100644 --- a/vendor/gopkg.in/yaml.v2/yaml.go +++ b/vendor/gopkg.in/yaml.v2/yaml.go @@ -157,8 +157,8 @@ func unmarshal(in []byte, out interface{}, strict bool) (err error) { // 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 +// Struct fields are only marshalled if they are exported (have an upper case +// first letter), and are marshalled 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. diff --git a/vendor/k8s.io/helm/pkg/chartutil/chartfile.go b/vendor/k8s.io/helm/pkg/chartutil/chartfile.go index 9897d66ff04..c2879cdae57 100644 --- a/vendor/k8s.io/helm/pkg/chartutil/chartfile.go +++ b/vendor/k8s.io/helm/pkg/chartutil/chartfile.go @@ -31,7 +31,7 @@ import ( // ApiVersionV1 is the API version number for version 1. // // This is ApiVersionV1 instead of APIVersionV1 to match the protobuf-generated name. -const ApiVersionV1 = "v1" +const ApiVersionV1 = "v1" // nolint // UnmarshalChartfile takes raw Chart.yaml data and unmarshals it. func UnmarshalChartfile(data []byte) (*chart.Metadata, error) { diff --git a/vendor/k8s.io/helm/pkg/chartutil/create.go b/vendor/k8s.io/helm/pkg/chartutil/create.go index 319a75e2f50..ec84ba7729f 100644 --- a/vendor/k8s.io/helm/pkg/chartutil/create.go +++ b/vendor/k8s.io/helm/pkg/chartutil/create.go @@ -120,7 +120,6 @@ const defaultIgnore = `# Patterns to ignore when building packages. const defaultIngress = `{{- if .Values.ingress.enabled -}} {{- $fullName := include ".fullname" . -}} -{{- $servicePort := .Values.service.port -}} {{- $ingressPath := .Values.ingress.path -}} apiVersion: extensions/v1beta1 kind: Ingress diff --git a/vendor/k8s.io/helm/pkg/chartutil/expand.go b/vendor/k8s.io/helm/pkg/chartutil/expand.go index ae28f814752..126e14e8005 100644 --- a/vendor/k8s.io/helm/pkg/chartutil/expand.go +++ b/vendor/k8s.io/helm/pkg/chartutil/expand.go @@ -63,11 +63,12 @@ func Expand(dir string, r io.Reader) error { if err != nil { return err } - defer file.Close() _, err = io.Copy(file, tr) if err != nil { + file.Close() return err } + file.Close() } return nil } diff --git a/vendor/k8s.io/helm/pkg/chartutil/files.go b/vendor/k8s.io/helm/pkg/chartutil/files.go index 687a9a8d61d..a711a336626 100644 --- a/vendor/k8s.io/helm/pkg/chartutil/files.go +++ b/vendor/k8s.io/helm/pkg/chartutil/files.go @@ -220,10 +220,10 @@ func ToJson(v interface{}) string { return string(data) } -// FromJson converts a YAML document into a map[string]interface{}. +// FromJson converts a JSON document into a map[string]interface{}. // // This is not a general-purpose JSON parser, and will not parse all valid -// YAML documents. Additionally, because its intended use is within templates +// JSON documents. Additionally, because its intended use is within templates // it tolerates errors. It will insert the returned error message string into // m["Error"] in the returned map. func FromJson(str string) map[string]interface{} { diff --git a/vendor/k8s.io/helm/pkg/chartutil/save.go b/vendor/k8s.io/helm/pkg/chartutil/save.go index b89917d9633..bff32dde519 100644 --- a/vendor/k8s.io/helm/pkg/chartutil/save.go +++ b/vendor/k8s.io/helm/pkg/chartutil/save.go @@ -70,6 +70,12 @@ func SaveDir(c *chart.Chart, dest string) error { // Save files for _, f := range c.Files { n := filepath.Join(outdir, f.TypeUrl) + + d := filepath.Dir(n) + if err := os.MkdirAll(d, 0755); err != nil { + return err + } + if err := ioutil.WriteFile(n, f.Value, 0755); err != nil { return err } diff --git a/vendor/k8s.io/helm/pkg/getter/httpgetter.go b/vendor/k8s.io/helm/pkg/getter/httpgetter.go index 5a2146ec6f8..3c20e35e199 100644 --- a/vendor/k8s.io/helm/pkg/getter/httpgetter.go +++ b/vendor/k8s.io/helm/pkg/getter/httpgetter.go @@ -27,13 +27,26 @@ import ( "k8s.io/helm/pkg/version" ) -//httpGetter is the efault HTTP(/S) backend handler -type httpGetter struct { - client *http.Client +//HttpGetter is the efault HTTP(/S) backend handler +// TODO: change the name to HTTPGetter in Helm 3 +type HttpGetter struct { //nolint + client *http.Client + username string + password string +} + +//SetCredentials sets the credentials for the getter +func (g *HttpGetter) SetCredentials(username, password string) { + g.username = username + g.password = password } //Get performs a Get from repo.Getter and returns the body. -func (g *httpGetter) Get(href string) (*bytes.Buffer, error) { +func (g *HttpGetter) Get(href string) (*bytes.Buffer, error) { + return g.get(href) +} + +func (g *HttpGetter) get(href string) (*bytes.Buffer, error) { buf := bytes.NewBuffer(nil) // Set a helm specific user agent so that a repo server and metrics can @@ -44,6 +57,10 @@ func (g *httpGetter) Get(href string) (*bytes.Buffer, error) { } req.Header.Set("User-Agent", "Helm/"+strings.TrimPrefix(version.GetVersion(), "v")) + if g.username != "" && g.password != "" { + req.SetBasicAuth(g.username, g.password) + } + resp, err := g.client.Do(req) if err != nil { return buf, err @@ -59,23 +76,29 @@ func (g *httpGetter) Get(href string) (*bytes.Buffer, error) { // newHTTPGetter constructs a valid http/https client as Getter func newHTTPGetter(URL, CertFile, KeyFile, CAFile string) (Getter, error) { - var client httpGetter + return NewHTTPGetter(URL, CertFile, KeyFile, CAFile) +} + +// NewHTTPGetter constructs a valid http/https client as HttpGetter +func NewHTTPGetter(URL, CertFile, KeyFile, CAFile string) (*HttpGetter, error) { + var client HttpGetter if CertFile != "" && KeyFile != "" { tlsConf, err := tlsutil.NewClientTLS(CertFile, KeyFile, CAFile) if err != nil { - return nil, fmt.Errorf("can't create TLS config for client: %s", err.Error()) + return &client, fmt.Errorf("can't create TLS config for client: %s", err.Error()) } tlsConf.BuildNameToCertificate() sni, err := urlutil.ExtractHostname(URL) if err != nil { - return nil, err + return &client, err } tlsConf.ServerName = sni client.client = &http.Client{ Transport: &http.Transport{ TLSClientConfig: tlsConf, + Proxy: http.ProxyFromEnvironment, }, } } else { diff --git a/vendor/k8s.io/helm/pkg/helm/client.go b/vendor/k8s.io/helm/pkg/helm/client.go new file mode 100644 index 00000000000..43e9f4dafa2 --- /dev/null +++ b/vendor/k8s.io/helm/pkg/helm/client.go @@ -0,0 +1,522 @@ +/* +Copyright 2016 The Kubernetes Authors 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 helm // import "k8s.io/helm/pkg/helm" + +import ( + "fmt" + "io" + "time" + + "golang.org/x/net/context" + "google.golang.org/grpc" + "google.golang.org/grpc/credentials" + "google.golang.org/grpc/keepalive" + + healthpb "google.golang.org/grpc/health/grpc_health_v1" + "k8s.io/helm/pkg/chartutil" + "k8s.io/helm/pkg/proto/hapi/chart" + rls "k8s.io/helm/pkg/proto/hapi/services" +) + +// maxMsgSize use 20MB as the default message size limit. +// grpc library default is 4MB +const maxMsgSize = 1024 * 1024 * 20 + +// Client manages client side of the Helm-Tiller protocol. +type Client struct { + opts options +} + +// NewClient creates a new client. +func NewClient(opts ...Option) *Client { + var c Client + // set some sane defaults + c.Option(ConnectTimeout(5)) + return c.Option(opts...) +} + +// Option configures the Helm client with the provided options. +func (h *Client) Option(opts ...Option) *Client { + for _, opt := range opts { + opt(&h.opts) + } + return h +} + +// ListReleases lists the current releases. +func (h *Client) ListReleases(opts ...ReleaseListOption) (*rls.ListReleasesResponse, error) { + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + req := &reqOpts.listReq + ctx := NewContext() + + if reqOpts.before != nil { + if err := reqOpts.before(ctx, req); err != nil { + return nil, err + } + } + return h.list(ctx, req) +} + +// InstallRelease loads a chart from chstr, installs it, and returns the release response. +func (h *Client) InstallRelease(chstr, ns string, opts ...InstallOption) (*rls.InstallReleaseResponse, error) { + // load the chart to install + chart, err := chartutil.Load(chstr) + if err != nil { + return nil, err + } + + return h.InstallReleaseFromChart(chart, ns, opts...) +} + +// InstallReleaseFromChart installs a new chart and returns the release response. +func (h *Client) InstallReleaseFromChart(chart *chart.Chart, ns string, opts ...InstallOption) (*rls.InstallReleaseResponse, error) { + // apply the install options + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + req := &reqOpts.instReq + req.Chart = chart + req.Namespace = ns + req.DryRun = reqOpts.dryRun + req.DisableHooks = reqOpts.disableHooks + req.ReuseName = reqOpts.reuseName + ctx := NewContext() + + if reqOpts.before != nil { + if err := reqOpts.before(ctx, req); err != nil { + return nil, err + } + } + err := chartutil.ProcessRequirementsEnabled(req.Chart, req.Values) + if err != nil { + return nil, err + } + err = chartutil.ProcessRequirementsImportValues(req.Chart) + if err != nil { + return nil, err + } + + return h.install(ctx, req) +} + +// DeleteRelease uninstalls a named release and returns the response. +func (h *Client) DeleteRelease(rlsName string, opts ...DeleteOption) (*rls.UninstallReleaseResponse, error) { + // apply the uninstall options + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + + if reqOpts.dryRun { + // In the dry run case, just see if the release exists + r, err := h.ReleaseContent(rlsName) + if err != nil { + return &rls.UninstallReleaseResponse{}, err + } + return &rls.UninstallReleaseResponse{Release: r.Release}, nil + } + + req := &reqOpts.uninstallReq + req.Name = rlsName + req.DisableHooks = reqOpts.disableHooks + ctx := NewContext() + + if reqOpts.before != nil { + if err := reqOpts.before(ctx, req); err != nil { + return nil, err + } + } + return h.delete(ctx, req) +} + +// UpdateRelease loads a chart from chstr and updates a release to a new/different chart. +func (h *Client) UpdateRelease(rlsName string, chstr string, opts ...UpdateOption) (*rls.UpdateReleaseResponse, error) { + // load the chart to update + chart, err := chartutil.Load(chstr) + if err != nil { + return nil, err + } + + return h.UpdateReleaseFromChart(rlsName, chart, opts...) +} + +// UpdateReleaseFromChart updates a release to a new/different chart. +func (h *Client) UpdateReleaseFromChart(rlsName string, chart *chart.Chart, opts ...UpdateOption) (*rls.UpdateReleaseResponse, error) { + // apply the update options + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + req := &reqOpts.updateReq + req.Chart = chart + req.DryRun = reqOpts.dryRun + req.Name = rlsName + req.DisableHooks = reqOpts.disableHooks + req.Recreate = reqOpts.recreate + req.Force = reqOpts.force + req.ResetValues = reqOpts.resetValues + req.ReuseValues = reqOpts.reuseValues + ctx := NewContext() + + if reqOpts.before != nil { + if err := reqOpts.before(ctx, req); err != nil { + return nil, err + } + } + err := chartutil.ProcessRequirementsEnabled(req.Chart, req.Values) + if err != nil { + return nil, err + } + err = chartutil.ProcessRequirementsImportValues(req.Chart) + if err != nil { + return nil, err + } + + return h.update(ctx, req) +} + +// GetVersion returns the server version. +func (h *Client) GetVersion(opts ...VersionOption) (*rls.GetVersionResponse, error) { + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + req := &rls.GetVersionRequest{} + ctx := NewContext() + + if reqOpts.before != nil { + if err := reqOpts.before(ctx, req); err != nil { + return nil, err + } + } + return h.version(ctx, req) +} + +// RollbackRelease rolls back a release to the previous version. +func (h *Client) RollbackRelease(rlsName string, opts ...RollbackOption) (*rls.RollbackReleaseResponse, error) { + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + req := &reqOpts.rollbackReq + req.Recreate = reqOpts.recreate + req.Force = reqOpts.force + req.DisableHooks = reqOpts.disableHooks + req.DryRun = reqOpts.dryRun + req.Name = rlsName + ctx := NewContext() + + if reqOpts.before != nil { + if err := reqOpts.before(ctx, req); err != nil { + return nil, err + } + } + return h.rollback(ctx, req) +} + +// ReleaseStatus returns the given release's status. +func (h *Client) ReleaseStatus(rlsName string, opts ...StatusOption) (*rls.GetReleaseStatusResponse, error) { + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + req := &reqOpts.statusReq + req.Name = rlsName + ctx := NewContext() + + if reqOpts.before != nil { + if err := reqOpts.before(ctx, req); err != nil { + return nil, err + } + } + return h.status(ctx, req) +} + +// ReleaseContent returns the configuration for a given release. +func (h *Client) ReleaseContent(rlsName string, opts ...ContentOption) (*rls.GetReleaseContentResponse, error) { + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + req := &reqOpts.contentReq + req.Name = rlsName + ctx := NewContext() + + if reqOpts.before != nil { + if err := reqOpts.before(ctx, req); err != nil { + return nil, err + } + } + return h.content(ctx, req) +} + +// ReleaseHistory returns a release's revision history. +func (h *Client) ReleaseHistory(rlsName string, opts ...HistoryOption) (*rls.GetHistoryResponse, error) { + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + + req := &reqOpts.histReq + req.Name = rlsName + ctx := NewContext() + + if reqOpts.before != nil { + if err := reqOpts.before(ctx, req); err != nil { + return nil, err + } + } + return h.history(ctx, req) +} + +// RunReleaseTest executes a pre-defined test on a release. +func (h *Client) RunReleaseTest(rlsName string, opts ...ReleaseTestOption) (<-chan *rls.TestReleaseResponse, <-chan error) { + reqOpts := h.opts + for _, opt := range opts { + opt(&reqOpts) + } + + req := &reqOpts.testReq + req.Name = rlsName + ctx := NewContext() + + return h.test(ctx, req) +} + +// PingTiller pings the Tiller pod and ensure's that it is up and running +func (h *Client) PingTiller() error { + ctx := NewContext() + return h.ping(ctx) +} + +// connect returns a gRPC connection to Tiller or error. The gRPC dial options +// are constructed here. +func (h *Client) connect(ctx context.Context) (conn *grpc.ClientConn, err error) { + opts := []grpc.DialOption{ + grpc.WithBlock(), + grpc.WithKeepaliveParams(keepalive.ClientParameters{ + // Send keepalive every 30 seconds to prevent the connection from + // getting closed by upstreams + Time: time.Duration(30) * time.Second, + }), + grpc.WithDefaultCallOptions(grpc.MaxCallRecvMsgSize(maxMsgSize)), + } + switch { + case h.opts.useTLS: + opts = append(opts, grpc.WithTransportCredentials(credentials.NewTLS(h.opts.tlsConfig))) + default: + opts = append(opts, grpc.WithInsecure()) + } + ctx, cancel := context.WithTimeout(ctx, h.opts.connectTimeout) + defer cancel() + if conn, err = grpc.DialContext(ctx, h.opts.host, opts...); err != nil { + return nil, err + } + return conn, nil +} + +// Executes tiller.ListReleases RPC. +func (h *Client) list(ctx context.Context, req *rls.ListReleasesRequest) (*rls.ListReleasesResponse, error) { + c, err := h.connect(ctx) + if err != nil { + return nil, err + } + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + s, err := rlc.ListReleases(ctx, req) + if err != nil { + return nil, err + } + var resp *rls.ListReleasesResponse + for { + r, err := s.Recv() + if err == io.EOF { + break + } + if err != nil { + return nil, err + } + if resp == nil { + resp = r + continue + } + resp.Releases = append(resp.Releases, r.GetReleases()[0]) + } + return resp, nil +} + +// Executes tiller.InstallRelease RPC. +func (h *Client) install(ctx context.Context, req *rls.InstallReleaseRequest) (*rls.InstallReleaseResponse, error) { + c, err := h.connect(ctx) + if err != nil { + return nil, err + } + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + return rlc.InstallRelease(ctx, req) +} + +// Executes tiller.UninstallRelease RPC. +func (h *Client) delete(ctx context.Context, req *rls.UninstallReleaseRequest) (*rls.UninstallReleaseResponse, error) { + c, err := h.connect(ctx) + if err != nil { + return nil, err + } + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + return rlc.UninstallRelease(ctx, req) +} + +// Executes tiller.UpdateRelease RPC. +func (h *Client) update(ctx context.Context, req *rls.UpdateReleaseRequest) (*rls.UpdateReleaseResponse, error) { + c, err := h.connect(ctx) + if err != nil { + return nil, err + } + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + return rlc.UpdateRelease(ctx, req) +} + +// Executes tiller.RollbackRelease RPC. +func (h *Client) rollback(ctx context.Context, req *rls.RollbackReleaseRequest) (*rls.RollbackReleaseResponse, error) { + c, err := h.connect(ctx) + if err != nil { + return nil, err + } + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + return rlc.RollbackRelease(ctx, req) +} + +// Executes tiller.GetReleaseStatus RPC. +func (h *Client) status(ctx context.Context, req *rls.GetReleaseStatusRequest) (*rls.GetReleaseStatusResponse, error) { + c, err := h.connect(ctx) + if err != nil { + return nil, err + } + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + return rlc.GetReleaseStatus(ctx, req) +} + +// Executes tiller.GetReleaseContent RPC. +func (h *Client) content(ctx context.Context, req *rls.GetReleaseContentRequest) (*rls.GetReleaseContentResponse, error) { + c, err := h.connect(ctx) + if err != nil { + return nil, err + } + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + return rlc.GetReleaseContent(ctx, req) +} + +// Executes tiller.GetVersion RPC. +func (h *Client) version(ctx context.Context, req *rls.GetVersionRequest) (*rls.GetVersionResponse, error) { + c, err := h.connect(ctx) + if err != nil { + return nil, err + } + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + return rlc.GetVersion(ctx, req) +} + +// Executes tiller.GetHistory RPC. +func (h *Client) history(ctx context.Context, req *rls.GetHistoryRequest) (*rls.GetHistoryResponse, error) { + c, err := h.connect(ctx) + if err != nil { + return nil, err + } + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + return rlc.GetHistory(ctx, req) +} + +// Executes tiller.TestRelease RPC. +func (h *Client) test(ctx context.Context, req *rls.TestReleaseRequest) (<-chan *rls.TestReleaseResponse, <-chan error) { + errc := make(chan error, 1) + c, err := h.connect(ctx) + if err != nil { + errc <- err + return nil, errc + } + + ch := make(chan *rls.TestReleaseResponse, 1) + go func() { + defer close(errc) + defer close(ch) + defer c.Close() + + rlc := rls.NewReleaseServiceClient(c) + s, err := rlc.RunReleaseTest(ctx, req) + if err != nil { + errc <- err + return + } + + for { + msg, err := s.Recv() + if err == io.EOF { + return + } + if err != nil { + errc <- err + return + } + ch <- msg + } + }() + + return ch, errc +} + +// Executes tiller.Ping RPC. +func (h *Client) ping(ctx context.Context) error { + c, err := h.connect(ctx) + if err != nil { + return err + } + defer c.Close() + + healthClient := healthpb.NewHealthClient(c) + resp, err := healthClient.Check(ctx, &healthpb.HealthCheckRequest{Service: "Tiller"}) + if err != nil { + return err + } + switch resp.GetStatus() { + case healthpb.HealthCheckResponse_SERVING: + return nil + case healthpb.HealthCheckResponse_NOT_SERVING: + return fmt.Errorf("tiller is not serving requests at this time, Please try again later") + default: + return fmt.Errorf("tiller healthcheck returned an unknown status") + } +} diff --git a/vendor/k8s.io/helm/pkg/helm/environment/environment.go b/vendor/k8s.io/helm/pkg/helm/environment/environment.go index 49d424b333c..2980e6dc9c9 100644 --- a/vendor/k8s.io/helm/pkg/helm/environment/environment.go +++ b/vendor/k8s.io/helm/pkg/helm/environment/environment.go @@ -39,6 +39,8 @@ var DefaultHelmHome = filepath.Join(homedir.HomeDir(), ".helm") type EnvSettings struct { // TillerHost is the host and port of Tiller. TillerHost string + // TillerConnectionTimeout is the duration (in seconds) helm will wait to establish a connection to tiller. + TillerConnectionTimeout int64 // TillerNamespace is the namespace in which Tiller runs. TillerNamespace string // Home is the local path to the Helm home directory. @@ -56,6 +58,7 @@ func (s *EnvSettings) AddFlags(fs *pflag.FlagSet) { fs.StringVar(&s.KubeContext, "kube-context", "", "name of the kubeconfig context to use") fs.BoolVar(&s.Debug, "debug", false, "enable verbose output") fs.StringVar(&s.TillerNamespace, "tiller-namespace", "kube-system", "namespace of Tiller") + fs.Int64Var(&s.TillerConnectionTimeout, "tiller-connection-timeout", int64(300), "the duration (in seconds) Helm will wait to establish a connection to tiller") } // Init sets values from the environment. diff --git a/vendor/k8s.io/helm/pkg/helm/fake.go b/vendor/k8s.io/helm/pkg/helm/fake.go new file mode 100644 index 00000000000..0a9e77c4406 --- /dev/null +++ b/vendor/k8s.io/helm/pkg/helm/fake.go @@ -0,0 +1,277 @@ +/* +Copyright 2016 The Kubernetes Authors 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 helm // import "k8s.io/helm/pkg/helm" + +import ( + "errors" + "fmt" + "math/rand" + "sync" + + "github.com/golang/protobuf/ptypes/timestamp" + "k8s.io/helm/pkg/proto/hapi/chart" + "k8s.io/helm/pkg/proto/hapi/release" + rls "k8s.io/helm/pkg/proto/hapi/services" + "k8s.io/helm/pkg/proto/hapi/version" +) + +// FakeClient implements Interface +type FakeClient struct { + Rels []*release.Release + Responses map[string]release.TestRun_Status + Opts options +} + +// Option returns the fake release client +func (c *FakeClient) Option(opts ...Option) Interface { + for _, opt := range opts { + opt(&c.Opts) + } + return c +} + +var _ Interface = &FakeClient{} +var _ Interface = (*FakeClient)(nil) + +// ListReleases lists the current releases +func (c *FakeClient) ListReleases(opts ...ReleaseListOption) (*rls.ListReleasesResponse, error) { + resp := &rls.ListReleasesResponse{ + Count: int64(len(c.Rels)), + Releases: c.Rels, + } + return resp, nil +} + +// InstallRelease creates a new release and returns a InstallReleaseResponse containing that release +func (c *FakeClient) InstallRelease(chStr, ns string, opts ...InstallOption) (*rls.InstallReleaseResponse, error) { + chart := &chart.Chart{} + return c.InstallReleaseFromChart(chart, ns, opts...) +} + +// InstallReleaseFromChart adds a new MockRelease to the fake client and returns a InstallReleaseResponse containing that release +func (c *FakeClient) InstallReleaseFromChart(chart *chart.Chart, ns string, opts ...InstallOption) (*rls.InstallReleaseResponse, error) { + for _, opt := range opts { + opt(&c.Opts) + } + + releaseName := c.Opts.instReq.Name + + // Check to see if the release already exists. + rel, err := c.ReleaseStatus(releaseName, nil) + if err == nil && rel != nil { + return nil, errors.New("cannot re-use a name that is still in use") + } + + release := ReleaseMock(&MockReleaseOptions{Name: releaseName, Namespace: ns}) + c.Rels = append(c.Rels, release) + + return &rls.InstallReleaseResponse{ + Release: release, + }, nil +} + +// DeleteRelease deletes a release from the FakeClient +func (c *FakeClient) DeleteRelease(rlsName string, opts ...DeleteOption) (*rls.UninstallReleaseResponse, error) { + for i, rel := range c.Rels { + if rel.Name == rlsName { + c.Rels = append(c.Rels[:i], c.Rels[i+1:]...) + return &rls.UninstallReleaseResponse{ + Release: rel, + }, nil + } + } + + return nil, fmt.Errorf("No such release: %s", rlsName) +} + +// GetVersion returns a fake version +func (c *FakeClient) GetVersion(opts ...VersionOption) (*rls.GetVersionResponse, error) { + return &rls.GetVersionResponse{ + Version: &version.Version{ + SemVer: "1.2.3-fakeclient+testonly", + }, + }, nil +} + +// UpdateRelease returns an UpdateReleaseResponse containing the updated release, if it exists +func (c *FakeClient) UpdateRelease(rlsName string, chStr string, opts ...UpdateOption) (*rls.UpdateReleaseResponse, error) { + return c.UpdateReleaseFromChart(rlsName, &chart.Chart{}, opts...) +} + +// UpdateReleaseFromChart returns an UpdateReleaseResponse containing the updated release, if it exists +func (c *FakeClient) UpdateReleaseFromChart(rlsName string, chart *chart.Chart, opts ...UpdateOption) (*rls.UpdateReleaseResponse, error) { + // Check to see if the release already exists. + rel, err := c.ReleaseContent(rlsName, nil) + if err != nil { + return nil, err + } + + return &rls.UpdateReleaseResponse{Release: rel.Release}, nil +} + +// RollbackRelease returns nil, nil +func (c *FakeClient) RollbackRelease(rlsName string, opts ...RollbackOption) (*rls.RollbackReleaseResponse, error) { + return nil, nil +} + +// ReleaseStatus returns a release status response with info from the matching release name. +func (c *FakeClient) ReleaseStatus(rlsName string, opts ...StatusOption) (*rls.GetReleaseStatusResponse, error) { + for _, rel := range c.Rels { + if rel.Name == rlsName { + return &rls.GetReleaseStatusResponse{ + Name: rel.Name, + Info: rel.Info, + Namespace: rel.Namespace, + }, nil + } + } + return nil, fmt.Errorf("No such release: %s", rlsName) +} + +// ReleaseContent returns the configuration for the matching release name in the fake release client. +func (c *FakeClient) ReleaseContent(rlsName string, opts ...ContentOption) (resp *rls.GetReleaseContentResponse, err error) { + for _, rel := range c.Rels { + if rel.Name == rlsName { + return &rls.GetReleaseContentResponse{ + Release: rel, + }, nil + } + } + return resp, fmt.Errorf("No such release: %s", rlsName) +} + +// ReleaseHistory returns a release's revision history. +func (c *FakeClient) ReleaseHistory(rlsName string, opts ...HistoryOption) (*rls.GetHistoryResponse, error) { + return &rls.GetHistoryResponse{Releases: c.Rels}, nil +} + +// RunReleaseTest executes a pre-defined tests on a release +func (c *FakeClient) RunReleaseTest(rlsName string, opts ...ReleaseTestOption) (<-chan *rls.TestReleaseResponse, <-chan error) { + + results := make(chan *rls.TestReleaseResponse) + errc := make(chan error, 1) + + go func() { + var wg sync.WaitGroup + for m, s := range c.Responses { + wg.Add(1) + + go func(msg string, status release.TestRun_Status) { + defer wg.Done() + results <- &rls.TestReleaseResponse{Msg: msg, Status: status} + }(m, s) + } + + wg.Wait() + close(results) + close(errc) + }() + + return results, errc +} + +// PingTiller pings the Tiller pod and ensure's that it is up and running +func (c *FakeClient) PingTiller() error { + return nil +} + +// MockHookTemplate is the hook template used for all mock release objects. +var MockHookTemplate = `apiVersion: v1 +kind: Job +metadata: + annotations: + "helm.sh/hook": pre-install +` + +// MockManifest is the manifest used for all mock release objects. +var MockManifest = `apiVersion: v1 +kind: Secret +metadata: + name: fixture +` + +// MockReleaseOptions allows for user-configurable options on mock release objects. +type MockReleaseOptions struct { + Name string + Version int32 + Chart *chart.Chart + StatusCode release.Status_Code + Namespace string +} + +// ReleaseMock creates a mock release object based on options set by MockReleaseOptions. This function should typically not be used outside of testing. +func ReleaseMock(opts *MockReleaseOptions) *release.Release { + date := timestamp.Timestamp{Seconds: 242085845, Nanos: 0} + + name := opts.Name + if name == "" { + name = "testrelease-" + string(rand.Intn(100)) + } + + var version int32 = 1 + if opts.Version != 0 { + version = opts.Version + } + + namespace := opts.Namespace + if namespace == "" { + namespace = "default" + } + + ch := opts.Chart + if opts.Chart == nil { + ch = &chart.Chart{ + Metadata: &chart.Metadata{ + Name: "foo", + Version: "0.1.0-beta.1", + }, + Templates: []*chart.Template{ + {Name: "templates/foo.tpl", Data: []byte(MockManifest)}, + }, + } + } + + scode := release.Status_DEPLOYED + if opts.StatusCode > 0 { + scode = opts.StatusCode + } + + return &release.Release{ + Name: name, + Info: &release.Info{ + FirstDeployed: &date, + LastDeployed: &date, + Status: &release.Status{Code: scode}, + Description: "Release mock", + }, + Chart: ch, + Config: &chart.Config{Raw: `name: "value"`}, + Version: version, + Namespace: namespace, + Hooks: []*release.Hook{ + { + Name: "pre-install-hook", + Kind: "Job", + Path: "pre-install-hook.yaml", + Manifest: MockHookTemplate, + LastRun: &date, + Events: []release.Hook_Event{release.Hook_PRE_INSTALL}, + }, + }, + Manifest: MockManifest, + } +} diff --git a/vendor/k8s.io/helm/pkg/helm/interface.go b/vendor/k8s.io/helm/pkg/helm/interface.go new file mode 100644 index 00000000000..10c04c71089 --- /dev/null +++ b/vendor/k8s.io/helm/pkg/helm/interface.go @@ -0,0 +1,39 @@ +/* +Copyright 2016 The Kubernetes Authors 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 helm + +import ( + "k8s.io/helm/pkg/proto/hapi/chart" + rls "k8s.io/helm/pkg/proto/hapi/services" +) + +// Interface for helm client for mocking in tests +type Interface interface { + ListReleases(opts ...ReleaseListOption) (*rls.ListReleasesResponse, error) + InstallRelease(chStr, namespace string, opts ...InstallOption) (*rls.InstallReleaseResponse, error) + InstallReleaseFromChart(chart *chart.Chart, namespace string, opts ...InstallOption) (*rls.InstallReleaseResponse, error) + DeleteRelease(rlsName string, opts ...DeleteOption) (*rls.UninstallReleaseResponse, error) + ReleaseStatus(rlsName string, opts ...StatusOption) (*rls.GetReleaseStatusResponse, error) + UpdateRelease(rlsName, chStr string, opts ...UpdateOption) (*rls.UpdateReleaseResponse, error) + UpdateReleaseFromChart(rlsName string, chart *chart.Chart, opts ...UpdateOption) (*rls.UpdateReleaseResponse, error) + RollbackRelease(rlsName string, opts ...RollbackOption) (*rls.RollbackReleaseResponse, error) + ReleaseContent(rlsName string, opts ...ContentOption) (*rls.GetReleaseContentResponse, error) + ReleaseHistory(rlsName string, opts ...HistoryOption) (*rls.GetHistoryResponse, error) + GetVersion(opts ...VersionOption) (*rls.GetVersionResponse, error) + RunReleaseTest(rlsName string, opts ...ReleaseTestOption) (<-chan *rls.TestReleaseResponse, <-chan error) + PingTiller() error +} diff --git a/vendor/k8s.io/helm/pkg/helm/option.go b/vendor/k8s.io/helm/pkg/helm/option.go new file mode 100644 index 00000000000..3381e3f80fc --- /dev/null +++ b/vendor/k8s.io/helm/pkg/helm/option.go @@ -0,0 +1,444 @@ +/* +Copyright 2016 The Kubernetes Authors 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 helm + +import ( + "crypto/tls" + "time" + + "github.com/golang/protobuf/proto" + "golang.org/x/net/context" + "google.golang.org/grpc/metadata" + + cpb "k8s.io/helm/pkg/proto/hapi/chart" + "k8s.io/helm/pkg/proto/hapi/release" + rls "k8s.io/helm/pkg/proto/hapi/services" + "k8s.io/helm/pkg/version" +) + +// Option allows specifying various settings configurable by +// the helm client user for overriding the defaults used when +// issuing rpc's to the Tiller release server. +type Option func(*options) + +// options specify optional settings used by the helm client. +type options struct { + // value of helm home override + host string + // if set dry-run helm client calls + dryRun bool + // if set enable TLS on helm client calls + useTLS bool + // if set, re-use an existing name + reuseName bool + // if set, performs pod restart during upgrade/rollback + recreate bool + // if set, force resource update through delete/recreate if needed + force bool + // if set, skip running hooks + disableHooks bool + // name of release + releaseName string + // tls.Config to use for rpc if tls enabled + tlsConfig *tls.Config + // release list options are applied directly to the list releases request + listReq rls.ListReleasesRequest + // release install options are applied directly to the install release request + instReq rls.InstallReleaseRequest + // release update options are applied directly to the update release request + updateReq rls.UpdateReleaseRequest + // release uninstall options are applied directly to the uninstall release request + uninstallReq rls.UninstallReleaseRequest + // release get status options are applied directly to the get release status request + statusReq rls.GetReleaseStatusRequest + // release get content options are applied directly to the get release content request + contentReq rls.GetReleaseContentRequest + // release rollback options are applied directly to the rollback release request + rollbackReq rls.RollbackReleaseRequest + // before intercepts client calls before sending + before func(context.Context, proto.Message) error + // release history options are applied directly to the get release history request + histReq rls.GetHistoryRequest + // resetValues instructs Tiller to reset values to their defaults. + resetValues bool + // reuseValues instructs Tiller to reuse the values from the last release. + reuseValues bool + // release test options are applied directly to the test release history request + testReq rls.TestReleaseRequest + // connectTimeout specifies the time duration Helm will wait to establish a connection to tiller + connectTimeout time.Duration +} + +// Host specifies the host address of the Tiller release server, (default = ":44134"). +func Host(host string) Option { + return func(opts *options) { + opts.host = host + } +} + +// WithTLS specifies the tls configuration if the helm client is enabled to use TLS. +func WithTLS(cfg *tls.Config) Option { + return func(opts *options) { + opts.useTLS = true + opts.tlsConfig = cfg + } +} + +// BeforeCall returns an option that allows intercepting a helm client rpc +// before being sent OTA to tiller. The intercepting function should return +// an error to indicate that the call should not proceed or nil otherwise. +func BeforeCall(fn func(context.Context, proto.Message) error) Option { + return func(opts *options) { + opts.before = fn + } +} + +// ReleaseListOption allows specifying various settings +// configurable by the helm client user for overriding +// the defaults used when running the `helm list` command. +type ReleaseListOption func(*options) + +// ReleaseListOffset specifies the offset into a list of releases. +func ReleaseListOffset(offset string) ReleaseListOption { + return func(opts *options) { + opts.listReq.Offset = offset + } +} + +// ReleaseListFilter specifies a filter to apply a list of releases. +func ReleaseListFilter(filter string) ReleaseListOption { + return func(opts *options) { + opts.listReq.Filter = filter + } +} + +// ReleaseListLimit set an upper bound on the number of releases returned. +func ReleaseListLimit(limit int) ReleaseListOption { + return func(opts *options) { + opts.listReq.Limit = int64(limit) + } +} + +// ReleaseListOrder specifies how to order a list of releases. +func ReleaseListOrder(order int32) ReleaseListOption { + return func(opts *options) { + opts.listReq.SortOrder = rls.ListSort_SortOrder(order) + } +} + +// ReleaseListSort specifies how to sort a release list. +func ReleaseListSort(sort int32) ReleaseListOption { + return func(opts *options) { + opts.listReq.SortBy = rls.ListSort_SortBy(sort) + } +} + +// ReleaseListStatuses specifies which status codes should be returned. +func ReleaseListStatuses(statuses []release.Status_Code) ReleaseListOption { + return func(opts *options) { + if len(statuses) == 0 { + statuses = []release.Status_Code{release.Status_DEPLOYED} + } + opts.listReq.StatusCodes = statuses + } +} + +// ReleaseListNamespace specifies the namespace to list releases from +func ReleaseListNamespace(namespace string) ReleaseListOption { + return func(opts *options) { + opts.listReq.Namespace = namespace + } +} + +// InstallOption allows specifying various settings +// configurable by the helm client user for overriding +// the defaults used when running the `helm install` command. +type InstallOption func(*options) + +// ValueOverrides specifies a list of values to include when installing. +func ValueOverrides(raw []byte) InstallOption { + return func(opts *options) { + opts.instReq.Values = &cpb.Config{Raw: string(raw)} + } +} + +// ReleaseName specifies the name of the release when installing. +func ReleaseName(name string) InstallOption { + return func(opts *options) { + opts.instReq.Name = name + } +} + +// ConnectTimeout specifies the duration (in seconds) Helm will wait to establish a connection to tiller +func ConnectTimeout(timeout int64) Option { + return func(opts *options) { + opts.connectTimeout = time.Duration(timeout) * time.Second + } +} + +// InstallTimeout specifies the number of seconds before kubernetes calls timeout +func InstallTimeout(timeout int64) InstallOption { + return func(opts *options) { + opts.instReq.Timeout = timeout + } +} + +// UpgradeTimeout specifies the number of seconds before kubernetes calls timeout +func UpgradeTimeout(timeout int64) UpdateOption { + return func(opts *options) { + opts.updateReq.Timeout = timeout + } +} + +// DeleteTimeout specifies the number of seconds before kubernetes calls timeout +func DeleteTimeout(timeout int64) DeleteOption { + return func(opts *options) { + opts.uninstallReq.Timeout = timeout + } +} + +// ReleaseTestTimeout specifies the number of seconds before kubernetes calls timeout +func ReleaseTestTimeout(timeout int64) ReleaseTestOption { + return func(opts *options) { + opts.testReq.Timeout = timeout + } +} + +// ReleaseTestCleanup is a boolean value representing whether to cleanup test pods +func ReleaseTestCleanup(cleanup bool) ReleaseTestOption { + return func(opts *options) { + opts.testReq.Cleanup = cleanup + } +} + +// RollbackTimeout specifies the number of seconds before kubernetes calls timeout +func RollbackTimeout(timeout int64) RollbackOption { + return func(opts *options) { + opts.rollbackReq.Timeout = timeout + } +} + +// InstallWait specifies whether or not to wait for all resources to be ready +func InstallWait(wait bool) InstallOption { + return func(opts *options) { + opts.instReq.Wait = wait + } +} + +// UpgradeWait specifies whether or not to wait for all resources to be ready +func UpgradeWait(wait bool) UpdateOption { + return func(opts *options) { + opts.updateReq.Wait = wait + } +} + +// RollbackWait specifies whether or not to wait for all resources to be ready +func RollbackWait(wait bool) RollbackOption { + return func(opts *options) { + opts.rollbackReq.Wait = wait + } +} + +// UpdateValueOverrides specifies a list of values to include when upgrading +func UpdateValueOverrides(raw []byte) UpdateOption { + return func(opts *options) { + opts.updateReq.Values = &cpb.Config{Raw: string(raw)} + } +} + +// DeleteDisableHooks will disable hooks for a deletion operation. +func DeleteDisableHooks(disable bool) DeleteOption { + return func(opts *options) { + opts.disableHooks = disable + } +} + +// DeleteDryRun will (if true) execute a deletion as a dry run. +func DeleteDryRun(dry bool) DeleteOption { + return func(opts *options) { + opts.dryRun = dry + } +} + +// DeletePurge removes the release from the store and make its name free for later use. +func DeletePurge(purge bool) DeleteOption { + return func(opts *options) { + opts.uninstallReq.Purge = purge + } +} + +// InstallDryRun will (if true) execute an installation as a dry run. +func InstallDryRun(dry bool) InstallOption { + return func(opts *options) { + opts.dryRun = dry + } +} + +// InstallDisableHooks disables hooks during installation. +func InstallDisableHooks(disable bool) InstallOption { + return func(opts *options) { + opts.disableHooks = disable + } +} + +// InstallReuseName will (if true) instruct Tiller to re-use an existing name. +func InstallReuseName(reuse bool) InstallOption { + return func(opts *options) { + opts.reuseName = reuse + } +} + +// RollbackDisableHooks will disable hooks for a rollback operation +func RollbackDisableHooks(disable bool) RollbackOption { + return func(opts *options) { + opts.disableHooks = disable + } +} + +// RollbackDryRun will (if true) execute a rollback as a dry run. +func RollbackDryRun(dry bool) RollbackOption { + return func(opts *options) { + opts.dryRun = dry + } +} + +// RollbackRecreate will (if true) recreate pods after rollback. +func RollbackRecreate(recreate bool) RollbackOption { + return func(opts *options) { + opts.recreate = recreate + } +} + +// RollbackForce will (if true) force resource update through delete/recreate if needed +func RollbackForce(force bool) RollbackOption { + return func(opts *options) { + opts.force = force + } +} + +// RollbackVersion sets the version of the release to deploy. +func RollbackVersion(ver int32) RollbackOption { + return func(opts *options) { + opts.rollbackReq.Version = ver + } +} + +// UpgradeDisableHooks will disable hooks for an upgrade operation. +func UpgradeDisableHooks(disable bool) UpdateOption { + return func(opts *options) { + opts.disableHooks = disable + } +} + +// UpgradeDryRun will (if true) execute an upgrade as a dry run. +func UpgradeDryRun(dry bool) UpdateOption { + return func(opts *options) { + opts.dryRun = dry + } +} + +// ResetValues will (if true) trigger resetting the values to their original state. +func ResetValues(reset bool) UpdateOption { + return func(opts *options) { + opts.resetValues = reset + } +} + +// ReuseValues will cause Tiller to reuse the values from the last release. +// This is ignored if ResetValues is true. +func ReuseValues(reuse bool) UpdateOption { + return func(opts *options) { + opts.reuseValues = reuse + } +} + +// UpgradeRecreate will (if true) recreate pods after upgrade. +func UpgradeRecreate(recreate bool) UpdateOption { + return func(opts *options) { + opts.recreate = recreate + } +} + +// UpgradeForce will (if true) force resource update through delete/recreate if needed +func UpgradeForce(force bool) UpdateOption { + return func(opts *options) { + opts.force = force + } +} + +// ContentOption allows setting optional attributes when +// performing a GetReleaseContent tiller rpc. +type ContentOption func(*options) + +// ContentReleaseVersion will instruct Tiller to retrieve the content +// of a particular version of a release. +func ContentReleaseVersion(version int32) ContentOption { + return func(opts *options) { + opts.contentReq.Version = version + } +} + +// StatusOption allows setting optional attributes when +// performing a GetReleaseStatus tiller rpc. +type StatusOption func(*options) + +// StatusReleaseVersion will instruct Tiller to retrieve the status +// of a particular version of a release. +func StatusReleaseVersion(version int32) StatusOption { + return func(opts *options) { + opts.statusReq.Version = version + } +} + +// DeleteOption allows setting optional attributes when +// performing a UninstallRelease tiller rpc. +type DeleteOption func(*options) + +// VersionOption -- TODO +type VersionOption func(*options) + +// UpdateOption allows specifying various settings +// configurable by the helm client user for overriding +// the defaults used when running the `helm upgrade` command. +type UpdateOption func(*options) + +// RollbackOption allows specififying various settings configurable +// by the helm client user for overriding the defaults used when +// running the `helm rollback` command. +type RollbackOption func(*options) + +// HistoryOption allows configuring optional request data for +// issuing a GetHistory rpc. +type HistoryOption func(*options) + +// WithMaxHistory sets the max number of releases to return +// in a release history query. +func WithMaxHistory(max int32) HistoryOption { + return func(opts *options) { + opts.histReq.Max = max + } +} + +// NewContext creates a versioned context. +func NewContext() context.Context { + md := metadata.Pairs("x-helm-api-client", version.GetVersion()) + return metadata.NewOutgoingContext(context.TODO(), md) +} + +// ReleaseTestOption allows configuring optional request data for +// issuing a TestRelease rpc. +type ReleaseTestOption func(*options) diff --git a/vendor/k8s.io/helm/pkg/proto/hapi/chart/metadata.pb.go b/vendor/k8s.io/helm/pkg/proto/hapi/chart/metadata.pb.go index 49a4aa0ac4e..9daeaa9e565 100644 --- a/vendor/k8s.io/helm/pkg/proto/hapi/chart/metadata.pb.go +++ b/vendor/k8s.io/helm/pkg/proto/hapi/chart/metadata.pb.go @@ -107,7 +107,7 @@ type Metadata struct { // Annotations are additional mappings uninterpreted by Tiller, // made available for inspection by other applications. Annotations map[string]string `protobuf:"bytes,16,rep,name=annotations" json:"annotations,omitempty" protobuf_key:"bytes,1,opt,name=key" protobuf_val:"bytes,2,opt,name=value"` - // KubeVersion is a SemVer constraints on what version of Kubernetes is required. + // KubeVersion is a SemVer constraint specifying the version of Kubernetes required. KubeVersion string `protobuf:"bytes,17,opt,name=kubeVersion" json:"kubeVersion,omitempty"` } @@ -244,32 +244,33 @@ func init() { func init() { proto.RegisterFile("hapi/chart/metadata.proto", fileDescriptor2) } var fileDescriptor2 = []byte{ - // 427 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x6c, 0x52, 0x5d, 0x6b, 0xdb, 0x30, - 0x14, 0x9d, 0x9b, 0x38, 0x89, 0xaf, 0xd7, 0xcd, 0xbb, 0x8c, 0xa2, 0x95, 0x31, 0x4c, 0xd8, 0x20, - 0x4f, 0x29, 0x6c, 0x30, 0xca, 0x1e, 0x06, 0x1b, 0x94, 0x3e, 0x6c, 0x4d, 0x87, 0xd9, 0x07, 0xec, - 0x4d, 0xb5, 0x2f, 0x8d, 0x48, 0x2c, 0x19, 0x49, 0xe9, 0xc8, 0xaf, 0xd8, 0x5f, 0x1e, 0x92, 0xad, - 0xda, 0x19, 0x7d, 0xbb, 0xe7, 0x1c, 0xdd, 0x23, 0x1d, 0xdd, 0x0b, 0x2f, 0xd6, 0xbc, 0x11, 0x67, - 0xe5, 0x9a, 0x6b, 0x7b, 0x56, 0x93, 0xe5, 0x15, 0xb7, 0x7c, 0xd9, 0x68, 0x65, 0x15, 0x82, 0x93, - 0x96, 0x5e, 0x9a, 0xbf, 0x07, 0xb8, 0xe2, 0x42, 0x5a, 0x2e, 0x24, 0x69, 0x44, 0x18, 0x4b, 0x5e, - 0x13, 0x8b, 0xf2, 0x68, 0x91, 0x14, 0xbe, 0xc6, 0xe7, 0x10, 0x53, 0xcd, 0xc5, 0x96, 0x1d, 0x79, - 0xb2, 0x05, 0xf3, 0xbf, 0x31, 0xcc, 0xae, 0x3a, 0xdb, 0x07, 0xdb, 0x10, 0xc6, 0x6b, 0x55, 0x53, - 0xd7, 0xe5, 0x6b, 0x64, 0x30, 0x35, 0x6a, 0xa7, 0x4b, 0x32, 0x6c, 0x94, 0x8f, 0x16, 0x49, 0x11, - 0xa0, 0x53, 0xee, 0x48, 0x1b, 0xa1, 0x24, 0x1b, 0xfb, 0x86, 0x00, 0x31, 0x87, 0xb4, 0x22, 0x53, - 0x6a, 0xd1, 0x58, 0xa7, 0xc6, 0x5e, 0x1d, 0x52, 0x78, 0x0a, 0xb3, 0x0d, 0xed, 0xff, 0x28, 0x5d, - 0x19, 0x36, 0xf1, 0xb6, 0xf7, 0x18, 0xcf, 0x21, 0xad, 0xef, 0xe3, 0x19, 0x36, 0xcd, 0x47, 0x8b, - 0xf4, 0xed, 0xc9, 0xb2, 0xff, 0x80, 0x65, 0x9f, 0xbe, 0x18, 0x1e, 0xc5, 0x13, 0x98, 0x90, 0xbc, - 0x15, 0x92, 0xd8, 0xcc, 0x5f, 0xd9, 0x21, 0x97, 0x4b, 0x94, 0x4a, 0xb2, 0xa4, 0xcd, 0xe5, 0x6a, - 0x7c, 0x05, 0xc0, 0x1b, 0xf1, 0xb3, 0x0b, 0x00, 0x5e, 0x19, 0x30, 0xf8, 0x12, 0x92, 0x52, 0xc9, - 0x4a, 0xf8, 0x04, 0xa9, 0x97, 0x7b, 0xc2, 0x39, 0x5a, 0x7e, 0x6b, 0xd8, 0xe3, 0xd6, 0xd1, 0xd5, - 0xad, 0x63, 0x13, 0x1c, 0x8f, 0x83, 0x63, 0x60, 0x9c, 0x5e, 0x51, 0xa3, 0xa9, 0xe4, 0x96, 0x2a, - 0xf6, 0x24, 0x8f, 0x16, 0xb3, 0x62, 0xc0, 0xe0, 0x6b, 0x38, 0xb6, 0x62, 0xbb, 0x25, 0x1d, 0x2c, - 0x9e, 0x7a, 0x8b, 0x43, 0x12, 0x2f, 0x21, 0xe5, 0x52, 0x2a, 0xcb, 0xdd, 0x3b, 0x0c, 0xcb, 0xfc, - 0xef, 0xbc, 0x39, 0xf8, 0x9d, 0xb0, 0x39, 0x9f, 0xfa, 0x73, 0x17, 0xd2, 0xea, 0x7d, 0x31, 0xec, - 0x74, 0x43, 0xda, 0xec, 0x6e, 0x28, 0x5c, 0xf6, 0xac, 0x1d, 0xd2, 0x80, 0x3a, 0xfd, 0x08, 0xd9, - 0xff, 0x16, 0x98, 0xc1, 0x68, 0x43, 0xfb, 0x6e, 0x6b, 0x5c, 0xe9, 0x76, 0xed, 0x8e, 0x6f, 0x77, - 0x61, 0x6b, 0x5a, 0xf0, 0xe1, 0xe8, 0x3c, 0x9a, 0xe7, 0x30, 0xb9, 0x68, 0x07, 0x90, 0xc2, 0xf4, - 0xc7, 0xea, 0xcb, 0xea, 0xfa, 0xd7, 0x2a, 0x7b, 0x84, 0x09, 0xc4, 0x97, 0xd7, 0xdf, 0xbf, 0x7d, - 0xcd, 0xa2, 0xcf, 0xd3, 0xdf, 0xb1, 0x7f, 0xf3, 0xcd, 0xc4, 0x6f, 0xf9, 0xbb, 0x7f, 0x01, 0x00, - 0x00, 0xff, 0xff, 0x7f, 0xc1, 0xec, 0x3d, 0x02, 0x03, 0x00, 0x00, + // 435 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x6c, 0x52, 0x5d, 0x6b, 0xd4, 0x40, + 0x14, 0x35, 0xcd, 0x66, 0x77, 0x73, 0x63, 0x35, 0x0e, 0x52, 0xc6, 0x22, 0x12, 0x16, 0x85, 0x7d, + 0xda, 0x82, 0xbe, 0x14, 0x1f, 0x04, 0x85, 0x52, 0x41, 0xbb, 0x95, 0xe0, 0x07, 0xf8, 0x36, 0x4d, + 0x2e, 0xdd, 0x61, 0x93, 0x99, 0x30, 0x99, 0xad, 0xec, 0xaf, 0xf0, 0x2f, 0xcb, 0xdc, 0x64, 0x9a, + 0xac, 0xf4, 0xed, 0x9e, 0x73, 0x66, 0xce, 0xcc, 0xbd, 0xf7, 0xc0, 0x8b, 0x8d, 0x68, 0xe4, 0x59, + 0xb1, 0x11, 0xc6, 0x9e, 0xd5, 0x68, 0x45, 0x29, 0xac, 0x58, 0x35, 0x46, 0x5b, 0xcd, 0xc0, 0x49, + 0x2b, 0x92, 0x16, 0x9f, 0x01, 0xae, 0x84, 0x54, 0x56, 0x48, 0x85, 0x86, 0x31, 0x98, 0x28, 0x51, + 0x23, 0x0f, 0xb2, 0x60, 0x19, 0xe7, 0x54, 0xb3, 0xe7, 0x10, 0x61, 0x2d, 0x64, 0xc5, 0x8f, 0x88, + 0xec, 0x00, 0x4b, 0x21, 0xdc, 0x99, 0x8a, 0x87, 0xc4, 0xb9, 0x72, 0xf1, 0x37, 0x82, 0xf9, 0x55, + 0xff, 0xd0, 0x83, 0x46, 0x0c, 0x26, 0x1b, 0x5d, 0x63, 0xef, 0x43, 0x35, 0xe3, 0x30, 0x6b, 0xf5, + 0xce, 0x14, 0xd8, 0xf2, 0x30, 0x0b, 0x97, 0x71, 0xee, 0xa1, 0x53, 0xee, 0xd0, 0xb4, 0x52, 0x2b, + 0x3e, 0xa1, 0x0b, 0x1e, 0xb2, 0x0c, 0x92, 0x12, 0xdb, 0xc2, 0xc8, 0xc6, 0x3a, 0x35, 0x22, 0x75, + 0x4c, 0xb1, 0x53, 0x98, 0x6f, 0x71, 0xff, 0x47, 0x9b, 0xb2, 0xe5, 0x53, 0xb2, 0xbd, 0xc7, 0xec, + 0x1c, 0x92, 0xfa, 0xbe, 0xe1, 0x96, 0xcf, 0xb2, 0x70, 0x99, 0xbc, 0x3d, 0x59, 0x0d, 0x23, 0x59, + 0x0d, 0xf3, 0xc8, 0xc7, 0x47, 0xd9, 0x09, 0x4c, 0x51, 0xdd, 0x4a, 0x85, 0x7c, 0x4e, 0x4f, 0xf6, + 0xc8, 0xf5, 0x25, 0x0b, 0xad, 0x78, 0xdc, 0xf5, 0xe5, 0x6a, 0xf6, 0x0a, 0x40, 0x34, 0xf2, 0x67, + 0xdf, 0x00, 0x90, 0x32, 0x62, 0xd8, 0x4b, 0x88, 0x0b, 0xad, 0x4a, 0x49, 0x1d, 0x24, 0x24, 0x0f, + 0x84, 0x73, 0xb4, 0xe2, 0xb6, 0xe5, 0x8f, 0x3b, 0x47, 0x57, 0x77, 0x8e, 0x8d, 0x77, 0x3c, 0xf6, + 0x8e, 0x9e, 0x71, 0x7a, 0x89, 0x8d, 0xc1, 0x42, 0x58, 0x2c, 0xf9, 0x93, 0x2c, 0x58, 0xce, 0xf3, + 0x11, 0xc3, 0x5e, 0xc3, 0xb1, 0x95, 0x55, 0x85, 0xc6, 0x5b, 0x3c, 0x25, 0x8b, 0x43, 0x92, 0x5d, + 0x42, 0x22, 0x94, 0xd2, 0x56, 0xb8, 0x7f, 0xb4, 0x3c, 0xa5, 0xe9, 0xbc, 0x39, 0x98, 0x8e, 0xcf, + 0xd2, 0xc7, 0xe1, 0xdc, 0x85, 0xb2, 0x66, 0x9f, 0x8f, 0x6f, 0xba, 0x25, 0x6d, 0x77, 0x37, 0xe8, + 0x1f, 0x7b, 0xd6, 0x2d, 0x69, 0x44, 0x9d, 0x7e, 0x80, 0xf4, 0x7f, 0x0b, 0x97, 0xaa, 0x2d, 0xee, + 0xfb, 0xd4, 0xb8, 0xd2, 0xa5, 0xef, 0x4e, 0x54, 0x3b, 0x9f, 0x9a, 0x0e, 0xbc, 0x3f, 0x3a, 0x0f, + 0x16, 0x19, 0x4c, 0x2f, 0xba, 0x05, 0x24, 0x30, 0xfb, 0xb1, 0xfe, 0xb2, 0xbe, 0xfe, 0xb5, 0x4e, + 0x1f, 0xb1, 0x18, 0xa2, 0xcb, 0xeb, 0xef, 0xdf, 0xbe, 0xa6, 0xc1, 0xa7, 0xd9, 0xef, 0x88, 0xfe, + 0x7c, 0x33, 0xa5, 0xdc, 0xbf, 0xfb, 0x17, 0x00, 0x00, 0xff, 0xff, 0x36, 0xf9, 0x0d, 0xa6, 0x14, + 0x03, 0x00, 0x00, } diff --git a/vendor/k8s.io/helm/pkg/proto/hapi/release/hook.pb.go b/vendor/k8s.io/helm/pkg/proto/hapi/release/hook.pb.go new file mode 100644 index 00000000000..00fa5c18857 --- /dev/null +++ b/vendor/k8s.io/helm/pkg/proto/hapi/release/hook.pb.go @@ -0,0 +1,231 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: hapi/release/hook.proto + +/* +Package release is a generated protocol buffer package. + +It is generated from these files: + hapi/release/hook.proto + hapi/release/info.proto + hapi/release/release.proto + hapi/release/status.proto + hapi/release/test_run.proto + hapi/release/test_suite.proto + +It has these top-level messages: + Hook + Info + Release + Status + TestRun + TestSuite +*/ +package release + +import proto "github.com/golang/protobuf/proto" +import fmt "fmt" +import math "math" +import google_protobuf "github.com/golang/protobuf/ptypes/timestamp" + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package + +type Hook_Event int32 + +const ( + Hook_UNKNOWN Hook_Event = 0 + Hook_PRE_INSTALL Hook_Event = 1 + Hook_POST_INSTALL Hook_Event = 2 + Hook_PRE_DELETE Hook_Event = 3 + Hook_POST_DELETE Hook_Event = 4 + Hook_PRE_UPGRADE Hook_Event = 5 + Hook_POST_UPGRADE Hook_Event = 6 + Hook_PRE_ROLLBACK Hook_Event = 7 + Hook_POST_ROLLBACK Hook_Event = 8 + Hook_RELEASE_TEST_SUCCESS Hook_Event = 9 + Hook_RELEASE_TEST_FAILURE Hook_Event = 10 +) + +var Hook_Event_name = map[int32]string{ + 0: "UNKNOWN", + 1: "PRE_INSTALL", + 2: "POST_INSTALL", + 3: "PRE_DELETE", + 4: "POST_DELETE", + 5: "PRE_UPGRADE", + 6: "POST_UPGRADE", + 7: "PRE_ROLLBACK", + 8: "POST_ROLLBACK", + 9: "RELEASE_TEST_SUCCESS", + 10: "RELEASE_TEST_FAILURE", +} +var Hook_Event_value = map[string]int32{ + "UNKNOWN": 0, + "PRE_INSTALL": 1, + "POST_INSTALL": 2, + "PRE_DELETE": 3, + "POST_DELETE": 4, + "PRE_UPGRADE": 5, + "POST_UPGRADE": 6, + "PRE_ROLLBACK": 7, + "POST_ROLLBACK": 8, + "RELEASE_TEST_SUCCESS": 9, + "RELEASE_TEST_FAILURE": 10, +} + +func (x Hook_Event) String() string { + return proto.EnumName(Hook_Event_name, int32(x)) +} +func (Hook_Event) EnumDescriptor() ([]byte, []int) { return fileDescriptor0, []int{0, 0} } + +type Hook_DeletePolicy int32 + +const ( + Hook_SUCCEEDED Hook_DeletePolicy = 0 + Hook_FAILED Hook_DeletePolicy = 1 + Hook_BEFORE_HOOK_CREATION Hook_DeletePolicy = 2 +) + +var Hook_DeletePolicy_name = map[int32]string{ + 0: "SUCCEEDED", + 1: "FAILED", + 2: "BEFORE_HOOK_CREATION", +} +var Hook_DeletePolicy_value = map[string]int32{ + "SUCCEEDED": 0, + "FAILED": 1, + "BEFORE_HOOK_CREATION": 2, +} + +func (x Hook_DeletePolicy) String() string { + return proto.EnumName(Hook_DeletePolicy_name, int32(x)) +} +func (Hook_DeletePolicy) EnumDescriptor() ([]byte, []int) { return fileDescriptor0, []int{0, 1} } + +// Hook defines a hook object. +type Hook struct { + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // Kind is the Kubernetes kind. + Kind string `protobuf:"bytes,2,opt,name=kind" json:"kind,omitempty"` + // Path is the chart-relative path to the template. + Path string `protobuf:"bytes,3,opt,name=path" json:"path,omitempty"` + // Manifest is the manifest contents. + Manifest string `protobuf:"bytes,4,opt,name=manifest" json:"manifest,omitempty"` + // Events are the events that this hook fires on. + Events []Hook_Event `protobuf:"varint,5,rep,packed,name=events,enum=hapi.release.Hook_Event" json:"events,omitempty"` + // LastRun indicates the date/time this was last run. + LastRun *google_protobuf.Timestamp `protobuf:"bytes,6,opt,name=last_run,json=lastRun" json:"last_run,omitempty"` + // Weight indicates the sort order for execution among similar Hook type + Weight int32 `protobuf:"varint,7,opt,name=weight" json:"weight,omitempty"` + // DeletePolicies are the policies that indicate when to delete the hook + DeletePolicies []Hook_DeletePolicy `protobuf:"varint,8,rep,packed,name=delete_policies,json=deletePolicies,enum=hapi.release.Hook_DeletePolicy" json:"delete_policies,omitempty"` +} + +func (m *Hook) Reset() { *m = Hook{} } +func (m *Hook) String() string { return proto.CompactTextString(m) } +func (*Hook) ProtoMessage() {} +func (*Hook) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{0} } + +func (m *Hook) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *Hook) GetKind() string { + if m != nil { + return m.Kind + } + return "" +} + +func (m *Hook) GetPath() string { + if m != nil { + return m.Path + } + return "" +} + +func (m *Hook) GetManifest() string { + if m != nil { + return m.Manifest + } + return "" +} + +func (m *Hook) GetEvents() []Hook_Event { + if m != nil { + return m.Events + } + return nil +} + +func (m *Hook) GetLastRun() *google_protobuf.Timestamp { + if m != nil { + return m.LastRun + } + return nil +} + +func (m *Hook) GetWeight() int32 { + if m != nil { + return m.Weight + } + return 0 +} + +func (m *Hook) GetDeletePolicies() []Hook_DeletePolicy { + if m != nil { + return m.DeletePolicies + } + return nil +} + +func init() { + proto.RegisterType((*Hook)(nil), "hapi.release.Hook") + proto.RegisterEnum("hapi.release.Hook_Event", Hook_Event_name, Hook_Event_value) + proto.RegisterEnum("hapi.release.Hook_DeletePolicy", Hook_DeletePolicy_name, Hook_DeletePolicy_value) +} + +func init() { proto.RegisterFile("hapi/release/hook.proto", fileDescriptor0) } + +var fileDescriptor0 = []byte{ + // 445 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x6c, 0x91, 0x51, 0x8f, 0x9a, 0x40, + 0x10, 0x80, 0x8f, 0x13, 0x41, 0x47, 0xcf, 0xdb, 0x6e, 0x9a, 0x76, 0xe3, 0xcb, 0x19, 0x9f, 0x7c, + 0xc2, 0xe6, 0x9a, 0xfe, 0x00, 0x84, 0xb9, 0x6a, 0x24, 0x60, 0x16, 0x4c, 0x93, 0xbe, 0x10, 0xae, + 0xee, 0x29, 0x11, 0x81, 0x08, 0xb6, 0xe9, 0x0f, 0xec, 0x3f, 0xe8, 0x0f, 0x6a, 0x76, 0x45, 0x7b, + 0x49, 0xfb, 0x36, 0xf3, 0xcd, 0x37, 0xc3, 0x0c, 0x0b, 0xef, 0x77, 0x49, 0x99, 0x4e, 0x8f, 0x22, + 0x13, 0x49, 0x25, 0xa6, 0xbb, 0xa2, 0xd8, 0x5b, 0xe5, 0xb1, 0xa8, 0x0b, 0xda, 0x97, 0x05, 0xab, + 0x29, 0x0c, 0x1f, 0xb6, 0x45, 0xb1, 0xcd, 0xc4, 0x54, 0xd5, 0x9e, 0x4f, 0x2f, 0xd3, 0x3a, 0x3d, + 0x88, 0xaa, 0x4e, 0x0e, 0xe5, 0x59, 0x1f, 0xff, 0xd2, 0x41, 0x9f, 0x17, 0xc5, 0x9e, 0x52, 0xd0, + 0xf3, 0xe4, 0x20, 0x98, 0x36, 0xd2, 0x26, 0x5d, 0xae, 0x62, 0xc9, 0xf6, 0x69, 0xbe, 0x61, 0xb7, + 0x67, 0x26, 0x63, 0xc9, 0xca, 0xa4, 0xde, 0xb1, 0xd6, 0x99, 0xc9, 0x98, 0x0e, 0xa1, 0x73, 0x48, + 0xf2, 0xf4, 0x45, 0x54, 0x35, 0xd3, 0x15, 0xbf, 0xe6, 0xf4, 0x03, 0x18, 0xe2, 0xbb, 0xc8, 0xeb, + 0x8a, 0xb5, 0x47, 0xad, 0xc9, 0xe0, 0x91, 0x59, 0xaf, 0x17, 0xb4, 0xe4, 0xb7, 0x2d, 0x94, 0x02, + 0x6f, 0x3c, 0xfa, 0x09, 0x3a, 0x59, 0x52, 0xd5, 0xf1, 0xf1, 0x94, 0x33, 0x63, 0xa4, 0x4d, 0x7a, + 0x8f, 0x43, 0xeb, 0x7c, 0x86, 0x75, 0x39, 0xc3, 0x8a, 0x2e, 0x67, 0x70, 0x53, 0xba, 0xfc, 0x94, + 0xd3, 0x77, 0x60, 0xfc, 0x10, 0xe9, 0x76, 0x57, 0x33, 0x73, 0xa4, 0x4d, 0xda, 0xbc, 0xc9, 0xe8, + 0x1c, 0xee, 0x37, 0x22, 0x13, 0xb5, 0x88, 0xcb, 0x22, 0x4b, 0xbf, 0xa5, 0xa2, 0x62, 0x1d, 0xb5, + 0xc9, 0xc3, 0x7f, 0x36, 0x71, 0x95, 0xb9, 0x92, 0xe2, 0x4f, 0x3e, 0xd8, 0xfc, 0xcd, 0x52, 0x51, + 0x8d, 0x7f, 0x6b, 0xd0, 0x56, 0xab, 0xd2, 0x1e, 0x98, 0x6b, 0x7f, 0xe9, 0x07, 0x5f, 0x7c, 0x72, + 0x43, 0xef, 0xa1, 0xb7, 0xe2, 0x18, 0x2f, 0xfc, 0x30, 0xb2, 0x3d, 0x8f, 0x68, 0x94, 0x40, 0x7f, + 0x15, 0x84, 0xd1, 0x95, 0xdc, 0xd2, 0x01, 0x80, 0x54, 0x5c, 0xf4, 0x30, 0x42, 0xd2, 0x52, 0x2d, + 0xd2, 0x68, 0x80, 0x7e, 0x99, 0xb1, 0x5e, 0x7d, 0xe6, 0xb6, 0x8b, 0xa4, 0x7d, 0x9d, 0x71, 0x21, + 0x86, 0x22, 0x1c, 0x63, 0x1e, 0x78, 0xde, 0xcc, 0x76, 0x96, 0xc4, 0xa4, 0x6f, 0xe0, 0x4e, 0x39, + 0x57, 0xd4, 0xa1, 0x0c, 0xde, 0x72, 0xf4, 0xd0, 0x0e, 0x31, 0x8e, 0x30, 0x8c, 0xe2, 0x70, 0xed, + 0x38, 0x18, 0x86, 0xa4, 0xfb, 0x4f, 0xe5, 0xc9, 0x5e, 0x78, 0x6b, 0x8e, 0x04, 0xc6, 0x0e, 0xf4, + 0x5f, 0x9f, 0x4d, 0xef, 0xa0, 0xab, 0xda, 0xd0, 0x45, 0x97, 0xdc, 0x50, 0x00, 0x43, 0xba, 0xe8, + 0x12, 0x4d, 0x0e, 0x99, 0xe1, 0x53, 0xc0, 0x31, 0x9e, 0x07, 0xc1, 0x32, 0x76, 0x38, 0xda, 0xd1, + 0x22, 0xf0, 0xc9, 0xed, 0xac, 0xfb, 0xd5, 0x6c, 0x7e, 0xe4, 0xb3, 0xa1, 0x5e, 0xe9, 0xe3, 0x9f, + 0x00, 0x00, 0x00, 0xff, 0xff, 0x13, 0x64, 0x75, 0x6c, 0xa3, 0x02, 0x00, 0x00, +} diff --git a/vendor/k8s.io/helm/pkg/proto/hapi/release/info.pb.go b/vendor/k8s.io/helm/pkg/proto/hapi/release/info.pb.go new file mode 100644 index 00000000000..7a7ccdd7467 --- /dev/null +++ b/vendor/k8s.io/helm/pkg/proto/hapi/release/info.pb.go @@ -0,0 +1,90 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: hapi/release/info.proto + +package release + +import proto "github.com/golang/protobuf/proto" +import fmt "fmt" +import math "math" +import google_protobuf "github.com/golang/protobuf/ptypes/timestamp" + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// Info describes release information. +type Info struct { + Status *Status `protobuf:"bytes,1,opt,name=status" json:"status,omitempty"` + FirstDeployed *google_protobuf.Timestamp `protobuf:"bytes,2,opt,name=first_deployed,json=firstDeployed" json:"first_deployed,omitempty"` + LastDeployed *google_protobuf.Timestamp `protobuf:"bytes,3,opt,name=last_deployed,json=lastDeployed" json:"last_deployed,omitempty"` + // Deleted tracks when this object was deleted. + Deleted *google_protobuf.Timestamp `protobuf:"bytes,4,opt,name=deleted" json:"deleted,omitempty"` + // Description is human-friendly "log entry" about this release. + Description string `protobuf:"bytes,5,opt,name=Description" json:"Description,omitempty"` +} + +func (m *Info) Reset() { *m = Info{} } +func (m *Info) String() string { return proto.CompactTextString(m) } +func (*Info) ProtoMessage() {} +func (*Info) Descriptor() ([]byte, []int) { return fileDescriptor1, []int{0} } + +func (m *Info) GetStatus() *Status { + if m != nil { + return m.Status + } + return nil +} + +func (m *Info) GetFirstDeployed() *google_protobuf.Timestamp { + if m != nil { + return m.FirstDeployed + } + return nil +} + +func (m *Info) GetLastDeployed() *google_protobuf.Timestamp { + if m != nil { + return m.LastDeployed + } + return nil +} + +func (m *Info) GetDeleted() *google_protobuf.Timestamp { + if m != nil { + return m.Deleted + } + return nil +} + +func (m *Info) GetDescription() string { + if m != nil { + return m.Description + } + return "" +} + +func init() { + proto.RegisterType((*Info)(nil), "hapi.release.Info") +} + +func init() { proto.RegisterFile("hapi/release/info.proto", fileDescriptor1) } + +var fileDescriptor1 = []byte{ + // 235 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x8f, 0x31, 0x4f, 0xc3, 0x30, + 0x10, 0x85, 0x95, 0x52, 0x5a, 0xd5, 0x6d, 0x19, 0x2c, 0x24, 0x42, 0x16, 0x22, 0xa6, 0x0e, 0xc8, + 0x91, 0x80, 0x1d, 0x81, 0xba, 0xb0, 0x06, 0x26, 0x16, 0xe4, 0xe2, 0x73, 0xb1, 0xe4, 0xe6, 0x2c, + 0xfb, 0x3a, 0xf0, 0x2f, 0xf8, 0xc9, 0xa8, 0xb6, 0x83, 0xd2, 0xa9, 0xab, 0xbf, 0xf7, 0x3e, 0xbf, + 0x63, 0x57, 0xdf, 0xd2, 0x99, 0xc6, 0x83, 0x05, 0x19, 0xa0, 0x31, 0x9d, 0x46, 0xe1, 0x3c, 0x12, + 0xf2, 0xc5, 0x01, 0x88, 0x0c, 0xaa, 0x9b, 0x2d, 0xe2, 0xd6, 0x42, 0x13, 0xd9, 0x66, 0xaf, 0x1b, + 0x32, 0x3b, 0x08, 0x24, 0x77, 0x2e, 0xc5, 0xab, 0xeb, 0x23, 0x4f, 0x20, 0x49, 0xfb, 0x90, 0xd0, + 0xed, 0xef, 0x88, 0x8d, 0x5f, 0x3b, 0x8d, 0xfc, 0x8e, 0x4d, 0x12, 0x28, 0x8b, 0xba, 0x58, 0xcd, + 0xef, 0x2f, 0xc5, 0xf0, 0x0f, 0xf1, 0x16, 0x59, 0x9b, 0x33, 0xfc, 0x99, 0x5d, 0x68, 0xe3, 0x03, + 0x7d, 0x2a, 0x70, 0x16, 0x7f, 0x40, 0x95, 0xa3, 0xd8, 0xaa, 0x44, 0xda, 0x22, 0xfa, 0x2d, 0xe2, + 0xbd, 0xdf, 0xd2, 0x2e, 0x63, 0x63, 0x9d, 0x0b, 0xfc, 0x89, 0x2d, 0xad, 0x1c, 0x1a, 0xce, 0x4e, + 0x1a, 0x16, 0x87, 0xc2, 0xbf, 0xe0, 0x91, 0x4d, 0x15, 0x58, 0x20, 0x50, 0xe5, 0xf8, 0x64, 0xb5, + 0x8f, 0xf2, 0x9a, 0xcd, 0xd7, 0x10, 0xbe, 0xbc, 0x71, 0x64, 0xb0, 0x2b, 0xcf, 0xeb, 0x62, 0x35, + 0x6b, 0x87, 0x4f, 0x2f, 0xb3, 0x8f, 0x69, 0xbe, 0x7a, 0x33, 0x89, 0xa6, 0x87, 0xbf, 0x00, 0x00, + 0x00, 0xff, 0xff, 0x1a, 0x52, 0x8f, 0x9c, 0x89, 0x01, 0x00, 0x00, +} diff --git a/vendor/k8s.io/helm/pkg/proto/hapi/release/release.pb.go b/vendor/k8s.io/helm/pkg/proto/hapi/release/release.pb.go new file mode 100644 index 00000000000..511b543d790 --- /dev/null +++ b/vendor/k8s.io/helm/pkg/proto/hapi/release/release.pb.go @@ -0,0 +1,124 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: hapi/release/release.proto + +package release + +import proto "github.com/golang/protobuf/proto" +import fmt "fmt" +import math "math" +import hapi_chart "k8s.io/helm/pkg/proto/hapi/chart" +import hapi_chart3 "k8s.io/helm/pkg/proto/hapi/chart" + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// Release describes a deployment of a chart, together with the chart +// and the variables used to deploy that chart. +type Release struct { + // Name is the name of the release + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // Info provides information about a release + Info *Info `protobuf:"bytes,2,opt,name=info" json:"info,omitempty"` + // Chart is the chart that was released. + Chart *hapi_chart3.Chart `protobuf:"bytes,3,opt,name=chart" json:"chart,omitempty"` + // Config is the set of extra Values added to the chart. + // These values override the default values inside of the chart. + Config *hapi_chart.Config `protobuf:"bytes,4,opt,name=config" json:"config,omitempty"` + // Manifest is the string representation of the rendered template. + Manifest string `protobuf:"bytes,5,opt,name=manifest" json:"manifest,omitempty"` + // Hooks are all of the hooks declared for this release. + Hooks []*Hook `protobuf:"bytes,6,rep,name=hooks" json:"hooks,omitempty"` + // Version is an int32 which represents the version of the release. + Version int32 `protobuf:"varint,7,opt,name=version" json:"version,omitempty"` + // Namespace is the kubernetes namespace of the release. + Namespace string `protobuf:"bytes,8,opt,name=namespace" json:"namespace,omitempty"` +} + +func (m *Release) Reset() { *m = Release{} } +func (m *Release) String() string { return proto.CompactTextString(m) } +func (*Release) ProtoMessage() {} +func (*Release) Descriptor() ([]byte, []int) { return fileDescriptor2, []int{0} } + +func (m *Release) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *Release) GetInfo() *Info { + if m != nil { + return m.Info + } + return nil +} + +func (m *Release) GetChart() *hapi_chart3.Chart { + if m != nil { + return m.Chart + } + return nil +} + +func (m *Release) GetConfig() *hapi_chart.Config { + if m != nil { + return m.Config + } + return nil +} + +func (m *Release) GetManifest() string { + if m != nil { + return m.Manifest + } + return "" +} + +func (m *Release) GetHooks() []*Hook { + if m != nil { + return m.Hooks + } + return nil +} + +func (m *Release) GetVersion() int32 { + if m != nil { + return m.Version + } + return 0 +} + +func (m *Release) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +func init() { + proto.RegisterType((*Release)(nil), "hapi.release.Release") +} + +func init() { proto.RegisterFile("hapi/release/release.proto", fileDescriptor2) } + +var fileDescriptor2 = []byte{ + // 256 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x64, 0x90, 0xbf, 0x4e, 0xc3, 0x40, + 0x0c, 0xc6, 0x95, 0x36, 0x7f, 0x1a, 0xc3, 0x82, 0x07, 0xb0, 0x22, 0x86, 0x88, 0x01, 0x22, 0x86, + 0x54, 0x82, 0x37, 0x80, 0x05, 0xd6, 0x1b, 0xd9, 0x8e, 0xe8, 0x42, 0x4e, 0xa5, 0xe7, 0x28, 0x17, + 0xf1, 0x2c, 0x3c, 0x2e, 0xba, 0x3f, 0x85, 0x94, 0x2e, 0x4e, 0xec, 0xdf, 0xa7, 0xcf, 0xdf, 0x19, + 0xaa, 0x41, 0x8e, 0x7a, 0x3b, 0xa9, 0x4f, 0x25, 0xad, 0x3a, 0x7c, 0xdb, 0x71, 0xe2, 0x99, 0xf1, + 0xdc, 0xb1, 0x36, 0xce, 0xaa, 0xab, 0x23, 0xe5, 0xc0, 0xbc, 0x0b, 0xb2, 0x7f, 0x40, 0x9b, 0x9e, + 0x8f, 0x40, 0x37, 0xc8, 0x69, 0xde, 0x76, 0x6c, 0x7a, 0xfd, 0x11, 0xc1, 0xe5, 0x12, 0xb8, 0x1a, + 0xe6, 0x37, 0xdf, 0x2b, 0x28, 0x44, 0xf0, 0x41, 0x84, 0xd4, 0xc8, 0xbd, 0xa2, 0xa4, 0x4e, 0x9a, + 0x52, 0xf8, 0x7f, 0xbc, 0x85, 0xd4, 0xd9, 0xd3, 0xaa, 0x4e, 0x9a, 0xb3, 0x07, 0x6c, 0x97, 0xf9, + 0xda, 0x57, 0xd3, 0xb3, 0xf0, 0x1c, 0xef, 0x20, 0xf3, 0xb6, 0xb4, 0xf6, 0xc2, 0x8b, 0x20, 0x0c, + 0x9b, 0x9e, 0x5d, 0x15, 0x81, 0xe3, 0x3d, 0xe4, 0x21, 0x18, 0xa5, 0x4b, 0xcb, 0xa8, 0xf4, 0x44, + 0x44, 0x05, 0x56, 0xb0, 0xd9, 0x4b, 0xa3, 0x7b, 0x65, 0x67, 0xca, 0x7c, 0xa8, 0xdf, 0x1e, 0x1b, + 0xc8, 0xdc, 0x41, 0x2c, 0xe5, 0xf5, 0xfa, 0x34, 0xd9, 0x0b, 0xf3, 0x4e, 0x04, 0x01, 0x12, 0x14, + 0x5f, 0x6a, 0xb2, 0x9a, 0x0d, 0x15, 0x75, 0xd2, 0x64, 0xe2, 0xd0, 0xe2, 0x35, 0x94, 0xee, 0x91, + 0x76, 0x94, 0x9d, 0xa2, 0x8d, 0x5f, 0xf0, 0x37, 0x78, 0x2a, 0xdf, 0x8a, 0x68, 0xf7, 0x9e, 0xfb, + 0x63, 0x3d, 0xfe, 0x04, 0x00, 0x00, 0xff, 0xff, 0xc8, 0x8f, 0xec, 0x97, 0xbb, 0x01, 0x00, 0x00, +} diff --git a/vendor/k8s.io/helm/pkg/proto/hapi/release/status.pb.go b/vendor/k8s.io/helm/pkg/proto/hapi/release/status.pb.go new file mode 100644 index 00000000000..284892642f9 --- /dev/null +++ b/vendor/k8s.io/helm/pkg/proto/hapi/release/status.pb.go @@ -0,0 +1,141 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: hapi/release/status.proto + +package release + +import proto "github.com/golang/protobuf/proto" +import fmt "fmt" +import math "math" +import _ "github.com/golang/protobuf/ptypes/any" + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +type Status_Code int32 + +const ( + // Status_UNKNOWN indicates that a release is in an uncertain state. + Status_UNKNOWN Status_Code = 0 + // Status_DEPLOYED indicates that the release has been pushed to Kubernetes. + Status_DEPLOYED Status_Code = 1 + // Status_DELETED indicates that a release has been deleted from Kubermetes. + Status_DELETED Status_Code = 2 + // Status_SUPERSEDED indicates that this release object is outdated and a newer one exists. + Status_SUPERSEDED Status_Code = 3 + // Status_FAILED indicates that the release was not successfully deployed. + Status_FAILED Status_Code = 4 + // Status_DELETING indicates that a delete operation is underway. + Status_DELETING Status_Code = 5 + // Status_PENDING_INSTALL indicates that an install operation is underway. + Status_PENDING_INSTALL Status_Code = 6 + // Status_PENDING_UPGRADE indicates that an upgrade operation is underway. + Status_PENDING_UPGRADE Status_Code = 7 + // Status_PENDING_ROLLBACK indicates that an rollback operation is underway. + Status_PENDING_ROLLBACK Status_Code = 8 +) + +var Status_Code_name = map[int32]string{ + 0: "UNKNOWN", + 1: "DEPLOYED", + 2: "DELETED", + 3: "SUPERSEDED", + 4: "FAILED", + 5: "DELETING", + 6: "PENDING_INSTALL", + 7: "PENDING_UPGRADE", + 8: "PENDING_ROLLBACK", +} +var Status_Code_value = map[string]int32{ + "UNKNOWN": 0, + "DEPLOYED": 1, + "DELETED": 2, + "SUPERSEDED": 3, + "FAILED": 4, + "DELETING": 5, + "PENDING_INSTALL": 6, + "PENDING_UPGRADE": 7, + "PENDING_ROLLBACK": 8, +} + +func (x Status_Code) String() string { + return proto.EnumName(Status_Code_name, int32(x)) +} +func (Status_Code) EnumDescriptor() ([]byte, []int) { return fileDescriptor3, []int{0, 0} } + +// Status defines the status of a release. +type Status struct { + Code Status_Code `protobuf:"varint,1,opt,name=code,enum=hapi.release.Status_Code" json:"code,omitempty"` + // Cluster resources as kubectl would print them. + Resources string `protobuf:"bytes,3,opt,name=resources" json:"resources,omitempty"` + // Contains the rendered templates/NOTES.txt if available + Notes string `protobuf:"bytes,4,opt,name=notes" json:"notes,omitempty"` + // LastTestSuiteRun provides results on the last test run on a release + LastTestSuiteRun *TestSuite `protobuf:"bytes,5,opt,name=last_test_suite_run,json=lastTestSuiteRun" json:"last_test_suite_run,omitempty"` +} + +func (m *Status) Reset() { *m = Status{} } +func (m *Status) String() string { return proto.CompactTextString(m) } +func (*Status) ProtoMessage() {} +func (*Status) Descriptor() ([]byte, []int) { return fileDescriptor3, []int{0} } + +func (m *Status) GetCode() Status_Code { + if m != nil { + return m.Code + } + return Status_UNKNOWN +} + +func (m *Status) GetResources() string { + if m != nil { + return m.Resources + } + return "" +} + +func (m *Status) GetNotes() string { + if m != nil { + return m.Notes + } + return "" +} + +func (m *Status) GetLastTestSuiteRun() *TestSuite { + if m != nil { + return m.LastTestSuiteRun + } + return nil +} + +func init() { + proto.RegisterType((*Status)(nil), "hapi.release.Status") + proto.RegisterEnum("hapi.release.Status_Code", Status_Code_name, Status_Code_value) +} + +func init() { proto.RegisterFile("hapi/release/status.proto", fileDescriptor3) } + +var fileDescriptor3 = []byte{ + // 333 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x54, 0x90, 0xd1, 0x6e, 0xa2, 0x40, + 0x14, 0x86, 0x17, 0x45, 0xd4, 0xa3, 0x71, 0x27, 0xa3, 0xc9, 0xa2, 0xd9, 0x4d, 0x8c, 0x57, 0xde, + 0x2c, 0x24, 0xf6, 0x09, 0xd0, 0x19, 0x0d, 0x71, 0x82, 0x04, 0x30, 0x4d, 0x7b, 0x43, 0x50, 0xa7, + 0xd6, 0xc4, 0x30, 0x86, 0x19, 0x2e, 0xfa, 0x26, 0x7d, 0xaa, 0x3e, 0x53, 0x03, 0xd8, 0xa8, 0x97, + 0xff, 0xff, 0x7d, 0x87, 0x73, 0x18, 0x18, 0xbe, 0x27, 0x97, 0x93, 0x9d, 0xf1, 0x33, 0x4f, 0x24, + 0xb7, 0xa5, 0x4a, 0x54, 0x2e, 0xad, 0x4b, 0x26, 0x94, 0xc0, 0xdd, 0x02, 0x59, 0x57, 0x34, 0xfa, + 0xf7, 0x20, 0x2a, 0x2e, 0x55, 0x2c, 0xf3, 0x93, 0xe2, 0x95, 0x3c, 0x1a, 0x1e, 0x85, 0x38, 0x9e, + 0xb9, 0x5d, 0xa6, 0x5d, 0xfe, 0x66, 0x27, 0xe9, 0x47, 0x85, 0x26, 0x5f, 0x35, 0x30, 0xc2, 0xf2, + 0xc3, 0xf8, 0x3f, 0xe8, 0x7b, 0x71, 0xe0, 0xa6, 0x36, 0xd6, 0xa6, 0xbd, 0xd9, 0xd0, 0xba, 0xdf, + 0x60, 0x55, 0x8e, 0xb5, 0x10, 0x07, 0x1e, 0x94, 0x1a, 0xfe, 0x0b, 0xed, 0x8c, 0x4b, 0x91, 0x67, + 0x7b, 0x2e, 0xcd, 0xfa, 0x58, 0x9b, 0xb6, 0x83, 0x5b, 0x81, 0x07, 0xd0, 0x48, 0x85, 0xe2, 0xd2, + 0xd4, 0x4b, 0x52, 0x05, 0xbc, 0x84, 0xfe, 0x39, 0x91, 0x2a, 0xbe, 0x5d, 0x18, 0x67, 0x79, 0x6a, + 0x36, 0xc6, 0xda, 0xb4, 0x33, 0xfb, 0xf3, 0xb8, 0x31, 0xe2, 0x52, 0x85, 0x85, 0x12, 0xa0, 0x62, + 0xe6, 0x16, 0xf3, 0x74, 0xf2, 0xa9, 0x81, 0x5e, 0x9c, 0x82, 0x3b, 0xd0, 0xdc, 0x7a, 0x6b, 0x6f, + 0xf3, 0xec, 0xa1, 0x5f, 0xb8, 0x0b, 0x2d, 0x42, 0x7d, 0xb6, 0x79, 0xa1, 0x04, 0x69, 0x05, 0x22, + 0x94, 0xd1, 0x88, 0x12, 0x54, 0xc3, 0x3d, 0x80, 0x70, 0xeb, 0xd3, 0x20, 0xa4, 0x84, 0x12, 0x54, + 0xc7, 0x00, 0xc6, 0xd2, 0x71, 0x19, 0x25, 0x48, 0xaf, 0xc6, 0x18, 0x8d, 0x5c, 0x6f, 0x85, 0x1a, + 0xb8, 0x0f, 0xbf, 0x7d, 0xea, 0x11, 0xd7, 0x5b, 0xc5, 0xae, 0x17, 0x46, 0x0e, 0x63, 0xc8, 0xb8, + 0x2f, 0xb7, 0xfe, 0x2a, 0x70, 0x08, 0x45, 0x4d, 0x3c, 0x00, 0xf4, 0x53, 0x06, 0x1b, 0xc6, 0xe6, + 0xce, 0x62, 0x8d, 0x5a, 0xf3, 0xf6, 0x6b, 0xf3, 0xfa, 0x07, 0x3b, 0xa3, 0x7c, 0xe2, 0xa7, 0xef, + 0x00, 0x00, 0x00, 0xff, 0xff, 0x09, 0x48, 0x18, 0xba, 0xc7, 0x01, 0x00, 0x00, +} diff --git a/vendor/k8s.io/helm/pkg/proto/hapi/release/test_run.pb.go b/vendor/k8s.io/helm/pkg/proto/hapi/release/test_run.pb.go new file mode 100644 index 00000000000..4d39d17c2b8 --- /dev/null +++ b/vendor/k8s.io/helm/pkg/proto/hapi/release/test_run.pb.go @@ -0,0 +1,118 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: hapi/release/test_run.proto + +package release + +import proto "github.com/golang/protobuf/proto" +import fmt "fmt" +import math "math" +import google_protobuf "github.com/golang/protobuf/ptypes/timestamp" + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +type TestRun_Status int32 + +const ( + TestRun_UNKNOWN TestRun_Status = 0 + TestRun_SUCCESS TestRun_Status = 1 + TestRun_FAILURE TestRun_Status = 2 + TestRun_RUNNING TestRun_Status = 3 +) + +var TestRun_Status_name = map[int32]string{ + 0: "UNKNOWN", + 1: "SUCCESS", + 2: "FAILURE", + 3: "RUNNING", +} +var TestRun_Status_value = map[string]int32{ + "UNKNOWN": 0, + "SUCCESS": 1, + "FAILURE": 2, + "RUNNING": 3, +} + +func (x TestRun_Status) String() string { + return proto.EnumName(TestRun_Status_name, int32(x)) +} +func (TestRun_Status) EnumDescriptor() ([]byte, []int) { return fileDescriptor4, []int{0, 0} } + +type TestRun struct { + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + Status TestRun_Status `protobuf:"varint,2,opt,name=status,enum=hapi.release.TestRun_Status" json:"status,omitempty"` + Info string `protobuf:"bytes,3,opt,name=info" json:"info,omitempty"` + StartedAt *google_protobuf.Timestamp `protobuf:"bytes,4,opt,name=started_at,json=startedAt" json:"started_at,omitempty"` + CompletedAt *google_protobuf.Timestamp `protobuf:"bytes,5,opt,name=completed_at,json=completedAt" json:"completed_at,omitempty"` +} + +func (m *TestRun) Reset() { *m = TestRun{} } +func (m *TestRun) String() string { return proto.CompactTextString(m) } +func (*TestRun) ProtoMessage() {} +func (*TestRun) Descriptor() ([]byte, []int) { return fileDescriptor4, []int{0} } + +func (m *TestRun) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *TestRun) GetStatus() TestRun_Status { + if m != nil { + return m.Status + } + return TestRun_UNKNOWN +} + +func (m *TestRun) GetInfo() string { + if m != nil { + return m.Info + } + return "" +} + +func (m *TestRun) GetStartedAt() *google_protobuf.Timestamp { + if m != nil { + return m.StartedAt + } + return nil +} + +func (m *TestRun) GetCompletedAt() *google_protobuf.Timestamp { + if m != nil { + return m.CompletedAt + } + return nil +} + +func init() { + proto.RegisterType((*TestRun)(nil), "hapi.release.TestRun") + proto.RegisterEnum("hapi.release.TestRun_Status", TestRun_Status_name, TestRun_Status_value) +} + +func init() { proto.RegisterFile("hapi/release/test_run.proto", fileDescriptor4) } + +var fileDescriptor4 = []byte{ + // 274 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x8f, 0xc1, 0x4b, 0xfb, 0x30, + 0x1c, 0xc5, 0x7f, 0xe9, 0xf6, 0x6b, 0x69, 0x3a, 0xa4, 0xe4, 0x54, 0xa6, 0x60, 0xd9, 0xa9, 0xa7, + 0x14, 0xa6, 0x17, 0x41, 0x0f, 0x75, 0x4c, 0x19, 0x4a, 0x84, 0x74, 0x45, 0xf0, 0x32, 0x32, 0xcd, + 0x66, 0xa1, 0x6d, 0x4a, 0xf3, 0xed, 0xdf, 0xe3, 0xbf, 0x2a, 0x69, 0x33, 0xf1, 0xe6, 0xed, 0xfb, + 0x78, 0x9f, 0xf7, 0xf2, 0x82, 0xcf, 0x3f, 0x45, 0x5b, 0xa6, 0x9d, 0xac, 0xa4, 0xd0, 0x32, 0x05, + 0xa9, 0x61, 0xd7, 0xf5, 0x0d, 0x6d, 0x3b, 0x05, 0x8a, 0xcc, 0x8c, 0x49, 0xad, 0x39, 0xbf, 0x3c, + 0x2a, 0x75, 0xac, 0x64, 0x3a, 0x78, 0xfb, 0xfe, 0x90, 0x42, 0x59, 0x4b, 0x0d, 0xa2, 0x6e, 0x47, + 0x7c, 0xf1, 0xe5, 0x60, 0x6f, 0x2b, 0x35, 0xf0, 0xbe, 0x21, 0x04, 0x4f, 0x1b, 0x51, 0xcb, 0x08, + 0xc5, 0x28, 0xf1, 0xf9, 0x70, 0x93, 0x6b, 0xec, 0x6a, 0x10, 0xd0, 0xeb, 0xc8, 0x89, 0x51, 0x72, + 0xb6, 0xbc, 0xa0, 0xbf, 0xfb, 0xa9, 0x8d, 0xd2, 0x7c, 0x60, 0xb8, 0x65, 0x4d, 0x53, 0xd9, 0x1c, + 0x54, 0x34, 0x19, 0x9b, 0xcc, 0x4d, 0x6e, 0x30, 0xd6, 0x20, 0x3a, 0x90, 0x1f, 0x3b, 0x01, 0xd1, + 0x34, 0x46, 0x49, 0xb0, 0x9c, 0xd3, 0x71, 0x1f, 0x3d, 0xed, 0xa3, 0xdb, 0xd3, 0x3e, 0xee, 0x5b, + 0x3a, 0x03, 0x72, 0x87, 0x67, 0xef, 0xaa, 0x6e, 0x2b, 0x69, 0xc3, 0xff, 0xff, 0x0c, 0x07, 0x3f, + 0x7c, 0x06, 0x8b, 0x5b, 0xec, 0x8e, 0xfb, 0x48, 0x80, 0xbd, 0x82, 0x3d, 0xb1, 0x97, 0x57, 0x16, + 0xfe, 0x33, 0x22, 0x2f, 0x56, 0xab, 0x75, 0x9e, 0x87, 0xc8, 0x88, 0x87, 0x6c, 0xf3, 0x5c, 0xf0, + 0x75, 0xe8, 0x18, 0xc1, 0x0b, 0xc6, 0x36, 0xec, 0x31, 0x9c, 0xdc, 0xfb, 0x6f, 0x9e, 0xfd, 0xed, + 0xde, 0x1d, 0x5e, 0xba, 0xfa, 0x0e, 0x00, 0x00, 0xff, 0xff, 0x31, 0x86, 0x46, 0xdb, 0x81, 0x01, + 0x00, 0x00, +} diff --git a/vendor/k8s.io/helm/pkg/proto/hapi/release/test_suite.pb.go b/vendor/k8s.io/helm/pkg/proto/hapi/release/test_suite.pb.go new file mode 100644 index 00000000000..b7fa261476d --- /dev/null +++ b/vendor/k8s.io/helm/pkg/proto/hapi/release/test_suite.pb.go @@ -0,0 +1,73 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: hapi/release/test_suite.proto + +package release + +import proto "github.com/golang/protobuf/proto" +import fmt "fmt" +import math "math" +import google_protobuf "github.com/golang/protobuf/ptypes/timestamp" + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// TestSuite comprises of the last run of the pre-defined test suite of a release version +type TestSuite struct { + // StartedAt indicates the date/time this test suite was kicked off + StartedAt *google_protobuf.Timestamp `protobuf:"bytes,1,opt,name=started_at,json=startedAt" json:"started_at,omitempty"` + // CompletedAt indicates the date/time this test suite was completed + CompletedAt *google_protobuf.Timestamp `protobuf:"bytes,2,opt,name=completed_at,json=completedAt" json:"completed_at,omitempty"` + // Results are the results of each segment of the test + Results []*TestRun `protobuf:"bytes,3,rep,name=results" json:"results,omitempty"` +} + +func (m *TestSuite) Reset() { *m = TestSuite{} } +func (m *TestSuite) String() string { return proto.CompactTextString(m) } +func (*TestSuite) ProtoMessage() {} +func (*TestSuite) Descriptor() ([]byte, []int) { return fileDescriptor5, []int{0} } + +func (m *TestSuite) GetStartedAt() *google_protobuf.Timestamp { + if m != nil { + return m.StartedAt + } + return nil +} + +func (m *TestSuite) GetCompletedAt() *google_protobuf.Timestamp { + if m != nil { + return m.CompletedAt + } + return nil +} + +func (m *TestSuite) GetResults() []*TestRun { + if m != nil { + return m.Results + } + return nil +} + +func init() { + proto.RegisterType((*TestSuite)(nil), "hapi.release.TestSuite") +} + +func init() { proto.RegisterFile("hapi/release/test_suite.proto", fileDescriptor5) } + +var fileDescriptor5 = []byte{ + // 207 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x8f, 0xc1, 0x4a, 0x86, 0x40, + 0x14, 0x85, 0x31, 0x21, 0x71, 0x74, 0x35, 0x10, 0x88, 0x11, 0x49, 0x2b, 0x57, 0x33, 0x60, 0xab, + 0x16, 0x2d, 0xec, 0x11, 0xcc, 0x55, 0x1b, 0x19, 0xeb, 0x66, 0xc2, 0xe8, 0x0c, 0x73, 0xef, 0xbc, + 0x5a, 0xcf, 0x17, 0xea, 0x18, 0x41, 0x8b, 0x7f, 0xfd, 0x7d, 0xe7, 0x9c, 0x7b, 0xd9, 0xdd, 0x97, + 0xb2, 0xb3, 0x74, 0xa0, 0x41, 0x21, 0x48, 0x02, 0xa4, 0x01, 0xfd, 0x4c, 0x20, 0xac, 0x33, 0x64, + 0x78, 0xbe, 0x61, 0x11, 0x70, 0x79, 0x3f, 0x19, 0x33, 0x69, 0x90, 0x3b, 0x1b, 0xfd, 0xa7, 0xa4, + 0x79, 0x01, 0x24, 0xb5, 0xd8, 0x43, 0x2f, 0x6f, 0xff, 0xb7, 0x39, 0xbf, 0x1e, 0xf0, 0xe1, 0x3b, + 0x62, 0x69, 0x0f, 0x48, 0xaf, 0x5b, 0x3f, 0x7f, 0x62, 0x0c, 0x49, 0x39, 0x82, 0x8f, 0x41, 0x51, + 0x11, 0x55, 0x51, 0x9d, 0x35, 0xa5, 0x38, 0x06, 0xc4, 0x39, 0x20, 0xfa, 0x73, 0xa0, 0x4b, 0x83, + 0xdd, 0x12, 0x7f, 0x66, 0xf9, 0xbb, 0x59, 0xac, 0x86, 0x10, 0xbe, 0xba, 0x18, 0xce, 0x7e, 0xfd, + 0x96, 0xb8, 0x64, 0x89, 0x03, 0xf4, 0x9a, 0xb0, 0x88, 0xab, 0xb8, 0xce, 0x9a, 0x1b, 0xf1, 0xf7, + 0x4b, 0xb1, 0xdd, 0xd8, 0xf9, 0xb5, 0x3b, 0xad, 0x97, 0xf4, 0x2d, 0x09, 0x6c, 0xbc, 0xde, 0xcb, + 0x1f, 0x7f, 0x02, 0x00, 0x00, 0xff, 0xff, 0x8c, 0x59, 0x65, 0x4f, 0x37, 0x01, 0x00, 0x00, +} diff --git a/vendor/k8s.io/helm/pkg/proto/hapi/services/tiller.pb.go b/vendor/k8s.io/helm/pkg/proto/hapi/services/tiller.pb.go new file mode 100644 index 00000000000..37535aac719 --- /dev/null +++ b/vendor/k8s.io/helm/pkg/proto/hapi/services/tiller.pb.go @@ -0,0 +1,1449 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// source: hapi/services/tiller.proto + +/* +Package services is a generated protocol buffer package. + +It is generated from these files: + hapi/services/tiller.proto + +It has these top-level messages: + ListReleasesRequest + ListSort + ListReleasesResponse + GetReleaseStatusRequest + GetReleaseStatusResponse + GetReleaseContentRequest + GetReleaseContentResponse + UpdateReleaseRequest + UpdateReleaseResponse + RollbackReleaseRequest + RollbackReleaseResponse + InstallReleaseRequest + InstallReleaseResponse + UninstallReleaseRequest + UninstallReleaseResponse + GetVersionRequest + GetVersionResponse + GetHistoryRequest + GetHistoryResponse + TestReleaseRequest + TestReleaseResponse +*/ +package services + +import proto "github.com/golang/protobuf/proto" +import fmt "fmt" +import math "math" +import hapi_chart3 "k8s.io/helm/pkg/proto/hapi/chart" +import hapi_chart "k8s.io/helm/pkg/proto/hapi/chart" +import hapi_release5 "k8s.io/helm/pkg/proto/hapi/release" +import hapi_release4 "k8s.io/helm/pkg/proto/hapi/release" +import hapi_release1 "k8s.io/helm/pkg/proto/hapi/release" +import hapi_release3 "k8s.io/helm/pkg/proto/hapi/release" +import hapi_version "k8s.io/helm/pkg/proto/hapi/version" + +import ( + context "golang.org/x/net/context" + grpc "google.golang.org/grpc" +) + +// Reference imports to suppress errors if they are not otherwise used. +var _ = proto.Marshal +var _ = fmt.Errorf +var _ = math.Inf + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the proto package it is being compiled against. +// A compilation error at this line likely means your copy of the +// proto package needs to be updated. +const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package + +// SortBy defines sort operations. +type ListSort_SortBy int32 + +const ( + ListSort_UNKNOWN ListSort_SortBy = 0 + ListSort_NAME ListSort_SortBy = 1 + ListSort_LAST_RELEASED ListSort_SortBy = 2 +) + +var ListSort_SortBy_name = map[int32]string{ + 0: "UNKNOWN", + 1: "NAME", + 2: "LAST_RELEASED", +} +var ListSort_SortBy_value = map[string]int32{ + "UNKNOWN": 0, + "NAME": 1, + "LAST_RELEASED": 2, +} + +func (x ListSort_SortBy) String() string { + return proto.EnumName(ListSort_SortBy_name, int32(x)) +} +func (ListSort_SortBy) EnumDescriptor() ([]byte, []int) { return fileDescriptor0, []int{1, 0} } + +// SortOrder defines sort orders to augment sorting operations. +type ListSort_SortOrder int32 + +const ( + ListSort_ASC ListSort_SortOrder = 0 + ListSort_DESC ListSort_SortOrder = 1 +) + +var ListSort_SortOrder_name = map[int32]string{ + 0: "ASC", + 1: "DESC", +} +var ListSort_SortOrder_value = map[string]int32{ + "ASC": 0, + "DESC": 1, +} + +func (x ListSort_SortOrder) String() string { + return proto.EnumName(ListSort_SortOrder_name, int32(x)) +} +func (ListSort_SortOrder) EnumDescriptor() ([]byte, []int) { return fileDescriptor0, []int{1, 1} } + +// ListReleasesRequest requests a list of releases. +// +// Releases can be retrieved in chunks by setting limit and offset. +// +// Releases can be sorted according to a few pre-determined sort stategies. +type ListReleasesRequest struct { + // Limit is the maximum number of releases to be returned. + Limit int64 `protobuf:"varint,1,opt,name=limit" json:"limit,omitempty"` + // Offset is the last release name that was seen. The next listing + // operation will start with the name after this one. + // Example: If list one returns albert, bernie, carl, and sets 'next: dennis'. + // dennis is the offset. Supplying 'dennis' for the next request should + // cause the next batch to return a set of results starting with 'dennis'. + Offset string `protobuf:"bytes,2,opt,name=offset" json:"offset,omitempty"` + // SortBy is the sort field that the ListReleases server should sort data before returning. + SortBy ListSort_SortBy `protobuf:"varint,3,opt,name=sort_by,json=sortBy,enum=hapi.services.tiller.ListSort_SortBy" json:"sort_by,omitempty"` + // Filter is a regular expression used to filter which releases should be listed. + // + // Anything that matches the regexp will be included in the results. + Filter string `protobuf:"bytes,4,opt,name=filter" json:"filter,omitempty"` + // SortOrder is the ordering directive used for sorting. + SortOrder ListSort_SortOrder `protobuf:"varint,5,opt,name=sort_order,json=sortOrder,enum=hapi.services.tiller.ListSort_SortOrder" json:"sort_order,omitempty"` + StatusCodes []hapi_release3.Status_Code `protobuf:"varint,6,rep,packed,name=status_codes,json=statusCodes,enum=hapi.release.Status_Code" json:"status_codes,omitempty"` + // Namespace is the filter to select releases only from a specific namespace. + Namespace string `protobuf:"bytes,7,opt,name=namespace" json:"namespace,omitempty"` +} + +func (m *ListReleasesRequest) Reset() { *m = ListReleasesRequest{} } +func (m *ListReleasesRequest) String() string { return proto.CompactTextString(m) } +func (*ListReleasesRequest) ProtoMessage() {} +func (*ListReleasesRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{0} } + +func (m *ListReleasesRequest) GetLimit() int64 { + if m != nil { + return m.Limit + } + return 0 +} + +func (m *ListReleasesRequest) GetOffset() string { + if m != nil { + return m.Offset + } + return "" +} + +func (m *ListReleasesRequest) GetSortBy() ListSort_SortBy { + if m != nil { + return m.SortBy + } + return ListSort_UNKNOWN +} + +func (m *ListReleasesRequest) GetFilter() string { + if m != nil { + return m.Filter + } + return "" +} + +func (m *ListReleasesRequest) GetSortOrder() ListSort_SortOrder { + if m != nil { + return m.SortOrder + } + return ListSort_ASC +} + +func (m *ListReleasesRequest) GetStatusCodes() []hapi_release3.Status_Code { + if m != nil { + return m.StatusCodes + } + return nil +} + +func (m *ListReleasesRequest) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +// ListSort defines sorting fields on a release list. +type ListSort struct { +} + +func (m *ListSort) Reset() { *m = ListSort{} } +func (m *ListSort) String() string { return proto.CompactTextString(m) } +func (*ListSort) ProtoMessage() {} +func (*ListSort) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{1} } + +// ListReleasesResponse is a list of releases. +type ListReleasesResponse struct { + // Count is the expected total number of releases to be returned. + Count int64 `protobuf:"varint,1,opt,name=count" json:"count,omitempty"` + // Next is the name of the next release. If this is other than an empty + // string, it means there are more results. + Next string `protobuf:"bytes,2,opt,name=next" json:"next,omitempty"` + // Total is the total number of queryable releases. + Total int64 `protobuf:"varint,3,opt,name=total" json:"total,omitempty"` + // Releases is the list of found release objects. + Releases []*hapi_release5.Release `protobuf:"bytes,4,rep,name=releases" json:"releases,omitempty"` +} + +func (m *ListReleasesResponse) Reset() { *m = ListReleasesResponse{} } +func (m *ListReleasesResponse) String() string { return proto.CompactTextString(m) } +func (*ListReleasesResponse) ProtoMessage() {} +func (*ListReleasesResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{2} } + +func (m *ListReleasesResponse) GetCount() int64 { + if m != nil { + return m.Count + } + return 0 +} + +func (m *ListReleasesResponse) GetNext() string { + if m != nil { + return m.Next + } + return "" +} + +func (m *ListReleasesResponse) GetTotal() int64 { + if m != nil { + return m.Total + } + return 0 +} + +func (m *ListReleasesResponse) GetReleases() []*hapi_release5.Release { + if m != nil { + return m.Releases + } + return nil +} + +// GetReleaseStatusRequest is a request to get the status of a release. +type GetReleaseStatusRequest struct { + // Name is the name of the release + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // Version is the version of the release + Version int32 `protobuf:"varint,2,opt,name=version" json:"version,omitempty"` +} + +func (m *GetReleaseStatusRequest) Reset() { *m = GetReleaseStatusRequest{} } +func (m *GetReleaseStatusRequest) String() string { return proto.CompactTextString(m) } +func (*GetReleaseStatusRequest) ProtoMessage() {} +func (*GetReleaseStatusRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{3} } + +func (m *GetReleaseStatusRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *GetReleaseStatusRequest) GetVersion() int32 { + if m != nil { + return m.Version + } + return 0 +} + +// GetReleaseStatusResponse is the response indicating the status of the named release. +type GetReleaseStatusResponse struct { + // Name is the name of the release. + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // Info contains information about the release. + Info *hapi_release4.Info `protobuf:"bytes,2,opt,name=info" json:"info,omitempty"` + // Namespace the release was released into + Namespace string `protobuf:"bytes,3,opt,name=namespace" json:"namespace,omitempty"` +} + +func (m *GetReleaseStatusResponse) Reset() { *m = GetReleaseStatusResponse{} } +func (m *GetReleaseStatusResponse) String() string { return proto.CompactTextString(m) } +func (*GetReleaseStatusResponse) ProtoMessage() {} +func (*GetReleaseStatusResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{4} } + +func (m *GetReleaseStatusResponse) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *GetReleaseStatusResponse) GetInfo() *hapi_release4.Info { + if m != nil { + return m.Info + } + return nil +} + +func (m *GetReleaseStatusResponse) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +// GetReleaseContentRequest is a request to get the contents of a release. +type GetReleaseContentRequest struct { + // The name of the release + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // Version is the version of the release + Version int32 `protobuf:"varint,2,opt,name=version" json:"version,omitempty"` +} + +func (m *GetReleaseContentRequest) Reset() { *m = GetReleaseContentRequest{} } +func (m *GetReleaseContentRequest) String() string { return proto.CompactTextString(m) } +func (*GetReleaseContentRequest) ProtoMessage() {} +func (*GetReleaseContentRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{5} } + +func (m *GetReleaseContentRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *GetReleaseContentRequest) GetVersion() int32 { + if m != nil { + return m.Version + } + return 0 +} + +// GetReleaseContentResponse is a response containing the contents of a release. +type GetReleaseContentResponse struct { + // The release content + Release *hapi_release5.Release `protobuf:"bytes,1,opt,name=release" json:"release,omitempty"` +} + +func (m *GetReleaseContentResponse) Reset() { *m = GetReleaseContentResponse{} } +func (m *GetReleaseContentResponse) String() string { return proto.CompactTextString(m) } +func (*GetReleaseContentResponse) ProtoMessage() {} +func (*GetReleaseContentResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{6} } + +func (m *GetReleaseContentResponse) GetRelease() *hapi_release5.Release { + if m != nil { + return m.Release + } + return nil +} + +// UpdateReleaseRequest updates a release. +type UpdateReleaseRequest struct { + // The name of the release + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // Chart is the protobuf representation of a chart. + Chart *hapi_chart3.Chart `protobuf:"bytes,2,opt,name=chart" json:"chart,omitempty"` + // Values is a string containing (unparsed) YAML values. + Values *hapi_chart.Config `protobuf:"bytes,3,opt,name=values" json:"values,omitempty"` + // dry_run, if true, will run through the release logic, but neither create + DryRun bool `protobuf:"varint,4,opt,name=dry_run,json=dryRun" json:"dry_run,omitempty"` + // DisableHooks causes the server to skip running any hooks for the upgrade. + DisableHooks bool `protobuf:"varint,5,opt,name=disable_hooks,json=disableHooks" json:"disable_hooks,omitempty"` + // Performs pods restart for resources if applicable + Recreate bool `protobuf:"varint,6,opt,name=recreate" json:"recreate,omitempty"` + // timeout specifies the max amount of time any kubernetes client command can run. + Timeout int64 `protobuf:"varint,7,opt,name=timeout" json:"timeout,omitempty"` + // ResetValues will cause Tiller to ignore stored values, resetting to default values. + ResetValues bool `protobuf:"varint,8,opt,name=reset_values,json=resetValues" json:"reset_values,omitempty"` + // wait, if true, will wait until all Pods, PVCs, and Services are in a ready state + // before marking the release as successful. It will wait for as long as timeout + Wait bool `protobuf:"varint,9,opt,name=wait" json:"wait,omitempty"` + // ReuseValues will cause Tiller to reuse the values from the last release. + // This is ignored if reset_values is set. + ReuseValues bool `protobuf:"varint,10,opt,name=reuse_values,json=reuseValues" json:"reuse_values,omitempty"` + // Force resource update through delete/recreate if needed. + Force bool `protobuf:"varint,11,opt,name=force" json:"force,omitempty"` +} + +func (m *UpdateReleaseRequest) Reset() { *m = UpdateReleaseRequest{} } +func (m *UpdateReleaseRequest) String() string { return proto.CompactTextString(m) } +func (*UpdateReleaseRequest) ProtoMessage() {} +func (*UpdateReleaseRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{7} } + +func (m *UpdateReleaseRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *UpdateReleaseRequest) GetChart() *hapi_chart3.Chart { + if m != nil { + return m.Chart + } + return nil +} + +func (m *UpdateReleaseRequest) GetValues() *hapi_chart.Config { + if m != nil { + return m.Values + } + return nil +} + +func (m *UpdateReleaseRequest) GetDryRun() bool { + if m != nil { + return m.DryRun + } + return false +} + +func (m *UpdateReleaseRequest) GetDisableHooks() bool { + if m != nil { + return m.DisableHooks + } + return false +} + +func (m *UpdateReleaseRequest) GetRecreate() bool { + if m != nil { + return m.Recreate + } + return false +} + +func (m *UpdateReleaseRequest) GetTimeout() int64 { + if m != nil { + return m.Timeout + } + return 0 +} + +func (m *UpdateReleaseRequest) GetResetValues() bool { + if m != nil { + return m.ResetValues + } + return false +} + +func (m *UpdateReleaseRequest) GetWait() bool { + if m != nil { + return m.Wait + } + return false +} + +func (m *UpdateReleaseRequest) GetReuseValues() bool { + if m != nil { + return m.ReuseValues + } + return false +} + +func (m *UpdateReleaseRequest) GetForce() bool { + if m != nil { + return m.Force + } + return false +} + +// UpdateReleaseResponse is the response to an update request. +type UpdateReleaseResponse struct { + Release *hapi_release5.Release `protobuf:"bytes,1,opt,name=release" json:"release,omitempty"` +} + +func (m *UpdateReleaseResponse) Reset() { *m = UpdateReleaseResponse{} } +func (m *UpdateReleaseResponse) String() string { return proto.CompactTextString(m) } +func (*UpdateReleaseResponse) ProtoMessage() {} +func (*UpdateReleaseResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{8} } + +func (m *UpdateReleaseResponse) GetRelease() *hapi_release5.Release { + if m != nil { + return m.Release + } + return nil +} + +type RollbackReleaseRequest struct { + // The name of the release + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // dry_run, if true, will run through the release logic but no create + DryRun bool `protobuf:"varint,2,opt,name=dry_run,json=dryRun" json:"dry_run,omitempty"` + // DisableHooks causes the server to skip running any hooks for the rollback + DisableHooks bool `protobuf:"varint,3,opt,name=disable_hooks,json=disableHooks" json:"disable_hooks,omitempty"` + // Version is the version of the release to deploy. + Version int32 `protobuf:"varint,4,opt,name=version" json:"version,omitempty"` + // Performs pods restart for resources if applicable + Recreate bool `protobuf:"varint,5,opt,name=recreate" json:"recreate,omitempty"` + // timeout specifies the max amount of time any kubernetes client command can run. + Timeout int64 `protobuf:"varint,6,opt,name=timeout" json:"timeout,omitempty"` + // wait, if true, will wait until all Pods, PVCs, and Services are in a ready state + // before marking the release as successful. It will wait for as long as timeout + Wait bool `protobuf:"varint,7,opt,name=wait" json:"wait,omitempty"` + // Force resource update through delete/recreate if needed. + Force bool `protobuf:"varint,8,opt,name=force" json:"force,omitempty"` +} + +func (m *RollbackReleaseRequest) Reset() { *m = RollbackReleaseRequest{} } +func (m *RollbackReleaseRequest) String() string { return proto.CompactTextString(m) } +func (*RollbackReleaseRequest) ProtoMessage() {} +func (*RollbackReleaseRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{9} } + +func (m *RollbackReleaseRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *RollbackReleaseRequest) GetDryRun() bool { + if m != nil { + return m.DryRun + } + return false +} + +func (m *RollbackReleaseRequest) GetDisableHooks() bool { + if m != nil { + return m.DisableHooks + } + return false +} + +func (m *RollbackReleaseRequest) GetVersion() int32 { + if m != nil { + return m.Version + } + return 0 +} + +func (m *RollbackReleaseRequest) GetRecreate() bool { + if m != nil { + return m.Recreate + } + return false +} + +func (m *RollbackReleaseRequest) GetTimeout() int64 { + if m != nil { + return m.Timeout + } + return 0 +} + +func (m *RollbackReleaseRequest) GetWait() bool { + if m != nil { + return m.Wait + } + return false +} + +func (m *RollbackReleaseRequest) GetForce() bool { + if m != nil { + return m.Force + } + return false +} + +// RollbackReleaseResponse is the response to an update request. +type RollbackReleaseResponse struct { + Release *hapi_release5.Release `protobuf:"bytes,1,opt,name=release" json:"release,omitempty"` +} + +func (m *RollbackReleaseResponse) Reset() { *m = RollbackReleaseResponse{} } +func (m *RollbackReleaseResponse) String() string { return proto.CompactTextString(m) } +func (*RollbackReleaseResponse) ProtoMessage() {} +func (*RollbackReleaseResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{10} } + +func (m *RollbackReleaseResponse) GetRelease() *hapi_release5.Release { + if m != nil { + return m.Release + } + return nil +} + +// InstallReleaseRequest is the request for an installation of a chart. +type InstallReleaseRequest struct { + // Chart is the protobuf representation of a chart. + Chart *hapi_chart3.Chart `protobuf:"bytes,1,opt,name=chart" json:"chart,omitempty"` + // Values is a string containing (unparsed) YAML values. + Values *hapi_chart.Config `protobuf:"bytes,2,opt,name=values" json:"values,omitempty"` + // DryRun, if true, will run through the release logic, but neither create + // a release object nor deploy to Kubernetes. The release object returned + // in the response will be fake. + DryRun bool `protobuf:"varint,3,opt,name=dry_run,json=dryRun" json:"dry_run,omitempty"` + // Name is the candidate release name. This must be unique to the + // namespace, otherwise the server will return an error. If it is not + // supplied, the server will autogenerate one. + Name string `protobuf:"bytes,4,opt,name=name" json:"name,omitempty"` + // DisableHooks causes the server to skip running any hooks for the install. + DisableHooks bool `protobuf:"varint,5,opt,name=disable_hooks,json=disableHooks" json:"disable_hooks,omitempty"` + // Namepace is the kubernetes namespace of the release. + Namespace string `protobuf:"bytes,6,opt,name=namespace" json:"namespace,omitempty"` + // ReuseName requests that Tiller re-uses a name, instead of erroring out. + ReuseName bool `protobuf:"varint,7,opt,name=reuse_name,json=reuseName" json:"reuse_name,omitempty"` + // timeout specifies the max amount of time any kubernetes client command can run. + Timeout int64 `protobuf:"varint,8,opt,name=timeout" json:"timeout,omitempty"` + // wait, if true, will wait until all Pods, PVCs, and Services are in a ready state + // before marking the release as successful. It will wait for as long as timeout + Wait bool `protobuf:"varint,9,opt,name=wait" json:"wait,omitempty"` +} + +func (m *InstallReleaseRequest) Reset() { *m = InstallReleaseRequest{} } +func (m *InstallReleaseRequest) String() string { return proto.CompactTextString(m) } +func (*InstallReleaseRequest) ProtoMessage() {} +func (*InstallReleaseRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{11} } + +func (m *InstallReleaseRequest) GetChart() *hapi_chart3.Chart { + if m != nil { + return m.Chart + } + return nil +} + +func (m *InstallReleaseRequest) GetValues() *hapi_chart.Config { + if m != nil { + return m.Values + } + return nil +} + +func (m *InstallReleaseRequest) GetDryRun() bool { + if m != nil { + return m.DryRun + } + return false +} + +func (m *InstallReleaseRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *InstallReleaseRequest) GetDisableHooks() bool { + if m != nil { + return m.DisableHooks + } + return false +} + +func (m *InstallReleaseRequest) GetNamespace() string { + if m != nil { + return m.Namespace + } + return "" +} + +func (m *InstallReleaseRequest) GetReuseName() bool { + if m != nil { + return m.ReuseName + } + return false +} + +func (m *InstallReleaseRequest) GetTimeout() int64 { + if m != nil { + return m.Timeout + } + return 0 +} + +func (m *InstallReleaseRequest) GetWait() bool { + if m != nil { + return m.Wait + } + return false +} + +// InstallReleaseResponse is the response from a release installation. +type InstallReleaseResponse struct { + Release *hapi_release5.Release `protobuf:"bytes,1,opt,name=release" json:"release,omitempty"` +} + +func (m *InstallReleaseResponse) Reset() { *m = InstallReleaseResponse{} } +func (m *InstallReleaseResponse) String() string { return proto.CompactTextString(m) } +func (*InstallReleaseResponse) ProtoMessage() {} +func (*InstallReleaseResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{12} } + +func (m *InstallReleaseResponse) GetRelease() *hapi_release5.Release { + if m != nil { + return m.Release + } + return nil +} + +// UninstallReleaseRequest represents a request to uninstall a named release. +type UninstallReleaseRequest struct { + // Name is the name of the release to delete. + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // DisableHooks causes the server to skip running any hooks for the uninstall. + DisableHooks bool `protobuf:"varint,2,opt,name=disable_hooks,json=disableHooks" json:"disable_hooks,omitempty"` + // Purge removes the release from the store and make its name free for later use. + Purge bool `protobuf:"varint,3,opt,name=purge" json:"purge,omitempty"` + // timeout specifies the max amount of time any kubernetes client command can run. + Timeout int64 `protobuf:"varint,4,opt,name=timeout" json:"timeout,omitempty"` +} + +func (m *UninstallReleaseRequest) Reset() { *m = UninstallReleaseRequest{} } +func (m *UninstallReleaseRequest) String() string { return proto.CompactTextString(m) } +func (*UninstallReleaseRequest) ProtoMessage() {} +func (*UninstallReleaseRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{13} } + +func (m *UninstallReleaseRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *UninstallReleaseRequest) GetDisableHooks() bool { + if m != nil { + return m.DisableHooks + } + return false +} + +func (m *UninstallReleaseRequest) GetPurge() bool { + if m != nil { + return m.Purge + } + return false +} + +func (m *UninstallReleaseRequest) GetTimeout() int64 { + if m != nil { + return m.Timeout + } + return 0 +} + +// UninstallReleaseResponse represents a successful response to an uninstall request. +type UninstallReleaseResponse struct { + // Release is the release that was marked deleted. + Release *hapi_release5.Release `protobuf:"bytes,1,opt,name=release" json:"release,omitempty"` + // Info is an uninstall message + Info string `protobuf:"bytes,2,opt,name=info" json:"info,omitempty"` +} + +func (m *UninstallReleaseResponse) Reset() { *m = UninstallReleaseResponse{} } +func (m *UninstallReleaseResponse) String() string { return proto.CompactTextString(m) } +func (*UninstallReleaseResponse) ProtoMessage() {} +func (*UninstallReleaseResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{14} } + +func (m *UninstallReleaseResponse) GetRelease() *hapi_release5.Release { + if m != nil { + return m.Release + } + return nil +} + +func (m *UninstallReleaseResponse) GetInfo() string { + if m != nil { + return m.Info + } + return "" +} + +// GetVersionRequest requests for version information. +type GetVersionRequest struct { +} + +func (m *GetVersionRequest) Reset() { *m = GetVersionRequest{} } +func (m *GetVersionRequest) String() string { return proto.CompactTextString(m) } +func (*GetVersionRequest) ProtoMessage() {} +func (*GetVersionRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{15} } + +type GetVersionResponse struct { + Version *hapi_version.Version `protobuf:"bytes,1,opt,name=Version" json:"Version,omitempty"` +} + +func (m *GetVersionResponse) Reset() { *m = GetVersionResponse{} } +func (m *GetVersionResponse) String() string { return proto.CompactTextString(m) } +func (*GetVersionResponse) ProtoMessage() {} +func (*GetVersionResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{16} } + +func (m *GetVersionResponse) GetVersion() *hapi_version.Version { + if m != nil { + return m.Version + } + return nil +} + +// GetHistoryRequest requests a release's history. +type GetHistoryRequest struct { + // The name of the release. + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // The maximum number of releases to include. + Max int32 `protobuf:"varint,2,opt,name=max" json:"max,omitempty"` +} + +func (m *GetHistoryRequest) Reset() { *m = GetHistoryRequest{} } +func (m *GetHistoryRequest) String() string { return proto.CompactTextString(m) } +func (*GetHistoryRequest) ProtoMessage() {} +func (*GetHistoryRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{17} } + +func (m *GetHistoryRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *GetHistoryRequest) GetMax() int32 { + if m != nil { + return m.Max + } + return 0 +} + +// GetHistoryResponse is received in response to a GetHistory rpc. +type GetHistoryResponse struct { + Releases []*hapi_release5.Release `protobuf:"bytes,1,rep,name=releases" json:"releases,omitempty"` +} + +func (m *GetHistoryResponse) Reset() { *m = GetHistoryResponse{} } +func (m *GetHistoryResponse) String() string { return proto.CompactTextString(m) } +func (*GetHistoryResponse) ProtoMessage() {} +func (*GetHistoryResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{18} } + +func (m *GetHistoryResponse) GetReleases() []*hapi_release5.Release { + if m != nil { + return m.Releases + } + return nil +} + +// TestReleaseRequest is a request to get the status of a release. +type TestReleaseRequest struct { + // Name is the name of the release + Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` + // timeout specifies the max amount of time any kubernetes client command can run. + Timeout int64 `protobuf:"varint,2,opt,name=timeout" json:"timeout,omitempty"` + // cleanup specifies whether or not to attempt pod deletion after test completes + Cleanup bool `protobuf:"varint,3,opt,name=cleanup" json:"cleanup,omitempty"` +} + +func (m *TestReleaseRequest) Reset() { *m = TestReleaseRequest{} } +func (m *TestReleaseRequest) String() string { return proto.CompactTextString(m) } +func (*TestReleaseRequest) ProtoMessage() {} +func (*TestReleaseRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{19} } + +func (m *TestReleaseRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *TestReleaseRequest) GetTimeout() int64 { + if m != nil { + return m.Timeout + } + return 0 +} + +func (m *TestReleaseRequest) GetCleanup() bool { + if m != nil { + return m.Cleanup + } + return false +} + +// TestReleaseResponse represents a message from executing a test +type TestReleaseResponse struct { + Msg string `protobuf:"bytes,1,opt,name=msg" json:"msg,omitempty"` + Status hapi_release1.TestRun_Status `protobuf:"varint,2,opt,name=status,enum=hapi.release.TestRun_Status" json:"status,omitempty"` +} + +func (m *TestReleaseResponse) Reset() { *m = TestReleaseResponse{} } +func (m *TestReleaseResponse) String() string { return proto.CompactTextString(m) } +func (*TestReleaseResponse) ProtoMessage() {} +func (*TestReleaseResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{20} } + +func (m *TestReleaseResponse) GetMsg() string { + if m != nil { + return m.Msg + } + return "" +} + +func (m *TestReleaseResponse) GetStatus() hapi_release1.TestRun_Status { + if m != nil { + return m.Status + } + return hapi_release1.TestRun_UNKNOWN +} + +func init() { + proto.RegisterType((*ListReleasesRequest)(nil), "hapi.services.tiller.ListReleasesRequest") + proto.RegisterType((*ListSort)(nil), "hapi.services.tiller.ListSort") + proto.RegisterType((*ListReleasesResponse)(nil), "hapi.services.tiller.ListReleasesResponse") + proto.RegisterType((*GetReleaseStatusRequest)(nil), "hapi.services.tiller.GetReleaseStatusRequest") + proto.RegisterType((*GetReleaseStatusResponse)(nil), "hapi.services.tiller.GetReleaseStatusResponse") + proto.RegisterType((*GetReleaseContentRequest)(nil), "hapi.services.tiller.GetReleaseContentRequest") + proto.RegisterType((*GetReleaseContentResponse)(nil), "hapi.services.tiller.GetReleaseContentResponse") + proto.RegisterType((*UpdateReleaseRequest)(nil), "hapi.services.tiller.UpdateReleaseRequest") + proto.RegisterType((*UpdateReleaseResponse)(nil), "hapi.services.tiller.UpdateReleaseResponse") + proto.RegisterType((*RollbackReleaseRequest)(nil), "hapi.services.tiller.RollbackReleaseRequest") + proto.RegisterType((*RollbackReleaseResponse)(nil), "hapi.services.tiller.RollbackReleaseResponse") + proto.RegisterType((*InstallReleaseRequest)(nil), "hapi.services.tiller.InstallReleaseRequest") + proto.RegisterType((*InstallReleaseResponse)(nil), "hapi.services.tiller.InstallReleaseResponse") + proto.RegisterType((*UninstallReleaseRequest)(nil), "hapi.services.tiller.UninstallReleaseRequest") + proto.RegisterType((*UninstallReleaseResponse)(nil), "hapi.services.tiller.UninstallReleaseResponse") + proto.RegisterType((*GetVersionRequest)(nil), "hapi.services.tiller.GetVersionRequest") + proto.RegisterType((*GetVersionResponse)(nil), "hapi.services.tiller.GetVersionResponse") + proto.RegisterType((*GetHistoryRequest)(nil), "hapi.services.tiller.GetHistoryRequest") + proto.RegisterType((*GetHistoryResponse)(nil), "hapi.services.tiller.GetHistoryResponse") + proto.RegisterType((*TestReleaseRequest)(nil), "hapi.services.tiller.TestReleaseRequest") + proto.RegisterType((*TestReleaseResponse)(nil), "hapi.services.tiller.TestReleaseResponse") + proto.RegisterEnum("hapi.services.tiller.ListSort_SortBy", ListSort_SortBy_name, ListSort_SortBy_value) + proto.RegisterEnum("hapi.services.tiller.ListSort_SortOrder", ListSort_SortOrder_name, ListSort_SortOrder_value) +} + +// Reference imports to suppress errors if they are not otherwise used. +var _ context.Context +var _ grpc.ClientConn + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the grpc package it is being compiled against. +const _ = grpc.SupportPackageIsVersion4 + +// Client API for ReleaseService service + +type ReleaseServiceClient interface { + // ListReleases retrieves release history. + // TODO: Allow filtering the set of releases by + // release status. By default, ListAllReleases returns the releases who + // current status is "Active". + ListReleases(ctx context.Context, in *ListReleasesRequest, opts ...grpc.CallOption) (ReleaseService_ListReleasesClient, error) + // GetReleasesStatus retrieves status information for the specified release. + GetReleaseStatus(ctx context.Context, in *GetReleaseStatusRequest, opts ...grpc.CallOption) (*GetReleaseStatusResponse, error) + // GetReleaseContent retrieves the release content (chart + value) for the specified release. + GetReleaseContent(ctx context.Context, in *GetReleaseContentRequest, opts ...grpc.CallOption) (*GetReleaseContentResponse, error) + // UpdateRelease updates release content. + UpdateRelease(ctx context.Context, in *UpdateReleaseRequest, opts ...grpc.CallOption) (*UpdateReleaseResponse, error) + // InstallRelease requests installation of a chart as a new release. + InstallRelease(ctx context.Context, in *InstallReleaseRequest, opts ...grpc.CallOption) (*InstallReleaseResponse, error) + // UninstallRelease requests deletion of a named release. + UninstallRelease(ctx context.Context, in *UninstallReleaseRequest, opts ...grpc.CallOption) (*UninstallReleaseResponse, error) + // GetVersion returns the current version of the server. + GetVersion(ctx context.Context, in *GetVersionRequest, opts ...grpc.CallOption) (*GetVersionResponse, error) + // RollbackRelease rolls back a release to a previous version. + RollbackRelease(ctx context.Context, in *RollbackReleaseRequest, opts ...grpc.CallOption) (*RollbackReleaseResponse, error) + // ReleaseHistory retrieves a releasse's history. + GetHistory(ctx context.Context, in *GetHistoryRequest, opts ...grpc.CallOption) (*GetHistoryResponse, error) + // RunReleaseTest executes the tests defined of a named release + RunReleaseTest(ctx context.Context, in *TestReleaseRequest, opts ...grpc.CallOption) (ReleaseService_RunReleaseTestClient, error) +} + +type releaseServiceClient struct { + cc *grpc.ClientConn +} + +func NewReleaseServiceClient(cc *grpc.ClientConn) ReleaseServiceClient { + return &releaseServiceClient{cc} +} + +func (c *releaseServiceClient) ListReleases(ctx context.Context, in *ListReleasesRequest, opts ...grpc.CallOption) (ReleaseService_ListReleasesClient, error) { + stream, err := grpc.NewClientStream(ctx, &_ReleaseService_serviceDesc.Streams[0], c.cc, "/hapi.services.tiller.ReleaseService/ListReleases", opts...) + if err != nil { + return nil, err + } + x := &releaseServiceListReleasesClient{stream} + if err := x.ClientStream.SendMsg(in); err != nil { + return nil, err + } + if err := x.ClientStream.CloseSend(); err != nil { + return nil, err + } + return x, nil +} + +type ReleaseService_ListReleasesClient interface { + Recv() (*ListReleasesResponse, error) + grpc.ClientStream +} + +type releaseServiceListReleasesClient struct { + grpc.ClientStream +} + +func (x *releaseServiceListReleasesClient) Recv() (*ListReleasesResponse, error) { + m := new(ListReleasesResponse) + if err := x.ClientStream.RecvMsg(m); err != nil { + return nil, err + } + return m, nil +} + +func (c *releaseServiceClient) GetReleaseStatus(ctx context.Context, in *GetReleaseStatusRequest, opts ...grpc.CallOption) (*GetReleaseStatusResponse, error) { + out := new(GetReleaseStatusResponse) + err := grpc.Invoke(ctx, "/hapi.services.tiller.ReleaseService/GetReleaseStatus", in, out, c.cc, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *releaseServiceClient) GetReleaseContent(ctx context.Context, in *GetReleaseContentRequest, opts ...grpc.CallOption) (*GetReleaseContentResponse, error) { + out := new(GetReleaseContentResponse) + err := grpc.Invoke(ctx, "/hapi.services.tiller.ReleaseService/GetReleaseContent", in, out, c.cc, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *releaseServiceClient) UpdateRelease(ctx context.Context, in *UpdateReleaseRequest, opts ...grpc.CallOption) (*UpdateReleaseResponse, error) { + out := new(UpdateReleaseResponse) + err := grpc.Invoke(ctx, "/hapi.services.tiller.ReleaseService/UpdateRelease", in, out, c.cc, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *releaseServiceClient) InstallRelease(ctx context.Context, in *InstallReleaseRequest, opts ...grpc.CallOption) (*InstallReleaseResponse, error) { + out := new(InstallReleaseResponse) + err := grpc.Invoke(ctx, "/hapi.services.tiller.ReleaseService/InstallRelease", in, out, c.cc, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *releaseServiceClient) UninstallRelease(ctx context.Context, in *UninstallReleaseRequest, opts ...grpc.CallOption) (*UninstallReleaseResponse, error) { + out := new(UninstallReleaseResponse) + err := grpc.Invoke(ctx, "/hapi.services.tiller.ReleaseService/UninstallRelease", in, out, c.cc, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *releaseServiceClient) GetVersion(ctx context.Context, in *GetVersionRequest, opts ...grpc.CallOption) (*GetVersionResponse, error) { + out := new(GetVersionResponse) + err := grpc.Invoke(ctx, "/hapi.services.tiller.ReleaseService/GetVersion", in, out, c.cc, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *releaseServiceClient) RollbackRelease(ctx context.Context, in *RollbackReleaseRequest, opts ...grpc.CallOption) (*RollbackReleaseResponse, error) { + out := new(RollbackReleaseResponse) + err := grpc.Invoke(ctx, "/hapi.services.tiller.ReleaseService/RollbackRelease", in, out, c.cc, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *releaseServiceClient) GetHistory(ctx context.Context, in *GetHistoryRequest, opts ...grpc.CallOption) (*GetHistoryResponse, error) { + out := new(GetHistoryResponse) + err := grpc.Invoke(ctx, "/hapi.services.tiller.ReleaseService/GetHistory", in, out, c.cc, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *releaseServiceClient) RunReleaseTest(ctx context.Context, in *TestReleaseRequest, opts ...grpc.CallOption) (ReleaseService_RunReleaseTestClient, error) { + stream, err := grpc.NewClientStream(ctx, &_ReleaseService_serviceDesc.Streams[1], c.cc, "/hapi.services.tiller.ReleaseService/RunReleaseTest", opts...) + if err != nil { + return nil, err + } + x := &releaseServiceRunReleaseTestClient{stream} + if err := x.ClientStream.SendMsg(in); err != nil { + return nil, err + } + if err := x.ClientStream.CloseSend(); err != nil { + return nil, err + } + return x, nil +} + +type ReleaseService_RunReleaseTestClient interface { + Recv() (*TestReleaseResponse, error) + grpc.ClientStream +} + +type releaseServiceRunReleaseTestClient struct { + grpc.ClientStream +} + +func (x *releaseServiceRunReleaseTestClient) Recv() (*TestReleaseResponse, error) { + m := new(TestReleaseResponse) + if err := x.ClientStream.RecvMsg(m); err != nil { + return nil, err + } + return m, nil +} + +// Server API for ReleaseService service + +type ReleaseServiceServer interface { + // ListReleases retrieves release history. + // TODO: Allow filtering the set of releases by + // release status. By default, ListAllReleases returns the releases who + // current status is "Active". + ListReleases(*ListReleasesRequest, ReleaseService_ListReleasesServer) error + // GetReleasesStatus retrieves status information for the specified release. + GetReleaseStatus(context.Context, *GetReleaseStatusRequest) (*GetReleaseStatusResponse, error) + // GetReleaseContent retrieves the release content (chart + value) for the specified release. + GetReleaseContent(context.Context, *GetReleaseContentRequest) (*GetReleaseContentResponse, error) + // UpdateRelease updates release content. + UpdateRelease(context.Context, *UpdateReleaseRequest) (*UpdateReleaseResponse, error) + // InstallRelease requests installation of a chart as a new release. + InstallRelease(context.Context, *InstallReleaseRequest) (*InstallReleaseResponse, error) + // UninstallRelease requests deletion of a named release. + UninstallRelease(context.Context, *UninstallReleaseRequest) (*UninstallReleaseResponse, error) + // GetVersion returns the current version of the server. + GetVersion(context.Context, *GetVersionRequest) (*GetVersionResponse, error) + // RollbackRelease rolls back a release to a previous version. + RollbackRelease(context.Context, *RollbackReleaseRequest) (*RollbackReleaseResponse, error) + // ReleaseHistory retrieves a releasse's history. + GetHistory(context.Context, *GetHistoryRequest) (*GetHistoryResponse, error) + // RunReleaseTest executes the tests defined of a named release + RunReleaseTest(*TestReleaseRequest, ReleaseService_RunReleaseTestServer) error +} + +func RegisterReleaseServiceServer(s *grpc.Server, srv ReleaseServiceServer) { + s.RegisterService(&_ReleaseService_serviceDesc, srv) +} + +func _ReleaseService_ListReleases_Handler(srv interface{}, stream grpc.ServerStream) error { + m := new(ListReleasesRequest) + if err := stream.RecvMsg(m); err != nil { + return err + } + return srv.(ReleaseServiceServer).ListReleases(m, &releaseServiceListReleasesServer{stream}) +} + +type ReleaseService_ListReleasesServer interface { + Send(*ListReleasesResponse) error + grpc.ServerStream +} + +type releaseServiceListReleasesServer struct { + grpc.ServerStream +} + +func (x *releaseServiceListReleasesServer) Send(m *ListReleasesResponse) error { + return x.ServerStream.SendMsg(m) +} + +func _ReleaseService_GetReleaseStatus_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(GetReleaseStatusRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ReleaseServiceServer).GetReleaseStatus(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/hapi.services.tiller.ReleaseService/GetReleaseStatus", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ReleaseServiceServer).GetReleaseStatus(ctx, req.(*GetReleaseStatusRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _ReleaseService_GetReleaseContent_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(GetReleaseContentRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ReleaseServiceServer).GetReleaseContent(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/hapi.services.tiller.ReleaseService/GetReleaseContent", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ReleaseServiceServer).GetReleaseContent(ctx, req.(*GetReleaseContentRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _ReleaseService_UpdateRelease_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(UpdateReleaseRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ReleaseServiceServer).UpdateRelease(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/hapi.services.tiller.ReleaseService/UpdateRelease", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ReleaseServiceServer).UpdateRelease(ctx, req.(*UpdateReleaseRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _ReleaseService_InstallRelease_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(InstallReleaseRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ReleaseServiceServer).InstallRelease(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/hapi.services.tiller.ReleaseService/InstallRelease", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ReleaseServiceServer).InstallRelease(ctx, req.(*InstallReleaseRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _ReleaseService_UninstallRelease_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(UninstallReleaseRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ReleaseServiceServer).UninstallRelease(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/hapi.services.tiller.ReleaseService/UninstallRelease", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ReleaseServiceServer).UninstallRelease(ctx, req.(*UninstallReleaseRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _ReleaseService_GetVersion_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(GetVersionRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ReleaseServiceServer).GetVersion(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/hapi.services.tiller.ReleaseService/GetVersion", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ReleaseServiceServer).GetVersion(ctx, req.(*GetVersionRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _ReleaseService_RollbackRelease_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(RollbackReleaseRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ReleaseServiceServer).RollbackRelease(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/hapi.services.tiller.ReleaseService/RollbackRelease", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ReleaseServiceServer).RollbackRelease(ctx, req.(*RollbackReleaseRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _ReleaseService_GetHistory_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(GetHistoryRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(ReleaseServiceServer).GetHistory(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/hapi.services.tiller.ReleaseService/GetHistory", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(ReleaseServiceServer).GetHistory(ctx, req.(*GetHistoryRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _ReleaseService_RunReleaseTest_Handler(srv interface{}, stream grpc.ServerStream) error { + m := new(TestReleaseRequest) + if err := stream.RecvMsg(m); err != nil { + return err + } + return srv.(ReleaseServiceServer).RunReleaseTest(m, &releaseServiceRunReleaseTestServer{stream}) +} + +type ReleaseService_RunReleaseTestServer interface { + Send(*TestReleaseResponse) error + grpc.ServerStream +} + +type releaseServiceRunReleaseTestServer struct { + grpc.ServerStream +} + +func (x *releaseServiceRunReleaseTestServer) Send(m *TestReleaseResponse) error { + return x.ServerStream.SendMsg(m) +} + +var _ReleaseService_serviceDesc = grpc.ServiceDesc{ + ServiceName: "hapi.services.tiller.ReleaseService", + HandlerType: (*ReleaseServiceServer)(nil), + Methods: []grpc.MethodDesc{ + { + MethodName: "GetReleaseStatus", + Handler: _ReleaseService_GetReleaseStatus_Handler, + }, + { + MethodName: "GetReleaseContent", + Handler: _ReleaseService_GetReleaseContent_Handler, + }, + { + MethodName: "UpdateRelease", + Handler: _ReleaseService_UpdateRelease_Handler, + }, + { + MethodName: "InstallRelease", + Handler: _ReleaseService_InstallRelease_Handler, + }, + { + MethodName: "UninstallRelease", + Handler: _ReleaseService_UninstallRelease_Handler, + }, + { + MethodName: "GetVersion", + Handler: _ReleaseService_GetVersion_Handler, + }, + { + MethodName: "RollbackRelease", + Handler: _ReleaseService_RollbackRelease_Handler, + }, + { + MethodName: "GetHistory", + Handler: _ReleaseService_GetHistory_Handler, + }, + }, + Streams: []grpc.StreamDesc{ + { + StreamName: "ListReleases", + Handler: _ReleaseService_ListReleases_Handler, + ServerStreams: true, + }, + { + StreamName: "RunReleaseTest", + Handler: _ReleaseService_RunReleaseTest_Handler, + ServerStreams: true, + }, + }, + Metadata: "hapi/services/tiller.proto", +} + +func init() { proto.RegisterFile("hapi/services/tiller.proto", fileDescriptor0) } + +var fileDescriptor0 = []byte{ + // 1217 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x57, 0xdd, 0x6e, 0xe3, 0xc4, + 0x17, 0xaf, 0xf3, 0x9d, 0x93, 0x36, 0xff, 0x74, 0x9a, 0xb6, 0xae, 0xff, 0x0b, 0x2a, 0x46, 0xb0, + 0xd9, 0x85, 0x4d, 0x21, 0x70, 0x83, 0x84, 0x90, 0xba, 0xdd, 0xa8, 0x2d, 0x94, 0xae, 0xe4, 0x6c, + 0x17, 0x09, 0x01, 0x91, 0x9b, 0x4c, 0x5a, 0xb3, 0x8e, 0x27, 0x78, 0xc6, 0x65, 0x7b, 0xcb, 0x1d, + 0x8f, 0xc2, 0x5b, 0xf0, 0x1e, 0x5c, 0xc2, 0x83, 0x20, 0xcf, 0x87, 0xeb, 0x49, 0xed, 0xd6, 0xf4, + 0x26, 0x9e, 0x99, 0xf3, 0xfd, 0x3b, 0x67, 0xce, 0x9c, 0x80, 0x75, 0xe9, 0x2e, 0xbc, 0x3d, 0x8a, + 0xc3, 0x2b, 0x6f, 0x82, 0xe9, 0x1e, 0xf3, 0x7c, 0x1f, 0x87, 0xfd, 0x45, 0x48, 0x18, 0x41, 0xdd, + 0x98, 0xd6, 0x57, 0xb4, 0xbe, 0xa0, 0x59, 0x5b, 0x5c, 0x62, 0x72, 0xe9, 0x86, 0x4c, 0xfc, 0x0a, + 0x6e, 0x6b, 0x3b, 0x7d, 0x4e, 0x82, 0x99, 0x77, 0x21, 0x09, 0xc2, 0x44, 0x88, 0x7d, 0xec, 0x52, + 0xac, 0xbe, 0x9a, 0x90, 0xa2, 0x79, 0xc1, 0x8c, 0x48, 0xc2, 0xff, 0x35, 0x02, 0xc3, 0x94, 0x8d, + 0xc3, 0x28, 0x90, 0xc4, 0x1d, 0x8d, 0x48, 0x99, 0xcb, 0x22, 0xaa, 0x19, 0xbb, 0xc2, 0x21, 0xf5, + 0x48, 0xa0, 0xbe, 0x82, 0x66, 0xff, 0x59, 0x82, 0x8d, 0x13, 0x8f, 0x32, 0x47, 0x08, 0x52, 0x07, + 0xff, 0x12, 0x61, 0xca, 0x50, 0x17, 0xaa, 0xbe, 0x37, 0xf7, 0x98, 0x69, 0xec, 0x1a, 0xbd, 0xb2, + 0x23, 0x36, 0x68, 0x0b, 0x6a, 0x64, 0x36, 0xa3, 0x98, 0x99, 0xa5, 0x5d, 0xa3, 0xd7, 0x74, 0xe4, + 0x0e, 0x7d, 0x05, 0x75, 0x4a, 0x42, 0x36, 0x3e, 0xbf, 0x36, 0xcb, 0xbb, 0x46, 0xaf, 0x3d, 0xf8, + 0xa0, 0x9f, 0x85, 0x53, 0x3f, 0xb6, 0x34, 0x22, 0x21, 0xeb, 0xc7, 0x3f, 0xcf, 0xaf, 0x9d, 0x1a, + 0xe5, 0xdf, 0x58, 0xef, 0xcc, 0xf3, 0x19, 0x0e, 0xcd, 0x8a, 0xd0, 0x2b, 0x76, 0xe8, 0x10, 0x80, + 0xeb, 0x25, 0xe1, 0x14, 0x87, 0x66, 0x95, 0xab, 0xee, 0x15, 0x50, 0xfd, 0x32, 0xe6, 0x77, 0x9a, + 0x54, 0x2d, 0xd1, 0x97, 0xb0, 0x2a, 0x20, 0x19, 0x4f, 0xc8, 0x14, 0x53, 0xb3, 0xb6, 0x5b, 0xee, + 0xb5, 0x07, 0x3b, 0x42, 0x95, 0x82, 0x7f, 0x24, 0x40, 0x3b, 0x20, 0x53, 0xec, 0xb4, 0x04, 0x7b, + 0xbc, 0xa6, 0xe8, 0x11, 0x34, 0x03, 0x77, 0x8e, 0xe9, 0xc2, 0x9d, 0x60, 0xb3, 0xce, 0x3d, 0xbc, + 0x39, 0xb0, 0x7f, 0x82, 0x86, 0x32, 0x6e, 0x0f, 0xa0, 0x26, 0x42, 0x43, 0x2d, 0xa8, 0x9f, 0x9d, + 0x7e, 0x73, 0xfa, 0xf2, 0xbb, 0xd3, 0xce, 0x0a, 0x6a, 0x40, 0xe5, 0x74, 0xff, 0xdb, 0x61, 0xc7, + 0x40, 0xeb, 0xb0, 0x76, 0xb2, 0x3f, 0x7a, 0x35, 0x76, 0x86, 0x27, 0xc3, 0xfd, 0xd1, 0xf0, 0x45, + 0xa7, 0x64, 0xbf, 0x0b, 0xcd, 0xc4, 0x67, 0x54, 0x87, 0xf2, 0xfe, 0xe8, 0x40, 0x88, 0xbc, 0x18, + 0x8e, 0x0e, 0x3a, 0x86, 0xfd, 0xbb, 0x01, 0x5d, 0x3d, 0x45, 0x74, 0x41, 0x02, 0x8a, 0xe3, 0x1c, + 0x4d, 0x48, 0x14, 0x24, 0x39, 0xe2, 0x1b, 0x84, 0xa0, 0x12, 0xe0, 0xb7, 0x2a, 0x43, 0x7c, 0x1d, + 0x73, 0x32, 0xc2, 0x5c, 0x9f, 0x67, 0xa7, 0xec, 0x88, 0x0d, 0xfa, 0x14, 0x1a, 0x32, 0x74, 0x6a, + 0x56, 0x76, 0xcb, 0xbd, 0xd6, 0x60, 0x53, 0x07, 0x44, 0x5a, 0x74, 0x12, 0x36, 0xfb, 0x10, 0xb6, + 0x0f, 0xb1, 0xf2, 0x44, 0xe0, 0xa5, 0x2a, 0x26, 0xb6, 0xeb, 0xce, 0x31, 0x77, 0x26, 0xb6, 0xeb, + 0xce, 0x31, 0x32, 0xa1, 0x2e, 0xcb, 0x8d, 0xbb, 0x53, 0x75, 0xd4, 0xd6, 0x66, 0x60, 0xde, 0x56, + 0x24, 0xe3, 0xca, 0xd2, 0xf4, 0x21, 0x54, 0xe2, 0x9b, 0xc0, 0xd5, 0xb4, 0x06, 0x48, 0xf7, 0xf3, + 0x38, 0x98, 0x11, 0x87, 0xd3, 0xf5, 0x54, 0x95, 0x97, 0x53, 0x75, 0x94, 0xb6, 0x7a, 0x40, 0x02, + 0x86, 0x03, 0xf6, 0x30, 0xff, 0x4f, 0x60, 0x27, 0x43, 0x93, 0x0c, 0x60, 0x0f, 0xea, 0xd2, 0x35, + 0xae, 0x2d, 0x17, 0x57, 0xc5, 0x65, 0xff, 0x5d, 0x82, 0xee, 0xd9, 0x62, 0xea, 0x32, 0xac, 0x48, + 0x77, 0x38, 0xf5, 0x18, 0xaa, 0xbc, 0xa3, 0x48, 0x2c, 0xd6, 0x85, 0x6e, 0xd1, 0x76, 0x0e, 0xe2, + 0x5f, 0x47, 0xd0, 0xd1, 0x53, 0xa8, 0x5d, 0xb9, 0x7e, 0x84, 0x29, 0x07, 0x22, 0x41, 0x4d, 0x72, + 0xf2, 0x76, 0xe4, 0x48, 0x0e, 0xb4, 0x0d, 0xf5, 0x69, 0x78, 0x1d, 0xf7, 0x13, 0x7e, 0x05, 0x1b, + 0x4e, 0x6d, 0x1a, 0x5e, 0x3b, 0x51, 0x80, 0xde, 0x87, 0xb5, 0xa9, 0x47, 0xdd, 0x73, 0x1f, 0x8f, + 0x2f, 0x09, 0x79, 0x43, 0xf9, 0x2d, 0x6c, 0x38, 0xab, 0xf2, 0xf0, 0x28, 0x3e, 0x43, 0x56, 0x5c, + 0x49, 0x93, 0x10, 0xbb, 0x0c, 0x9b, 0x35, 0x4e, 0x4f, 0xf6, 0x31, 0x86, 0xcc, 0x9b, 0x63, 0x12, + 0x31, 0x7e, 0x75, 0xca, 0x8e, 0xda, 0xa2, 0xf7, 0x60, 0x35, 0xc4, 0x14, 0xb3, 0xb1, 0xf4, 0xb2, + 0xc1, 0x25, 0x5b, 0xfc, 0xec, 0xb5, 0x70, 0x0b, 0x41, 0xe5, 0x57, 0xd7, 0x63, 0x66, 0x93, 0x93, + 0xf8, 0x5a, 0x88, 0x45, 0x14, 0x2b, 0x31, 0x50, 0x62, 0x11, 0xc5, 0x52, 0xac, 0x0b, 0xd5, 0x19, + 0x09, 0x27, 0xd8, 0x6c, 0x71, 0x9a, 0xd8, 0xd8, 0x47, 0xb0, 0xb9, 0x04, 0xf2, 0x43, 0xf3, 0xf5, + 0x8f, 0x01, 0x5b, 0x0e, 0xf1, 0xfd, 0x73, 0x77, 0xf2, 0xa6, 0x40, 0xc6, 0x52, 0xe0, 0x96, 0xee, + 0x06, 0xb7, 0x9c, 0x01, 0x6e, 0xaa, 0x08, 0x2b, 0x5a, 0x11, 0x6a, 0xb0, 0x57, 0xf3, 0x61, 0xaf, + 0xe9, 0xb0, 0x2b, 0x4c, 0xeb, 0x29, 0x4c, 0x13, 0xc0, 0x1a, 0x69, 0xc0, 0xbe, 0x86, 0xed, 0x5b, + 0x51, 0x3e, 0x14, 0xb2, 0x3f, 0x4a, 0xb0, 0x79, 0x1c, 0x50, 0xe6, 0xfa, 0xfe, 0x12, 0x62, 0x49, + 0x3d, 0x1b, 0x85, 0xeb, 0xb9, 0xf4, 0x5f, 0xea, 0xb9, 0xac, 0x41, 0xae, 0xf2, 0x53, 0x49, 0xe5, + 0xa7, 0x50, 0x8d, 0x6b, 0x9d, 0xa5, 0xb6, 0xd4, 0x59, 0xd0, 0x3b, 0x00, 0xa2, 0x28, 0xb9, 0x72, + 0x01, 0x6d, 0x93, 0x9f, 0x9c, 0xca, 0x46, 0xa2, 0xb2, 0xd1, 0xc8, 0xce, 0x46, 0xaa, 0xc2, 0xed, + 0x63, 0xd8, 0x5a, 0x86, 0xea, 0xa1, 0xb0, 0xff, 0x66, 0xc0, 0xf6, 0x59, 0xe0, 0x65, 0x02, 0x9f, + 0x55, 0xaa, 0xb7, 0xa0, 0x28, 0x65, 0x40, 0xd1, 0x85, 0xea, 0x22, 0x0a, 0x2f, 0xb0, 0x84, 0x56, + 0x6c, 0xd2, 0x31, 0x56, 0xb4, 0x18, 0xed, 0x31, 0x98, 0xb7, 0x7d, 0x78, 0x60, 0x44, 0xb1, 0xd7, + 0xc9, 0x4b, 0xd0, 0x14, 0x5d, 0xdf, 0xde, 0x80, 0xf5, 0x43, 0xcc, 0x5e, 0x8b, 0x6b, 0x21, 0xc3, + 0xb3, 0x87, 0x80, 0xd2, 0x87, 0x37, 0xf6, 0xe4, 0x91, 0x6e, 0x4f, 0x8d, 0x45, 0x8a, 0x5f, 0x71, + 0xd9, 0x5f, 0x70, 0xdd, 0x47, 0x1e, 0x65, 0x24, 0xbc, 0xbe, 0x0b, 0xba, 0x0e, 0x94, 0xe7, 0xee, + 0x5b, 0xf9, 0x50, 0xc4, 0x4b, 0xfb, 0x90, 0x7b, 0x90, 0x88, 0x4a, 0x0f, 0xd2, 0xcf, 0xae, 0x51, + 0xec, 0xd9, 0xfd, 0x01, 0xd0, 0x2b, 0x9c, 0x4c, 0x00, 0xf7, 0xbc, 0x58, 0x2a, 0x09, 0x25, 0xbd, + 0xd0, 0x4c, 0xa8, 0x4f, 0x7c, 0xec, 0x06, 0xd1, 0x42, 0xa6, 0x4d, 0x6d, 0xed, 0x1f, 0x61, 0x43, + 0xd3, 0x2e, 0xfd, 0x8c, 0xe3, 0xa1, 0x17, 0x52, 0x7b, 0xbc, 0x44, 0x9f, 0x43, 0x4d, 0x8c, 0x45, + 0x5c, 0x77, 0x7b, 0xf0, 0x48, 0xf7, 0x9b, 0x2b, 0x89, 0x02, 0x39, 0x47, 0x39, 0x92, 0x77, 0xf0, + 0x57, 0x03, 0xda, 0xea, 0xa1, 0x17, 0x43, 0x1b, 0xf2, 0x60, 0x35, 0x3d, 0xd1, 0xa0, 0x27, 0xf9, + 0x33, 0xdd, 0xd2, 0x60, 0x6a, 0x3d, 0x2d, 0xc2, 0x2a, 0x22, 0xb0, 0x57, 0x3e, 0x31, 0x10, 0x85, + 0xce, 0xf2, 0xa0, 0x81, 0x9e, 0x65, 0xeb, 0xc8, 0x99, 0x6c, 0xac, 0x7e, 0x51, 0x76, 0x65, 0x16, + 0x5d, 0xf1, 0x9a, 0xd1, 0xa7, 0x03, 0x74, 0xaf, 0x1a, 0x7d, 0x20, 0xb1, 0xf6, 0x0a, 0xf3, 0x27, + 0x76, 0x7f, 0x86, 0x35, 0xed, 0x85, 0x43, 0x39, 0x68, 0x65, 0xcd, 0x1a, 0xd6, 0x47, 0x85, 0x78, + 0x13, 0x5b, 0x73, 0x68, 0xeb, 0x4d, 0x0a, 0xe5, 0x28, 0xc8, 0xec, 0xfa, 0xd6, 0xc7, 0xc5, 0x98, + 0x13, 0x73, 0x14, 0x3a, 0xcb, 0x3d, 0x24, 0x2f, 0x8f, 0x39, 0xfd, 0x2e, 0x2f, 0x8f, 0x79, 0xad, + 0xc9, 0x5e, 0x41, 0x2e, 0xc0, 0x4d, 0x0b, 0x41, 0x8f, 0x73, 0x13, 0xa2, 0x77, 0x1e, 0xab, 0x77, + 0x3f, 0x63, 0x62, 0x62, 0x01, 0xff, 0x5b, 0x7a, 0x63, 0x51, 0x0e, 0x34, 0xd9, 0x03, 0x87, 0xf5, + 0xac, 0x20, 0xf7, 0x52, 0x50, 0xb2, 0x2b, 0xdd, 0x11, 0x94, 0xde, 0xf2, 0xee, 0x08, 0x6a, 0xa9, + 0xc1, 0xd9, 0x2b, 0xc8, 0x83, 0xb6, 0x13, 0x05, 0xd2, 0x74, 0xdc, 0x16, 0x50, 0x8e, 0xf4, 0xed, + 0xae, 0x66, 0x3d, 0x29, 0xc0, 0x79, 0x73, 0xbf, 0x9f, 0xc3, 0xf7, 0x0d, 0xc5, 0x7a, 0x5e, 0xe3, + 0xff, 0x69, 0x3f, 0xfb, 0x37, 0x00, 0x00, 0xff, 0xff, 0xf3, 0x7c, 0x9c, 0x49, 0xc1, 0x0f, 0x00, + 0x00, +} diff --git a/vendor/k8s.io/helm/pkg/repo/chartrepo.go b/vendor/k8s.io/helm/pkg/repo/chartrepo.go index b95a7ae07e6..438f66d7cd7 100644 --- a/vendor/k8s.io/helm/pkg/repo/chartrepo.go +++ b/vendor/k8s.io/helm/pkg/repo/chartrepo.go @@ -36,6 +36,8 @@ type Entry struct { Name string `json:"name"` Cache string `json:"cache"` URL string `json:"url"` + Username string `json:"username"` + Password string `json:"password"` CertFile string `json:"certFile"` KeyFile string `json:"keyFile"` CAFile string `json:"caFile"` @@ -117,6 +119,8 @@ func (r *ChartRepository) DownloadIndexFile(cachePath string) error { parsedURL.Path = strings.TrimSuffix(parsedURL.Path, "/") + "/index.yaml" indexURL = parsedURL.String() + + r.setCredentials() resp, err := r.Client.Get(indexURL) if err != nil { return err @@ -145,6 +149,13 @@ func (r *ChartRepository) DownloadIndexFile(cachePath string) error { return ioutil.WriteFile(cp, index, 0644) } +// If HttpGetter is used, this method sets the configured repository credentials on the HttpGetter. +func (r *ChartRepository) setCredentials() { + if t, ok := r.Client.(*getter.HttpGetter); ok { + t.SetCredentials(r.Config.Username, r.Config.Password) + } +} + // Index generates an index for the chart repository and writes an index.yaml file. func (r *ChartRepository) Index() error { err := r.generateIndex() @@ -186,6 +197,13 @@ func (r *ChartRepository) generateIndex() error { // FindChartInRepoURL finds chart in chart repository pointed by repoURL // without adding repo to repositories func FindChartInRepoURL(repoURL, chartName, chartVersion, certFile, keyFile, caFile string, getters getter.Providers) (string, error) { + return FindChartInAuthRepoURL(repoURL, "", "", chartName, chartVersion, certFile, keyFile, caFile, getters) +} + +// FindChartInAuthRepoURL finds chart in chart repository pointed by repoURL +// without adding repo to repositories, like FindChartInRepoURL, +// but it also receives credentials for the chart repository. +func FindChartInAuthRepoURL(repoURL, username, password, chartName, chartVersion, certFile, keyFile, caFile string, getters getter.Providers) (string, error) { // Download and write the index file to a temporary location tempIndexFile, err := ioutil.TempFile("", "tmp-repo-file") @@ -196,6 +214,8 @@ func FindChartInRepoURL(repoURL, chartName, chartVersion, certFile, keyFile, caF c := Entry{ URL: repoURL, + Username: username, + Password: password, CertFile: certFile, KeyFile: keyFile, CAFile: caFile, diff --git a/vendor/k8s.io/helm/pkg/repo/repo.go b/vendor/k8s.io/helm/pkg/repo/repo.go index 194eace79e2..b5bba164e07 100644 --- a/vendor/k8s.io/helm/pkg/repo/repo.go +++ b/vendor/k8s.io/helm/pkg/repo/repo.go @@ -31,7 +31,8 @@ import ( var ErrRepoOutOfDate = errors.New("repository file is out of date") // RepoFile represents the repositories.yaml file in $HELM_HOME -type RepoFile struct { +// TODO: change type name to File in Helm 3 to resolve linter warning +type RepoFile struct { // nolint APIVersion string `json:"apiVersion"` Generated time.Time `json:"generated"` Repositories []*Entry `json:"repositories"` diff --git a/vendor/k8s.io/helm/pkg/version/version.go b/vendor/k8s.io/helm/pkg/version/version.go index 6f5a1a45274..43f1ad40ad9 100644 --- a/vendor/k8s.io/helm/pkg/version/version.go +++ b/vendor/k8s.io/helm/pkg/version/version.go @@ -26,7 +26,7 @@ var ( // Increment major number for new feature additions and behavioral changes. // Increment minor number for bug fixes and performance enhancements. // Increment patch number for critical fixes to existing releases. - Version = "v2.8" + Version = "v2.9" // BuildMetadata is extra build time data BuildMetadata = "unreleased" diff --git a/vendor/k8s.io/kube-openapi/pkg/common/common.go b/vendor/k8s.io/kube-openapi/pkg/common/common.go index fbe01cabb3b..0d235876deb 100644 --- a/vendor/k8s.io/kube-openapi/pkg/common/common.go +++ b/vendor/k8s.io/kube-openapi/pkg/common/common.go @@ -32,7 +32,7 @@ type OpenAPIDefinition struct { type ReferenceCallback func(path string) spec.Ref -// OpenAPIDefinitions is collection of all definitions. +// GetOpenAPIDefinitions is collection of all definitions. type GetOpenAPIDefinitions func(ReferenceCallback) map[string]OpenAPIDefinition // OpenAPIDefinitionGetter gets openAPI definitions for a given type. If a type implements this interface, From b225b5fc79a856cf8bd8615aea2ac02fe7a8f85e Mon Sep 17 00:00:00 2001 From: Andres Date: Tue, 12 Jun 2018 12:31:07 +0200 Subject: [PATCH 02/13] Docs, make tasks and dockerfiles --- Makefile | 6 ++++++ cmd/tiller-proxy/.gitignore | 1 + cmd/tiller-proxy/Dockerfile | 9 ++++++++ cmd/tiller-proxy/Dockerfile.dev | 4 ++++ cmd/tiller-proxy/README.md | 37 +++++++++++++++++++++++++++++++++ 5 files changed, 57 insertions(+) create mode 100644 cmd/tiller-proxy/.gitignore create mode 100644 cmd/tiller-proxy/Dockerfile create mode 100644 cmd/tiller-proxy/Dockerfile.dev create mode 100644 cmd/tiller-proxy/README.md diff --git a/Makefile b/Makefile index 75481d614a1..8663a087818 100644 --- a/Makefile +++ b/Makefile @@ -38,6 +38,12 @@ kubeapps/%: kubeapps/dashboard: docker build -t kubeapps/dashboard:$(VERSION) -f dashboard/Dockerfile dashboard/ +tiller-proxy-dev: + CGO_ENABLED=0 GOOS=linux go build -installsuffix cgo -o ./cmd/tiller-proxy/proxy-static ./cmd/tiller-proxy + docker build -t kubeapps/tiller-proxy -f ./cmd/tiller-proxy/Dockerfile.dev . +tiller-proxy: + docker build -t kubeapps/tiller-proxy -f ./cmd/tiller-proxy/Dockerfile . + fmt: $(GOFMT) -s -w $(GO_FILES) diff --git a/cmd/tiller-proxy/.gitignore b/cmd/tiller-proxy/.gitignore new file mode 100644 index 00000000000..6ef760cbd1d --- /dev/null +++ b/cmd/tiller-proxy/.gitignore @@ -0,0 +1 @@ +proxy-static diff --git a/cmd/tiller-proxy/Dockerfile b/cmd/tiller-proxy/Dockerfile new file mode 100644 index 00000000000..7d976c4753c --- /dev/null +++ b/cmd/tiller-proxy/Dockerfile @@ -0,0 +1,9 @@ +FROM quay.io/deis/go-dev:v1.8.2 as builder +COPY . /go/src/github.com/kubeapps/kubeapps +WORKDIR /go/src/github.com/kubeapps/kubeapps +RUN CGO_ENABLED=0 go build -a -installsuffix cgo ./cmd/tiller-proxy + +FROM scratch +COPY --from=builder /go/src/github.com/kubeapps/kubeapps/cmd/tiller-proxy/tiller-proxy /proxy +EXPOSE 8080 +CMD ["/proxy"] diff --git a/cmd/tiller-proxy/Dockerfile.dev b/cmd/tiller-proxy/Dockerfile.dev new file mode 100644 index 00000000000..cb264c181a3 --- /dev/null +++ b/cmd/tiller-proxy/Dockerfile.dev @@ -0,0 +1,4 @@ +FROM alpine:3.6 +RUN apk --no-cache add ca-certificates +COPY ./cmd/tiller-proxy/proxy-static /proxy +CMD ["/proxy"] \ No newline at end of file diff --git a/cmd/tiller-proxy/README.md b/cmd/tiller-proxy/README.md new file mode 100644 index 00000000000..7ce3b979176 --- /dev/null +++ b/cmd/tiller-proxy/README.md @@ -0,0 +1,37 @@ +# Tiller Proxy + +This proxy is a service for Kubeapps that connects the Dashboard with Tiller. The goal of this Proxy is to provide a secure proxy for authenticated users to deploy, upgrade and delete charts in different namespaces. + +Part of the logic of this tool has been extracted from [helm-CRD](https://github.com/bitnami-labs/helm-crd). That tool has been deprecated in Kubeapps to avoid having to synchronize the state of a release in two different places (Tiller and the CRD object). + +The client should provide the header `Authorization: Bearer TOKEN` being TOKEN the Kubernetes API Token in order to perform any action. + +The client should have permissions to: + + - "List" access to all the resources and all the groups for listing releases in a namespace. + - "Read" access to all the release resources in a release when doing a HTTP GET over a specific release. + - "Create" and "update" permissions to all the release resources when doing an HTTP POST or PUT to install or update a release. + +# Configuration + +It is possible to configure this proxy with the following flags: + +``` + --debug enable verbose output + --home string location of your Helm config. Overrides $HELM_HOME (default "/Users/andresmartinez/.helm") + --host string address of Tiller. Overrides $HELM_HOST + --kube-context string name of the kubeconfig context to use + --tiller-connection-timeout int the duration (in seconds) Helm will wait to establish a connection to tiller (default 300) + --tiller-namespace string namespace of Tiller (default "kube-system") +``` + +# Routes + +This proxy provides 6 different routes: + + - `GET` `/v1/releases`: List all the releases of the Tiller + - `GET` `/namespaces/{namespace}/releases`: List all the releases within a namespace + - `POST` `/namespaces/{namespace}/releases`: Create a new release + - `GET` `/namespaces/{namespace}/releases/{release}`: Get release info + - `PUT` `/namespaces/{namespace}/releases/{release}`: Update release info + - `DELETE` `/namespaces/{namespace}/releases/{release}`: Delete a release From 3f0d6e7b4316101d5b4873fa97d3fbd9705bd924 Mon Sep 17 00:00:00 2001 From: Andres Date: Tue, 12 Jun 2018 12:31:45 +0200 Subject: [PATCH 03/13] Copy chart logic from helm-crd --- cmd/tiller-proxy/chart/chart.go | 147 +++++++++++++++++++++++++++ cmd/tiller-proxy/chart/chart_test.go | 91 +++++++++++++++++ 2 files changed, 238 insertions(+) create mode 100644 cmd/tiller-proxy/chart/chart.go create mode 100644 cmd/tiller-proxy/chart/chart_test.go diff --git a/cmd/tiller-proxy/chart/chart.go b/cmd/tiller-proxy/chart/chart.go new file mode 100644 index 00000000000..a65e75318a4 --- /dev/null +++ b/cmd/tiller-proxy/chart/chart.go @@ -0,0 +1,147 @@ +/* +Copyright (c) 2018 Bitnami + +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 chart + +import ( + "bytes" + "fmt" + "io" + "io/ioutil" + "net/http" + "net/url" + "strings" + + "github.com/ghodss/yaml" + "k8s.io/helm/pkg/proto/hapi/chart" + "k8s.io/helm/pkg/repo" +) + +// HTTPClient Interface to perform HTTP requests +type HTTPClient interface { + Do(req *http.Request) (*http.Response, error) +} + +func getReq(rawURL, authHeader string) (*http.Request, error) { + parsedURL, err := url.ParseRequestURI(rawURL) + if err != nil { + return nil, err + } + + req, err := http.NewRequest("GET", parsedURL.String(), nil) + if err != nil { + return nil, err + } + + if len(authHeader) > 0 { + req.Header.Set("Authorization", authHeader) + } + return req, nil +} + +func readResponseBody(res *http.Response) ([]byte, error) { + if res != nil { + defer res.Body.Close() + } + + if res.StatusCode != http.StatusOK { + return nil, fmt.Errorf("chart download request failed") + } + + body, err := ioutil.ReadAll(res.Body) + if err != nil { + return nil, err + } + return body, nil +} + +func parseIndex(data []byte) (*repo.IndexFile, error) { + index := &repo.IndexFile{} + err := yaml.Unmarshal(data, index) + if err != nil { + return index, err + } + index.SortEntries() + return index, nil +} + +// FetchRepoIndex returns a Helm repository +func FetchRepoIndex(netClient *HTTPClient, repoURL string, authHeader string) (*repo.IndexFile, error) { + req, err := getReq(repoURL, authHeader) + if err != nil { + return nil, err + } + + res, err := (*netClient).Do(req) + if err != nil { + return nil, err + } + data, err := readResponseBody(res) + if err != nil { + return nil, err + } + + return parseIndex(data) +} + +func resolveChartURL(index, chart string) (string, error) { + indexURL, err := url.Parse(strings.TrimSpace(index)) + if err != nil { + return "", err + } + chartURL, err := indexURL.Parse(strings.TrimSpace(chart)) + if err != nil { + return "", err + } + return chartURL.String(), nil +} + +// FindChartInRepoIndex returns the URL of a chart given a Helm repository and its name and version +func FindChartInRepoIndex(repoIndex *repo.IndexFile, repoURL, chartName, chartVersion string) (string, error) { + errMsg := fmt.Sprintf("chart %q", chartName) + if chartVersion != "" { + errMsg = fmt.Sprintf("%s version %q", errMsg, chartVersion) + } + cv, err := repoIndex.Get(chartName, chartVersion) + if err != nil { + return "", fmt.Errorf("%s not found in repository", errMsg) + } + if len(cv.URLs) == 0 { + return "", fmt.Errorf("%s has no downloadable URLs", errMsg) + } + return resolveChartURL(repoURL, cv.URLs[0]) +} + +// LoadChart should return a Chart struct from an IOReader +type LoadChart func(in io.Reader) (*chart.Chart, error) + +// FetchChart returns the Chart content given an URL and the auth header if needed +func FetchChart(netClient *HTTPClient, chartURL, authHeader string, load LoadChart) (*chart.Chart, error) { + req, err := getReq(chartURL, authHeader) + if err != nil { + return nil, err + } + + res, err := (*netClient).Do(req) + if err != nil { + return nil, err + } + data, err := readResponseBody(res) + if err != nil { + return nil, err + } + return load(bytes.NewReader(data)) +} diff --git a/cmd/tiller-proxy/chart/chart_test.go b/cmd/tiller-proxy/chart/chart_test.go new file mode 100644 index 00000000000..5c331a272c8 --- /dev/null +++ b/cmd/tiller-proxy/chart/chart_test.go @@ -0,0 +1,91 @@ +/* +Copyright (c) 2018 Bitnami + +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 chart + +import ( + "fmt" + "testing" + "time" + + "github.com/arschles/assert" + "k8s.io/helm/pkg/proto/hapi/chart" + "k8s.io/helm/pkg/repo" +) + +func Test_resolveChartURL(t *testing.T) { + tests := []struct { + name string + baseURL string + chartURL string + wantedURL string + }{ + { + "absolute url", + "http://www.google.com", + "http://charts.example.com/repo/wordpress-0.1.0.tgz", + "http://charts.example.com/repo/wordpress-0.1.0.tgz", + }, + { + "relative, repo url", + "http://charts.example.com/repo/", + "wordpress-0.1.0.tgz", + "http://charts.example.com/repo/wordpress-0.1.0.tgz", + }, + { + "relative, repo index url", + "http://charts.example.com/repo/index.yaml", + "wordpress-0.1.0.tgz", + "http://charts.example.com/repo/wordpress-0.1.0.tgz", + }, + { + "relative, repo url - no trailing slash", + "http://charts.example.com/repo", + "wordpress-0.1.0.tgz", + "http://charts.example.com/wordpress-0.1.0.tgz", + }, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + chartURL, err := resolveChartURL(tt.baseURL, tt.chartURL) + assert.NoErr(t, err) + assert.Equal(t, chartURL, tt.wantedURL, "url") + }) + } +} + +func TestFindChartInRepoIndex(t *testing.T) { + name := "foo" + version := "v1.0.0" + chartURL := "wordpress-0.1.0.tgz" + repoURL := "http://charts.example.com/repo/" + expectedURL := fmt.Sprintf("%s%s", repoURL, chartURL) + + chartMeta := chart.Metadata{Name: name, Version: version} + chartVersion := repo.ChartVersion{URLs: []string{chartURL}} + chartVersion.Metadata = &chartMeta + chartVersions := []*repo.ChartVersion{&chartVersion} + entries := map[string]repo.ChartVersions{} + entries[name] = chartVersions + index := &repo.IndexFile{APIVersion: "v1", Generated: time.Now(), Entries: entries} + + res, err := FindChartInRepoIndex(index, repoURL, name, version) + if err != nil { + t.Errorf("Unexpected error %v", err) + } + if res != expectedURL { + t.Errorf("Expecting %s to be resolved as %s", res, expectedURL) + } +} From 22d2777688fca89e373e46ae6485067bd898eba1 Mon Sep 17 00:00:00 2001 From: Andres Date: Tue, 12 Jun 2018 12:33:12 +0200 Subject: [PATCH 04/13] Proxy logic to communicate with tiller --- cmd/tiller-proxy/proxy/proxy.go | 309 +++++++++++++++++++++++ cmd/tiller-proxy/proxy/proxy_test.go | 364 +++++++++++++++++++++++++++ 2 files changed, 673 insertions(+) create mode 100644 cmd/tiller-proxy/proxy/proxy.go create mode 100644 cmd/tiller-proxy/proxy/proxy_test.go diff --git a/cmd/tiller-proxy/proxy/proxy.go b/cmd/tiller-proxy/proxy/proxy.go new file mode 100644 index 00000000000..f5621f218de --- /dev/null +++ b/cmd/tiller-proxy/proxy/proxy.go @@ -0,0 +1,309 @@ +/* +Copyright (c) 2018 Bitnami + +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 proxy + +import ( + "encoding/json" + "fmt" + "os" + "strings" + "sync" + + log "github.com/sirupsen/logrus" + "google.golang.org/grpc" + corev1 "k8s.io/api/core/v1" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/client-go/kubernetes" + "k8s.io/helm/pkg/helm" + "k8s.io/helm/pkg/proto/hapi/chart" + "k8s.io/helm/pkg/proto/hapi/release" + + chartUtils "github.com/kubeapps/kubeapps/cmd/tiller-proxy/chart" +) + +const ( + defaultNamespace = metav1.NamespaceSystem + defaultRepoURL = "https://kubernetes-charts.storage.googleapis.com" + defaultTimeoutSeconds = 180 +) + +var ( + appMutex map[string]*sync.Mutex +) + +func init() { + appMutex = make(map[string]*sync.Mutex) +} + +// Proxy contains all the elements to contact Tiller and the K8s API +type Proxy struct { + kubeClient kubernetes.Interface + helmClient helm.Interface + netClient *chartUtils.HTTPClient + loadChart chartUtils.LoadChart +} + +type helmRelease struct { + // RepoURL is the URL of the repository. Defaults to stable repo. + RepoURL string `json:"repoUrl,omitempty"` + // ChartName is the name of the chart within the repo. + ChartName string `json:"chartName"` + // ReleaseName is the Name of the release given to Tiller. + ReleaseName string `json:"releaseName"` + // Version is the chart version. + Version string `json:"version"` + // Auth is the authentication. + Auth helmReleaseAuth `json:"auth,omitempty"` + // Values is a string containing (unparsed) YAML values. + Values string `json:"values,omitempty"` +} + +type helmReleaseAuth struct { + // Header is header based Authorization + Header *helmReleaseAuthHeader `json:"header,omitempty"` +} + +type helmReleaseAuthHeader struct { + // Selects a key of a secret in the pod's namespace + SecretKeyRef corev1.SecretKeySelector `json:"secretKeyRef,omitempty"` +} + +func isNotFound(err error) bool { + // Ideally this would be `grpc.Code(err) == codes.NotFound`, + // but it seems helm doesn't return grpc codes + return strings.Contains(grpc.ErrorDesc(err), "not found") +} + +// NewProxy creates a Proxy +func NewProxy(kubeClient kubernetes.Interface, helmClient helm.Interface, netClient chartUtils.HTTPClient, loadChart chartUtils.LoadChart) *Proxy { + return &Proxy{ + kubeClient: kubeClient, + helmClient: helmClient, + netClient: &netClient, + loadChart: loadChart, + } +} + +// AppOverview represents the basics of a release +type AppOverview struct { + ReleaseName string `json:"releaseName"` + Version string `json:"version"` + Namespace string `json:"namespace"` +} + +func (p *Proxy) getChart(rel *helmRelease) (*chart.Chart, error) { + repoURL := rel.RepoURL + if repoURL == "" { + // FIXME: Make configurable + repoURL = defaultRepoURL + } + repoURL = strings.TrimSuffix(strings.TrimSpace(repoURL), "/") + "/index.yaml" + + authHeader := "" + if rel.Auth.Header != nil { + namespace := os.Getenv("POD_NAMESPACE") + if namespace == "" { + namespace = defaultNamespace + } + + secret, err := p.kubeClient.Core().Secrets(namespace).Get(rel.Auth.Header.SecretKeyRef.Name, metav1.GetOptions{}) + if err != nil { + return nil, err + } + authHeader = string(secret.Data[rel.Auth.Header.SecretKeyRef.Key]) + } + + log.Printf("Downloading repo %s index...", repoURL) + repoIndex, err := chartUtils.FetchRepoIndex(p.netClient, repoURL, authHeader) + if err != nil { + return nil, err + } + + chartURL, err := chartUtils.FindChartInRepoIndex(repoIndex, repoURL, rel.ChartName, rel.Version) + if err != nil { + return nil, err + } + + log.Printf("Downloading %s ...", chartURL) + chartRequested, err := chartUtils.FetchChart(p.netClient, chartURL, authHeader, p.loadChart) + if err != nil { + return nil, err + } + return chartRequested, nil +} + +func (p *Proxy) get(name, namespace string) (*release.Release, error) { + list, err := p.helmClient.ListReleases() + if err != nil { + return nil, fmt.Errorf("Unable to list helm releases: %v", err) + } + var rel *release.Release + for _, r := range list.Releases { + if (namespace == "" || namespace == r.Namespace) && r.Name == name { + rel = r + break + } + } + if rel == nil { + return nil, fmt.Errorf("Release %s not found in namespace %s", name, namespace) + } + return rel, nil +} + +func (p *Proxy) deploy(name, namespace, values string, ch *chart.Chart) (*release.Release, error) { + log.Printf("Installing release %s into namespace %s", name, namespace) + res, err := p.helmClient.InstallReleaseFromChart( + ch, + namespace, + helm.ValueOverrides([]byte(values)), + helm.ReleaseName(name), + ) + if err != nil { + return nil, err + } + return res.GetRelease(), nil +} + +func (p *Proxy) update(name, namespace, values string, ch *chart.Chart) (*release.Release, error) { + log.Printf("Updating release %s", name) + res, err := p.helmClient.UpdateReleaseFromChart( + name, + ch, + helm.UpdateValueOverrides([]byte(values)), + //helm.UpgradeForce(true), ? + ) + if err != nil { + return nil, err + } + return res.GetRelease(), nil +} + +// LogReleaseStatus prints the status of the given release if exists +func (p *Proxy) LogReleaseStatus(relName string) { + status, err := p.helmClient.ReleaseStatus(relName) + if err == nil { + if status.Info != nil && status.Info.Status != nil { + log.Printf("Release status: %s", status.Info.Status.Code) + } + } else { + log.Printf("Unable to fetch release status for %s: %v", relName, err) + } +} + +// ListReleases list releases in a specific namespace if given +func (p *Proxy) ListReleases(namespace string) ([]AppOverview, error) { + list, err := p.helmClient.ListReleases() + if err != nil { + return []AppOverview{}, fmt.Errorf("Unable to list helm releases: %v", err) + } + appList := []AppOverview{} + for _, r := range list.Releases { + if namespace == "" || namespace == r.Namespace { + appList = append(appList, AppOverview{r.Name, r.Chart.Metadata.Version, r.Namespace}) + } + } + return appList, nil +} + +func lock(name string) { + if appMutex[name] == nil { + appMutex[name] = &sync.Mutex{} + } + appMutex[name].Lock() +} + +func unlock(name string) { + appMutex[name].Unlock() +} + +// CreateRelease creates a tiller release +func (p *Proxy) CreateRelease(namespace string, rawRelease []byte) (*release.Release, error) { + hrelease := &helmRelease{} + err := json.Unmarshal(rawRelease, hrelease) + if err != nil { + return nil, fmt.Errorf("Unable to parse request body: %v", err) + } + lock(hrelease.ReleaseName) + defer unlock(hrelease.ReleaseName) + ch, err := p.getChart(hrelease) + if err != nil { + return nil, fmt.Errorf("Unable to retrieve chart info: %v", err) + } + if err != nil { + return nil, err + } + rel, err := p.deploy(hrelease.ReleaseName, namespace, hrelease.Values, ch) + if err != nil { + return nil, fmt.Errorf("Unable create release: %v", err) + } + return rel, nil +} + +// UpdateRelease upgrades a tiller release +func (p *Proxy) UpdateRelease(name, namespace string, rawRelease []byte) (*release.Release, error) { + lock(name) + defer unlock(name) + var rel *release.Release + // Check if the release already exists + _, err := p.get(name, namespace) + if err != nil && isNotFound(err) { + return nil, fmt.Errorf("Release %s not found in the namespace %s. Unable to update it", name, namespace) + } else if err != nil { + return nil, err + } else { + hrelease := &helmRelease{} + err := json.Unmarshal(rawRelease, hrelease) + if err != nil { + return nil, fmt.Errorf("Unable to parse request body: %v", err) + } + ch, err := p.getChart(hrelease) + if err != nil { + return nil, fmt.Errorf("Unable to retrieve chart info: %v", err) + } + if err != nil { + return nil, err + } + rel, err = p.update(hrelease.ReleaseName, namespace, hrelease.Values, ch) + if err != nil { + return nil, fmt.Errorf("Unable to update release: %v", err) + } + } + return rel, nil +} + +// GetRelease returns the info of a release +func (p *Proxy) GetRelease(name, namespace string) (*release.Release, error) { + lock(name) + defer unlock(name) + return p.get(name, namespace) +} + +// DeleteRelease deletes a release +func (p *Proxy) DeleteRelease(name, namespace string) error { + lock(name) + defer unlock(name) + // Validate that the release actually belongs to the namespace + _, err := p.get(name, namespace) + if err != nil { + return err + } + _, err = p.helmClient.DeleteRelease(name, helm.DeletePurge(true)) + if err != nil { + return fmt.Errorf("Unable to delete release: %v", err) + } + return nil +} diff --git a/cmd/tiller-proxy/proxy/proxy_test.go b/cmd/tiller-proxy/proxy/proxy_test.go new file mode 100644 index 00000000000..0fc6e6e8bbf --- /dev/null +++ b/cmd/tiller-proxy/proxy/proxy_test.go @@ -0,0 +1,364 @@ +/* +Copyright (c) 2018 Bitnami + +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 proxy + +import ( + "bytes" + "encoding/json" + "fmt" + "io" + "io/ioutil" + "net/http" + "reflect" + "strings" + "testing" + "time" + + "k8s.io/client-go/kubernetes/fake" + "k8s.io/helm/pkg/helm" + "k8s.io/helm/pkg/proto/hapi/chart" + "k8s.io/helm/pkg/proto/hapi/release" + "k8s.io/helm/pkg/repo" +) + +// Fake server for repositories and charts +type fakeHTTPClient struct { + repoURLs []string + chartURLs []string + index *repo.IndexFile +} + +func (f *fakeHTTPClient) Do(h *http.Request) (*http.Response, error) { + for _, repoURL := range f.repoURLs { + if h.URL.String() == fmt.Sprintf("%sindex.yaml", repoURL) { + // Return fake chart index (not customizable per repo) + body, err := json.Marshal(*f.index) + if err != nil { + fmt.Printf("Error! %v", err) + } + return &http.Response{StatusCode: 200, Body: ioutil.NopCloser(bytes.NewReader(body))}, nil + } + } + for _, chartURL := range f.chartURLs { + if h.URL.String() == chartURL { + // Simulate download time + time.Sleep(100 * time.Millisecond) + // Fake chart response + return &http.Response{StatusCode: 200, Body: ioutil.NopCloser(bytes.NewReader([]byte{}))}, nil + } + } + // Unexpected path + return &http.Response{StatusCode: 404}, fmt.Errorf("Unexpected path") +} + +func fakeLoadChart(in io.Reader) (*chart.Chart, error) { + // Fake I/O time + time.Sleep(100 * time.Millisecond) + return &chart.Chart{}, nil +} + +func prepareTestProxy(hrs []helmRelease, existingTillerReleases []AppOverview) *Proxy { + var repoURLs []string + var chartURLs []string + entries := map[string]repo.ChartVersions{} + // Populate Chart registry with content of the given helmReleases + for _, hr := range hrs { + repoURLs = append(repoURLs, hr.RepoURL) + chartMeta := chart.Metadata{Name: hr.ChartName, Version: hr.Version} + chartURL := fmt.Sprintf("%s%s-%s.tgz", hr.RepoURL, hr.ChartName, hr.Version) + chartURLs = append(chartURLs, chartURL) + chartVersion := repo.ChartVersion{Metadata: &chartMeta, URLs: []string{chartURL}} + chartVersions := []*repo.ChartVersion{&chartVersion} + entries[hr.ChartName] = chartVersions + } + index := &repo.IndexFile{APIVersion: "v1", Generated: time.Now(), Entries: entries} + netClient := fakeHTTPClient{repoURLs, chartURLs, index} + helmClient := helm.FakeClient{} + // Populate Fake helm client with releases + for _, r := range existingTillerReleases { + helmClient.Rels = append(helmClient.Rels, &release.Release{ + Name: r.ReleaseName, + Namespace: r.Namespace, + Chart: &chart.Chart{ + Metadata: &chart.Metadata{ + Version: r.Version, + }, + }, + }) + } + kubeClient := fake.NewSimpleClientset() + return NewProxy(kubeClient, &helmClient, &netClient, fakeLoadChart) +} + +func TestListAllReleases(t *testing.T) { + app1 := AppOverview{"foo", "1.0.0", "my_ns"} + app2 := AppOverview{"bar", "1.0.0", "other_ns"} + proxy := prepareTestProxy([]helmRelease{}, []AppOverview{app1, app2}) + + // Should return all the releases if no namespace is given + releases, err := proxy.ListReleases("") + if err != nil { + t.Fatalf("Unexpected error %v", err) + } + if len(releases) != 2 { + t.Errorf("It should return both releases") + } + if !reflect.DeepEqual([]AppOverview{app1, app2}, releases) { + t.Errorf("Unexpected list of releases %v", releases) + } +} + +func TestListNamespacedRelease(t *testing.T) { + app1 := AppOverview{"foo", "1.0.0", "my_ns"} + app2 := AppOverview{"bar", "1.0.0", "other_ns"} + proxy := prepareTestProxy([]helmRelease{}, []AppOverview{app1, app2}) + + // Should return all the releases if no namespace is given + releases, err := proxy.ListReleases(app1.Namespace) + if err != nil { + t.Fatalf("Unexpected error %v", err) + } + if len(releases) != 1 { + t.Errorf("It should return both releases") + } + if !reflect.DeepEqual([]AppOverview{app1}, releases) { + t.Errorf("Unexpected list of releases %v", releases) + } +} + +func TestCreateHelmRelease(t *testing.T) { + ns := "myns" + h := helmRelease{ + ReleaseName: "not-foo", + RepoURL: "http://charts.example.com/repo/", + ChartName: "foo", + Version: "v1.0.0", + } + rawRelease, _ := json.Marshal(h) + proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{}) + + result, err := proxy.CreateRelease(ns, rawRelease) + if err != nil { + t.Errorf("Unexpected error %v", err) + } + if result.Name != h.ReleaseName { + t.Errorf("Expected release named %s received %s", h.ReleaseName, result.Name) + } + if result.Namespace != ns { + t.Errorf("Expected release in namespace %s received %s", ns, result.Namespace) + } + // We cannot check that the rest of the chart properties as properly set + // because the fake InstallReleaseFromChart ignores the given chart +} + +func TestCreateConflictingHelmRelease(t *testing.T) { + ns1 := "myns" + h := helmRelease{ + ReleaseName: "not-foo", + RepoURL: "http://charts.example.com/repo/", + ChartName: "foo", + Version: "v1.0.0", + } + ns2 := "other_ns" + app := AppOverview{h.ReleaseName, h.Version, ns2} + rawRelease, _ := json.Marshal(h) + proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{app}) + + _, err := proxy.CreateRelease(ns1, rawRelease) + if err == nil { + t.Error("Release should fail, an existing release in a different namespace already exists") + } + if !strings.Contains(err.Error(), "name that is still in use") { + t.Errorf("Unexpected error %v", err) + } +} + +func TestHelmReleaseUpdated(t *testing.T) { + ns := "myns" + h := helmRelease{ + ReleaseName: "not-foo", + RepoURL: "http://charts.example.com/repo/", + ChartName: "foo", + Version: "v1.0.0", + } + rawRelease, _ := json.Marshal(h) + app := AppOverview{h.ReleaseName, h.Version, ns} + proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{app}) + + result, err := proxy.UpdateRelease(h.ReleaseName, ns, rawRelease) + if err != nil { + t.Errorf("Unexpected error %v", err) + } + if result.Name != h.ReleaseName { + t.Errorf("Expected release named %s received %s", h.ReleaseName, result.Name) + } + if result.Namespace != ns { + t.Errorf("Expected release in namespace %s received %s", ns, result.Namespace) + } + rels, err := proxy.helmClient.ListReleases() + if err != nil { + t.Errorf("Unexpected error %v", err) + } + // We cannot test that the release content changes because fake UpdateReleaseResponse + // does not modify the release + if len(rels.Releases) != 1 { + t.Errorf("Unexpected amount of releases %d, it should update the existing one", len(rels.Releases)) + } +} + +func TestUpdateMissingHelmRelease(t *testing.T) { + ns := "myns" + h := helmRelease{ + ReleaseName: "not-foo", + RepoURL: "http://charts.example.com/repo/", + ChartName: "foo", + Version: "v1.0.0", + } + rawRelease, _ := json.Marshal(h) + // Simulate the same app but in a different namespace + ns2 := "other_ns" + app := AppOverview{h.ReleaseName, h.Version, ns2} + proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{app}) + + _, err := proxy.UpdateRelease(h.ReleaseName, ns, rawRelease) + if err == nil { + t.Error("Update should fail, there is not a release in the namespace specified") + } + if !strings.Contains(err.Error(), "not found") { + t.Errorf("Unexpected error %v", err) + } +} + +func TestGetHelmRelease(t *testing.T) { + app1 := AppOverview{"foo", "1.0.0", "my_ns"} + app2 := AppOverview{"bar", "1.0.0", "other_ns"} + type testStruct struct { + existingApps []AppOverview + shouldFail bool + targetApp string + tartegNamespace string + expectedResult string + } + tests := []testStruct{ + {[]AppOverview{app1, app2}, false, "foo", "my_ns", "foo"}, + {[]AppOverview{app1, app2}, true, "bar", "my_ns", ""}, + {[]AppOverview{app1, app2}, true, "foobar", "my_ns", ""}, + {[]AppOverview{app1, app2}, false, "foo", "", "foo"}, + } + for _, test := range tests { + proxy := prepareTestProxy([]helmRelease{}, test.existingApps) + res, err := proxy.GetRelease(test.targetApp, test.tartegNamespace) + if test.shouldFail && err == nil { + t.Errorf("Get %s/%s should fail", test.tartegNamespace, test.targetApp) + } + if !test.shouldFail { + if err != nil { + t.Errorf("Unexpected error %v", err) + } + if res.Name != test.expectedResult { + t.Errorf("Expecting app %s, received %s", test.expectedResult, res.Name) + } + } + } +} + +func TestHelmReleaseDeleted(t *testing.T) { + app := AppOverview{"foo", "1.0.0", "my_ns"} + proxy := prepareTestProxy([]helmRelease{}, []AppOverview{app}) + + err := proxy.DeleteRelease(app.ReleaseName, app.Namespace) + if err != nil { + t.Errorf("Unexpected error %v", err) + } + rels, err := proxy.helmClient.ListReleases() + if err != nil { + t.Errorf("Unexpected error %v", err) + } + if len(rels.Releases) != 0 { + t.Errorf("Unexpected amount of releases %d, it should be empty", len(rels.Releases)) + } +} + +func TestDeleteMissingHelmRelease(t *testing.T) { + app := AppOverview{"foo", "1.0.0", "my_ns"} + proxy := prepareTestProxy([]helmRelease{}, []AppOverview{app}) + + err := proxy.DeleteRelease(app.ReleaseName, "other_ns") + if err == nil { + t.Error("Delete should fail, there is not a release in the namespace specified") + } + rels, err := proxy.helmClient.ListReleases() + if err != nil { + t.Errorf("Unexpected error %v", err) + } + if len(rels.Releases) != 1 { + t.Errorf("Unexpected amount of releases %d, it contain a release", len(rels.Releases)) + } +} + +func TestEnsureThreadSafety(t *testing.T) { + ns := "myns" + h := helmRelease{ + ReleaseName: "not-foo", + RepoURL: "http://charts.example.com/repo/", + ChartName: "foo", + Version: "v1.0.0", + } + rawRelease, _ := json.Marshal(h) + proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{}) + finish := make(chan struct{}) + type test func() + phases := []test{ + func() { + // Create first element + result, err := proxy.CreateRelease(ns, rawRelease) + if err != nil { + t.Errorf("Unexpected error %v", err) + } + if result.Name != h.ReleaseName { + t.Errorf("Expected release named %s received %s", h.ReleaseName, result.Name) + } + }, + func() { + // Try to create it again + _, err := proxy.CreateRelease(ns, rawRelease) + if err == nil { + t.Errorf("Should fail with 'already exists'") + } + }, + func() { + _, err := proxy.UpdateRelease(h.ReleaseName, ns, rawRelease) + if err != nil { + t.Errorf("Unexpected error %v", err) + } + }, + func() { + err := proxy.DeleteRelease(h.ReleaseName, ns) + if err != nil { + t.Errorf("Unexpected error %v", err) + } + finish <- struct{}{} + }, + } + for _, phase := range phases { + // Run all phases in parallel + go phase() + // Give minimum time for phase to block + time.Sleep(1 * time.Millisecond) + } + <-finish +} From e0bfeac4cc4df512deedf7e1d07988a4b2eed766 Mon Sep 17 00:00:00 2001 From: Andres Date: Tue, 12 Jun 2018 12:34:02 +0200 Subject: [PATCH 05/13] Proxy HTTP wrapper --- cmd/tiller-proxy/handler.go | 124 ++++++++++++++++++++++++++++++++++++ 1 file changed, 124 insertions(+) create mode 100644 cmd/tiller-proxy/handler.go diff --git a/cmd/tiller-proxy/handler.go b/cmd/tiller-proxy/handler.go new file mode 100644 index 00000000000..d54ac67fa54 --- /dev/null +++ b/cmd/tiller-proxy/handler.go @@ -0,0 +1,124 @@ +/* +Copyright (c) 2018 Bitnami + +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 main + +import ( + "io/ioutil" + "k8s.io/helm/pkg/proto/hapi/release" + "net/http" + "strings" + + "github.com/gorilla/mux" + "github.com/kubeapps/common/response" + log "github.com/sirupsen/logrus" +) + +// Params a key-value map of path params +type Params map[string]string + +// WithParams can be used to wrap handlers to take an extra arg for path params +type WithParams func(http.ResponseWriter, *http.Request, Params) + +func (h WithParams) ServeHTTP(w http.ResponseWriter, req *http.Request) { + vars := mux.Vars(req) + h(w, req, vars) +} + +func isNotFound(err error) bool { + return strings.Contains(err.Error(), "not found") +} + +func isAlreadyExists(err error) bool { + return strings.Contains(err.Error(), "is still in use") || strings.Contains(err.Error(), "already exists") +} + +func deployRelease(w http.ResponseWriter, req *http.Request, params Params) { + log.Printf("Creating/updating Helm Release") + defer req.Body.Close() + body, err := ioutil.ReadAll(req.Body) + if err != nil { + response.NewErrorResponse(http.StatusInternalServerError, err.Error()).Write(w) + return + } + var rel *release.Release + if req.Method == "POST" && params["releaseName"] == "" { + rel, err = p.CreateRelease(params["namespace"], body) + } else { + rel, err = p.UpdateRelease(params["releaseName"], params["namespace"], body) + } + if err != nil { + errCode := http.StatusInternalServerError + if isAlreadyExists(err) { + errCode = http.StatusConflict + } else if isNotFound(err) { + errCode = http.StatusNotFound + } + response.NewErrorResponse(errCode, err.Error()).Write(w) + return + } + log.Printf("Installed/updated release %s", rel.Name) + p.LogReleaseStatus(rel.Name) + response.NewDataResponse(*rel).Write(w) +} + +func listAllReleases(w http.ResponseWriter, req *http.Request) { + log.Printf("Listing All Helm Releases") + apps, err := p.ListReleases("") + if err != nil { + response.NewErrorResponse(http.StatusInternalServerError, err.Error()).Write(w) + return + } + response.NewDataResponse(apps).Write(w) +} + +func listReleases(w http.ResponseWriter, req *http.Request, params Params) { + log.Printf("Listing Helm Releases of the namespace %s", params["namespace"]) + apps, err := p.ListReleases(params["namespace"]) + if err != nil { + response.NewErrorResponse(http.StatusInternalServerError, err.Error()).Write(w) + return + } + response.NewDataResponse(apps).Write(w) +} + +func getRelease(w http.ResponseWriter, req *http.Request, params Params) { + log.Printf("Getting Helm Release %s", params["releaseName"]) + rel, err := p.GetRelease(params["releaseName"], params["namespace"]) + if err != nil { + errCode := http.StatusInternalServerError + if isNotFound(err) { + errCode = http.StatusNotFound + } + response.NewErrorResponse(errCode, err.Error()).Write(w) + return + } + response.NewDataResponse(*rel).Write(w) +} + +func deleteRelease(w http.ResponseWriter, req *http.Request, params Params) { + log.Printf("Deleting Helm Release %s", params["releaseName"]) + err := p.DeleteRelease(params["releaseName"], params["namespace"]) + if err != nil { + errCode := http.StatusInternalServerError + if isNotFound(err) { + errCode = http.StatusNotFound + } + response.NewErrorResponse(errCode, err.Error()).Write(w) + return + } + w.Write([]byte("OK")) +} From cbeb53cd848fecc297511666eda4b4a06d6e8dc3 Mon Sep 17 00:00:00 2001 From: Andres Date: Tue, 12 Jun 2018 12:34:11 +0200 Subject: [PATCH 06/13] Main function --- cmd/tiller-proxy/main.go | 106 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 106 insertions(+) create mode 100644 cmd/tiller-proxy/main.go diff --git a/cmd/tiller-proxy/main.go b/cmd/tiller-proxy/main.go new file mode 100644 index 00000000000..a4de0e1c0c6 --- /dev/null +++ b/cmd/tiller-proxy/main.go @@ -0,0 +1,106 @@ +/* +Copyright (c) 2018 Bitnami + +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 main + +import ( + "net/http" + "os" + "time" + + "github.com/gorilla/mux" + "github.com/heptiolabs/healthcheck" + log "github.com/sirupsen/logrus" + "github.com/spf13/pflag" + "github.com/urfave/negroni" + "k8s.io/client-go/kubernetes" + "k8s.io/client-go/rest" + "k8s.io/helm/pkg/chartutil" + "k8s.io/helm/pkg/helm" + "k8s.io/helm/pkg/helm/environment" + + "github.com/kubeapps/kubeapps/cmd/tiller-proxy/proxy" +) + +var ( + settings environment.EnvSettings + p *proxy.Proxy +) + +const ( + defaultTimeoutSeconds = 180 +) + +func init() { + settings.AddFlags(pflag.CommandLine) +} + +func main() { + pflag.Parse() + + // set defaults from environment + settings.Init(pflag.CommandLine) + + config, err := rest.InClusterConfig() + if err != nil { + panic(err) + } + + kubeClient, err := kubernetes.NewForConfig(config) + if err != nil { + panic(err) + } + + log.Printf("Using tiller host: %s", settings.TillerHost) + helmClient := helm.NewClient(helm.Host(settings.TillerHost)) + err = helmClient.PingTiller() + if err != nil { + panic(err) + } + + netClient := &http.Client{ + Timeout: time.Second * defaultTimeoutSeconds, + } + + p = proxy.NewProxy(kubeClient, helmClient, netClient, chartutil.LoadArchive) + + r := mux.NewRouter() + + // Healthcheck + health := healthcheck.NewHandler() + r.Handle("/live", health) + r.Handle("/ready", health) + + // Routes + apiv1 := r.PathPrefix("/v1").Subrouter() + apiv1.Methods("GET").Path("/releases").HandlerFunc(listAllReleases) + apiv1.Methods("GET").Path("/namespaces/{namespace}/releases").Handler(WithParams(listReleases)) + apiv1.Methods("POST").Path("/namespaces/{namespace}/releases").Handler(WithParams(deployRelease)) + apiv1.Methods("GET").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithParams(getRelease)) + apiv1.Methods("PUT").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithParams(deployRelease)) + apiv1.Methods("DELETE").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithParams(deleteRelease)) + + n := negroni.Classic() + n.UseHandler(r) + + port := os.Getenv("PORT") + if port == "" { + port = "8080" + } + addr := ":" + port + log.WithFields(log.Fields{"addr": addr}).Info("Started Tiller Proxy") + http.ListenAndServe(addr, n) +} From 4e02db6c0bbb2591666c1341dbfa133e04837c78 Mon Sep 17 00:00:00 2001 From: Andres Date: Wed, 13 Jun 2018 12:29:50 +0200 Subject: [PATCH 07/13] Minor review --- Makefile | 3 --- cmd/tiller-proxy/Dockerfile | 2 +- cmd/tiller-proxy/Dockerfile.dev | 4 ---- cmd/tiller-proxy/handler.go | 14 ++++++------ cmd/tiller-proxy/main.go | 12 +++++----- .../tiller-proxy => pkg/utils}/chart/chart.go | 0 .../utils}/chart/chart_test.go | 0 .../tiller-proxy => pkg/utils}/proxy/proxy.go | 2 +- .../utils}/proxy/proxy_test.go | 22 +++++++++---------- 9 files changed, 26 insertions(+), 33 deletions(-) delete mode 100644 cmd/tiller-proxy/Dockerfile.dev rename {cmd/tiller-proxy => pkg/utils}/chart/chart.go (100%) rename {cmd/tiller-proxy => pkg/utils}/chart/chart_test.go (100%) rename {cmd/tiller-proxy => pkg/utils}/proxy/proxy.go (99%) rename {cmd/tiller-proxy => pkg/utils}/proxy/proxy_test.go (93%) diff --git a/Makefile b/Makefile index 8663a087818..8a0044c9fc3 100644 --- a/Makefile +++ b/Makefile @@ -38,9 +38,6 @@ kubeapps/%: kubeapps/dashboard: docker build -t kubeapps/dashboard:$(VERSION) -f dashboard/Dockerfile dashboard/ -tiller-proxy-dev: - CGO_ENABLED=0 GOOS=linux go build -installsuffix cgo -o ./cmd/tiller-proxy/proxy-static ./cmd/tiller-proxy - docker build -t kubeapps/tiller-proxy -f ./cmd/tiller-proxy/Dockerfile.dev . tiller-proxy: docker build -t kubeapps/tiller-proxy -f ./cmd/tiller-proxy/Dockerfile . diff --git a/cmd/tiller-proxy/Dockerfile b/cmd/tiller-proxy/Dockerfile index 7d976c4753c..6c552519cfe 100644 --- a/cmd/tiller-proxy/Dockerfile +++ b/cmd/tiller-proxy/Dockerfile @@ -4,6 +4,6 @@ WORKDIR /go/src/github.com/kubeapps/kubeapps RUN CGO_ENABLED=0 go build -a -installsuffix cgo ./cmd/tiller-proxy FROM scratch -COPY --from=builder /go/src/github.com/kubeapps/kubeapps/cmd/tiller-proxy/tiller-proxy /proxy +COPY --from=builder /go/src/github.com/kubeapps/kubeapps/tiller-proxy /proxy EXPOSE 8080 CMD ["/proxy"] diff --git a/cmd/tiller-proxy/Dockerfile.dev b/cmd/tiller-proxy/Dockerfile.dev deleted file mode 100644 index cb264c181a3..00000000000 --- a/cmd/tiller-proxy/Dockerfile.dev +++ /dev/null @@ -1,4 +0,0 @@ -FROM alpine:3.6 -RUN apk --no-cache add ca-certificates -COPY ./cmd/tiller-proxy/proxy-static /proxy -CMD ["/proxy"] \ No newline at end of file diff --git a/cmd/tiller-proxy/handler.go b/cmd/tiller-proxy/handler.go index d54ac67fa54..8e310b75ff7 100644 --- a/cmd/tiller-proxy/handler.go +++ b/cmd/tiller-proxy/handler.go @@ -56,9 +56,9 @@ func deployRelease(w http.ResponseWriter, req *http.Request, params Params) { } var rel *release.Release if req.Method == "POST" && params["releaseName"] == "" { - rel, err = p.CreateRelease(params["namespace"], body) + rel, err = proxy.CreateRelease(params["namespace"], body) } else { - rel, err = p.UpdateRelease(params["releaseName"], params["namespace"], body) + rel, err = proxy.UpdateRelease(params["releaseName"], params["namespace"], body) } if err != nil { errCode := http.StatusInternalServerError @@ -71,13 +71,13 @@ func deployRelease(w http.ResponseWriter, req *http.Request, params Params) { return } log.Printf("Installed/updated release %s", rel.Name) - p.LogReleaseStatus(rel.Name) + proxy.LogReleaseStatus(rel.Name) response.NewDataResponse(*rel).Write(w) } func listAllReleases(w http.ResponseWriter, req *http.Request) { log.Printf("Listing All Helm Releases") - apps, err := p.ListReleases("") + apps, err := proxy.ListReleases("") if err != nil { response.NewErrorResponse(http.StatusInternalServerError, err.Error()).Write(w) return @@ -87,7 +87,7 @@ func listAllReleases(w http.ResponseWriter, req *http.Request) { func listReleases(w http.ResponseWriter, req *http.Request, params Params) { log.Printf("Listing Helm Releases of the namespace %s", params["namespace"]) - apps, err := p.ListReleases(params["namespace"]) + apps, err := proxy.ListReleases(params["namespace"]) if err != nil { response.NewErrorResponse(http.StatusInternalServerError, err.Error()).Write(w) return @@ -97,7 +97,7 @@ func listReleases(w http.ResponseWriter, req *http.Request, params Params) { func getRelease(w http.ResponseWriter, req *http.Request, params Params) { log.Printf("Getting Helm Release %s", params["releaseName"]) - rel, err := p.GetRelease(params["releaseName"], params["namespace"]) + rel, err := proxy.GetRelease(params["releaseName"], params["namespace"]) if err != nil { errCode := http.StatusInternalServerError if isNotFound(err) { @@ -111,7 +111,7 @@ func getRelease(w http.ResponseWriter, req *http.Request, params Params) { func deleteRelease(w http.ResponseWriter, req *http.Request, params Params) { log.Printf("Deleting Helm Release %s", params["releaseName"]) - err := p.DeleteRelease(params["releaseName"], params["namespace"]) + err := proxy.DeleteRelease(params["releaseName"], params["namespace"]) if err != nil { errCode := http.StatusInternalServerError if isNotFound(err) { diff --git a/cmd/tiller-proxy/main.go b/cmd/tiller-proxy/main.go index a4de0e1c0c6..4f6a7f9f70f 100644 --- a/cmd/tiller-proxy/main.go +++ b/cmd/tiller-proxy/main.go @@ -32,12 +32,12 @@ import ( "k8s.io/helm/pkg/helm" "k8s.io/helm/pkg/helm/environment" - "github.com/kubeapps/kubeapps/cmd/tiller-proxy/proxy" + tillerProxy "github.com/kubeapps/kubeapps/pkg/utils/proxy" ) var ( settings environment.EnvSettings - p *proxy.Proxy + proxy *tillerProxy.Proxy ) const ( @@ -56,26 +56,26 @@ func main() { config, err := rest.InClusterConfig() if err != nil { - panic(err) + log.Fatalf("Unable to get cluter config: %v", err) } kubeClient, err := kubernetes.NewForConfig(config) if err != nil { - panic(err) + log.Fatalf("Unable to create a kubernetes client: %v", err) } log.Printf("Using tiller host: %s", settings.TillerHost) helmClient := helm.NewClient(helm.Host(settings.TillerHost)) err = helmClient.PingTiller() if err != nil { - panic(err) + log.Fatalf("Unable to connect to Tiller: %v", err) } netClient := &http.Client{ Timeout: time.Second * defaultTimeoutSeconds, } - p = proxy.NewProxy(kubeClient, helmClient, netClient, chartutil.LoadArchive) + proxy = tillerProxy.NewProxy(kubeClient, helmClient, netClient, chartutil.LoadArchive) r := mux.NewRouter() diff --git a/cmd/tiller-proxy/chart/chart.go b/pkg/utils/chart/chart.go similarity index 100% rename from cmd/tiller-proxy/chart/chart.go rename to pkg/utils/chart/chart.go diff --git a/cmd/tiller-proxy/chart/chart_test.go b/pkg/utils/chart/chart_test.go similarity index 100% rename from cmd/tiller-proxy/chart/chart_test.go rename to pkg/utils/chart/chart_test.go diff --git a/cmd/tiller-proxy/proxy/proxy.go b/pkg/utils/proxy/proxy.go similarity index 99% rename from cmd/tiller-proxy/proxy/proxy.go rename to pkg/utils/proxy/proxy.go index f5621f218de..60956dd84dc 100644 --- a/cmd/tiller-proxy/proxy/proxy.go +++ b/pkg/utils/proxy/proxy.go @@ -32,7 +32,7 @@ import ( "k8s.io/helm/pkg/proto/hapi/chart" "k8s.io/helm/pkg/proto/hapi/release" - chartUtils "github.com/kubeapps/kubeapps/cmd/tiller-proxy/chart" + chartUtils "github.com/kubeapps/kubeapps/pkg/utils/chart" ) const ( diff --git a/cmd/tiller-proxy/proxy/proxy_test.go b/pkg/utils/proxy/proxy_test.go similarity index 93% rename from cmd/tiller-proxy/proxy/proxy_test.go rename to pkg/utils/proxy/proxy_test.go index 0fc6e6e8bbf..eac17dc773e 100644 --- a/cmd/tiller-proxy/proxy/proxy_test.go +++ b/pkg/utils/proxy/proxy_test.go @@ -71,7 +71,7 @@ func fakeLoadChart(in io.Reader) (*chart.Chart, error) { return &chart.Chart{}, nil } -func prepareTestProxy(hrs []helmRelease, existingTillerReleases []AppOverview) *Proxy { +func newFakeProxy(hrs []helmRelease, existingTillerReleases []AppOverview) *Proxy { var repoURLs []string var chartURLs []string entries := map[string]repo.ChartVersions{} @@ -107,7 +107,7 @@ func prepareTestProxy(hrs []helmRelease, existingTillerReleases []AppOverview) * func TestListAllReleases(t *testing.T) { app1 := AppOverview{"foo", "1.0.0", "my_ns"} app2 := AppOverview{"bar", "1.0.0", "other_ns"} - proxy := prepareTestProxy([]helmRelease{}, []AppOverview{app1, app2}) + proxy := newFakeProxy([]helmRelease{}, []AppOverview{app1, app2}) // Should return all the releases if no namespace is given releases, err := proxy.ListReleases("") @@ -125,7 +125,7 @@ func TestListAllReleases(t *testing.T) { func TestListNamespacedRelease(t *testing.T) { app1 := AppOverview{"foo", "1.0.0", "my_ns"} app2 := AppOverview{"bar", "1.0.0", "other_ns"} - proxy := prepareTestProxy([]helmRelease{}, []AppOverview{app1, app2}) + proxy := newFakeProxy([]helmRelease{}, []AppOverview{app1, app2}) // Should return all the releases if no namespace is given releases, err := proxy.ListReleases(app1.Namespace) @@ -149,7 +149,7 @@ func TestCreateHelmRelease(t *testing.T) { Version: "v1.0.0", } rawRelease, _ := json.Marshal(h) - proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{}) + proxy := newFakeProxy([]helmRelease{h}, []AppOverview{}) result, err := proxy.CreateRelease(ns, rawRelease) if err != nil { @@ -176,7 +176,7 @@ func TestCreateConflictingHelmRelease(t *testing.T) { ns2 := "other_ns" app := AppOverview{h.ReleaseName, h.Version, ns2} rawRelease, _ := json.Marshal(h) - proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{app}) + proxy := newFakeProxy([]helmRelease{h}, []AppOverview{app}) _, err := proxy.CreateRelease(ns1, rawRelease) if err == nil { @@ -197,7 +197,7 @@ func TestHelmReleaseUpdated(t *testing.T) { } rawRelease, _ := json.Marshal(h) app := AppOverview{h.ReleaseName, h.Version, ns} - proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{app}) + proxy := newFakeProxy([]helmRelease{h}, []AppOverview{app}) result, err := proxy.UpdateRelease(h.ReleaseName, ns, rawRelease) if err != nil { @@ -232,7 +232,7 @@ func TestUpdateMissingHelmRelease(t *testing.T) { // Simulate the same app but in a different namespace ns2 := "other_ns" app := AppOverview{h.ReleaseName, h.Version, ns2} - proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{app}) + proxy := newFakeProxy([]helmRelease{h}, []AppOverview{app}) _, err := proxy.UpdateRelease(h.ReleaseName, ns, rawRelease) if err == nil { @@ -260,7 +260,7 @@ func TestGetHelmRelease(t *testing.T) { {[]AppOverview{app1, app2}, false, "foo", "", "foo"}, } for _, test := range tests { - proxy := prepareTestProxy([]helmRelease{}, test.existingApps) + proxy := newFakeProxy([]helmRelease{}, test.existingApps) res, err := proxy.GetRelease(test.targetApp, test.tartegNamespace) if test.shouldFail && err == nil { t.Errorf("Get %s/%s should fail", test.tartegNamespace, test.targetApp) @@ -278,7 +278,7 @@ func TestGetHelmRelease(t *testing.T) { func TestHelmReleaseDeleted(t *testing.T) { app := AppOverview{"foo", "1.0.0", "my_ns"} - proxy := prepareTestProxy([]helmRelease{}, []AppOverview{app}) + proxy := newFakeProxy([]helmRelease{}, []AppOverview{app}) err := proxy.DeleteRelease(app.ReleaseName, app.Namespace) if err != nil { @@ -295,7 +295,7 @@ func TestHelmReleaseDeleted(t *testing.T) { func TestDeleteMissingHelmRelease(t *testing.T) { app := AppOverview{"foo", "1.0.0", "my_ns"} - proxy := prepareTestProxy([]helmRelease{}, []AppOverview{app}) + proxy := newFakeProxy([]helmRelease{}, []AppOverview{app}) err := proxy.DeleteRelease(app.ReleaseName, "other_ns") if err == nil { @@ -319,7 +319,7 @@ func TestEnsureThreadSafety(t *testing.T) { Version: "v1.0.0", } rawRelease, _ := json.Marshal(h) - proxy := prepareTestProxy([]helmRelease{h}, []AppOverview{}) + proxy := newFakeProxy([]helmRelease{h}, []AppOverview{}) finish := make(chan struct{}) type test func() phases := []test{ From 0be05b76020d4111102ee07e3d99afdc040bf9c4 Mon Sep 17 00:00:00 2001 From: Andres Date: Fri, 15 Jun 2018 12:17:03 +0200 Subject: [PATCH 08/13] CMD update --- cmd/tiller-proxy/README.md | 17 ++-- cmd/tiller-proxy/handler.go | 171 ++++++++++++++++++++++++++++-------- cmd/tiller-proxy/main.go | 38 ++++---- 3 files changed, 161 insertions(+), 65 deletions(-) diff --git a/cmd/tiller-proxy/README.md b/cmd/tiller-proxy/README.md index 7ce3b979176..0a0db26f762 100644 --- a/cmd/tiller-proxy/README.md +++ b/cmd/tiller-proxy/README.md @@ -6,12 +6,6 @@ Part of the logic of this tool has been extracted from [helm-CRD](https://github The client should provide the header `Authorization: Bearer TOKEN` being TOKEN the Kubernetes API Token in order to perform any action. -The client should have permissions to: - - - "List" access to all the resources and all the groups for listing releases in a namespace. - - "Read" access to all the release resources in a release when doing a HTTP GET over a specific release. - - "Create" and "update" permissions to all the release resources when doing an HTTP POST or PUT to install or update a release. - # Configuration It is possible to configure this proxy with the following flags: @@ -35,3 +29,14 @@ This proxy provides 6 different routes: - `GET` `/namespaces/{namespace}/releases/{release}`: Get release info - `PUT` `/namespaces/{namespace}/releases/{release}`: Update release info - `DELETE` `/namespaces/{namespace}/releases/{release}`: Delete a release + +# Enabling authorization + +It is possible to enable authorization for helm releases setting the env var `ENABLE_AUTH`. If enabled, the client should have permissions to: + + - "Read" access to all the release resources in a release when doing a HTTP GET over a specific release. + - "Create" access to all the release resources in a release when doing a when doing an HTTP POST. + - "Create", "Update" and "Delete" permissions to all the release resources when doing an HTTP PUT to upgrade a release. + - "Delete" permissions to all the release resources when doing an HTTP PUT. + +Note that the user only needs a valid token in order to list releases. diff --git a/cmd/tiller-proxy/handler.go b/cmd/tiller-proxy/handler.go index 8e310b75ff7..19867545ed8 100644 --- a/cmd/tiller-proxy/handler.go +++ b/cmd/tiller-proxy/handler.go @@ -20,22 +20,55 @@ import ( "io/ioutil" "k8s.io/helm/pkg/proto/hapi/release" "net/http" + "os" + "strconv" "strings" + "time" "github.com/gorilla/mux" "github.com/kubeapps/common/response" log "github.com/sirupsen/logrus" + "k8s.io/helm/pkg/chartutil" + + "github.com/kubeapps/kubeapps/pkg/auth" + chartUtils "github.com/kubeapps/kubeapps/pkg/chart" +) + +const ( + defaultTimeoutSeconds = 180 +) + +var ( + netClient *http.Client + enableAuth bool ) +func init() { + netClient = &http.Client{ + Timeout: time.Second * defaultTimeoutSeconds, + } + enableAuth, _ = strconv.ParseBool(os.Getenv("ENABLE_AUTH")) +} + // Params a key-value map of path params type Params map[string]string -// WithParams can be used to wrap handlers to take an extra arg for path params -type WithParams func(http.ResponseWriter, *http.Request, Params) +// WithAuth can be used to wrap handlers to take an extra arg for path params +type WithAuth func(http.ResponseWriter, *http.Request, Params, *auth.UserAuth) -func (h WithParams) ServeHTTP(w http.ResponseWriter, req *http.Request) { +func (h WithAuth) ServeHTTP(w http.ResponseWriter, req *http.Request) { vars := mux.Vars(req) - h(w, req, vars) + authHeader := strings.Split(req.Header.Get("Authorization"), "Bearer ") + if len(authHeader) != 2 { + response.NewErrorResponse(http.StatusUnauthorized, "Unauthorized").Write(w) + return + } + userAuth, err := auth.NewAuth(authHeader[1]) + if err != nil { + response.NewErrorResponse(http.StatusUnauthorized, err.Error()).Write(w) + return + } + h(w, req, vars, userAuth) } func isNotFound(err error) bool { @@ -46,78 +79,142 @@ func isAlreadyExists(err error) bool { return strings.Contains(err.Error(), "is still in use") || strings.Contains(err.Error(), "already exists") } -func deployRelease(w http.ResponseWriter, req *http.Request, params Params) { +func isForbidden(err error) bool { + return strings.Contains(err.Error(), "Unauthorized") +} + +func errorCode(err error) int { + errCode := http.StatusInternalServerError + if isAlreadyExists(err) { + errCode = http.StatusConflict + } else if isNotFound(err) { + errCode = http.StatusNotFound + } else if isForbidden(err) { + errCode = http.StatusForbidden + } + return errCode +} + +func deployRelease(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { log.Printf("Creating/updating Helm Release") defer req.Body.Close() body, err := ioutil.ReadAll(req.Body) if err != nil { - response.NewErrorResponse(http.StatusInternalServerError, err.Error()).Write(w) + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + chartDetails, err := chartUtils.ParseDetails(body) + if err != nil { + response.NewErrorResponse(http.StatusUnprocessableEntity, err.Error()).Write(w) return } + ch, err := chartUtils.GetChart(chartDetails, kubeClient, netClient, chartutil.LoadArchive) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + action := "create" + if req.Method == "PUT" && params["releaseName"] != "" { + action = "upgrade" + } + if enableAuth { + manifest, err := proxy.ResolveManifest(params["namespace"], chartDetails.Values, ch) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + err = user.CanI(params["namespace"], action, manifest) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + } var rel *release.Release - if req.Method == "POST" && params["releaseName"] == "" { - rel, err = proxy.CreateRelease(params["namespace"], body) + if action == "create" { + rel, err = proxy.CreateRelease( + chartDetails.ReleaseName, + params["namespace"], + chartDetails.Values, + ch, + ) } else { - rel, err = proxy.UpdateRelease(params["releaseName"], params["namespace"], body) + rel, err = proxy.UpdateRelease( + params["releaseName"], + params["namespace"], + chartDetails.Values, + ch, + ) } if err != nil { - errCode := http.StatusInternalServerError - if isAlreadyExists(err) { - errCode = http.StatusConflict - } else if isNotFound(err) { - errCode = http.StatusNotFound - } - response.NewErrorResponse(errCode, err.Error()).Write(w) + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } log.Printf("Installed/updated release %s", rel.Name) - proxy.LogReleaseStatus(rel.Name) + status, err := proxy.GetReleaseStatus(rel.Name) + if err != nil { + log.Printf("Unable to fecth release status of %s: %v", rel.Name, err) + } else { + log.Printf("Release status: %s", status) + } response.NewDataResponse(*rel).Write(w) } -func listAllReleases(w http.ResponseWriter, req *http.Request) { - log.Printf("Listing All Helm Releases") +func listAllReleases(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { apps, err := proxy.ListReleases("") if err != nil { - response.NewErrorResponse(http.StatusInternalServerError, err.Error()).Write(w) + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } response.NewDataResponse(apps).Write(w) } -func listReleases(w http.ResponseWriter, req *http.Request, params Params) { - log.Printf("Listing Helm Releases of the namespace %s", params["namespace"]) +func listReleases(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { apps, err := proxy.ListReleases(params["namespace"]) if err != nil { - response.NewErrorResponse(http.StatusInternalServerError, err.Error()).Write(w) + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } response.NewDataResponse(apps).Write(w) } -func getRelease(w http.ResponseWriter, req *http.Request, params Params) { - log.Printf("Getting Helm Release %s", params["releaseName"]) +func getRelease(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { rel, err := proxy.GetRelease(params["releaseName"], params["namespace"]) if err != nil { - errCode := http.StatusInternalServerError - if isNotFound(err) { - errCode = http.StatusNotFound - } - response.NewErrorResponse(errCode, err.Error()).Write(w) + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } + if enableAuth { + manifest, err := proxy.ResolveManifest(params["namespace"], rel.Config.Raw, rel.Chart) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + err = user.CanI(params["namespace"], "get", manifest) + } response.NewDataResponse(*rel).Write(w) } -func deleteRelease(w http.ResponseWriter, req *http.Request, params Params) { - log.Printf("Deleting Helm Release %s", params["releaseName"]) +func deleteRelease(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { + if enableAuth { + rel, err := proxy.GetRelease(params["releaseName"], params["namespace"]) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + manifest, err := proxy.ResolveManifest(params["namespace"], rel.Config.Raw, rel.Chart) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + err = user.CanI(params["namespace"], "delete", manifest) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + } err := proxy.DeleteRelease(params["releaseName"], params["namespace"]) if err != nil { - errCode := http.StatusInternalServerError - if isNotFound(err) { - errCode = http.StatusNotFound - } - response.NewErrorResponse(errCode, err.Error()).Write(w) + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } w.Write([]byte("OK")) diff --git a/cmd/tiller-proxy/main.go b/cmd/tiller-proxy/main.go index 4f6a7f9f70f..991ad7f4f9e 100644 --- a/cmd/tiller-proxy/main.go +++ b/cmd/tiller-proxy/main.go @@ -19,7 +19,6 @@ package main import ( "net/http" "os" - "time" "github.com/gorilla/mux" "github.com/heptiolabs/healthcheck" @@ -28,20 +27,16 @@ import ( "github.com/urfave/negroni" "k8s.io/client-go/kubernetes" "k8s.io/client-go/rest" - "k8s.io/helm/pkg/chartutil" "k8s.io/helm/pkg/helm" "k8s.io/helm/pkg/helm/environment" - tillerProxy "github.com/kubeapps/kubeapps/pkg/utils/proxy" + tillerProxy "github.com/kubeapps/kubeapps/pkg/proxy" ) var ( - settings environment.EnvSettings - proxy *tillerProxy.Proxy -) - -const ( - defaultTimeoutSeconds = 180 + settings environment.EnvSettings + proxy *tillerProxy.Proxy + kubeClient kubernetes.Interface ) func init() { @@ -59,7 +54,7 @@ func main() { log.Fatalf("Unable to get cluter config: %v", err) } - kubeClient, err := kubernetes.NewForConfig(config) + kubeClient, err = kubernetes.NewForConfig(config) if err != nil { log.Fatalf("Unable to create a kubernetes client: %v", err) } @@ -71,11 +66,7 @@ func main() { log.Fatalf("Unable to connect to Tiller: %v", err) } - netClient := &http.Client{ - Timeout: time.Second * defaultTimeoutSeconds, - } - - proxy = tillerProxy.NewProxy(kubeClient, helmClient, netClient, chartutil.LoadArchive) + proxy = tillerProxy.NewProxy(kubeClient, helmClient) r := mux.NewRouter() @@ -86,12 +77,12 @@ func main() { // Routes apiv1 := r.PathPrefix("/v1").Subrouter() - apiv1.Methods("GET").Path("/releases").HandlerFunc(listAllReleases) - apiv1.Methods("GET").Path("/namespaces/{namespace}/releases").Handler(WithParams(listReleases)) - apiv1.Methods("POST").Path("/namespaces/{namespace}/releases").Handler(WithParams(deployRelease)) - apiv1.Methods("GET").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithParams(getRelease)) - apiv1.Methods("PUT").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithParams(deployRelease)) - apiv1.Methods("DELETE").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithParams(deleteRelease)) + apiv1.Methods("GET").Path("/releases").Handler(WithAuth(listAllReleases)) + apiv1.Methods("GET").Path("/namespaces/{namespace}/releases").Handler(WithAuth(listReleases)) + apiv1.Methods("POST").Path("/namespaces/{namespace}/releases").Handler(WithAuth(deployRelease)) + apiv1.Methods("GET").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithAuth(getRelease)) + apiv1.Methods("PUT").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithAuth(deployRelease)) + apiv1.Methods("DELETE").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithAuth(deleteRelease)) n := negroni.Classic() n.UseHandler(r) @@ -102,5 +93,8 @@ func main() { } addr := ":" + port log.WithFields(log.Fields{"addr": addr}).Info("Started Tiller Proxy") - http.ListenAndServe(addr, n) + err = http.ListenAndServe(addr, n) + if err != nil { + log.Fatalf("Unable to start the server: %v", err) + } } From aba1f3b32666a8e073b11e7f792f5171e40a6eb0 Mon Sep 17 00:00:00 2001 From: Andres Date: Fri, 15 Jun 2018 12:17:21 +0200 Subject: [PATCH 09/13] Chart utils update --- pkg/{utils => }/chart/chart.go | 103 +++++++++++++++- pkg/chart/chart_test.go | 207 +++++++++++++++++++++++++++++++++ pkg/utils/chart/chart_test.go | 91 --------------- 3 files changed, 304 insertions(+), 97 deletions(-) rename pkg/{utils => }/chart/chart.go (50%) create mode 100644 pkg/chart/chart_test.go delete mode 100644 pkg/utils/chart/chart_test.go diff --git a/pkg/utils/chart/chart.go b/pkg/chart/chart.go similarity index 50% rename from pkg/utils/chart/chart.go rename to pkg/chart/chart.go index a65e75318a4..ac99db37222 100644 --- a/pkg/utils/chart/chart.go +++ b/pkg/chart/chart.go @@ -18,18 +18,57 @@ package chart import ( "bytes" + "encoding/json" "fmt" "io" "io/ioutil" + "log" "net/http" "net/url" + "os" "strings" "github.com/ghodss/yaml" + corev1 "k8s.io/api/core/v1" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/client-go/kubernetes" "k8s.io/helm/pkg/proto/hapi/chart" "k8s.io/helm/pkg/repo" ) +const ( + defaultNamespace = metav1.NamespaceSystem + defaultRepoURL = "https://kubernetes-charts.storage.googleapis.com" +) + +// Details contains the information to retrieve a Chart +type Details struct { + // RepoURL is the URL of the repository. Defaults to stable repo. + RepoURL string `json:"repoUrl,omitempty"` + // ChartName is the name of the chart within the repo. + ChartName string `json:"chartName"` + // ReleaseName is the Name of the release given to Tiller. + ReleaseName string `json:"releaseName"` + // Version is the chart version. + Version string `json:"version"` + // Auth is the authentication. + Auth Auth `json:"auth,omitempty"` + // Values is a string containing (unparsed) YAML values. + Values string `json:"values,omitempty"` +} + +// Auth contains the information to authenticate against a private registry +type Auth struct { + // Header is header based Authorization + Header *AuthHeader `json:"header,omitempty"` +} + +// AuthHeader contains the secret information for authenticate +type AuthHeader struct { + // Selects a key of a secret in the pod's namespace + SecretKeyRef corev1.SecretKeySelector `json:"secretKeyRef,omitempty"` +} + // HTTPClient Interface to perform HTTP requests type HTTPClient interface { Do(req *http.Request) (*http.Response, error) @@ -78,8 +117,8 @@ func parseIndex(data []byte) (*repo.IndexFile, error) { return index, nil } -// FetchRepoIndex returns a Helm repository -func FetchRepoIndex(netClient *HTTPClient, repoURL string, authHeader string) (*repo.IndexFile, error) { +// fetchRepoIndex returns a Helm repository +func fetchRepoIndex(netClient *HTTPClient, repoURL string, authHeader string) (*repo.IndexFile, error) { req, err := getReq(repoURL, authHeader) if err != nil { return nil, err @@ -109,8 +148,8 @@ func resolveChartURL(index, chart string) (string, error) { return chartURL.String(), nil } -// FindChartInRepoIndex returns the URL of a chart given a Helm repository and its name and version -func FindChartInRepoIndex(repoIndex *repo.IndexFile, repoURL, chartName, chartVersion string) (string, error) { +// findChartInRepoIndex returns the URL of a chart given a Helm repository and its name and version +func findChartInRepoIndex(repoIndex *repo.IndexFile, repoURL, chartName, chartVersion string) (string, error) { errMsg := fmt.Sprintf("chart %q", chartName) if chartVersion != "" { errMsg = fmt.Sprintf("%s version %q", errMsg, chartVersion) @@ -128,8 +167,8 @@ func FindChartInRepoIndex(repoIndex *repo.IndexFile, repoURL, chartName, chartVe // LoadChart should return a Chart struct from an IOReader type LoadChart func(in io.Reader) (*chart.Chart, error) -// FetchChart returns the Chart content given an URL and the auth header if needed -func FetchChart(netClient *HTTPClient, chartURL, authHeader string, load LoadChart) (*chart.Chart, error) { +// fetchChart returns the Chart content given an URL and the auth header if needed +func fetchChart(netClient *HTTPClient, chartURL, authHeader string, load LoadChart) (*chart.Chart, error) { req, err := getReq(chartURL, authHeader) if err != nil { return nil, err @@ -145,3 +184,55 @@ func FetchChart(netClient *HTTPClient, chartURL, authHeader string, load LoadCha } return load(bytes.NewReader(data)) } + +// ParseDetails return Chart details +func ParseDetails(data []byte) (*Details, error) { + details := &Details{} + err := json.Unmarshal(data, details) + if err != nil { + return nil, fmt.Errorf("Unable to parse request body: %v", err) + } + return details, nil +} + +// GetChart retrieves and loads a Chart from a registry +func GetChart(details *Details, kubeClient kubernetes.Interface, netClient HTTPClient, load LoadChart) (*chart.Chart, error) { + repoURL := details.RepoURL + if repoURL == "" { + // FIXME: Make configurable + repoURL = defaultRepoURL + } + repoURL = strings.TrimSuffix(strings.TrimSpace(repoURL), "/") + "/index.yaml" + + authHeader := "" + if details.Auth.Header != nil { + namespace := os.Getenv("POD_NAMESPACE") + if namespace == "" { + namespace = defaultNamespace + } + + secret, err := kubeClient.Core().Secrets(namespace).Get(details.Auth.Header.SecretKeyRef.Name, metav1.GetOptions{}) + if err != nil { + return nil, err + } + authHeader = string(secret.Data[details.Auth.Header.SecretKeyRef.Key]) + } + + log.Printf("Downloading repo %s index...", repoURL) + repoIndex, err := fetchRepoIndex(&netClient, repoURL, authHeader) + if err != nil { + return nil, err + } + + chartURL, err := findChartInRepoIndex(repoIndex, repoURL, details.ChartName, details.Version) + if err != nil { + return nil, err + } + + log.Printf("Downloading %s ...", chartURL) + chartRequested, err := fetchChart(&netClient, chartURL, authHeader, load) + if err != nil { + return nil, err + } + return chartRequested, nil +} diff --git a/pkg/chart/chart_test.go b/pkg/chart/chart_test.go new file mode 100644 index 00000000000..45bae54e836 --- /dev/null +++ b/pkg/chart/chart_test.go @@ -0,0 +1,207 @@ +/* +Copyright (c) 2018 Bitnami + +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 chart + +import ( + "bytes" + "encoding/json" + "fmt" + "io" + "io/ioutil" + "net/http" + "reflect" + "testing" + "time" + + "github.com/arschles/assert" + corev1 "k8s.io/api/core/v1" + "k8s.io/client-go/kubernetes/fake" + "k8s.io/helm/pkg/proto/hapi/chart" + "k8s.io/helm/pkg/repo" +) + +func Test_resolveChartURL(t *testing.T) { + tests := []struct { + name string + baseURL string + chartURL string + wantedURL string + }{ + { + "absolute url", + "http://www.google.com", + "http://charts.example.com/repo/wordpress-0.1.0.tgz", + "http://charts.example.com/repo/wordpress-0.1.0.tgz", + }, + { + "relative, repo url", + "http://charts.example.com/repo/", + "wordpress-0.1.0.tgz", + "http://charts.example.com/repo/wordpress-0.1.0.tgz", + }, + { + "relative, repo index url", + "http://charts.example.com/repo/index.yaml", + "wordpress-0.1.0.tgz", + "http://charts.example.com/repo/wordpress-0.1.0.tgz", + }, + { + "relative, repo url - no trailing slash", + "http://charts.example.com/repo", + "wordpress-0.1.0.tgz", + "http://charts.example.com/wordpress-0.1.0.tgz", + }, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + chartURL, err := resolveChartURL(tt.baseURL, tt.chartURL) + assert.NoErr(t, err) + assert.Equal(t, chartURL, tt.wantedURL, "url") + }) + } +} + +func TestFindChartInRepoIndex(t *testing.T) { + name := "foo" + version := "v1.0.0" + chartURL := "wordpress-0.1.0.tgz" + repoURL := "http://charts.example.com/repo/" + expectedURL := fmt.Sprintf("%s%s", repoURL, chartURL) + + chartMeta := chart.Metadata{Name: name, Version: version} + chartVersion := repo.ChartVersion{URLs: []string{chartURL}} + chartVersion.Metadata = &chartMeta + chartVersions := []*repo.ChartVersion{&chartVersion} + entries := map[string]repo.ChartVersions{} + entries[name] = chartVersions + index := &repo.IndexFile{APIVersion: "v1", Generated: time.Now(), Entries: entries} + + res, err := findChartInRepoIndex(index, repoURL, name, version) + if err != nil { + t.Errorf("Unexpected error %v", err) + } + if res != expectedURL { + t.Errorf("Expecting %s to be resolved as %s", res, expectedURL) + } +} + +func TestParseDetails(t *testing.T) { + data := `{ + "repoUrl": "foo.com", + "chartName": "test", + "releaseName": "foo", + "version": "1.0.0", + "values": "foo: bar", + "auth": { + "header": { + "secretKeyRef": { + "key": "bar" + } + } + } + }` + expectedDetails := Details{ + RepoURL: "foo.com", + ChartName: "test", + ReleaseName: "foo", + Version: "1.0.0", + Values: "foo: bar", + Auth: Auth{ + Header: &AuthHeader{ + SecretKeyRef: corev1.SecretKeySelector{ + Key: "bar", + }, + }, + }, + } + details, err := ParseDetails([]byte(data)) + if err != nil { + t.Fatalf("Unexpected error: %v", err) + } + if !reflect.DeepEqual(expectedDetails, *details) { + t.Errorf("%v != %v", expectedDetails, *details) + } +} + +// Fake server for repositories and charts +type fakeHTTPClient struct { + repoURLs []string + chartURLs []string + index *repo.IndexFile +} + +func (f *fakeHTTPClient) Do(h *http.Request) (*http.Response, error) { + for _, repoURL := range f.repoURLs { + if h.URL.String() == fmt.Sprintf("%sindex.yaml", repoURL) { + // Return fake chart index (not customizable per repo) + body, err := json.Marshal(*f.index) + if err != nil { + fmt.Printf("Error! %v", err) + } + return &http.Response{StatusCode: 200, Body: ioutil.NopCloser(bytes.NewReader(body))}, nil + } + } + for _, chartURL := range f.chartURLs { + if h.URL.String() == chartURL { + // Simulate download time + time.Sleep(100 * time.Millisecond) + // Fake chart response + return &http.Response{StatusCode: 200, Body: ioutil.NopCloser(bytes.NewReader([]byte{}))}, nil + } + } + // Unexpected path + return &http.Response{StatusCode: 404}, fmt.Errorf("Unexpected path") +} + +func fakeLoadChart(in io.Reader) (*chart.Chart, error) { + return &chart.Chart{}, nil +} + +func newHTTPClient(charts []Details) fakeHTTPClient { + var repoURLs []string + var chartURLs []string + entries := map[string]repo.ChartVersions{} + // Populate Chart registry with content of the given helmReleases + for _, ch := range charts { + repoURLs = append(repoURLs, ch.RepoURL) + chartMeta := chart.Metadata{Name: ch.ChartName, Version: ch.Version} + chartURL := fmt.Sprintf("%s%s-%s.tgz", ch.RepoURL, ch.ChartName, ch.Version) + chartURLs = append(chartURLs, chartURL) + chartVersion := repo.ChartVersion{Metadata: &chartMeta, URLs: []string{chartURL}} + chartVersions := []*repo.ChartVersion{&chartVersion} + entries[ch.ChartName] = chartVersions + } + index := &repo.IndexFile{APIVersion: "v1", Generated: time.Now(), Entries: entries} + return fakeHTTPClient{repoURLs, chartURLs, index} +} + +func TestGetChart(t *testing.T) { + target := Details{ + RepoURL: "http://foo.com/", + ChartName: "test", + ReleaseName: "foo", + Version: "1.0.0", + } + httpClient := newHTTPClient([]Details{target}) + kubeClient := fake.NewSimpleClientset() + ch, err := GetChart(&target, kubeClient, &httpClient, fakeLoadChart) + if err != nil { + t.Errorf("Unexpected error: %v", err) + } + if ch == nil { + t.Errorf("It should return a Chart") + } +} diff --git a/pkg/utils/chart/chart_test.go b/pkg/utils/chart/chart_test.go deleted file mode 100644 index 5c331a272c8..00000000000 --- a/pkg/utils/chart/chart_test.go +++ /dev/null @@ -1,91 +0,0 @@ -/* -Copyright (c) 2018 Bitnami - -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 chart - -import ( - "fmt" - "testing" - "time" - - "github.com/arschles/assert" - "k8s.io/helm/pkg/proto/hapi/chart" - "k8s.io/helm/pkg/repo" -) - -func Test_resolveChartURL(t *testing.T) { - tests := []struct { - name string - baseURL string - chartURL string - wantedURL string - }{ - { - "absolute url", - "http://www.google.com", - "http://charts.example.com/repo/wordpress-0.1.0.tgz", - "http://charts.example.com/repo/wordpress-0.1.0.tgz", - }, - { - "relative, repo url", - "http://charts.example.com/repo/", - "wordpress-0.1.0.tgz", - "http://charts.example.com/repo/wordpress-0.1.0.tgz", - }, - { - "relative, repo index url", - "http://charts.example.com/repo/index.yaml", - "wordpress-0.1.0.tgz", - "http://charts.example.com/repo/wordpress-0.1.0.tgz", - }, - { - "relative, repo url - no trailing slash", - "http://charts.example.com/repo", - "wordpress-0.1.0.tgz", - "http://charts.example.com/wordpress-0.1.0.tgz", - }, - } - for _, tt := range tests { - t.Run(tt.name, func(t *testing.T) { - chartURL, err := resolveChartURL(tt.baseURL, tt.chartURL) - assert.NoErr(t, err) - assert.Equal(t, chartURL, tt.wantedURL, "url") - }) - } -} - -func TestFindChartInRepoIndex(t *testing.T) { - name := "foo" - version := "v1.0.0" - chartURL := "wordpress-0.1.0.tgz" - repoURL := "http://charts.example.com/repo/" - expectedURL := fmt.Sprintf("%s%s", repoURL, chartURL) - - chartMeta := chart.Metadata{Name: name, Version: version} - chartVersion := repo.ChartVersion{URLs: []string{chartURL}} - chartVersion.Metadata = &chartMeta - chartVersions := []*repo.ChartVersion{&chartVersion} - entries := map[string]repo.ChartVersions{} - entries[name] = chartVersions - index := &repo.IndexFile{APIVersion: "v1", Generated: time.Now(), Entries: entries} - - res, err := FindChartInRepoIndex(index, repoURL, name, version) - if err != nil { - t.Errorf("Unexpected error %v", err) - } - if res != expectedURL { - t.Errorf("Expecting %s to be resolved as %s", res, expectedURL) - } -} From 3a970de8fbdddda6c4d401bbb5c3ccb55c825fe6 Mon Sep 17 00:00:00 2001 From: Andres Date: Fri, 15 Jun 2018 12:21:24 +0200 Subject: [PATCH 10/13] Update proxy pkg --- pkg/{utils => }/proxy/proxy.go | 209 ++++++++-------------------- pkg/{utils => }/proxy/proxy_test.go | 200 +++++++++++--------------- 2 files changed, 138 insertions(+), 271 deletions(-) rename pkg/{utils => }/proxy/proxy.go (50%) rename pkg/{utils => }/proxy/proxy_test.go (58%) diff --git a/pkg/utils/proxy/proxy.go b/pkg/proxy/proxy.go similarity index 50% rename from pkg/utils/proxy/proxy.go rename to pkg/proxy/proxy.go index 60956dd84dc..8236e56aa36 100644 --- a/pkg/utils/proxy/proxy.go +++ b/pkg/proxy/proxy.go @@ -17,69 +17,45 @@ limitations under the License. package proxy import ( - "encoding/json" "fmt" - "os" "strings" "sync" log "github.com/sirupsen/logrus" "google.golang.org/grpc" - corev1 "k8s.io/api/core/v1" - metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/client-go/kubernetes" "k8s.io/helm/pkg/helm" "k8s.io/helm/pkg/proto/hapi/chart" "k8s.io/helm/pkg/proto/hapi/release" - - chartUtils "github.com/kubeapps/kubeapps/pkg/utils/chart" ) const ( - defaultNamespace = metav1.NamespaceSystem - defaultRepoURL = "https://kubernetes-charts.storage.googleapis.com" defaultTimeoutSeconds = 180 ) var ( - appMutex map[string]*sync.Mutex + appMutex map[string]*sync.Mutex + releaseStatuses []release.Status_Code ) func init() { appMutex = make(map[string]*sync.Mutex) + releaseStatuses = []release.Status_Code{ + release.Status_UNKNOWN, + release.Status_DEPLOYED, + release.Status_DELETED, + release.Status_DELETING, + release.Status_FAILED, + release.Status_PENDING_INSTALL, + release.Status_PENDING_UPGRADE, + release.Status_PENDING_ROLLBACK, + } } // Proxy contains all the elements to contact Tiller and the K8s API type Proxy struct { kubeClient kubernetes.Interface helmClient helm.Interface - netClient *chartUtils.HTTPClient - loadChart chartUtils.LoadChart -} - -type helmRelease struct { - // RepoURL is the URL of the repository. Defaults to stable repo. - RepoURL string `json:"repoUrl,omitempty"` - // ChartName is the name of the chart within the repo. - ChartName string `json:"chartName"` - // ReleaseName is the Name of the release given to Tiller. - ReleaseName string `json:"releaseName"` - // Version is the chart version. - Version string `json:"version"` - // Auth is the authentication. - Auth helmReleaseAuth `json:"auth,omitempty"` - // Values is a string containing (unparsed) YAML values. - Values string `json:"values,omitempty"` -} - -type helmReleaseAuth struct { - // Header is header based Authorization - Header *helmReleaseAuthHeader `json:"header,omitempty"` -} - -type helmReleaseAuthHeader struct { - // Selects a key of a secret in the pod's namespace - SecretKeyRef corev1.SecretKeySelector `json:"secretKeyRef,omitempty"` } func isNotFound(err error) bool { @@ -89,12 +65,10 @@ func isNotFound(err error) bool { } // NewProxy creates a Proxy -func NewProxy(kubeClient kubernetes.Interface, helmClient helm.Interface, netClient chartUtils.HTTPClient, loadChart chartUtils.LoadChart) *Proxy { +func NewProxy(kubeClient kubernetes.Interface, helmClient helm.Interface) *Proxy { return &Proxy{ kubeClient: kubeClient, helmClient: helmClient, - netClient: &netClient, - loadChart: loadChart, } } @@ -105,49 +79,8 @@ type AppOverview struct { Namespace string `json:"namespace"` } -func (p *Proxy) getChart(rel *helmRelease) (*chart.Chart, error) { - repoURL := rel.RepoURL - if repoURL == "" { - // FIXME: Make configurable - repoURL = defaultRepoURL - } - repoURL = strings.TrimSuffix(strings.TrimSpace(repoURL), "/") + "/index.yaml" - - authHeader := "" - if rel.Auth.Header != nil { - namespace := os.Getenv("POD_NAMESPACE") - if namespace == "" { - namespace = defaultNamespace - } - - secret, err := p.kubeClient.Core().Secrets(namespace).Get(rel.Auth.Header.SecretKeyRef.Name, metav1.GetOptions{}) - if err != nil { - return nil, err - } - authHeader = string(secret.Data[rel.Auth.Header.SecretKeyRef.Key]) - } - - log.Printf("Downloading repo %s index...", repoURL) - repoIndex, err := chartUtils.FetchRepoIndex(p.netClient, repoURL, authHeader) - if err != nil { - return nil, err - } - - chartURL, err := chartUtils.FindChartInRepoIndex(repoIndex, repoURL, rel.ChartName, rel.Version) - if err != nil { - return nil, err - } - - log.Printf("Downloading %s ...", chartURL) - chartRequested, err := chartUtils.FetchChart(p.netClient, chartURL, authHeader, p.loadChart) - if err != nil { - return nil, err - } - return chartRequested, nil -} - func (p *Proxy) get(name, namespace string) (*release.Release, error) { - list, err := p.helmClient.ListReleases() + list, err := p.helmClient.ListReleases(helm.ReleaseListStatuses(releaseStatuses)) if err != nil { return nil, fmt.Errorf("Unable to list helm releases: %v", err) } @@ -164,49 +97,39 @@ func (p *Proxy) get(name, namespace string) (*release.Release, error) { return rel, nil } -func (p *Proxy) deploy(name, namespace, values string, ch *chart.Chart) (*release.Release, error) { - log.Printf("Installing release %s into namespace %s", name, namespace) - res, err := p.helmClient.InstallReleaseFromChart( - ch, - namespace, - helm.ValueOverrides([]byte(values)), - helm.ReleaseName(name), - ) - if err != nil { - return nil, err +// GetReleaseStatus prints the status of the given release if exists +func (p *Proxy) GetReleaseStatus(relName string) (release.Status_Code, error) { + status, err := p.helmClient.ReleaseStatus(relName) + if err == nil { + if status.Info != nil && status.Info.Status != nil { + return status.Info.Status.Code, nil + } } - return res.GetRelease(), nil + return release.Status_Code(0), fmt.Errorf("Unable to fetch release status for %s: %v", relName, err) } -func (p *Proxy) update(name, namespace, values string, ch *chart.Chart) (*release.Release, error) { - log.Printf("Updating release %s", name) - res, err := p.helmClient.UpdateReleaseFromChart( - name, +// ResolveManifest returns a manifest given the chart parameters +func (p *Proxy) ResolveManifest(namespace, values string, ch *chart.Chart) (string, error) { + // We use the release returned after running a dry-run to know the elements to install + resDry, err := p.helmClient.InstallReleaseFromChart( ch, - helm.UpdateValueOverrides([]byte(values)), - //helm.UpgradeForce(true), ? + namespace, + helm.ValueOverrides([]byte(values)), + helm.ReleaseName(""), + helm.InstallDryRun(true), ) if err != nil { - return nil, err - } - return res.GetRelease(), nil -} - -// LogReleaseStatus prints the status of the given release if exists -func (p *Proxy) LogReleaseStatus(relName string) { - status, err := p.helmClient.ReleaseStatus(relName) - if err == nil { - if status.Info != nil && status.Info.Status != nil { - log.Printf("Release status: %s", status.Info.Status.Code) - } - } else { - log.Printf("Unable to fetch release status for %s: %v", relName, err) + return "", err } + // The manifest returned has some extra new lines at the beginning + return strings.TrimLeft(resDry.Release.Manifest, "\n"), nil } // ListReleases list releases in a specific namespace if given func (p *Proxy) ListReleases(namespace string) ([]AppOverview, error) { - list, err := p.helmClient.ListReleases() + list, err := p.helmClient.ListReleases( + helm.ReleaseListStatuses(releaseStatuses), + ) if err != nil { return []AppOverview{}, fmt.Errorf("Unable to list helm releases: %v", err) } @@ -231,58 +154,44 @@ func unlock(name string) { } // CreateRelease creates a tiller release -func (p *Proxy) CreateRelease(namespace string, rawRelease []byte) (*release.Release, error) { - hrelease := &helmRelease{} - err := json.Unmarshal(rawRelease, hrelease) - if err != nil { - return nil, fmt.Errorf("Unable to parse request body: %v", err) - } - lock(hrelease.ReleaseName) - defer unlock(hrelease.ReleaseName) - ch, err := p.getChart(hrelease) - if err != nil { - return nil, fmt.Errorf("Unable to retrieve chart info: %v", err) - } - if err != nil { - return nil, err - } - rel, err := p.deploy(hrelease.ReleaseName, namespace, hrelease.Values, ch) +func (p *Proxy) CreateRelease(name, namespace, values string, ch *chart.Chart) (*release.Release, error) { + lock(name) + defer unlock(name) + log.Printf("Installing release %s into namespace %s", name, namespace) + res, err := p.helmClient.InstallReleaseFromChart( + ch, + namespace, + helm.ValueOverrides([]byte(values)), + helm.ReleaseName(name), + ) if err != nil { return nil, fmt.Errorf("Unable create release: %v", err) } - return rel, nil + return res.GetRelease(), nil } // UpdateRelease upgrades a tiller release -func (p *Proxy) UpdateRelease(name, namespace string, rawRelease []byte) (*release.Release, error) { +func (p *Proxy) UpdateRelease(name, namespace string, values string, ch *chart.Chart) (*release.Release, error) { lock(name) defer unlock(name) - var rel *release.Release // Check if the release already exists _, err := p.get(name, namespace) if err != nil && isNotFound(err) { return nil, fmt.Errorf("Release %s not found in the namespace %s. Unable to update it", name, namespace) } else if err != nil { return nil, err - } else { - hrelease := &helmRelease{} - err := json.Unmarshal(rawRelease, hrelease) - if err != nil { - return nil, fmt.Errorf("Unable to parse request body: %v", err) - } - ch, err := p.getChart(hrelease) - if err != nil { - return nil, fmt.Errorf("Unable to retrieve chart info: %v", err) - } - if err != nil { - return nil, err - } - rel, err = p.update(hrelease.ReleaseName, namespace, hrelease.Values, ch) - if err != nil { - return nil, fmt.Errorf("Unable to update release: %v", err) - } } - return rel, nil + log.Printf("Updating release %s", name) + res, err := p.helmClient.UpdateReleaseFromChart( + name, + ch, + helm.UpdateValueOverrides([]byte(values)), + //helm.UpgradeForce(true), ? + ) + if err != nil { + return nil, fmt.Errorf("Unable to update release: %v", err) + } + return res.GetRelease(), nil } // GetRelease returns the info of a release diff --git a/pkg/utils/proxy/proxy_test.go b/pkg/proxy/proxy_test.go similarity index 58% rename from pkg/utils/proxy/proxy_test.go rename to pkg/proxy/proxy_test.go index eac17dc773e..51d1917b359 100644 --- a/pkg/utils/proxy/proxy_test.go +++ b/pkg/proxy/proxy_test.go @@ -17,12 +17,6 @@ limitations under the License. package proxy import ( - "bytes" - "encoding/json" - "fmt" - "io" - "io/ioutil" - "net/http" "reflect" "strings" "testing" @@ -32,61 +26,9 @@ import ( "k8s.io/helm/pkg/helm" "k8s.io/helm/pkg/proto/hapi/chart" "k8s.io/helm/pkg/proto/hapi/release" - "k8s.io/helm/pkg/repo" ) -// Fake server for repositories and charts -type fakeHTTPClient struct { - repoURLs []string - chartURLs []string - index *repo.IndexFile -} - -func (f *fakeHTTPClient) Do(h *http.Request) (*http.Response, error) { - for _, repoURL := range f.repoURLs { - if h.URL.String() == fmt.Sprintf("%sindex.yaml", repoURL) { - // Return fake chart index (not customizable per repo) - body, err := json.Marshal(*f.index) - if err != nil { - fmt.Printf("Error! %v", err) - } - return &http.Response{StatusCode: 200, Body: ioutil.NopCloser(bytes.NewReader(body))}, nil - } - } - for _, chartURL := range f.chartURLs { - if h.URL.String() == chartURL { - // Simulate download time - time.Sleep(100 * time.Millisecond) - // Fake chart response - return &http.Response{StatusCode: 200, Body: ioutil.NopCloser(bytes.NewReader([]byte{}))}, nil - } - } - // Unexpected path - return &http.Response{StatusCode: 404}, fmt.Errorf("Unexpected path") -} - -func fakeLoadChart(in io.Reader) (*chart.Chart, error) { - // Fake I/O time - time.Sleep(100 * time.Millisecond) - return &chart.Chart{}, nil -} - -func newFakeProxy(hrs []helmRelease, existingTillerReleases []AppOverview) *Proxy { - var repoURLs []string - var chartURLs []string - entries := map[string]repo.ChartVersions{} - // Populate Chart registry with content of the given helmReleases - for _, hr := range hrs { - repoURLs = append(repoURLs, hr.RepoURL) - chartMeta := chart.Metadata{Name: hr.ChartName, Version: hr.Version} - chartURL := fmt.Sprintf("%s%s-%s.tgz", hr.RepoURL, hr.ChartName, hr.Version) - chartURLs = append(chartURLs, chartURL) - chartVersion := repo.ChartVersion{Metadata: &chartMeta, URLs: []string{chartURL}} - chartVersions := []*repo.ChartVersion{&chartVersion} - entries[hr.ChartName] = chartVersions - } - index := &repo.IndexFile{APIVersion: "v1", Generated: time.Now(), Entries: entries} - netClient := fakeHTTPClient{repoURLs, chartURLs, index} +func newFakeProxy(existingTillerReleases []AppOverview) *Proxy { helmClient := helm.FakeClient{} // Populate Fake helm client with releases for _, r := range existingTillerReleases { @@ -101,13 +43,13 @@ func newFakeProxy(hrs []helmRelease, existingTillerReleases []AppOverview) *Prox }) } kubeClient := fake.NewSimpleClientset() - return NewProxy(kubeClient, &helmClient, &netClient, fakeLoadChart) + return NewProxy(kubeClient, &helmClient) } func TestListAllReleases(t *testing.T) { app1 := AppOverview{"foo", "1.0.0", "my_ns"} app2 := AppOverview{"bar", "1.0.0", "other_ns"} - proxy := newFakeProxy([]helmRelease{}, []AppOverview{app1, app2}) + proxy := newFakeProxy([]AppOverview{app1, app2}) // Should return all the releases if no namespace is given releases, err := proxy.ListReleases("") @@ -125,7 +67,7 @@ func TestListAllReleases(t *testing.T) { func TestListNamespacedRelease(t *testing.T) { app1 := AppOverview{"foo", "1.0.0", "my_ns"} app2 := AppOverview{"bar", "1.0.0", "other_ns"} - proxy := newFakeProxy([]helmRelease{}, []AppOverview{app1, app2}) + proxy := newFakeProxy([]AppOverview{app1, app2}) // Should return all the releases if no namespace is given releases, err := proxy.ListReleases(app1.Namespace) @@ -140,23 +82,43 @@ func TestListNamespacedRelease(t *testing.T) { } } +func TestResolveManifest(t *testing.T) { + ns := "myns" + chartName := "bar" + version := "v1.0.0" + ch := &chart.Chart{ + Metadata: &chart.Metadata{Name: chartName, Version: version}, + } + proxy := newFakeProxy([]AppOverview{}) + + manifest, err := proxy.ResolveManifest(ns, "", ch) + if err != nil { + t.Fatalf("Unexpected error %v", err) + } + if !strings.Contains(manifest, "apiVersion") || !strings.Contains(manifest, "kind") { + t.Errorf("%s doesn't contain a manifest", manifest) + } + if strings.HasPrefix(manifest, "\n") { + t.Error("The manifest should not contain new lines at the beginning") + } +} + func TestCreateHelmRelease(t *testing.T) { ns := "myns" - h := helmRelease{ - ReleaseName: "not-foo", - RepoURL: "http://charts.example.com/repo/", - ChartName: "foo", - Version: "v1.0.0", - } - rawRelease, _ := json.Marshal(h) - proxy := newFakeProxy([]helmRelease{h}, []AppOverview{}) + rs := "foo" + chartName := "bar" + version := "v1.0.0" + ch := &chart.Chart{ + Metadata: &chart.Metadata{Name: chartName, Version: version}, + } + proxy := newFakeProxy([]AppOverview{}) - result, err := proxy.CreateRelease(ns, rawRelease) + result, err := proxy.CreateRelease(rs, ns, "", ch) if err != nil { t.Errorf("Unexpected error %v", err) } - if result.Name != h.ReleaseName { - t.Errorf("Expected release named %s received %s", h.ReleaseName, result.Name) + if result.Name != rs { + t.Errorf("Expected release named %s received %s", rs, result.Name) } if result.Namespace != ns { t.Errorf("Expected release in namespace %s received %s", ns, result.Namespace) @@ -166,19 +128,18 @@ func TestCreateHelmRelease(t *testing.T) { } func TestCreateConflictingHelmRelease(t *testing.T) { - ns1 := "myns" - h := helmRelease{ - ReleaseName: "not-foo", - RepoURL: "http://charts.example.com/repo/", - ChartName: "foo", - Version: "v1.0.0", + ns := "myns" + rs := "foo" + chartName := "bar" + version := "v1.0.0" + ch := &chart.Chart{ + Metadata: &chart.Metadata{Name: chartName, Version: version}, } ns2 := "other_ns" - app := AppOverview{h.ReleaseName, h.Version, ns2} - rawRelease, _ := json.Marshal(h) - proxy := newFakeProxy([]helmRelease{h}, []AppOverview{app}) + app := AppOverview{rs, version, ns2} + proxy := newFakeProxy([]AppOverview{app}) - _, err := proxy.CreateRelease(ns1, rawRelease) + _, err := proxy.CreateRelease(rs, ns, "", ch) if err == nil { t.Error("Release should fail, an existing release in a different namespace already exists") } @@ -189,22 +150,21 @@ func TestCreateConflictingHelmRelease(t *testing.T) { func TestHelmReleaseUpdated(t *testing.T) { ns := "myns" - h := helmRelease{ - ReleaseName: "not-foo", - RepoURL: "http://charts.example.com/repo/", - ChartName: "foo", - Version: "v1.0.0", - } - rawRelease, _ := json.Marshal(h) - app := AppOverview{h.ReleaseName, h.Version, ns} - proxy := newFakeProxy([]helmRelease{h}, []AppOverview{app}) + rs := "foo" + chartName := "bar" + version := "v1.0.0" + ch := &chart.Chart{ + Metadata: &chart.Metadata{Name: chartName, Version: version}, + } + app := AppOverview{rs, version, ns} + proxy := newFakeProxy([]AppOverview{app}) - result, err := proxy.UpdateRelease(h.ReleaseName, ns, rawRelease) + result, err := proxy.UpdateRelease(rs, ns, "", ch) if err != nil { t.Errorf("Unexpected error %v", err) } - if result.Name != h.ReleaseName { - t.Errorf("Expected release named %s received %s", h.ReleaseName, result.Name) + if result.Name != rs { + t.Errorf("Expected release named %s received %s", rs, result.Name) } if result.Namespace != ns { t.Errorf("Expected release in namespace %s received %s", ns, result.Namespace) @@ -222,19 +182,18 @@ func TestHelmReleaseUpdated(t *testing.T) { func TestUpdateMissingHelmRelease(t *testing.T) { ns := "myns" - h := helmRelease{ - ReleaseName: "not-foo", - RepoURL: "http://charts.example.com/repo/", - ChartName: "foo", - Version: "v1.0.0", + rs := "foo" + chartName := "bar" + version := "v1.0.0" + ch := &chart.Chart{ + Metadata: &chart.Metadata{Name: chartName, Version: version}, } - rawRelease, _ := json.Marshal(h) // Simulate the same app but in a different namespace ns2 := "other_ns" - app := AppOverview{h.ReleaseName, h.Version, ns2} - proxy := newFakeProxy([]helmRelease{h}, []AppOverview{app}) + app := AppOverview{rs, version, ns2} + proxy := newFakeProxy([]AppOverview{app}) - _, err := proxy.UpdateRelease(h.ReleaseName, ns, rawRelease) + _, err := proxy.UpdateRelease(rs, ns, "", ch) if err == nil { t.Error("Update should fail, there is not a release in the namespace specified") } @@ -260,7 +219,7 @@ func TestGetHelmRelease(t *testing.T) { {[]AppOverview{app1, app2}, false, "foo", "", "foo"}, } for _, test := range tests { - proxy := newFakeProxy([]helmRelease{}, test.existingApps) + proxy := newFakeProxy(test.existingApps) res, err := proxy.GetRelease(test.targetApp, test.tartegNamespace) if test.shouldFail && err == nil { t.Errorf("Get %s/%s should fail", test.tartegNamespace, test.targetApp) @@ -278,7 +237,7 @@ func TestGetHelmRelease(t *testing.T) { func TestHelmReleaseDeleted(t *testing.T) { app := AppOverview{"foo", "1.0.0", "my_ns"} - proxy := newFakeProxy([]helmRelease{}, []AppOverview{app}) + proxy := newFakeProxy([]AppOverview{app}) err := proxy.DeleteRelease(app.ReleaseName, app.Namespace) if err != nil { @@ -295,7 +254,7 @@ func TestHelmReleaseDeleted(t *testing.T) { func TestDeleteMissingHelmRelease(t *testing.T) { app := AppOverview{"foo", "1.0.0", "my_ns"} - proxy := newFakeProxy([]helmRelease{}, []AppOverview{app}) + proxy := newFakeProxy([]AppOverview{app}) err := proxy.DeleteRelease(app.ReleaseName, "other_ns") if err == nil { @@ -312,42 +271,41 @@ func TestDeleteMissingHelmRelease(t *testing.T) { func TestEnsureThreadSafety(t *testing.T) { ns := "myns" - h := helmRelease{ - ReleaseName: "not-foo", - RepoURL: "http://charts.example.com/repo/", - ChartName: "foo", - Version: "v1.0.0", - } - rawRelease, _ := json.Marshal(h) - proxy := newFakeProxy([]helmRelease{h}, []AppOverview{}) + rs := "foo" + chartName := "bar" + version := "v1.0.0" + ch := &chart.Chart{ + Metadata: &chart.Metadata{Name: chartName, Version: version}, + } + proxy := newFakeProxy([]AppOverview{}) finish := make(chan struct{}) type test func() phases := []test{ func() { // Create first element - result, err := proxy.CreateRelease(ns, rawRelease) + result, err := proxy.CreateRelease(rs, ns, "", ch) if err != nil { t.Errorf("Unexpected error %v", err) } - if result.Name != h.ReleaseName { - t.Errorf("Expected release named %s received %s", h.ReleaseName, result.Name) + if result.Name != rs { + t.Errorf("Expected release named %s received %s", rs, result.Name) } }, func() { // Try to create it again - _, err := proxy.CreateRelease(ns, rawRelease) + _, err := proxy.CreateRelease(rs, ns, "", ch) if err == nil { t.Errorf("Should fail with 'already exists'") } }, func() { - _, err := proxy.UpdateRelease(h.ReleaseName, ns, rawRelease) + _, err := proxy.UpdateRelease(rs, ns, "", ch) if err != nil { t.Errorf("Unexpected error %v", err) } }, func() { - err := proxy.DeleteRelease(h.ReleaseName, ns) + err := proxy.DeleteRelease(rs, ns) if err != nil { t.Errorf("Unexpected error %v", err) } From 6d2dc61cb920477f65c2a61a9bd53b5c14a6a548 Mon Sep 17 00:00:00 2001 From: Andres Date: Mon, 18 Jun 2018 12:40:05 +0200 Subject: [PATCH 11/13] Add auth functionality --- cmd/kubeapps/down.go | 4 +- cmd/kubeapps/root.go | 34 -------- cmd/kubeapps/root_test.go | 39 --------- cmd/kubeapps/up.go | 6 +- pkg/auth/auth.go | 171 ++++++++++++++++++++++++++++++++++++++ pkg/auth/auth_test.go | 84 +++++++++++++++++++ pkg/yaml/yaml.go | 57 +++++++++++++ pkg/yaml/yaml_test.go | 60 +++++++++++++ 8 files changed, 379 insertions(+), 76 deletions(-) create mode 100644 pkg/auth/auth.go create mode 100644 pkg/auth/auth_test.go create mode 100644 pkg/yaml/yaml.go create mode 100644 pkg/yaml/yaml_test.go diff --git a/cmd/kubeapps/down.go b/cmd/kubeapps/down.go index 5bfd5a539a0..3d2b9ef78fc 100644 --- a/cmd/kubeapps/down.go +++ b/cmd/kubeapps/down.go @@ -25,6 +25,8 @@ import ( k8sErrors "k8s.io/apimachinery/pkg/api/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/runtime/schema" + + yamlUtils "github.com/kubeapps/kubeapps/pkg/yaml" ) var downCmd = &cobra.Command{ @@ -65,7 +67,7 @@ var downCmd = &cobra.Command{ if err != nil { return fmt.Errorf("can't read kubeapps manifest: %v", err) } - objs, err := parseObjects(manifest) + objs, err := yamlUtils.ParseObjects(manifest) if err != nil { return fmt.Errorf("can't parse kubeapps manifest: %v", err) } diff --git a/cmd/kubeapps/root.go b/cmd/kubeapps/root.go index c117abd1f6c..8cd2f7d7741 100644 --- a/cmd/kubeapps/root.go +++ b/cmd/kubeapps/root.go @@ -17,24 +17,18 @@ limitations under the License. package kubeapps import ( - "bufio" "crypto/rand" "encoding/base64" "errors" "fmt" - "io" "os" "path/filepath" - "strings" "github.com/ksonnet/kubecfg/utils" "github.com/sirupsen/logrus" "github.com/spf13/cobra" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" - "k8s.io/apimachinery/pkg/runtime" "k8s.io/apimachinery/pkg/runtime/schema" - "k8s.io/apimachinery/pkg/util/yaml" "k8s.io/client-go/discovery" "k8s.io/client-go/dynamic" "k8s.io/client-go/rest" @@ -92,34 +86,6 @@ func logLevel(verbosity string) logrus.Level { } } -func parseObjects(manifest string) ([]*unstructured.Unstructured, error) { - r := strings.NewReader(manifest) - decoder := yaml.NewYAMLReader(bufio.NewReader(r)) - ret := []runtime.Object{} - for { - bytes, err := decoder.Read() - if err == io.EOF { - break - } else if err != nil { - return nil, err - } - if len(bytes) == 0 { - continue - } - jsondata, err := yaml.ToJSON(bytes) - if err != nil { - return nil, err - } - obj, _, err := unstructured.UnstructuredJSONScheme.Decode(jsondata, nil, nil) - if err != nil { - return nil, err - } - ret = append(ret, obj) - } - - return utils.FlattenToV1(ret), nil -} - func restClientPool() (dynamic.ClientPool, discovery.DiscoveryInterface, error) { conf, err := buildOutOfClusterConfig() if err != nil { diff --git a/cmd/kubeapps/root_test.go b/cmd/kubeapps/root_test.go index fd5e603755b..a4249edcf40 100644 --- a/cmd/kubeapps/root_test.go +++ b/cmd/kubeapps/root_test.go @@ -22,45 +22,6 @@ import ( "testing" ) -func TestParseObjectsSuccess(t *testing.T) { - m1 := `apiVersion: v1 -kind: Namespace -metadata: - annotations: {} - labels: - name: kubeless - name: kubeless` - rs, err := parseObjects(m1) - if err != nil { - t.Error(err) - } - if len(rs) != 1 { - t.Errorf("Expected 1 yaml element, got %v", len(rs)) - } - - // validate some fields of the parsed object - if rs[0].GetAPIVersion() != "v1" { - t.Errorf("Expected apiversion=v1, go %s", rs[0].GetAPIVersion()) - } - if rs[0].GetKind() != "Namespace" { - t.Errorf("Expected kind = Namespace, go %s", rs[0].GetKind()) - } -} - -func TestParseObjectFailure(t *testing.T) { - m2 := `apiVersion: v1 -kind: Namespace -metadata: - annotations: {} - labels: - name: kubeless - name: kubeless` - _, err := parseObjects(m2) - if err == nil { - t.Error("Expected parse fail, got success") - } -} - func TestGenerateEncodedRandomPassword(t *testing.T) { got, err := generateEncodedRandomPassword(12) if err != nil { diff --git a/cmd/kubeapps/up.go b/cmd/kubeapps/up.go index 666d16483a3..b217b1d3803 100644 --- a/cmd/kubeapps/up.go +++ b/cmd/kubeapps/up.go @@ -30,7 +30,6 @@ import ( "github.com/gosuri/uitable" "github.com/ksonnet/kubecfg/pkg/kubecfg" "github.com/ksonnet/kubecfg/utils" - "github.com/kubeapps/kubeapps/pkg/gke" "github.com/spf13/cobra" "k8s.io/api/apps/v1beta1" "k8s.io/api/core/v1" @@ -40,6 +39,9 @@ import ( "k8s.io/apimachinery/pkg/runtime/schema" "k8s.io/client-go/discovery" "k8s.io/client-go/kubernetes" + + "github.com/kubeapps/kubeapps/pkg/gke" + yamlUtils "github.com/kubeapps/kubeapps/pkg/yaml" ) const ( @@ -113,7 +115,7 @@ List of components that kubeapps up installs: return fmt.Errorf("can't read kubeapps manifest: %v", err) } - objs, err := parseObjects(manifest) + objs, err := yamlUtils.ParseObjects(manifest) if err != nil { return fmt.Errorf("can't parse kubeapps manifest: %v", err) } diff --git a/pkg/auth/auth.go b/pkg/auth/auth.go new file mode 100644 index 00000000000..5729b8b05b7 --- /dev/null +++ b/pkg/auth/auth.go @@ -0,0 +1,171 @@ +/* +Copyright (c) 2018 Bitnami + +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 auth + +import ( + "fmt" + + authorizationapi "k8s.io/api/authorization/v1" + discovery "k8s.io/client-go/discovery" + "k8s.io/client-go/kubernetes" + authorizationv1 "k8s.io/client-go/kubernetes/typed/authorization/v1" + "k8s.io/client-go/rest" + + yamlUtils "github.com/kubeapps/kubeapps/pkg/yaml" +) + +// UserAuth contains information to check user permissions +type UserAuth struct { + authCli authorizationv1.AuthorizationV1Interface + discoveryCli discovery.DiscoveryInterface +} + +type resource struct { + APIVersion string + Kind string + Namespace string +} + +// NewAuth creates a auth agent +func NewAuth(token string) (*UserAuth, error) { + config, err := rest.InClusterConfig() + // Overwrite default token + config.BearerToken = token + kubeClient, err := kubernetes.NewForConfig(config) + authCli := kubeClient.AuthorizationV1() + discoveryCli := kubeClient.Discovery() + + // Check if the given token is a valid + _, err = kubeClient.AuthorizationV1().SelfSubjectRulesReviews().Create(&authorizationapi.SelfSubjectRulesReview{ + Spec: authorizationapi.SelfSubjectRulesReviewSpec{ + Namespace: "default", + }, + }) + if err != nil { + return nil, err + } + + return &UserAuth{authCli, discoveryCli}, nil +} + +func resolve(discoveryCli discovery.DiscoveryInterface, groupVersion, kind string) (string, error) { + resourceList, err := discoveryCli.ServerResourcesForGroupVersion(groupVersion) + if err != nil { + return "", nil + } + for _, r := range resourceList.APIResources { + if r.Kind == kind { + return r.Name, nil + } + } + return "", fmt.Errorf("Unable to find the kind %s in the resource group %s", kind, groupVersion) +} + +func (u *UserAuth) canPerform(verb, group, resource, namespace string) (bool, error) { + res, err := u.authCli.SelfSubjectAccessReviews().Create(&authorizationapi.SelfSubjectAccessReview{ + Spec: authorizationapi.SelfSubjectAccessReviewSpec{ + ResourceAttributes: &authorizationapi.ResourceAttributes{ + Group: group, + Resource: resource, + Verb: verb, + Namespace: namespace, + }, + }, + }) + if err != nil { + return false, err + } + return res.Status.Allowed, nil +} + +func (u *UserAuth) getResourcesToCheck(namespace, manifest string) ([]resource, error) { + objs, err := yamlUtils.ParseObjects(manifest) + if err != nil { + return []resource{}, err + } + resourcesToCheck := map[string]*resource{} + result := []resource{} + for _, obj := range objs { + // Object can specify a different namespace, if not use the default one + ns := obj.GetNamespace() + if ns == "" { + ns = namespace + } + resourceToCheck := fmt.Sprintf("%s/%s/%s", ns, obj.GetAPIVersion(), obj.GetKind()) + if resourcesToCheck[resourceToCheck] == nil { + r := resource{obj.GetAPIVersion(), obj.GetKind(), ns} + resourcesToCheck[resourceToCheck] = &r + result = append(result, r) + } + } + return result, nil +} + +func (u *UserAuth) isAllowed(verb string, itemsToCheck []resource) error { + for _, i := range itemsToCheck { + resource, err := resolve(u.discoveryCli, i.APIVersion, i.Kind) + if err != nil { + return err + } + group := i.APIVersion + if group == "v1" { + // The group should be empty for the core API group + group = "" + } + allowed, _ := u.canPerform(verb, group, resource, i.Namespace) + if !allowed { + return fmt.Errorf("Unauthorized to %s %s/%s in the %s namespace", verb, i.APIVersion, resource, i.Namespace) + } + } + return nil +} + +// CanI returns if the user can perform the given action with the given chart and parameters +func (u *UserAuth) CanI(namespace, action, manifest string) error { + resources, err := u.getResourcesToCheck(namespace, manifest) + if err != nil { + return err + } + switch action { + case "create": + err := u.isAllowed("create", resources) + if err != nil { + return err + } + case "upgrade": + // For upgrading a chart the user should be able to create, update and delete resources + for _, v := range []string{"create", "update", "delete"} { + err = u.isAllowed(v, resources) + if err != nil { + return err + } + } + case "get": + err := u.isAllowed("get", resources) + if err != nil { + return err + } + case "delete": + err := u.isAllowed("delete", resources) + if err != nil { + return err + } + default: + return fmt.Errorf("Unexpected action to check %s", action) + } + return nil +} diff --git a/pkg/auth/auth_test.go b/pkg/auth/auth_test.go new file mode 100644 index 00000000000..57b6623fa4e --- /dev/null +++ b/pkg/auth/auth_test.go @@ -0,0 +1,84 @@ +/* +Copyright (c) 2018 Bitnami + +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 auth + +import ( + "strings" + "testing" + + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + fakediscovery "k8s.io/client-go/discovery/fake" + "k8s.io/client-go/kubernetes/fake" +) + +func TestCanI(t *testing.T) { + resourceList := metav1.APIResourceList{ + GroupVersion: "v1", + APIResources: []metav1.APIResource{ + {Name: "pods", Kind: "Pod"}, + }, + } + cli := fake.NewSimpleClientset() + fakeDiscovery, ok := cli.Discovery().(*fakediscovery.FakeDiscovery) + if !ok { + t.Fatalf("couldn't convert Discovery() to *FakeDiscovery") + } + fakeDiscovery.Resources = []*metav1.APIResourceList{&resourceList} + auth := UserAuth{ + authCli: cli.AuthorizationV1(), + discoveryCli: cli.Discovery(), + } + manifest := `--- +apiVersion: v1 +kind: Pod +` + err := auth.CanI("foo", "create", manifest) + // Fake client returns an empty result so it will deny any request + if !strings.Contains(err.Error(), "Unauthorized to create v1/pods in the foo namespace") { + t.Errorf("Unexpected error: %v", err) + } +} + +func TestNamespacedCanI(t *testing.T) { + resourceList := metav1.APIResourceList{ + GroupVersion: "v1", + APIResources: []metav1.APIResource{ + {Name: "pods", Kind: "Pod"}, + }, + } + cli := fake.NewSimpleClientset() + fakeDiscovery, ok := cli.Discovery().(*fakediscovery.FakeDiscovery) + if !ok { + t.Fatalf("couldn't convert Discovery() to *FakeDiscovery") + } + fakeDiscovery.Resources = []*metav1.APIResourceList{&resourceList} + auth := UserAuth{ + authCli: cli.AuthorizationV1(), + discoveryCli: cli.Discovery(), + } + manifest := `--- +apiVersion: v1 +kind: Pod +metadata: + namespace: bar +` + err := auth.CanI("foo", "create", manifest) + // Fake client returns an empty result so it will deny any request + if !strings.Contains(err.Error(), "Unauthorized to create v1/pods in the bar namespace") { + t.Errorf("Unexpected error: %v", err) + } +} diff --git a/pkg/yaml/yaml.go b/pkg/yaml/yaml.go new file mode 100644 index 00000000000..95369c6e3df --- /dev/null +++ b/pkg/yaml/yaml.go @@ -0,0 +1,57 @@ +/* +Copyright (c) 2018 Bitnami + +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 yaml + +import ( + "bufio" + "io" + "strings" + + "github.com/ksonnet/kubecfg/utils" + "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" + "k8s.io/apimachinery/pkg/runtime" + "k8s.io/apimachinery/pkg/util/yaml" +) + +// ParseObjects returns an Unstructured object list based on the content of a YAML manifest +func ParseObjects(manifest string) ([]*unstructured.Unstructured, error) { + r := strings.NewReader(manifest) + decoder := yaml.NewYAMLReader(bufio.NewReader(r)) + ret := []runtime.Object{} + for { + bytes, err := decoder.Read() + if err == io.EOF { + break + } else if err != nil { + return nil, err + } + if len(bytes) == 0 { + continue + } + jsondata, err := yaml.ToJSON(bytes) + if err != nil { + return nil, err + } + obj, _, err := unstructured.UnstructuredJSONScheme.Decode(jsondata, nil, nil) + if err != nil { + return nil, err + } + ret = append(ret, obj) + } + + return utils.FlattenToV1(ret), nil +} diff --git a/pkg/yaml/yaml_test.go b/pkg/yaml/yaml_test.go new file mode 100644 index 00000000000..030df61d993 --- /dev/null +++ b/pkg/yaml/yaml_test.go @@ -0,0 +1,60 @@ +/* +Copyright (c) 2018 Bitnami + +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 yaml + +import ( + "testing" +) + +func TestParseObjectsSuccess(t *testing.T) { + m1 := `apiVersion: v1 +kind: Namespace +metadata: + annotations: {} + labels: + name: kubeless + name: kubeless` + rs, err := ParseObjects(m1) + if err != nil { + t.Error(err) + } + if len(rs) != 1 { + t.Errorf("Expected 1 yaml element, got %v", len(rs)) + } + + // validate some fields of the parsed object + if rs[0].GetAPIVersion() != "v1" { + t.Errorf("Expected apiversion=v1, go %s", rs[0].GetAPIVersion()) + } + if rs[0].GetKind() != "Namespace" { + t.Errorf("Expected kind = Namespace, go %s", rs[0].GetKind()) + } +} + +func TestParseObjectFailure(t *testing.T) { + m2 := `apiVersion: v1 +kind: Namespace +metadata: + annotations: {} + labels: + name: kubeless + name: kubeless` + _, err := ParseObjects(m2) + if err == nil { + t.Error("Expected parse fail, got success") + } +} From 4c08eb94045e4b6a223c894475af2f4aff8feabd Mon Sep 17 00:00:00 2001 From: Andres Date: Tue, 19 Jun 2018 12:13:45 +0200 Subject: [PATCH 12/13] Review --- cmd/tiller-proxy/Dockerfile.dev | 4 + cmd/tiller-proxy/README.md | 4 +- cmd/tiller-proxy/handler.go | 161 ++++++++++++++++++++------------ cmd/tiller-proxy/main.go | 34 +++++-- cmd/tiller-proxy/tiller-proxy | Bin 0 -> 38483444 bytes pkg/auth/auth.go | 35 +++---- pkg/proxy/proxy.go | 8 +- 7 files changed, 151 insertions(+), 95 deletions(-) create mode 100644 cmd/tiller-proxy/Dockerfile.dev create mode 100755 cmd/tiller-proxy/tiller-proxy diff --git a/cmd/tiller-proxy/Dockerfile.dev b/cmd/tiller-proxy/Dockerfile.dev new file mode 100644 index 00000000000..fe0313b974e --- /dev/null +++ b/cmd/tiller-proxy/Dockerfile.dev @@ -0,0 +1,4 @@ +FROM alpine:3.6 +RUN apk --no-cache add ca-certificates +COPY ./proxy-static /proxy +CMD ["/proxy"] diff --git a/cmd/tiller-proxy/README.md b/cmd/tiller-proxy/README.md index 0a0db26f762..a94029f737f 100644 --- a/cmd/tiller-proxy/README.md +++ b/cmd/tiller-proxy/README.md @@ -32,7 +32,7 @@ This proxy provides 6 different routes: # Enabling authorization -It is possible to enable authorization for helm releases setting the env var `ENABLE_AUTH`. If enabled, the client should have permissions to: +By default, authorization for any request is enabled (it can be disabled using the flag --disable-auth). If enabled, the client should have permissions to: - "Read" access to all the release resources in a release when doing a HTTP GET over a specific release. - "Create" access to all the release resources in a release when doing a when doing an HTTP POST. @@ -40,3 +40,5 @@ It is possible to enable authorization for helm releases setting the env var `EN - "Delete" permissions to all the release resources when doing an HTTP PUT. Note that the user only needs a valid token in order to list releases. + +Right now, the only supported method for authentication is using a bearer token. diff --git a/cmd/tiller-proxy/handler.go b/cmd/tiller-proxy/handler.go index 19867545ed8..aa0993e4fe2 100644 --- a/cmd/tiller-proxy/handler.go +++ b/cmd/tiller-proxy/handler.go @@ -17,18 +17,18 @@ limitations under the License. package main import ( + "context" "io/ioutil" - "k8s.io/helm/pkg/proto/hapi/release" "net/http" - "os" - "strconv" "strings" "time" "github.com/gorilla/mux" "github.com/kubeapps/common/response" log "github.com/sirupsen/logrus" + "github.com/urfave/negroni" "k8s.io/helm/pkg/chartutil" + "k8s.io/helm/pkg/proto/hapi/chart" "github.com/kubeapps/kubeapps/pkg/auth" chartUtils "github.com/kubeapps/kubeapps/pkg/chart" @@ -39,36 +39,53 @@ const ( ) var ( - netClient *http.Client - enableAuth bool + netClient *http.Client ) func init() { netClient = &http.Client{ Timeout: time.Second * defaultTimeoutSeconds, } - enableAuth, _ = strconv.ParseBool(os.Getenv("ENABLE_AUTH")) +} + +// Context key type for request contexts +type contextKey int + +// userKey is the context key for the User data in the request context +const userKey contextKey = 0 + +// authGate implements middleware to check if the user is logged in before continuing +func authGate() negroni.HandlerFunc { + return func(w http.ResponseWriter, req *http.Request, next http.HandlerFunc) { + authHeader := strings.Split(req.Header.Get("Authorization"), "Bearer ") + if len(authHeader) != 2 { + response.NewErrorResponse(http.StatusUnauthorized, "Unauthorized").Write(w) + return + } + userAuth, err := auth.NewAuth(authHeader[1]) + if err != nil { + response.NewErrorResponse(http.StatusInternalServerError, err.Error()).Write(w) + return + } + err = userAuth.Validate() + if err != nil { + response.NewErrorResponse(http.StatusUnauthorized, err.Error()).Write(w) + return + } + ctx := context.WithValue(req.Context(), userKey, *userAuth) + next(w, req.WithContext(ctx)) + } } // Params a key-value map of path params type Params map[string]string -// WithAuth can be used to wrap handlers to take an extra arg for path params -type WithAuth func(http.ResponseWriter, *http.Request, Params, *auth.UserAuth) +// WithParams can be used to wrap handlers to take an extra arg for path params +type WithParams func(http.ResponseWriter, *http.Request, Params) -func (h WithAuth) ServeHTTP(w http.ResponseWriter, req *http.Request) { +func (h WithParams) ServeHTTP(w http.ResponseWriter, req *http.Request) { vars := mux.Vars(req) - authHeader := strings.Split(req.Header.Get("Authorization"), "Bearer ") - if len(authHeader) != 2 { - response.NewErrorResponse(http.StatusUnauthorized, "Unauthorized").Write(w) - return - } - userAuth, err := auth.NewAuth(authHeader[1]) - if err != nil { - response.NewErrorResponse(http.StatusUnauthorized, err.Error()).Write(w) - return - } - h(w, req, vars, userAuth) + h(w, req, vars) } func isNotFound(err error) bool { @@ -95,71 +112,93 @@ func errorCode(err error) int { return errCode } -func deployRelease(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { - log.Printf("Creating/updating Helm Release") +func getChart(req *http.Request) (*chartUtils.Details, *chart.Chart, error) { defer req.Body.Close() body, err := ioutil.ReadAll(req.Body) if err != nil { - response.NewErrorResponse(errorCode(err), err.Error()).Write(w) - return + return nil, nil, err } chartDetails, err := chartUtils.ParseDetails(body) if err != nil { - response.NewErrorResponse(http.StatusUnprocessableEntity, err.Error()).Write(w) - return + return nil, nil, err } ch, err := chartUtils.GetChart(chartDetails, kubeClient, netClient, chartutil.LoadArchive) + if err != nil { + return nil, nil, err + } + return chartDetails, ch, nil +} + +func logStatus(name string) { + status, err := proxy.GetReleaseStatus(name) + if err != nil { + log.Printf("Unable to fecth release status of %s: %v", name, err) + } else { + log.Printf("Release status: %s", status) + } +} + +func createRelease(w http.ResponseWriter, req *http.Request, params Params) { + log.Printf("Creating Helm Release") + chartDetails, ch, err := getChart(req) if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } - action := "create" - if req.Method == "PUT" && params["releaseName"] != "" { - action = "upgrade" - } - if enableAuth { + if !disableAuth { manifest, err := proxy.ResolveManifest(params["namespace"], chartDetails.Values, ch) if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } - err = user.CanI(params["namespace"], action, manifest) + userAuth := req.Context().Value(userKey).(auth.UserAuth) + err = userAuth.CanI(params["namespace"], "create", manifest) if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } } - var rel *release.Release - if action == "create" { - rel, err = proxy.CreateRelease( - chartDetails.ReleaseName, - params["namespace"], - chartDetails.Values, - ch, - ) - } else { - rel, err = proxy.UpdateRelease( - params["releaseName"], - params["namespace"], - chartDetails.Values, - ch, - ) + rel, err := proxy.CreateRelease(chartDetails.ReleaseName, params["namespace"], chartDetails.Values, ch) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return } + log.Printf("Installed release %s", rel.Name) + logStatus(rel.Name) + response.NewDataResponse(*rel).Write(w) +} + +func upgradeRelease(w http.ResponseWriter, req *http.Request, params Params) { + log.Printf("Upgrading Helm Release") + chartDetails, ch, err := getChart(req) if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } - log.Printf("Installed/updated release %s", rel.Name) - status, err := proxy.GetReleaseStatus(rel.Name) + if !disableAuth { + manifest, err := proxy.ResolveManifest(params["namespace"], chartDetails.Values, ch) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + userAuth := req.Context().Value(userKey).(auth.UserAuth) + err = userAuth.CanI(params["namespace"], "create", manifest) + if err != nil { + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return + } + } + rel, err := proxy.UpdateRelease(params["releaseName"], params["namespace"], chartDetails.Values, ch) if err != nil { - log.Printf("Unable to fecth release status of %s: %v", rel.Name, err) - } else { - log.Printf("Release status: %s", status) + response.NewErrorResponse(errorCode(err), err.Error()).Write(w) + return } + log.Printf("Upgraded release %s", rel.Name) + logStatus(rel.Name) response.NewDataResponse(*rel).Write(w) } -func listAllReleases(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { +func listAllReleases(w http.ResponseWriter, req *http.Request) { apps, err := proxy.ListReleases("") if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) @@ -168,7 +207,7 @@ func listAllReleases(w http.ResponseWriter, req *http.Request, params Params, us response.NewDataResponse(apps).Write(w) } -func listReleases(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { +func listReleases(w http.ResponseWriter, req *http.Request, params Params) { apps, err := proxy.ListReleases(params["namespace"]) if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) @@ -177,25 +216,26 @@ func listReleases(w http.ResponseWriter, req *http.Request, params Params, user response.NewDataResponse(apps).Write(w) } -func getRelease(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { +func getRelease(w http.ResponseWriter, req *http.Request, params Params) { rel, err := proxy.GetRelease(params["releaseName"], params["namespace"]) if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } - if enableAuth { + if !disableAuth { manifest, err := proxy.ResolveManifest(params["namespace"], rel.Config.Raw, rel.Chart) if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } - err = user.CanI(params["namespace"], "get", manifest) + userAuth := req.Context().Value(userKey).(auth.UserAuth) + err = userAuth.CanI(params["namespace"], "get", manifest) } response.NewDataResponse(*rel).Write(w) } -func deleteRelease(w http.ResponseWriter, req *http.Request, params Params, user *auth.UserAuth) { - if enableAuth { +func deleteRelease(w http.ResponseWriter, req *http.Request, params Params) { + if !disableAuth { rel, err := proxy.GetRelease(params["releaseName"], params["namespace"]) if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) @@ -206,7 +246,8 @@ func deleteRelease(w http.ResponseWriter, req *http.Request, params Params, user response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return } - err = user.CanI(params["namespace"], "delete", manifest) + userAuth := req.Context().Value(userKey).(auth.UserAuth) + err = userAuth.CanI(params["namespace"], "delete", manifest) if err != nil { response.NewErrorResponse(errorCode(err), err.Error()).Write(w) return diff --git a/cmd/tiller-proxy/main.go b/cmd/tiller-proxy/main.go index 991ad7f4f9e..d0649ee4e3a 100644 --- a/cmd/tiller-proxy/main.go +++ b/cmd/tiller-proxy/main.go @@ -34,13 +34,15 @@ import ( ) var ( - settings environment.EnvSettings - proxy *tillerProxy.Proxy - kubeClient kubernetes.Interface + settings environment.EnvSettings + proxy *tillerProxy.Proxy + kubeClient kubernetes.Interface + disableAuth bool ) func init() { settings.AddFlags(pflag.CommandLine) + pflag.BoolVar(&disableAuth, "disable-auth", false, "Disable authorization check") } func main() { @@ -75,14 +77,28 @@ func main() { r.Handle("/live", health) r.Handle("/ready", health) + authGate := authGate() + // Routes apiv1 := r.PathPrefix("/v1").Subrouter() - apiv1.Methods("GET").Path("/releases").Handler(WithAuth(listAllReleases)) - apiv1.Methods("GET").Path("/namespaces/{namespace}/releases").Handler(WithAuth(listReleases)) - apiv1.Methods("POST").Path("/namespaces/{namespace}/releases").Handler(WithAuth(deployRelease)) - apiv1.Methods("GET").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithAuth(getRelease)) - apiv1.Methods("PUT").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithAuth(deployRelease)) - apiv1.Methods("DELETE").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(WithAuth(deleteRelease)) + apiv1.Methods("GET").Path("/releases").HandlerFunc(listAllReleases) + apiv1.Methods("GET").Path("/namespaces/{namespace}/releases").Handler(WithParams(listReleases)) + apiv1.Methods("POST").Path("/namespaces/{namespace}/releases").Handler(negroni.New( + authGate, + negroni.Wrap(WithParams(createRelease)), + )) + apiv1.Methods("GET").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(negroni.New( + authGate, + negroni.Wrap(WithParams(getRelease)), + )) + apiv1.Methods("PUT").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(negroni.New( + authGate, + negroni.Wrap(WithParams(upgradeRelease)), + )) + apiv1.Methods("DELETE").Path("/namespaces/{namespace}/releases/{releaseName}").Handler(negroni.New( + authGate, + negroni.Wrap(WithParams(deleteRelease)), + )) n := negroni.Classic() n.UseHandler(r) diff --git a/cmd/tiller-proxy/tiller-proxy b/cmd/tiller-proxy/tiller-proxy new file mode 100755 index 0000000000000000000000000000000000000000..b51189fb6adb6a6148537c2a9bcb630a58aae516 GIT binary patch literal 38483444 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

lk$hpemE{FNV^UR9A?ffymc+Cc?n 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%0A(PB3&XpSb^e0L*bzv>Vpa)9kuXoiF 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:gaqx7 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


ViR(;pIHfGM)m?ID1GwoRTE*NlrB&vcRK z6vll}HQP@C|DGFE{ldjj`oB*r`v1|k@bCNsWBB)IdCutnuybpx$$`oA|BJ$qpQAal+#TxX!`=0wn9LPZyR@S;* zK=$CcYjGDB>wT4LGobL-`cJxO*a+-@gXdS&f1POjqW&L-G`^?b8qxTklr?qVhcrGk zt@1#r`R8G*Hfa1QWm@Ck*Y{aWj5bVGj$voX=UG(y+0KgnTG9AVpB1L@Q4<2OYz}m% z#y^Y$G(mJO7)FyKQZ)RGxKdOmqa>B0NlJ>&*rNEDO*^EhWwSiKolQF)-@Z;B-zrVp zr6`d-a!Tij6rHb{=LSNG-Z54nN`4+B2Sx68wq1<{uLG)p1;FV?@j;M{y-JMsU} z$r}DE4i4e}!X+C1HBf%Z_~$uwy>0NP$H2e$*J?&DI4|Y54*%IyzqQ*C6^w&*MSKhs zYgS$?a5j8nC|$5HqZ$A2#Jl$4&AS`OzQWbzXO z^VV(j3gANMoX*UgYD&2Od<os;6Ur1jUEV~se$mQsPW)HqrwNm zT59^$H@*qLyX81H^av4sD&83irX}Ej*@E_X_jIEj+;y)AXp$47Z3}9U`Rbl*%LeA{ z(mZIAD|i_|fF}50;R6sMZy>cWGg8TC75LM~t0xQb#9{myM6e3!uqg{l^42b&WYkZo z^Zq4@Sw7Y3r@&bvzu*uMq^X=g$(POiQs_LP@13phEq7+CUjjV7-8t(7aNDDi&I%M) zNZ;DSa%QXdK^4;rsM)ri)Av1}jj$F12wq zfn}RuX>3=^>9w+UjFfKzq3WoCLs27## z3D+zq9u!Hu^0sNG0JW)9N_a0R%!GO`v~z^~2*P+}Xy+hxQ(y{_zv4I`|6UgMh43x= z-ELLuL*N5u@PL{UqK|7pDeilYq42{k^WH$XSD0GJvB zewHmcxT0muaG6fw>2N>-X4pNGeN0~~fokTv(y*Ig#@}$M>`^kWcrxh`Q(6`5i3U{% z4G=%quw!+AZOisSaE|lgKfV@SASBA5hALEA!FF{$Y9%NR=Zq|N6z7b`8!z=wMG zHa|E8!_*6@MdToEI%`?YoA3onD3rpi;1{JPO_&tQSs5fG%ZDG@>SUy|(IWjQ>((ZP!+JN#&U@4S^ zxM{6JGdnP_>z6-*c2-$@P^tkyQSgrilCVQDj3-2$?!v%s33 zCe4488`510ZsB1r`&ErZ&^uj)oilXU*(S0k=0@S*4b1NiS~}rzD`k~6sPWbTOa%ma z?IUv(Q9tk+N~l3bWTF}^-;Tf!SRit~oFN|fX4N#RCci(F(zxX7M?01O0fROU@(2A? zm|y<}g|2BoVPhxu?r(UBILOA4lhg zz{h)z!@&o3p_~->`$dCaIgF#`apSZg2$H7gmtmzekTL?(8x+iBFeSSdgjbzZv`_G= zx?iotfOF!~?uHMShHPE1Ast%^kD6s5{p&0z}hyTe9{ zrk6XG^9~4oIZ0T-m`f7?x++A!AA<=IU}{Z)$lC@vKa!YTy?Ncxpg`( zPVlI7$!Am7!c6uasLiD4N2*3*DNAJ~^1j~=G>VVSg({2$+~c?@1p(x+X@>4=T3?Qd zK49*UOAp%c5VCF8%L9@O_0GRr8|qQ#yBy%?Q}9W6{7YamU>c_#L}F!Qf?}w1`2jKp z-`>5jyH&HN8sFV__7(NgoHBL2d*LNW6X8wKUv!owfSRAw9rC_JNd43W?uF-fq{V9Z z`~b@yc&b&iSKYBdNYdPC>MY#RN!^i&K28kYajUu`)jf;CkGoRUUA-duIaS@|a?fJ5 zH|}z&yN=*C1vA)gfDNAB&poTR+;j=lAb~yxFQm5&%!|}bo!zsVfgQ{Yq~}ffp_?Y$ zj$YE-vp!ZgK#lMQY$Y;PA@NJ*(eFKf#}&K>72qgQ`QnfjRISgh0&;^y#oHN*?9) z7PZm)l}aq1@-v`tB$~{eyL~xK2E_>&Vo_TMXZmli|D{zCjg(@k~Le z38*WsJIK-&BWi)^L_OuUz~s34LDs9mb0Pf0BcHG0#S`fS)og2Ihlm%~v9)!Ja7f}u zOoUOHiYbXs#EcS13Q_#MuX*GgD6*3-lIHYt*l;6{C_bvdT<7z5b_x#j7!uXJDA0Rz zwxHEC!#X+XRe~uO;on?6F!KWVqDJPz9=@oNMX{QYRnU+}l;!dc_PgRN@BqRl6;{sC z(c?@B0xiFuV9j#QdzqoyBtx~c&LPzlfPt&{E2ghd0p}+Y6(+7FZT#t%%q1!^M@ZBA zG&afxNP!~Ne@i_{nCIN|ltM`%zm}7?3W!(2?p}Cl7w;yw_b%{y{-*rzn~vlf(<)rC z?2*6@-xp(Fp>2onBl8#?Ao~PrLJSG!)f<}pw`F+zLvRvE7prd5w3~xfy8fX6cm%pD z#Fi^imFuNoFCkpFoR)QDP2f~amW~iRaTeI@=N%`QGMR&!8oS=O*tL8rgTVeLarB2U z5f7kSzzKz*$X)@LEZg##u>l!z3b*`t(t=MZi>Z)gmfd9Kfu&~bF3?AaWold63gD~4 zCOWE?JVO+R5SjA{fNyR7_xUYNxgJ1Nj~|L^>%r&1l>th>ViMJUzV|)Q`-4`v?HNK7 zMrc6AJn2T&PJ=F>O%Z6*eHe(Ib~dP9C)-FuXaR8``=k&K(4dnYL{PZ!gX^VZdtfIL zsO|-h0{oR(Ee(_lDfhC^5weMnQ)J-0X3MRL*~6qz$kEmE85sk!aEYa^o;eqG5gf9z z6IjvogP{VOY2SbmAsM1#C4=6iGDyZy_Ze=Q6PKGjkm+hbOoUW$&1ez92b9jNp`5a! z1IZ(I0pngh0;$T>LQH1acB-X05Y;8EF@obv7LW6#!=O{2 z4{c=Xml}5qyi|Khl6b4kHL?u-rLnZ2kw<*S(w0tIm$*{lncdH zlIC4sxxn(l6pbH3{0IOTr0HSrYTt)V_Xq?{|8}+dAYfnnsyil- z2MXK^dv#Rq?Hz+)S!(wlU-`G%y(d&Q*6zKca)Ui_UF}a@Zdq$je7p9iLvC4CyX>*r zy@%Yg7}Mfjc7tL{PsmMj7XIVA7Wf^Qt;Q2X1Vc4F!NTm7N0^ByH{PPF07vUr!rbvwO(+s{P#y3p)62SM`aR7&yJg6KCqctxSv>F5cqxOo}6~+j; zR~+N-d+A@BG3fd`7X-%uULYCbSaC_HZd0X;HefuY`@JzDFNH{dg)5s)_H|j+&C=Hxq3WJwV)Rxw9chZCdjH;UXLCSPPnGxL1zZa zPn!@(M9_G^kx_hbXUj7kSTkC88Uh++#4;eyY3{lu^lz2y>GZ6UL6fpm_@9R%l?Y&} z)qZ5 z_`wf57IaT^^$XZb*o+Gh<-EyGKXcZ{cnD9QBo7r?oRM1b0Y`{p(=&8(%GJy>NF?PR z2nOg*06&l$os$=wn8?I=IC>r-~^lUxk5ge4HOUyGN-Sq_|TLBh``od70XEQWQHe(vz&kLpb-dX0G*B( zFabun5Z5{GJTo6$sL)&>mc$_HTsQ#18un{Dk{IUnd)xw~R%oV@r#SyXhlg%5j=)+> zB5Z<>{xf`nn0yE46}?@wjT7vlCn%&NjR4gQ;c%^R%hUuvJ;+Q@INacEmE5Y7hUjon z8o&YgfzAhzi1Qgp72pb(riLJ)Ht{))03FsNDlQ*w0jC=LIjk|n%OH0#TX5^6O(u_SpyRv%X@tSS(sSn@+%wr1|Kw5~$0(^&fq(GC`r5}uI_^n>zUjL0*H6Co8lF*AcbP;O zUYVQ{6*FPY2K6!_vO!~?W-&Qg-ulWz!nz5L6Ud0^%&V~{*fA)DE_9j>Gdv}{WM`iG zz4oK>g}SKx6t4rG$K0Gnf~?qFkWW3`-e2<*JnHSZhWyF}-c6NV zaSyJHNSAvu-QHK=G2&V|6K;>vdz9mJ}I46m3Dl{DyIgh{+N z;AxA%1?CG?)2!3{)+prH{D-J@JEPX^PR3~=zDpCVz_PIQX`zM|J?Tyc0<^*OIS;@X z&K-A}c!_S_Mse%f#6xp>wZ=p5QuAVxls3hX33=#2C`Br9A-}|1xgofLlMJUy-+|vX z)r8w1Owv8vj%-S{l5oygJWBHCX~Tn>M%q@iBD}EJ@VGiOPR%43R0J*qD!s76P=)S+_Gyn`_p8oQ+GF)jvr6lIg94I9+ zEQL(;06RBOKeq+7LTS#`>C`P&ccN^WoG%>zj7&)@M1V?u=eprMX=m!hn@+^}U)7>K zP+N?rzag=M`3BF*}1Mr2Ps}7~HSYc8pi?g~=Upv-w4hFPdHnA+O{* zsUns-yIeqxaXB%f6pYHcbano;EefgxYNa2Hv{*p_3#O56v|0g9lBylhOR~?-pqNq9 z4QPQDDpqi<>M7AktzB0Kq_LkuLDig`0%;j0kyGGoXE-~uf)ZNQn@E>?fl;{^N~Rvf z2y`Jp*#C66Ue)q6h4En-d$rSZ7t?t{>g$By#g&C=TuSt(&+P%{3DmB}H{81ESPB4= zqL~x#hvS4%qz~Ug{*xx)PRqVM4Hf(&E#FzV$2HRb6z+!0!sx*HZgjL3fLI2nL|MM6 zGw+ZcCnC#;!~zynx${gOJg*nI=x)180fKWse&Bk$onC~m0aWMN8PM`u`kOd<|I%b3# z5LC%nLi<=6J_N*?6Nwn6g2UiK;JVhw>kbvq@p3JrYnugPt!roS3%DXo*S`Ij@*AVl z9nQ)hnp>E6RO?(#xI8B(Pk4)KNBRUndnodWIw^p9B6~fJB!q5(j5AX`fW?lWq4u8- zPM?#L%Z~hqP*-Kk$5*w%60JTfpA4q#K5$ zkgyE-BKubKku=~RrDho3zN!^vB^Y>KfHaIyf?sQk$_I=RyobMOZ86x{--&tXyf_bS zXRO>J&w;7!Eer}N>WoKmdk5!>Evg@(maMSV&6W6CDMd5*8S6vztfSL#Y`ElRR?GL=9nq35o$$FS>8(x-c!PVuL3>Ml!e@8%EAa{$_hwM zc?MKp)RZ00AZE%Zd>J!kIS)1LMrV`U6KT25aQ^*|s3)t6V!K}#eUsb!1QpfKwlA&O zpVqD$OL#&wfK?$&$YV}_Hl#qLA{fKoIZAMq>qj?fJHkb#))42o>!xG8zdA(E{n$vI@sWmsKm676w zV~-<)gq4vVq~UBzlGp-mx}cEdH(V>Bbkik(22y&ROA$~C8O}92H303TmywxZsEgJk zMh#GrINPJ=>aH6Y_JC2Do3&0+qpJjq8lBn*VAT_3u$`z$ft5PLc_~fV&pe_MYFUg; zn8%F`Yoarh+GW4StA;UA{Q*o^Dd-%|O7s_g$#ptQ{1~Ql<7tPNw<@0bf7HDToR!o1 z2R>76jWqU9F=!YHlj}s7C`O_^3a6(f|8>p0(b~-g_=}&iVcSe;>{J?)P2mSYNq>kn3FZfp%J~poElb9}$^vuG2368#C&oT1Jbg)=UHG*#0q@ zDEOywDL&t!*)ACy3DsO`fXJADOUR6g(;!gIc$05qK4_FmZzMZceE}yxG!It5zVpq z40UwjXVq8kW!4d7PM17u1XiAWTPtrcRD}WziMwhPaUKnla7^=^Arjp+^IV>iUU_S? zRuj-Xsx%r5z73pi=&oj&cqX0}AJ&ibMC0vRWheAD%1#L`KH(e_?X3jT2SW7_v`8Tw zLu8upgr@Td8-&)$ZzIt=@|G|M&R70)CWe+HxWkiJkl)F9>U@c#S8x1bYhoe%X5^U! z*3Xw{@VuR_pR1OdsS^kU&u7WV`xnD?aTy2-}B7w41lyGnTw0mX}vRPq}>VRH_i z#InZx#?+E<-O>1kgao9QgzNUg{qrNx<9Va-2N^>BXv&rd2|9K~qC=KbVU($-3+rCt z=z~-&XYJ$Ve1@qBs8k;Q*QZ(GvG(lMI|&WiT1i#PMH;*6Ymbrh$AX=ELrV61Rrc{t zZ|;XM9u3C6C>T1P59;!p9%tYsGaDv>Er_qfZ=h$DU{lo*22rJk(!Mt?Il0_AbF^i~j+E~>$(8>1i zXjfb!glm5ld-$K@tX!d*TR27JP;egiwu>{pCZ-Z4UJyHOJ>qv(C6ieER1Rk1Z^p|P zVngL`Btf8-l=kcYrjCscs+*-KuzMm_CKNkdlK107B1CqXT;E8h8 zXmeWmS>0HW=|m9RpjVTB5f3?Ixdv%WoD|{U#=VRKFNuWl0M6PO@6}C_GH^v+R5^Wj zTY~bRy)``QL!Y)#4JsoiM^~bo@BmndS}D^wU^*Pz-~P2LZ6qC_0iUj5Ts9<9iCCLW z>reCGkB1b$DN2)oKJwY`I!Wd@Gmik8w%7ffC(UB7+#~ z=JPeaw{y65IPMZJ;Ez-C1I*<+X4%=Zmy%z1DlJCMx(en84(3YIU{bA`+{R$`e$J40 zljJO1w*~qhv$Y*L!ex>8iNM&L_l141@khizpxpw4j0Pt%zmVyr79X9Nx@aInuot%<8TsfZ1tny_|GV$ig=^{szv3Th1KW0E^ za37wFja8lc_C|P7KVv$Gh@+(oa&R&kbiFiF3DqCZ`*;}bP3Nx8yHBZ=F>DNSD2E|; z$auXfb1>nUt-|n$$)NOco+Fv5g(8OQ+Nc;7v(ZSR7qb46JBl{)9=eLdderT5={=qo z#w=xbAu$A+mJrHXi4CH{10>74MXGc2!%>qJQk_7O9*(4OtMni-S_hIBBxV58=*`&( z9s%>woA;|cXY}TQ;kv)3HbBUEk6kIKJ}#HuGkNhysHy)+sP=0F(rAS=Mj?%D0i@rl zN|N}5I1N)s!xd6>3m`q?Lc-W8tB+Y3V0CB#WipfYfTUGrGU|u)Z=8?6g{a*H9pYv{ zd-4{q?K+5~FZmtUWr0b?tkVGNObuMYMa>1zP(_i6tb27fy;+>vLq)>>d|6B3U21i) z3<5}Yb2S%!7n$E`{On4RrW-ZvEb`W}^{M$a$x=&UmuO z#~?XfC8Q75{X{2LTrO_TZNsk+EBaFFj};`T_W*wGPFIk9I<=QeUN$ePyT$op+~lrh zIu2sF=y!!{W%Dk`9+6I&88a-l&}+;hk`Zo{71!>=??cGWjipfthAlV#OR1qa2?w-Vz?R&P|&Z#yn8>-NTziw=}4uD;C zPac3~1}N^s?434Am<^TLki{(VXNroPXfTPm%ZUc(=^dsuv!&;T`Qwo`V3JWMz;Nz7 z1<7Ht>@Y5{h_KVzF?W)|xi%Oh*9l2$;>MuK#E+t(T>igt4kamz%|SRs24KuYlCUyW z^CU+vUXC-)-VWDH)gP_o$2k4bT7F!IAF+;^-IsQ+PjIujTBGypd89hl{zE_fN`8c8 zi5vTo<^218pV<*qtI3q3Wn4pRtJ5-Lr^h=i1|Z9edrDz`%t8W(sV3=yKbU7+iah{e zgh=97(S)9ik_SdOm2Z&yFn?en$opg^<Wu%cT{346F! zlufLU9nI&3PKa>H)x_@Op+kn*(X<=}+`#;gwtod=r94u9GM9inrIqQnr;g_Ro0TSD z+fq*Ro5m0BuX(Ua0hCeVXKp=ersK{{eI-a% zqnD9-snW~w*q4*I0#MTUCo&)CL!FoI`+~x)v;JNd^$3MIiL!67k9qV+4UU=;b)w zf6#b>=*Rp>6zGevCyrKACJ0R@Lck8rp*^a7gV`osF`hSg0IA4m=Nuy;TwpXcInTuTJH3^R(hizX==fx#Z3i<)3>XlJ zcD^YRx6=vagk4pfuBO3snkJoL$JhC>y&~~z;W910;c*zfVobJYuVueo-%L1wz6P4g zclt{2Wwp;u^21pt5RGCUJOpY)5*Le81tt@k+4BT+ibGz=;!wv!-JEyP4n`M@vr&pt z2R!gkmvN+Ju!`u0y;hM=jn5S;&L>MxkXjr$xN`Y~3XwvP0pE;_QQeX2Sp;OOm!h(F z-dzMBpDxX;KgvIGMrHWnbq40Q?0emHqEvz4ql)26&-)Mcme?^`l#}e@z=P%!} zgt4J9o64g0dh$k#&IWED-`q2eviKy)4JkjRN%xoMC37A+5;_rgldmHdaie zI2Lb&3`PYY^%_6rd>5!(MufIoJBt+L^y(b6(tWA8nI9Sa#FdDL)=krmA8dX)iwnWf?HTfettE^# zz)*{v8%}U(Db($Hf+_`&Rb~xBNa|@e|CIq;O#)YV6)|rfa*U=0W+B)9ByvlIup(|y zn0&bTFdGQQPq30vHOfy^E0Dl?!0-M+0vU$>5ys#Yi*isFVY51}s)u!4MGwoFz2cGc z#Ax7H;7lf&fQ4^_kEgbW*fcf5KFeCo}}Opk8?V4F~ZTrE9c=4;4h3}h}N^e z;*ZH$WGUyrP9ph~UF;S_>&4Pk#6!D%?fE=|l+Qk&tSILg787TP6VG^P!j)-#p6s#p zoVQSKaLh1c#z@M>bxHspk@7N(BzcCDxjx{lQ84st5b6Qic-8_|08*#an3<)iRvWXA}h=`&RWQ94%?rh-Up;3z;rssUGKY85aReCK>`BWCgsc zY7HG*|G_?Nyf`uEG%MdZ)wCjRgidwyL{}Og6)gr^Y8BgH1rY1>m#HBV%$74sPYExdRy^n13sule^l(O1k|g69D=vd?JyQrDk9NdviN6Q z*J3%nlD>G|(i;vyh;Enj7^%x^C6}XqJQu%uuD+oyVjIKmZOB8Kbi+@2N)oZCk?+RX zJEy8hCLwRGLVtRK8fp3y?+aH&oXhtaH5s!`xq7A!BAiPZObn{k^15d^h7CoON4yZS ziV~gM&F5TVxJB3L7gn*|9P74Tj?r85{8=kxYUj?+>1i2`jilff25|fIJfq4SYxw z@m+kRIE;K88(2@s;0}o>$xJM--4V|NSFCAV`+{l!Xe^Q9 z2);1!(HA8=>>4NNhRwG$q$Wu63CO{m*){swl|m%)Valp=xQ_Em^73H5b*4P)lW$pjFXziaFt?RQN{P3T zVaZ1#+#slzEx07jSTs3IO;>FWG?BpYsv;ZBwspw*LMm{V<6LooGG_s)q2tBS}R>tYb)~cqDvAV(tP6ke}iB;tZM~-uTBog zgDjC^^4nuN<6rbkZiKeYRWqTz)m6;6RZYsyGmMr(LTvjpB&#O z@-n7nERx%OW#R?tMSmUSL6I125k^SX?JEha2Y`(vFszjG2)A;xwTBD>umA?@?R@iv z!Y(A(BBETJgl)km7F(fxywh_xbJ9o>h^>YQIF+}lC|cIDqjAWuI{t%jC>Y-L1+wun zAWHWdyR|3kf`1@P>HFbizXi@H0$W>-)hMC;<&VdS|0i2}lfLIEXYhe8vZ@&vx4+$> zBMW{K-5{zH`a`=#!sjjb5kA6V1soe8lMoTK3eaKNTGwa6zGkpEMA&=*Q^_hMkOpv9 zr2O;TTLA(CQ?z0zs0=Wrxe_u30Y79o#~NnLC+uPuWgyQ3&BQX`l-Qcju&;F!c5+V> zCUP5t^Xn9t&BSIbW24m+d(lYlL8{w_Y8-uNyj$x(w8Rtg#yj0O(ejNeI=v>P=bN8? z+OjqABK4U^2;$ZYylAs>u^+P%e*vQ=5K1?UwXHK&g-wCH^00I74IUUhsNeQkL{~?jgJ%tGaREj zI2?D9e`|%%>XepChxAh}=o40Q zbQoTgpgQ+9FG1;(yD!C8^BN8*1%eeNa9yMCl|<`HqN_`yo7e|{h0j$Q1ySB&3!~Wr zvRL8_9+bv9uRgsFN0{t|ALJ>VjjEY$JR_9@T#CJ4v*c<>Mhbv9-hy1NbJ{*>*}OUu zO~d9k7-u+rJzxu`U-p=lc5r$Tk+z&}&c;<{pVM_ZYUlup#f3}bViU*tl%k>L;adjm zyr1DQ{}#z)cV&Sge$-#i#gwY&$5n^hQ-R4RSbNv)3yDW%?qSZuz`k-;PfV7FN8Ryf ztWEa(u@XpHlDCohrJcL&k-oQKB)!MXOZLA)7jrGWT=}6?PSqLe6 z$mUok>GQp*rkk=U;abPfGR_t(s*pKy^lJ=5_mQug@H~CdvA9AFg9BYV(>tR$BV%aW zd61EehW8`AGcxk|6C$0_u!KJ|a_|!o&5VY55quLbBO?p{xWM05=En^W=+g`aJ>@Bu zj58YI<|)qX;nQ~Wn9-N0(aO6cg342*ra#m+Sm%&$J2& zhCGcz^4s0%Kt{CDD$`~mdBU%aR0~-nZ{z(o5^A>@%`uC^BxVhg)Kw9q>ocUcHb`vO z9xU0^mIeZs7J~C$J;v}vj$zXH{Yl3!!tpES_(3IUj6;wwYuY}B<6+h}HnKtH&q+4& z_4_RSdyfYCLkm@2;=Sbat>vYeukuT+`KQKv;EVQYjOOhSkz!AP76%3Bxu5{eNGm|M zMdWln6`m{Hmp zNdwu3;?kHU=fcVV!~wh*~$yu}1Qb1{Bk8o=h3;k^gS7NTuVrszdf*rq~5L)s8+rxUt zTP7z<+Eb47YY3ZNMXIT4;Zio}qk>aO(f1S$hR1jf108TR>NT+0jzAo$k>s*T9Dw-gaVm6CY6=)ugr)pER*dpJc!-Z6|JN zVxD;d&$OL*rU^L{BjB926X!H>GmEA(uT^}J&b$ufi*)AoB)&*zUJt?xby4$KBsL%` zu^d{|`Sdf0^#jzW(Iw71{IQnrLB{n$1tZDkgFDX3=TPEzZ)Hv6JU)F;+m#;{&=iB= z%*!0Ju1JP&ra62}uSO+YY*oS%X-rju>Pdb98OIyQ^XsAENAi0heTu2~C_JUHQzQJ8 z$e>bD9A{%KLXW2@wH_uvzmns8dRcSI^`yJF!cz>Cvq+WlvQL5R2<4*1{kCgq0%YP`5e|O@JyvZ&z%=5 z5kqp$G?TM=)U)>*74+g%cL~%)8Gw(@FI5Gpg%Oot4;o+`z5gppN>830jvwVYvCxy} zB{UV3=Xj`(Gzl$K;%{;-YoW<}>4G*XgCV*b13g{98bzdt8AYU+F~S5wOLt*N3Y-D2 zHK&X2T$GHvU_smu_2J&i;%*E9bMi^qRltZk>0;`ncc^A#dG}1APFll3c%BHGp{Ca5 zeMEX^;+GsXaW42~kol48T$k;ewMhkNN=U{;J(kHDHyLZtg;>ZG%Ts4|B6K`HgSb^b zVJ)06K@c+5DVn4JRRZ_q2hGjINP@o@5oIcl$V7v`@f;O@Z~oWbI;_AK@*xhY-)0lC zVvFe_t$PJ~kI?Hx5ts>5%VZhH1QUq}m=J6kO;LolrWmP4;ktu`U_eWq(n_8D3eoXI z;15a*pQ4*ftXmQt!L0HT~UR6 zFpE&E(*`~ig|z;kp6`gg<<5n zxXka3f+9p-ejDvOW)YP!B9s#qsD%ejD{yE%SsomlwqES)ti++P56)vB!VYW%Rh;R( zI|6sqIf5yG36ju71ZpPJidQlo*1PbthVyNy>g;@V3oIF(pC4sTk2ug;&+5a(gYrEG z)wPK`@Wbgg8)#jEo%q3cu&n2bKasqi3nn=ge$Clg9RER)*w8Fw9(YR-ut40KUZ*4+gvbK?j{Oh=GdE)M-oHTw~a_!4IT}b)ROA&oyJhc{N30lCbz36MJG{$))Ny ze`;=I?wqAGD{x09H_1C4)@+IXrbOeTd&D|BG9YQSHU;4uEkr9T6Souh=nfXbWpj&Y zXHmd$nzZlJJLh}QhW)MRaczabav z(wP$uF-K4|&2ez}t(aQqYM9u1dg!*x20L_4;ngaZ_^t5Nyc?}JmRde&GPFde z+9E)ne=Yi}7b~UYr>jM0!kKK(sI8Tuw7Z}NK>T~`L?sr9#IDE33$b_lkMQ`3EX12n zc>^a~zQr)OB;N5(l?D#l{7>T&Ni7ES=dN|HMF^Gr5BS|2t0&<7=6F(NJriOL^iIA9pPYEA|%b6`9@=8(JxGRGe>wj;Y@#svz4 zIac|ZLymnwz8V|>A_@>A>8kY0;;#s9a$=!xolMRWl=C$M7yeE7sni?F=24#6>8cf#Tq!RZk`H(Mzr_IvqKp4Np2d5LX^a zr22DXut`59i>)GXYu%MpN@apG{HaTUAqnZvqy&dKhyuq{DadNGdHC0k3rixvNnl-P&@<0!9RCC z(J239BmEWpv-sWs|FA0fhsOZB36tCyn^A`vzG+jFmT#^m5SMShU*hr2=e!rb zDd(iiIM4CWY2QBFxZc_OZ^?WUp-&0tIp{a@oO$Qd-@oG_(#QT2V==}0%>jB38`-$7 z+10OW!r{4@6M~B7fpv5ra8|t6Zk*1Rm&Q)QoP4L!p09?- ze~ChJ)0c3`L&xEUCIFLjL_bTqtuKwfTEd-UU$rU0?y=H+7nf$fNfykKn4(UQ<44ua zpfT?uQE_xx^2iZDckVIMD~y<(x9emLu@z3%dOs#a!{%)K z&vXh<=W9Pd>haw|XZT{!`$d82T*dntoUfrt1`s%}WCxHw6?*d#>omzk1;Kpw9byAl z)wyrT`mLPoW5zEtaWmtG>=BGFoL)?GQl5B*OgM0}FyXUzW2lSqAi#g&aSx`kciuFA ze}(?Vycv=q%2;`4x1IQI3%5h%@9yKX)SQSvLk^a0uni z8A2w7!suDF2wqeKQ1~$|I_S=E1Ub$5X(~E!LXcPKp9lIg>?Ft&7~v3e+>xxTa|;)a zIA2+buTzc0Trhe*8a`JWZZAO^6tCeqN6QzXsr612O*K41;P@{9KRj*|R~~Jo=d4ji zdRV@g0ow8HA??UR!HJ;bWv7G{kin5C!>Ro#DQ*tS7+8KckSfs~hVT(L=CMET-FRsP zgo{L>f#U6P=p+NF(f-T83?g*>m!TVHKFpQbUdzxGu)1Wfbi~KlWFlp>Iz~v-DiX&) zdSq)ZG=uZd0#b8H!%B2$-WVk%dkN+fQueoDx^;t_A?31%gp@mzl=wbkbYr3~3D*}5 zG<*l>BOX?jAW>7sGSEQ2Gey91SF##9d&38 z7AAyP&h=UKI!wx*P$248I&Z5qho;kG})esW)M{CE^9%@Yv!??7|^c zA{6%u8;rx?Q@>yIAUaoH1>-8U!M((@X3=28$nnH^1BtE;-w;|E(AxT7I@<4XIfoSc z<6PRKDO5->^V4bgSt#}36j16DYxPx^1ocV0Z`W0tEW*=-pj2i^uW*P9uW@sY@r!i> zz}H-z)6A^W*eSR_TGr@RlinatHSGlYDBE!cB54af7(|(!1z@GIGm#^5J`~D6&_+8z z6P+GSl=iF-$93fs9j69}l*YO)KE3XXa2>xCbaMAEPLE%ad3w)xZ#?|Wc#ma$W4-eq zpl;b(wZoawuFD#pFNywE8vV5-`f6!(tuq-}s-@A5rO~$WUy7-PWI1I>A!6gOw|3o#d>d^q zZUksEVKAfZm6hXF1%GB}n1#lV*Wsc??w9RqGp(7L}-GoQcEaZycK-8oVbgnlV)fc2{INka_BRyXW$91AD-jUq_2`bq9TX;Z7YGF$_jRQJQ z)&=dc#65tjO+AJ<6AiH?C@1}8zbMI0hX=L8g>1iw2CrC^fT&N7*NK0#;{~EpVX>r) z8*FK(p@&dk;mgwlhWgyTGMe=qb@|5a4{eyZpL`Mz)!viN^#1c=*P9aG2a~9VMO2d_ z$YT~!zG2Cm=dFi~umL@|b27HzEk{O7=xD$601wh`GUdidOGkXmp~Z9*gW}S0+5M?> z{NFInpZ~3lb0>RcPKyBJ=xGsP9Gn&rhJw^n0a`$_YYhho2g4vHkR7@wue)8nKXaSc?2Fi^Z1dsl!Q~MkS$Y?AW`t1oQ(XD&A@7sVS#6 zj5|YR!jy?xa(;Kcp7tRm*R$RxaT$CZ+R&n58o$R<)fmyQ+(f*)311cHA`A z$Z=WPpk11}&g#=9Lf~yVqZ)iN>ph5)eeAYCWU} z64!$D0Mf7?&L=l%7YoQrpoCNpkm;qxE)lF=BUJ}^zAK8OrRmZsxW)A9$~bSp`NUvU za}-Fp_6;%j5@MpQr=-ZB;;1=4&MRny7Zss3GNqfW$rDTnXl$<$?kk&P9HvQ9hCE6noyc99AI5 z2KkP78N>8*aE2&WgQ*f!d^7Peh-qPScsM&ZSHi>e88i0a9@8=g0ZiqwQX%C4wDn;s zDcitQ8B2A9G8P9AqyuBobdNI`;FhN8UASd*y~KsnG%!Eh^ka3{<#w!q^d#~ekQUPs zfg&8#)wl%xuJXAAoau+he}uv&67(iL0=h!(v`lDjHn!jeSdkvzwex)OAlGX5RVS}r z8kae8t$JqhP)3FI_>76Ca64A>>f%bBP~% zO^rJ6DQMIw%yN#0rcX}ifFjtfwSgGV9>$j zSvLdF88zAJ6Cp;tQ~SOt#%pOm9X)i@n>M4nHrLa-=F~iaEnF`9?QU8z>=*C!@JY56 znN^8D@3tZ=1V|G&q)~-BTJG)4h4jvK&Z@$ZM+eb(kzeo#e1Z{iN^W=cTouyLtu$Fd z!pKPmqDRce<>rj}mcJD#sLE(#T5@c2{L_e*4DwIsCop>55P?hTROJ-6Q{mc+Wpq(rv?s`#>cZrY5r$&U8m!g0-^F~Clu^W4MLC3@G+o6D~VwQ{3ml> z?Uz)5jh$D^=qh7`+(T-F z8fj$WG!PPb(^_9pV{2a)-kaiZgDS21R;j^GPM03w6!`IJ=39Qi``a7sX`P;G%b;UOe5Wv74>F45rZz8&MS)= zD+PKjmsjF)nu#sSjpjoXTFWcER#ArLAYiBMV+f7a@*{5bc+LL|A1=WyslH0Clhf7) zmd~?F;!QC+;sWYfo-!I>7w5T^0jq$ag7k2xM90$g2_2?>ac(U8n~6dVEU;MqM?B9C zyl{cU^&*KKr9F*dI(?CCisMdVp=Y{D;`)QUG}oc@sOQ2I9+*O{U4|-9# z*gjGp2z1p4QZbD_m`;F3A3R5WV)cPGYxIGXg7O*U3aH^Lr;j;0Qq&SUC=nGi1yS=g z>0rZj6pRUM4uUzzXO=vbC-oz&25=0B!86ErUcN`wN&#`JX6-`PjbTtWN|^CZGj^g{ zSst$YoQf*?TDVTqAi(`lD`0L0inw?R=svaLpFKjYKuTa|&OTL72luI!$7&l~1M@GT$ z=9oofS&7eabeusCLB?l-3cKHAY%@jyv=enw$yFk#TIaFTTz}ZV82vmU%VKnN0_d_5 z2Pty}^)*>U{Vnkal!>zy>6i@-&PHZszCrB*1+oP7_@B{;%W>->4(UycaP&3VyPoJE z8Y+~(zbJxTcxeox4QboJb214+A9NKUuk*6qK>poHfV?ahYgrpnK@eA!>B&YFnbE=! zrt7q`-)d1wA5?>Q!(5e=&OaGJZLm%L2|h`=#;5?uCzskW=oKyWPnMn;)JOHC@Rb@=V6B^7p*k0)_>C zT@#tV3GNw=?wO;(i_8sl$m&_A+kC1zN(Z;ai&$8pRtfindMyhj`yBtc4}8L7M4PqJ z&A1&eP{=S0Fi&Czpuo6-K~0bOopYSo&YsUvgz`@HJ)--&zQ;AS;(O$gGRpi=&twy1 zS^#>Pp7>zaO`YY)@ND=5?!pQCidYr$vfVz%e!B{gE^_%Vy9?vq)%lZNimE{RziL)S zKt7GX@TCB_8L+Wgy-X(xG_2jg(CCKq0mNXyNF<6vBx2i>-}# z|768`j@*cN8`hM10bB2%Lb&36S)UZ~{I^ znuFM=@!w%*0n%13|7E*<TvevLd}mN8Vf0P%9^4M4}p}kZ3a`7veVAoUg!nNoJCs!My)ywvIwl zgL+{=79Qxlq?&z6GcOs;=Vo3qn^_lPdter|Sz{@Iq7;OmyjD;pYG!;<0pIsqXy?S} z)g%@X`-FOhLPW7slg+_8{-quh`ylr_e-a>en>CdjLjj^Ktp$0T-GL<>jI(xKi;h6d zi;7?7CR%h#CjI>UQXn%yen9b&&J0~J(+Y{jlO?^S;Yed=E4vP6MuL{M1+`2hx|s*~ zMpuxwBK1%&H_NeuPy<3(fL3}LJfgj9IDjG7^G*$#1Ps+Gam0K>HA85>FjBJ?ZakwV z?5BATe?^B6sov%``fKFZk0bN{fIssC{TUs`ALzu$?R*@Ayd&na;2nKBT0 z(RLKRqi*7bXYg$ihhvU8Mo&+FDvgEyg7>987b3PP<89N$Cz_NTNmId6oi5RZdJ!7X z&T-le@Is#Q^;+^t4x1Ks7Ii6h$vRY=31X~ZC*XTJrxh!y^2t9CINBA=P$7Pm2r}X0 zQpgm2U*gmr=CV@Q|Mp=)XNXNRA`( zh=D!tq)4$zNCV{(Jw!LxnqvnPl|nx%B9NR|I#+EcD)sD4ta(%(Wzs<`^wVyl;eY0( z5mH+cgJT;b?P!;@HXJDQ(#bdJoa1cXQ=KBP3KyBcFS(IuAQt!N5bIc>#VkS;&O+@9 z7SE@YW!Q%3V=LhOMtLg=b%#qeKY?q_nGR+EmB8fxWBtt)nC8%krw9w!qN>PghI_c? zJ&hF7Nb}IFxh$^?AsZTOZm6Uc ziVx_fTOBOv8a7;~LZTWH)Dy{qtU~!BRExeDiBnNYk}$CK5|IEk70cxweOtf@eM zfErChpg(g=e<~>)lEgfcQ&SmQSxMx2`L0MaObk}1WL!t#w(-1dFSmtGR3Lq}9|&#A zbac~DrHBNw-$RdwW)HS2FkT!E^SS+ki!c+-XVPo+z^!=bdZ|{cXKuwqn=9XjQmNH* zP~xG%<*(u=D9nYL?j&)%*8R}Ben=9A#8x$_@eK0= zTqi8*Es%?f8RVW*Q%rD0Y_(9cbS27&^DT}cY3l)o{~3l*aj>#AM?I;eKmrwowr>4m zv&Ie-X91K9wu+#r9urp0aW-`F%?<@i&=Flj2S7Ti{^@Quf~Q9UB_ekL@N zIu|(i+(OD*!X+)+fN7+Mc&|NBH`sJu{HCPNI-@QH=PdE1XnXu4=iMBYg&qgK2@{?h zdghvv%wCzpWS_;dO0KW=qaj{gPwbH3ZW)rkzl+jHjsywy45UHmCI2}x&IFunQ}PqKCg<(>L< zy0b!92%M39OJ={!SoV%Xb*@@1u77AO9-{hL>lS;}4`uZ+$<=3Nu=;D)Y4rlF{s102 z?>)6{Yb-PiZz8ewU3q-#FXA0$zxxTk3K|ccdZrKf{si7N8F*{K?P>%3VW}Sa1;A1L zyG_2X<+J*i4cavbnnVaf4-z+g4<5Lo^>eiKJGA;UYkbxBX7z`YtN*<96jcBITCJX; z)g3%U>kGU4knh6kmnTQ98o_Sy5a`nc?0OL2~uWrTVp|`T(syK&xMM zk+1awSUvGgQs3{C>PMLBZMAv~51r$mG*<2e3z2Yg?B`>&4xJQixW z26iEyeaN#90v`qoX=xAp{ukgYZlw;Z!av`@UnWtbY{JL5JYMRfj4;((i6qKgBk1Lt z>eX8P&qS}Qp!dh$yuP2JZ%;gRwmHZuu^N9<%C!x+d8{KTAA1bfvWUARv<@ zAJUdYvo9jbvCs|*b$A;;)SfMY+D4$BVW3{8P=Ea$JsB{Qgzn+%NwL0-eu%fd#_GllXRTdAkuR$ja@9@Bx7DrF@$qZ`b(VKBjL^;M>n0XS*-@-d5||?tHsQ-u~0~ z_7r`)`2)OtSl*8Iz3r%PU*g*d^7b#jx1WLefYl>>d!@YX>wBwaCVM{Kf-QbH)W;Sg zuFrp+#1_YFA=hRC1QyIL0pP>%09A`NGU8{PlN>VqsN|~aHnZyDtEDPjf$Y!mU~%ZJ z!6lh;z?SNF9FD#W&w0|(!N|C6_!tjfGY|IUgWK?6mk+eWj(CtbNrG#=Us`P9G;=N1Evn%-Q8GTk~I&m(a$x-j|-eb(O69t}@3z@oy^4Swie~R}`Y|_5%!Dl1% z+5V<(h|dc2*>>G~{c$}Q!y)Ad=W&d_Vm^TFQwpw?7; zkk8gJxh&p0!#tbBXLsqd_U740K08I9Iln0)gZb=7W=zF<_ci7E^VxKLR)%NJNqkVI z4?bC?6%XgL-;r&NiX#Bb*_#jE)CcWYE1M5)zyoLDMYuz%pO;D?IR#1n#ak4FfPX=C z3BQv*q0EWkJvnXr=wXLq9SgDd1je6JOsd$cPD*;0@4ll?o&zPF;oLsmJuQ)Ixbd^# znppq`9iIfC$a}YQ@LkP(QIOj3hTgUw@PHdSq^rt`vveSO-Vwac4kz{Z9;$_u{=$ES zx)m1|=fPn+cC0!p((}!5Z9f$6zLe)0AI*v}esU9AXkypl3a7m1C*j&(&_6BmCGK#{ zf2=$odsORWx)(bYUNOU_6}VOxM0)-ZuASso7>hf=MC${9|8=-l7xSYIC4^Ub0$xS% zstmqAuEqGi=R)(HKVNT^R^sAvs+>LI2hHJbScR>g??j?KtOLxq-(SzS;?T>Q1A5#r z1zQDgjc^+6CR#bKrk0cMjCEfso0DKF(3$V&^z3PiEXJ06g&}v;j(gOr;>G zaE30a>|dOcTAE+Ca(229qjw7KGzG>RzrfD^3-TEX!;u8E?U-#~JTR^}BR3A`Jv;?u zJ;ZG4-#i5k?G%Y~2Ho?xsy8ChE)7c*HvbYrRxRq*mkC=XmhHU3FET0bAJ1;`y*T?o zDzPvukG;6Jb88QO@0T!R!nP>-xa&> zM9w>cnVl!6CCPcYTgd5?3}CSPP5{7-$Z)Ps22kM^ax#+u+&Y@_V-XY>piYLwhs2^Ob!T(Tc z%)8JcOK}Gs1MPGU{teAXk$h%L)<)eT)mj9asf_L5--x0}&$q(0MYc%YW>-aiqbhO` z3YViWt|Q8&NqTwOK;Sx}LO}48 zbJH=Y5*v-d2+y6w3oHJPYa|wvk&aEGijBl(>8}^$7pXHFj}^!RT3kjxHc2k%c%4>= zO_#TmX2@lh{(3=v_57joBtod{iN<8WW0T~9L(liaqvxf{Xu0&9AD&!~GkuFa(*%|L z9sc2b0kR1qIU1K(bz)E#Vo)3IhFZP@|NfCwc4lhX#6eKT(6U|h(%Dtb63VTFYW}q{ zsQ1x8Viq_LmH3%KT#!%83-+`dweHq^Ax+)xTKXWCjz^#fXn*3T;RgMp(HCVfCQZ$E z=+22HkOrWXodIczJ%D0BXPR5urPU#6N}sKzPm|KrS5lfb>5rkQ9naL#o9G;h1#`Q) zJWc6YDCP|B4^jOK?vnh8VHc;$X0k3`Rus?^HS=?HL>asysdB(F&agYIu1Qi7zn=r= zKIWOLWPfHH87`fEfJzX51{)kIaDP4gnPrv72=5+>)m-QV_%S_KS9R9x@#0*3Q@II# zb=?E9Q^5&Aex)1nh;uejOY9_^$c(>4A^q#Qs5=yw5{}T zUO3WrHASq2Rx)3_>^4iQB>DdKj3()k=KJZOLmFS{{mL$)3-^efmIG2WqWh9&IE8RP z{WBce=@*;zf3L@?6w#;IuOakeDV@+wtUKlANy%~O0B?|dP;xf&-W^<9nEZC01YOK}tLwVGLr`6WG9hHE(K zIW6AtY&=XY#EdZ%)OaCf>El3zRd?MHB}cm+g&L{YsB-vGvQjxfr8nJX00P zV0)(o`2|b-Bmas0K~ZW%swq;%iDF|5e*&FSm5`!j?l^$$JjfP;U$aW$mtmaG`ui6T zwcnR#=CtYRbm;1ynUj5BDRUyh7}Wq{U zp${^`?jfmYyFeVVSTbPcd!Kt#R-6jj#q*r?~fZg|D_Qaq|gU}_M2C^f& z)WdWs$bV;pz8FVJF#3W&p%*3L0ewND%H2Nt3blm3#l%?Xi;)3+oeQvSz^4VK_69HB zX@)atJR>RmUh1_s#@`;WqWZboWTWTuCkWyih8}F?{-p64c0Azcvp;6O9S^OOd7rM(HIb1$(3rDd2eO4rfFp_OeL?z$$K8*TXaghT z%1kU&K96E6^vmuq_oW!?Sf?_%XIMX;*Z1Qm&>)<_Sl(}Q$<7Sd#q-v@NIVd47CiPL z9-CgHt>%Onq(Nu;iTq)_cpmoYC6ag~=V60ou+h*;7E2d7FCjm*;TvbzabU?4$&x{S zya2doMWS$R;OiqZHLtH^rh48E5>wmVLl=2*Cn62ElMS~fwKo9mfwfZf{kVwedn`Vo$0pslI14&I7yk0zS#Z#xzZP73xfRo}P2lLN21LwG*Rx$E*~_5IO=yFqv!R3`FErYh&1=%Ycr z^XvN?&u>=WuPfSieP3>ILhIFR6B5vbzVBx6ZcN{IV5C@2a1aN{-Zwy^!;~718RDG4;99F1cZ}xfR~WF(E6W#ABz+c`+%861S4!_ zjatcWu<=ZW0g>y12`^Nwnn zec0SP)joW4yV{43@h;QZ@+J(zf&0TgEO;ca6xVvXBe!a}vi|iM~Ui|VeUh;nB zWn1mVl}85bg_Wn~{4L5Gw7&P1bqHw-;Z zGQf|ZTye|c2gg5+KDbo$!Mg{O4Lp6Y^Q(S+AUPl#vI6>`^$}o!mg$26pTF4E=P%~_ z{Kby%xcXq}Oiv$7+TX7acB5W;t-c9;kat4U`XGKGu>Qt5rF(jP!1;^oFVZQ6pW2TR zCCu3u9FJWC@$+*yZ;!l+%|M)<_7lh5m3n-~=wP&f9niSjmu-FFtSQ8$5qp*@j}s3{ zk;m0YT4_cehp~z-Gs5 z@nPFLUNggHyq?+B8?UebY{%={XJx$JlS|(Fylm@u9R%Eb@fE8-TR2|9@!kx9rt{m$aSK^*8HleSsKDKFn_0f4? zly98d4@s}D8jCOPMzBrC7h6|7>uG%F(tL3o4nsTJ7GLaqKq~)V&^-SiyxsiY-tvFg z5%q*z)+|LBMVM`QNqI_?|rd38S+bb@&72{k}sZ6NCW& z4r|Px+^tB)ziEH+BJfs$?ZF~7) zT06rJ4`h4%@asU!55Lb6e)vi*d0+Fgt@?0J;P(FlKhPijPy9*pU$N^`wv7MaUvi75 z_^yrcpUbbrZ!rAPL8w#Sa(~pVzfUAKVKjZHSXnhdRJ0I;TOS9CPM9S1N6VsBBUlH@ zPuKFYh})9#v$XsSURqMVUdu~*eM`zO*YZnR3V*GZU)7TG?Zb0NJ1B@HfSiR`Seh!vyP%Vp>M(7dHXW?;=6P0A2q3{Cn8D{Sj zbOH9-iME!^%5|SksOg-sh2facbLCQ@KB+?Agx_b7AV(f6#6v^-6BK5_fRweTP$jhM z9GZ24kA-$N_qonA9iJ!~8`WJ0pb^VKZ z_j>-trjz~tg~Uhx^-L4~MfMR*`xm2_ulkL1G`o=|e$M$&x_HIh?qXj$r^d4b!HJ6p zJOi?tS*4SiE5_utE@-mF^PygQr`VIFWzE`?%h<+t&4)_c7<+O~ThE^S?L6?4tY5zI znAnrKa>;v+mu29F(=rU!{o7XBz{O@Z-K9dCTGf)sK4o zUn%#>{}pm?_u3sqMj2MVi5cOB%N zZ=!iiSVmenR>OoN@G{eR_g@GTX6%A6;oXxECLGs*pZ8rwM4@CL`dA{%&b*slG}2*L z`J4+M*6tw2&@YQK)mSKU7&{TJ`xB9ght?m+v1p6Cm!}efKX^wlD3#%K^n(crm`nra zXX>|jsBLQngCJia_Vssp3fr^)xY9!rtGC&EukfLWlf|o~X(Zi?$|ZKraX1QvNycy4qXW!L|t(BUZM99hXY7*sGXwacDSSJ%4Du(WS5-8yt7+am&`3DF1 zZgqNXz@JyK?cBKyo7SB}v02KQfIo{vt-6^b33N!X1-%^g1(tI=lQ-v})4Ku4;giLH_s7rN~Ll(>u!xY^9U>h||+rDXUVC3dM1n>!u`-(%5WIx5wq{(4Q zx7QmpmUHlLD6r*z%oSb=o85sf-{^|PrIF+ZbzsJRz?Qa2EXlZ{xly79U>FRXJ z@cKJ`obB&R4@iF>mP_6vyliWKr|#8wf0_Ro@K2CNP}?>Z+6}q@%R>2FMDZ3-ruIvn z@P=L}eG!U@S{bbAT!g3sCcFor%{2L+!&2jaop(#|Pr5~#^-mV>3HaOPpUm8>htxUG z{Goa`3tV-=8P-2J{eGeM(Q?T2%bIbpa;vWI{ zPzS}ZUG&i#TTpe&(_g~;c3am^-1>|^>pVC8`b<`=cn~pJXf3%e$-4E~el^;!0Gz=F z=N7CF1@uiL^P>pU>*CqBb_n`xpTFey*(9cV*!K{AnEt(d(;WsWF~vFQ5h@Cu?wnxm zbDbx?l?r=BeHD137%H^#Rrup!t(@zOWCc%kezZH7X{Z{X>brPBoqo>{e=i(YIZj_75*Y3M%}=-PnyZ^P|S%ueTFy z)A83XyZ9GwzicOZ=gHmB+&1NRez;4D{&^HqgkPwez->{s*cD76Z9P+Et zKSyrz^v_!*R{wl^kLaKG*=KLZ}%KsS<~_r$(U%TFG1MIk@$bx1Eijm59eBiN-?sqyQzK6AbjiNGoG z>-MM6oLeXQW=!H?&d*2lEsS5kzH^E^U0_bUZbF`Z*>!v6>BAq5JbnI)Cr`Jy`ExH# z6?uACE_sjevaRwo0J!}Z?D>BxKdhhMgnUxI3Q;1Sk;uhCO(4zyIgQ?)V~PW=V7Vx{(4`r%~kD#^8WFcetDPUNN)Q&Any<4 zv{>FJ-08`Ct=y};kCuCt_c>3y@_t3kllRFd_~o6EPv^>en~?XH@|u?SLzzhWjq_DF zy}YN+$3FZgk@3w>?!JL!XmUO_0nl4IKk1cg;(0Yc8u`L}tl#x^elqF~k*~|-l6N^T zjmcMI^RZ1k`{gUh4~_W;!#X$XAAEktb3R4(N-I%hH>0g>^ACEpOVMZ1F-srOq8$5mX)``|X$i7|Z{mT?y@_yx|F?u&PKe;K}Pj6SA+r~1|h_jbJMR|q> zH$Fn6^6bK6dAN+mCuqJr^_%K0Py1jB5afr{e29U?q93MY1@*(r%l-O6mMX6M9D)%K zh4X!`c&@tQcic@OQs4a_=04Z?;nRRZIlDdRwq5xUk;xn;^~d|lz3P`@xmW$t|4CQB z>^R=jFC!22>lazCXeS4bHR4ZPv`5qWX!mQZ>fIy zu!GSrUB379%N$G4t-*{8SFFK^r` z^qwo1yytjnjNXmumxF-Yf5BhMLh45vh4kOnFD^XlAB}}TfCKOF^iLOapX*%vQ9%E!Y`eYs$GL^WsQTv%xmW$OR_;~* zyz{85f1+bO{j=#5zy6Uky>F6pyBg6yA9ZY6|D2A*QRtr?*q1c%fX3EK#}VvO9A>7A zB;u9o{-1y>9$xmW&*rbd3>&gIbq6%r;`P$kTcyb3T}L)6k4LkO?Xvfszc%vN;5_vi~Gbm3_%Sqd`&Bu)dh&4orG9zHqrZQ>ocq;?JiM_> z)AG>!Fp-B}TBntV@VFlkc0`Q6g46cF+{S>THA4fkz4g<rWvvj2CdjK2mgLC%wgW(B*vCvKi zOcw>S|FIU#*tB5ec(eC$RFg{^?bM>M(q>s$Iu+?>!5o(sj4bd@N(D2@fElV_c6Y)2 zG$LK6c3`JU{9u$eM;kDEDVPh-wb(q77K|)Zw@L-`{m$B{g*!{9@?9{Or3I5kY+jI~ zB@EwW3yEhKFjpyt>YyD zd@;+z86gy&ToUh;ce1}G8Ozynvs+UfvUupRbTzL&$6u37;4JWJit8K?Rivxg;~0NU zA=(75CZz`CI67U;OZxh23bto>H7O{lx#g)e{VYzc+0m;>*+9(&>1y73w!cm3=NcTF zNiPqyr8uDGgmg9knp$(ZSCbNenrEb|dFG$}ZIY#(%e zK1a9xQED~+0dGsMDy%4%m@rEx3Gw7xpSnq4E5geS}-!OkNd$W zHg_5@bqc2B56d6nv|z+?U*ZR2_}_pzRKfH+(qglu(vT3W;&nn)fc zhoJ9e zO(UQ;q^r4lvtP8O&D*`2##Z)CSM!TPf1Bh&XP{Tp*vfY4YGx<=ZOY*9=hZZ}a`_Bz zh~0jE5%#w!{dB~sk$xImd3(B=9}M@`BzrkedNqjyIAdVCnzK@Csy`-el47X2U%Hw{ zkN3ApCUTDT+EguaR~u!j-#}_AKXf(pdmXg-bexTE?G_V2Gp;2)lI_-jkv`cYF0oKQ z1Mzl3jEBDe-HPzPD?ExK_~W0LbVvo0VZa=(VD8vr!3<9ehMeNOJ|YF1d9Ag7Ux5jM zjq{rYQ|N-RXH8LOi+Za|1#_JNGfKhSC0vUQ{F;vXPAv%bw_=ZANS(~SMJBbLbbTc~ z2uRmV9I6>Ke*>hFN*4n3>WSW+DkIlptfMn9*EbQO6uNi)#otB35kNXiLQ zsN&hrZDLKE0xLED5FbUjj%133E^0;ER$ag@0NK#HH6X*r4>0jv_#yuM^Ar5}jelxC z$DdF5XX@AZbCiQWIqUG}asD~)d;FP=KZ`@_evjyvx^$+Eyw@>+De#>ekxJSy9r$(z zYRq2J`GfjtUT5KzH+c}dDI_QH7Smk&=cmdh5fN=px>Kw`kf0YNlcQk;C zoZb2KcYL1!#eS+me(er;fTliSqz*kTc7A3u=Op?4Sdj9AKb+b zUCjrJ@Kq{c*UexTan9${VtE=Wu1CF7@Bk&Yj#2!}oTFIcbbMhIJyR9|@sx*XbM!kVS;qM4k~yB8v?hXOdW3D@lRswJ%X ziCprQ^8y?pu(HjR$0CXc3-uQfjewgnx$)9?TPyxAt_P{GK@xOk2(IUG;ku#x744F^ z3fH9d!V0;&dOEr4GR4oz zjYN4!FqD)tEC`@xJ{q)c6MZsqT<>!Mh_dpMb_>`iB$0AwMUwvfxDoulZ&)BF+nkY$ zk9kc%aXBaV1|(nLOJDd5RRvDWMW?yTqypD!oDlzm_u(J2%LL`HK7;kl*lC6M1V|Gf z{t4_Ac?!$c?p_g8=CR0+;3HKJ;2%DfLh8u=6Zl|GO={W1Iq0)1&(%z@^zeVHc zjnVOkC5;hmnH{5*%aR7!H-2-2?^4E3rb(Y3YJn$>-{5Z=9lz!2$B&1}!)nF;ANJk_ zKC0^4AJ0GrCK^0L4Q-^T6CK;cVw(usL{VpOB4=>0QK?3xHuhReTPhI{(SigfK#s$x z?M20ww)Ca8dX-Y7+H%_rK?q+ zA#-uTSZt8rbC=12?Nk?JVWvI3yMRI4^XRITUGg=1y5*DIl5qkTZKOT3741E}2Y&7A z`8Pha*#035GKEpgQ#1ibMazu+xs6U=bs_aXZK$ta_megj%bwqa!ls@!5Z9bVFT`vA(gCH+pvkfJgKx7=_fyzC$)l~eYbk3{2;5L_1FCJ^PIQP?SoGE zeW9`7bE^MKY0qJ(`GblBs{h9m|5WEo!>~>K{H;Vb?wS7{81yM^&^4;6 zfumG?qCKx|H;44VlTn!8{GI|5AyjU7oq`&7KXZT#C1P~_=NvIQa-E3Lmc5|oe|M!P zfuh~c)?Quxje9U^f_$N>$!H(wTSXe7Qn*C(w-~h}`5v34E+I*w609|*^_m$y);WEk z`Ive5Sex5C++4DSdFLBCZw>R7wHu4JvGZa$>zT*u#O}$D0MIhLjDT++l61U(W+b-M zPdBFRl5kOD*xDK{+BDAE89uxtoH%wxxL{KR?XUbweEgYNVe35{$}!H`8@4)3>kXXI zVOpCMy7NCY9ykNFMPj#l$Cd3g7T$=Pab;_bh1U=VFmMg)(~OLhLj09D5QM$FQkoXA zG)7>jh;J_gLOM4P1~@%rgn+&I3v8Zr5yg&7gF{3YzKWXUv<{xT zcrzM5i#+7`MVf~=76o*`q}jn1{+(NU02LKbOBMCYw%t9&EJA}<3K7jBoH=mVJp6{4 zIDUm$@G^-jM0Ks>Weti(APfs02S>Ew0Hq+h00)hgHQ#rpX+bqAjHt-U@Z}4+tO~q4 z39{YL_J)04P!$(=8Tw!LUjm^RlmKr+GT9Ak-zPMO8oO)_4qjz@z_uVHqmSq-$TvPoVWZSX z-9UC)3XhpdJpTL@LH5xWco{wHzw|HapZ89nf8PB0|0?}6pD{Y2ZhTPdGrj7cFSaE+ z^U8Ca&b;RuA>wtrPEP;CL;eo)(jX4S_&Ua0=G^_%0;ct}u&x=`sa6$9g>)M8g1?`a z%uq<{deKJv5%6WkWz0xzw2BX)C~DHfF&O|+cg^RX?4{r}AjzT+aiNt>8Uyg_4TzhcFr18L+0%jDHhm?b~Q9tm6aH1nmRyUN#SJGZRP9 zKKL@LmC|(`;bpy0n;J1X|1Nv;KED3Qus8iv$e2lFu2IN*9?0};Z}w1tGRHe{cj^9= zA(^SY$wmGeG9`N2YcIhU9~{-9GuiRr2w!debR6Os#LXh{u9y)Vq6Ltpc%!^JVHUX2 z;5!WioZy^RQme!TmQ=g`$TL%!;O@gO2R@zfqatl5$b4BA+G;%bJLG$wmuwhDK!fgo zhh0t1?lyS)*^_DnRmi+xUwn$lhJhLBn8T5z1B7#Koxz)U?-;d%_my#>FH8xs%kc>c z*y=2)3;r}B1Rj)ynCP*B*S;{lvWjG7rm76m1%LU>*Zq39Rx7)Zim&Yq*WP<8HC%g2 zU^|_rhHDUKH41}xnZDSdgv!qikiW<3D)AWI6p>LH+NcJ2rLjRvRK`MNypWHpkg?EQ z9|%Yb;)5pLMhWS)2h~um%HHh)4KR4ak+OR5_KJRTfBN9m^tJn}5LCc3|ZKA%aS59Agd&tYl>h)@Y8 zuMR-Bm_-N8vg0sPS|yj7MeijQ_{(NI7crB+8xM?-*W5S9(aClgVX+ic4saQstH2-p zV=FbD6n+GGOWQ6pJ2#p0cg(s7F*)$rz1X?ukP&?sqAL|g8oim#*`ogD?oA@CEHn^V(L;{78*jVW0>o8`T0NXf` zLlCijj>qiHG1Gt|AkFKr2DBx)8i|9vt*hQi~e?3x?pQ>b_dYGk>n_fj{jznfE)C_%! z_35fV!J!z%u|GiwJ(_fs1;kv0Q+y!|ZfXP(Sd%uBCyq}VhkZ7~uEaPC+iezMY@^gx zxCl=+h7WHG!(xXE63#GkoC`-iHkmwl{5=d3VcsLwMx1MIJTOK$!5PYmQ=%(_dj+-X z=tc(}@z}^1kW)F}mC;&q$S@slnglfnL(F$yp#6o%5r0LH@4~F~jCRWl4i+tj1*Ard z36n!L={U5Fq)_8dt^UOEVe7=-LO;V3d@pRhl;rjIOxHH01tAf@w3H*(fIR{qAF%sP zYKWQekM5p8F9%R-hzh+)MEFwP^zbQljm~g4yWPHjEat{q|SIWP>EFXOVHh zCzarnss{U`3xzR0P|3S08M74}aZtu}8T>HgR>(GlcQW`9ya0YDenJo(9q~x4R@UW? zCYs2Q&j$EN=R&$T=nYw_Dr!%BA9f`WQrnW*o3_BVTFC)rM*YTuu^c{hwXc5$rf(cI7Gv@zTMi{*-LLBDjHRhkfTv(RzBRyeu^C~BeclI+@-P0ez=U_H|!fyOrI{-g74aCo_9{hYe2S0b7f}eX%MYdc5 zM1VRth!>@}I1S|tGqI=COzbT-bHHnF7n(V*nTdCNX3pVoq9s3^(-BVW_KwR*gcEx_ z<8n5R%YnR3^qb+to2B8zTgBsY_J>hwT+Z8Jlp2?Fn0ycb%=}2sQL+PJd(E7!I55#; z<}{l*G773toQ1rVrZrEwIrlFE)t(0tvf4g{LfMd+q4`jlLw#m^Oh4(YIAch(eTj}M z%!GY~>1sqc#N6D$!9ij-GVMky4a4JkKnc2%y|!};B`wb z#!CIo=w4)lI&C&L@5K$Wb>JPcHA{`r6|7MmG}+Hbg%#cFGB>{q{QKpHt$Mt=!pvz8 zZ?-Yab=`Hh`6uAdf4d_k4QBL+*N9dNgxzS*#8aT1LZ_fTUw08yVlVL63p^Zjp$-ov z(LIKDz~c~D5ar_2A&DbSqsFZWm(-&+uQBgcD1g=+z>gp(^aJqP18?$J8$FV+7K=`j zkL`Ml5UVJZeb140`WdY;#yI2dvC-vGGNlKqi#~F z3O!m(y1(|)3q;>Ntdd(^hN62ceN;ilgPlmmTa$9FwyR3BkMWSdQN=&@QANz%|2#;* z_{Valah<|i*7IJ*@QeL6ugf+X^OuP7K~3HKmKV@zou=_@BQ34$D9o|(SjoT0-z31t zd%Sd)n+4idW6?b7hB6HKhe@`T{ziF&Xl6DafO?Q48D6eb#yajk_Ytko?*Cm8?~Q<@V_YP@7JJ5n?^6lngg?rFcuVT}9>+ zau(qLb{USRA_$1DtX7ml1R?2Kzy+m%RfZ8wf{vUd?wX1b09J>f&rv&W)K<`R`EbJx zp6Le^+ZSl8ov`ESbx4>4!JIUczgn4k6+rSx41@ziiCMrW z@==c$vfqnI2!4+znw>ZK`X;~|pT05eYjo$-NmFY5g?z&nQ=*FXO%-oSWb@TMcz8Q$Dc#=Lmz zPQBfjd|M%J?V^oP8t-eRk@8RCA^&ov4`#a2fVumnQP2m{2IvDxfqb(xnnOd)CU89G ze~x7!ThcMK3yc0Jk$e-1EOWlIcD$TFhNhTSCLhTg$Y$Dq3)vBI0$wouVmQqB;R8M z676tJpMVkDUFF#M;H{gv0(j7COxD->1HhU8v{ztKi9q5jC9U;WF-2gp5n0T+Ybii* zy})YZJv;Fs+=8b_%zD13lbX@5O65QUQY}Nrq*R`dH+8xY`Z1;QitQisLmNC1^dT)o zkqxh+=m>(i0VQi?BT$XFAlwa6(UYtFHByl_XL0wvf9s|aAALA24hG$&<6za)i$Gl4 z&a!RyO`(!pF7PODwc5fa_2K0m)Q7CsVJ#G1#{3Sif*EUYpX4ayv*litCM*j%hc&b& z=-yeI+7_YPzBoa;?QABWu-jtp)|&*#b|#+;h<%G+boY%asgMNP`CCm%-5nX|=S-&0<+J@j5dZ2MmW)$9kwt$+B+(ovkm(; zbzW5Nip0)rM`D(}G4)4nUobn@n9-yCW`7FtdJnE#cl9@8rCgNroM}PsIM)m$qgV`N zA328&(IeoLeUbC$Z-Ho|Nf<;=hC;#^9NaA3&)_1s$87sNJ>q;b+R)A+gr4zNIzr24#_p4A6{bo zcL)#r8w)sDgPi@5)2DJ~8w-A^a%LlEzRKw~7A#ab-N=cN9$^kJ7JOIb9Dtk{_Yvkm zW5HKc&VkH@Rs_ruBTQ?A8L#f3s)^szA#>%?x3S@Fr?Frta%1qCeW4lc1p3*y#hA1d zk0KYkFf7I3vk|Y*fIZ-EdE5_=F&ItYF`BSeJq}&iALTGOWo|U$aVIzUVt2mEjb>1P z07&RUH*#ah%iIHI+#zrWASZ^uggbD?c&aA!srX_rA}lj7g8U<{1S{eXJyvR3utYR{ z_5{iu9%0E9;tkQu7_^Z!ScPDR;s$#{f$;TSpCmg~@~TQ+R>^vm)T`tLm8?+7Q!4qD zN`9h}M^y5lO6pWHS0!T;5TN-I{OKMK%mtCbeiC5^+_0Tqt9Ei$%54~S+^6^ zA|1e=68EM%H&Km3K!E8~uhZ$P3Z+0K8>ejx878rStdOj&0Sr;NG(&W6_&_WtYr#yY z;|t4dXqD;OOcKt%!HmnI3~e`9hu6+Kq%>uP5FR*J^0~*16E<_C901rxA8n&uBSAB^ zF^Z$=pXal-U)mebmX2sp$*_7*>+k3@Ew5emjrRq()LCu)&CU(r@!VOTsRjLxc&FuK zDV`@j!BscRQ**R)dP_?DkDiq#{%PY)k^kQ)`3LnF!2|vA-igf`44yF@5*4m3VK@aAOYNLxffSm+MCrM z^p5VYO3ANA*(3}g#JU7`4o)Dr%cO&Z6&GtCRr`p`oai1PDSzMvnvW4iGV7tq&*c;!s`abfA8mE)t%qtc8KPS*HW}<3Rq; z$-F-11^UN<{?C(n^O+Y7IF1I?Ci8lk7fm=mV8(Y9Ob_#+0mlcD*$@Cy7TSFv7XCRY9Q}`&FrV>w+ z(X}(z3_#ALsK|m7O@|5KnoY>`J%0cdx}DF`)qf}^{#e?dFyaRV zEtw3h{hNTKQHtM*dEhsU=s)Bwra6va>ZA2C(}j7ABmE(R_l+S(!$5-}A^?U@0k*Ua zyv7>#_i*Q$aM{M$pATaJU6fw$S7O7O7+Z)wCO7`g<4X31%eGJ5(kir0?C#HjLlG=_ z!YpcU8&H=w!0fC?uxWM~6*O>Vn53*}+E?M-h>8u+*8}?P(?;{kOH|v z`e%%c&i}xiT|uaZxpvts2q)m0%&o{I6}cW?gcvDzEJxYW)Cdz_H*d_ zYtf{ay7o6Jmc>0uYJzGYB0@<@74$F12SDh(yba;bM7Zq8>|x=u&C`6>#PT+cD@#oK z%r&uLFOMtP9xh8v-QI>h05uiuU*(Z>-Q;baq7RJNWONhc4U!p1qIBrD1=J#V12@@hw(O|!}67;y0^yt!mKT`NXlTC*F z0Y8kU+#~+mbd7S&5a-DU0EOHi?>|1x2Cj1t!AqC@!Nc$2e6eTXB*fjz9(fVSp+Vp+ z&v^i7|KU=#f&}ehG}>}s9KOmGb7!rQ*(*F4bO9c$b8lF!_Xbe4;Jfo7c#gR+`Q{xi7$tdF=uPWc0(p(&&-l@d7LV}Eyv^XU|xVaS*8npQ4`hP0<& zNxs7^*oz>dJmc!|-=q4)th5Wggu>mPkF{Wnp+Hd}}O?`=_KA$qJX~JK`x-PvSFhsFrWAr{>yXJIaj^ za9hg0fP~QqKv&nW7K9`f6YCXhDc$|Of1uf?+Mi=fg5=>im;3UobaF4hO26p@?d!w$ zcJ|GWr11kjM@i!cGO(9{b$h@EDic_hHU{`94z=UI17n=vd%LA@P1DE87mZiqlSRGSJkndE_Mox*Amy2N)B%XokeODbASkL4tkwPiFtIWtjE`Ko<5|sF%$>}I(nQ?$!4m^5cSaO+tAWS>_?sj)k;V;qK67i=eSN`;@bH7gH0<z+L z;`h<(pCv6!3Rne|34}r~hR84jY9S?PTu7i2wE;GTqIs(VFa@|#B;q$1 zyT3?+D1KI}X5;Sv`r{L-jlvoD@!A`|pPbCmULuI+BRkcwwICc+(^9>XW7~Z|ST8%U zU@}1yVE{-fNChsozYEWz8ykVv3fM|DRStM{0N&cb$PVUgo-(^}@KP;9oLwcJ#K9-6 z)||VX*a_!8SwuX0Wt&BsK;oBbc?U#n3=G=}AX)a^p93zpVL)g9*D2zmKdzFWNdkSg zYLzBi-2JEhTTm^UYrBRrFWxRmy^SZ|?ma^wt^O@E+l{FeIvM(^M(L~nas&Ul`$h1e zuY{n`SCXPxB6}%)CH&1P_evH+|C*$VOu6r;2Ky6s`AKQ6#e5XMsU7CfSa>!|U^;aP z8m-k?Jue+~RwN5Ks~8&;B~i4CEIKLq>Bufl;091##PxR*%b%K17?VNJfsbn)NN|o0 zR9p*#CH-e#w^MZBE65=_P&JFo2=G7Fwn`_XKcUIUe_eE-0!$sa@7yHv!U7J3GzYZ{ z21*B33cpD3Y_Xc0bvS8K&zy9N{%lFv22I*{1ZoNm7w&_hSoAsS6!gHtMz$J!=_NF3 zo8^1}^s7nbX2C@CP9iBzMQg%{8aaXgCezhS4cNl0sDd5CZ&@F_ln~J})tVkOp){TL zk#vKAF4FA->Fg&#A!hT$V}kX+N6FmiGfXfyS`BphPczj_p)QOyU-S(z&+ktVK;|=|wXWmz8 z>&ZAd$SWFG1Ohr(G;Y0=)EalWz6sdRUIu`=8(TRM2IX++bB@LpNuV{UoS`%>C{J|` zP5Tf*K+~eS)Le%!VcGWkOg5N?#1SlEH*gtbh8p)sv(mT@(^9jNE2RjqA@J6(iKgA! z_IpRus>V}JmTLQwu4zl9=d`A+m%16Lz1&aGy|QI$r46XQST8Bb(6oaJfXi_SSiA4M zM0jW_liqj;7D+GxiI{flX7_Lf;%@W{js;+1xL&$AbmR z(GEmi|0IuY>MvOkZ~c|Zf;ejj;;fH2VD5BdJ{qf;qa6qp*Qh)L2!=~o5GnqiJi2qB zWbqgaZcte;#OTN|7MKp0dvX%*cys=ar>7VTE>w9=As8$n=s49_K%2o8){-R`0dbWj z7jFj{3y#9Ppi!7a4h{-pS~-{lZ>r-oW5I5`K)X%@B=yWN7W`G71&vTnJvqNv0_?xT zL$ZG12tAGe7#@t6iqfJ_=ed zhRZe>an9(ED_dto>tP43ish{cT00VL=<*$r_<7g87<2_=!m#{s?s`_9odttC-P0(1?5X+v6 zt8o0Pevz_zBl=I6H7Jy9n0(LZSZIYOaUh?_0E^Wn>#g>5fF*}R)*G61JI2I@{VY_n zD}*pfF5vEn4STF)S2%u4{|G)wo;RHnhCc%Akkv#a(UvFP3AjchiaHp}EEF6s%Auj7 z3^L=ckhM3M*iZVugumRJAXX=Ya$dppU)6oi5w;J69a)liJ0Ja!X!D|CfIOA5h0b|5 znD_?)ypF$Nrv?*y0bmFEy;8M$P_sm zf`_C7zSu%YC0K_@8|SHxLl&&9z%N)=p{J?Z_y{>Y!MaL4OGQ@&8T9;A12cd_^MiHO zltXA8+BgS{o}Kzh8W=q}b-w~L5M?|w?y-)7fr52hFLWel#&?|JIk-J##?1}}r{MO~ z84=WeDz0*8TuPdwSO6O4$eT3~$}7 zl4_NFTP5F6$;~Pmuaa>pxk@EhsH9XSB`P^zCFiPSm`aAI(eYnB_lVKlv!9_>T3%9ddt z*2=S_eJB*Zei9GGHFE63LwJz153_jV*oR5H>1H21A7dY&#h`>bA-l(*$W{kSj#2qT zpB|u0cZ!`T=fhEcJQJgUKzi*T#8&(TZ;*tTGvT3$STFVg#^HmI)hzabGAiQ# zhaT+1h0mth2gm>vT0P9eXMfMfq4`-Q4OU0WJY=JOWgeiCjzgy&`eRr7a5XBiM*77% zK$wy5!(eRW%97(DYZn^L)*Ptt#V8VWY%W?4=`i?RGEdDFbf^Y%tD8l z1ruhWgJxkfsajVdiUnq2qpB5Vp@U`tZ&70f%tD8l1yjs|7x8p#1NW^CF$+~Hxk)A0 zspM*vgj8~wN-kE(msC=yk^+?sRmtfp$yJG4CC3j-MTb?=u98-j?2!ca0K>N72yNmI z`X9z&qjyiW<{La$S-H`0Jb)#*jkE7o-{SS-+QjJT5NwEN?!ZXA!X@+F zEr(;qaV58{1neDovpZ~}3rPNVj2JTR&37)RCnave$EmrLeA zQ9PKa_mo?SAQVR=KIE6L2V7&o`oO6rzuejsM1MknHsDz<9J1YLL1VeK&5<=c9(Fq2 zxbhsja4K6lSF9ezqSO6?;gC7^1-OG@$cwrFw4^a?9WjeuG0P4c(KW~d-#!TSQ}&)Q z@3X+Y^%)k!Qk(m}2{74reLZBYQP>S~YwSSF7HEMjP;F3+@LBU<`#8!8SzD3{Q+s_t zt;xw0%E3-D8%dM+kk;7&m+WU5i4Xd(oxspq)3zrmp|zhP5_IEAwzTep19g>^SI3AZ{Y@>$1aTM~(PA+?1n23VQs^F{p)fJQc%^ z9Zv>bV`90B%B@$E3K|Fxjl?gif10oI9w{%`TyE{t4)Z@yaPpaeeA&;J^Y!p&%S&28 z@hy1HQWxC6l8>R{%S$$ni|2Z2+2(P^t8F~0erZR*g<8LfT9Nk_L^9FbPiBP~TU0uA=+#fTK#jh6L<4_2WQV7K+iSl86yz3V#S z0)V-CW*9oXigkGHN8#v@fqcw?D3XMz5VD390G$BPF&h9kfBKX7 z^-cc;^MMTR337NdLyWw~Ly!ICYt=j<{8hl0I9o^o225vOz=3IR`%g5{ubY^nH^4Qk z__nN-o4fx>qGCPmU&a*iZI!z3^{&8U%pE4~PJY+L+Tw$1e$EICnvYo0^HONSFg%9ZJ?D1gKyZe&riZVJSyC>c&6#r zPNoc?v1k=bRr9KnS2KBq{?SB6kWM0RPB;&dJce^)?r$&Sl&UfR1p&i&dVD&2XtKYZ zT-a{kv4#P>@1YL1+xeyx^VP9xbgt}=gr?9mU}#>-7-fKSKs3H496VkNd5{JC>rB2) zXKYvujKmdTUhFyQ@C46(^%ZlYAS6Aj!ofPCO0&;U+cKte*RtREZRFc>i{IjD7 z^yCd?V16;Ozi!*a6voQhzbw$K4lvSyO-H)cu_?_cK4n{v8a3%2YMxe!fB%wJHte75}YK zj=M{2rB><*3aYGv^A^-GTCFt6bKU=Q*Dk{?#qE-dRh6s)LY*{nKg0n?ZBHV@WA9|b zMfD#K7l!VxQ(nNQyIHc25KSKLaq?zX>vI@&3O!q&Qd2a~U!*Z`Di_6uj-g^Z6=<}6 zml=~(glfRGQop1qZj}C|Z9bOV$r4NinH^7$UOHl_zaG`ofRZR|gir)*;wW5^3{4q( zMVsi9?=OOgJ+2lTL!W$%K7ERiyRDBBe`3~j5*L0zhj-T1yaZmr9c$0#*UuP1MA2c? zoe8_2+1Y4XXeKBiT>>d#+d75KCZkzgv}k(;L-f$2k0uq!u$LX3xaTPG$J={SZ{Pi^ z^LDMgwSN*r>q^rUNJ@W*zI^%w?YS$}o``M__cIGX0{YsZcQYGw#XgPlx<`@?+VPTu z@?fVyPo~~pmTb_WBhpp|Nem9<=-$9m8~cwkp=!+4FW&D_g> zXkvNjllbjNOQ8A_QLVSn!dx7dWnG1Jp>40&ofaB%NvbjAKXA3M1eA|VJY!nW@Olg{ zf&}&6+l>Plk+tSd|IF0$@$`11bZ5fwns|;2WMI}lJVX(nldagf2sjrN&PA1TQLQiP zYCsL=`XP1wdcqjoFSUs5WbuE)!T*gk{6FrY#$U1#f4Lz3azXs%g80h?@#lquzg%nl zclC}xwF)``M1`9Q`Zst%|2GjtH)?;4#vAh({5QN6USlvm{@~k7c5QUoVHjFoHoEL< z^yS8W_6X-`KfBa&|7s9`9V%*kR}Lv-aiA<;C_0 zT$)i#LwQd%2A_h@B@OS@?daDX=)cj3L$%>=jTg`FdfV_`+0KXL%G-_V4V}ii7IxiQ zq>GqRjC7BtI2W09{;&3!zi^*Xc<^>(+CQ@av$+#6w&L$qqp;Cf*B&wkk1*D4yv7)O zHSlQgCBd@(-r)5BOtD$A^h+;^&#zER;`du)-5$2*Z%Emmzu|AQ=E1b0lHXb1Dp9aA z%+34E0(=FVTIj004>%o;zM)a&>~H6WL&lT=_&WvA6G+FRN@y8g`I1+~$*Vx}sv>z+ zmAtBUuI{gqE>(c;*D@$j?_VZ8d?a`3#mUUe(=*rOX8O?NyQcJaE$ZfVpf_h=It{wD zPmk&g4~2{={rK}m{#^FAwOg`yanX(qut)ru4PUd|ZW?#gaFiju%_AkQ`{@&t_)d4p7s!d-!|I!>1eh z)4*46;Odf4vkOUe{WT|g%y$X=lxD5x<%>XQ4%Kki_9phBD>o9|%ie3yP3&mI1v?i{ zZ}9?;(wz-*?Mu5ZPP-1IU00-CSEXH7r>=im1Hz=;N-rmC`ROve<*K%+m#5{Co=)Yd zN1o|trM;KlPQ7ozd%k_Wfxn;uY2L|3wBW(iy=Q|cJKo^s-_FMGw2vUPQ`@BzS>nK2 z@X0~}VpKO?0}gM*g9oKUjVVna&Ng#>J&%|q$nE^u!=EQU)m0!<-C&c0cDTPd_BSt8#N0R+X<-o#L;+VwrRI)v&12 zAlG&_5gnFsKC#RD*W76ZN^tIHyX{JCBN^;?*aKeEWe%j zRm~bm6mRr8qFCJ`v~7{zsZUBJCF^g}ns51-b-%pdExor^_2ghu>aV!2-hB_ zDo)GzH+d3BmEV(AeqXBm9x1PKS4er4Q9Y?jmEW6IzAaULuaw^@wN*=bl~Kw+A+$|4 z;mtG<`%@s^6cBF`#1jvZyku6DS3y~ZhbctfN`vx`6qL6F%6@^e+<~IM`Z<(d z#6vy}$7NcFi^4kq0f`x%unu?aZ@nCv1g)Io>Y`54;%jj%5k)Q)a>~!6kni`v31rBL zD^3}5k`$|(Wd$Xo%4*5vN?EDMEhJ>wBT^Ijx#f_|d?Brr`=@1%Z8-6de&No)lIE9P z{@+?(m9N1Ch$)P*ft|etM0bT^*XA-~ekfLjrBNG$2C03ZnN3k);~*xcxOA;#Z_wBj zLM(X^`Yb&6NDUHW-dSGWwDLw3c?ehCitwW-^?F%Pub)o7Uf$E|)ydcOJ-vP@`MRm6 z*W4#X)!ow5>;1{s?LEEzh_8()Dqw~SwGtK=YU2Q0sLh>l@hgA5%KWs1P4Hx;zePP+ zEz6{V#gt0zEs)uFZjxWxs?wc1P zpA0MAhf^v8|1ws(zo%4cPw8L4O7q5)%Bp`EE6qn!Dz%^XFJPs4ZpxAxbmhN{*hiWl zmQeIg78)68$ublSNB@~?%;W9=p9lm6_Y)PYN5Sb+KT%PN`zI>cq6;eD_jO_T*F_9p z7cqQY#PD?y!`DR&Uq41d(VfOH16ShoAJ`<9K0e(lmlUG|JLEFJ%e`_*Ha^fMmsPwx zB$s5P1IOTz_QQp8+vpw6!6;E2I9y&w(4|>_$K?cqF3sA7%Wn{LY1TWq{0>2vW*xxg zRDv$eI*iME3A!|^6PMY3{2)k-UxZ=si#b^Q-sTVB7asuQ7twP3&cZ~Law5(64{Jc5 zq=sJtC*INU|3*bP%nut>4KEFrNXV4ogDO`O?=A^7&|+N@+BBF{>s@{Ft>c!W^*eje zq|AazRRQOCjSdc%gp}_nV+}E#Q;H?y>tZmsegZ8l7zJo^_p?8G$H>=Lj4Dou(Ngr9 z&`4NiXAgEkFskYUMylz3pi%V+G5UC$K#bCy@e`6M&_^;oD|(PT(_7!Ib|@v{(;KCp zSjKE0-+iiAKAu?5ijF)HULS9*gkJT1!>g*V^b$RKBD{98LQ0<~mR{-A(l@*m&-8&_ z?SOYe{`&XZQB?QI2SK3FC$queu^!@9#3ezp|DSz^Uid%zoN1q1Z^kq(xnr20zg?`S zV^~Fe8k7`mVjRGU;J^;Dm}4>dA|;WIG5jkEXhgEh!)dH;LWPv3Wss@Hud~$7f0;M$$TP4(<)1QNieFHHLHW}ZkfcuGoCVr~m zd`_7J-*ZYeT+b;pr8Up8HDP`vKJQzIWrU-xETqQWJvv`9jlrKa{Au71rlm@EzQ~_- z{8>*bEvW%q@xR1zPgBtHcA3=r&x}y|66rzuBC1F|@}!5-mq@3i-nZaAYj|C<>p?;n zzaG?jk-mhumNM`0KN-|A8Y8Zcaqj5T!KIU%gEY1Ha`8d&T-bJFixhy z>g@S1y_$7sj4|c5q3sOJb&1J^F^fsB`vAS*9h|Gk7-jwM=?(D29IQpsfxo$H84ql* z3%`wJ4GnFwCO5S{Bc41Dw)IpA9@c^J7(A?Dir}H72p&Gfdn~h*)j9|wlAjqolr=y| zxw?nJL-H}#261&y1UR%HO%EQrexrkjo@Y)vcsR`8MQZWsWpYf}jxi;~52I0Uw_L;2 z3tzVv!_|x8ZZAfu7lCdsBI-p&w-*!Di>hufCaV|K-CoQ};$ECF9_9dhiVU!)$N(Dy zOsY5;U{8?&_7oXlPr(2iu%`@#&c!gEnwN8%j-BSKE+(9o8ae*m1K#R{ANTC`Sx4dH=w@kWl%oBcXBu>|Dos6-9$eb=mZf>!AUzBC&H=t zi=;g1 zK@PiXJXG|_y+fk$5V0jM_YjKe4Gpr{|BZ!(IudeT(xQoYva#x+fT3d5(D=BNSTz(a zE+tki0c91do)F+u3Bp2%aVfFt301t5ST)!bmyA_oInx|2Mwr9J2y?g?VGb7~%;92$ zIb4h|C%G6w$B|nbFi!nsz;{aJ_)B-G$f$|<*xc`wgL@@W+Jvcl68y#tOBc0&^ zoY|H^05{8*LBL!PJLO$}K9TgU(LDOjaH1j88C`(;g=9~@_@7_O_5ZhSzygB20ay|= zt=Wa%aLI@zIU1+|S@B^L9sCA+=+`hB_~4NKLXQi{Jvie6>)rKEpvcs^pvn1wFa3S% zoaE!=3doH2U)t;xOTJHyH~2l`by%zK(0(S(BS59+6%Z^nQNK8_o? zo?jqf5x!c$jD`8mw@fS-<)*qncvSXw9Xk0K+ascYM_J=d?do$q!Y z4?dIRciT6CX<6qaBEi!EfX8aLdWJ7Ta7?M~+g!gnVXRWy`_*E-)^9;B?9UD45WEV< z@|xs(6O;tT_~sLzYT5U20T#ge@J+D`X+G9~4a0&J&+LnMOyK4{W_+rg;DHZM0z6|o z%CE#C$XObWjcms<+JoFct?cO3AGJPY@z(P@m3&M=Hr9 z737f$Qm%?!!HY?XPjOYvD=>%bk0zVCso)MD`#1_!qgk>QZsJvKsIBC;Qv+ly6iJE@x8nozNC;>^DfrT=aw{C4N;tN z8^7qnd8R9ty};Uqy$hmyuZYCmz8VvIYz$kXcHZzt-@(H{r{2eh*v4WPzGIh?XLfv_ zC8H%B{89=#B{e113@h1eZH(?lfg#%kO78tZZh+&7?!mM3)(Mcj#U&d<@`*df>8$aB zXJ(oBwi;V<1WUH!Q*HpjC&-W83-G!3hf21Uyh0YnxxAaO1lm_}Bxt>iEV0}NLe_^t zY-kaTzJ0}*SoZRu^&$2$!VUKO_#Iy4^98mW`hCzkl2|{CTby7E5LAh;zkd|8j$xY) zG>-c`VGAv84Wix=5AJdleG`TAei4EQ`+_Bnp^|kahf115C4VQNlI(A62g{-0rznw!BmGS*FJ|zDKc^KbZ6^3!_F}4gquYL6%(-m=Tva7DC z?Hh1K^}BFHGj4d`bBmd1I~!*-P%ofOyr1lDY@zxSMIo{MjQ+$N}Gh>F(Ts1jRG>@GG-pvha97=Kt} zVoxdTAA*ew68n7S+&!IHomns74_$>#EOE^B9-mo)VmS4z1b4gh&5~^dfZ&&5@Xsu0 zH2>I+p%nkj0vvv@l>ieqR^kFEj)TU*(IuNuV1)Y5ENC`gcqvQ$XBJ=!(v5QuO+WV z_k*t{gN0xp@Z&bWp}$_^2V!2$jb2{ZubLhhVVk7A*&!=&cw2C5TQFMR5f8O?Kh?iXQ?JfJ}>NRWG6}rC-5rL($6f+tum$%w)bo2xb$jK}!QTgK=0a_aQUqh-u+VT-c9mi4Iv4 zz2hx*(BXys7dgoYW*rVFY6Vu@8)g8uI}y>__bKXw1djO00iWXNvbM9Zg%g+*#}aN; zdCzBFN@dPAY)FJx@QH9X>t;xEt}2WZ5TRpeK(Kui^A?*qc-`hVR#Cc32^)0>Oe+to z_^*Yt#Gbbvxhn7pf?pMik z*P?riL9Yz{?R`Iv^RDP+KaL^GPp}`yoSPJP!^hG7G1x70KaSx-pnukBYR zezPE305KU9fNX&b*uIT}18Dtjvc;EG>PTs7==WEGdo@yr5t z=LgE$Qd<$&H5I`1yO}caKZ>6r=VOr&+$zCt`O3%OXDqlv+2?fq1VW%Z_8}=J1uzJ3 z=l_$R*n*~UEr}lcx!fLhAb}SwgypslNdqMaP* zY5dD}KW-+qoqmhyr}UK+c8(sRr8jTmv%yipCrNk_h$0uh>>l(Yu&D zi&pUmpsSRA+@SR%s!NXN_Uq%|(A?yBE;%X!skRCoQllac;GTcqacQ~^;7UY0;E+Qc z^p0_y?9Id-EV;=~;_YlRHgZHHJ{o7%c6g`$r1e6)L0u#1+(A?pZ&iK3L0GOI#DI$g zhuRKjR0sbTEmGq}h!2!evby-a7&h+08K&3~>J{nf)yD*+9x(!)ssGvf9Nwr}G45ln z>LY>lp&uK$6%hf_uKOtUia?#V8@O@=*&*4;AGM9{K0K{V(p>QfhNnaH@HCJy zJhh*BN|fjmDp{tI$5iq|mE0TwcYNq85oLUz z(MO8g)2YQi`t`xysC9xq3Q7H|j|s?(J~|(7GWtmA$aKzNAAKpK)^yIes9PTy(U-{* z4kNA{LC#3_(<80R6NS(8V zgQ&I(U#)Y;@y=zx^tB_M_U9kQ?gQsc{-D#I4T`UGPsJ;28~`v;9{AiG<{>UU_-iK- z-+EKaglI~jsO>knXR;ID`dzKWx4y&L`WD}sQQoD!uk_H~eZM6|*SS|nduN^h9vb*~ zW&;nKsPfm+zzljC3%;Y|%cQ;yP~Qe9P!%}c34aw3tZ*?|1C|TnBwkhV3XPPFU#6pJ za3ni%{;w*8(lQd|>3qms$jl%CITCCMa5GJS#LcM8LKS?BjFnJmvS$=*5X6#&a3#Bs zIMr0q6v2VRX$3qoPg%p*1k^kgKyC&Q?od^Phelz-G#&^-*0rmwpHscS-3Ut^P0T7QA(zf4|L{QKY1basdSj$#Y za^^hYM!B`y?yG>ztW5VzkFOcDh2sDlO%zZWPxz7tnfTt?E55=zKGSl#O*caxqZyTj z=x9(mP^vgfbu@iXT_TC)rNFYy>X}}~f>BsT1{};Z{>Aw5qvwG?20~vtKh2-g#EYFm zc7?NsjuR>ZgVBMQJ9<5~3X0#$J&NXUVuaTk3!F*rSU+`?C34eAB1cU zWAD#P8xnxq^qwU|0UUQ_Y0SM5vTnw|Ur5B|2zl%JLNmsr&e35Qu-z;0fVse1+B-a8 zb)_%nzE{EX65da#9<1xV0uSw|;z5`X7Kq)W-341!;nccfoN0$({YK*f?%2VK@CqBd zu|^R!d&u3~W=RGN+~bC)Mp2jGY^nzuqzKRAkz!H=D#qS3BUPjr#&i&N(7Z5u=;FFz zpEf(!ptjkc0w1C3YE->_>h9JeLCefX-qWxZ?$GFm69aW4PfyE?TA^La4o+=p{Xld_ zQppa@L9P=g#XiC6i;?M)70kY5y`92rZeUF|%@Zq!mCx`qavT-Z9B)mTk- z<@X@SH|d+JdGishrybSYGJZa|>;&WIE5@b?izws@lDU$- zq?O+OAljQYe$LQm#)7kyJw(~`@dqrU*=f!_(#bASW+(36bA}$ZZ8%SB8N@CJSh;nK za?U+Mr*PJLO86nQfs!2vQu(pFE4J%*9Sym-LG^3cu=}BMYuJ)2tx*q|oehZVMi4TY zD<0+S^JAly@YCWs+&dRLa9f+P09H1r4Ig$ksEw3uocdJTZIrYgPpA`T&;5sYyA4qD zj;9@SC`U1TGApYwmN`7)}|@INc^YId$~`yi;&^|y~U)?)j2fzK)>AGEv_F2~7{*}*Js zi7Xi-sf-T5Tn!LKG9k)V$!QS1Nr<_b5S@$;#JnU#ZzjZkx-AZl`ALX*nGl_f4#Z(e zi20ci`*(rpOF|r$3DL>uK=dae`Z6JAcY#=#gb0GC)6vQ3KpdWgSeOaX-34NC65{Yo zh)zZa;>aY#;!KDGxGvnh9}W3L;r%R3?~#H3=`4O1y`?*<>rF z8@TAZ2`gD{Y$x|VFdBC6_=Ye-TezKlk%+`eio!YyUUA*&B5QT2GfXq({YvPjLfQ^Q zU9@1rl+f9v>jSN#0&@MR2iM%!%NeraOCjw~XdRdde{^^F8Z1R$YGS}o;E%?{JR0fG z2fg4~5S=J@J=}K*z(47z*i85*v7Q6#w%97DA^Oo!o~T~@yX1H`ahHsD?`3_xj&}(I z#Q{hK1T*pZb`SOhx*pp-MmzGRA!;$`{ij0ktcSeCq^xn;=}=4k2o8EaX;cayqlQJi z^4anypxe9M1e56X5U#GnUst!(F6@4$fc$)m4*HGl`p?W>~aDa062Id!JK2k0xnq5AV?S zbf2eyD2cHGJn)(OvfnpIQwkYdEvBNk9}g-=s8kFf+X<7$2yWc{RLG%$JR}8X9?b9s zNFZeP*ez<%`a&rT+?(3qgBa*86@XFw&z`_CpFw|YBNc``#ROFNtQpH*!_m~k^LX$%C2weP7r9j*x4QDtx$fbC&&b{;sy%naaACsTw zO8zGM(p%B|H|+N>M$5jG-ZG^DQuNR0ShbGp9M!{ct_I6GuJnGi_uNVG<~l7LOnvEH zf8#o>SGx2kCJ-|HK?N6VN!A5iG*8H2XJZJ$r=kneh4=eXjXe_hxBY^(`B)nkRGi!P zLO1^DyZ*}4^_@U}xm3-6ya+Y-s=rQ1KkPP44T*MM&UQMIQfG^#SWL>AL{bvHNy_BK z!kBkeXAt`dHvbph_;W@{7kWd7zy-_#*H3QPC`!U(-!CmsD#slo(L7R8{Y$k6lUem@ zGookc63^XVPe}Nl2umdZ(MjDy9eE-rY7jvUh{Zs)?iQUJ`b{+N$8j%y$6g8ptnkPT>OaH zu|YPV=f-ZyMRpk@8H5g1dQ+YN-NPXxq2H#UR{**OK))^7aq&e3 zJp$-?X8e}C+WwK)Rh8jrN5EKkD&9q~!SXTyxCZC9=7$k?S-1{&a$1Q>-YG0%X ziZ0>%_@J!;s%6$So=SjP1#QS@kk)6v-H(hUqc`y}gpm{ohgtZ=+A@IRmuv*tx{`Za;X<0j%4bzIH{G9D;hi_p8KJ_&YePYp!5);BT7 zY`^}XsK3`#@`_3tRgzH2A64>ul{~EycQMReF(9P$ne4~?8?tz}7(0Bij_lbJpeFyZ z_gSEt?YG}Qok1Oru-A|AoR8j%xo^EpjP7~J*7>a$k!>KZM*Ug25R*u@YWf~3(1cgp zk;z_-6`XBuv`M$R?s^o}RT=YtNKFv0_z2U?IIGG7%wpGO8(6(Ul>>i< z;feUv4)gFEX5u&^E0}+d&nm&!tpOb8$>XiKx;GXn$u>4vSL5B-_hpIS5oFzs+mU6+ z`M%2e6Xwh zsNpk<);O>W*1#>q5^vE^P)EgPEZeK+piR>XR>?ZFjw`Sv>Jrn1g>W4MWN{=QSl3pj zFH%t5^?U$$wf+a=w{f?2|Dh7k}AU@CTAJbA2`J4jUs{dZsLUm+@bS z>cRAokktr~-7PcBRlJ(Qa8dvQie(R4$w4jG5d`-3e@H-0hQW(s1vO0rEajQ!T}qKw zM^J#)5-+E#gPw&}rOF=h&v!*-!`I_PAo>Vu28G)e*&fxpTZf}{!@Ibo=JT#|%fDqk z_16Q;?cu!1^T&7oamkGF7Xo_Fvp(o;-@TjNp^m~e{^`sqE4_|wn{w?euR0b`u<*Iz)7M$s*@o`r6^Ue6-; zfz*8${d0lRKNTE5fR6kDWnhNQD)!7I(}i`Qyf$&n<_6<|mmp?lyb{g<7wsAg-{w8Y z9Wdi})>AWJJ%H8^1@GZF8xMSvzZ(z4B^yPC0)`r@*Z@$ICfvdYBTlWTnYpA^XhBp_ z%MP?*YwUEmolwJf4 zA?(vB_OgnYZc54+V3Ng-=CE4rSQLxwzbW80a=sQkgt{Bd!&okO3^TeoYI;vSvzJo3 z=Wn?0%WMd`Y=S1$Y^=_bm;`uKH63QhegNN=uoTn*tG}i|z@c?i@+}3BseK@KP;lOHQ zSe0rnf5gkG)&{(^57&uCXje(AO7^Ja(jrL7s-zA`@e};>Wy(JflgxAXx3EU|=gmyx zI)zuH958e~`!rtd;UEeKB#&>JUrC~T4`qZDkd=YL0(vku-tdO}xjaAy#H#go2y`=# z;K00#)t;nKBX{#8_IAF-nSBeN5oDHX$B+w2UCly3R5D)m2ZZ+I+kyf(g5}IdFLtz%#-JyK^ox#6g`}H;4mDfD&_ec| z3#At}ejWsW7~LXDH-p~#JfM||-pd4CeI5+xO|O#&!7oS3f106I;*zaXrV6qR!j%d+ z`7feAlSiemv;G@59n6&CRyAp!+9j3<{T02R?cTrt9(lUxtN+9D^d#Jke@ULkjOc?r zUH8Gq$WuYB(EeV3&+;Vx_-qVxVY6pa9bu@zA4pIg7={0|1TDfPS)3l2h*FKD6;)X8 z-5-;#MY0}zH%z1w6)fJ|x{m@QU+5gI8xI>0zZ%gqIHN~AQ(?)>%J{X7^+yMm?D%sH zn5eCP{OhioV}WTmTDyui)gK!ew3-iZEx?znt6ssJYXEESV7GD9`gl)XdBK`s&i1S7 za2YCC7pUnhow_Feb$n&B!;BvD7}1{~C+5M1`3ts&a<-1Ho9M}F`+41X|G9y>>Hc%z zf{Esw1b>+<3(@JxlFXo+fEEvDi-ihevugb{xaYA)CLPhx zGUGSE7eDHrJta1AF;wkqpi)166_#JH3D5J4=pks4x`}ziVJ%%j9?I-3cm>Gg%@*pH z_(cEkK;5jNTn^Ju9eC;q7BpgADsub=IYM=zq5bf(f3N^YVRq(CUDz7KW01#xPRWk8 zew_`ZWvJ#@>9ip@mKfh-fP&v(rQ?h9fak9Gw8j9=F2)NGY_t?TW~`cy5n{9xS$SX> zs8yQR_M8w&oRMBAC989xUDF5?a0tUWBM@do+oyqA?w5iE^*s2rE_7OdvV+wDZg8uk zM`Pm`!M@<50(>8ZaI+ER(lTI_JKS1-7^f}c4EOwkH8}@O9C$XoF7Gt?umH52b}t~8 zU;}KP3hPZ(0McCxNXT#of z*7`j`Nfu@0ru%y^We64{21xHE-)=y`wio%pY-_SFnj<~)MU^Z(8#G-ZcBTtG=dil8 zNIR(6{`u}}0zN&L;MTdf;+@N$`3}63y|3cuv^no#PR~8IgdH%w1eXDIc@8cw#$}!R z7bs%C-O5!s592bmiU1QYyYctB-Fgmj{_OFSzN>f}1& zu*FAxI#!+)`&xEvoG13x+}QUJDLsy%!s*z}-D(Kpqf6_rLF=`kbs!Y`H1>%Pp(ldY z=3vQ&V8OOv$>v1ESs@p4)Z+|g_vrZ3Lms?MsNXdpo zJ@VuDVO!;2{3(@x4f5moae&9zA&4(eOA^6?R+LJ-i2V4tt4ZZwG+5SNJS{3+y*SC@yh^o9E&CZQ3k3By@DPZx*q^o2Q4A4^Faig}f<%R`ueJ}A&# z6a2hw+a00_P#cR#1B8CVbYVyqaA)~$YC#o-T0m7S4D2=ae7Z2i44AWgHyxo0Lr0AF z4`VsOT}bEGg&}j$7A)UQVW`4T7`mT&J_j~qLu2xkl8-aOFCC@mkuAL3qyeW zKrj&v!5vhCk)d><%lkwx>03cvh?cDjL$W`XUcHNTAE+f=D~Jop(qy_1)RL|h%!OoW z0^J8{p=*1V=00$j^sJyRBuf+JkEPa$M7a<25_u4=6r!bxav$g=T`RZ?(HsteDEEP0 zA`d-@a&s`JF<8(s zh(43vmc|GNqzShj%&89+G*eIu5`@y#`B6|rv5BPgDCJGT9Ge3cNNhnXp>%bL6co{L z!T{1NA#9qsH)2E;EU-!3g3W}|)lpJVMA!8$_a{SLVTqm;z{wC-SVLMR6i(9weJ5`3 zD&b^ED=Z>y68fg;hLa&}?@HoiNZYHnI2qCkhe)f0zG-Ts@1#AE{x})piV*gwNKS^h z!XnZvVVg9Kax%p2RkfT9afL^ER4pe%+}>5o$q=`9)p9b#6(*5p35C;COK&FXwZu0z zYE9d_M(NE&sluXQdsQU8StwOj)N1egqc;ns3PYRrt~PqJPpYV>P?4)1wM8GO)w`1D z1GRe94Sk@N^lXnR;bWQ&tPK(F4Vybtv1UAX%|uij<4 z5A^C?l>0!h-bJ|&1nX6l`#`VWMfv0C>!0{KCcvQByte%eY0mOj zSOcxEXIo$KSU2WcQxH02d@YJE1y!I`|EA)DaZE^Z|C~#MUSq+)GZ818yT6XB?JR8F z&NQym7`AZdJ-2X|6o(Bm)xkP!{5H__Y8JkK4qFE!@jE2&8C??yTU*DKy*|#k(th#2 zDMNns;FhdlEGHPdGdmc&#}kYNbAz#KyChncmZ*9Zu(()|V+R?MK zj;>9(kK^fma|ZC$Xs^8U%DaPW6NA*dt9!;Lw>_NU+!-xzKVjGMjo zH2m(y<#Drj4#3UX9jCHwL$iB9PXJdH#Kl#}wl+5n*A5HN&V=SbLC=5Lu(hS7XMfAT z=k%tud^3BWqorl`hSOTU>25;<8(_;fJvd*`a{w0)yTI1Mdl#<|fTOf8lUu%-vl;NF z^%!i^((+!90eIgK-X2HGd$ZpoJTNdV9G)-~#6=5UgTNc7eMop8CA56jvzg$U@uL&q z4iVgLN6Tlk*ArY*bKur+a5!Jkvk@09a9sqq^;WGVx!IlAbC|aqS`vHqUi2OrssM~2RRUmn@Z9yT9I=OazhSMK3G z+wn+C%Wx6I>^*p7`0V%OkuTZrE_68r=aNT;YpuXCs;3K&G_~MJEMMc1QM2EbM?R%C zn2(goBcs3!G(dX7R0Svj9)S|bBUA$Gkt%s)oYtI-{{4pRtByt=4`3gk3L%1bbf=dDPF-?QVBQ+R(Py6zWuE~Eem?c7@3`ZC_bhKl>S0bR z!it>t-SNwweLfKNsCpk^-c=>*PEc@b8o1C2<#}*V>jbGACKrxJqtsEg< z+S#nHWo-%Z@+MmxiI*$wVmH2z3otp+&J13PnOZrLb8fPaM^(I3>hiIvYmvhlW-V6Jj-!?V?$= zBb*SwS!@^CTOl6D;AV_q2yA=b8}vTd^A?;(cpS3maRbL&irL?Sl-M zBaHDDA(_%d2-0>8am+;HV~Aju!0Q_%9zz&ae5}ciBab1DT0vrkn#T}FJsR85=rN?R zlx^*R^%&AvA&sq=_84+`T1YnK+;R+QJd4K15W#Z-Z$VFV@O%tmH1M$|JH9@KIGWMg z4#AHhjds;mMd`;7#+zsxTQI~9ISYf$j^r%1^JbJoL@XRVvk19HhN$3~MrKD(GVKVt#RN8qa*Ldkg!~~l zyhJg`2)rT0TMAo5^2XUrh%3guQC!jY?i&ztgqds-&6_I*HQOrcn zph9dhu#RR+qWKVC9yW>OOXgl7#&oub>@NDN5L-oT5Xly2Z6SUbtVi)f(d-=%;_4PQ ziRQ|l?}a#;$##*N7~*9XZ`!;>&Jo2wV}+r^9X|!jd++Yv`JJ)iNHyOHizZWJMw6VNhJwi-rNxRQA=;Ku z5P8+eSg|oDxS`nby6l*NBLuu>Kqzv&JU3Q=95z7?ib7KhZyuLp$jSst5DJ3$b}V`VHJ z!?>Ftle@?SLx|5`aUK%CJIA!6S1kAqTaVZ6h62GsfBG zO;1O^iT{TL;UPugGhc_nCuDpr?1(<_D{l; zoe2uDv!AUZ*$FYiC8AM`MCFh|JaM;5G*3-TFol>(Ws@kTkbMd<#Z4|zOi?Z^A*M#M zMHEv=K!*6?3hF3+AeTL1<6o9@d~k%$5xSD6k=p7Zbl`?z}L~{0L6Sl@@L@h zXcK^`0vahcaCx-YzeL(0VG3rC7WU6TJLXiu@zLf#Wo*V=9(X?5#HU=qnd!b`@LY+u z$KZB8nnWcHkHPl?d_p3wV=(?O8#3-X2Ir3n35dRq!TEBuV+?i-rk_{fV2Q_I{RL@g z$79D}`z5qK2E(r@fQMbBl7N*+_2`|xmQP58b`0L%Wkcr3kHLH=+F^WbI|l0?qFJ;N zGlWyArNZi#D)=4s#s>3&H+Hajq>JL6ixa|JUBb-VNSO-gb}o6TE5& zKERz1`Cs+)2H)MH_A7+mm-72_GqHUki`y5{xqSiqLAXuIi+xqt7=rB}Mds$JsjwvD z>Kv=y8g8OYQlLclVuJ@ZbEq9yPBuE%ZiMTy9U>j?Y*97sg)e)0yBGD@fBz>u^zCR! zCHTLkm^ImI8!Fs64cNnheao`73;VsX95_$+U0;H#xD_K&HnvpvU4aey?b^evpcO_8 zc5!@#|J&4~vZGAxRLR4xB5W_iB5H0PbGnG~5({PbgGSGGNb+KH=ZAU$9VyQ%z)KqC ziJA`lgZe=U2HtX;TjUo3S@((%d~E!EK)u|) z9pA{t%WVd4e7ViUFJEq}W8&(Af52t*Ay`PpE!ha?oP{68=2yAp5W8>Kzv-+y^8oKd za40aaT(%}_E9aECYWHfj7bg+wU8pnkKI#nd{WyOZxau4C{_4g!?^x`jdqIjB`Gx?M z3y|Vu=c-HhUx~-CiMd!F!;jzdF?`L>J2u;Q56cV{OKVmoD%SlAQI%+ew&XpCN`CyD ztx@p9Ta=XGo0N>^B{pzuQNI#Zi2(B&X^tOx3V4Zkep0gU9+nv@vZ14H&_e9B0rU;= zCiDRcItt??rT8YX%n;REk&c>2SE2#{fKHR<`0*xq0O_cCl;rf?lZxgZ8@dP3QDy_s z*TYWb$D?eHjlF=L>YJ2?<}+;QGXQ<0K%XMb0lic~p8@D;zI#TZxo$&8eS?MR0`xtM zDe~hS1s#@|G!lF8(rX<>zROBcQ3Rz82I5{3Ho&a~0MtB6N-rcI-^Zi!!=Siuo3jSi zrD)*MKQ#$zfL&iSbyf4|FC)V?zoHhLA#+E&y2eXbB)7mS(O1WWa0PYsx{vv*?w*fyTy{Z2pC4^C{B- zSa5?g1mtUGeW_7%B0)xyxHt-AG>HmIaFY}@TAEpd1%_#yZ2qt~BT^i@T|i=^+ND0t>m(ezy}AXzZNKPo#C zUL<{&2|OW9dZjOYWxWB1BPe$A(%>AOKdzMyJH_(%C8 zL54^y2gntDK#F;Ufuw>5*Q12FIdaT9QAUlw;IePr)6Ft!1Y39?LkAl}DkmQe<+*|~ zBo%AK3Q31hx*s>b_Q(d(FV*35b=a&9o$An`4y)CnNgZBOhkvWX-_+rc>aao`4t$DH zzZ~^iIpT-LW7*$(ABTyf)WiDdF|!oXr|pcM%z9X3D38P`yDoRsHB_)3)}wk0{1)qB zjhS=AQb>29k@4JdRy{0TTREjnKDo=m1O;A7u?IatTeL$?%TX`u(&}E+%Nn57%|Xb* zmOtgKn*Fo1x_JJwYiF&*8FrFttG&Z?|23$Xr8fSu0F{6Kh_H%Ti`j7M2)3Mpd)J_1 zR#?;Ai$fK&rm1mDXyJh5`|V0k8QqqM<Txl4YdBZeoCB@cdXZVIYcDP0 z$i=$EU{tu95MHcn=Fy6Em73)bFg#ne)gp>@UGk`@p%YreH1sUd(7*TC8hZUY*3hMf z-dA=+4ZRSJjKK()QLzoWID4jVgp_QH*Xnk_PY0_wq==?si*&JkTftc462r}P%i%xj zY^6H~-y1)JORe5~&?w^mnc+XYOsK@WU`nV}eXC^+O9{OeW7odOgCvnz;FG9|!A@r|iHQhp#&5iTCl+B&>{zUJ2>N6S`$>fgAfB19_ zzXCp~3)6;5mqp-fb(Kkh4dXTJ!UxXbN5#2eGjKj4I8AxG$}l$@ zEVHPQP^BjMmCj!_W$K6AaD{F}(5o#za=kC;vt92Czfl(`tln4px32dk0rt`BeLX%* z87gL&s>)cpRb}k|XT2{@sVHn{0jJ}v_4g^n$kGx2SM|P3QN^zJ^;@T6J)1}{-)H3S zLBtA`{2$c&>cWhL@L2Dw6tv^y+tvFTI8K~JoH`sBD`&gZVbVu%0Y|9!Rj=mH6EWmq z{=8qr^_;4?h57Rip`cb3G%#u7LK69ojUbDorCp163DEhi?=)y)(I3xVCg&5S4!)2S(#HC)Mj zN6jA|e~yu*6eX0vtk$eC1~#M+7%4EBgKs-3b5@nJV=$La=8pfa%>5(yEtq@lFZSd} zIE-e_@Leq0R;vylZGyHvW>=RBj}MWr=~Vi5qtdr$!3Fa*D|m#y@o3I%IYDH-ns(lT z_@0-e4ns3*ot3gsQ5l<5;TDe%;D~Z(rB$JFXZNsEYg7#DHT&Dy*-ZiKigkTZXYfv=kd`FT0iUFuch1>Vx zwmg0W|1~q`!J0QAtKX1pT0K$_EAX^l-OLVcdYOy{Cvs@6 z3E0)wAc&)g{Y1=wg0&b~jkhimZE97AH`L)JIbhTs|0y+=fD+$5#j4D9-{ta1e4ZTs zs~(xw2|Z+Z6)}Fw_n{C#i~$7s-eYUm<&LqAxe?!c+?G#3t%-laJ%>@W0#vulQ;5!VO1dmnY(n*O{d-vJ6i0lbpPtZT+@fcQ7NB6#F7EeSeow3sRxlFD@@}Sm^ z$2U2_XSSf!5mab=t2=I#|BTv4rc84d%SpRec+t|9&aPRg1&kvzJTt@ z=*ZcSvxb+vs{*S>crpSxYjQR?4!OOX-Hs+;@=Z)2(ge4o)q_en)vXVDF1pJD-6hgZ zCen?9^b;cOB+~ai83vK=@OXQn&w})zC!_)L5l=rD_dFN2Wzdha#LAuUF+960c66snZeb1B8MWlwuyU*io5~RC48HWVvPI4xk z?(%pK2-2Mv(vRGZ05JI`rVwe0+tKVnjiBo0XFm9MkYXXHt4*X362#jH4*eytdo{R$u={ApdryvblNI!Ht8i2_+k@XS_oDjALg_5e9e%N?z zKE*<$jV4kE2}oBFX#50=oX}(c(7_kINjp$1_kLS7Sa#U zp}^#um`bFn5Vps=-(B6fbJ))56bq3aG?79`KpG&@{Y1LXgXJqgy4K^}?D2LB(oLR> zt%7tTRZfs@5*36ZZM2YXLWcsAZ($ zc6c%xh!l#w!Qw+!cjL&v zP%K2c%|r?z0qIU6HHdVrCu2X6;*obe-VX%nYEQ;`LAr{Z38yIN1Qi6*RTk1tbSN=@1(mdNv|CsdQ6a84LFQ^kJc0ANsNseF>z`V_W~?%U{QM)X$@Ifh&r>lo<4lQS>E~KHYW{ zt-lFq{q86V#6ZLP*BOJpY(-xR=_|5*%9~H7z>)Ry*pF)Ek@}Y!gT7ovpOf?z+wSMi zF~M{D-Tf34MbVcQgT6dPUn=RFYI~|b*Op(=@1CllIEucJG3Xns=u0DgCAL%h@K4Xr z=y#`9Fg1$4^ceKH6n!H}-wfOTZK^*oxBvZLNfdpVG3fIs`qD{XsqO!+o^t79{qO%~ zMA4TOgFao+mr43=vHjm2tvS#3zyB+ZqHjzL`ic~NS)^~K?f=@(j(@)Y{ogH7^kv7O zuUOGHhV;#{{a@R?)8FWS|2H#=zT6n}O;z+|lfE+B|Lq>q)!P65Z&nn2c`@iKQS{}K zzH;0DUH;%7-|K(>R~ALz*ckN9Q1s=IzDnEwO}TkBWL z5w^ixOc66sbf}SrmiHS&B-062x0qFI1Yzo&Vl3W^%v#LJ>?9mBlfrEK^h# zk;eaz+d)=PN2pNabTfrJ0~QZ&hP;zxzlLOca%+eW?^9 zQ-sbSq05C(GpSWKW;QZu{XAI~*+da~OAJEkfE1ynBy@!kY9_3oG~Rfs-(9B2CW_FR zF$kp(QiR?@LZ22wO~*OuCnxuR_*l0BD5D6S6@yT^Aw}p+63Q1ib{tven*^Kc=Y*Tc zCW_Fq7=+RjDMDwF(C36u(|!Ja$}A{BKToJdHc^C@#~_r>ND*2_LiyUw_Mj&jzwGFL z4@%iY5n368Q2HZ9XgLXeK?pUSXlBym@AtnGrEH=Iogafx`XfbXB?;xLVLR5WyYRTL z``?dJHj#w>riw)M$(Yrx;AKhb%_ps|;na>h%U0a(?0;8E@kG%oZnH0~^h!djFhg=1 zgk001jtD$`QvW+tN+^n4ah`q2rEgN?k{^=WEaaMQHF?%Wr}lq5+5nVM)b1j;uBf{@*=Sm4hkt>e0FS)cuMK1Xvxo--&ri=aeYtQHQzl)`WqR16@ z+Lv5fq#~F6kleLGuKA|(UnwK||4pYzD2iNhs(s0&Q7UrD56OL3$Ti*V6@Tu$vj5#J zB@{)jxYoYp(kK}O9@4hy8@SDINb(brqlfm`60O<;%NKb z-FKchv;X}rB@{)jIM}|@rBNz!SKt@P?ZVNX`+v1)S$Y5aT}mj5Tyd~{$)!;$a>)4kt+_iFS#^I zMK1Xvx!Z+Y)9)q^Xj|I|w~Lp>?~)&q`(GSwzq_mQF8GN4O&xImqpWa?#|k&BU-QIcm75p;$j(4{Eiuo!FO?G*S<3x9r8iu&2-W?r~1uDNkRTuXCfMciA>jd#So*W7q(+(*q@ z7fjre&cEAonzvR=+>PHA6A$I+{&REu?_qgsn~UrIl8HTMZ_5pbi!O|7S$J6gUpL9S4DI z-C!*7A_u{fJn==j$t|DFS$6`@cMciUR^V-O=LjiVNJ`6>bJh)WXNZ7yCbfLovmW2| z^JHu`DcdyyMVT7;z)j=g5}*J1x;P34ByT}!qXmZ>gsgYn8O@Z;H)U&!g(B2VJyhU0 z;C39qvM(a;mR{LC1oBAnKp@Y6MmKH&&?ibDZ8nj+(Jh;~a162sZ6Kr|r;UWM^-lCt zPs^Di4=ltK00WwDIx}umE@*3c=5Uu#^kzZEhoD3X%O8YHra?>6p(RDR=}I!_A&|u$ z^5mv_25o5GdV|)6+6tR_Sp?&T+`l<2buf2;B6Nx<$}SMlXDT#+*@E3w9%FXl)ddJk1HeT$aVB9&PP`fQnfu3eyHR)=l zDbQY9Q@TLIW?NI53q)BhO?j7^;&JSxra(=gERF-BD5?*(ofJPKH%s*ZFz*^NXhQ)O zt>%bDNe8K}$Pm5RC2Hb!V4PYQP^g86@sZD#&=p(U<|LTRO5?bObnIO<_86kUhFp z>4+1AK}QUT4WHaB$Y>U+?0_P{k|#q)T%secXjd{L*EI+|K22+m;Y(VHU{@?(QlPzU zX-L=q#Fx-?`pK8P_w9U%Zky?M^(D95{@r~^Q9t<-17AUhp6rO}OA4ST7{TC6O8fef zQt>5|wU!vZM64;cFS$W`$I_Jli7&aOAAQOD-@=#7v<>yU`jT-ozpF2q)jz(Z`KO{I z`(ybMy}Gpuk)d9FxXOVIEsL(**V`KwshIJI6{;Z0um+bfFGBY(gZPdSUPc7;GF<~y zSR*)_F%XE8N8}=-F5?k~A<)XpLNN&92SUe{9q^f0vVO=srB9U+c=rf|EyRE}TY*7h z7MvsAKzoTe5Ss`Je5ZwB24V=31BZ>jJBJ`VFd5hh2HrssVxrhG)C@It0R;yuqSyiy z2ucu%5CsTA_In&rfq^;rTaf`qbQ58?$&w?9Xm*WI3_$>7NJSCA<|aq)r~rVG0y*OF zkG^q3YT(}*@-bYSEMRo!pbk}%e(C}a8TEI7Bk6iP)iuBj5rm^=GQ?;Up@49-Q;q5v zwTS|ng}=MdF(Nen28sdl3(Up9DqQrJ1?Kg)1&+mVC{jAA1=^PPQ4GuD9Q-?4-;&RJdV6P=v>d$iZ2Z5| zi9hqw@#o%b<_40_WNu)3+-J>=Q{ujCZY+%3)7k^3btLw$rSZu(5;R_}Cfjm?$~nD~(w+H8FnMt5Vv zmTj_k7WLjDs>>Oxev4`de>71b?fW72SY#>e>Y_vD`2q)=!U4!O- zouLaJLfe3Z3b}eqW~^*gsy+=;Y%ix??T(uGh2C=#N=K z=mGvjL8QmzIdWUmT->zqeC(?SZf<(c@0f!Ufip5ow3X#)y{@XmLn}0F>c1@gw9MEx)3 zwq0 znv6|{gqfSwVGNnM2weBkPk(J@F{L5q1mD&N=pQ~yJB%X$GRrd{b z%3=6PJk;!WXp0K@6iNr=Q475+!}da^OMbI90y2rZoUo8q?`m%2wrl-3q@)I=(u;n9 z3Xzp8$bzhrSzFC%{73v7?H7vGE?Oj&FPCOE$jMaN|HEb>1r`KA%^%bOK{YJhixM`h z=#<8MNUt-ts9@OU>x=IeiSMvbOs2YbV7mB}+)5G|44N?4|9TlWl z7^3m!2ec&{$vmDeHZJ~*eh2mpiltTNaDi`V_a85J=>AG4 zs-x7sIhYuhs>fL724yHgIIgMMbV^qRH&8j1(Sh1DBk^gwniwlbqAR7sgZJ`eU!oTn z;5h1jOz2*Xz?3AHnsQUM0=rMPAA?<#k&Z6GO?9n9b*lFU@pzc282$0Es(=A&Mu#m|4g-A#D=nvK%x9;*rm%a>;)l{_bcYuk zFTY{A!f1Q!P2+@PdMBGFR=R>DrAsVGFm6SI7`I6sBn-WIK}icI zX~ya&!@M3qqW>roR6I)DJo!131rsT*CmXBIQiZ5MxTOqKv(ulUnpFULt*IIVgMXHS zQtI4zFaX!aS{xDlK<{hISuoW%h!ukB66N>MRE<_Pe7GD&jo_i?AY9nZR6-jArTc<% z1!CCHd+9i-0NJ~y5Opx@`d@Hi8%@Tpz?cG+R5t#LkzqEzM5^{A{`NTWVL7Wv($Wv5 z4vwkl9BelvvuoGuqZ^4{Vce&WZY}hpj@rk1;4p^79lRy|;n)EuGYb%l(9y+{9UVpa ztF@(r08|Qp)(EhrnJYwJ9+t7P2xi82ZZtQ(ud_>CLZ9fPR4q_yy>e`p*P^ABkhd)3 z_opa@Rzt5@mk(NqLJbNs$X~5{-?w~x#%h{Bk?EM~iBm6tSFd}NS0HdTW>Da@=9ocs z#)%p;s5N%CFwVe910RJxg((ULjg8X7QWcB7971u?oOCi7K0Rz21brDHfj*~k zHL^~i@1dauGMs=SvwkZCl1_G>6=0^Hc^)UeDh{Z0dUf*Z&!2F$?rqgOx+Dk-7~^z* zLK%L?>;9p)JjEEtjsi(?_07uA(Kj+iNO-f{94ICM zhpvBwQW*%=EqgJ7SOf9}!EH`4&`hyi!#i;o!532bd!IABgH(Vh4@l z&&7SpfF@d^hO0J4e&3o^*EP()0t3%OY~;YW8#W#K z7X{7f&}-&&s10*Vecxt1&Y z`$z6Wv8|JFKU8eXxEVORAB@aL%*_ElXv-|vEpibuzk|2HxR$v5Wb69_tFNI5c(eInF5fsrN5$^^il*?$BR4{NXE)&7FEa!ghDE6s&U>+hsgM{Q5na zFRA3gBlOzU+m#P_PWdsvbxb_x*Nhy{Kgbj%gE;klf*JT>jQ?Ro1OW>vqp-7d|8#s% zV7<2FReEIp_#ROBF8q8ZDoW=fa#F>leU}2Hiy$?AS-_?H?^a(HxL6)Tnf@>F1AXT5 z&T#O}0h)WH`5HJh53u0N0>nZO%O5YY`TR_ecfKRpw=fyai)`rlvcTQy%K{UmIiOc7 z=tY2@;=7R_BG7H|l!1-1&|Bo?7(@7Ex`?E~d{R~Nm!IL4`~@q?;YSSF3DUx>i&JlyXFDsHiFSoOg>Zn@A=@hhO4q1D|+M`71! z@5GsJ3M#Kl1mZn`od$iGjd5LN1ZqA{(Eams!m73ZmX8$WB;czolW^|}RBKmrmzqy- znwuZ0)_wG8!Vw5Y}+)aiMDM21`*P#-6sBpXEAS$8b zG6!1vGyg;Eb+pRnwJc?Zl8EAi1=P1ZR=+(BQ4B!P`ZD)zYyZk1+(2{s@HwDIlTyz7T$n(oQF2V2=25?h2hp+0VJk zeu^1`V94ViIA#ne>ibMHRpo4+7jt%gKR@lP`%9ePx?Z;oxksj?u}dCZ`X2b!y>Fx9 zZiAkGKwEN-Jj{=KK$Otxa_TpIAj2E{z?fCUkpLmQagAgWOyBq&>UEoDSd##b*W*0aeVjDh1j6&@}A2lcuiFlXbe*If)zK#VZY;NN8&JQ)0$9M?0y4uNbG z2Ni6>MdP|pMD>f+p->$rsKXQ0(D@_O>uyl-WE{m@y}d!C|C~xMBA(=+439_cvXZ2B zjqaUrt5%I}$N~1T9<4PeB*ntQ&`L7}=SRvLAy5}#q4u_iA;(&EqAjW74@V~-)3ssf zdaDfgQkBR=ShJr^kT?`#s+${didcrpC;uqdvQQW!Fk^)=lcv~_2UBqtUFbiT)X_Cg z?h@h6se+t7hBQOA$zLJ+^V{{NPo@!8Zx<)&eJ*naNrb$3468RyRL}DkZ4(sdQ81<7 zrq1+u_D4;iouh=*nSP2FsPle~Ng>6D?@;BR-#6daSaqgPXPJ7|nf4yNz;vfgq(HY{ zVACljlXe?JxnQt467N#?nZ+@t1)4KXm6UGi9uf$q)fXjPru!%G#bv^RslKAxVi`KR zP*!@sQ>%FzPofEWu>?&H;ffDeP=7aw@eyxp>x;6H#?;aJfOF0))}MCP&&Wm^tb~Q6 zowI+_T}-WUX{gjKssR;Q0SH#r=x<*u`UzCd4mQw=p8QA@;n(W$kUA`t1451y?xV7? z4-zW_jNPH?#*JzUy+O5Is}7?VLX(=!Q3eAF9Mmj05IAeja1tB?;uFkQJUH;omyii{ zOvn!a_QJ)NJG6(PG<>9{*=bJ%O|=Z^Bfl>gJ^vk#r=#mn-@ch_wI-g9dk*8x0&sd! zF8&Od*VAi^!hGE*K|tS{H~{y<=f4XuP(6t6dyo*gZkRE1#$olLQ3cv}LxOK|vTqvZ zb*K^j6jX*AIlLday>DZkq{o-!_I9{)R!#8N##KIj`v!N$Mt4pJR*@y3PHv!Kpxe93 z(do|FIKlt$fNNiDGu#;gw8nj`Hd`HN#K#vmqR4ViV1j?CD@3ZT=n`Ki;TE<3Fc$$>lbF ztY?eHf5ODHQ18S6kdbWIvzrw(v61_H<7$VSWK|J=4R=+0OT z;sGjET6K6F>p@YVDHZym$hyJ#{r7FMvZPfEvaU(>46w->dnB@|KYy~*B5R`aNOZLy zTK|PjSLTuE`uwd=GHkl?jzrh{121Z_=}I{gT}y_(_q9z|`jP1RGWGfbo37j=(Uln7 z`X`&NZxbvqrUD-#X>%O9M{1#oRv%|ZQeG5&ZhE2#n*o)J2 zcm}!)nmSZ)qob3GRlWDFB~&T61^Now`4IY%M(We)KmN@fxS5B?=&0yq@YUB2hv-pC z-e=$7W&$3gm!gWFNDsD#I6d25e;PNPF>(IsosTEs=E#^hODDa$7dNwF;w*dZjn{EA zHzv;3g->MB$Hrpw;Mq@Z!-FX?QPySmyo;M@F;OOtsz+u2iJ37`=C6I12ALfb=Vy<9 z@HuXdjfr#r{HIRC&E%LkZ@u=pX5l1Cvb^>(MyFoj6DglQ`fK+f^bN${4rn9Q-9Q6` zfT4u_`>Wn_E^`k89CZ9@G|4lYG!Dik)ysc8bec*gwvAQmzD?DFYXSb#nhC5*+u-&fukFn^04w{U~^AMyB5}(-Jq=H!lq{*id2WB@eHo-d$ zOe!$nkl3Fu@#2iU`}Se7XHTus3Nv0wvXZEp=8`7k!a0a}T}%u|$Ccr(&MwH6!DP)QoMIVE!UY9>eJz)0;seGY#{CLOD&W@^ zAIFa(|3pV&{(ej-a2ZQbPjz_w6VZJCpm~LM)AC{Nz$Xa>g96A%%w80nEr_^az@PX{ zhDtH%=)_j!ZSHtuyu9rLkHvNu0p#xhGI3rCe*H;-?fxTvzhPfpWnO)-AP1Xv*L8b2 zOCy5i76Pb70}!OdLI4(l;6UO$4ZlnT!8Aw{r@&#}FmVKXFiw;T9x509%K#;Hg!@O;?-aLyQ+hU zbJzKc-{27|jAX7o^xbp{3fiOCD0n@FoS2|-nL3FKfTiGtYem5)sKX`dkSmAq`L*c# z8W0_+?~q~1y{2wM2WOfF1fzwr8h5y?96L^7RHEqAaY;*ovpn6KV&#gc-O#~O^?Dt@ zpvE(}-em?8Dt!C<6=%8j`a2O041~H5IP$n@CdfDaLSe?^lAH2`z1qZ_$+U}6Wv~nO zq?J{On7?U@|E~B2NwfH7hJV7)gFX{I=p(zA-V=rtCSAmy;|n}+sw+71lydywQ0;&ec*jP5_agZ!T>zcDyYeS$HRS z!VFS)isFa)YxEyL&jKd!LvK^E(#)ZbzsAa;f}1>8!>MQT>xfubd!~KIKQwrd)9Ym4 z&+EJX`KO$Y z53S0uwnJO8TUyc;(28|0-g9zrz>0JA0$G0G)m#-X;LSmpSilWal8ysP;CM{N4FbwC zp5Ou%8g8qLrlw~jr87{gD+C3tt~1kLMqfZ<4jiW~xt$dF&=>57tI;2(ilV!j<>j~} zM0iJL_O2sH(d;Z)g~se7RUCQ_W7bxtp5UL|h201@&P{yfJh>+;lNSPe@9|pAeqgVk zdMTF4Pt3-DsN%K2D|ek*-9I7ypR`R(pFddlB|${k{igd|&?IJ@L5A~qLL@!%!<&-X zyO#81QR}$Wp#qE&U)#iNv;<+|V6c1*+S3udhE7||(Ov?fJ~tP>(?Xe?V##i1S!S)h zA;WA|b3m(b{-h1^oc}U)Ecj>Ocp1797hECO+{g?XY4z^Yb)Won*1OLze2_c*N_rNwGzBd+vls6M!g{kJm8a-QnlK)%3{K%&SLxkjivsSfp5&sXa$}+0E2bNJ zd6gL2>8s^%iaM0v4zpVZmuWfbSot<>@lDFVfty+MK>Pz*i$$;DrfO4hzs+@eI{vk~ z&YCaRp}l$C$EkL`E>T)AR}57==v*)te+O2~ctvFCFFBnrY7W8}c992)5Z}k72t|7I z>tS|~8!fr=U(;0J3lSpH`MBV>^(Fw+Dh9qHzGwL>REq9LU~w>m#rWOoNp{Z1YfwaF z)0v7re$K2`k7L+ieuFu{{Oj@au%H2b=mH@>G>yPENM!&CnZ0-|VH*I@g9f@{n+7u~ zC<$FLo@y8Qe@`7U)xob0pU*^ZR6}#4?ED?Li@ZG#0-6dI1SnDjfn40FSriy{a z9O>8AL^p0ajA>XSY&>6rWj}`s@tr|`V%oWU%ZPL?^f&noKs6eB)Vm!x0vR?Ehs6~* ze2GKm%9}|rJ~SB@S`&AaNuJa~rTfS2=;b=HcBAZcRwj7Foim2veLqW0`oUQ>t>2bgWT@mVmw8h(g)!0)$l6V^(PbuS|*#ufB^^k~K({(OYJ zdFPTEUkH74|1rzomj;*v26eiAE*105!S72jUn(D)v#NGgg)^ria*H0`eS;_xx1)wp|FrhjGo-5Z6lfESLsDVCsI#Snw0{74zQ~$r19>7Ee+34k68g zd|~fd>Tw`7I$%+Ng|Actg>xEz3C9l%tPC9;rZ2TSmqq2^;pJ+WDxSpD6 z410ffFYx0V>_e|zE=Uuqd)uXTvObP4_0)GbaRsjtcWKwJ16?DlcWW~`cWcwv@778h zadDM)Uc0vVEQkQ@K!@OjS0k%6&DmIuM{$v^o!Gh|ZIaOj=l|&3&1Vu%y0Zh9>23y@ z=tJ~M6_M7Q3IYTMARet(;v#!RXRp8{vFi|_m5h>#&g;VIgrrW~AU$LCNILsawLCYf z<(JSQP-61ddxz*(09S_B%p#xD*UH^wXdSMWG-yt;yzVF3d645hAPlzl0M6<*= zJdQ?as9phE#PZ&|a&JbAdk}dzWA6tiLotlhM$wdyZi1$ChOO9$u+O=hD%iO958LXceHrG&I0!}VVIk^!|sF^?UcXev^51%6{AdZ1>#KHa;xVx8Gj=?-e z;MW$vh5iH$;qib!vHdZ%(1lQom7@Y`84{hwnllt#AY0H;;h=lja2?O@;yekKeWFb} zo&yBTg=+7#=0X)%l`PQcGWj4j8v2IbqV8kgM+IDocyk?qBLe|z-qGfhc}MqVbHY$! z{M)?pSL0_thQvqM9x;mFMT*~WnS)6*o*x9nC;w*S-NL*x#F$66^ zEws}3T(+88lGc3_prXPGjl_%iek~hkwYsw6sPn2r0P$s@kL&)U(OL>3e@r4H=$o5| zz5v%;d<%WRcmlZ^ki(; zIV}p*Xo7k%w!YLHQGOs6bI`g~<)~JXneUgn{gbUf>2{@szB-kfe zxa8CW!PE3WSGqn3(>03M7Nt@5BM7h*P$K1bM1CK!0SES{NAa5vSh4w?`-3CNufT?f zd}xOe-5a0Z2#_yOgc0;(t15{wckBU58f7&{pTl0RF4W zS*P#ACL+GTmJkCfW;AkAAuksohI=`^NaHFc2nvlb)9aQY843$|KWa`uM6OstxBA|# zI<{9s$k4b0z2yV-$Mt;&x)ZV26sUm5MOmjqwX(2UMfM(;k(Mz@K-pb{ZBD=#-rS$~ z>}`J#9|jL~$2-{n+hTqH8ezR-23Su)XPKCO2JF!@CA~9&f8m(jlGQA|3CJ?lZ~0(u0qYA0!A) z@6!OF75P?(1Ixl&^WUGn0ds5`M_6wfV_p;5hm&@0|Bs^AjEBSeOCiIMI!zx(#k?1Z zThqJ&I@uUP%elGlaAmhr9=6%c{yBLXDdWPQ+A==xElb7^t7-5ZKLnjejECn=JCZ$D zm>;_55=e=JG3F0_>1GKbB%FBq7KRq*HC7C`2T?KNgDh%@>3sKH4|9K{Z-34$I1;{F zAsQ8#AcAT@Ts!o-A9uuQ=LGODax`gVNr6?~C28zMurs52&r8)WC97NOcYOz8dCR{fYP7Vrz5R zYD=42+Z6vL$KszmKA>aa{SWca48=2J?~!;$t7Af@;tntmSxI*@ppi^3V;1~Ee{jsT zQlvOR*wO$EK@4J4VD7?>g=-L(XV$$?nW`hE_54Feal5?I55|&y9oXp&6lO(&AO;E6 zzA94TFH$NMM#9xpb&vpOVCpP-!z{aiq?t;VMd$n_;0h){g^a7OgE0RS8hMl#j?$;4 z%AU}LG;S*f!%HL3CwhMYUXC4K1Txay^|{EuHe$DZa_=f;kdePQxZr$D_`5{COydzX z%9Y?z=Oqge+P{pA=yBcutWVax7w{2l0eVT8Ygv9RsJ<>_0ul7iJwMvNByRtlxg3mi z7s&Q*sxvz<4B{1l*!_~?J}N$$I~MTJ#y zGdeq_0rKB0$T8$QH@6SHV=a2GfiYSh5$-jd;>QSgWh{6F=tySJ6zNrj=CFN-hGXCo(x-h5BFCB{I)9Y+xVBzcMsJ zh&^fpy&1-_QaYoVG`%vqALT;ml+2tv?m~1+Ggt62oQPkNhhQ2@)vh^QhFF)H`_SOq zj6d-uEbIfLjfbfLnapy=E8`07oQuen>qOW(_@L@2oo_PLT42dPn;X0VsF-)!Ndr2l z5=(@u@Vm*Vz8bFK!zhPFbVzhUOlaQbPQH=?dx=SN{HP)cFx&O|zHPdL+i_0Sz1SUe zXuLjp6E6q0oW@_+CCBAg|Ez=V9He@z>ds&I9QLjGuBP6^u zKeK}R&7H45c*3&R5LWJnQ~W-`j{exY`?kI9e~pV9z2mlqWvGjP+Xt5q#aU-v!-B*_ z1$mve^f$4dM}?+u2_o=C7O)E|TT}I%&99ntkTuY8c>L(y-j8qlKDViD>p6$<2C%~!JOO0l`uVsX9EjhT5$yL;}iKJwtO^I@u5&lD4Jb)?{ zv40NlKYl(v^!_6c47ud}$3MtYYhp2O;{C@PyL%01GG2Xf%{jEi_!qPgvF=DLK@bPF zRSU~YWz!7cs2FPahgUxE541sE>fQ^ioEmP!8S6+)bm@iZm?a0>t6xaDe<+Quu&8*ku*@hFR zxZM4u(Rw9J_YBwQnDw^#mGoyuAnXL2lu(HslrY{^g$YBi_IGr@-IfHLOVSN0Ikx0_nDd<=qT| z#W-W|gGYEb^B~9y&Vm7ku^TBrZLzujCW^*9$)U*-E)*H#8_8cJ>-lTS@8CJRfoW&9`_TCUQ-tT>rVu zk}EWrFUCNlrQWUCR;Qt#TpVUp?#CDf{6`*-=ib#wY4Bp-x&{u z^?go*4qo%RM^pXKz0?5z$VE!{oUi_E4Eg534%dyDUW0nWG5;On50}GmV3l}?4Z#B* z!9>6u1FIn31t($>pYQ{bpsUTECf1xubh!k(A7GNkk1Qdisk8R2@vv{CuOMYp(~m zYirJQkTLY^@eV8^Ovc4^SVxdBhjlXtBQb#`WLR`E?>t!wwAx-F)sAP5YXxzRc2ZNy zadsx{LE$m}`m9XMf1nP%I&^VULM za0Oc+P?V??H20Sf&^AvOYX&b(CqTfc!Ldtz#D9od^n5bK@uf8-u^CmgQ)pKlgnH+ zg*SPS(pY#i2A=Feqy85vqAg*885QSV4x15iUhecIR!);83AgbQ01RZXE=-|hO?Edj zOy((}a(Tm8a@HhbG4IqgjJ09c>~Eg0UY4U!BJd|0k4e+8P+1Te58g$aAe}SO%T3dm zcS$k5Fjocu3$8FR3MlEux)Yf#D`&oeb9>MVeq>3Hl4o!?I^J4nXKFqKAeE0eNJDc( zSF?@!YuPDNp+f-TLiCiGhssAed>kEb&pJrE-SK$ZX>6XRdK0e8>~>^$^8>SQCxyj* zaNEEb``|=$4D6=!WQA}i_JgU3!Ma3IG}%bNbg}N(8C=Y49^#b;?b%eDi$e(}7Opfo zM$AVZd`4{JWOdkD0NePg&w`{V`?#EXRI`01{YfePNvTo_NUJhu71EKZ6SS4NLv#e) z{;_XhYvsbVTq2CcdtSWi*r%`m3TEt@d{RSU-Hr;>JSa;p!uW$c<-pmk!L8JTI+W;q z4nMjFDFd8J%4pMjQOSE%cUqDE z#_Y@MNAl^y-oRD-nm%JmR5u{W|Q+f7K|wL?zSF0gbTCZ z3~G1~v4^uTf1|eK5C~(v$Pz{kdJ#g`?h_~buSb0*(4a^hhMEl~Xl?Ny$cP0}&o~6J z5EV#vPWIpAn4JIN!UifkJUR1P{=|P>O?$A*J3{?Xr-tQEZh!aI>{3#l1)VNUp)2>UfqsY;KLO}BtN;ROlYzf4=%6YI1DgB;| z9w_-@be3Bg2>3U295-oOtGE@tjF8Yi4e_8-gmiN#Hdk_5Rdjr&6swylTuhXi_JG1d z%b4)@Cr&O_T1HCXECnuRvZ}~V>G1?^zH$(c3ssWD2_O`aHd$$mxpd=Q=)n!fl*Bua43IQc2|zQ04Z`@E0qc2|ydxUKToHhkO6P#+O0$PJ5c~k! zQ$o4`1prwy_3vSl$*>iT@f2ra9A0n`PQ!vZ|JdWGDA2xB^!&DYm*S7ML}qj7Q*cLq{0V~vveF&e(5bWgXl~Fgqn0S1 z>E57tqu!lNUTp)k6q-2GjW0CCWghzkG7_C*@n*}1xn$mn9`+1n;A(0;$`-BwgWwFT zMQXlL`&)5T3)Eq*I^3xaGu0t*Dg4z8BnxBvE7?!-3}HvE&w&tUlEh*XTS8Y++C8{6 zVHg&Ix9i?r4DGI!-AVZ$FEnTous}ZIPh4AM_BVP21_Q-1dyCq>^*E*NN<|13VLY~s zDRh9+{RDdw)<*ruW{WCedltH^28(o!-Q&Q`rS`nc;wfspe@gKK4VeY(81JD!j8>6` zljX1Kg(}&Dz7ErU(=nKLF8B;FzyPdTBZLTOHpQzAKh7k7SIoP2#)!AFq zxOQ)&LwlsLc3n9zm_E+PHwiUi+t+vEdiUp;#;ql2?V-l*Hsgln(rssv8IDnX@@W_W z@M_U3AgM$lA}bkL?;u&Hm}IF1%G%2L1Mp#i-uyXTxLI*F7R=7Qy>&nimdSvk{f^n! zGEXZ?)a!;Zk5M^2i?tkW<%|JHI@aT_?n5>O)%-`W(q5>g^@yP<>K}VTm~g1G`_x&D z93t~2b1#Q(K?!C-9ncp5$-vd>i)3`H6YD1>nw)};Si1oF1jLY_k!lK6H8S>Gf}#BP z=yU)?1Mm=@50$qM7)iY!Q$~j%frZ0SS*aHhG*HpZl8vT6NhdD97@Bxd$gHC5>2bwRls#eXej;2F9WBzD z`E4W#d+GF~ssoOSRQwo-wAU#tuN+seC$_qhK$N&<+G7otlgYB8?yau?FFL7XZlYZ9 zIlakh{gC>l9Ek&cc-yAAH-h~A|5@)bOEde9M-!NTHPQM+@^(kO!^a1 z4(O5EArbt}EkoaBQ(v>Fui~nZU=Y5_Paq90(!dVM0v}xbi$#RgJ~%Bn6l9%5zIK9X zA&RRKV>*_ZCF$Rz76Gv<1i%*`EM+GQLWHK{$^SlI+Py6WlNBfFua^=Bf(ug@G;c z{E~&!xEotjNOd+Rm{lap3(toOdH9j$OT4W>(g7FqQi<|xVA1DF_qx-ymF}dmj*5Y8 z?sPmTeWi2!mDnBKJQLkqhHeIx^0@IFmVb7?4g!OBK;9(K#o)3S#y2ca4S&3tT{uGk~r{5gonAmyxJ$IN-Akcq{P4w6mclRw%|7s`gH_n012j|!KpZ6PG5n`M(_tv znOyve(Vr{GM4xx4Sy=9lw{r{5A!6_>_BkTLKEZ3aX&P#A)xxMJKt->zXzcp3pFp3+ zbsOX-z15xMfLL{JibRXBCHkNjIia!J8(C!FGJxu@1FHA>ohQut}a;z1Zi3DlZASKQiL3IGAvT)rrABN_X z2tLEfg{FS66C4lW(zGy4q z!3zXQU~MmPB<^`h!uAeh8Lev3xnBDbm1BhVujVv%LdCzyVTLr`9AGV%m%J_ z!5ZVqc((D(m;s=QLk@H9kBHQ1`FeUaRx|b9yI@{#z>8s2(ms>~-Ub4e1(l$RHW$%HR;qt1^^@L!ca2x}{GfleVf1eg(g ziL15-G63rSabG| zaDJ7SDCdWtH>|LhKsKpK^4Mka$c5@~|My}4gTj-_QT8tq?=xR6_BoNCOlpgBL4wK` zU_y(Lh^AL6;Sv@lp^o)`HlaT-=Y>=7Rl?+4_|OfF$hP3NR(6f9c|NvQzUJ}W(fTcV zO%pyx_W?Gby7ZGi&@;GL1NpMI_OZ*v4a%z+Dc2xriHUFr*CP7)*;uYWSeT5d;U&8F zMyL?9)H^ZVmxRK&jJ0Lsw>8by5nhF2?Ot)F0N35Adpof|6ywVqRyaSC7URMIhRON0 z=Rs~A=-$Zqa_)HeN@(^hSPsVWbmGp|!7+Ssve2EUVx&j$C~v|Z%2( z%}132jG^~kBrCuJ+T!hiDh5S=_ok>+k^@si3~!@WSUcB92fCOp2i~w$rtVB<`0j!b z?K~7lg`eo!LaZX)GDLqBp!g47Ldr9w8Tao|>XWTTONc8=1_yjA2e2=L`i!}l>T{2& zK9fxKxh&lmU$g&0st*&-P=sRiR|yibz>KIxvYkeQls1@w{1Mcr-MEVjL#aLkNOss$ z0#UuL41?+p@GQtQi68q#t&C(hwHtp|0@aaCNbGNoe-#;@xCp@>Vtbg}oto zQ$Cj0TV#fB{Pugacj~S6FG9bx#mfjevR()KU+4E7^8<5c5o`(6EU+KOy-sgyV*kQ? z*P|>o>~#}te;$M+3jk+faOcZpo`O8OdyqnT&!iYZoeT&vbC&@D%4^Izo9-VEbiZt* z-zUB*cn*l>gn%?h(aVe|=q(GM&skA`8a{OY_1FRQfwok#!W>23qK^BDI>%WTiv*7o99G5D-M*!Mgj=o@G}TSMovc8t>rN2@HRd>#u;ihsN02334B!hRpV` z@TJH<0S=GyLkzL(ZOFFJi>PNlXKGk8Qk0KD0vz*WAh0xZB*$hy7ep0YNQdTK6RgA$!}U}gjD1T)Q5v$KC?8-DwUj$TUl9Ga ztM^scQfaEU%i2)ybLPh!%%iW?{1y+KPs0`mx*0ml@1}jq&P9frGiCmhH`MAChK8cE zD{zUzEX7d@-_GQw6ELXYVJWTOT3c@#f{`P`y}IA(N{3FO7>chr5Ag}oF=fm(X?3@X zPRYb%Xy-pKgIC(H#T!~23idq>Ph5;TWgHA0) zerr79OFrN?RY?qAfgu?K&sX5nsB3Elmnr`0X7);xx1;+%64MD0#@SQQu@z7_a2rey zDc*dTnm^Hdc1*>)X)hJeeE$HQlL?>MyJ0gu_|)JlqEmt3@dO>}G4Rwt;w;x?+-t5x zhUj}8>u>09v~jU5Sf9x^vwh8Jzsp$mC{}G zMLvEy5(`^l0=_tW(*`dzs|XzST#7*fIRKi!@A&++bGC|nVLECMy+^(n1Qgw?!!+Q` ztKfJ3%&ET05TWO-ss4Rus_y4`SQ_f)ui5?RbaTEhig2WF9_W)e$fb zxRx>Y`;asVP3l(7N8Tea2kT22_V_%APt@K^3_ECCgGJrYuq;RqI%r-n8mc*Lg!gXW z_boR3QG}25pba1D76MM!9|ip;fgWYwzf}4Hcg=Skm?Mbybz#Pc1h-bpa%q@+YIT_A zVCZ4qQmbPvE6D|^V1c2?GKte7rtBjz@LF?p;|CNY`V|gVsKhW$uP`+ejqtK*-xpYY zU6h&WZO2?oT;%#~H4P2>Ix$7kPioNd*$+INjJIj7dDzQ}l@6G|6pQs{LzZ|kV_gH5 z@Rv0V3VPW#`Z@)FwCfnxEI7!1RG_M*WcsD9lx{s7*69E6b}sN$71#bxgh+hQ6RcRU zqEYEJ_$pMq4K3*Ln8w$j#G+hU7W@o{Y% z9tC`(_{Im;s{0tKSXv2qCI9bl&Fp<1Nf7P5|9n2M&)$3X%$oI{HEU+f4gRRcasf`4 zeDhFmCekHmTpNyx?{MSbIpuKJDdMmKdUbD~UcU(GrF~&Mz1qIa?+5r-M4mJL<9sdq z=$Jb4pwM4;rNJ$fNO>LB8mxt&C2jJElGw@EVFfnS_(w&#R> z3-F~r=kmk$F%q_bLu8)iBs^t0u(mEsJTs4Zp?OR=~_nCwZbA zNRLYPpzgxnlajSz@lz;0d;rgQM!@Nu4C_ zV1-GDZPOP9P_mEK3IIC2k0Ln$G1_h2GHce)!%2$Rl2Zq1huKbGl;_j}Y=?sStEXug zC+@G4K-Ef@;&v-W9R*-cBpynE(QNvYNOy=p6e6?dg|%<99C*5-Hm%*|!#nq1Hl|bk zs=;SDbeHA3to8eEcFZ&WkZy3K023?%-(Hi?6NjL{*w)UOOV@u!%`JVqboO6S7e!q+ zvrFvJP*M=a-N>O|bwLniXHKWGvcrO>z7WRQaqR|&h|gSSDn*q!771Sn7nPYOdHaBJ zTQi?QyNYCayz|Qby%{4%62v>d-F^}I|Njvw_Md()6yc|nCc<~@jR+@l0-Oc<{ZAi9 zeigUb;3bLhR3yJj*UEt!F5b>tliz1U`JKIGCxDBk?Fd8@;UkpeSRle`cv?RV=df)b z4d?JZ^m&Z&ORP;J*(@2TyJSD=E(AH}OBLAw848Q!G`+(jygM7&!JFF=VYT)+@>$qg z0YInqQ6vW-M3|Wfs5|SHLMeV()RGwMuSGI2+L7Vvs}Tx(y6wrBCf!2W;4I?L|mjCa6oTT=5$&` zI{M(PoFa($Z3jdm{>YqA#NTT-5r23uMErB1h-c-SaKm~R?>W`wCodGXlZ#v$f7)NM z9~ObrG}g<)Due#pDX1BCsr>7BW^?OR{Lp;69v;DO^YHLoPGiqTd3k?Bq=~vrRcOF! zR5}{E8rJ}iyZt3&o2eoimV)H3rLnoc;*&8CbySZ$O)Tobp!N%RtN@s+ zma;Zd;nFvmMP<>5V&<`Hpczmfi%S=#m^^5VRh?op#MD>GGU<#hP?v1n2zzOuTwB8| z@%--@M(%dmANY3~N9IiZm$4j242fL}*JHcc|2l^F#L9~fv=Jl*Fbwl3nQfjex|Y9p zT1U9%+9P}RiiNbu*xx}IeiuwWh7sjoG`hb8z7>28QAT9C;|SLkkg zba$TpYDBeV>rS!upIGq;%IK=F^ah1jRfqoiVI6bxyErp27l=e55ct%csw9yrWW20! zOQ`353Rvj=s#ARTfA_wdJ}J%oQ+h64a@f9+;`!z^q2g(_k$rH=9w?r9l*^4EfuvlDrmNZ#!X6AD2o zKq!PT^Q?yzA)>Y^1OwY=p4B^r@b11YeEhb0M9;3()v|&VWj>{XnF%5va*q{VK*qAG z6N61J=o=qjq@+)1msq8~T8`eEN^ZuvEdG`uwK_rr?*ZRAF&mjV+ME*U|JKu|cuBy6SPOW=_lQjqOJ+RZGJO zgTco-ir0xRb1BZ}G65g%VU4_+HRrK zX;;*EZP)o;sO{#sH^&T*v|ZcPp|<?MTxf|S}V9YF+KI=?yB@;o^Z&`UiM_-wr(vgzM+$8%C_HQFPt$2+x6_c5KB+O zpVX^KD0eY8Y;JSz%*k57#hKDFIH@QxiiMzZaz6LjKH2|Tl}Sy5uvZ~f$I+#ECU-SR zR}It7HIg)xOO7Pvcu^*1CV6t403sgz@o80P7DY+LNI3%MmoX(nF}rD)DVfVn#3+ol z(SLYuVyT9Nxo-fK^y*7pC<_jF)iGLw<)XuY9EQBw<)j0(^(5&7OY&!||G`hz>Z3&? zTh!5T)g5XFHMJ&KsNB!1%tOt?Vs-LRG|71*p`=V&h{M;0I~>A#iek~Xc(!lKH#u=w zYVd=fp>G8FuTz7`<4Wlj*yXL)Xq-X;UrgeDIu=vr5gi5cEP4awxZ}C}Q#zeP+2CBJ z4TM=5_L!~Bwl2)!rVc*ZT5sA#ExT2G>T7VX(n7T#w=`~ZaJz2LrQfmnFPVeTII>O* zrDS3;FPJ9}s~WA{2Sc&A7}*b=9+ra)@Q_Pr+u+?8imuKZxsYmMD46L?m`V%<&j_`Z z;@-HWY{^21jp>KYa+vXFiZ8hMsU7I{AzFPy~6Q}LwiveYMus_@3yW&VdTgt3?fOcRKK8bqq-^zo1ZhacUNb#B;g|| ze73djDXcXUu9we@fuzOJ?MmH>!oqL}0ILV{`(1#PpePprxXY$6Lg5V=eBGY;xUSC} zEvMUXeKO5BC8 z92RIyrx_wHpK*5s+~t2r-wV3FW#;N{?sCV@bZi*ULz~iQ(<@_cJXt>zAXJ_q97YU-v&7N`bK7OqxSMp|AD1aGcs|9foySOLL8 zllde0QI)1?rC5S7L;KYEX6|eUi>v6YPW+f5iEos-YQi zfJMkUvDpi`QKsV~ML3NN=BJwWK7ZA5bbaM<`-iyh-v}2u z6X(~%T425bWkC*i>MD3i(FN0mrXaMs7vzh0#z&zpG|I?_<#Y&B5Zgumm#uXvh|@|f zq1i-J=I%~1L^BPc70{Dg^yF*wJ~n@~F&3&*hG4lt9vT9{*vk-9k7Ch@48bGhe~KoR zqDMS31QH>4(#KVFSX|a9TW6_qXMdC?oV&(#G!bzbT@DpdXzNZb%U48onIA?W_6>_As9u-1Di{q@TJ%qsmSb?cNq zV`^DhXJGUDU4WF}vmSsc!Zm2lHRKll!mBBH^HXAJ8CWmPnZrV*FFrbhmb>0U?ae%b zRUXp&$D{57)BEq@-d@4o6VnboF+JlE)Z8lR{r#Pa-`ib2?JmmK#tL*x?{7NC^!^5S zxu=M}mGL~Q?`^*Jhp;VU2(-n;CzDJAL@Z3|%*{GsCaqef`CV|ZE zp;Ox}r5(;~_Ni46ROUUmgYK zeM%ML`dPUtR%LFZ_o|dVTlrYyz>Sn?leXwTK zK}p3EyZa74~#Sl^1q39WVR_%c0lv?&|a{G&RZD61MUM3#3!TFenfzfz|_(=#n# z7H;%X&6KQ$>D8$^!%RY!b&5Ry+G<07NNY2(@=F<4RPX_{;@1gtl|ouP_)pF)kP@sD zFTjG9FMadK7At!5$c4J%9t!?M@+8>fbbtxxi*9hS0-a6Z!t$x1({~eMS@iH!to@Jn z(IjX)&vjU9!YJ8kmEK_JNt}Bs&u(xLoz&N9!1YX{jf8QUbp;{^>z))3g@Jq@1RAwk zwJ-KH3MU!?HmS(m5-C~+c4yfwY-EjKM zan;P~v#xF0OsZasihc63J*Te{w-P#4XAbpyCg=%tpqu_lRq{#lkRB%wm%W_sR$V2u z)b(HXEuR*A`w_K~k8HU3qFoFT1^W6k67{_O1td0c%4gX{LcHaMT8!a?H~a>naj{vg zbm(Yws1o1A&j?50PHmLS%MKNQVCs=N1dpqTUsLp}ESSrrch_PolN*(CrL7Fo>c1-s z&Q$4Z2pVdKOapwUrXd12w&bco@yczn_FvKq<{{g!3H#Reep7`d8PnA&rETpMTXNzc zANtAxAELdjiVujo8(d`(4|Cn~dKz1D8WW(6ZmPw4d`dqhsj%yg+5#Lxy`FbpU|jQL zHxl${fdm!s&)(bPpX>VMpQca1KaGX_^UE#?jqyYtR*8njDIGR6TRd7GhC&& z$3Jb-sp6mZ9R4{ZkAH@Xf3nfj?Xys&nTQ=>p~K&HXu;s*p(SLYwtN=4yk8b-IJyrO zil5qxg^v1N-z;>G3lGeH9~OEjmxT)WXQEi7KmF4w&XwGzY_X`4QE^GdYV*IgLno3bGs`KpobI@6`CWaM@VS zyGXR9r^CIZWe2 z5*&?y2u?iDgmvV3IMd9oR9Wn`$T)igSiYo+M)fN zlY624?BDi{_NTvTXuo3a^%xIopwb_eVNzZxaKS&o;xfZx9{#2`q8qUG7c(?sEEyNUG3T=D zQg7;)e%0xho9b5YgIe31QDzQN;e6`lIQ~Wge}m_GW~puNS@8UO zfHMt%A!-($^u&=jx$)7p#K{;R$sg7DXuYm!f5kuD$h|GvDzO!Hcqom=?@UjbD=U)V z0&5>O=jv4c-sN?eXalr&vQ4G}YqE{0pO!5TH%pu)z} zLBk5Mv@aTMphQ0nU_9RRxvCsGEmUQ#N}@TOCx~P5YN1ta*`9*!9}1^DY0;D7)!N{t zB~iTePcRK(>#5q@y&Grgdlsre z1WWm(DCmCR{{W73$*$Kg18f>rLqh~JKg!f%7%vDOFUi}Pn|vtYKz|X{84?>F;A87Q zc<8g=ty^}DwX-!!4jVj@$>8e1H@mVI97||dx;sv|kE>jIV8@tsnY;DSvlzF(Bsq&{<{7@=-a!w@Ai^g+0VEtxvVN6aJTi1tqeb<>T8POevAxf?}JIs)%w-G&VQP1Y+?bPV) z32wZ9;0BcTNkk+=OYE*${cZ8dLq&*Q`!5i`>;7zP&dbIJB~Kp8-tS`G1ca#*M+MXW zs9yPCljo+eWGi{BvY;_x~e98F@_K~W))4$f_3|4#! z){gBI(u4OogwCY~GFgzK9TapXp44;M+>%-(RV(3f1~ zld$|1^mjlBby8A1 zZ8|r0@0rEt&;Fq55+Zs$1c(6wVsbtZtbQESvh}do4RFNA0>v8H(>LOPvIZJ&fsZer z?hj4=>0|OPXNc9pJ>(~srb-5Fo@5htdw7+)P<>?Id7_+&#Hz`r)40l~;`1>22A8Ev z9{h}sfe~#LLe|U0_A#b580}raa`97zEPthpE*=s_ce<&vMl~?WSFCySoiV&@ZMG#g z?`SJ<-PMS(jky&jrO(CAU$rnk)OZNAI4pTUXg zYLx_JpW^9IZN^qvozdww58%Al_oY#obC}@HeRz4SKli~q80nIKOxO6#OK`bhPHT!n zKuD-fx9NuzTT$?xp7)`Mrq*Z;6o(LG{(%Thn>ATyJFuyGH9_Yw?~m!pJjmnTNbg$UdDo3*ieo-3<+!6oVVsruv#qw2i`FuM*y$YJ?boO&U^5A_2WwjL00Ey z^^^7Ic74!?zE35L|6yG_Ru1|lC`sMEPjUU?Ezc3E3(6%_bQ#jeU6&{REPq^R5+`NO zcXd`)%%M7i`-wN|F&(tLtbE@!tDS?oH|Wln^SYBW{;>W`G5yv1{7iYqZ^3~YSlSAx z$GJ(Bwl38kZI(zk?%`PaE*|P20uqkdPlnB@1y8!9ev>z=$Q-2AWLo>(F76LK6m5Vq zY?sj)oAVGgtSm+WFkm2fIiwJ55Xh)wTh#IUGL$n1*T#@iIc0 z5L-PlIdGhh*Ai&HQ`Bnh-Z^%S4YAXgZPmtd>E^9EJ}uGuCi~+ZSDt9?p}H*;b>Fjx z@iZvp@+@qWQ%m(jo*Ie_zgMN#uALd>ts?|Xc=~BI$6Lsv=yZWe`O;U z>mkDYiXnNh;-#@6@nOD8q2$)lC3dGs4?f~9DHXXq(jYfJ`*u&)(_%LEip5kz;Wlvr zjMtE2E7;2hI`-KWcw$SgD4vk)j(5IW()!k*c*m6kCni@-=nMu-Xk9;GLeJ`n9mkgF z{hD{-LS8e5x^mEj_dD5Xdk`G5O>;=XRZTjvt!ncNRZF)VQ`P#~PL5fAPOA{DI^NMZ z^2B3P<9CTYk^E9@$(77+^Z=A)-W%I#8l+16w)s`&IAJ?u;+?Bnx4?2I@iH}j9N%6E z6N+<=wBBTAgvCY9s>x1Q8L#AXkqzYt>~z9K7P1!?J@$FWMP8SHp15QYO%1_>7*79EmQ%i9yyDWry$ggHyU0D`41jotgQl*e_;QsPpJ=%Xb7#v)PpAl%3# zc>5UR<7w{llDmA%UB2!v2d#&Jk2MA^(ErN>Mz8(0YGK|+tdWP6GNB-q5uPZ&Ks~6C za}``|9&4n#4c}0sPO1~3fIB^UkmHMy<5um*6`nbK2P?|YjCVg?1?cIFKCL^@k*9%+vFbYVTq8ryD`xxqGu@z%8qsD=5n`@My$E4rb zDLwekRlfjUG(_4@^pytlZz{C95W!NEO^JGS8V}VeOxdx=U#P?rdaPOnZ+xUasUPSQ zixarxBYyXwm1#=e_u^Ubb|;0_%(~b_L2eySxPk zq*5LOvW9a#i}I)e_hE|9mWM3mVa8e%q%$ndgDctpphMLN%gN6k3Y7`u<(1Ei*+zaoacK8sB@wS{`CN?+lnF9_ERAltM@SH<$C1yYCh6n6Vf07k+$$T6)hrmGO?Lx!EfO zy@j9a!e-H^uVlmrGK!7f6LYQv$SDur`>kk%6%Y?p3V(H>C}l2!8bHUsWzWyredWNt z4oR>ys>U7;PHwN#o3oV~qp0Sd&amFDyJJfn@3(CEW~^;2E=bFkhFIH6s4_n|W4z@B zw?R%w3*Cw>X*P4&#CC>Sb>VhnuSrkosUemsy&MntOTi6E{;MVXae|BLEXsz!h8-3{`31{s5UpYM7HMLOT0V_ z`sCQ$b9m6Q<@i|pXB9~g>p}b&Pf}Mf@aAj{V;+hvxnX1{J!#p>r$=K0TDJ1(^*j;B zB3_UvX3|zTmq-XKJddAq!)2ATkVH9SUrt>_$(frx0~v=N!w}(f^Bp$ z&yD{W2RbHd>ywEDWczaSFBDORHRp4x9<}*}$Ky7|=2>1|@)e219Nyh8UsAHrp{q`| zXzlr*So*iRBb#OZkLzKWar#<1!`KeE%hJbgL*L-$PGSV>J8ac~iw1Ro-i9MM zg&WXUbXfdF>3A>=O%Qb$1EFb%aKMWbu)Pj*Dq!a8;_Y!y%wXN!#>|O!L%)A6xLL=j zQ?J|>PTTK;2kBjIbrTlhv5#TrUNvSdKTl_)r+uShg zg*64Q@k4TX<{ZBDgfn4ghA=_XuOi(O*%P(yK?~)@PM&Z; z`Zt*~piRrxZ^hb{5pPgb?o%yWFNn2G!CT9GN^}E@+Y=}u-AL48JZUz`r}G)npbjK5 z1`}jru;8GqmE(|(; z^5ut*KfY0+l8|0mGR$dd}{ppO{^o;7iquy z=OMc?bu?=!bFhCLe?jBJU7R5JR3=3XJ&~mOd>a%T@M(us^Crs0DoDkSX{f%cJ23Xi zt4o*M^H*`KaOBLl2iE)fd~9|ZrjdEasxDHlTc6esdaN(8P0O@p@1{iZ2}?D_7-u&i-UJ7a0d;p9WYy3sQ$=jS0jkIuNN+l^2L>75lVryH3@31MHOxeKe^&9_Qegzr%NC&qDiW!|+s@XG zu15~~nr-abtveb;OU#fNV!k_AM5N@CW0o@?=HsfKHXJ2e_C?qKDH zV#_X;uj_q!nFnLYe0+gg^E1c*RW3S&8V%Too?x(#__FK5M1$RokgZP??CUYpeZYRZ z0n`WVxv&ldRxw|T3M;Z_J0yj`>Db13o-sK|D>a-cr{Xd1cX5F9%EY*5W9jo@&)Aaj zEGv6IHc!zG1y$Bim(m7S>pE^_Ed2#u98bu5j1?Ph#hfp$wYq{+k+-yXox@0X-)ll; zcdShtlut0lJE3w*tZfOmYCU#ME5Gb;hvSL)m&V(Anoi|c(;@tdwP~G2B8gj;Cj0?z zOM`!0ryhDSo4rEP2jk_ISa|(Mm3YVe%KSQdR!yvYV%n|-N#;_Ttxlg*to|&f1x`YZ z$8KJgQF097{ZqLJ_{-R;dXg0qjyQp6g4SH@!&{^|vnSUH_mAd{+difJ{R#Kk-D>j) z@|!n1tqw-MBz8KV@5SQ5ruAZuv*n>E)QGyS%=`iqob$ao)8P=%%Z&^v5m321LCY(> ztEi(2f{=%+Ci=V(phG2*e1aD*%7P`I&0K6(omPPG-lS6LlK2x|X#+1arpFFcn`Oc9 zpGr+LU80CAGGVg-p;`?E&%Ws0-T zPoz(ziY+tW5~-SnNCoJAy3S$PC%urLC{>3}M85=g{^aj=I1kFjd^qVqf5a$`Qn*+_ zwV~zJY4SGG+6ucnw!lJ6$U37zvH66K-G{~I*CMyl6Q+pqLX<)CB|Y2x!UKm1X*64l zlj{1q(!Sf1a0re}#x--vx0bb4ZV`jyAJ_!Rb7zWhKD?8S6B1Z! zKKBI9=+M2N6c&OS7+YWSqHq%>1Z8m})qUg5y>X*quw_W`y$N(8`MmerovrPdI&v}< zkIJvu9A`ti9Ov*!?LoBe@906en-u}72^+0Y>5vBAq;*be;9{J3xU z{VwF~h+^l-woo%%z54k+x!QIU3D*56>bV%&Rqj8HTDJ5y*Ss|KLh8+oM(ZY$8$)K#BuzP@ zUug04{1)+|yc~(77iL?`%8?_fq(&0aY1gpd(ph_1?I_ljnP2hKu};Z5&$*uI8;4Gz zkM4)MKm z0+b{baXc!*Iu+*mv(VZ#Uj|OXq;dE2cFhj{TXY|8a{)lO;3Zq1$pa&6e?{xTy}@9n zG!KmW%oC;<9`9=BoZv-P8_pg&`&w(=B8R4g%qx)QzxM~dI_EUMqn+Ed3{(oGB4Vdq z!$|4!7z&FQ?1DA-4E+Fq2yjSu3BK$+04&sZj7a9PFq(=UbP(yme)gSz0HUm9ad#rA zac0Q#K@TfVA_=x40Asy^GInb4-p&SY3Z<6l&()kBi~%0^_{{aD#snT#r{ub)Lp)nN z!(__h8N%}~|4SIr5Eg|2Z`wq-@NBw?3c9XmIcI`(UP;C&%QHutTC%b8;Bi(ljwCwF zq1^b%P~IqGivtr(v<7f$#5AZSk1ZO)yc)VdqUn59zYvNB#h)|TJnJvW=C{xhHmuCb zr_INvoM^TPzf8$CYf6?1T>vZ0DtB?pkUn{GIg2Uq9GQf5jl0pcMthXM#7S}ZX82ak zFjqTb@>-!%OxC-{5tE&I<93-0L9qpOeh01O1|g9OIK=DmA?PX!?MYT44hdpMfTt~G%J_RN}vq%BDSRD#Os;by7$Oqxtu>CId=Gj zj)}vW+Y%F-&Yt0gw2b1x9)8Qr@`!&CSE+a7M3I@W-F!D6?${n7Eedw~%0?5p(UR@D zNYv6!wo&9~7t;e4Jc@wGMmWymTuDiJ=s4OzlP{@X1)k{%>8YwfFq>jQB!VBX-b7rV z)7-@3foj{NO=A8xV3R2{MFRuWuAKPk0Vd}nS87_h0v}o|Z032~O)s8L+C?h734F%wg?2Sh`ZdEBlz%dCpzdxXY+NqJ!k`%VEg+ z3+ag?J6-&Ftme6AZ|GDv(LeX;n)X-vxkmT43_hG^w46u?QmXu*GEEw;XTlI^SWnT` zt>26-_yPB=TPMX9Twp(#9NnixwfOO767MKXW$?4Zni)0Os0b?73&D}!ML)?NrjcJr zPx52V3@VK+8P@Uv*{l<#5qt2%*6R4XrCUkv`)hHccn#AYwna2X@9ghMtH{cLOEZPd zVm3I=$2UST3lGBG9>uh7z<2|a5BMz)ua%1eMX;626G)BEgdv#Gz+W1`)o)Vw`#u->{(Hak zPgvgb`tvGo3K%HqDfya$myU~*q-spD{```>rr@U=Mz+|eQpnc9@KZzFFcolhJNk!n znv$?EjX~j=bjhn7PK`SkO|3ccg`dlVgRNc9Ub9zp@|GQ`b1MsHcP&&f^g63dodEP< zt};2u09PKo{GFUme9ZpmewvEY|9K-@0LG&((n!#o{>zi`tdW20PYr)B|+s=G-8Q(x$Ez0&-xjOMau_=G+i0>P@7?i znahQuJWdFi`FJS*#vC9=OQL_zA$k%y9vr_cOWeZ8RmIOs*Vb31t9qP-GMG<(z&fGK z8PcrjlHX8C*ZsX(R_v?qmJbXiy}_E7q^kwhpcXSd7VIdHs&d|ZM0KC(ySl|xH|D7^ z?@JdKv~;6d3UjE^CGWO7L2&tfCU(0mmlC)693RcD$Q;C1Xv?NuA2?s&K11LIYD^XU zQVud=!5>}}y<`yhxU?|o-A^mYbj1Ah5{Uf#z1{+*Cu(DSs24o=U6&yTH=DT)t#D}0 zO8$FU_>Iqcu+Q2X@)PR{#vSRBwxjMaI3ud*Gu=3iA+PEi(_J0qYI;~Ai4Cwq>5_%B zwK7kAlZfxBE~owQl&9r-T7izWM7+`Z5i~ubM7(?@(zqf0(T-Awu_GFU$ zmPKl7;Ya2+c)xY)1+#{y&-!ue2c(;S+g>vhKaV#oBVX3KmGq^l_H;UnUhL@u7tmza zukOR@6lM0}U9j^|v$Id!gJt~X-Py z{o+Ud@$@C10;K&dN`X-MqA;dgL)zyK{#v`s8*@;zVB9V=TzEVXL$VNE{aI zF;o05bb|g0DR@+#IdNfX@Zx1rYVh7l4VGXZ(_!9qore5zQtvo?c{s_YU9SgE-A(6} zLYD1(o_}HRx6(m!{^ANo;H>CBKuCZf7|_lo2Ugr3*qtBZNPwGS>Nfbs)qMh-$mTNl zER6u(O8~DN02?W~1F)3<8($t={0hLn6?{&>)&XqR{{g<~CjeWyU>hdb_^)LACbz^t zIMAn(0+tM%Tu^aq@Ksnsw}w?PsLxupck;47(9*)Z`eSnrhSs!EpPL`A^bLARCf4d$ zTd@kHa<>g{6#Q4P@fEA5vwMa!nmwC7X-rBmQ+tM62AJP|FuN(zORNzQctB=$%N-cO zhuSUtiB7E>Yx9Ry0e^`k>|bVw&e&JZM&3=SfXwQFrva!Xf-Ac!j@ z%21tT-0lZX|;0c6S4yF%t(lm;N*#`xCS%tf=u^= z;fSa7q2!5b#4hZ_NZa5(bc&ZpCEbra{7=6e+|&1qK?n2&CxSca=m`R>YKx9gXE6Ip z$8R)c>e-@yw)bHuAPfH7C%>6+xc!NO|5<1JcF&!3q@j@CVsj4rD1I3Dk^GQGq##8; zKTPkBA0B;uJN)qHKN&xu40`dy%3?%mJ1nuM`ng6d(VoW=Gw$q@CBD)Uv4nAh@kM_u zp+t7EM6+1pqQzixNyHL)^o`A#^ilX6@saqvtq*+0=66VO^&?}=tcMZG`joMY{%AP; zQXe=?=tvrNt75%MaqGt7zJzW}r?Rpl!Ta3{VEIpA*?1`r(Vt%2C!#mZ{1}KX^@vt- zM6lEELG(`|M0>d^z;~O5I=%L9Yynw1kGp#01@fqbyV#PwD_@AUTLi?EUFuBa>QY4b ziqbIS*LFBeorFeqbVcAN&Ai;>(`1Ou9#wAMO{fjLXa zoHb{+bA0W;y|i{Vjna0GGH1YtFf)d{W$FG)J9g9D%(bF4T8{)x0ipEU|n%<1ZW@p+C>&9{CexJcZgq``?P0Br8mX6jO{wE)OmM)k5u#cQ_W~6 zZB(sYV>PlwLEze&-KpvNFx2no5z@saL%+-Mx1c){1qQV3W-AL&5loxk zC*D1nQfS2?m=84_B|X9ZM`m8_5I=dfA=Y9`cBxz)yRlP4nZj(e2Ra zqI?TjVE+zx^uc$$SRSzc1C@0`CAqfD3;b2YY44o1yNpcQ^go6mZBwqy7LQsQd*HRA z*!4>ltla!O7LyGnY{Zgts7De9)jVpDgQ7QASCO+apNndKM}^Q1`Sfvg?AbeaN0eg( zccPiR$!-J(g#>M@79es6+SDiM@_JSQaYHWAGk4})2aa$$ur3ddaq?lX-i#@II|is1s1Xlw=0$tN?DX;!o~s7Js-~hA}5R zWdILjo-HkGvl{q`LLK;1ilX7~4?lDG%j$NT=&)WFVsY4=5f=Y57mJ_E!J^Y`{bKD~ zkAbyS!M?u$YcJ$tEh~>%eA!~KkH>GWVRuwch_Bn}Ozv4r)$pYVT?1d%q)vwqr?W>w zqj->5hK{c(;6b4bESnrMmFwTG^*s$tcE9gR?K92P;FR z7?+lxLUACnRb8k;j0x&2%yvn@5iqM_htHzyG+wAAnpvSAU*yMss_J@Ee-uLP44ypD zEubh1{^G3xufsVu!P3fh6}`S15`A?H+f#L|4w@Iz!vpCnvYqW8&^+(vE9*1}oxMT) zrTNN*x~ARL$H7~86eA9PtzJR?PP_UfCizgyPzjvd*1~fPgHzA??Z3D0(xJ&&7HgZW zaxP2<{ny1796|-G%ZrxVfG7s93D#21FXffEw$^1VYs40VuGIJiYS@BO9y6}d=2%Q~}Z^%2}MMroTG6D@tJ7P5s^Q_KuJELJy+q67UTww}-e zTUPHUCniDOI=fCEk)4*purc6xx|Go$`u_PrYHzLP66#;)hU*#<9EBZkTc|*{>xis!wEF~76_5O z4g3p&gFo!*iR~6_`Uy-pv)2GKj~{*h&VM<6l&%p!w&)5!>gvsCoz@@WKlxb})Q-_! zoVZP#xE)%KTh`d*BM0hVY{BKmdD(?taGpZ>TIe-3pYw#>i1U^|5pkY@;$<82;{%}e zA$U$%)Fsk>&2mD#Wbh`%SAL~MR!z_=CyLS(iZBaLx=gQJRUxya1`jC; zwFVg<(Z^X16k9rs&w4KYvTAk1IB_xmnumEV z?&;0N=fK4u7#Hiv!H|ppWfpW46?BhZd zuW^5EXzwS~B&yhyaDL@JIIf73dn~-g!KW!5mt==3b3GNs!{8-r!4t{dQ4u!clbhXn z5o9uD=rqqRv~vriqOKnWO+NzeDVTsfc&DF_ZG!-69otr^kKxXo$pMF1PORd9#PArS zVSXsA#F?bn&NQOb+A$FT`MnC>{~^}5O|GSypf=|7r2TOP_R#8o&FV4n_JT1H7H!wA zF7Jni<@qKqPob&QZGu-usp77G71YPZ&7=%b>%r{u-2TvvT@9Zsn=f1L8X;1*TJ4bR zenV&1oAQ9w+FCS5navzpdrr^>jp?*64O(iB{j{^|ojm--<}8$CNjK98HQ8!A zLyMPFjpd9=~DxL$qL8O;0vJ>SLk+%Z%E{eIy34{a`n z8uUNmd*T^XhYw3j8yZklbj53N>sh^Cl{{`^Xxxmwf0{B-t_^JP5DN+3g*6WOA(?ff1l}ZKtrLPgH zv6#BVblCY)seT3)_!t%FEnT<4l@EhZNv_8GV*o|0i-qc61o^at`W^3eI< z$QHc}mu7&MW-YM0$sW3(n#Nfg2iDNz8bW_HsanR)x0>^L4I0W}7l=@5 z0LaKr%kFSjG!iUx{tPWtN~Yp67|8n!DI_>E_zf|7(X!sLHayTE*lh$F1;XC=Sr`b5 zwc7@O1jBrMFgAY|>s{zwqswD$@2VeE%6fB_ADNb+H`Y7WI=8NOyA$3(2ocRcSRO-* zz97&CEBeg7lt=OG6~a7GHou%8rKWYFtd7Vf2%!GawMKPq_s|?E(uZ5PP_l>fJmk6G_j)K>iSCPYi_+$Fu%M;3C zbDk~**4Z1@2-C3OYF%MLyV9wRx_3!3?7vG{Gk>x9Zz&TMG<4g0b~nJ`Z9hrxpVH6y ztL!~_rh3nVw(szOaop|P+c<8qe(>kVaWbcgG>cetW#gMR!zO%bzLv&ue<7)dJT;bC zA3x?Hc`C+b38jnA{~7NzY+p}>Vo~S1u!p6Yx8Twh&ZCAoVSKd!1MxYGWjB5|9_|H| zXsK=^c^%}D^9#5;xES2m>IZ)w?wh!c@Q@}hqLm3+o&J>>0LM1M4Gu)$|OLn3W-6~P9ja*lxx?4a=PHc=k+oi zN26jo?cT3aMH5Qpkfu|na|hxq9bnGFQkq11$9h z!_DqI2E6+=Gxh|{%JqU^RvA|*S)o^c+K~rN7$M)-nRH!y!G9cDIQn6r@EooL|*S zBiP$F=xlBg-io49ZKx4>N~itR6)6>z;cEuOZL>`4_<=pgNksb<t}S0F&sAw=Cv-QY&wLuJsihWc(HoL<$=}m`wz%?a zwJ6K$S|p=Ez3AlQi178QlFuS8;NVQO#Jd>kA zPXCe2@fD>~=UV$&ovbpB3Ea0$rzTP-0m121FbQ<;t0|1Ucnxo?dFN?=&H30DbxeWaSmtR z|7t-I$KOu>Ip&>X=V&<%kcpf5WKHtwU>gacD346JJ$g2CHJQ9>yjdK1lbT7FoHfsp z!~vB)!85@TU+pt)VBiB|x4IF=UZ7kviZHXARsU+{3Uvc2mVNdU zJ^QT-a_*j3wG2A-WPZjTO_o8P`2oM&V49ap?d5qqa+_zJ#joI{B(BdOet8Ex&;KbB z+0Fm?zILyhy`jYrv&b~I{GVo{BG%2WIb$|ZeUm+#iOW2RS#zeGz$4f*AKAt}!mp`M zjcD4=5UyXY>gmz-{E7dHc(VkT?3HB(rpAN+YMTCZZrx!!ALwf)Lc)f4&~ z569Y%asE|hSV26j09%^iHQO>(k_wM=d-Fp4tFGigKS1qi@ zL>o|;X0@I9kpw-tygC`k*?FpJ^QM~Qi`B8;KVLKI<*MZSiP-Nqvc<$0u1jmu;|ES4 zT?lWrCfQY;e7!pPcun%Xs^p{9$t_jm9=U9IP4bzVQ7_h{$L?M;?jM)!TGPI+=@*#? z)pZ;Du*yiYOwA%d!$d+VM@zQqr729d2-j7oPARQU%LRKs)_xctuo!@IkP>zd(uFr- zLQr&D2B;!!k932XZYee4fdgQQWAmDMJHfb4n_kZOyqZt$tL-&}AC0Zb?CQRmnCw)a z1kEuMJBqQwLT#wy%rZC~CmFx}W!Nws7J>bH>$r9mfni3g4PJ|OGC>XIakqnQJZ@kR z9VNk54)4a5b3T>6TQ4a1j&Tz`exK6rJ4Z)f&b!c>H#!=~#W4DP48O$$0#(mUQmNDR zCUO*Be9863ib|M!_vT&|p*QYJSHwtV@&bc9WHGi34t>rQz0c4`Q8>*tt_CUUno-f> z+@dsUH9||*3R4?P)nOr zQ&syvU6np_TeWH|qsEg{Qy<WZs*~>}*1lc6|Jzl&tTipjx|elh z-e+;(q|LVsUM*=>1U zIW>&$;QEv&oK1qKIN-LR+MTl1e%)2Od;itGcABcq)+i+^7N^>D$_=t4^NdjzgU)>L58|VA3am% z!>X!qSjG2w0K2{H9N^!T{o->cJ5G)qx0^H)xCw54C8r22*lUDB^=95w$J3{Cw#&m! z`x!5N2i_Npd0who+f}oFSLQBgcRT@x--w1x*PUtSpi5X5{FHih?l&i)qg~g{JetHZ zZZ1QM?qZx}t|*LMM>m)z-ssfyb)Yf}40?3H=s5Ah$*fJZ8#c>{L;j)5s=g z4Aad@6WRW_NxDGwW0)y!3=_<^F$|j0uQxU$L==STVoN^TK~mqt^5+gT_s#E~1KHJF z@a5m)JwK_G^D6~BgBa-&4J`yG-1wu}UUD?BN~BNrj^(r|kr3muxIql)P@9oQfdN$S zHHKAX8d9io!Lm)GK2d=Cyy;Ghc;o~)YUMW*pZUkkiv(0B<@*S3Ji|f~p(vp`>xCk2 z__WOi&Ej!=sQWs5=^AFv1)EfBPaNn1t?PY(_H5U+GKekqna>(em!w-lWN3sDIrHbA z+@~|YP#;G~2~*GS9@)ZkwX~0yzneS+auYLSX+F5|6^l8~cbB>D(&8>xxXY=pT9J#~ z-FfcvHFr7PUG|%W^Lhd&qlVGrUh(;{YPlePgozrh20^!wN3wU@y2eUijSZPlmKr*9 zUO296+B>moLMiYVgN z`jMKkNt=YOO6U;A*dJNUw+hVkRL3T+s!C5RVkYGZT(AjPRFnk1S-CW2g&2eUplAm- z)RpObJs+l_No8;e>cvZrpFfx)POZ;QcPvWz!0|&(Hr*jHY%!R^-UP$dm$wL?HUU%c z!Apkr6<34W-^0XN)Y`A?_`v3`iX48MHUH6|`H%2?i14&H7b|e#c{}TssiP^l&~PtM zILBRKy0k*T^i}NC!V5PvkV)l+JB_^H@@xG~d2pHyS=&ao@WiTb+C%JbLJg%F60Iwm z(RC<&8^lqq`&JI+=Et0l)3;p@0nuoKsFK?dqPQR$Z4kNdvu&3JUwld51Cm9YgPUf6 ztJfW_viM2kWs3i8{InCS#Q157(3M=|f`w^+rCUyD{gMhi&$fdYr(hv0xwdt0H)xUX zYJ(3sulh5#ZLHvG^#iKT#Rc6kYujtv zat}zSP{hl!9Kal?r94q^QCH2xTu4*8R~K}DvYK{_c|)SH&8$rQL`EH9-%JvQu6kK{ z9cbcU=&O$7GzA}Pvn_~0N2OZVgQd772^h}slni-3s!TlJ`hw$m`v$5zB;VkWuR6Y= zI@GT5JFRja2iDB^TqiKbT8~r-K6M!J13K+rahdv*+BMPo+8}nj9#p`i0gR{tpGJ=h}ArVJuo;cYb!NhZ#DZ75Ink3gwTNV zEd%b;*^(DpNe$&lO{Y7+kd2FrI&$dRzoZ{vE>JzNM%$$_+;q}W`auIl2ELmDGVp4! zN}2KB=LeBWaZEzms-7VA%q!(!bn>Q;0QC?&5n+?kVNWMYRc8a#?nB2_;u!&j0XJYn z7-hB!dy;t&#}in(X3K?;3e+^uLaz8X4>UWI?wqbDNPGQcnRG(-IU&>SwUHYyRSTH` zQf_$Ql3pRm7)pDmCV5*WCld=L!K!21&6$@8vQFMO=LY{f8^i8qEr}3A>8xg`(~auR zb#Bx~C|n@M*u77LXvZvI=t`;9P@-aID5quF07#6&O5-t z$cDaO{)hLe!p!d&X}Mo_@~bMjF|)VEW`2wvM(<&WUr!HxyhizWCwYhWn&Z{~Mw|~k z2)gcvUUh;n?Nu)1zMZy2Zd5~2=9dI)=v$>4sBO(#?$7bOtFi%g3t4o&1pBh&x&{Iygxgii0l?I0$ zp1-ezR583B-1xddd`Tmo!VB4GYcGG*7TDyS-`Jmbg41Fhf-x|nv`xP951tG20EhlX z{3jOXRfQF_GIFTUi$%fTEW#?!OIU$ZQA7ahdyB!)FDfQx8`QtzDx<8pFcoEv+%k>s zdXVg=U#QRvMW9gzg-KK&)YuiiU2=ehBY z19j-Ho^|%IEO>@MlN7~zm4sKU7KV$eC6Nqe-Q@h>YgELehMb)+K&L{&0DUCiyVL;N z$mbzo-Kq+}q>c3_!1Ue#6I&TxcmE>+`2+Ia8RAoew>}dRr+GQR=6(&p4Z?`p4<2AV zlK{Rlf<-+|_kf;jtvQ;$Nk91WEWePSydEup1X-nrEJom2nv-{B;X7k*eabs=IPVs7 zYv0|cAN=WECs)CyHWNu$Bf^hy$I!9X3+cMB)bXr~Sne=C@F>!Bt?kOp=%uqg|`y!8FK#0A0NR!R;;i`*(inWz>9^N%$^O*DJ?IzKey8m5CCf zh(SV&x`nUNEU&IUGstRPYKO?ldpTJyzd5Q@MiirDZq!Pi-%{sW3H=sxllovHwL<8e zMAgh|5G!cDSn&aZlbFe@eYE(=6~af}en_UqMfjksrA36B=l9JE>rio0%d|Nw{A+*3kzA$f>*x{VYYjo zK~0#WujQ%Y&y-DcvjXoV@<6R;xVD;ct&j?^LA+DXV75WOMh8Ru&JjpcwPN221LJx_ zi!k}|-OHok9n%9^5l$ZzW*}gYpTql=8xWcG!Kc)raUdpg$O`!FpN`*6(q=@dy&Bl9~U+&ZUOVvdf4T zT_`tN-LF)^cyQAT1(->IpvOcLm8s+4jFK>DnZa z25+#-(7)^AK(c&XatnhbXZIF@1RbD~qXXv!mZk=uJ00Ej5GRURA}W=51rMXw!RYnN zgD1%%?fP4YKk%kmpG(1;;g8?oQ1}z-5I@78M9A>hDEzr-rt9i~eRD?yRci2)O%Zo^ zsK8P$sJ?7a1^>JN&UhDX6mf?8QNSNk$nbj}e<+MY&nE~+4VLAqeHmC3Iy~WXiLq5i zqX-xBM)gF0k~fE;*t~UiPc`ILwLR4Y8Og#mzIr5~gWJa~y=+hAZ}+M%HPCjZUmGZQ zx$6}Ng?$T7EgWtPBbRE&i@ z`lW9J(z45j0aB|HF!}(CmHICvJXkMcI;t=81}a^$^w~AWwxz)jp0Uwi!}-u4g|W$@ zK>_~basvzS?^{L3&r@QgKty0!));Fuayhb0fzf;(u%At^DM$JkGTaR5qI`iJ{PISj zX6WN~8S!Ub;73qn0*hJ-t~$b@<`W5Q_9!l zU^Jx?N${$}d&AgUf`4|INid=p?X3~J1x*^xTZL>IlrBJ!Ultd@?%5;El>xyF4RTuL zbiC9%wM9B!E(ro&<`j(gW^_{-3~lb+?OX^`g9iYeG)-2=z&yP``_6pRG3k=OeK+E> z3!e`8?DK1l&q~jO&wk-#y@0>ADoRQom*fx=fJ>$S099TjRzPDb`G|hIt6ShVZHN4} z8HUj2xlQX#@Lc!JXK_ZjjE`Z_lD2nD=9=s>^n6_kWbOd=laNZO6^7~^JAg}2ZVrQ% zJmI>T!>W}AZUGz!me&QAX}NJ^MemkJZ2h}hKJo**9Q8lCIF`oA)raxm_R+58T$ZLO zb9((Ek?PcOv?5`_1C+vs>Wwl97OPV30l&(f=@%T1yVG;tzYAff8*RVUv`$ zmm?i_&Q2%@>INl3)f{}+3x8jTkDQ*ZmlOh9)Hkr-NC{Z6=bmCuhAm=Zhiz#>nOn4< zP+Kng^ua78k98TFK5my0Pv}C)(cUx&!B_RATY57~7!5AmM~v>%ymtii_$j9yam+7v z1UIjIX9sa}{P&EIOe-PKLW^x$AG~u8nju42II=(m`r#eTx9qrn_)o7NW`At`aNgU7 z_^;Sy=pT$!eTnP7fpN`#b{Sf(i=h~_S31S}=)wIXHivc+SDBVVaV6gZ zRVHzb7pQ;Q$supB!f^6$EBKnX)S;m#*=5AZy3jWICmJwyeXjowMVzwo!a`1=p1u_P zVRIa(91GG<0O{ndk4PMTJP;VIBGTY5lho z;o^b%LR=K}jf?%;g^S?Dv(SnEVgk!_Vu3z9_v7iqPwp>Ge8Z4jW0#>v>*A0cIpY5~ z$aNkqXb}ht+-9LZE@Q6 zy81G-$1Wp^tS|ZEbn^i_z(SXwU&uoJh|??A{GTe`b9RK^AO2P$u>J7+7z0-R($$~X zU;4>kh2X(IwabWGbji^L@|RBBj=tIfU9iIncv{2%3dcP9nsLlyb{X-wE(Hqs+vPjJ zF~^@*NQ8bkW>JfAOpaqVjetP#mD5o|EjVTc`sZVg*FL#F_Vjuq>|g9Mbcrsg6bw-m zBf0EAhX-`c|LS<{1Z(oh6YX+TwY6*^h-kdly&aj&VW|Rx{jv1V=Pug;BG-MhkjVW= z+NzoVr)r_ulx2PlH5|W2X7CT+*g;_THemlfwJ_%uAyn}5e}~_Btk!G;YLzOwZ=0$UNg0D^r;^) zUbFeMf_Pyzo_`0<;ofiBRDL^~A4f~^m4tEFLf50w zA~OR_gqmw9L1)BY;ju$-9Pu&c7-f-$1z$Q-bG@2Ep=gEpu}*KTPjNTpm@fI@Xm?Oi zohAnBOAOBfu2l!V1Sip(Bit-mfxWdo271X;gC&}ldB8x8LM)sa=4KMHa&?AMpnkw5BUYU)Qh+L} z6oS!zg&@^`l_?LN*;hyqmM8+!JXByLk(q82quIr{5$^XS)@ajgiZ%L}uPQDNRzgSN z6wLeddw(8f!q@K>>aj}Y@^fq=T^n-DwaHP!m2g`lxGmn2NbXJ(A-F*~zK&|;eVCXp zqs0weYwg8#Q-}l0hR}|3>5@N%JV`Ch0ySg=3zQNl2p%0FL}+RQdv6gIIMDY2{22UG z>{y@R`-_a1zvnKmSHlF`dQFJs@x%1vkX=~pVweryhT|+Yh>U2unI+Lh!3In36l;Tf zC=|L&lCW~vt%CLYwAA%0A92g8KQ`wcA)?p(GV^Whz_CE@LLs2`22VZB)Zci969Rw} zx_Dde+NRI2h;`iMJ#?{AahL(2$>r3v(Rv>u(jcFqu+;dGJ+^Uci<(W>8s)5Ju&Vmn z*Uh>|z4E(8{o+LMrww+a)U$1{%NfvCl|)r_MxH(6d-txnUebnZvyAgg;p`sZVED+%A=$~ zWjhIJxq;?H;0pwSA6~u$rsy*)c#~y7o_Ty~9TcljS4@F`-*Q!bA0Obz89F|wZ8~7g zI+g}-$kw<=uHGxQWbEGQnYYASdWK)#)w*(hykqR%+B`4nVYyJ1?URTB{ai?mDDMS(#^gio$aWK>cwG97I8=|`ldEf{G!%{80|}*OFUf7KvRKB5;K(T6ExAqTZ2Len!;OJUEmRDBMZH zA2tc|-R$)peK!3;QK+CG2)~Tjs=Fwd_fcOPIm53ZaNgG^ZTIW+&}a4%%xXG<85n9E z;6rjhP9@N-j>39d8WF-Z9d1af)(gm(+w(S$F)6}yNy1u}VaT@bqt4~Q^$aExDKBcX zS4i?$4izr=BP&0mh0L^sgLu2~M?Mcx&a2Z=tNrn)jYHYq%Jp-tty+CJGu%?BLMN%@TH~g}#Gw+F*pegS zE!##nmB`^>zsSsJ6)EhsFWmJi1!5Fv?f!1l5L@nzZ0|92X;EfBNY&ci%u_G%OZ0RX zo{o8F%u|`7@W*CDYC-pyfh)jU*u5d4X1aY(s{2M?AD4gh$KTM$Bl%b>)ia;vhXrZF zT-}lvPWdHF7~NjEM9y2A%O*^h{P&}axRtntj3nma#*taZ4+k_`-qNRhG6gTE}h&H>WjpjecbNu_u#aCt(a$Ns}99dI& zFclQaF2sc2vXz(XW}(4>X|z=j!K*)%WNADBT`Q$>;<7&p`FeFSJN4m86!yVqFZ^1z zX8P|b+6%vyt(lspvqQeNG-({8d?c9({Yf^Q(!bkuNVH-L-zJ&~ukxGu-Lf>cWa`Mv z_kVIi2WbG_SM?Qm_LLryUle`IRtfCDXDgsq2M?0_$xcezD&aDDL%D$PTY%_Ku7Fj9 zhVImTZiT@YkA;-SLeyUQqqnMT{{FY%3oL2qC9f?RIyqj%c*s)ahnl`J{*b1+Y-coBhYWhydHif?Q zt}keuKo^eb_z}4PT+=v-?s`0ZhBCfKf zaD|R<=(VDND)~3wNGCj{2d|4uH85^TSC1So&`X2*E%|!E1|;fnx@69?5^9u>3}%^t zMGM8{)OSdTj=;Bs^)2`m z?&|A1uigk^$gRSyI<<3ms_yztR^$uh-6H=5>*0m2RKkeZ?Dz#KZlQ1HlFJh_m;C!Y zxzD;xyKy043QvjznvF~n`b7oRBHZASS8D5IhgMicXf6Jr5Ur(pfl82rDWvkla5*ga zirGr_&-L6p%1GX|*5<`neRU}_FLFx(4z z)#TE>_#jnsZMCJVA40L657UXggZOpPW6pe<8e=hMetQ&Hcj&UB;Ej6F{3MEa)@MyQ z-&ZOS{%TryTGLz{4edLMYHs|espaL|WxgZYUvxCIKi_0oR4Sm48RcH%!8(lx+g`Mu zGprNBgfy6mOJNu<0-^qQwJY4zDp= ztRtaJnzzvP3o%qZFTyPK2ATX8?#0}G%z4huHiEA>3KR;Xz43P)+=>j zXa$+y$GK|mSaX65MZs8G4J>j{<1pdBLX}aY#T)yqF<9^=y1BRM^-u#B^!Gx?pO8^8 zKlqdXN@@q+Wk?TZ?HlSSuYt8?z5F7F)|27cmnNgL*qUsJDgvtJMDjCiVLuF*2^LM( zMvW$rsAQ;^E;)Np-WK*?%!&q$KXWJGR517&>RBgLb#wP z$7&@FZ93rpQTIOZRhM=D|Aw1R1J6uJ?8X{4bEMTUtznQygE~jg5R<#m$a|G{VOo(6 zr9>TWbDXvVWHY^sy4RiEQBhzKHzw)^BvVZJQ;7d?O4{c*G?bEo#lFwi`?{`k&c-n6 zuHXIm?V()f^Y6Oe*Zcqbef|5MH$xlOt2xg1=Yxwn*oUT1U-(G`+4?a&hF2qIuYH=jU68RBc zi`eC6p!8q_^Q>g(9Fy6ije3+FkU0M-YNF}hTMp3g^91h!ZKB@#N@jmjZ6#WdnYZr? zv#-3eKJJ7*jg|*#Wezvc#8_}tr1`xfk>RAmGrAOR4hB!0y8In$p!WyS@81VrK4pA5 zfIqK!Kd_AwZ(?NhkJZmYMHb)avT@xg*urv+$RW$Z1XNkHgtY~|Peos&*4|}-@qI~! zfPNaR$p2JFosy^YgWB}sF|8svHo+cpiSb*siF|!`pZxXb)b$Fo>DTh6x(EWQg>@7m z)ikavTN|zYhS`FY75PR7^e1++ZNGH@zNcePXP?ZheqfpE(X9E#v^7(0%^HX@$g{V2 z?(z0w*b)v`Ej^6=x_W;FH-GGX(y3l+BA7@bJvBXY+TpUt#yOVTF>e_n_TC+R?N;l- zCGUk8lY`R8!;e7ha>-NM+G5^L6VLQgCw&=TB8?U|pd>b`VHN_my`}`5JcgC_gZONN ziHYC6N}E?S=mtA1W0g#V=sDe2&)LM{levs>T4N9)T$0nxZp)%Wc{B+JD6bd7!fUI= zt=$%}Q9?d!Z}s5LTc=)-h+5P8O{~vb-YdkxOX8zMZf}Y`B|@4<6*6ZF?fe#G7fQip zrebp424FfjW??HxkG04TR9@10H2$$zONVYq`)d~j*JX{;q|XQ0J9sAHI*3_Bn;J^ZT?O?TFMEU>S{u2+EK#qsK{8*f}40x;4?A=I7bN_`9n`* z|FyfDuqiiS%$BgfL8=({fF+}2gHLC!gM%kEmNk)mi9Jszy88L%QRT;$tAS$TO#>du zbTh{VY;@tf9cTzm08OX>u0~sS7(9}6iM6RZ%G4DQ1ouYgTKdwfK#*boe?OjS~Xe*?#iPR4|C#x*0O-IUK(~F3un(kVe6)2Oy450azsn|)3YTi z55`>J#eIwFvOK|LrWI7`+XY%>Vzf{R*(W;Sio(n$0Ct@IxHSd^Vosz@(Sn; z#vouP>^tCBq7P#J==QIf;1}Ow#Xfhn+ZCzP(FRI0dX<*f2ew``fge8P{A}wNFn6j0 zQUXPKQ%c|#ah;Mh_v#U^7;eUQ-*~N80P}sH>qPgdQUKGv%kHGV!=4Y2{tvOjBq!je zciO)szZ=^!udtLW}PY47%T;?boXlb4fr zhjO22d)ee`lQpH=Pj#6V$iG&K8 zc#MT~yRLFGiHY=~0-KozUS{+~^6r&HSX>~Hf62pFBg)&(QbL5hdf7 z`ur>GE~^eiASLVw8>C?WAchA-&fclvs2Bv@YmE{_qdyu5l4ae&g9A-RB*qRvs;MFYtF4>YA zzrOw%-Tru@wZv|-EBtV_r0u?XWH=oMBE)kp%{4yb#(^emEjYgW`k`ODq42dRm9hR# zwt{{P(ibO5AQ}g*=kz%gambH7wvCnXiN=X)v)s^2gPtM8W@3g&PX?FUj}FO2sCb<5`~&Nl^qU@V`o8za z(q0{U9d*_;slX9v&`mi4zu`x$(sN;{sek0tAQgtATX*Y#p578R$i#EY*`Qda+t3x3 zZjI*5kNYjKXnvv|g}1u0f#<1A$@{cDMT<7mw0(&=6(iPSzCCnJNL$B~V_#0CA589f zEZMd9?9`ZUt*@&~6?dAV&?-Jb1F5}#1D)qOIy)_7bS6m~ZK%q5O_o`8F4NTvIa-v5 zuN1(CM-~B)P@b^kT@^JDE9gwEU!)D$Z~3Yf$Gc+IJEU(0grf!c&gA_48P3RC<>`a_ z`!?Y~jYfjh2q+ylKwOTX78`k@tG>PEHfK;bC!Z>o2}$$)R&$Wgyv`%^6*-J**O0tD}*p6i|)y z5t|b35GZ^*OXkEHYAtunplI4js0sgy%AO*Um6 zF(=RpPsN}|oR=BR$hhBTpRdK#Y__>R*0^6FhmBLxb_#6Q)$X{(>H^s-Q*}!m5;UJQ{IQaZ&a&rpZf>sq$6<8WS>{Q{wgIt5R_0p43ah&1Kuw z3s6eeEZ3Cv9&6MdEvM?j*BtG$yLqIC438@r*=T;92Sj zadO~|WfSpw^d16+48>;EObT8&yc zML(g*@O7pu7E~S_Uzw&#+s?@5!#z-j1kBs%CPFNAvY7EDk~S4KbbGGOGiGaZGMUEu zqlbV1@eyIUz+Blyxh|^x1$@}%c8BG)3SGqg6Iim%pH)^E*iN^{n9=Ap+ndLOGH;zA zB*q$XSqb9=iYskT{l>mwu{I63$pmcblL@F%4a8+FcIF-DP$K89(d`LEH_CY^*^x|l znt>m)Rw`8hlk?Dqsx3cY@?Q#FWCj9Znw1-wX9A;{G9D^AlNQskq-k?1DZod&#|Nff zrh=7)^5$T9`n}lq8;zvfXrk3_uStX<9$h3w=}|8nIVjd7#&+vV!_QdqB%vEJ4i+i8 ze#lRvAF@n>CN+L@tYxG2JfxvI^<%lIyl}FjC)-%|rMKg7aaoeM$Ch356WYdXO3|*m znJRuP0p)AQJ}86db|X;pLWw$paa1J9GfdVUm7R9`GRe1eul3Y=_$A92JLWRF^@wiP z&&=ra%vFAqKt@v;Q?Wg6OR4q2uOtQix2qdt?-xcCf((Y9BB%mUhJX9gH;!dE7F$7-b&w#qk z?<#p*QUvSJz42ROEfYw?=DWnKzH1h=ulDSPeG+F2uQ_i;>|@@FXu8dwhzmJgqfSTjSQo`1u8VzdF6`oE z=G_TSYVG7DQO#Ih8IO;G0MVGIO^$3ZEQB(Xg)i*~WYdo%bO!Ah+zKx{co@*APxXmL z>QFukf?T+K5|AEyfj;TN$%MH^45g}fkjo{WbwP)44D^c*;ST9nJle;^ubg0^F1mUc zCJjA6Uu4uj=?l+xaFrNrmzlO_N?o?3khj#N_%JzsZ>+@;)+p+hKIXqUbNJ`(}JqHfpi+_AanWqF(BGP`-Jpaf^)erKXI%$O5H(BVGAH4`mUrnw^KQ z3@DnyEVy$iazyM@Q-#@Mp>PQ|lVkR(b-|S?enc`l%AXQkVP3Cu5w_{T2pp6-I4C%; zbi_3)Pta>*IFM$8?k3FDg<~%3Zb-4Gp$E|Fq_+!EWzD6mNEm zSB)EmsDpX9UUWrG2x!ruzLcS!W$d8d~Z75NjQ6xZ_8F%Dmmni zh16hu%)~1UKn;S?#ooTFeMAe!2`1Jz9U1u2`hbV|^zL@2za5Xh^CsGLo6lz-L@uN2 zuQT`M8drSL6*FD&NmpFrii=#4a>Zm8`{%kvWbn`%!5ww6Q@GG72U$g_c()({$Nm&e<-0ET0lsYdy7Gyd>USbMt+11!~7~ z;FPdtzAuv7;9vGO5{6x5cjN{AmMvv+KKZ}7fJgQU0I#2V?R2$_-3U`Tymqyr9P$I` z#)Pxk-cERRO6w2~GcCcaaruA zTl9mZU#uw{vS%ukwBLgB%JlVO=Mr*y)`F9CBXbo&>DE}| z5o#I@Rj#@-bGP=TG9TaESBw)LUmP4 zUiElytnEzmPQr0$3Xm{mk>V9YlX_6&d(d*7;Dzc^uI8tHS~oJI1deqTU8t_7 zEa9{^w%{T272J@46k?sRnvN%1_*ovsT8=l69Rxb-PAX4ahC8OOq}&$pxK1Fr0?LtSyO6&yre>wWM{M&41xQPFm>NQIf!w zOpLK4m8oAhp6FM3z=udfRMw;F{Xj?ol`{=;Cb;214H5*>42x1i(P;ITkpk199%Zf5@^gtKLsRudlFkS6a z6{}PwNSdk_m)pfOrFZ=Z9873fkjrNAv77*<5a5(tOia~~17jrK>!1!%x;i@DrXV(X z0y$f!r+Sq-yt~QA<NNTCXw~+D>X!%vdJM=Rm!`Y})%VzwkX=!a^OgyK^A3WUl5Kh$cEnb!@QTke6CoR@ znCLz~3v;^q^$$mNClEMPuh)66AU`sg9I6dD4%K-d1IUA&^lnABed65;!;L7Z*Eaem zbg+6eA7wdm@sQ$5HHbnziQ{N@{%BOyfn@6QYY=m)9RqCE$$Ant?Tm^ z8+r@u5;!H#B-XKmFo`NPJ;lPXt79$KSPbC#i6}+wD(2ipsYXS)hNElQ=KAK(BXQZIXrwm%NVd+qN=~jsE9ogm zD5Wp?RURGwWZ+oiR4k`)sKOwzZJm`({vfkKYm^|6`o=g~toe&DVDHz+=Kbl|@ADwPdtgSn) zj&aP-C>*d}H22?-N@dQ&GBc=^LMf#(DcS0eac5tw@hsi(db>6=V_zSqfSwa;@0!d? z!{%w??KG*#6&6=z6I_RvC*!=34tK2--uzW?3Ib59_!?$H;ynp!D~B-(9`CU5$S1cr zPZ2VhwCgpw0^)&D_S-z^HW%edW$THva^{nH{o%}<^alfzHLylewDeg=qN&ok31KuY z{x~#FZgNfzB53b3#4XO(p9o_963=D|LUJ5MD#J=WQ0saDefjNrp*#u~?n6kOGn~*J z-jq?GUq(JIpnATO@TjG{n!GI+kM{VJCU9qc-=<1BUEkVYS4yKvUo=N`qAT9(ig&xB z$`xZ=@n%;X>x$v7xb+M6`2tsbEQX)^5uh31ujaEki48bIkPp>|V` z`f4JE=t|Chuw4>iL^iaTSa^G=(_O!)26DRg14>ac(JK9DVoy)d-$}W;H-AW6PnD=S zvlD)N5}Mpj%gOXd%980}t3>18b5rQ0Ix%_!m*=HR-l`ijlbH_|3*GRO2f(+>6p_%D zq(b#6C6`&RAFapTpJb{_dSf!Z4xnn&PbE!*zm(kcoKDuQ<@~kA|DxUV)6-rks~!Jq z#-X`NrC&*QJzsKuy5#iK_!nX=n)a3CVaqIjNLi4>VbnlbCp$tSy}`Ull96LJoR=B? zR>@Fu>~HlPOe%@N>oA%^7{KooXxy$+4y!u)+8bQVgeD~UBT-Sf6uW6R{&;qebwgy) zA_5k1#%_8_x6tw}8nicPZ2XLUmkWl_G`9^A$jsWWwgVK#?)5;S)+Mafbf_r0k)eLk z*&vu1Ah>##0GcC+8?2>C8~P-FhGN+i#H7O>n3nLPq_jqN^ETZgHn~gmp86-r<&+Tp z_;9s3aIh>|d4;j}Td%ZYiMu++U47GCeccr^hQs%aS0WrGLs(dV>$tm<^A!dSL;g{)P6$qQ#LVMr;8JN zVWn8hG<^Z+GbQPD;U+q?((@sEoGE?oNY71%^W0eRz1y6k zr#?fYW$J?eo)5Uh2HCe*njq}3?RbOr)migz!#4*!e$czW5+DT)ohmWxf>(bzcIDYn zut#s0X*!|(vsPqW@zFB0K(Pj-^W)KZ`TvjClYc)KR=JtO^d>!Qs;xr5kPaz$prLuo0EmgJUUaN8h>1-p%zGU};T6>#U@jub?88yOJeg^jwAwh{ID_S2jX`B===zDz6!OGv!(Xe?N% z@lDp3$aeFNS69w?@j8}^>3XtJH4m7CTR7>K^%}P^Z~F@+QoC>olp+jIlt?PeqYrP% z`PU}G#u5cVDUJ8SobT4?gn>ake3?(7j|q#xNbTk4{ckVZ2mQJWlGnL z@L*(0@46~Xe~Nv{j80Sx$6n-o&H?sjx$`&AQa)+kPUDF5QfG?sH@gk(E1jgjoO6$ z>8~xo=DAa5KDg&P(5BAb_XwM}PI$yHtg#j92+`PLk>&s)8n!X#1si@$k{m*_Z!{tD zs5fOX+rwm7pCL^%Ub~c6m+Oc{csEO zzW(q|n@$M|ELB!7v+OH`=T_-uwA6Ady?|crb(v!tDUvYD#T!e9WEo4I80csLS_l&@ ze1^vQ$rD;^^RyU{xiWm`Q&-@Cq{&GAQy{A{Ba0x)V~(5sezG z1FOAK2}3zPXBL?^`ujx6HlSV zbf30fl>lW*+y3G?2CG_-X#V$yoce~A=9(Jq_@ejgd~^FR08a4V*W(sEm)YW4X5W4U zhKWvaNHd9-V&r_m=a%pRoESZIXBLD;AN?~Z+k~Sy5MS4PfU)xm;cAp{#XqG>f8lV& z&oN8YtckZ$mR8@y?+b%^wNbl)?0@aW{@$gcL-@pIoXQ1q^R;`^6=#JA319+>!U8crSKUY+cYFmv)BL_Z8WInQ6c7E)_77n8hO z8(Y{xCM4E!fhvddm_%j4$O@kXW`&seQFqIuqz>MNC`OD-0wj0E8jlvnQNgB~&|7oV zt=1W9`Vz5wo=B|c$W}gzP1>GlT+1#UXMi8T)38cittMsI z_%oE~Hu-AzTFZTq;(m{bV=yKqz>5TH${Sb@13oFu$4trgx8=?|hHpu#MZfx!z_rYs zLyVNzR7rf}+ab3CrgHU2Yijt~_0rFB5-065YI+8xA7#AEWcf$>T(;IL_Uv=qPNugc z)AuL$JS)ap0@$haE{%n0DWSi?=B78lfKFY->qXkq@V8u$x$QqcbKK#n@vmHccgUd$ z!j?8r{9Ox)*XNvo;`Ji< zR3rGcyf4D8vg(74pMYPB4l_oyPS~teXC~bYRM!t^suybn`68=9Qvu)lia?%ZK15ia z7|;}mYRe}di#29pO0l8jJDDzd0LivE!nod;Bk%-LZCsfrJBAQHvMnXNW`?6RV53dc zH>LHs4XBt{Q-wX5QHHQ@i8U^>N26Ji{hL&Jb29y_RC-%-&#qMF!u?5Dp>e)}GVPIF z@JLEI_^ru3J8Cm?N9?a1|NB_ur|k0yuVvTy+>rP{9q&}BJWM5T2+2h>3#rU+uznar zKvaihV+`UOy=s03xU3Kw@e}esTeW!4I_wb4SyWc-3=sSlbdKJ&mVv-zrj@lehfPx? zrA0R$-~HX$`PdtJYI`Qm9+5(|-nJ&aF*}@IjN9D%C$Ir3!fdfO_`db1PawDX9cq-? zoR-7*o$CkjokCV8rH|8=;=k?t~958;y(0z%_R=(B)^s6gNJXzHq0zP(;` ziJ=i6WJn&eOR^F}NRT!HoLI9u`t8dOIKA(|p{K2f zVGbV~CHQM2FZ#2?&`y|ZC3$!&kr;b#sWYDQ)>Uzdy8(tO7|qOfD;=b(XZ@^7G(u3H z>{bUy%#llj7aa-JGF!COpxi`KH)2Sdu2B6PcBjaQ&j893h6SDX1{f9?2(VvQGbN3*}xs|zw$K7=>$ z6yCtv$xTnhn*Uov$m#n9&vc$=zol#c@?`eOeLS>Mc=K0!J;Cc5QLCe5@Hu-CUk1ZJ z)bsb~d1gf8ZuN9HhD=P8nMzNQ&uGRP7dC)pm`>gxJmc(6_VXH!mOrGCEmb{>CTkIv z1*>%E-{*h`+za|94c`y4N zt~J44NS{3JcfzAZk=_>?O??uu!ysCC7MTyeH5mbhY^E57N9x4B}pD|~xLyQ?Ey zQRIpTcHxZwhE=-qnQ_1o%F}ZD*Nj5>X=@&0Jd`BMzt?Dq_c@8y(VHMr{T~vs)oaNz z98S66t~g}J>FTnHZBlxzRMg1sHL~$lJVd_zov85wVPK&DAG`T*WC9RoDF&FS7+_{j zgTq%%w}Wf3-x5{Df-#+;i-y1r9*rA}ADPJ17c=~aLeLxd0Sia*3EqGaNdm8pNo?1& z@vkwRP`6?DI_cH8bOxscJbSiSpV@d!5PvOfKVma*_olRpU^rSyGD3Ui>@6~2aQ1W? zISElZU5=jW6~KOkcB)iv+?*L(qm3}pusl3j4p2-`hxL5k>ca@QR+Oy!(Eo_n3{Gcg zfYs~vgnpGrP5uqq_jzi-3HgEG)p!%#DzrAPo3)lev+WNOdnsBO8z$9wxxegQ1%T$T znT0mt559{Hcl&iabYf~&o3jeOInwRR1wW}J8F~E)BSsFMb=q}kKYFRw#Nb+2^tj?N zSDgM5Z21&sID~Rm=HoewuWkM90rRbIS1WS)qQm7pxW>0=(S^oP*)zgu0xztIE!<@9 zvb2GaD#^nAvAa{KsFwHYCD_0a4UXr+TaC}a8A@EFy<2Fg&$)bKS+?{r6AHA6g;vw# zXQno&4b6~-NovP-i{mPU@T%y<7aS~8;R7?;)*e=WlKdAD_Q(Ewchs&o+Eqewhk+d= zA>?hYgpV4TSM4Crl>YR^5Z&X%CNk%ixH?-_i@0*hX$L8tCbsoCMKqt`3);uCy`HW! zb4^0mB{Z$Sfdq%C{G9F+QbyFPc0#{eDtJBm{a7j0LGm6t#kBVz-iUg-%WXxqWrq`V zn93MUzS&2OqJcZHzJg8()V=z_sv!CbYf20u0aCUrw!lUoAZwjbliHjZORBn_KTOmq zk1lwN%g-R3A>-P8JqtpVucG?KZfPs9SBE-exI#YLo~>F%mDa-k;JxH&`Sj17n1J$} z1BQ?~Z#WDlHF?)C2#L@PkY0wlpc6rmj7tvqAbo%KBpIj7h@bX4qprR~|1f^h@=MX* zl$9}o*BEqDDir@n0+ih#;#>0d_l5XHXxa?nne))JD?GAUWB(UEinaX2-W9&3%S>TA znehs?&Q?2NGkOk7`bAIL9%fgfxG#}L1|&rmN{jiY{LCQ?1pBc>jB~i-9VGtB)l(vp;7+pY6t3_nospBsx!zxV(_K!R2ErTG1HWocf@#qQP1CAG1%s9U;^;Ven7> zf^o8zs35E0kWhTn)id;~tl%_-ycON{hVHNC}mC@`_zoE8)jwerh!sncU_S-KI4UC|F4qce)V%S7E_=Nm0=Tbmr)ncTB2+11B-a%WS~8=6hF`}0U-8SS$Ne>a z$^P&k$1hJkGbF#PT>j7Gmqgt7Wz*SKoaL^*-g7AYB3p>Pfa$Nq??%5Qq(bXRD%^Mp zE)5GD8Ja;In@UAY3n#qzbZUh}2Xp3gs@3{6OCQuk_id+kF5|kKqj5lY$RD2XiXI_q zxUV_q`DT_$uUdxL+}{~e*qC)YL@v7TY5H^)Rxuy446=Vu4Vj-XKU8_Ib_)o6WUN@z zX4;4Oy8mHMHBLQXvhGcG+pR-O4Vhl$#r3V(9J7qzt4?Y<-F1%bVV9H(wl`jTLTBxm zHMN;@$vqNVxLNFcMNkj|Br>^GH|*~R>t(_^_9A%NEJZy!Jn8B&YdAe|Bq?|szgLu$ z9?ll*2{JV(rhNLKMp~*v@S&xgy`XI=w7A@{w(BgGnZmdq!z5GG^;Qi~vbRH;GLgnC z(+NgFj5m$o5fUNI0l&mmabrKz38UfiG@2@FxKrC& zW(!!FeqcA-?BpRyLsJDe>{0WP_Ncv53s7rY-<)Jg!0aOvOucFTlqLr>_tzh(Mi=g} z;ryn`a<#+?m4$P;A#Vd(%cg3$!nl@a3#QvBJ*yfGF+Q!PwJRDxD3A7!kg;fT-7>yv zbM?ZzuvWXnlj*_M6UTiKxO~WhF+;>=o11nbd^o>weM%jD0I?$uqn2WsW`BeH22N0mEjTDoyRI^5_JGf4!|6H5? zb!~cUEj!-8J@a{n8ce1)*UGi^m`anv>&#&?V2B0ynI=%10`6|Bv(3hl)So$ay`r+y z+FYH>==5-{y||^NQ|Z&ftcJ_9TN83^vjc3Ooam1aNpclkAo^&;Y4Y*Iv}(4{?LC_; z#@UHIYf*-<=m%*~&yD??O%edFL&6?adMKE74ME%n-Z0G*k_x1A-tpwU3L>ZC*St@OR8KA~6SG?IgY4z7g) zBR%h{FG7I&qF_XQ$*z%JlnisBj@DV(?v?}cvhWu|Md8$pjBqYQ>jGmV-Hhl~n6c3_ zt@P0|$hg8ww$`Emn`uCL7>_Q#$B{ZAQco4Brw<@yzCY7xNirtTOvWg)Rc1XB`_+P> zpUTxyU902bw{DeO3n9AR=&$vDwnjNuVBMyhCN@%Gc9q_pN+U!|bHdZXJ4lSl2%@t! zm4-{*rdB32NRbm7eqe6BO+Y(ab6jB7$le~!);Mmyi!*0Vn*3ZiX(GMF z+fE?EDFR_$i!*kDsYux2{XVPJy_fwd`BuwZ$V;#}X3?$Ra#%p``jG_mY*VEzuArIe zriPdUpb}o~QML2dMHHC1Hm87FPq6ctv=p-0W}1VGZFDNr@Mnb(q z?brW3_?Mb${X4;TiZnaJ<_`q+^fy1uO?=L5hnBFD|KBuZbi1rWp@U)HqFWM3qPCeH zl!_TAG?ko&;3>g)TO-+} z+7mo2_t?Tnv!$wx%L*w6n3-I)Si`(-V;|a$TU07g2C>cCZRu1#aoJ$vGYzjnX2zH< z2nE(u*Mo#YZj$sswnUI25_2a?gIN%B^QR;f>y=#S_|Q^L{E5^W60XEY(`F26$p>90>V)=D zs@H4-2r~=iY=mE5=W-uzY{UXQ&+h7RDuWK7ynqR!az88hJ*9QAp)-Y`$u>`Ey~CsR z4vQ+zPuF*qou8iDRepYYbk}*UE7pnb=e4e0H^;tSx~{>>6;{g>?mMiJSJYM$724Gb zqMQLy(4X2^0_-4I);S+0I1ch*f@2?r38&xbgi)Z||Q2{Wn_@zSpS{41&4{atSde#F(Z>n^akpoT?|5f(TuGqlA>zsZE^9(T< zbN1DF>Ne&#>{>%SaSpNf9@P(T{s-j@Fgc#Z;5QNoc2O@k0C&bNlskAU%RWT^RjQ}4 zv*ZBYlSh!_JvRazw*N|Y{hs%oQr2A1PU=X})F`Xn*O}fXf2qeFx&3eDFFC|`Qu2wK zPd4r+^1YIkr6N?Hz5r3XtX!Ona67oJ9ltZyG*U}Yg=20Ay}Jxy?Jnpv63P97Fp$U` zB}+P>M5DWXJcO+0NrcRMa{`ItB9T!5SZj=>9En^bop=uJz*-_>dcgf&Xdf(-zydEO$ z53To(LplI)!DtQD5z!aUh}isPba;l zHq9RSVXr=R;O2;_y{zj@r8{d`*0O=Oll>3XHvew!1e+a&MbXVO zm#L7llFrnf><6qN#bss@@a3XYTU{?u1%;Ugw-0$+_dDmIVM+h{PeNYDeJUTpL@qhC!+L++L~b z22)bLQM9D$met=SO0oZ2*FjObY>|sAVNp*jrtbsG1_4D4qpW6zoUDXsD!nUmz(z3x z%#4($b-ruI5wZo<(FgtBH*vLve~{mf7USa#mp-y4($YCAe6tEpps$04AVt*`_#EDE zRl-OSzgW{yNOY6PLBS{HYR(dJv5M29%6rA8LuCL0VtTvPLtgOyJnF;X z0Xc1Z8rFs4qN?)D#J}7p;!da(=L_FTcn~&75H~Lvnz+BWF63Q@9;=x&MFDX$Zm4Tu z2>i$kAq2(~(#w$Oc1pFqNY{|f+8@gA5GiKaOE5zrahZwa7)_tXrPD+{jdU@jPZ(_% z(^&DV3hZJACnw-|iM^A1o|MMYPwlZ+r)1~MsQc?q1QNBUgQO&?}(QKO4dR;|*RToiDrR}}Oa zE@k-1YLl-_pG}J4-#T&6%xLE=xxO(QQg1iVd2x(`+4lj7T25oDP^(2*oAbyUWokY% zJTBp@*6-H#ha4dnKV%poe;|Uw-4D&8gfb6_J0Z$L>bvNnRzwP6N>orQ!a5-Wp`(aE z^+KE+CFg(6Rcs5QL{kt%mf833b>ve5=6cT9gesdEz4Emodk!qtmkcw@fyI&%Hh;Tq zwDl?7KHBxk_rJfBV5>aV=9VfrsS)X`1e8?ulZv-k!%xM|m-q7;LEs{x8m@Op!{(?# z)`c$Uux}Q74ncd-b3{HIUiLngrikRG5yfVzM{T_;-b9fXDkDdHYS8cQhD zwD9lf;6k_T5f%lsJJ=y=g&`me={g&o?23r*O5#&m+t&$hWiSNyl-8zoLQEm?EYU87 zCFnsqx>no{-72KSARg&OBi;-t*A=cqybas3Q-D1ou98HHc%nMQtA}`JE^_L&Pq#C( zh@8mOYs$_XF;j!?;ta^ANOnC}A|`RT^7x>35m^-rCt|#WTGO{&=jg|C;lKq`&%^v0 z(6=_zu6CUb*Yp#6u-G|KLK{^n+M21VWP5;{{-dmg9GI8>i@mEnuJD;%EKGBGDdtts zfQB|Sqz;hYX`ta<3j+_sO>u)esXQ-ZNm03(w@x*UfV z+V$wV8{9`!EH#H-s**LGW3oot(Mr;eDp65oDmnIzf{{@##DX@og5;G+IIL-O!ht$8 zk2*Yryy*wSdD9<{-qz^gN(h?3(o^%QLhb=N%QZv$)~>a8h}b&)<^pV;cra{bf2|n` zgPnawrbdCK<3T4>DhAy zN@m27zmU&+z*OC58|CjRHXwfjA-%JqR~yzwef^37HB2p$bt{iLUZ;jX zY3+LYvFzJyB+~m&;J;2C&y>!#8bt>AJ(=^VQNI2ZtI_;I%ZK3#iR7|nqPBhP&1iPH zhUTDMjXm^}dN{X4$3pMRMtVwn4TflE=4kgXKlj0%Bfr{w{3hr3SBP;oLL{MrW{t7) z=O zmm7pjt;i=G^7#f^uY9ox)3~!nBatlS(m$3R%uGGP4u|P_VPYaPZI~_&6TDMx^_1um zYk8Btr8hK6#0&c~s0eIYK^0?zo7(gm?cy2e&cs%8ek zL(KU0=O)#j@M3CAlsu9t+2@ootFvbIDBC#ZyS#lt`nZSK?V?zd+Hgz!jP0LVd`Uae$4PZ$rTe_@!ziKUj`>=4a`vZ&rGVE?*@yX zltrDlvrq7(m%6xwWRF~2vEnEb9%lkfs!SH)TIZq}C!N@KmQBvhSTXS$6^xkBW9bE4 zbN(FZc?mL`6muTX}58qUZ;EqI%5go)o5*;6-ylE@TJ{2p&l7j0buyK`s z5SZvw29DTZBz6zWTAx3hveQqCu8mFVPG;)ILG0ajP-E9iXD5nxYh2Lng^UI)^hQJ* zctY}kwy27ZzQ+MXuw`;Qt+IwK-(J-e>CWB>iVM4eyH=aJ0q5=NBKMYC8C1PLz8hql zT?XP#JxA-?``DBoyLR4^5{IhOjX_%wubf-X;D4;s+x*3z?|nMQF@C-L#MPeh=c0M& z4-Slt0cyI|Pk-e4Q>XsSl-@?%2RJWuJ0L&?3#c7*=8guC72F_SodzdCPW1fj0z6?c z%sG0!dg+gha8dN6$8e1_&NfwOmD?Ks@8qL4qDxJ3em!oEvq`-o^(AdXK$0K+x}gYG^^XI;g8g zf&)a>F4wOo=nH>5q@d6I%8;IydXy7%2U%XvINr-Q-)WE!-8_NIY6UKkyv(3=qx;#D z{mmk~>2v@yiHhvDS0#Ki=lJ1}gY?7%>O0Dp>vc>S4vmoF9? z?BVF%2W@AG-XloIKPWjK-*wF&#pGU_=S=)^t37X9^h=hhOgvU@>!_@fP90><=1;?8 zzkH_X>X)c?V{c@tU~R#A$_yT}w5H8p`o7zb(zG5X$E(NB%t)d-x`pu6h1a8(yu*=~_$Y~>6-LVm=6rr4y`q)xQ< z10j=~Cf746thpgfP31L>PDv(u&+|JTFmst{BKlCbl_!%O312H+q}r3|-zJs2cc26S zIMfB8>NMvxogh6L)^-P)RS?oB~^g*UuG`#k%SW_0`GbwZ3#&a6_kBqgn zadl2?C9%0{F3c22$)_sj;e6L)MsL=qir1RUxHs1Hy~BXix07$zPZY*Im?K94U3oAf zilb)XZpKzxZs7=^ zve}Dm<)eE$8`nE|`Xl7JG;fj4!~;OkD@ab9nLtQ`{F2Cf)u$0i)|7@rF2yaJ}DAEPxi(|@9w zPPldizkVpql>H>OkBj^4HiL$%D?4~Q+1Ous;~N^+J`h{^gbnF8uHB)Z@8Rvc&sKF~ zm1Kn2HAdvYW<QfjL1wC_}=iMhF<*DK3SmW)w%Br-q?$d31Xw zr?_wh=`u+2Tm5m42 z=qNg2Lz+*BlQ!o+Br~Lt+@6yP>B>daoJJ3ZCxivZfeL4&=5P7thvwr0@jd&^S~VO--=9{Hm7uxoYg%&w*y@`8 z2G~+>oamkLqsP8p`>WV*++Q}kgnf`&6OH@JV@(%=N%J+c*Yb=0HNTVc-g2tSzD;*N z6>EBv$~pBf*ck}-mg$iWlw*0S{{(ikcb-;a_-5GKhH1?1>-0mWsN z+688E1A2h&v;0{YR#LT%>k@0DHv&j+Lq5NlnN;b|Gx?6oZ*8>RE_D{2V4~X^2)$31-HvlL$Aax?c%M|I<+r^Jb2MTKKW=h z+}JrxIh)~5Gi3#DxucsDuz;j2!qO+T6(voG1W?*p;MUlS&fN~&Z6*onur zuPgd6dF5j{F#f7Lvp?ezLxi)BXQe{cHNuWb><&Elu52rHF^MmmO23?R@Fq@pH92Na z?UDO(RbP>>dg5JQcU2#6XVG8Clgaa^mGrA-&249gELOX3dBJtOzjh2R?3dV5X}glh z=?w)P$dcae_dU(ljv?L5T9zkkn>W{=#=OK_+nQy`HplALJ14rfr;VidTdrE0eTZjL zH%8+J>OY>$q$*jb#AfB+=E*ttPb%qur!HGsxJ-9jKBTyGl1W_LcFsIe97wLDiXiG^at5zq+E}d=n=Apd+8HV-rGu~F_Jm< zv78yQ8Wk%>=VMsQ3n-%MlSbMF`FZgc^)9z2Q<7Zf2%x#DzUlQ04kdZ+aF}!Pu2)X0uFbw`a7+D)RK1+ojuPD?tF8DOAzH>bHi<3{e+aTIo|<4 z-roaBmb&-42Jo$iPK+!um|qB5qrMvo=~Y}8uHQ4{fzOaqGlyJJ3BRUC#|nBp1tSOu zoP&XI+XyjES`D`&u1#7uPqkJy@>EKSzVB1~_{?lF7Vo$bLB!|7Te zhs=*?g6(mi=>$!pF_u8QQ51dbd%4WDA5kz}F~Gop@u3(gI)Bd#I&a>bpl_>mO?H|e>b>f&?+ten77k`x71rJ zUxGndYlX^9N9#S9z#KAZY>43c;PdCi12UeuaU!XvDsE)8t59hkn2qF0?fvs~-4_yg^dU(e6}KKx+)Y*3Hn-QQjc9z%eI6q zBMf4v3PR*9s5?|IJ?XJBq{de`>@tzdToP#sbERd9g!^hxn_@#j_7-t_3Z}+v5hQX) zlpvxXqiV-)QMW5>eT_ac*Ofb1d^bZxPijP|gg)a*+)tjo!w~B*hq|k?$5$d+tC&e5 ztQcbiexQP(ctJt7=p(o!y)tqgR=VD*;ZD0g`SRI1{B=ic!CbY(5+$aV$J*4aO)q}~ z7McwPY@Fmz$*$jNoa9B%RJE~5e_~_zw-?u@pHFW3bM~8p5PWv4X0Ljc@#wH?XY~tH z2)A=z6Xqhy^IB6q<>$3d>nWSkTGEqB%O6uz3hL3^bLFBLKI=)&zw6(H31tV^?&&h& zL@g%zyCpAe@5K7$DMb5r01rqGr?S{{# zP7H}poH%+9L8;(Vcu#xZK^?D^lmu_Sjqlv3sgzg;S5gW&g(lOl3)6C@n)wGMANcbOzE112W{gv-$sRcG)iq$p%Aa(G6?kv+S-*}oS6}|i0Y!}UNj1C zcf}7DK-1H?Ul{LZCRMI-^el4zimBSPTREx4_niR8fWb*$oLFq`ijEbM`ZWZylk0+O zx#2PiM*h8ebN%m zU&qLedsU9={o0o<^LB-$9EjeyM?W$XR+0_fSHYPlv!9ZOGDk+sC?pm03G9tKVXc$t z1^R%Ow?Tt_5mLUdM`{wrH0wo%!m=b-H?anw7DYXN21#6GLosMUHxzRm;HQn zR_|vfY;P_7$u~7h5o`YKFj`9=$Kcqc?R`RSdeZg^U6dtShi^}0coG~nUSD{wz3wLz z2`qdw@xJE5%U8_XY*}BW4|8+jPrZ*c#0Vf^-$RfnX#^6VdGfKKbe@fzJF$B&s(TVo4XG7)W?N#O!6MO*hP@~)(#zPCo5vV?g)ys-;az^XymjQi-3Ea-&wfWD z9Yc{_tl9vyM<2zO!RsG}C|(}Z`?KE`R?^+kT|Y-69?_e|)s1_Ps;`o??J~%G{tZ@? zyCMV9sr&QRbyH|o+?%iRYHeP%+bq(6EF?njorRV6ewU9XKYgbYHy9t_5whsNrsslQ zjhWG9&7MALKL7>dKADGA zEsuWqEiKDFdsJf2Gl}8{6Ppl@7v8#R*~LY#LS~H8gNd=cb@{xzVi&#h1`cIl%lKy# z#gB&Fuk&vn~DY{DTqxi&)cji216QckSBcA68z`d5r%m)^w>JZn&aq znLP|G^2)Kf@82&q!HFH0zxuW2(=JOCKb+V^ZtkVZD_%Wb)$C#C)TZNk=ib_{JtD|B z(Zj!T@)fV1JoXjR$xX`Kq_^F5;~QR{Wr`52~i0@akRH4}W+)^=#nb$yYou*5i=L2zoet-%a=CAD)`~ z@@hTt*-<{!R0_vJ?g!R1f<{E;zdCWzQKJ;BbKCtvZznPVSUqcwU8+r$&C99`Es z6<(Z<0hfj|u@k2uVhLvmD@Vb>6~)nAk}>8O=$9DWTZ z)}(j>BYygLRPXvh@~{f^QRL_HCQjI#7_%|)%cWIc?Wp)_1>POAdTA$iYoP#TO1~5Q z&`jx$KRtqwVEm%&ZWG`&O$cx;IxL8;l?DELQ>C5dXY-XZnpHG!r(n<&+T|*7`K%m5 zDR6$5?sXgeclA^;ZHr-DH@?uFZ7Lpm-Y zOiJBITGd~hh_GDB*Anwnxsl7tB$U@)xkk)-r@j9TyXT5 z7PYY(KlkE*c3Avk@R?zE%h{x^%Vq#>xqt&dHEJJQX=G`I<%U;AyWhIsP>Xlg0>XSN-TUS; z*mIve*CD?QMYSCz_=yx6%k=|pae%v1ewl##j9eH_`?XDRabb2RGO43s8aKp{n_24y z?h7|1?qxQ|YKw@I{hR>{XM-8H5iq;#F))%$a~|k^;mB}?EtjacxJhu!z>{&j~Up>~z(gMwBK+@{Vsk2-kQ$`0{By>ZqTwngqN z0JrhY#ePKqzJjTn9~|ZcVhFc<)iBaqhEXVy6m(99Sie62s_8FJj6l&StWRj~W2S z)!y!#^dSsfA>yhdvj8P~tGrY`GPtDK!-rr4Bn7Y(6oIiiL2m$1PoL^JKrck+7XTD% zx8;~0_0pWqxr}9iYEe|WdXz9Gib{J|h=Ggj2|!0*o)UV`QJb?5m0M06R%X0=m=zOC zR1D(Xih_z`&BJkC?#EiuF8%ekdfqy5kF9*P4gjU=*unW)_{!cx3~|uP(z~+l8k0i= zt9hC5eDCjsF+1Fs*3uILvd@eU(e%}uLl#!p@K7gPaw{U z&UxJYwzFJu*mbyXQY)ntS>e0{C6uRepCheG-%ctu>DQvJDf_h z*59U9t-{ta7sP$*IBF;VJmdQ`LXz*IOP$vNzOhA67UV8mCLgxUyCA!`3A{ZN=8EWA zFN@I7tnN( z_$knIs=hlQY-;zcWqB-&fhim1&e8Oako7Vj6VIZ@L{Fz$F=Dg|)HGp}vVU?cquW2| zTBetzRISUF)D1qbY4>(BHq!Qyt$XAQDJ7#-y3UlIb&a=m2aff` zCcBgzV46&*E5tcBpHi+452HsQp`gL2{}&S`lNvuYV~^1MI7nUDG$e>VltY}hG2b<14JjgruV1Vn=bc8Pi=Zqk!f+v^oyIiCT= zVayfkb)2Vqf9*xtSlOv6FUlgXhu`NipuI>NVl`n=-7gc%3AMUFg)@=M-jYwG3;zT; z3xkD0gv~cHUq;WIcA6n~W`&o|dZ93{W~WCt%yMX`6Cce|GoX25_lU3?(-MskUL)T4tb|N@eX;nUC1GynVUso z8VRW4X7>*6?Rhm~4j#lBWe5yRU>71*IVn`>-9sdn;m3xm^5bI%5=$Kt<&0SBkS>f^ z>X0s~91|Jy$niW>Vr}|DAeIryh+{;7z749|6F~@H#kE{>5l2cuL<>4Z%EpL;vJqjj zKO{K#o22rTj|Rm3W2N%O@qc^0s|?@rD@5@O$Y_6`0&8LdZ)&IX!D*t(ej;;)Z zK6I&^ZoSG&WruYvFO^HUK6I&+#>s`r#zSyxg&4^g3$Cq-HhYmwue>iX z!66ar(482WyP7y)cxWh`9bvvk3 z9?M=j7qkxN)B$f$w`7xz&sb_m9k9JtiviG(joU&Jnfn~Fi< zU!#{1g@3W;b2S|UJmyOkv2!O+a#^2l zyMUcF%R^8UMf<+u_zw?+sKY}Lm$Hc4h4;p5>|(J`$C77)t_Gszn}DE)%7o-{se8O_ zd6*_RCrk)}1Ew=to-9n;>tNY+GoQ|N?X2*PuXYdtnXBHvkBwd>ctScw3{ATO0(>=I z?Og;7R-9B5Q7i}>|GMqpz7tx-=qBUo*6Dli0I9$YtN-BrboS>6nb61x%awqj(p3iC;*5B8D|viQA$ z3Wuca^8EgKK8T~?Kf__H{fwhdk+9g`sfD<8Qg<^ofn-*~xg&(CU|bZNZ{>j$nqw5Y z!$MY_+t8mHA664_PW0~+ zW>8^ZOnlXmgzLU74YHY(Y2C&b{8OIO4ohnpiTY9nL{^a zK+|J2l}NwY+EIQk`&Lz{^FW;jiK2y?y0uN%QIL~;<4!#nihZU>k%lf@8e)=AT>A4} zCW?1hG4fUwAV273CAH>xQ51d?8J7x*wL|fNoD*HV&hoq;amD$rm}G^Zh{lfsoK|a9 zr1psuW<7pt#acS1K^ILaJkz>qi5R9OM2CIeVWnCIj}QUPZj@)DrOHg{RkJ)s0nI&9 zK5@cZ3I=~sSw8(6-Lb`hy#6w>(DSqTEOdVUfX)B;H)U<+?QAeuu4H5dVVon>EwVeB z`Z1gtE&QK7LlbZ2J=3qD-#u$o#G0QIX!E*;iPsyu9!l(atoQK5rYOOIeyF&(cHp_H zl$6SiF9dDS1lj|P70dSblPi8DR_^xS{Y>m#U9sCb!>jX2?Vf|~wfPw%-@hJ;jo%n+ z`no|jt+K8O(p+4XX#G-6BJ*W1Hdmh4xrCVKl_$r)99!7Si>!*1E@yn6lv6Eh*%tiT zKA)i|*Kent?0S~tfDy##54UQ_)yER1yVB=C4@*>?Q`1`d^eo$R;>)_l_vg?!gI2MX zMe~7^pK&AgpTGqbGqXh$2Aoy%||UCf?JDF}KUQ7mz_yybK; z8HPdX8jvkRXZQ`e8oXK~8vL1VTP)a;hs3(&}ReXl6*YU1IgIt?TEgPl`^;w^j$5lds#vL{#PN9!SL| zZ89uyaav-Tp*%F~cCs8kypGUH+TQ|&4lOo8i z60HBa8|^pXRN=|?ewUrAjYjXV&wToaQQifAk>p|{JM95kVGp|qO}$|^{L#K%Q?8lB z?$O{l&ELbc?xZR=3~{YS1zZ|mwEWrt=yDwJftbF1oYeC_yH%PabonQ}cnwq^cX zb}%)u;)GYn?C#&7Ma}A)O?clDjoFo0-_?j1(a%X&eukqf^Z_Ll0+A$k^=SDT<(vVr^_?leN{mRaM;Rs@Q~*?7a^di(@y{0diJ5 zLNsrS-MS|G9)2a#FK01j^d#UZy(YU=BHDUXw!=!2#%csbB+_@-Z)qIp?tByrAM#;~ zC9Mb_qNi-98|fHm7MCii5h+EC?8At-E*yueYFs3%TAWVRVj&-ySk>lPTh%D%=q9Ur zuI855NR-V#34EA$GCI`Mb!sZzm3>WyCo|$>mrC1tvy#Y!4HB#0>9k#yG-ib$CMnlu z@}FIzFFE_~a#zF1fi;Aw(J!5rn;Jb=A6qr~K%~ehw%Cobz>^Z*phL2+Dy!y&l4U__ zxP)JF1jo@7!Obx(q`0tV^}3+~oVv5!m*SKjVK7sA$_({4cUf_ZhFuw0bx$vQ;~Fl( zzXm)`vU?$1lvBc8={N>B=#73v|Btsf0k5(+`~MT*NKn!fi`ckOgQhi9tHGrv6>1Qa zCmL#~w#KCzTbH!O79~-vh@lC~@o>Oe-}hDPTd}RJ)}^*ZT>)0!q~YR;gG;t@<2; z3T`Ya`G3Cm%yX6`2)*9l_0M&|bDm{p?z#85XXc)&DLoT2bm~1duC>y!&5_@jiniNO zbGUeD->%1qm2y1*vm;Y1HuR}zb>klPHr(s4=ARV1%X4R8B3{vA<-Y90D7T+Q0?}7~ z&^-IFzjU+ggKdI|aJftN;gP=V!;O)BxMSDtLt`KIVY8|8&#(_qf3|%%E!D$5oS$nS z{Fpeh6S5DZ?7f#CT%8@*hfi=LA_+!v@Rl<6VLs|KKKC#w)ksNz&kj)`(i8B!2{raX zk}h^P>F+UFXt5VLXk{`D6}lx75l!;QG+-YrBCDP0>C>GaX|EiU) z(CC7>9%e!VhQ(b+>nvH;-UvCVUmYRhwtak5eD;@BJ~i)CJ@>{U zFl$jmItL}Ia0cT8Kr(|7tO)}%8U4{8S(9;~Oh$*`COxtDlxpC|&P$zJoHZUA&tOjO zKu>p1Yw2l7*k2|I>t2~PBqhZozHbI(ah?Gon@7fgRH+l6Wk8C*;i_0+1_X5U3)|xhj^YSZiUe5c!nV0Dn{E@qWUr-~B zoi#7>|8M5yAgh|`W_i74W2oAjyB_SF9_7u8WyMStZ#lhB^Rnv8Zp2n*9<_kQ(0KD= zW(D)|6=z-+<<}6Im-*C?-FYLw+YHnL#`uwIy94ubf4+HXb4DV=4wx6Q!!DSYf?noj z#kcd!%M-~w^Aa2UADWkcPTGlix#2vuhr!A-FW-yzZC;*qBkfe|yiBp!vSpEZxyud5 z?^|f*7PpoPF&e9<5>L=EO~@hN9XOT4=n zM`K+1R5mwE(`c-b97RnGD>tXVZ?bF7IC6lM-q)xN_Gyf4C@1=%;`;}QyA__$T0p^Q zZWMs3EUX%&V^$RdRJNy+ME||?5j+TYKMiF67kZ$_eg(t#X%63$h3_WeyGi(-+6&+N zIeg#qlHvQ0x(MIey5aGS#b^fU+Dm9z$G~@EANbyXmcw_TzJPQa-)afzF5~-$o4cJi zZ}_fKJySit@yUzt{I0{dNnR`P;mOYtm|&fKuS+Kz*1zkq4ohefJ{9}zsh;Qav3}Ko zePSJOHSqz~>(kv*vDzgcVf|2H{rYc#_4yIjvuh6X{HgVBv7t>l%-FC%P$uqjK6=Vu zvEUj3#1|FG5tSxl_g9rIkdvj4{}=p!W(oVgc>hyY%V6)mCZkDcWv228>B+pk&G+!@ zn}{jJ7JVz~ttJyP$2ZI$9%)dxz0q@ZiBEOmM0TiR90~b!j6@f3A^PeklYK|R@BNf*mB!pY zyXva?h{$=0~XfRnMYJjiK z@lBextj!GkjL-fZK`joQHfJ*pzP z((C+tC7gSY8K$9jp$9jg8QH$ro*j`9d-DigQo|Dcge0CqaDCp2R%n>=_VjOirYRGr-U#@WoLW z1qrOgO{`cN4*P;=M6_IWgH%l^Vj6-VF}5;DoC=5i^(-yPy|RMU%EN=i$<(rcdH6MU z&8ZkwnV<{Kwxu<2&x&y0sqhgB20*%6!N@gdWH1tcG{VR~9(MM80vOqvtL3u#&FqWC zPQ@In1kb-+XWAd^OI?qiK`YBC@-OSN8s=^cYI=#0<54x~weS4_WB zr~sRcq%=dwiavtI+8X}Q)lLh52u*=`6;S0=z};tB#Q3Y~JcT9um^(#`3xnljDrpEx zMcdjlW*R*YM3e|Wy$s~61Q<|5v*c+~Y$O%CV1h%EXZ#v(w7;>x975V&7V>4 zG2~RMT7a}By}#L{#px-sAE(uUS>o}zye78G!|!F|;I%UG8X8sq(Nsm2*Wdv0TH?PQ zuQ8`y<9nzGI`*&>qL(cR!;|UM?;KNS>rag<-{S1k<}-|f_pjdD@)?%uW}@&6TVqb<-k#Sd4p5*(MnA$3sMbbIzFad zy1cz#dw(x%*Z~QfvQ;FfvNocoBB*{oKK~ZJGB6crgZ7mM<_vWY$Y~-oeGzeDr3VvE z%z(*naf~VdG6S>49tlK*I0CVzOj8(e;sVu=>TlI`#!}G$)jv(J(Xa60W=O}1`K>le z6j)3-NTgG-)h9WYH1P;h<2_5>xsTMpF`~x*D2vjl*$kL4ChKLWMvU2z9%P0f)8^JG zu%YWek}pVtN9n|~gU zIfzq)MRB5>bdKb_vHBR1oGOttOH{jfJz7`uVdL;V9BV^6+Ow~03BB1o-7>m&s$xos zbEX(xsRbUL5)=!5zX+>;IVl)+itzh; zJGoPxY!&IcCmgQ+uv9Zr71{n^imV$w;f>EaP%PcsKUr2&CJ_VIKIR~~QQYBeqqf=Y zp?5rELUWTYn34H2cvq`)Ds7;JCstSe*z_L?WEfEWGdCp?m?4+v;o6E?pHq|$CAJZSNgX_3Ni=9RO2arE z$LU0T<8MYP(`>H=xAq5)3}!T~1U93zZNO?fIW(FFl$vme-x)Dk^ly?XY?Ow6z=(J< zy&8+Vc4bjA_R~|GGgV^R|5QL3i!3vcNS+FbGGH+>I}v(Z24RR}NrA(-@|%tI4JJ&07_mvFvjkG zH^%sQr7lAU=#I9ajofh>tO(0K|Cx;O-5gq^>+R;@@&yL-itvLUB64kWCAtQ z&r=A)eE~yIe1&~&VTmYI^WT?B`9u*AKO2dzp%y=F$<1WlY*gW%W{-35Zep5ua*fnW zq`5Pr{o1(Hi&?7d$cOFa)Rbm5G4K2;Sy^dI8p#7w0DbmNBPBZ6)MwxB?cKMBF6p~( zO}Txe%FpiG^~d$uw~IfgzM0Q#eY0M=xSa1>G{>%x(Dj~O#QjkO49-JLq6tC^C0k9= z5&-igvqXch&7bmfza}G9q_mX6ZV;9O$wRyLUoo*y)r!74-8aOnXE+g{WypIIWERzR!eV0z1M;(2#(QOR& zlRrhDk;F&?!QauK9|%G${307+%`q^dV{?w`ITl>`6K6*og$&5*B7T%t#P4q>nW7je zUU&6q#P6IrH|PgqlMh(jL@6h_cC8xr1;YUsA@55y;$e%Hjd%!pc>zkrE*u>hT5NoF ztaaRAaf>-_&9bpRWg+N$& z$Q*TY9^Q!fvZq=V?FerKl2%;+%AN?XITnsno)7cK^8Cg4tY52+Uir>y+Ns!Bdtzl~ zO(FIR1~Y>zWQqfi^JBX*DToRcsj)b&1_STad0MIq(IURw7+$k_VIZ08 z(~B$o2-14ds8X$l*&UZcnjAOpRURrHDP=I#;fzY;bI6*5E1J^a`wL0eFBmV!wemxU zAUVAX+YO>GtI#Ta)jWZ);{>ocAz51??qc;APOX@&CdhZdF!tt%(C#!$YB7^~f+i3# zz@Wxlj-^gUlM#Cd9aF?0X_qQ_NCmVGuoetAM4^w?Xc ze(!)D+gLsdJ^pgcuF%60X!IIi!H1s7vG_B0H+z8QTULn7Oe{s>ONe))aHgW?YS425 zdd`OZMilrgN6(=U!sox@z^xJ2Rf+51W{b%=M>ZL|Z=ChANN!b1(v>hr7M%fKCQqdd zA+KCXkQbZ7*g?WO`KE!w3wPWgY(AC|+&I@@1%5sm5l;o;Xlf-he#3XXrx9HKTVCXE z`IY{mX?$E>qLD;UO?ZQZVl9Y9_$SXblaXS8t_OH#!#&`Lu8A`;pcS9lRN!Hq;% zI?}3SJmMA6v`kN%5#f`(EcOs#R9qy&O=J6Dnb)+{Az~TRPMMKvxcppWnbxD}+3o*gVM)Q9&bb9ORs#(Zd5h>zf#Zt2}!m$EPm|W<+Nz-i#c@B@qiIMG*m>mp@wE?m4y07suY-N zR4fo-HKYHp(K(Q_R=&U+W&^%ujt5?6bJ`dr+7<#h@PSMbzo?O}>KD~&zU`?|^5`!_6KkqGfS^nYj@kOPACw4%MxmSnq*_JUn zy=x%9w%N2}QJy`><`Cf z8vXq6sL`1_YxK=B8trCTXcsF>B4<20geL+n{MAT!Y)~$bW$B+9SMJZ>y0{2>&Dfv; zq1HRB&^6_+5GmBXrbV|yHCc-F_Mvyu*thfJ?nfyoPf$S)@Ldp|@bCwoE)<+=3m+(G zHDO|Af1sKocbyk&DdTs(;7hss&07++qsU3P;D6W;;}Vl{9IysOo`tlUFt_@7zWUn* zXexHYBQDu+_~>3Dx$hAL?EQ!pjtdgwi!{NzcnhaD5kB^V@WK_z;-YUrA;!kf8(*U) z9<~J%@QnnJ_}O@Z-qIR=Q0M}cNCg3YG+&NpOBLUBPA5ILxQE6eQP>4xt1JlT&vLq_ z(Q8M!cZe1>MZ0&uLyh0WYik*O0z&eM3D8}>?0R$lT8elaZFtoLlA&XGv zF0~J08~&-RJH`L9%h2a^sa{2(C@0S{OXRljG1Ylq@Ml%IKAA+uZc{>rzb+u)p#a!?DB^9m#zftTv|mq}S{8!a;{IJ~XfX?f!o>}Y zRM|ea6!{1ja+5xgU%LcpDmLz~o~M5F`ACgKj0GblW6vHdsgBQdY4klap-}+!}OJxUkFdI)oFmh|aaF#znVZor7FQR!izDuO#C_q>9H`ZDvUQ*dGCP z{Ki^?0`Xg6ctE>DHe6OG&F@utAXVO|;jQFSsl_p$j6MtKQ;<5>oHkn{B_k_^f2jh_ zQLF*Sszb$C-+q?w5ty+~OFh$aNkJIX%3}03RzpTz-5aDz5K4!hF`jcL(#132+!x|= zSDC~YAMw06cj!TO8MePJ)i3NS=SFHg!d5c&+H(;Hk1Wk{Fd54;!t6YqBdv8GPXXT4 zPL74iAMSCAqv2#>vPm?Aaz3-^%ym~y*Nr2i+(lgB z;_7OVkrgOUw0y_8!i@M9zRC6rbnDg3D_IgSE92d~TNZ2f^t0tLLKxGktK}knpEadj zzs2|7|Ylp+dUlIx`^lHG{R{bEYM>*tN8PaC9ZpLrysz=otYl-`B)h9qAD|? zqz7jdv3zW$u#-N_RPw`)83AZD>n^)q5u4t?YuIzlAwEb1LbXQ%MGkMGR0_hqw{@BM zs!*$CLaK@2EEg(si}{1Z*X*siFtUHL|n#xHxXwewVYt;^GaLKM4F7#UbEbo>tm(_>f%y(^`{Gv=6o`z?1l z*+XyPWgaJWL{3exI-*Tsv!;aUtTq}fG94;H%?OrA3MV!pC+F~AyOli7; zUGrBUXYZ|+rg*HmN}Z79*PnjNR7xjmx1cE>SfoSuSe#Z}qh%hMVH)R_s4^I|B>Z?t zR%`6WZp0_LZV|tjI8N>Q#i$eFGrx;wvoqjT0_ltvpWqtc?HD)0^+jRF>p40<;yNO> z|3=f`7thp&6U_kIrpK0^qU6id8Na)k zFbQ4v^BE1CIXF8$^H)eh>iEu4gD(GpUgNn3s9W}(1l9k%nlt2^%bU7p&N;1oJdWR^ zM@xdxrF!beeBeZ_ma6@-@TtubB&1w*RXS(JDx_u|);->K;^}2zF6NEGcaH0CeSxfg z5P&hTuAxA})s@cmr)tS)BJxKi#70hjl-5vRSo-)TlV;kt5v0vTMhjpqG8cvaz4bw6 zI|N8i1^{`E`D&m}c8v$erKe)+o|Ny7`Ia^ruF?X8YozN-!}X)xLVts}GLH@6m`3rR zcu^|jGx;z%^vj*%cIE%(C_8GW40*X!=b> zLFMGGRyzLBkxq^JsYKhnU#fl!0d51`@(;xYGG&m@s8F@6-&f_ev&+Yw;$+K$as`tw z!H9QccOsdiE{M1P5~Vh3a?9S@5xRiZv17YGfWQ=_XIVschosAGG*=q{0J!m_;0A2< z%@$!*IoeEz)icP>j<2--VtgO5bTLVIwBg730%6f%`J7zmMz{4j0q=htgz@@K&-&xD z&Olme13{lep_Kju)COYDv|_ACLlFnsP^wI_5#IK!i+EOLM1r+Q*r4hq@%az)!Lk8+ z9xjSub}!YSzU7i2b*j|o)x(wz*k_~|2kLlTGg*KJ42SEXraY9?(YK8hQyi7+lfrN) z1!OOL;C-=!iK4NC+)j<)Y?BD*hOx|iW7iEq8z(bKxzHBgM`p*ZxXSwQ${O{-OEg?X z*dw!hLof`_hr#TD!EiP(9MuO5sRo$8Q{Apfe+;9C=N<@Qui;k|J?Tl`tHC`$PNHYv zzEm(&2=igfi_V=Yf(;L|$Brc7sDC)bmk4sYWv*S`y0mO1_xfp(9e*1>G8_n-@N^;w zv;3E8FDFT?&!2qR9`MPG4OL>7#9g+dT0?y8td`?eW6y#6k#!lkNeGbhcBdS5DhEXg zbmJ(fVbXrHOS-B(4JoT}HT;hoi|u|`*Y3*(98t;ULG9MyOu`?s8=Wr}PY)HJ z?c^&3H`eN!8aDB8@f36DFcFwDXVK^>Lv#M7UMj|T%GZ(^K$8)4agf;3H9KQv@@osP z{7QaAsof=9$0ukoba_HWYS^C-%L7jVGsp7HfcN;u-r!lHWsf10AO>Y4 z9ZmmRDmL+S`Yaz(FxuoTJt4m87Q$8u3xP%ow%oHJ>QgUOtTi6+Y5t0nTZhpQ6l;`X zvrWRVWRrSiaSAp!w%Mgca*6+Sn>fr@s^PGjBd6AeuP9amN| zvgm~lB++XR2|tR%?2^Y0ElK;R5ph&a`1Ad9@KIpI_V~ELdhPMCz;61$hvUs1^vEOM z265A9Y#}RDg#4ZMNIH~&fG`p|SNQHbt`anK2iv@COdXLjqGCiqKO}^Pt~b%y zE&e%TX3vRF7?r$IIDy#s3GzKx;KOFmWrmjPL4#f)Luw(Hi2rHcx=61RKFLWy$SOzX0w$}dT_^XJOEPr0!ZyeYOiW%CT#uyEQP@- zZpBF;8VWN>tH?_#F1KsCZg(78A8jNuHh&-c>So`Q=;{FlNNW|mguu6KK!4P_GYvNO*`RPJ zdU|K-N7j&$QpzO_FFyVye$ zIrCcRTr~!7zRreqzG6CdyDEgLsyMw;u>(Let!m;Djh^HL@znx-4b6M1IL7Ty{zmb! z;+1w8`gdJ=DDI|LBV9_zBE?;=-kC@OYl9fpwUMWxAfB|Hh==pG&=0$0g%G(8g9*%r zv(s5Ud)0V##L$(~%Ocf6ZLamKj#Zm3`cjv8Ob00>KCVkVlb)$X3B5vrUUkzufblEb zC9atUxj|xM5B%CN@}OOYKBP+zjC|*n9E>>FEE*7z#bd;J(F+XU3x|^^-5fr%`ltQ~ zTY!;89SS5`5o+QTCDp*64`0NcksJhy0@O?AG-SHd1Al4!d3ZBwK5LMy(H>xG0ZeIl z&&#f#z?K;Y^!Shy25!Gq_&WLyyNv#WF4j4OsLb4r9_SOV2XvHEIfy%icaU}2*7IvQ z7<*wXxYIYO)1M=z6|QKp0N7%8*>`VT^b1(PVJ>>sKezQt-;vE}+t8Rl|Jr1+kdKY0 zn7T=^=)M2$#9K}&mvk~DQu-<~e0k?aO7;BLrEkPJumX5CAHmjNNm7w42w?jYa=oQo z-y*z}o$uZpXaK5dx<8q0m`|^vo;%R8NNWV$*v>4=*$6FFBX1VGGfr9I=Z$~5B?M3E`ttFXJ}4P`bGXHykK?oF zm)R7q*PoLWpHb!d)K9UyT6g*N5cn>Ixrv5`eevH+$A3-YzebH=8zr5sYK4_DrwG-P+Y6G# zG4=3?mV*rzn#{8@$Mh@o6w%;Wi0qsZMRhxRAb&ExC? zr0zWKD9j~FiW1>EmV0VR6YD><@N+D_jAy8N81mBtq*0Kk_##f=EdKF1qYFKrSPc?8 z==q#fCY9=XO3H=r-DrwF=S2AmN92V!VRK`Oj2X^=bo*rE(_7u;CU<$i1nAD`$*%eF zwD_z)s>NRGk!pg(0FF&snTcIALmXz0+UXlFDtyePLL|mi2-h$dR5AKAqwP=x^vld* zod(3?r0yoc4{aB^)^&FDaRVOA60Qr^rf zZQAnkt9bjRX3$O6mgh6`{31>g$AnMYE>3e1WdH1I_mu@N>HFZ998y^R(mb?pS&bSB zGNMmC^|~>Zt0#R~LW!ae5+X+$vvSTO@sC4|)Q^^HHz;h?X24&rU! z9Q5dycaejZeGZiV33s6(+r&ei&cWfh8HpDKrMk&>z1u zsxZE2K)?8+C&-hPn+6ZycOA9fw)}wy`=?ST;Lfq zk!rS$K&a;fFjl;E^Y6hJVFtC%`CVsaWK0;^>y{3OPt?6F=n`Ugh@rd7^D$)68$~H# zH`j1@(#0lSYbM#{=3+4QyfEeddhp-B9ljvsB+*O%LCE@Kk*2L}9Ty~RNbZ?nhG^n$ zHKW$r3Pt&KvAi{-w`;>bQa$7$37KBC)%IZ(3lpI6Tgd ziQXbkfN#n5wO;sb+e)o-g=~~sL$crKR(@Z8T#&%$q4uJ1g5U*0<8}DW)X@On;I0! zm!zj5eZ79c3sv;I0RH&-FXT{Yl&*(l#nrzI&75Z^A#b9+ShvbyE}GW;ct|K6T69d&^AHOe(hWO1W^t_<2_tX1~5Wn7uEO zupaWYkHaT@oCH+hQz~@DKRrGVe3fHY`R8R+!z?$1kn)Xg@fFQM{^@C+89dc@X;b#}AZqT6A25vY4I zLY*n79{9UM+|t9|vpWg=R|Mp-R?Cnb-zd4S2U%*uiSlrR#dHN-5y=E?naY%e?Zs~7 zSmF9v{NfE#1DSrjzNdQ);e-Z5Z{}sy5cksbOps&g=MSVmU-y>2PksB;|DitIFn_hkX2?G8sj`nFU??8CSiTMFakm7jJe zW8dBjDS>R}v|l5nCyKZJ_wj}Lwzeet_5k~KME2X3iG25p|87L)yUkCk&cdAU=uq*W z_-eWLo1i5Q?+%z&8x%eMx6_e+Q~GsX z;A^k#5B&7QcSpd{qo_Nz{nd{iukF#2es$HaO?#+oSPv)*eRb9wgY=~g&t$Rf@onCg zIEP(MG9{vU*B-7$PS#XaU4>V@D;CP>s#TL`A1<4SZO0&M=>)a`*Y%7tmI1VkF~@-j zRPzY!3P!8nhqBj0Tz)fK3e{kjh>NILo3duTcPuNG_6YARK*`=1q=@YV)yKBn7bFhq zx;NW{Z2N5+p!A`*bo}$}9^#sy-F<^3-U11+pq80DybQi;TUxXvOjtu|p+qgPcHy9| zWl;;+`nCRNm-~0L->vl-{rkM@-^%U{yVgIoKLz~a!kF8s|9n3$R6lWC=wdBMr<<4= z+&I}9el?i?q+gBtMgLhWxJqTff?Ofq82X!pp2_-VstDnnzHkH(rkgcz0!0Lpk8QbD zC`$H0|L^t~Yk2r3s4buc8o^czi$oBV8vOwPOfe@RO{?|;aRWWjIz=FHE`NB-c5syv z7^KWRw&f0i@!N<}?wU`pV}Peb_+q%C|2#Yg3my<9SSlP_IC%6;+tQLH;n8a8FKVe& zEwRevpspv?LSFsxSyDu_0l1R@oHh_1$MY>}qdwc`N-d9UnBz%egaEP#4MqqcvS~Oi z>mZa>C2Bwt3;kHWrzr2l!c5#4jn05Lob@RrBJgP>su#pFfY?U6`RK`q|FV;T9b)v9 z*JA}chyg!FFCd8kQ69c7JE`yXzTTrfSRm70 zd{NZioc!jl`-J8eWSV!M&Y z1u|c-UDHdRE)#zGpqJqXXhnx)4GbGW&|7XSMB6UtFd(KtC}f+AwX=7-@?p5u+q( z)~jtJ6D*ypEhdW&Q#CnmBw+5pFHuCwW z7W{zzp8BF%umg%sxYWR(5q)4FFTFf8>SeUWnl0e$R^iOF#UsMm13mQXWkKKV!3sI; z!O)rZGTNfbgf^?3&R284&NTNoHTNK$R82*iSKyMq<>t4exN6k@y!Su3rPup>{Ahn~ zQIK$6NV52rn9Z_%ff&(gvzF6H>>raEOD4VN!N~D(-KSz-<84^T>eQ}R!-qBlX=Z;f zFYj1DgbF+s5yWmWRF||Iz=jFOi>aX_7V*CN$(An!$%2;Mh=(84yc@f+N(+|g|H35? zz;gv%ue;0RQOEo>AO6X}j|7QLoGpvh%@x4K6Ld)oKt~D=a8@sjp%qNdOgJob4R40& zg<21kC6H#|_!uV6buK(3{{15u@$xL&<-rr5Wkdb84W)v~#T!6K>C=j;;YB|BLKJUX zUQQDJ7kfgD%XuIL;er;B<3b*U zSCm1AP?L?R*bM3jn|Po#ruT(k6trh#q0Qx2LbngNd~F}}NBzy%umXUzIJZOBl)o~6 zypenT`PrK-{AB;zUw#ZMq`+&xL#2~ZRw~5+afr7LR=UJJg1;Sp{sosE-g4=ALG`AV zc=F_;8C!pR{!cEBw--_hHcr76pc(2A5A3|r5yH`md8i^am5S9rBwmE!!*fo5t6S5c zclXO{vxIPcGYU!DOl1z_RQgqR&MNrDbEcJe6RKWrAX8+wE5)&>1ch;<#bwMKT4(*L zo@>KL&wUF{@tB#hR0vacI=WmEBoyO^*}`iI-EI%qT?UXE0S`PaS15|XY9po8s{{Yn z1#%k%Nh1&Tw8?pR7RvBY{e9<;j$x=qdMP#Z?W;|8;xi{%Jl58`BLH>fRV_FrXUHqoZdhmL!KRD!cPfv%v8&VBiRDFs_PE>E%pc;6>kWO)nje# zjm%09{k>6&rLXfgZxB>|JL=3Ce5GTKo`}!8RRvP94-fyNQ89e+*&Oi!Z4g#+gR~Ze zoyR)Y*gXbSR;ekCqsK+BOo_2qK6M7C`mBr3{hS)8UKwwz)Q@D{lR8L|gAZTZjq4M{ zXe10leB3Jdc3*dpqNenM)Wm_d$Yb$aql3iCKy${6)1!mJfAX`xJAd${V8lwbG4p2> zc(BOuE?rFivhBZdOqm*Y1l4Q-$8i37wy>pjcoI*VmM1zFq-0dttm8un+#AiNYh!@FGqO;0P?Rnq5NzF9I7a6D3 z|4ld!*1Uo7;ZUgVVEFc+`|08D&*7~`RzG0IS9N$c&0(B^2@8aY0}N@2BHBKt<0Q+S36^AD=!Egy3hFyPW=io+X!t83#`HoBj%>A-kx=3frcn(Pan7P#lg@W|?{0dK-V3UIr>;grf-5OCe zRy)!eo}%yoGz1~5EpH!Wd*`4boXV*aG<6gPh|nwN#) z1+`3_)ExS5ceuwhnm<{&xjS6-y-&KshpYH+;F}w|!+yWx#l<)uB=yWRfr$fCA z-LNVnLy+WwVc$$wPTM-1$fZnTvT8fJ|HEzL@PyDftP(?e6d!#dj!+qyiozd}u4h^7 z{tw5wSrG>xuF?>`(5%SGU%=u$8xByP<2j0;Fa2lvi{WmKT+w}HB7bFIe1gSw=6>Z< zZyH;m`^2&-5(bznAXpDymG`b~F)|~)C0UXYmB@uJ9PWCH2$;~Q9UCT}w*e4)<}dC+ zA5APkpB^wGK5|Md?G=&4N>)tbj6c)dJn{)x=7%Z)zTCuMWmbPo7y; zy|QJWWKDVUq;fL$U*AE}2ZT9-Yh*{)JN$dgbtPJY8BTfrO<2;@zBIKO@4B1a$OOG4 zdCgKEL@dLVOjq~#F3r(j-QlHObaz-!iuCC3EZ5&aG^r6y0L;Y%*kUa&pP0lsJ!2AH zYC*VuH44ut1ruKR|ATyvx(Y`@AcwSlg$Mi)V9=K>eDT;@!24Y(1wSN>&vdIb4oY8= z?L`)Tyt=i{->z``%T2Hoca<+tpYXTsibv3)dtzB=zjixyP^nYew)Kmrerc}u&kSrXua=BO*1wGg&$`o87e1e+|h`F)uS4n zL((=5pq7oR?xsHPY_n*2o*i)_o(F~%!knOTSUP;ax4X$F)5=r4Xy@PRx7YOM`J}uL ztUl2a-BfX4rPtT*MU8F&bXW_A_5x=ymh77-`PUn_;adJKqtfw~%>|5d| z;o-IeP&U%|)if!LR3jz|Or#_{jXKzSrqzeGt|PBQeD?l=YXqrGHU^tt3Knl?f#cIb zAxR~CngnE%;NZR1l9Oi78XbCsZEC`1a+F&#cGgdg3C`99GK#hI=Rc2X=-`oQ z;yWtfHsgo|cd{l7TG!7_p@`;{huAGplY{Q~y}Nly+vpeO)2fKK$RxCz!F}S|g}GVI}3S5ur8L*MmP#GFJkRNBM3b{Z2;8ee!49);;2L ze=DJYFf|y~CNr#)0mZ2h#j1d`NrqEgcdr3yCOYe7zyscmlcfwRYQ3QrYd8jW?7hGW zTLdK<7m9(b&{%Jx;cc6y&`hgT^#jIuSncb4t@b?(?tL+sUV~-)lX)7}>(FHw4qrL; z^LHY*%~+MlQh3iFd%JC>u$^qm^BQEx$oITZ)QCYgSz&4bYw6@oRX-h{H^2iZC!kS% zabgi3@%bpaizhYfPJJcuWIGO10CLf|1>0)X{>jBkRb>FfP7muaRTA zpB%IJtpg?`mP{DlIU&`^iG#1#Zhp3I_#1V@-wg(Bo{&1ed&2Owb%0*IY}$(MC;7PT zeU{d*>t4CI>i{-!)o$*r8~#}8+|8TUE&lj`w$}=S;had#CByVl%rwfq<~^77qEl)- zA=Hz*gUze7_#P1qdFrKhqdvf&F?|&s2E;+kADBo%fyYe4%OFX*^rzpQ?q^iXTK`xT z>#tWJx@QZ?Sj!aC4j1b3pH}YoqkF%qC-^9Yf66!6W3Rsjl6rM-WDwbC}w%ZEn$6i2M7Mmy} z(WkcyLKKy_Fj8mh?Kd(To;pZxZOrVaG0HMVl%C=w%rZ3_<^4Z0NR47)=85RO%ZetX zg6;{j>}T=K1cC@{ck$z-Wb?8ub@4}*adMxcmt-ScM(4Zh;^UT`oN6vAB#*#A8~H5` zN7tsBD;b4u?_ZZ1SF%SPSzG2l;Z+gi3~aa`2^tg0!lz>QrXvMs(S~Le+*5z(t>A22 zIuv*qm*NF`|Fr&5=^dpw_O8u4UjQ{(#Nh#CGinYQnSi*s94Y4O#>sr}B!id?UbjPk0e2mD!=u`x=RYWZ0=fd*!`iUB!cU7j5 zXv)D9v)Z|Fu#HN^sHT;!)eru>ZZm_G^4w=&M$Bzi&jy)(U`p3DFs(X1$KJ__3KGuV zb=Yrj?^gI5Z|~Z^!FTi)F3YiZ&BsWsZRAt^d5E^~Q>e9#<;aI6LqIngLq~^30crRX z4+z@CLx|T9ElP4@+eWbwPp3)S5TCLhh=OI#mprscU`0K4pa@LLMOhon8*m%{J%9#S zFMyu5=q`+vW-&aJjjg!Yl=p+W?5LM>eJ|Vl?B&Rh(knEk+)?S9ed&dLmJV+@#x%$c z?lRn6_H~yb?(*XEXqVq-hMzg{;ncYDYh64`IV6FsK*^i}!LBZ;OP!9ASskA{l5c7`-M6h( zKa$h7O36G^yZBWp8IZHwE173bPEFerC36Z&X6tdaOo!B_rd6Y4x=}K9QZmoP=Pp7q zi1d>s!8PIuNFB{eNzY&g>IvekpqD!|;wksuNp-u+r(uE(Iw}kurdZou0xaH?hW(F= zqB(xhDx%)2M)>o5WwMltTtz2SP8iJjQ)H*^D?kN*ma6UW$G*}caqA6KeyStxQoW_w}Y)F)pnmt%WI7pOQlTQCf0WM z3F_1oihl)x(knFL)cEGfv^)7HHp|t0`7YEwvOE2rvcizZ$bs;1pCE*L9AP?gfV*7m zE*HAXyCdyg=q?l8!x!A$Z&sr?pC%xf^^Nr_>z`Tt?mqRt$Nn;@9eI*JG0Y&vMK^q6 zJcQP(gP7Heo15`=zBkJ!g!sWCO(2Oemya*10B_0Ib1#o8WM=F*K3n;kC4`XUTF*PD zO2k<_Xwn0|`JYBNBZ!PB9{}EJCEh9<&r`9v6c4|k1*5EZBe=q&#Ibk4TN2mUb0>+2 z<_DOvlm^;XCvc4Q0(M)OL^J?;LHp_!!TpDs9_~Ngmjm~gfFv3FVixW{FWfoYFQ2v}R9`yaW5S%xED%4=#M99qCL&eCCx&|&AaAZNyy^O)@RRd9rm%iJD&)0eRIO$Dv z74s9zGAe0fP>8~PaynC=qJzgh;*XmXKG9D)a}u)O#=Zo?Pn^zk-{Hoo-*A_Kg8f@q z#aw<&jVt%(y}c`&J7dEF!HzvQm5e=i_9Ke$>oC-4CDmSjc|KJ3v9H|VN)#a@x97~a zWnELJX?|&2e<`s}HIkZE*)OQxb`@i@ShCHt$8~?nVUKGSB__2=Wc?^DQpbDHBxyfQbM1v7^c|~z$kznEI|T5EO@EU=T(kNe zOmfja-NUyJe{T+-+9sN2`GoJq+aBY~W#jsHvrEB`d9agPRGhYey3gTGo@gbWOOv%s z>pC91+DmkYt!B(KRA2pPMxqb=mnr-mOZ28Qc1faNcoEHi!H1IQ@S9&TwKv{f?sb=H zclouu{L)=McoLQPZZC74W3SPVTikf(emCBkBXlJ0DsR;l{b*N6ZERs@utaN6^Yo)( z2~{xD(iI|Z9ajEKRN}|1(drr8JxH)=P(SiAU><0cG$aYEtWHBUF|9==c#)X8Jwi>et@^{*YVx;FK#Eebg#R*iX7 zyfkLboA6TEKC8zJe|}s$lY751o4R(hgut5!a!o_g`1K0gH9^#N9Ua3J-hDgkX#UyC z0*9F|N#v+-?(aX;_OPF3on(;~7+ z+!!M{{c(Ny0x=Ocroi(nctEe{7#&<8pCd;F-|S2R&IG7&KuxJ~Di}Ghw*shQUvU&U zV$HOvQdfXe+)>v>G!pqrP%Y? zY3F`kHLSP(czKJ?Mo7l4Iork+SL(vJ!oEUJg?)d0w)=X*u6=!&`}%-g`r3>gOI$9& z#`x2As<+2y*TWxVu*z z+imVGHrrJ)byq53UeJC0E&JNrd79nbtf5n#(mwf3txv_ z<)+e`-Q{2Ia-qAN>n;uMve;c7a+k60GWc=y{J~j0pY_+#@BTcpqb0gKIghN5`A1tj ztoiYG6j0dd{3AZVWU0K3Vo+ovy!D!#VIDFREjHN;5C3`}Mf0K`MIQLdT*NaO$C{^f zvyVggbeS#=VZOu7J_;rG0ntLr(S6~k?_;77!9WV4UbQty7dC3dflGm&d=0iG+$H5| zF800p!JijKQ!Xj5M-oILsM|}nv{88Ip*gW&rs`KgVg)PsgcZ0_Q4E2i=yep4^2#$6yK0qp^JxuD zO~#~Xp>%3o5jS}&pIfhs1^`retr`GnWoo_EZZsgE(^I8P=jaLe2)hn(2tZ}4e_$9D zeY4l(ia{@QrK2!3%Fx2l(uiP$>J>)1&Gu(UZln()!aS|kjE^JI2TDirl4yBEyN_!` zv9!f_}t-oU;Prx0_?-n zUeE%15+J^z=wlV@n)AxwwHJsm}UNG;U#~y`_J=!|92ZvZ6 zz0Cop_66d`WUX7n`3ujY9imlg=ZpS*UhFK7o%@?qh-YB20lT27I0w^ zO0>8J!_9Bkq;+{mOCI!@NuWT{jpR^pRp`d40Skjf94&>!n^yl>jc%L>p_{_f(bpou zWc8&JSp|w4upfj{i$5r}?^hJ__mxq}Y-2OMDU72@>`H>eUn!^{ncj^-&$Yes8LY&tE{e70^K$2=S>NWdvd-(peG(eR$6 z#E%+?A2lu+*^#~&0SVVULZ@`5StitFKl-wtqd(hz8u|OMpEh|Q`}vUx>VLF;ClgV+ z*|9LIm1q7`)qt1Aotm$F{&un;{>G-FOWM6nm1X+wm$I`o;?EsVm_~GQ*3PkfW|ro6 zB@X!}tB@7uTHjbB_|mvO1sTJu`kw} zTYG>mJFO_T@f7=dlP){?8V#ZosKWo<$27==4A|-cJ3AjK%HWfg zKbuduSzYS29{6@)G*w(Oo&bs>54L#}>fFoo_)L479Ag$5G)G$4DSI)wvsB;#PSt3T zPpn*p$5Za{4;Fcl*xpN+ z{f0Zr503bieYu!pdrjrGn<0(Qyu|LTk$I1aqf*7EEt9?hyP(lHr6jy$_Kv)k8w4Rp zE6ep-9Lk*6(xDH`!s>88m^;_(b3@5 z+h&A5TCtPYvs7&U4}7Hfzi-T$`#G4(lCl0vGLhoH-?x)U@$#{KM~Zti*G@g*u`er9 zEZh{N`=NrxvZf-E{md@!ab-`#<=$$PaVd)DTcu*;8uJhLDJ+R*8!Zt4uGQ1dt zr~C!w`D8YDljmQj+RGP9i)WEPk`UIbh-2?EerGU|l2C zVX+*iH$+1f%!nXgvhcNFj)PpUUC#rU)|jZiOgtNmT-SAM00PxN$G@gqqqTkEiAB!s ztqF8SVWt|-hb&206HooZ${LLakg(I1$cdGP-ue~!KR9>cPxf}zfQF8%$@~=i)dgPQ zZ~Lztfmf30WbE^gn!u0bvyGK*Edb{O9p@z5xo{7=#Z<6~5q8E>(Oa{+k5V8!Zyl0N zNFQ@0X-q|7CcM!%EP1xX60LqA1%^g|?4Jt=(+mKT_*({$gWv4{KLaUn{;mP?(K}2p zuYEy)>}1VYpMw-OgqYUOU>r7$I&-_>o6bDAEy_&@(oqL~~Q}cs6fpiXS?|A5wjea>`lf}QP z5DRFKQrF+HK&j}l!goRXp~+ap?0C3Y*@9t5_g+j?e73KlDE!J^Stg3NpCpk_#lHQ0 z&q!zgB8QQNQGYV_#KRf-Z7Pl!>9?bIiIF-e5SIQ^^z))_oY#}%5}VWGwGI;_fc}?? zV|~saqY+xOxbMUPu5ZUq*YQ<0KyOx(U2hJYTuM_!`U6s+J*RPk!08?7=WMCc^}U8J zd3>LQQN!fp~+czj9%z*On-Jc8DQWY>z0~s+APohaq)|#-r`ET&CCyZP%ZVqdmIU!mr zTb5rnm@Oh#4ZQSU>4bT8rkp#2cNN^BBSz@4^AZ&RFIAbM)y z3q3bX!^`4Cwl`v3vJ+xx+U!YDC5n>WZj9C}%j*xlNw6M(6?nN7DE2KiWveRC_b@ob zu^%}B+q_a{*`Rn-ib6nR@Y#?xnz4%}fGdS4I^}a_U=Gbm_KOx=U)-Vvb20=ZGi@5m zQe>*WMkxI_q>2@6cQBBMFPhrVBe0(#aOR`#X`z2w=$^W7tGbuh%&AJ>%qLnS)X1oc zLt4JPhYdU5y%R=2n?!??Jo^eiT=sojgO2UZAoHY{ER(XRYs{AA>V{lC`SI? za%U8Twexehv@%FV@MIR509cb~2&_J`P!{f0Divh5Rr)9P;z812(xQJL;-`+wcC?(U zUtq*^)C2YnwkDjF^UbvV{WpxCQJt+oiD*XQwQPA+E@Vx1igL=wpLTaWE*6|h2{|9F zx@Jp;WBvfOUd#?94P#mP1$dv|>-8ArX7ruk3kfiPGZ}!H`bvwa|4iTG2H&9eQn7u~ z9+3s}B1B?iT&am=cs8YSk!DR*DN=qxbSP{{`~86qX(i#eKUD_vTwetCG|)Ja2n!yJ6p859eMU4f0{lG6OZURv>Y5J?B0(Bx4ud z2U1g4A`tPJO6@X`%bL7nl24|IQ%e=3O5JWjh`}s= zJQeLQ1(BZ08jR=T?CDbrKE6k7ejQmVHu(+DC#NSP0;ypd;VYA_;-O`cBeKMMO}IOQ zYXnk*BL7+_#cvw)Q*^0mYdVuh&ssQ+bB3`7+LF+Z_F0Uwrc>s_3r~qwr|@4y>7(Up zrD89=?jd^ong}A3aQfGNj~O%@&*7=r_+T=0omxZ|3>L(A%fw==`G@jlExU+uEUHA6 z$~t_qd7rcL50|%!C9o7mV|G^c*NCDdT(UMADbQjgN#AJ0)Y%x06kGHcxkUafJS?ZH zL;Gn_fUKdJvrlr^b$nxE%R0I#bHrwejqAzQ)m)pX+qjxKikwDH`kiOdLU2F(SzsyZtq9g2nnwCEjbU1_^poo#`3NFkzcZRRpOY;gl!++?e z+~2Iw&GqJtJ?vNUtO)2iQb(bmbGRa*oaF@e=OU+wJG2pFd z-umA5a!a6U&s88m)VVov&SD5Z}RccpxkYFoDw8K8~ zBAHt28jyZTFoK z_sR%_bNx9jWhiA+z*=T3QtQtvXpvmK@NHCO+GyL3Ql6(q5Qhd13#3x{`zb%H>$}N) zq9*lmqZks^B$H@{6*UtMgy$q?R7uK9;jI|0YdF2?@El0WGRC=Iwx=c5Q^{u-e_!=P z6beiYq9$@13{NK8M9w#e3NZs&p4)d*ugxhk)dG-S%ZJAl%0zQ}#Aaf4yw z*POnkPQp>fG%a6sLYVrSskWTfe1T0Ihh+t9wBXXs4f5&cx*oS&b6tOP&_yPM{GwIr zbYK{Zrd8X^>;3(`Mw|BX2D|rqXU0;gA#`R$y9}>O09SsPOZWm|2}0z$Hsa*R&9!kA zq<@Mn=#d@oRaCFbj<;4yI29ZBlGhT4wDr~!G{A|LT2Lh-(3sP38KrRfAQ8#@A;;wD zZNg!O8<0ueJB$Zo2YoLDw9TCuOIyR zibH-%mJRPzsP8oU-9E=&oB@F@A$q$mKL0&ENW2`yQpd?d(h@he`OSNpcXeP=g|yUI z4pdGo^;Y}_QK3>ea4lN#>>Q1?#>@3;#Iu15ry4-1C_JAdJ55g5hURHj2!QwosqCs) zJwX35B*`E?dK<|S9;mT^4_~A|&`fIL<@8sKYBt-T)i0^o)|(>_N1@`>SUemdd-adx z;jj=;4os=MS2)cF2=nlY?^ADqru4(c#V}C%J~=heMS`q94F^q#L1&-Bn~c3x33Dck z*Xfd1a;`7gx7fP_lrw28U*`a8C#dWA#lZU)uG;qhu-fp{ZE5AUtaFzW+~phYa*VrF zy35v^aGIVaZKRy0?D*N@4L_F5w&lgYz#%*>y^tMOI8W5;rfB5{SP!qFT78HK^pcLR zg1z2oIECE^U({ImA`qI5{Vf{eW+mG#Y6?;7WK6`tqHNPUu2O7P)Rucy6c&3WFTKz_ z3Fa8}O&=H?J6(Ei8XU5Ge9;ivO2+Q}y#+>(;j_u#>wv}sMYwAP2!A}iy21rXZ_q7< zZGo!<8w%%VmXro2#S43j_phZn3Ki z=~h|aWWsX%CA9zb&c(pEAq3Ij6lF-d2~GNV%IY%Equc;JP7L|SY< z!FHf17t=qil1SP3xCg*?2xB`)$~4uIGHF^dBJczH8c>~83U6BB2A-08joW55sg*1p zDuiIQKwJPo$0?rfFmY67+b8E6n}7eaFIibXFw-{2y$s}Wc+x#;%;j3&Ba+4_2E(~= zT7=#93PS4F1(CHHD^;XPgeZWoEfx1#uc9D(q*2&Ygf0r?RMSNqFl~+!Pbe^gA#^;T z4M=6m%ED)jwK+QzZEr1dc)Rey%L-+KL;20I`)S&Pq>XoLl(d*WxzA({B3*3UuZ3x9 zTU{`Iq!6qcp{`j15RDY3$ucw1qbXj5BbuQg-DY^PZ^g5;(IOXfCZ-xBY0J?~av$lQ z@h%EM%-rPMFMeUP44%lNl<3gCGVy&yxbRMw5};Dg8q^urWNqI~`o5~wVQQ5uG&Iqu z-I6eQl#Pbiokvh%=g8HTpnGJu_P~6vE_IS+^(r|bv1Ux$dxc~VSnU&h)h0fu8~z** z){W_2Ifl$#wVT(}c0V~`__Gs+zgCy}4tc-+QM-9{-SE{DhKIF-NCkFkcir&kc~sl> zYGK`==j#$r)+OFR=}x;5n8sOB2>Cz_b;Dt<=Y!$fg3Zqb!=DQnp0|9bHdRkLs3+sI zZGve8*#ut7P5ZP~Ce1t_5;h>!PD?K=Z$vS9C29)0r=m{AUO3pa{YqVSr0wT=ZQs5F zZNJG+D+1MH=?+DVc2v{#pIH;j3(r)R}FN8=-f<;Zb z0olqQTc>2*2r>fD$cndqjqcowa8OG$LUf{0ymn8yMMWIt+R3l@o;CgWe9E@lc_=IB zMc>UMA{+(bMf*74i_vN0|>I(X-_R7ktZ4vCeJIX}li) z`e&U_BjiJybxB}y*prYd{%C8TjiVk5!naCu8jt(Nbxp?p_`k04+ZDh-XV$yMZ$IBR z9?xwY4PLyRBWYdFH}i|0lOwwLioP31@fU;_=Qb{{Q$2Uy=Mlc~{e9!8KP{{{Bx?M+ zDLFl_q48TYjo*}Q{F5zx_MAEk!i`_Z>3M$R_ucGzey!OnMSiUDd%o{`J~X%SDjFY` zX?%3H@vHl898wm9Q+C{Vm2Z52ZydK-Js%l0e#50XJ;xvvzsc#s4(;pt<-?U*VYUzCiU?W^D2 zS6|_(|FF(i|L`S(EOx?E;^N|QcCiSB`CTlzJ83td`LeYsqbgZM?3^$Wv@QtujoOqj zeU2w$DP5DXmv3@?yVwk&*|vecir68$Ne>Sw=fi^VjkTH!yqC}Aixz1ri#s5BB#dq_?PjbZ{<)K>dReXBS;#XPm<>)}QzKte0 zMryJv{*Q+r%L0FtT0gF5@h@8OIllNGT=6|!@iSiN$QIvU#S3~Ce}>t%WO1z(Z#j>a zmudPf6`Qv$rzi;w3c|;Ia?lLg7FyBIxuQ5Ku{(LNEcVJT{J9QJ&vUNBFL)kab{|8~ zSGc=CcTKvxfxC-zcP4k~It5Kqqc78gT0Qtgp^nt(7CoragS*^=W<5Aq56*TEUh5CY zoEtGj&xre})bsvX_d=d=h&>z)vxOVE-}v1z9Q_@?YoLU^0qQutXsB4 z*lkt#XWf2ivqI>j@He{sfxivH>vj7tn-)S(hck6M(cdlLtuhn`=apNYF^=Zps0jY*9)x4eH{jKhGJYpgPQ8$^T^h zUd8f_nkC^M5@3IhHQqCx@)_+HpPk$OUOQ_4s-3t0l^wSqpY@IesKYh(w92uU%l5-eoOxSCUI*%>?XqmkWRL&#KF$g0dDt#UfDZqPGi^<$hhEoAyN zv62DInm1D?cWfp@KuxgEx?uRr{McvR<~4(O!x%?NmT)UuRWrjk8(Dxrf6@`UB;bt# zFinSb7*%SdV1hl}!yg)psy-q1QPtG+JRbrea@8JFv^_ zp;qD1mp^|k0$Zbh1|7sd4Qw03TT~xPr04j$s(f9qzx^mc%1+ThRk5q!~u$S}%j)l+Ut!fU*|8!gHN4Pg$-CH2Mk$t<&?`644H_rgp2p&eE-kH#~Pj*yk1 z@vCDp9b_1bCohWXFABPe+BfJv6HD`C_u~{B;Ah_DRS@kP^lN_pvyTiJ3ZmrYI%0}%~4Sg6{j*17FZ8uHXR9xrlb>)&@Vr{6=d|J(<)#|p(ensRsg;AoD4W`0loumL@d~U*JlJ-|n~Y+NjARCm%f?) zoi${609fuL%p2n>JWv`=+u){sKo%Otad+_-J{@C$=#ubX&qlA^B;xchG11nxsc;T; zI3e)NCg#kpRpT6>f4K_H*E16PiOJG%P`1g>sKQXw^^k_Jt<}fekR=CumaO-!j7U3{ z3?vQpUU&V$j^A?XJ1`7~1N&&D14azzy<(%|(|-nMUTU0)vI5nI`eWmz7H4)`^?B2c z)@YJfZJZMCID!<6|5nNuPSXjp%~+h_IgPVzbiZR?@GkP=lNez5-kBkoP$qpHsL@dPp&5S*wi!F7?>YD0nM@$4{r>Y&?%aFNJ?Guu_q=B#WS#owXH&LP&SWiN5^AvzL#x0b04&C_ zJ=jTT4b&z(9LqKuP{FitOpYFdbfR}eG@Z~Z)2tSl4nvOnS-EOK(AGi=%EJqO5{}d2b2vyuvKusx>ywJ!e&~Qfk-X}Hfor6tT4&9?H{_eVnl2Jv^PaHbRIUBpUy)f=lWT(#E6Z4H;#60DZtKSEyA}0>Q2kqE~cI?9T zQi2TsAb#G?QW=9zW&;jCC#7NVq=4)-AYB~eL11}pDNILhU+qr)k4QkHUQVlrAkZY* z@an}>c@Roq__MXP#4`#x*j})w*;)|x;#h2gx?wKVR(t_MrL@>r7MFAiomxYKzo zVjLM_TtS!N^xZU(lHCVNjXb)7NE@GXnw4&#RY5vMlzt#hK1l;qXXVwC8sub_G8ALpcpo8_ zT~cay;t1b~!?utJLBH+ymUJ?M0nk-MpWT@RQkuO+IylAi%Hk)(-fsqh5>L{* zkaj-^ZpcCv>SkEc_F)T1O!LEs#t9yBi0=d|`8M0FIyxA6(gQQhQ)sTf9~-Pw3@Qz0B3iJ$kv~Iw;fQ=n{JdCPkmxN$jNjFDX*T@rrsjZbSoF zX)$@2R74Ty5~ic%%dMesYyk`6QNy43Xz@oo&U%LcH zDMRxoO*(v7i);uoKY75~lMpjg2b?uI3Fu#h?dFrLm1vB#KL5TJkciCVLoDUw!#jrh zv<6p6>u-)qqP1u`hR`_6Yg#qTN`lJ6jo6vNP z59+r8%~=mC78=l)Mz_c;fuw-ur>0TyMzBA=#H2K8)x^k-M?`nV8WEOXUju=_3`9>L ze0f0ccaARhe3M3Y^13yG#$26}?U<|0aKMPP$$K#%X1)(7j+o9aSB8;vzrDfcH}J09 zGr84RRp0Z!bQc&^13j`Oj}A+nLn325ywB&Nny{wEc|_E%is|7tT5r=pI>Vp(^689` z3*~D*mEFuSfnDvkwdE9O)Lls-f>@wQ^$CO)-Yl0^FybEn{%6uA%(z)%3;TvCQioHj z#UsM#%od#Oke}VRLHmhDd8xEvEHrFkQ780ZgNd>nI~|X`>)K&SVwtMzI6vI`%r-)4 z9?|JDX$A3mtG0ID&zFIykR1~Bck;}d5n_v{xndLXBf=l<-qXHJ!5S1YGtQtapqUQu zQqDld8D@4u%*;%fYSu;?>6pBXLIW!S`$rffebkvizr!2&VmUMrc-?G8t;j$EY8LZBRRL!qb9)6 zk>;48q1{_AX`1UE+=~q}=up4R#6QYGj3vw;J`c5w zT*%K8oU7@cT?-QsvOXc5{__ZyA4~tSI+K7zC=%5Q7vL|4{*Nypc1HhYGzmqZkc>ah z%vNF+^9vwm;ws=oU%>3od*mQErnB*(HeodvXKWsZnKgs*dHbSK@?etlT0l+BzrKj$o z(jV0Pf3Ea-H+xE7)8CuhVM5WwHFU-hlPdB%D#D$Z$nXrde6t{HcQmjDXsR(l>2=qw z9Sb3kz|Z;eE&0h$SXrn3bOoC&$AWG2>Xu-qmx+_Y3-;d48Mm^y{<~gR|BmOsXT;vB zeUEZeh~Kp9|C-FPCYwji*M}np`vFJ+-)6hlC2`M~3m8YSBsR*jz0~@xk?@SA?SJ&T zZ_oxVk3NRxw=CI?44(d4&>sv_i)?m0e9B!!jQb9cr)Elut$Y-n$` zZ0Rlci8_dmGww|k>2bArbg?{o4Ue+yBW}(Q;?|lHC&=y3?Cp_qJKWwLAh*Za+W~TW zu)W<`ZVv>XbkNI2MCn-d-8J22)zT}$s`G-Zl9)Y(U+l(gpI;MyM_wW0Irj4)d-jvj zRV%U_xrH1z@7swztp^9~l+T{DBD+md{jRS2_+J71cLi;|u1Y%m*D3ym%!d>(AA$%` zGWr@UM5ztgo^#A`_qmX#qeE*DYg_*e#ifQM#8sVkl51WB^n~gWfO1QgDjhTvGC;q@%l`S*Kg${p2_Q6(k4Dv<8s97ZM=tt)!@fW zK;uf#MVL?#Zuk|yLjP_(ia}g@AO#eEr=@)-OcbNntcq`H_$UG$iWG-uEH7@V$ve5> zdKrdWHpfaLN>KW z>Ev%RGU_wJ&eMRpbnyq-rM;GoYW$$~5mtd-RA3ax3GIIj&5^Mu=G71q#R=8!Wu@K* zg|yW#9~2aPiV-a93==JyU|2)N(F|>8NS2F7vYgyB!)%=*J&YOV9IBW(3TLV=yg-22 z#^xt4BdeAsb>p1S*31@xR^kQI!^=@KKGJJ>+0R&?9YLh!Z=?NkG8tV?L; z037~-fJf9Sw6l2&X!%M;xiN`70Ij?Ri?iKv2L^5a{~B7zNj)H%04~`udy$0MW%0X( zYsF3T&1CGDFpKM2I61lu@={Ev*oj%NeyEYS4~!6Z#SX?z6B;te@<=k#M7jQe z|4WoblgNsN1QUON^i^!PLJgS5Tk~qLzWQUXh1c&OX1g!tbrWP%76F;~w+#i@wn&Lt zh`*YskVub45Vf{yrG$RPSkl?_q|GZMW3LVLp>M$#L>}Yc|Ci85*>_QQV}ny}Zwf$i zUG#7zo-Jg60~aNIGHx604R|+vz2AgG!V6$kk%}yhx0J@8^Ct=04LsMdUssj*6X&I% zuUARCEJRx46X{zS&o>L_K_tGCe25d8H^3*-N{>jN?B7iz*F6?*$Ht+<1{*rxMC&uO ztJ_u0&{bU%v2D45X#8_ePc@QWf1qtFyeHS+`?bt7(>%N>TXw$1JNoV!ndQtFJ&EQz;bHC$;NnewGo{7UykO>u#U$$i>?~*L=9|Q4S>+gPU&Wnf^+oUQ)Jy4f;6s^ghJ4DLafW# zmxpR#vOWhebiw9}tgE4;UwGOr`m0a4aV&m4&CWXFim8GS&UgsN9wA&#pPjHIC+yse zn}sNs5yK$Rfut(f+=hGpK@NuO(<1Doa@beKZa44YD~Y@oOY+QqNp=vm)w6p1NsNXt zgYdy;%#%78e2*)NbBO@^~IbWx`W39;@EeY-xFbVlbSJd~rJaMucgK+z{i?MG2*X5tr>hU0}SDK@;d6!9>M zYvZ6UqbNl@F9Li(0WX#6s~?;W<%r5jpM)=F zn57jQHvyDQ0wpJ@U?fvOcIKNrq_-!<04x*Wo)p+`fHY@!4-!Kr)$M z^JkQ*dhLBdl+VWawu1)4T6IW3WshR3A zHLps3i#48+S1mV4fV!v8f;c%C?;vaOj}epUEWmMZUU5um<7$$P8Yf>Gjg#NhIK0p* zDW;I2nexVid(}-whJJDs0ETml;-sM?Wzqr!L)rqvTje7JEpo*&ZeC$M%Xyu=jAWAT zQ6;eB9~j(wK#MTAf(V1bd}T~{YhT|C%4;!$J@yR7Iqmgab5_icAtkCO##J>>r#eUD z*!_AHNt2D)Gq89+NB)Y~)(MPCS)q~oIY_&_0A)!%#f<*$Y_mUlaX@R~?;`Yf@O&6H zhy5>smEqn;OAxY%U%L&JiC_Dpee!4fWIUdXlr`K0omPw1grJmRC1mW)d;&i|uTXGX zl*iM5ON-vbMB9T{5@~9b9M#;5n;bPhiDwdoJ}58yPW*Bt_TQK#1Q~^oVyh0+0@H?~ z9jqug6a`9)UZ}aAG@lL`XrkDfSBL4VL4AC7$ZKK8I9a)31P>&$iCilT zFt31<7^V}3vN$JX#EeZ7ISk#lk+bL^hVIGHk8PGG96LjdRCmM|lW}r0aUKb+tP+;Z zi)`Xv>1kvX_j;;wdhn=qDknUEjU!#a&zBDXnd@SSlsKqz$^`_0({Ugd`Cc3pv2uao zjUfk+7E?VS*m#K-&uKJ9H>GCXE_~FXXD>>FL{m~K#EJqaciJ(klOTVmfU$K5T5Q;| zN4W7`{(?-1R&Z2xJRaEHn@Srt?;f63f+zTe=q$o_@x{0q7;fB!Up8#X#f)$M;C|ry>6jC->%2=q6D-QG{F6n_I?XOINbN;cYOa2B3#@*WZ&Nm+ZMe4GYE$J z%kBF}4)3QLTl@l6_aZm9WvB3s`yuehFU+zYPs|!P-eO-fq zV!pA)+g3no#!6NQp{(N-8j;>XAn4C&;=tsv230Kij0z&3DW%(QJhr2DSHdB41rxH< zG|ULk{Nf)h%wON;`~b`>z$021zA_!#H+J?djJy^Lvs*tJd>I@SGlRvKv?ykcFs9Y- zLd$@fGJ1NA6q!agn@0G`G%_~Oh`g3Y=I*hbM(&juc}tIQp z4qP)boSXwl3c6msa!j9qY++7c!?#=s)7@`>9T*_du8S}klc0EYLN8|dqAnGS6dt%+ zFt*uY<~D2@7>@1N3k`^|<}5}S@IAuQvh-Jsz|zY&U1uBq;Hv6bJuS>SxzP8AL#!L78j>9zfWZp)}zsn}YTuKfoXE^_L|L zTtk;zP!sN?G^CarTpMUKtT{8QWzrc zqfIK8QVHael_bVP&Lz|#{TN8(xTn5H;pAtUMdStw5VnHEiJi-a-|eF8pw4CQ`k;%l z)D7^vU(IFscR)=M{@p9wm_;2iL!ENOtVCV}G1tu%A(jvqy-gbR#2ge)LF9<{yJ&F2 zHmZK|Tdz-ESEF2utPHYM}2X@=m^TzMC-9K5oKLja*Hj=ZF z&!zQ(thRy0{DW*>_g#yK>>7%Wc{NyHt_Ey0ZbVn$O;y|%No?9akb&V!)QMAAc^)~A_vPGU zY+I4sBcbDAF$S#)LJ~x*r2+t!!5Zi(=Ln%S<0AYylfZaLaI35R_omyit-`2k>kF8jMw3)*@ti`N+w=M zHKNV$Qn2yTkCTD{07|J{Fg-}64ttPwzffl*{$M?c28EYYR<4l2q_T44W>#KQKt`%j zP~{S&8t~KECw4F$562{END&rdzWQ=qBoHw*!t|1m?f`T#B?-ac5iAzo`%?Wa=Hy$d zNvpKkKuo})c=AR7C3Sd{P1tY)t7X^1nRG)N@qyWZ6*H0m5D}j&5*cGgVGV)s8?QHw zyMHqss44u59hDOjL6>-?fQqO!#5z8tIs>9NmpXE7jxA@ zoIh0wgD3t{r9bo-Ux+}SSmX(0I99}B0DHQiYo;A?YnjW25VURyBt?dpxa~jRAz_sM z6(mU79=Z`j3f}H78>!^dcglpFn3X46I6(-6TP!*&uUJ^WC@;#ZvrqUr?s5Q$c1&rA zO17KWDajO47Db3(`HMmtp?rwDgecC+Q-MV#_^kqqN_e9JOZ}i1lX#58%y+A5H*_Sv zL{hJ``NSv%n3gFDL*RK1>15Q;B&P$9WziJ_71CJEZ4}?9iUJy!?`Ie-LE;x>rb}fE z6LHgKZh*iHtw})isuBypNC1czxN|-vze|`@z^qd$Mj?G>IWr3t=!G-GeV;WE27X$=*-od$FU-7nlOAVw$5Y`pzQhPUTF^_ATk(g z{>k6KWXPCfK7oj2yBBArm%&lDE3{yo*gFaqD4-r-+q9#x1eYV^DfW-LS)olbWq{tA zBHpm_kMc}L?I;pP2oDjHt_|2FP1|$_2?zEuw?q|Z zUWtTa?vS?LhFyuO&(-#*15h_%IST#+`>J0oRj~zy46Qgmo=#Y|W5HqJn?zV~QWURF z-!mV2N;H%Dob4{W?MGtD&#z)drZrH2ttCcDY~7jCU%z81J?AI?3rc_XsZ!dHF1qTL zYo7B?0Y1eJfFVCrqI!6EwjA-l!1F7aOJVhPn-X>9(<)Ko0e)ciW41^XvLn2LOxq{3 zxDodlF?x1DSihI-M>=gB@V1qa*f5WFIJVfdNsU7a2$|I*?GuSawn>D8UsNK%R{ADL zLaZ7NI(#p0fWz z@PH_cCh$N)+Gb}`ESzVhXGuVXO;h#=FL(uqmh2q9N%q}Cmof*PIsT!y+2@-Ua0QgW zBlb4=YJYt-bpt25D8uBnSj^?$1sTSUAIHMKXC@H|84((oCnG#FMQAYgFW32bbL5I~ zX%(V1@AK#sg-MH2h>rL=2$L^FYfWlSl->{fy5n+_!@jF7qYxP=VdV*RqA!IAN%Y!Y zT+=)4E{cLv(SbGo;f5iIkl9Kx| z3G)NX14Bg_6w3(fHILLoyo^BF%xXZ~jBYoE4x|_@CK4I*#qMB^YS$%qO*a#FJPK=P!_o)e975#Q$Vw(8F^7wgx4yuaG~a2 zOgkE^F!yaj;u(3B=3ctgDI3B1U1?<6X5>||DE5p6!>jod0<6b}A-t3OSYAD^K&MHr z^A#;W%hJc<XSjlu#k3 z=ODjlH)bTW?y$bhi1H6kbmw_G9+_{fFJH-aiB9O`cHjESYoXZWO-U33NV8cJ*p;M| z;8{9lq*54pF{_ z)Mgv0ohjzb)542>XSL8KTJ(7c>i06N~ZA@Y|8e&CkXr+K28sa?SX_XK`WaOn3tpef9XKngf zpFWR!p9vAj~LdXbFC7SrGS|}g}lVRqndZa+!dLkLLtMPEGQM+{_BZy6t%B(_DW(nzm6|Y zgjg%*%*0;*H-2G~HDr^*pLmY^4z;Nv6qf*&eiJJIFHdaV$Q}g%?Z0zxo&qjSkHlCX-TRUhZePe1ZQWud8WL5o& zNpHbHx&V_?s&2$J&GfRqzkA7s5AI+ue5e`0fS*;#NO%=;l?uj;8)#9MRaZQhhas6O!B>X zmmkyQ!&lZ@-aDbo2hkuPN+j#es{=?QEOUF`7Xx`MCgzvxX_+J*6qQ!ewAb_F*?ztE z{jx>sooVXjD>KXYu0Xx=TI&7wbG3L9jw9kUtnqyCw#7y@Jkj_%_3aCcZI;EKD~+#} zb0-jYZ7#zuLT8dGH1|+b_7x;Ciy36;e7dKX%}pysVmc2EaJI{o*Obq7QY8X02n|C4 zNtzIcCb{V}^R(?5eutG746n;c&M4P|pg&+%T12?g0!dcvqF9L8A7xlRQOeQpfw<94 z+fIz(-3{5)h^Zo-Tubs1V8y8ZTk_#Q2sloy%x4Kj8Y8;`Q2IcIenMk78$}=wF3gF@ z)Evz1_@Ui_$IfBsXw^-dVf;ijOpKQNY&T)WxrdF{0+}*)2z~=PP`gQP`ji__oJr79aS>t?~22A~pQMZw}!MdHr zNH8FABlE5y@AG_lKjV`Yk@q=9-uY^O)uYvIz8=YIA!*-FgYs^B{FKiOMu1?&X0{JG zT_`yh48h73F{xa!?m{|t{YS524hBP04m!s2ic!wr-C*?;MX3%nV)d5fG6~?#XnbSh z`EMbSJQf1k6U;Bzm&p{IIKdg24PPU6I3DsjphFI_SpAWvO|YwA$BN?EJ2=xxk|wLU z^%=HSEOSoANfk>2*^*N+<&%?5WWvGP#6VUK^0oNnyZK-x-$Fw^zA_1u8UOLgC$EKk zE82tjS@P*QUhx+sFT-ZaNEjJq$MWYK*S%NuPVx&mq_3zMh_3dZX;@HRLTIP|o&}7t zl(JG7gFe~r2c0M@#X(utk@y>E0r|-a#|}dM__b3w=0Fhe3zKlUvM2?nWi1Mm=oSFO z%mWbsID1|JAkrK@fHJ$l0J!C6K7jfW0bIIm0C8qdDhMOzDG0$tGz@RHNE2d5xyEE> zLMM2TcJT=I+?TUGg6YSE=lxFbD6wY=opmYz>Ihn%GPGVVt zkyZ*S*s_vWCv>HBHMA$LuLxDq$EiY^xZ#^l)Zb%KssPM10x;VM0C?^T0Hnbq_-5$^ zsD$cAB>0k#g3VI*lL+2{t<_Uxu>Ofu5Sk1K)3*mgZ2$!Qh#(xdZ4f2^1W+AuG>1#@ z3$q;mto*=~^kX{HsAEAAfX$K!gcmbhXp<|3`FMrKKq%7_?Bl&T>Y)VFj|uJM_frX$ zBt0uI!61cTS3Z(fW7Z2CFx>{O49e`b;5jP*kA6&ezIbn&@QmmT&!m4TJQ6)YK;h|x zfe1&o$H4hN^^J&rL=dk3fFMYO$8>C}4E+o1r5I==ZswX%G&hI74mQ0U&G8R9QU6y> z!$b*zd1cZtEpPfZU0#b#|N28k8_{2xwkfrGA)v{PLj2Q(Y#iWb?1jZKBg1zrNxb!y zLe`zg$DJ0JCBeCRnXH#<_0m%>WAyUOP^=?sd9KrbMY73x!#b$y7&sBE42#$-4HlY} zAjm@xuZ)Nl^Q13X1hDu!%<9b=AI7L}9Tq6^yM|@?h*KbM zK@@5l4a{$Wn6M8_`z5V|vC3e(G!wCoR4@h$=o^+*Ep;pMfdsbz0uq7sdL?=Dbg|w> zSPv}LlMp>V*Gw%nS44a3r8N>TxSsHgYcvmP#Y}S5D8zwICGacxT0+7E$#(%AXqDyz zqH2BMp#)gFrGU;Ek^ZDiei}pAoEl_RkQGzBy=>T-XZhJMsXwkjHVMFFG$5AhAqare zX6c0Rm>Dm{2om(tl^YsFBm)X?gH|WN0y2jvue?^<&NLm$%xBeF)KMO*iBA>h=lzZi zwecHFVY^ZBo~rfp2(TCI`E-LZ5mguaL^ILXLV!S2haw9XlWE{gYBMKgavAx2i@AKQ ztay{4tkeTkqNf!;f8`eaYmGYcHY|Vp0$UC9~*(9wKd_!%i#P_ya$S3=ogm-=&RUaVDSUA_@(Dd z%`AG97Nuce2Ox2u7VQ;o>?6)}MCre($6k6x&G{FAf?MUYYX zJYsUk6}6XNENEl_wy~GWS3CJ|u`#YtP5ey1!b+Z7;lcT3ZOtWxe${9;A+}MVvhAEd`8E$-mx5}6+YA2wUoADqhBj|Xr zMkjRR{zgvz-_AQOCjqJOdEfz-_!eOsaO_oE5N+N!`t+5TUs`kV<<&LOqW^>&-^IJ| zg7dQLw_X!&d=)nUl8Xm36VLK1uW(|asiggJR@MF}|Mih?zYF)fBtBFQ?2`Dm<<|`( zNOk9gZ@6JGcGbr)J+|)8ie|2l(zMDPmIt3%FItOehH(x2@xJs`X_X^UKsfMOF^Kky z!G>sCLY;^v{ye*VK{S3Odf=h2GZ^#GfWsKG-<09LTFm_v(ThlFjE=F837^VzI+>2v ziGQeAWQT7!lk()8usI3c>>#=VKyLsbN&R9%^82Ti0Qq9EwnKo!5u%d-QDC*3CBSAg znNqBaco&c|iUZm_0{mt~kO0|icJ*;T8Ub!s>Bvsh+1hoZ*gwwJus%HI*Xm4}+Io&O&&3tLb z7t2Vel)=S@Ej`0i=|`i^>EFs$_IHxB$wAKZJTn9)yXKT(Em#O0Am(lcx7sM=b8QcCM3)HvBpfW_GX6WnP`fcdqj_SSHqqgBnZnqUiAOu9Hr< z?zLi~M(zdMGzOno+r+CFeCp^@eG20Q`8pKxhW{Zf5g7dO{n;r+hXVcUCMX-;G~mb_ zHzM^0YeRkbCWitR(F&97-}viNZ6CY1sJ0N6?)qcsIKjx0qL&vD-ODE337 zFQXsShJA|!kJjD-9ogqVb-MVu)E zY*{zpz5Ds?f?gm;vby6Ai&}Hm=Q!hSG1eti$t5j zxYM&SSRC;kKm;o)!B!T;>ONRZyyrTP%(c80Gl0@nJFxmdP0_c8yV&BFAH*+W@T=qzI0K{2 zR{`rHj-1t%p$9wVY~a=oBS-`qmX$Ac@4s5u(SwL{x@eNXC*eQ-H^3eA9Rq>_cai0M zcq24W4my`A>BS-OG2WBpw7?2H3)uCMInkaX`r^-6SHrT%Qg`A&>_yicfFP;;@RSx( zFD1TEk7!{)qtXG9#XU95D>2#7Jb?ij!_Bx|(FTI1103}*dM#?bx}4yn)Y+)=7a;vP zxYnSWq06K3P0>y7$iX**my@!EWtn(b17tagjd8Ts)@omg-Q&g!rDqNRrH3e`DV^D} zISzWt9Xu6_nRCaQ}uiT~Xw>5&%^8Uc+d}5>xq8Bj$E1P!)I)YVW%cL(AgH(H*f)DrU z27fDw54J7lKVHrUDE-w#siT!xRTHZ^a=fa&cT?6eQRgJ&q!+`cho|08(%{e{^n0AF z^&l#a-t6Fc@4YtjEHGehYUUi~)ffwJ8QIV_2}7GTmp8Q5W4I3c2CcmQ0kTy@r@W~I zn_W7gvxgXy#(Wm}3}$2CpE?_HFaPip&|G%K5wS#&hEsbo>0eG(>47Ac%iK7Cmna23 zCGnQ_KQKAeBmmpxre<0u)YKd-bwNMS_$74h0@@Lj2Pc+SPV&fpT{5w0@;b>D#pi1F z$T3%-T}U!>HvV;zPl1u-#-69+hTE#F!s$2&3eXv4-cGXA>9SIe4p4J_b8Irpi4my4 zQfy2#zn!6D{PkfSC-S%)X5K&~bO1JlZ(=%~)T-oSX{HOZap+D@(NlMylhmoeaKF-e_KxF8xav!k)%5njNJA_*x)Me=39?517N3Mb<6MZ@|`TLe^+qSAB;n#Os= zQyJDkz1*iS!D)tp67Glzdb}aDifK>?Tkf#8+II~vIC4<37?Xh zje`jUl6C8alQz3*b}n&383WCs*Ux^XDSe2K^tAhabUn{l>;Ew?@$BZl2S#ubwNsZ( zu5hR5XuLcdqIX=0zqDT400!>kE0f1XMnhuar{pyEZQGBvT$_s|=J;s*_*~95T4Na6 zhASu}%ysQ=C-mz;3sMvSX1ix4w*U-_1=EstLI`Mh!Jw~})`w%OnWaEgErbF*ZI!E8W$%Q}IKjtNix85RUQWWb`;cHo!WQNU zFx#zOuA}K1&V_0_q1N53M$=t6$7hi(Iqu)usLN)5PuPBXa;rO5_Mz%g>UA-Qkm$#X z$ugcwg>ijuIe4EC3Z`r0HJwBWGIM>llB4z_N?;x7P;clU=D-P^dc36r95?~Xc3W3` zPa=@qbEJArQc@rm^4|{Hj2ADD#(OvS{rx^7RRP&Np0at@ zNDHSK_7YI{Nd^@(L?x8X60IdkHm4I5>&2~r#@8C)m69mJ+Y||oFH5%f}ahv zgf|I)xWOp=bo^O4T@()31{K&X8js8~daka|%r z_*{V#J{F0ZWfe=^@A`m3iJ*@agj3?P;T@=D62^EmBDkZ<<6?Y&!zEq-pf&5rHb^8WMY6sN@iQU$y-T@iC0I-qoU=L4rtnYH{Uv7#Sq?71H?LjK9!(P z)lzI}aPFSu$lhqtjtf#M4M(p0H!Y?Fn>PAUj+j>CE6JR?_M7>21wVu}*gMbt6J3Fo zEFjFB7}x(7t(|lnt!o7WvZgF-l!0tA!~>GRUL0&OErqo29!cAaq7Vkb80{wx5vC(^ z07<%gkg@S-Mp{NCU>|D&@G$M}BX1FSslgYgazMfgD5=sbG(q4mz3Lc*253>k>JVhR z7fN;T9)=I>5jqt%5;U9^**pr^_iB|U6m^W)6E9%D2LY-U)FEzb5=Wz`fnas6MF=Id z?~#JgyKB=TWMWYu)PAqqw>Jbn3ffsACbSr?YavzhJNGwS0@kVj1*P52dA@-&hljQz z6^oE>bI-t`!`SAbB|N2pwS&~nm-;i4F}crP=G4l=`jCO#3F|CDS4 zvHK)tQkd;qgHVHbz-On+q%3KF1_H6VpP`=*Rpk(rQOi=$Q(Z=>SW;*RGhNhb0kC$=5*BtBlI#2zx@bG5zry|0XshI z*BXuY%X1$v<#M?_6klbN1W016G^BWC!ZLmq4Rkaw`K=&uI1xAnT41@`3I3NAelTzh z4KDvd3(AeTmKz3#@Dxr)O2$KoTte5BrMsY^1XyT76`WsVfCoBa7NBVVqHAaV#tih7 zN1Km*ho&FM_p^3|@z=XwD1k(8h$}3lZ(Cp$qD32#zkzishINWAb*nECtc!LA*8L3D zDgJFTZD%*miwdJ$@Vuzs+B3A|yr_J^(g~e+>|!xL5xVSr?6*rlzV@HK%Z`vS+3wLx zI=O7=$cXJAtvno34vV@e<*=yhfK|$2QC0FN>9D9@;!)tRsFUQ@J1pvGx%Cc<%9mU3 zuqf`dR=?FdEUGtdF`ua?E|kv#;sbt!{#j_FJ&LLzdBajgGKX9eL9XN{RT7~f%<++Q z{}cj;E)c~^;m>QN;dc2m@wa+D)THrA=RXYu_KS5Cf$+0CE`9;)@T?95~O*|p$lz&U#!7bfdqfezCT>U&F(8XJL za5W}pKOc4a+#G%7-BS9dj;yhB6EX}2Ggbwon?>7Gjk8p*{t3epq*Y(J`f~W?lK7Fx zS{P@I*ivIkvlEgRQxbIqAo~oFP9_2;sRG6iUVye;s8oSS_@%#AGJNstHJWMkxD-<>5uVQK09sIeT9hn;qU9cJY-LUzh zr~^L|{v(Jx26EqkX?JdWCVEM?c@88+U;8P4>gYeJ=|AvKs4&O4R`4oYc!eK1oJ!)3 zdWAR|*9?0ufhphvkw6bg6x$xK6!PcRp|C%E7j=Tv?KL{ zY+A27KLb2^IXQM95xYab&AXh!Mezy>f-bFHABaiKsJUfE1$v!KRV4C9orbQm;feeG<)lo)*R$8_&>SgGt&NwK~zED+s8V z4;)N0?e}aItf?z?$_twM!QGx&&@{RbwvCD+hJ!tqfI8#``$7@k%w`=B-hB6VQV6vb zdx`>!V5gXx9VARg&q#8Mv_A&g(6Fo;XWU6IjY)6>Jbi4Z!$f#cT1kM5$7i=^%nB9I zd^QK=q$P8H)q`pY-CUGckILC;FNdX0?8UIcX(|xwL;A0mrngIY`QXPU{G>tYh@O}N z9ZsUb*}H6y230S0p9byI7_3wRZ~EtZe%~T&!y#FC7}1CE2Ysh)EYe4hsYZeE6b0nW zXny!-c&PpNl;kR`lk(IZ@C~%<9~iMuwMUgyfG)>hJTVn>4F#Ew7R7A4uew&BhKCQz z$QVD47?cwtp!HZEjYXpJFkc@&@_>(4R1Iyo6IwL1{4;3H#!sdx6g@vZp+h9(UzKPH zepE}9!czXqaqr}ue7t~un68Mr#vOJ&r33;M1zk^yPp}#mi zbAJ6$%pAe|?KOhzT-|ooF<0pJW_hmGEra~B+|YpyTDRpNDK{*xWM(CN3L{W9>Vo^W7sE5)kRIliDNYu{35WIqM+apcco!>|d(nxq*GXIJ#fq$4R6glTzJ&$HQ8knRlZ zm(J>+VFopgYENE9jc1Z|Qx;te`wIRR!`WiR0^Nlk&(g~z4K-`yfTH~-pQv^ji5dFA z;OtFrAqAr$vz!4ofzW;zo>s}njVy04XaN*)+N! zbJS&T9a}c^E#y)mb!%Xs&;nPzLwEtw?ke(lu5yN#Br^q_^JXMkdy{3Oo}gojL@8!L zs-R2T-%To_-5A-Fl}$4;vZ*8+XZ*$tf9D(iE=tc|h-NhxpNnoG6ccBL{Uv&8Tw%sK zBsncfu^NO`{hvu5>)?R8Q;o2Sbs>0^y5NvmmrTTI-i%^_<>c^ZV-;LW^FR@E4VtSQsQyu=$+6Y z(iIEDjX)|#$huoaF_dForllrF!_hE^B6`~t6 zl?dB}=;ozqh_QW$+HXOtI{ygdDz?g%xC_x2j~~ETm!YQZoI0UR83rEEBU_G9Fq6R; zVfO|cGAu1I2*R&7w&%7W#I4eV0@(I%GY1VHGPjyusP`%^Vu z!w`GwUc{ZVn27r$K~OeK;t{cz>P%adcfs_}vf5Kdv@E7(eBJ4Ls5GRQwgDD{sdSnI zQ?m5vlmqC$jgu}qUub)g+Q?LhP!O-9Pc*NNrj zLZ@{8(|wpIjS#v@;)1zmcUN--6|3dBhS0JTpbeqxsZLVGG{=Y_7~g7iUrQyopXOM zA7lC`x=BXN?4vPN_t9uJB%8d9l$5$e-G9n%q6l88uE+|&ers%)f;E*>=n9Qox#RR5kauzrt|8A z{<5#nZhb{||29eBc8C+(q{hPsq^HKtayHQaoEimPG@t)tF$2qn!i~Gqs3l3o45N7B zGpTq-A7tqOc5kNQSzE>Y02bly?e!#_GyGl<{Fvqs%n7*7Gh6s=9Mj7&Ynf_|67ql8zXXogN&{g>V+-Wl+vAKCqtS1MA(BFzw$vjD@ezfAWqPssz0J zgDBRu#_SCz&Vo$e&$G#`FZucVrG&vMB1CBAzhNlPBkJcvuF_? z2+)L=U5Kc2>`&NxU(b5j1#o}*iF%R(($D2%fR#^F@<~52Z@@GnH+K8Fapg>d*h(P0 z5Iq*a{HTuCiKK9&g)o8vt-K;|6^8hXn1i|bmJ#cv2=*-zv@G46Q2XNG+IOIm;r2gI z0gf0ztzDkTZH&;Gbgj`^fdJ&`!bO4B1Q~J%gcB?&)VvY=aRXvuBUD!4%-0Hiu=g?* zxr?xu2yvCT4Fut2U?d4DiE675QnO#|@Hg~EVH{YB>DO5dpqZU0jb{xz%^AIGc1iO- zvp1fQc_Nn57nR1#hRL+<*j9G0&T0u`rvP=P+i@qd#~jm%@mBZUFi0EU#6__PGlUQb zGvtbS$%0qt?Sa1k&?597Z`>8sY<}KtPd?RnQ%2xPLI|x8A(VbL6u@2bv1K9ZSILqI z4`#0is|qTBR_4wDi7CO-jR1*N;IL*#45$cPzNkO;Mih1KBydM#TE7*z3Zwazyiyb- zEOkQHKHW*+?movttD0d2uFq2{aJoZLCxP3zhu_+c37k~u3)};yBKK6R{!c4#DO}oa zU;t(N9N<_|EqP9vH{P=(M%UpPkNxc_Burm@T83?vdbN6>k z?B`;NRqm`Tu#@KIdNaZTC9p?{Q7PA`)OuB^-u--)(jru;*zE7CQch^$9!Y!}bW!*C zl*E8eG0eDqZ49GG6-OlySxMP~8KjzavAX$GXp51L0$6I=rebp~7YiPYA(L!Cz!AAU zzqDkhuYZakO4ng$^qOL_K z>bL#n`-*y!#0I;&c%j~dUfDAlvlHK+1!rS!zOZ1c4Cj<|cHq`9Lat~LyJ1gra+37) zAC=!jPrJg}UHYWe7m;=~Q&1Db8JazU*rJ?i4EvnXBIHcR?cbL(o@6(N_OG!vKjXQ8 z&3`~nTMX(?m#Ac~OG3rz|Her8Tcmax*9)Qh05p*XYI?{&#*nn3rQKLvTnEk|YO!APh| z>h`iqx!6&nM|j#*Fb@-VjW%NmVZ+w^uya1Ahd}H%6Bfu)hFGnsdH{tJ`l7EdQ(A=Z zJa`-7VI~QaH8bpwVEeg6KpKEDXqKOb)FDcExnJ{B-y2S4QO=TI~nw&vEJrT)pw zV!XRXb!yw1g0nk$quaHR~CPQFF= zmfy-=fz(K^0{rF+_5ZlhmKX=TiwbEYemMNTsMcO-nKfkDwwN^`fwrB{zP*zy{%_9i zmc@6EK3a0?1#4m9chOGoUiaP|YThwoBI%vb6W+TV zdFRI8KuZ5eS5x{)`TPP79Ljp;(afPwUMKNfd~TlXj_H^ym{3JAW88KNW|>AEra&PC zD}_%>B%ux&kibO_EI6APcS+AK&OyMq0LLYvg4kO%dr?4TyHCs@-PLXx6rS=mI?7y3 zEX7)Cpvlk$+vXE}Q5zmq@B!^RWJvn^(t8sFf9oE}!EOI%E(c$Wa16>Noa@u&$B;rn zO)5FvR1#r?2Lwq{T7_#Cs31eh@I1T#xnFLZKA2mde}{lBhWQC!Nni&WD9|;%vBxHk z<-0^4W0XuDza@|N2sgeinJx?uHI2@@5+(6yKR#-F3+YJy=pMj1If`|J8rVc;DBx2i z6M>cHu#e7s#5_Bg>pceSPxXZ5S>^+f!U%U1eW84Assp4#w%c|7D84;2Qag_?_VE#7{3t@gdSH* zj4q$fy(80A0Kk?c0lqUaR*+id^kPvjgEL29 zIWxDpf7W}L?CxA2;a>RjC0%e@gc{H|fj7-3!3bfy5P<5P`HO^ya2YwnGL+$AB4ddy z&Jy7)T3M7zRk(@|!RU|JR&y^g+0rcLqaf6U#Nau8+h zE>~k%NGysK3y?|!b`0Db`z*1b6S^eiyE`pH!EXCQlDmU4DE`N1H;1y`CH~juU|J2t!FxUMDXr$A#+x+|#~o?`U5}9@ZOV>c~8828`^C zFP`M0C~D)H0ALRy3*yieXiI^+)f{2~rWwQw>9C3g;i)=!i1sAH!`NMxMSQ9$!qJ?M zrz_%Mq6m#e{1j{ruuGdk9P7*(w_#yFk3i}$q)ZfI^U{C# zb)ATf^fW!9mPew^SjgQBQU)Xkgb~sKUz56(D&t6abfyiQb)9rZNfK0NsG8X-B*NBB z1)1)@m#JK&kSE`er$DZ{u>-I=t*0fA$-#)hYn_%V7Yfwzkc)NibdrnGyLVVFe!5lU z0vJ#f+=Fn-4Sv?bAGv$tCh>dxdIFTeF*q_j16w(4RbnN68;MgPM1P3n!(iJ&A!Dip zE};-Uhv}f$At5oGH6i3~L$&+^{-K^N_}WAt=GC71YTP7Z1#jcn;DjpkQge_rX<@;@ zLONKS(BRmEQlpzcpOs+hN%Yy1v-d`G&7oV~J|PpTb}V2Tybod8Ias$7x>z=Mvgj`A zs)-NxZpm=p+ydgZ*p+U*#i%C^M1m}3vD+T<=uMda9#@-E8S*G;vD>GZW)fKJ_Kw_o zi``z9TW_&ji`;sP-Tr}FtZsV%muMX7PU)gf=eV!k-rfOmh5}NO`x2x+cMj)unQiQFxEs+TIIkC=&Nd*{-64BnMyrc1jri^QTQ1y^ll*ei%)@ z15N-7``~VV!H;BjrvJaPy+JMtW1hg+n%J9H2+?|g#Xs=!>4}_}ZH5@ktHbrx9us}} za`{M9@AA0Hms+Nv3?SZ8Sx2y*PQFlk29%qBX!uuqX~Ua&YhE3qul_v2Z&+SS!(TRi z--eT76$~SaLXy#Vp^lls`N_lu8t-HLE*9A*(EhgMzE>(#YMvPu?$u>3PZk&W9hQn9(_ns2U!xT1&n zYCR5VWDoH?i6t%z)#xNFGKWlh17(NN0wY67=%g6Pv{1-|NxyQPpZdwyG^^&5 z^(+GI-7HtkhUb;h(hT`FwEQ9CJr8?WsS9|_A{u-p4M9_-A#@Pd;G^&YjHmHq%YLFx zj+?MZB6NukFhjSvsRoh3yHBdsNO67DQVa6Za)r<275m?OW4VtZEP2Jq;H4xr;2`X5 zwi`bMk--;l_>sXQ@)VH)=+(xrfd;|m7b~T<8Rqmf^i|{@%D^kuFK@LCo3VG%ztLSa zoZH;DP8*J3pCQCz$45}fYqMAhNJy3<{Fy`U>$qXMSj>H9BYeWM?o+rVqLQw`9vud* z>2gJEuJHXV0G}42TFf_U0gQ$8wrK=&+ip5p-aGZ&*1cin9N5tKoBGYf2#~WvP((lk z$*7dyT%v`9d6nGMK*|0TN-{3i)woaZne-gK2Du@QB~eR7Juml~7qlpZ!dW(lp;!5B z{Q$qnb#LEEr$9wwEwwmuPdku_bGeq@34OOEz!oReQL48;j6{!TDHh@rBBBsPz|Gt% z@Em**ZAkL6lUhk!)0GyB2rD4nbS-SBKhhB+hMFhjhdcq#XdK-U-vu_xm|M5J?4GZ0 zkE7BK`2gxI^hk^w0ZrqB*K8%-XKj&>u;?HqE3V(*asjzZ9 zvbGP?7`H((As&+TQgWw&lVI}P3B9~237qNCA46Pz-yHlUU)NoBB)U7zr^Wt7w;_)#f@6c`yuoI!-}7##J+ zA3>->&W|W&(JInhy3BPXUOmfWLR6D{HwF}K;AW%~mI9uu;Q>0qIcj z-TlWbDh2F0s_qH-)EhRn5_i8M6Tr|BQU(2!u1tRD@Y(ij<+p|WOkUSQ zu;X*pghM`P%EJpni=I0n^VrPs(0=o3@-miOTD!CR^8U<&FAvQ`kxX~De|*{D&MjEq z;Xd~GcOCAXBQ|unec#7z>!8m&+%ryxs^VZYK$_v+i=)(g;84edM+{b+-BL@T^| ze0sFUq&9SjG<1t;=$G2izIez6s@Z^Pu`Z0>4y_rl)O%h<$DPne3 zKSor)1`k%42k-DfBObhD9=wDHiJvgwcZNS_o;}WIf924RGrZP3yNAyP>$B6%vp?|J zVp+j8{MY8$L_WJrpA9n4F6FbgnOt**|N5s2*)RF*B0O_pQoor-96<`~AJnn}wyqfQehrLX<5v@NxZSOI!9#TydF*UBu^nfL%F^n^pAC;@ za^q<18G)^qKf>NK8>2&!fBC;ctfnWR6;sGoY;1Q-?VY65UpmD<vuElc4_qzYF^mH7y!T1p{gNBzxE1& zR>hQ~2mr)3U?2PwHtL2{{jTfWKANTbP;-L%z4qUGwcXCQsfCw>T@KVw$l*a+gh%+A zc*q@aVGRP@Y+FP75_dGg6uZ#Z}|5wNcI9y%>mcYCq)5CKLn-X}A=-Pjc z{j*X8^doP4Q5dAqta=pCO!uIfOK9#(p~wGDe=ZW}sFR{Ujh_jHMgXQA(VrhepAGkS zL7y$33M`L2^8Y7&`aO_jUoKXd_61DcrOyuA(@bf@v)1YC>BW#o7^u{E>X)hx(2wCN zkE$bLzaXip>cP_L0o}v?q-dIe>iTs;`lJ5=(xaPU0;<1JG-s)TB$r z(uhd@VEWvihCZRr^tlLae=qukei(hm{Hgo&X_?!ZK9nzsDR_7j{(O2N`PZiT%2%0G zn!Ii{d5wIfnIaqtX%DM!7b`uteySqOM zq3S}Zx;RjElvNjYu9}vXJq&kFaR7L=X9SjmW(o+azwn!H#GD12r|p7_=eS>e$Cq|y zCL(k`rPiP{?HUzxf2qKh5#pf;J5!>&q|T(?3Wz?!J7^D|KNi;K>>5TL-7PCT1Da!) zH+k7?;IY(w_yGt+Z)B~6^(p*E{2rbn`N8BE9{J&f$;;hwlO`#FI#Fvr9SyFkt;EqX z00Zf!=V}fVU_m(<6L6pUQi&pL511Ez4`Zv}_mZP&YM*I;Exe!?%xf=ma7lYY&$)On zxY=#HALty@mHvaN>s6j3%Mz6T3}3D(4MwT;Umw4CGU; z!TcUf4JR|QiD@yi!FS6W%)D*(-TXb29H%^jJ=C}nN0qVm(_x=21q645` zpX#Bb3N;&bi7XMxh<^Ts2(1Y)z^xP*<5p)AJ1cnj%se7{A)}Q1xvazq)k@3g*PNT$ zvPc}IIMDLd!ImLsw&h-`H?|q~O4Blw*H|1t50y(#`;=pGa-jzzNr_$Y%l+eh5T>V6 zMstGpQS{?8(y7z_Mb&~ikgiizzK_XWfC4>dWC-}{g}&fUGv<-VZzRCnNnSa83x@N( znZ^rpaPUv00l&)m3&DZe$_O`+U{xSC5O;sWn$a$pW#;-u833SWPEHW%rQKmw?rPIE z>Jety5iv_^yEBq|?Y$t(f3497_={K`59&}ATgyF$Ca)`$@t?W6wj3%ZYs{U{)gKx) zI`8+M+?iRTPT#ZTC4_Qh@MRlOarzFoFY~;Ypr)=%7wZvjJRVJB?mn3A@*7S-{|N`& zP)^pZgJx^^qUe=yYv}#Wo;6+CW}SqDhkma;=4s=NZUnv#k`!39JWswSioiAuCGci?acBHK4D{ z2F-IV&FA4=88;2(xgVwR4TNzXQO5oSm1RY*hj043++o{E)*@nznAxZK#MhPPm4sZH zG>~g8g#35^kZ~qtqLb-OKs~6HU6}bJ&|{98G>b5Y_YjUId2R%H@-oUfcAr|L%S%ng z?(~-s6W$Fpxpew|~b2gG#0tMw3)`!C#5-^bo3)rR?p~AmF2?$5xODZiUJhTdI^K}3m<8>Zv z%5$ zD~TJ$9L_LAN3V~=YtLibGOQov&tt@L%*cz1AYjfVAuL)Oj_oNg#zM5Og=n7ulX5Cd z${8>zm}SV8DBfyPHd3skl<_(Ex~%9OYf>PV}cn3`i zD}dpEcsKvOYm-7?JrOS#$h&D$M9q^-3eP7tI~8}wqGE8wCiM6iDJ&n3cMmG9=TjNtp>sMvMMqP0H7#Xoa2NQ&#kbH7WCrNjWl4 zHaPW7%E1Qmid2(Q??FCLAg}FYQV6IA_4hR?f`HYI;m@f_`P!HioghXLiV#mHH0utl z8W5bQbFwihwO3FzWHVl7h-EYwbt)y3O$v8$WMxzhwoTPYYf^%Ia_?^4hDj+@*fKoW zlGOIi%hRf@%4cVj!paC6n{Jj zbxt$pZa84$7N$^R8O9QOY$6N5U?nlh3c#YVQo<$*k6B1;EFl}E#otUY%EQ^UIS>xS z?XkRE{=lErBw~E8+~@`HcAqmW%VK%kQIPTo?A(ihFB)0j0~NE8 z&HRBs(@2JCgzu#hFuj`3G%93op+~T>_4t(XpT4n8Tcxp;wy`zIjkU26V8r*fF`<|= zhFYa|!O+F*mFrCPTuRFrA zwb^p?akT}ZE*XS+Htk?ezJOr+e_rll-Qix}(M;vHBBNmS`9fG(ZfmbduDw!fkLB^b zMNmPM9veC~0xu(lCF?DMuugS&3~?;5)fOgKTP)R1mG|21nVKj1FR~9sQrToweOa*D zYH7{uWd3YQ8S$?~9->kOBEV&S@Hv#KxZQT62y{8{xiaILrP5H9&GY=ADCn;f@!orTNF z*#xX$W{L(duvEhq2-R?|YPJRT&;lU)LNv*gPA}QYZ)ym4p161-b=zS`q(Qq;nZUY+ zKk#Q@ZDS+Q3BI>9v}yovZKaTkIL*@u09VfPG&yn&blSe%MyG8$3o}l+1cjvQGl9Kk z%=48XC5orp==U7=yap-gF9*XbNnypzZ3rl(rpgD=lqJS6GP>AfzJ5X6{HRa@s8vMIEey1d90V=#{pJC+-g%Obcqegn=5WJ%$c6aHO(A;j*k)EXhz4Oo(wY0fibp zm@2U}L~OuEikK_pvTcgpIj23{E0EbYIZbXCMSQ<|aaTp69#R{U{x#*z+6FuCg_ zYOvzoMF-mZ3Zf;d)VU)qB4@STp2qDh*o?!#H(G1}1 zA?Xt?WN;~arAv;CbK6mElK3M)V^tWwECW4Qk^@hyE!mBP?v*3v>^W7GFu+$}15O8G%ILcOa&M`IHxi zN7hZ{x_zjq(8P$Q`H)I1peLx4(s18$MNX1ebZ2A_3Uoyp+qLOe#LrnVypa<%U9r$o?O1ndl`n`vd5mw znbVEWDaf};kv*}c3Qj&>iX2Ht;(+xX9lF+gFZ>EG*ezH&M)yqRcj1>i{tpm>O#BLr zmq|W&78NvQPAfBjqTXffcrxn1m>mcvyeTtTdYjXQ?d5t3CJ?D%x$ZfvF@<61$VD~z zm7K#3f2{Qy=HmNGHVCWh&9_@L9gv^wkC7zhZ!4HAlKpHpanXdUow_i8L!^Yp+E}ZJ zCB)XSH^XQ6V`FW+##IAEt^LN13pQ5Ia$PodB*QW%^!5sqnO-)|%S>z4g&rQLLjV`g zcBn`t@v+g<9VWcu@TA06m*D~MXhHizsaF2LpTUWyhIq8_YVhcyv2YtzNr+bh2|< zl49J6l6TaHTEe`fWB-6rTQg=;$mE2pH0SCdK>`NMWShu4P5UhhmBzo2NQqggg0i9& z;hRb&;4@n)idTni^}Tuy7Q7Ig0zv|TWOiFdP8lopoTdJ}U7|HRn!s2IgfW2^rTRPH?yXSlsv$_AWprM3F*1idg9f0V-8u&>;IIG8H2VpI?>4R2e|_ zBy;!RXH{U>Y}6zjb{~bl3%9E)$%rHWBh*M2#*WXn$aKZUCFB%!nNJiIqJ)t^!W@9E3Hb0|PPX&?%4h>^)^57?*SVieeLteNh{t1wA(HW+sLAC3%s*q0x6 zsjX8a=n?Z~fu#)Ln+&)2U?n|RV&5qbC_@uXqm>@CH-Zcn+A~NJ6i(HuP45N>R7bEB ze^2#T^(rZ31<^K5u)w?wcU(lnMzwXYhWMsaP3}VyWJ!m^*5I|qMxHdH0U*o(^$n=p zhz6#qSzDSqGWttXFGSJytfUd700n2^yGc*L?Tfviyo}}_!y2~IRL@@jmXf8eeM*W? zzZ{N49qom5DP7hu!qiZiXvAnlN+nfzq?MeYAQsdX&Xq9(vwt}>Y&!Yg%qgEcBU*!bO+5TH5P@$;K)_X} zPUzFPjant`Xh(pSS9s}K$v8^XT4GH;V+97QwBAfk7AH!i-qytZymm>bm2ZC2kr>-K z0xS0-u#@o1y{!ole}FTCI3XkuAC%-ZX>hvt&=-~j zJG!CwTH5e+cG$Ux-+_r0B~4{{XVDQc9#U&VE^?$s$JFmYl*tbxtR*E#J1hQ9 z!~6C1TkC7<{S~|zkvHRIlnuDaMcT8$a0SLQ&^U)B#6m}CJM!5=fjhBHTPS1;#cUxO zUQm;FR$>VCu4A!93dhk++>_r`TJ%l~FX)qfA~uCONHnx-B%b(p5)!ZLXr)ROtq-6`vxY|i9|?TNO6&RH^VBsP&X4Piz_yMEt!|0o%)!llo|Ca3krn87y!5Qr2>v0Re|ZJ)}fSS1N?-$xxGr4dqQ!wmw-%B=@Fg^8Flu4fKJ0K=N`mvunTsaA(CMf}3H zN7Jq}(KI!QkEThPM$@FIV~@QxsHwpsy(#%-DqtAZQ*iW}0(_@}<~V>IPQT?1*P{8E zuWm89mGVUuJgb7yPoVj8@?16l@b>SV@(kg%S}#?Itz^=YK}+bI4WBC$&bx0q+XFnU z(yCy4aPeMWwb>2YB-lQtk5KIctmZ;u@FtVv)>BT@G6NoZINX6{$V=lAnP?&*o6Xue zLS?ZHLTlpg8sx?)-?kfV9?H6@Jd8ZhGBHg`0B%2YDcxXa&Ko=LF z-fJ5d@&Lcl(Ddfb^-^miRq*v@iT$}4wKf8B7+GJhQguZ+V?%Tych-9CiV(XTtV#;# zDiQ(ZIny$gLai`dv>{rs^TX8QgNe@aZ>4&~K(g6I1q~4(q5f`z{-OJFz3;U8a;P*2 z$_Okrhk|%QDIF>^tj3tST42k85NOu^E8u;7V(eQF#d1StXM@Jq~s1MNU087Jy=7ntIJ8R2``5C63Xxn*7cYRzf-=ClmsP0 z0c3TH_)(RZJM;*HXrR;S*ifqY&+g>V@L@L@jwqo>KnjS8NIM6d{%nIWc_CAP&uCt% zI5D?en=fcVbrn$ex75n^1l&|7`VeSodA6iX$zQP8!z1=zNMX+WS_Jla6`ZPq?ieSV`(~I;7>F@X$;Jy)%qb>MXM8Ll!2KuWwu!c)UIy4;A2VWg9e{F;#$=?mawieE8uu0#UBdf%;!;>;m`8`g?M+Wx>2+HrasZr&3v<3Q#2+*HwX&dxMG6vd zHHDuU;CB?BuJyqeqpUU&)CYseZ>qK-T}{J%XR_@@&7c4C9`(gDA(1^@U6_&3CW zKUKkRy4;5U^$I>tULQXhuxZa~@tyjhp2hhb0Y>G_4>~A*$9%@YEYmz&zQ3xzOS236 zUZcL3sPDrpCPC6=;P26T?_zx*18)kwJ{Srmf`pj9iR}c?O?8g9+qb zQ@`Wm8=-Gf@DBRs7(uhf?7$?_ah*37PjE@tM-BHEd7e%t^$lDf`El%gJkC%+!RDJt7s*mnhp$u_gP=|w_MRKkff8eRgm>K&3)`~ZF11|4_ioz#Uk@_@I z8UjCM@RQv^_b-$VCJHe8kE4V1fOS9aGO`ut7PBB1fAR>@r5F*M3G-Xy8C_b*T2z-@uI>l5tkmo_I>VY;jzq@bM{^x7 zeGFoy3dD*+O)d6cCPjWXd-DdDAaATJ#nRG%rrBH5pm@jcW)m)R0kR1iyU7{AI?Xq- z%r&rXTq6dg=m(bp&s?(^d5&WIlsfu1TG9Y!o!fgH-;Q5V92>1h8)yoSfk&smyq3cRJEKT z$1x$MNY&wNopPQ|X)q-=AeQMVMkQ+XNX-gQGUuO3PAiNoK{SJ3U*cCEruF&8n&kQv z5o~5hSEtO2N60DB$CCge>K33Td1f)!>0(HT^|d+pwZAS#(p$wOoiMp7uAhUzu@XKHG>SqBkQO2rl#Mu;p&9WxnG*m4^_A__SkL+Y1(dDvB9 z?w31)%GB5!8!C7;TOdfo$zhS`9hyT<2UH(yl2|x)&*Q{wPE#k1L%xVTM*k=!7#2X? zGp>l`5jW&#`ALwehLiDwjSA@NW3w%;1a4_*+&T}5;~F=q*H|SZuNyW)+sc=QwN%0Y zYDNKiGrl$4j-Mj~+B*oe2cFE-htLudBKtFFn|l6fI7^H^|D=V#7N}E1>vcF?hm{gS zWl=;6m}0K}Ql-B@iK<}^rpV%ti~J`*seb5F;i^dTuHJZyuLN&>C9{>B*WoKfD35$( zDi$TFp!

3FQaF0vrs2ET}TH{3wtjKiF<4!ebWT9FA~6GHt7+0)QwL=cFM~m{d#@ zj4e*o88`NP0i4#*RIGl6+acCvwR$|Q*)Ob|oOatb_oXXzJ8 zEaR3|2XJijQ-5~+zG-a-9An8Gn|U9cCf|Aul8>{x>JwL%a>lQeI}S9`-{X_5*J zw?dwgD!k#UVl?9wRL%H8)oQUoaJm%0R*T3C9l>}VPFdCwmzjsVNQhXdNJShg21N!N zZUqikHo~fCw!lzZ_*g~4-;%{-ceUC1epJz&x{7S}ASYw4G6ttGcgapAKXX*^s2rjp zm19@lBrjAgZ86`@K*bQMp*9&qzhwUzQCBK_E&&`q#ZI&mQKpcTd)ZgRyG3Xc#dqFuy{i^yc_pWH{-fSJ@ez*wS+bzrQn0g<}Ej^xgD z-W7p{q|PfCOH{EAjMeSvT$f(6uNFhukg-Dcb@Sk3=2x3*3PH0Iiag{>$P?Knu4xiS z;8Jnn?+In-B$ahA{QYP62ECYYnRn0&MoTqrKuntS&+1RX9Jr@y05!;R0Kn*q&f8&# zZ_teRL&)3bkhi~;ck;;?N$fuZbAC^3lsUh#2(U8$koSh!+EI+CpO;kq z*v9}sKsHXo>4u)&vP9N1u44;eX_Rx)_pBu}Pz?72w*h4x%Hlo##O54d*B5hq-QUf1 zzOy1X0qfqnHXAKVjnYF&laB=u|DaQi(iZ0LtlMo)QNB z>am2^mdZHvgZF^Vyb!{oAp-x!QSr};fq!PdRgJ$QA_G@HepOk#um97mim?-Xs21lt z`!K69zK39aJh2{|@9`xzd*X3{egEdh8rz3#esKHy7s;2mab+FmN0LC=rpDJINXsUY zA<~vF5z;v{Q&i_Zq|B>%50Ag`?YlrIBy}(5O)rl{9Jd zeB4(U*9b>xWKF%{>sez28k3C#EKnGYcncT0B~2Udk>oQH z877u&1=ErflD#}KC?xNG^dV4+GD+2#4S`8gYI%<8dHGeS{RQP0C}T;3Gy^~x(%ew@ z+K#J6Z-Q?M**~Szz<&n%r}YwsbxzO5@@BbI2iUL#rMqoD8@ro?Azqhx4F&-Wds4B~ zHXjd;Stxy~c`H}lw@MGgs6euxcra>`wn28$>1SBj0-C~H{FG4X$!29_Qsr0JOP_rB zB%`7th*A{>pdp;*`?#hIG#>$iEl7$Ev3R2B(b)2|#&k8o`Z!f7eS62G6;U%-tcXBr zEw>85I8QXZ$}_Q$ho5C<*@FtBbLoN^p$x6jkri}6$57~Wne^;tL!a@+F9M7*q0Xh@=s;N^OB& zFOo=EK3^k}rVu&5H6nUTLj)EV9|;z#kjP?3RxB+3LTF$|mW>@Y(E^dcKU6iL=8$T> zja7`6Kti|Ma?}I(#l|CyuG9xl*9sBr4Mm)OVlLcn!yfoH&zc? z$mbmfb~#~#M|leQ+kw2VOz$?PAXtcLKN_+uVr=cx!XSeAge+Fny1HaBRd==NzZGUb z6^*D3|7K7JsM6A%X>@~O&iMl@GGUxxRI^|>y<{CL2VIKfG)R`YQB*V%!HPlpj=+X( z47XvlU`c)Iyh++%<#h$5GhqC@s{;p4^R83&DSo53dxa0sOSi}O+2h57GKmS3*3M4= z9_>{&wnM}%fSqh<>}vRLf`3<$zQ^!x5SQnNk`?&cBtCz-^7+%1&#z(~7^~ZnUZ)JU zFWHx$*m-rA{3P!;aG*MWTqX>AXJ2TRkLTCgyammRBA0t2z^J0^3dt96W8`>OjkB`@T&7rt_in&%L`9 zSCf5o7)rLpHMKak&ycJN)t0o-1pIfCY6K+i{3Ik8To)!YZrt*^w-1b=&Sgi(^k%spc&a&Uk5Ye?q>gPK@bm4N z3Zi7f_1mH|;{->QNs$+$q)i~3`pllm2$rPO8g3mFkUZDyEuFsJhM8inE+iUek4DK< z5TlSQb^2n961Y=}6;g=4j1PJc`~R`Ikoa3k&9i@ucySZ%T4Rl~C*^x?no79R2yE$4 zx7GVx*8-N|zZ%Qk&`H`1f^q3>NY$I0boEIxFSW1ee05$5RdKSJud#L6uvMi9w$Ew1 z(W;UQH0o)#e2T4_$~gJJB9?##qGcsDb2M7P7h`cz8mWYx7*x7H-dTPxG-GKq98RPiN)`Dpu=jT_=lK zB-(wpNEu4?>jKe=t*J6|3_;ownLn^5Z7+hAT^yaTR{#JmMXGOFS+Vfp6C4WMp>B)U zlURT~(>$*?Y0_3wr$`4^TpE({e9eWtZ_fH|KBUXf3}QV^SGkrX#Z$6lo5nquRPi84 z+p}_!9r}+d|KtPqz6$scycrRa6LNc%}AQebtUSKPeUvQ)nwy zE-SdRJ)P+jp|==fRa~0pN<mdHGNTjH_91>?oGcKgpD4D%dmZHhNhfClx$SO7Krp>*aRwjtXKt@}L04Q-4K zPT}nV-mfz^WJL`~DPlu>u`x5*+-Qa;HNCpA2J>1VM`lPw257?`;hGzpWx`Z9bfgv#b2Y0M6sxHgPz-)lNv?SHsKPG;Ik@&P;sZ5)E~34;?49h!EMdtSHTmo zfNMisAe=JgvXy6&c9%f~q~vi;XfU6}2!JKZxL8DZYJE3xsvcfw zeNeKP>Y>`a=~`%$_n}wVXZAs31?o==G@oWb`N*V8GKSz!#H33HU;h^{YtnCD`m%oe zY_l%ks+B;h$8GBmtJvP(?bA{FzWIoJnrsAP6sA;t16!YCU_Ac>qOH03qt60se!Nh0IWq_KIb zSt2-klv@~U5#f%=ES``;g(Z9tuOb`B&&1`lCQZUIbE>MF+ z3Fw8^}4In8t!IL1b+g9k_RLPj>N;DVR9%v>aU1 zarH3tAutl8Wu#;=MW))E=YfFEYPG%s>MLmP1}hQEMA7VTr!jNpj`<_%s5FtqaMfbhP^soVP)_lndl8lxS+!}aBoh%y zHCHgP-==CohQfzrc*IKDyaol6pZdwCP)0Ki9V~+!H?WpSSO>BT3@^Cq2z~9vNp zZpdmg6wm3r)Z@i5c9{6vpE&khY`J|b&G7%W1&6(ky^`%Ep#@(O#=ngzzr=B~4e#d0 zS;MgC3E@j6P~@1(8wckL^^nch<09qYZw{sag7edhW*=sL`fJuut3Ay!o^HPSp4!?4 zO~y(ConUO3mc*E7D(W%L+>RzK#Uo`lQ)ZDPU<-B_dOI3k?8JqRL3RRSF1Vv{=3LP@ z(61~2Ik1Hbxu7eV>()diIaGDjPm)av`;E>P8*~C^Em!(7=HX{_1Kr15zN8liZ7|clQG^iTg7@3iSnO3X>L7FS%sVkm_%2Rhd4Z*xD0v7@W@p5@0 z$jjtO!R#6ibFk0os$dS1C&Ii`o(S_2EDA(05P^c3El+%Ru{D`dmE&W_K90zAyuqlxs7P zes<6d(8c3dQK}HVWURze>-G6y-uSj{lVt%%pVd}L^X*}%+&;m|MHPqqEves^X$K?s zOJwi<0J;|z>W_Ua43-7=|6L#2FCj+M-)%sj;C_i?7jXxNV?voG;npAkfWrsR68olu zYb+wL;t2cy-Xal$SANX>Q=+VV-Cns)?Uzvd|F~bGrv*A80`#oKZG)a5pdCd79cNH2 z_)fS2psoE9YX6_?msnV;QJHA$Q81vw(F9uUCn(EE zMl#if*uq6@SU*m)4*yQhw1t1iPE%nBa; zTfl3qac6Rw^T^`^{%Nq1-9Js8RX8x0Almft0Rb0vMUD@yFexM(=g+>oI zG;eS|`HFm5m?3_OcaSzWI2>P1aFmRr6Pbg=a9S;8ZXf&G4L{_hCsz5C<1voEGDpJ>&js+4`_hb(Z`C z4)CV>5af4?v}+C2m0Or7SC)n#4I;>3IdCZnKg}vAQy%>Kya{*`S^S)BeRlD|{Qa=F zxOq^OagDe^xN0$XzK8bN2evqj^nl?n>l!RyIWzQ1!1Gkr1}S0X74RvIKbgp(F_u9x zd!a0c$J7!aHloG*d@H^@2l2cBhE8UR)sAXoei?7!RyYz0=> zi64-&00QRaMtqHdBU)N&c-jv}#Q_nS-(_Z0Z6Rf>0Bq{6h=3O?Xm^Da%5fredRmjd z9fd3fA^lY@5((NtADv$Ck+0*-FNa%{5FK6gl=q+k8qQ|2b&MNloUi%yxZ zX9WU%g|1$AkGSe`=q@jE4}KdmZ{N$qr#QsqN&E2S6%rZkV`r!F44$+cxZdl zCWiPSHkqSh52`X2ZO;#BPug6pw`X$xN3_ic_@iSQWh#xh{R~MzIuM89doRIl684k$ z2c%bpDgF=dQ;Hu$rVk%w*(0DcvA}jUe>vhBIDm6+Fql70YjVmtv|l!VT;|i5eldLL z@TfINX_N1z8qYtvvV+>^@6u`j$N8Zrv8ZJ^)VlLSt`HvNoN@+Sr-pcHLKxP$U^KXJ z=|94_Fc)k8tp%a~z77QU1#BBF`j3|d71(r?P6bveSlG4%fsmv$zQltpfI5t+HD4S+ zIvm$e)Q;*Uy}}$-3pCxlAV@r`28Mv!4>J*pYnH_a z{L`*kHk0vwEIKsmHhOsED!t)_>44r9rw6r~WG2i|C8ai;iHWm*RSg@se$2bFVU&bo zF`tvOFF{Plfq#Np1PF1G{6i8c8Oi46PCT$_5-tBYHHwiIEX1cXV??8{Vee1eN|uDn zAh8iGfLd>9cnYu7v5Vz+GRyuT%cUo);87KPaWQ=316W_72cIJQcaM%k-wqb}0oZQ1 zVem%ic9d6*zu54}Knz!J!?ok63dW{78QwvAxpiRRy2)J(-yod)wDgfiEEKeDbI)8Apu3WjpplB#2Pt{C7edr4I%oz}@0 z5#a(0JX{|EuQ!`%F5w;4SF)1=>hsXk$;XJa<6J4i5*}fvR699Q_dJfhecim|B2e#8 z)VJzyKS!Ly_h9=R>)$5cLKvvjgqy2gv|-#`zlW1ZeA0kVW;Fz_+j!lIe(b?k0*^{~=@9Cd5FEL;x?|ecI(1qsvvv_(R2Ty)Pz;xPE|RmF9d+0>FFahK%f@t z;$S%A7{+NPaGr~TDwejwD2_>pZIPbL|Hz#$P&mlt3*UigSAi)Y)MvfRS2LNWCA5XD$)8Zg_#GgRnSPYVi0zSOL|c= z!72S;C$&ze;Ocbw#y;Gvf{trL8oexeN|rt<4h`Lr6nvK$eAhug)$QO%?Asw3n6GD_ z5m?(XG6g$bQr>^7q$eXvGCva^0`+A0fQgK~NHd+LRt>=!p$ddELd{rho|gr!I^VXu z+&2CSZBnC@=}zKavXk=4!7AnGsZcA^ERMFjsDPAFq@-91N{J|xUX5mfsKZ(v5e2kf zM>5R^xe35ONw$GT4AHE<*^*uvRf5t*OOWQP95Jgrr4YY8iFKe;njeyApPeoBQl!>b zV2cn{vY0ehnxl4!`hlX9 zY2G4x7I1WI>(*R7D#VXMHY4k1A9xdI>b(?D$>In`YE)@KqER1^T?ZlcVm9iX45H1I z1V`ph5?rZ|&y(Da;gzC~vn4p84+Fm(rx2+wRk^LyrFtE%E@z#~Ds$}oqk#Tef)hSx z09CK>iiEE4Y6V@r4u?LB(4lT;gA_13LK%xN;47seOc_@(DFi{8S@2dAS2Xz>DQ5-f zl;%au7bbs6QpMBsc+wozIIIoRf9MPOdjf_rLjGo}_V_zC@{*mZ)yz@j0&s5Fq@+Ds zoA?v~>=lt;3}*-)YS>1pcQT;0#g(??=gvy5BSC8p8BTFGeoqYS8m@JNhv`tTEfZn2 zPZ`iOf9#_ms5DWVNKoI0<)lp_Icy)%MtSZ(=dh>+TS_a`tacF%@NpV&42&(nrGYe} z7s0tC!P+v37Ex*d_k*(!i*(%s8wCn;MKLTVS=>kcrkhQXOZ- z{rXT24{)ejeg>i2&O^OJ69RYVYrXB$K0Zgh1IE5u&gmDiuR9Ta-IL1_(8K-FNdE%+ z$oIO_t2~{Tq5Hc>?VRsAsh-`e0(7$q?W@(o^aY$r`jFBe`mPHR-l_bZIck{=REBac z7iJWL5L%cJmRFAqVVNho3T+e|$=9X{4u*Z70{R1m@`c(L3!{o8f`wyTD>e}kt`*BP z51j!tpf^}vYr~kzw8f!!wUBXybr!+t_W;6xPoZ~AcbfD! z@}OP{jpTvYwIk<2l>lkQ1Hrt@kykKypwMZ>1L9-uP7m>5;?eQoZGa#TCaNKCr{aNf zpCfsYM52zI2MY66JP^z~9l5B22MV25JRm;i_h}&>B(wQ6g|SRj3@!#ACcS%9kk}QlxErAmg}b-e zB&^`5N-#Yd*8)AMa2AF#VH0)v8con*1MNT8}E>oKgf&MfSVcFom~r zM5Z-d(#&Rkd{mLbH0eLUv?@BLqN#3|syiA4ZxjTNCTFjs&bf^vxJSj#zZ`8&HlNDq z3>0&hCK7ctY&h{~Q8K^c5oAZh1`<;oofvVBu0QIUaUU&8>O8fhA_ke1GG=!X5xTeZ z6`+ijKh22Cd`$SP{rHl_22x@FOHcGie#CxX&XR=IQ^Glr1c*H`c;-r#bo zC$6@}rWRUf6h@5ZIgC(>*{rtk37G9z^=nNV%V#glIePw599(PF0W3g9^O$QITlBC; z1>)8)2m7(ATZ_5TeI1Cjhf{iG>To~8qnk*bCY?!n5JiR8Y1V5s#QcYWNaV|5cJ3SD z++6AYPLuvhXe`sPpn*3EnmhnsLl_*rt2;t(Nk)G$(pRyvE8x+yzX!2C3<5!NEWBjw z#qi6RVD#aWz9%cFNrHGJUg1m%LY3FCpsthAFg5qln%X2`p*6Z6getFt9F9J2GFbyw ze5QW|5RiX^|tA&fpDjjG-Bo1u(jY zi=5u)?3Z_U<9x%%VHY+qsdJKH7c5I2^^8cUAw-)I;c%lO%#TyCOPgIz|I?bqvKmC8 zO0+{`bhZXHA3I0TX0GDkL2NvN@@1i?r+-4|DG$Q>tfqhVpN9*iM-w_mQfh?Pi>Zh( zUp#pHbf^`quU$I?I&3EQ2A?xQ=IqN(!i)3uroPbhuU)_8Wa#s{YZ6$0QP1nfl=Pdu zq0PLc-tpAyOVD;vXXdZ|L48xE*14e;rc5RbydbYQxZZ8kQ;;1rek_Y1%0AR3U{HmK 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 z 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

3MAQ>5$dWU9w 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

rg(v(3?%Mz7Q^eFn+! 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%0D=;=33))s(~yYb?{D)J$4v$}54j?tcu0z$ zY>L-t@g1{;yVv8kM+^uZv&(&e>3W3?HLc+8WPuuMPo%~j2!zHX!5LZgXQMOVlg7r^ zLtmtHPuYboTHR{IK9TLS*?A>=UmuX$LTEUrn>dYQ9cP zt7klFpE%8=Z9foccWT--Chc>kU9M?|n6$M_J4Vy?HEGM3)<)9~Flh^zwuY1H_KDBV z)_P|%ZJwsN_)Qjgns$xJcMa3(5h%g?3ns)5-Ao(xdkZ_OjA^_A9>7MMv^7kds%aBV+ES+N zr)k4Y+M`V4m24<``z%HHcBVx%?S7LsiD|m+{=|tU?P{hyBwO)MeBGoCXWE&Xw%(-m zXWH+a)U;2$$fO;`w8u29Bhs9%OpuvR`@|>{Iy2!1TzKxh`pfFZSXcat$9lo>gsQCw z9go0j4g9yxL)Y!YadI0mdSi8Eh{O>G?m*p$yux?1iCD;0wK8>u^LP&i{1N*mL@#~% zj(aN-?cPxDRS}3M$6p+bB^ie!oP{DIY(jj>j^X1Uye557G45CZ%+9@0GDdOfqVB`{ z=tMjMTNBf&!Z;uQyt=W$@~Tgq-=9iN4#cy>A&<*o(FM)rAvsnleosurVK-&Hd;AAS zkRPcbb`je5{6T$HuXFS6=HQWrO%Rj~I&KyJda-;B3d$WgdTW+Xpg7XfyJ^1I zU=S3$7I_389w*`{1ku!v4CSa!AtyEZM515u`!;^x=Cp%h=E()lxM9FRHBnZA zb20>CQ%ql&4?`1K;q*UJMizei9vU8{y#c}dj(ddmrq)xTfIPLr-gq`;mtFxK@EacI z&W)}PB*^l$#HLw$Gk!u-TLVFZ2y?$HYz+(w#E0AcA=h|;OtCj#1Tn^$3GCJPsZS6n{NQ@ zh6RS?WE#+yCIMqI{Gl%beqZQfwSp zBNPeJqaW~rPa6ea3jF{Msy{tQ+7fWAx=ZYrj@!elXE^?0Y8Jx!qa$lKO7?V^zp5z_3n7B z&$HG=%B!aIyaM$DZ*Tlj+j|Zx$YY#%Vw3t0H}!)!MsPqdk(mJ;MdgA(kiZN{UZgnf zO`K|oQywXSVbbmm^Ax8bJx&HbN%RHBx|&5KlpbX8#^+oj7;Sm70X03&nnYVxv8GqO z)+fr-Fw_@_O|<=|us#Tq@G~Fn^XhXO4J2fxSb?w6CT2a9INU`XL|dLE4*zm-2)4Hu z>QACC2eE!3FpNY#5Y+nP+Oq0v)bKoO5N*M>hwcrgg8u=02tWe-t6B@6`w^1pOCRD7 zR?+oa`OuaG`hj#vq|kWU@?#8bdXQ}rZTUCbv?P&V!xQUcHBs$vpcw@SQ~R#*`4@&j1pibsP}gVawf==4on0c7UAsR>!E+(TZ;4hFK_>U)V&LQRmIi! zpJgPYHbCf2woAZqIf}V>pl%u)T%+Pyx-rN+2=;U%iI6+{9isFviI40_RN}fpEYY{ zh-+=lJ#np=g$_~Gw;9hA)SsMui-uf9V~E7?30egvIMWpe+I@qx#h_Zd*RY-afu>G@ zC`=5d2Vd2!0F06W!okOU{}vu=7bX1Ks&UjFeb6Spkis{mH2LFx)?)iGM?qMoW?amU0sW1Ajb4Ta((zmBw_{crv+7*$}OjtkfTC zxGqRZ4Vew}WN20&Q2;)-7_q8=bG-);XUFuE2E&tEg9 zN+iMURxweX`OYb?@lJUW{%uJ@Kl?R#pO{@p34myn?Y49SWUc)KNdXNvvIt0{Z&_T; z=ku;Mc&Ka$2rweRIRYk3O!&1zr!rYkMGHhrqD8BhnwtWRy>n1pcU1aUkls+JzD(Y% ze>YwXrZMLVwt)~n@-pR_R+5k=q_$aFiP#~hUdz!b;F%DI0dA2;1AQyXM<#YHX zQntqB!`b}$q}5^sZN@%T*D$`y#|aO*?c#fQmnG>k2Ke!ger8fU{z0n;)QHfCFJSBP zHA$TgkO?^-mZ$EQVgdvoz-b`5JfVg)zSE6o)vD-}25t12wZHMw#yGn>?E#&%NboO= ze()+(_(GNn`f_9Z_5TC;xM`ahnf=H|j$Y`?+m06?ak- zC$^iKC08&S>(SgKk#5$~&pWO8c)>%w<3Kd?WstpJmd(vp#rk7o{9eRQgA|rrPoFkR zIrY3@pel2iDc6|~a%OFhX$rmjt=@I5-6Yv#2fL%HT9UupkuBOM4r}Y+>&s5dDpoX7 zlaB^D?V7xMJ^W?Wadg`2j?e0Z0MjKM!a}FPl2zlB=dq_vPP=d5F&p#=z|6Nnm%CF~ z+bbAooUN87TZb*rY|Go|fR{k9&Z^I%)^2k63)z5BaY;MR;ttKPvL&9-i3;u16&0$h zwbMOhiEc5sEBrO$s$E;5EO)(I;@Q`7$`GZMFglNCS^*LsrJL}6f3(Hpc{;eI!mABT zZgUXM@kO#aI*8vx08&h`+S+dXTIw4+VnO>1@hHkzo{G68I09-)jP4d5o&V9pahg!F z`(DGpNra`6lV)!aKG?R4G;Fn~g?e{@$L(Zlgz(e={0JD`YPS&pY!GditG#_=RVV_i z{tJEDS{j+i_V8>n^<{+?LkV6pMeH%pK6?Dd+B+~aCj-X@a4j6$-ZQizOCO~2aa`tG z5Cmo(L9;8B1>%*hV(snDU(i0mDjFl9p0Mfk9I|c4V->NsOsgpFp7=0}?2V#B3q++p z<{3SlR`85mE8ne7e;UPSYbc>>2@UC5sRluaYdAhPVx}>KmQD0ojV#YI!2F?Sls7u_ zzTBQq^IODryPaTRJseAp)6mB`!aPO}zPSgWZN6SXI2_n4&hE~8?+81`mCF_Rp)ayQ z+Gcs;prON*xS6fIvG7YeUC0&D$0g-9c|+ ziSAU-@^)VkmYrIkfX3_678+fBrOBRW4fFV+$+_Efez0HL?@T1jqJ)Dsxl_uJFu7{4 zqGU<*^A_jum^0jcmcF)nT;1k<%QcrABEF0w2L17l^(vY9t+)~^NUVFx$*M^U1y~+1 zrNMwAn_j9pr(%Z^dsz~^|6H(O?cu?$50g_nPc~cU6Mrh z<67f-iuy5se&a-vF)`5T)htzw_IJec;9?J~E3rkl-uRxcPhgsC$?UCpr~f`g!^-HR zXJM{8{+%@&|3UwchhDYfiEYY zVfT<)X+N{KGo8I{6c=M}16{GVx_bVcs#_7vU+=Uc#z)<@^kUdjslz5cPCdfrFT>XL z4wLd0SJZdSua*KAzt^u@AdNelTdLLuL8+G;*uf|DNJDC=K4_+j25p&cn-RfR`buJj z7_>>Y;-x5l?Q@z)!?EQ|sX@#0s{~`Dy1DlGYqbM`%9HA5dwQ z_Xg*4P_{N|vV@EK-R9(M!zIx36y$!a5D-6TKeZNFwt0Gw78e+K=_w59sHdIgs; zwhyqga=%!=H2rFO?APRlWp!+6R2GCIH%%vQeboXL)vDL(&nf78%3S-ID`neR-4M&8 z(=s!MbgEYN*S$n%PzejlRDk@h9(fP9FO>4|dI>7p7pyH(O&QxgBpkfIeXfYh9PdQi zRI@|~eOo2mR!9H7Rqm$7*mSN|9YbBIhjcY#2cl>DgQj|r#AIc!7K5y5Lr~@Y+nQ$ zIgb+N{{$*JX^{kj&1~aO4?6101vYZ;!Y?7Mm!bH}RA2UEok5c|uJ3H(pxRKA(MQYC zf5&*^T3}xxU{zLrwVyfua*LovekDSZUtPWY&eAP1G236~b9FwPu#p)+1zI;%TOXc> z-@H(QD5N)x;Jl288(|pVm>kUIxUhBN>lDhzYC!qu>MNJvs`6F-Y7&4b&E|KIawz`1Go7k=1TB(@<7)aT*dz=CX1Bd9oQ4kM>IFze*2Qy<~`*Rnizt7)%G4^_L#qC z>3a`BwE1IT{6~iII4&*R>mU9vtgyG6kZ}V7H_4!(0s5I-F2c)y-@U**h1rJqu!}5C zSC{_g{6Wnhom^1;+{B|#uRq`OU;DcGo_ly#8r}a0zWRmtv)pIfk*xH2>@*hnRQ+AK z&C_|GHwSdUqs#$aRn*?6n6KUH?s!fXW+q-O8ITkCuT5u|3F&{n7S{+cppGm~H&f(hapJ_kk-Rl6-p1Rr?QMe_bI>|o zCiAtGK>eBKYY&o@Qgl+LL_J_8hAEqYJn^YmLE2NC`H(lGHxmU@xeGLvdw-4>3i+X{ zaFwxTJ|ue{g-^XuOW8>{Dk^runSsg*Sa z9VTO1{hRi#DDMKvAEmSeJ_MP#2^7zom|v{*vV^P&u%bD$bo?3~X+{KE7Dlg@#mHzS z=_J{+hxrb>XLjbA!%3lhD1QvaEsmlv z102^xyJz1O@$v^t;EMk9$C8u(uCA_^e*g;mIUFm}O`T}Uw0bf6v$MQA2;{U0r zU1pg+1JbMAlA4u0U)G&d#z}^8lab$Lw#@e*~a&Fhx5Q!g8Zvxi&`7C*Wtp z@SNNqJg|wM58VhnsnP=6YzUrkOuT={2V&w4t)KULXO+s}x0#ZW-}Waxz}&UuDS_Ka zu{Rv%%{jG7HYpTG%JG(7`tf?+5`x^J0dS{k1>H6J0CSo+{UKMjaJI=b48@&a5K||5 z`EloIHL1;Jg~n!Eeban=xo}B#)LbG&MLYZ%#{MgeEmzq3Cw1hut=K)Yd4W3m?Dq4K z+Y0niSAM?JJ=u3fI%o2t|84s@=CvYaQlKREu(w6ZBwDuc|6}`k&&Q-$<<`Dz+p{_k|-hr>$gHNF@J%9J};Nw10?l*#u>*Lose7wE(v*API!B64ue)pyV`%>WVjw^gu;O`!g zeFw>h=Z)RA{1dGF|AN1J^9w~Ls=(jvvbRMhsvm#%)b-0be|M8Vf`|W{zndb*-WUd% z`|SSiZ{LrZ=Rf7|t|bfJ!Sh-D-JylBY{!Q3W1I2 zmS;_asM?OGi0{&&-Rz&F=@5= zW%y@HWT!)ajr}uCrFs9XkN5J=%Jqn=&9Y(N&A(Gcxa7$oHfy8LJOjid@|e~x4E=@viw5d@P+hVJ&{j#t*$wr z>@Z&hpRC6FWQLPTi-e+u(bTtv=4kZqVDG!UPiCE$Pxh?$$#fzb4spIeHe780wf=Yt zA0o$__{IFTJ>sZWkO#>e66>83jUyD%R@S)OQPb29C>n5I91Zxy_S$`9JrHS{^oKEq zhu|xP@jD04L4T+y2sQ5(Lj(YXIAjvDF}ls-cL;%tr$nc}6?3FPJ4xQ^MfszK9Dbxf zi`T=2iJj*7b3-=$smp&sNMulK2#=+UY$p+ZRx*sKO$F8RF!SAw>wk;tye^9%eOXSx zi&B*elNYp~oP51Fp=iB=xvzd#dPZRrhb>Lct?XXjwyE-dG_vAklxj=FuHkDZB^ImK z&_cjchW%~Vt%Q^c=K^S>J=4o*R?6Sq*F8cpK>mp2!nZwmT5ab!R7PF3biwvTu|_pyV#rWmz#0FztU z<{&DlKRMYBC@%868Mx5~SRf~2NwV8clCyKrH7q_4{9IJt5Y|~%CBw~^lGA?(R_jx5 zx!|#;sT)Q-e%S>IJAy|I?Fd5FFL-5BZ5GJ+0>*_R08KC&8%>R3iPY$-bYj#3OSAZr z9`P}|U~u0912y;C(&UZ*x;|HQw4;}f-bSRRB& zmkCFe(KA$>}o;wXm_4Eigm|wU1nO zQ66gPRt~jqvSLI1=ohuGK47Tb%Mg}_+RCZhNZ!PbKK=$zuZQ3Rag%!=t0$mwh2Q|e zZHC|*ejOuNQwQ3N+JR*n*=OcJ$3ywOev*@IYIJ>iq|rkVy)|`gHG4oOy9b*Yu_PuK zp%r3uz~e{6gn-9yH$oKhc=AfKn{YL(s(FM0KK~{$vJDdBtA8?L{8uqC#OG-wf{gPW zlXFYE)|B?g_=LfuJm$Za1km0;!Th!ZK_UOoj>%KV|Cbl?zxNCw4@gnX`Q#}F#X;)H z%$Xw7>U$uQHsJL1Dd2zeuTew!dx_KrDQ6GhU)h6Gw-wJLgigm)AqpyBI{4h}VqHto zI_cJG1ifZqG?7+|5HI+{R!Gcf#qpiAZU|W8lq10 zD`*$pZ?rXrFVbO)OG`E?Wsk3*pUWg=Jq1#B@I5gZ3#2T0naF6eWz+LTWGs}jT|F5) zM8+@u3No@^deMFr-$Hj4(GRjY`XTb7-}RNAe$r`G=|%(zwUj!sT7=vQLP}mu(Ld?! z5*#oFU6G^aop;mA$^F=)iJzkVFMjIwOG_O$t=E3d2HXG2`u(qSd^$YMMm}Lv^`-;k z{<_}A(;Cr{n{J@B`|hH*{mci+pZYHCf!7Hrcf3yKILZ`fEg=$I&ZQ)}jP0YuXF*H^ z_=$HsY2u2ivOsh}#%yF~-1EY^jWDa;E)EQfh5<m-TIRw)>I-7+Am0@wzXpJ(5~3Y3^1msqX=O}Wxa&D?~E&42El;(uP5 zb&A#Hu;Pu3KPmAq`EOcz^HluizU&(W3^ZX_3IX+r-jXp&$f=TtyAy`Pr_fg$ZlhA6 z0pN`hn)DXL+N6c1_VLb|S+INBodRg5A<>c6Y`hXf*s(o<6p-f*!kKchX*Ci}1(NH3 zymf#j1|6X1GYl_)4bsY^m7awwMbssFmG-1yRSQ4ulmtE3zxCdQi9g)oad}Ia#iiIP zPU@l!{g|b%#awh)>wOF*v9Dhpy=#?wTr`62Z&|e*W^kNUTi9>dpMLwHnDNPct3KOT z+tfZaOHK^N3MU&x2kD3i|1nk_?C14WlFwr$< zHx#OgQsT{HSz(>7SfvY))#!O`RI0pPK8LC{OpHe&Q6RW3aI%tvC+yD4H(#9qU6WQf z$}SR82y{h6bfw!t7^iq=$Bsw+B_8Q^TUM)C*qK9G_+T&g_`1Qe3R5o)eT3r~rtd-R z$!T+KThUnFrdevb9N&kNJu`Sk%B_)IOHP)7Uj6eC3>&P6H#l|~@qDto$*S@as=b@i z7vm$XOHTjGrW$(m9W`v}QNxx?6u>qk?}iZ%C9j;#JDsgCpNbo79D?zzU$BaC2z(Mf zNK8!Vs}o~di~QhoKamAb=|lY%bTN-5=ax^M=0h;r;uW^YMw3bU=X*SypJq^ypF4RhGM9_4l>v0qSNc&Eo$jp+nsb^<%GNmI zzwHYz5$O})SPlfvy0IEhc>W&oOmg}_)PjxHES15H){oT9Gq*HI9jpRhwfP@25x8c@0<&8U z)-Ymma{5v_Sf6@ZuI+G9ud#uiT=`4u_IfbC3W1dZ_6kc^oP2;QYtO@s2nyyWe{Fsm zo2A91cJK;BH{#@lNGcwf>O0oqf6uV1TYo6673g=IZJu^p#m5y#?~}pVdn+Btj72Kd zi`IZu6jFak`pLJ&&Rv0zzJHr`r#B;MV^k%6WD)3zA0v_mRhe?MXWJDw-WGexZ$C(F zQo`9T*VpJ9UYJl(zWVG%#XOE z9m>*HYZ^bdWPT()CD)K5g}fc@Y%ZdsP9`*H`Z56-#ac$uscHeJ8GsJT0>l_A2*-JV zwl;t+QC>Jhcr}M$6l$ETVMjhyBRMP*S7Ej}^RTugO)bmRT9eCy)Pl@D+#;wEMNLrG z=!Sn@Q2V$Y`c?|VafJ4?rWU}N=9iibus*gJYsB&!eR-|IGl1t?7J$tZ$*f{eQ(7wL z-dd{E4gY*gRs57;eqO3NZbyX!S{E)=Nls5h5B9k*P_7-Po--Y^6CHR9^nR1wQDvm^ z{;6UFsyYrs<=KldLuR@7^KQ~%lUA<+HW`Z*x?(JJ^{`&6TjIzfudeg_bqQDXSJ;#v zJVx{P=tIelBxaeb<_PAoLs48p$*VLnUTS}rgM_db=cFATcT=sU9z zqlc#xH~-4%xF4$;IyKc5sR_c-)y@Q`h!<`pWEr`nr_|+6$}JvU&C?U;$jMZB9?sIr z_DcZ#>b(r`$-0bqDmneHl&w##uuzX&v_R`Wu3XGhb=$RgASgo$a+a)*H7aV-lyj$* zb%0~d1bB3}DY^*-K&KP+=g6Hf|H(XafIr^4W-hu0z9SY~#@?Tfd`dz@-AEjQt_Q34 z+N5*|MC#K|)ZYqSCoNjVh4UH~^pcJ5R~UOlMei&{2d3y-W`EOx%AunhxW0*|S+TZ( z9=RCOuyeE8#wVYn0P}FFk*^)O*leeyuGiuuTFiXiE0r=+akey6LBlZd+D&nz1sdi4 z@2gSMBNh}yw+I8BbSy~gbEH_@XYs+z^`_buWY%(xp8Of@-H-an6R$#lFgf{o)l(3U zG6{mm6zhjw7;Q00y|oku%Yayww*(a~KCTt1hO;>K7ca^o-fl>A)fL_$#`~|c_;x_; zP9#-V%K4eYvo!9|9S(&F1@3%wc!?XcB3tIuv%d-FPVYvPP18gQ6gal>(x|ayvqfHu z;&035!8awnOQXkc1O;30T^0p7eG<&|Y%#l@8y?=LEH)KU7lV<3qLSQ`noft?9D8giyI$ z(a3xW08|?^Nd?d%`CW^uVehgbN>+-t$rd%rP_NObps0E0mPs9d9{u75aP-v}M@8_? zcJM+oP0;{vE!EZqXD(rLin>d8Pj;CKSnx^$4lZR=cpYv>>w&;?Q#!nuy3!As&h5+& znbc{~{mi973geZCWGoWjKT87(Z>q`-HR_&eV_U!tI3>}Yn>i|g#e$}y@I6bPfF#*^)|uASf4Ulhji~ALdBgX)l7^m`L$q&4GBQd&E1*>1vG))=G27}6tl z(jwuTX(>O=>Z^#ptJKo_fHQNp_mZ}P;Xb#2>&4#2+ZWBN)j>wLDev-03e2B@ zo>SFsOwa2{|Lpyvy!dkr+1mIScv_%m$#pS33kDX?eLHJcb6&h*LkPmCvayQ8fg|R} zW;z#SzE1to>T8ho?Q=#hC+`-I-$wpefql~&SH-1Z5-N8-c<+wsgC4kfw^G^~Q~Gg` zT9{hHY4K+0KES@JeI7?vcm^!I&r0yd{|nZee62)OJeAh!te1DayDLmj~LoESpkVZ$d1lTizqsX zxL}6x45BLym9}OEmjNn|v3~kK2$zk1m!44rX|#d!z_;I}bad*ip^Jkv-wWu=lqc1f za3lwf`d*B&Ufie01-%H%whU4_J53%NgSE=2q<_FI4V40ciptfQmmNIy(}hRQ&N@8w zBijYZI#vak%+ncztcxth1aUk=+pJvc;hd!_M#%XG(OK`BWjMoKes?uYvm75OKRy;_ z^IKMEB(_kAiQi{uwdQc!GbprCy(Zkb-|M#2k*axEDe2&J@=>gNE#V8bXwWO>|4A(i02o= z<2EseK-2OI&n)OFA^^6WxN2{Jo?)shJda@t@tCK8b#d92`vl?fn`kC``geJ7_Csa+ z*X~=01jkQ+JakFv3Pb558gld43?A0RFyjaNXR&3k8FU@PU^dNv@ZjMJ)QrQXO?? z#Q+dnV7l7IKvsqLV6z(wkn@Rr;0+@}*dZaFZ!iq5y;=B|y)fOQ(7I6KRLPMZ|HFk6 z@Dkfr|223)eS(L~4&o4rH_`i-Y~+-!5vAa3g#DwpzA2!sGLLR1g66X%)MMKuTxxeg zkm}1EW?H_%s-03;Z4OZEMfB5tstsFlBYm}uSm5*^^MZ|y9?z`MHB1~35Aw3iH?B0x zd`Ewy0Kbm;*vtnI5%rgcz7sgsAX5+4_^GjV+#CwKAuQWU%C4h+#Qfxx7vM#^Ip507 z^iw&e3!M&?wm11Pg2NP*(Hz#Ui1a9bkNI#+DVw;`dtaJg}+b5@Vt0LX}SvA8EcnZGy(iK69mT9+#ldl9F$S$tzU@%;am|FGqLEg!RccJD z4NTU}kBO3*BrXjH|NX{(B}qI`9j*Pk>whdsX3=vzk1Jv>4(yV78s03{#a9z9bGkUq z9h@7sYK4x+B9j%uA_^HcC{+JZ>p#uto#QUwbeBI|iS64g8+gn4OV~euezzU+)&KfC z7D2fepl ziZ00ciKRgrh#yW06fJ*htn-tr^kH?50jaRLh{J595>UmVhMMTTTeN3Y;qp3YF+DF_-snpmryeAQ4H{i&gUq=bpz?x{1)glzO#)iwr&fdmKY zQ4I>gVluV5iJrcBeFR0brokG$<`(r6FA14=61Us_P!GtYOmxK&WxAtQv-&Kwt4Y#is16b&K3d9y$>d$peegQZVG4& z+juh@TSVm7RE6*Hj zMh}YsturyL;a`RF^UdicVhvfTf1R40Juy9^{5h-?+-&d$u4!6r>HV2#u0GmAYv0F! zKDv`?@o4+jCA%NA0#dTX#-?3wztor1!@z=ZQ&+#460K``w^D zE=5u^8o=#69N>}B7*Yfe?!IqgMy`o#^(ai-d37wE$dr|mfS!M3o~)pQ{M;Bo&T^mK zb9~-0fCEK-Slp^KSkzexn$T41CTcXH$-0V~C)RWRsdnqH)Us+v_n0ii{q`t&sIJr;9(;wYC1$DO*cUfh}P0k)#{J@`AT_OO%+wC2?t5w11iT~CP{dx|9F^q$bA13YgBm+r!rdd2g?7f9{1!xyZRsm|m3t3{Q z3X8R)3(wCYsqN3I(8RA<-=grc-)^W*K4^@7GaKyfPCue^CUdt4W)>cc@Mmsn*J^Mx z0Zf3uMn3M4`;e6TuqB>DTLK@V{W5{k!rWSoG-0cp0}lKN6AhQeMp3VU-qZ!})sK5P zMKli|c}mNi1TZ!VM@J>7)w~FApb^ulMjt`d#hKnzH`0q+9j*SPC)OxDw^pOw4|8py zG`+otDWq`2#Or^`QzTzhy`h5S0#S4+(jr^lSg@ZapmgdJxVsRfXqz7Js`Vlp;ZLQy z6WDZ z$qxlxAD3OaRYQ2py801I&i`xg4(bxDA_o@p(Ii&!>o%@_&Ba%`0r_N@A`3FWl?SQ4 z{W2wxA@o%aTRv=MZ)FgkU%KG6^5oo++idY+KsrU&2W6LTP6G7#f9tKlDnT?p?9wTd z2U-0E`~{AEex3JM4SlJ*hIG=CAoN!h?+kup1yiuY8ArL9gIxDvCpr9#5SRmHef>G6 zVXT|u#c)b3_jM>MojNX-+J>bng^gx)2aeg!0(f9VgA*zXf)Q^gr#vD^=8>YA1$%yQ2kAd%XXx-IMjtXQ!B8K99wUD z&3(iMb?Q}|*A@;s{3@?JOhD$_2t%c9^$(rM{)=Wld#FAYLi2COtpT(^@V?Dt8vjIU- zPoisHF>YHk32xhVH7F&+2x{Ta(G*BlVBnX|rd6q)7FJ1kyv4es33+Ko z?R#y4b`kqaQr#P`{LfB0UWw$$m%>-#&eUsK@kY_K!Yl`k73OmUY=cX{q|*y3M) z7*k-6Y(F!o70+dgAW#sYem5g-bk1p1o?cH$8lFT2r};b<5!9>(Jd;+7_cKdQwq0q~ z%c-W*ki>igZ_t_?VtLlAJN)02gP~e0!unVm`ooamWZ9PCO0?1o_ zPDa=?57WthF@5Pz3h8D>*5)YUdZHg*20FEahv{@nE#}nQc%4`wesw-tt?*kTTW|Wq zfZcd!C3kf}dJ{Lksa9vLBkbIdpeH}l`{dn&>nvh_aDST#X`@f z-*oo69M*n_@JNsd5hbqXBUnyuXx~x_>vf4R zL*G$oG%zCWOK`Kh?Md1}LYMW^UMk#K^E|abcpgxcW7N1@D%= zdL29rC12wq-?zopADUM^d&R>OO}y^OtG>}ef6Ku|=(yLa|K(JNjxJaIt*-jParH0Q zpvysDXVnK(zel!u@0gZHM;2FqgjL^Q)wgdC@}I_V{jk%mMVjz7?T( znFqW22RHM;t@sK@y|I%k6zZ8at)Sd>{@F!(_CxpVxBl5#diEvv>=m9xizassY1K81ulEn> zDQd#NR8! z>6=q#fZD}LWg&Y0UGkbulUV~Gii}%wJ;jc0d4n$ zG5XX0$;m&GBI{aBzctm14QTe3FwS2CU8Z(v7OgNK&-IO-TqHsF!>@Rgf$(HD!(Ex2 z_61c;zD(CpixQ51xGzZl@$F#2YnyRh9z66QxLFq@$Gi>2c1BF%onJ45L`Rd0Gj82j zH1{-xC+kP7O?Iv1W^8&)U*Fi|AD2O#&A85QNRC;4TsVH4(qP@gO1GSLh1gUY|1|O9 zQY|UyIY75Gb|zd>FJt`VSTUV&GJE$^L{oO@VZ_c~2!KO|CR{=joN`6ZcqxntQx_foxFU@w2n zqu<-h6nEm=e(=M|MdS6>(SF#<%x3(GuK$aHe6*!GwhdJO4exSE&=pGY1E3nCAvd*-kOSdBJqK}=&y_7og}lr7rT4aI zp+NdRz4e0BpFDkv^CF|`!B~IoM&G1?qVpn?lh=Z9`V87s;L*`ED3n)h%yhIRvSv-J56x)#{RW=q+h)WGvTfm+is3zAN@WXj@&xBRXGT z#BOiPPR`azM#*$j81#}+xRGbEy$1W*?%dXsavfFD@EZT!&tb7O|yTZ)i*g&{N3 z0T$hs4ls}@g3MQVbe}PhHd}}$FE^$bcL6y62V9cFdCq^d@#*8A3O{=?Z6dtI_+d|p z`9dFvIKfh6$AJiSy=VTVsCf`9p{gkVmk={(?K@n0mQFl_Eg_1u!Jig>Ds=p}L&psc z9dz2JacpA_hmmvD>8qZ!PM>lvU0nmwl@K9`Zm@e>;l$dqTFqN(hhpTcwVs z2W_DXXQxg4I_H2u`>e{4F@E&HPu1g_U5|fS)MMqvxE?DnCc0^v^|<9cdMsl}j|ELR zbkJzIDtS{$ypAE}fWr4TZt(qOTUt9d(rPFDT7uriX-6~X_x9q1ydKw=!>@7%Cw=@9 zq2pwCnWpDL=BqSt7`i4H)yFFLVP!l<0~Vq$`KHF1g4y_ePKUSCba0 z1A&8a<&`2 z95Dj-h+<|l2IY!9f2k|BuPe5@FNWDIiT?SAY;C{s#om)WP9@5GF+M7Z9?BJ)=8OHw z75m$8*Qf;r#TNTwj1xBOFVDg9Hf&z(uH*p%axpiZ}QW<(;|J&ywhT1_wV*4Na& zJ7bQ=C=y+}M*GDNztHxJFXTnw{Do>^{IUPF*qf(#aFxCpqF=Z0>j(bzKptei3(WE} zOTck{-@?Sq1y}F{D-%mm_;8s1jNe>#`gR~x8sRvc=!TEY{sUECyqnMNRV1gdp=^oVS!Kr%C>K^Q=2gmBc zaQ9$qJs6<}CGNqy2l1dr50+@)7mj*C54P8X85$ZrHi5epd2?JjeNhmYcjwse>huh2 z8!AzJ(mg?XZy$kQcn5PvxxH?m);?0pispMJc3|u4Wb27@=#SsE>bt6!Y4-VTnB0JX zf5}uZFVn9VjY2+JME05_g<@JYt-x_e(-G_#DLFlOQw}sT$4lhc&l8sR;t!#RO^$} zTF{^5 zOIUhESn>LgG})bW&P!@sRk~s&1%mLTN_52W24IjH2Qws&`yx`At{ACHYFu@?;@7TV z4Fv}=)rw2mM`-WSfp_C5W)2kPH6(sE+Ht1Bc25wRpg@Xj>;)oaU9^dR{@*~{3>eW{ zKZa$_*N4JOrjon1W7-ePVQGA_+x9V5e-Q}!dv>y06P;#>dp6+%d)k)levzk{xAaPN z^)B;0iN{Lep!6Z?xaL{n8Nq0qAG(3LW_d3+6VKifeWjUkR*eKkzof#F-Cq>>y86m4 z9os&}>P~Mn>4WiK`RY;0Zc8KJRr|K~?ELn#lHJEUAj^_Hr*o(0ZT9?Ner1le`UU2r zZI@7KqW#=#l}C?mII;bdFq0+7EFrX~d#4e4gy-Lm8>S z*%V0j{DWWFLRa&{rCd_7_b+O$_g;sjU#y3upB|HsB(vG8r}l@Wvdp{I36PZeub6^C zDu?co2j|xW@=Bsx`mL!n^Sl%%91>)%r_Sj5Z^IQoals_yO>d;IV71Y6FNcKkCc}#M zIoZjQI1=teJ}%D)eR~*f$qWZ)W)-jY6B^ z;VEptpZGpX-a1!Jw_ZNWhlX%|t5tV-G+`GPAVaI09}e5;MUc}o(NMM5e|&#bvA#AP zNqfX;e{`bj7Ro|~1k{>s0G_Ode&Q@@zT5Z2T?+g2x$wDm)6a&_dO`8I@HuXMeD1XK zC*t$DZ*35tM}tokXW>}fO_*5N#hk|-PH_Fpk&I!wH+^oj98FXcw+f^G0emj~;PKDI zpKH(jy!br)y!H6=(VadKpDDH1KYxBId@eoy6Y;r+n)pxQ^P;t%4WB>%=I6!dJ+15E z^O7%qB0fi`z5fe*UNrU-@%hX*`p0KI{Ew=@rw#e<)S*1A)HuegC!A{|6+7*vimWXk zNzOTC((P5zeQD}`ExJHW++4)}r%^w`G67YD|BIS+F`M$NjzmkWt>4BPrb|b>@?7O4Q_)1?tSl8|-)=Q^WK{HYQuBP(J&Ck5-)hXf%Z_HBf10c+J3-mjk z1V=WLk)^~$HCS}MkH#0;kG80Pm^+7GtE4^W-;6?|rupZ(rS zP388ZE$rVX*yDTNaEXd}*nDC8PsHYRXV7B*^0_g4{FM`3$2MY*4_D0_vd2)|@9%NC zqAmUJ@1gmc2&V>@IoVyUa%qO`iQCWd@&vKU#g>&(*FJF)2efN(+-syXjDzGl4X!#6 z@*uo?m3VTEcydkDo07-*y%LsnJn`maxRKl*rgyAWX547bQn*kXQS!b&bMAfb7lhvq z(K&kYezzlglg;&M{c6urg|L0zVVdm)PCy%QQDWJM70IqR;jBq#`)Z1;r9L&jq`W>H zS&|;~r|+PWmbY(KpBhlod!3>lBS~8Aoi4#?ag1dSm5rpwi%+$5VrmmLpH= zC=3_E?fO$0owK*YOpSixF3BkbGiWPYPs2=|&gEp?TkjV&m}?EX9>V24nbDYyh{@9@ zE$L&uq6Z&d+OCO5*j5QkOnn9Ety$o4^*@Cdz*U?He@`H=nrDX;Fru_szswvQO8 zCPz-1(Xm3&%3?yg=*&e*)aoGVMl4$~(_4j*|e%t^&^bC03@+&d_ zil*0FO{my*64_MU$S%<6+)43I$$kf0ZVCe+&~8 z=#YZ<8X_xi zvF&?cq&mjP{r`wD;wR1>QgSo9Rnc{?3p(bKyEiBPbC%*i?SoY-HqJR!K4%qlwZO}* z#>>N_Z(IS+h}xis+JuAN-7y6aDx(%DSQ-7OD$g^a zD)C%Fi)2wRY5OW1*`CC8BLNKJ2JlZKXH>5(Z9h=pDtD#xgW9&2c$6R_Rz7L1f>H`s z)|HJst8KBqq+{7H^$lmD=@O)%rGfG+Q`vqIN&Dskxuth%ag%(3$npg@;6`|uamRXi z$h<>LiOEa$9??WWH0rAmw}v|-?)vntcJbVP^aDt5tRicEQx0QSu1NSQY?GXO;0|@2 zA2+xEBM2`bPWrxHFAmr$BwVQ1T}#n7W0G^rhK=s*Yi@sy)S={*Ur7hC!^O~#>-o#_ z`~@GAa{O^n`na4H78g(Hp@g!C8fDd+<5?X~Pm+-JxXKo{2E}>HVc9l92B={d=IEcN zIai}jNE|NP29~{A;|KN6^nw_t82aqPJh^R(IlKMfc?y}~m+f+dB+oCQ#qc{>j;rvQ z@wqCXDb3n|g*Hhs-~q>f4r(m_A=PA=kd8&C58?<$zp%~Nyjegu68&D;8$#)ZQLpU! za+sVl8$d>lz4Gw=l082&m?{?TiHAU0mS;c7(cSddeHz1j`k^&?e1Ka^U7Uo7qk92b1AJ^ zX;=9pqt3Y|vx*gFVa0uUwH5$tVbE~!lf(F2tNTZdJZ|OcWRDUiXwdLCVp-ecnM3qI znCyKqy8B*p+irK4{oJMR1cYdz3(*$n$BCoSjj&!ezC}Lp5HY(q+_k#HjX`Qr)v&Ro z_F>x)Sf6xhYxnD^y!Yp^coyp4iCFj5d^SObT7R%_4{Prhycg|nE4_mLTvWL*8n0>| zTu*=7c3xepF=P{Pm#L#wwy0Bx^=Uv8xM@VzS=YI=ZCro~ltrYy#2roIdcm!sswS7s zx^RtCv}&S%pCv03n>xUH!MH;0bS>(@&<^T))g0QkwRe^D-b`EAjz%0`wuTK=BW)p- zthV)Lv6)TAQPA=p!oi21Ci}=9kYCuc*eW*bqZTPcK6hHtSx^A~(r@ztuTV3fpD*Nl z&=<{6Szl^(6OEt`o(U?Renrp@THJS6Nv0VLM<0!Y_IJ=JPa(Ak9h~W7SOt7wXd$Dr z_pF58YliL8EqsTFzayJ`qRkKM@m-f)`Zo=|f;4M*(ql^LtPO*JO>TZ%|8Q4t{M)vG ztfk#L6^A9{L8(7^Lj!BSkUxv|SC^&%XAFOI%)%HsmSWAs`@120)CMdXa`47*iS^8) zjk{JAsnN3z-PK0Tgm1-y-VJ~9cu;i-Nb{)b2cGZ2&-5T39|#__R>P1$@Fc32INk=L zv(|$MGE0_X*s68cl7+}%tBoFK5-<;gUiGDT~ z0JU#b7G;I-O(?{d>obi2N&x{6UJqTLihwtvVe`;cDQJF>4^5FinRxkn_&TjYB8uQ| zI_y*9OK5_08$#IHjUeoM4S?8^2jb_$*W&8W#qj5%1oQB<>bTF2uhqwSd_A?_{{+59 z3B><!XuAzW#gP{|S6m2*m$;eC@Hz=i;v<{$?J&I_p0> zzNW?ax?rFG34Fa6Yz$x7{YUe3zSEHm*U@2`1v&0(HVbl^*XIm>a(3ya!C5qF)+E;b zMRv)o5q2r|LS&l$tZ_}&G+Euzc_fPV&WgS)kT| zHNWsSe%zPy=s8^AfwKN>yz7deH=-br6`FYsyw%g;qF|?*h5fvl|J_l5`Aq|}0KSQz z*1rE_hpZrc76@$TWXIeNcVASn`kCo!LKoG)t63lSWb=S?H z5;obbt5Fw~PDT|P8`usT6+b^g8Y4Vw zyh4|pg!Y(e=g$Y}Q~1b@mackwGLrf14x9v-5BQSq_Ntk$htkdE_81JMD4@CEKO1s1sBH5727bi@*LN$ho``*oq zx{}q-v$%}D($JWGx}mXdqF*$*z$-K|4Ur{OQ;`0OM!s!q=*S+GPcg5RIZr4~4?5#1 z4Lb*q`v=3$Gwe}}eZMtVmLdJw0*WDb4_QTfx~>rboSPUEadY3*=%o*ed#6tnwT|qQ z#Eag27g7{s67Q5pclgiDior_LTni{RoBCo0lAZEadJnRy95jwygcP{dAw@UQ)h7ul zh7Zhh=I>ILDPr%7h5L@^neRa4)SAqf2t(VpT<%r332!vdy(PIaW4noJ->$fTWGuQS zS3p_FmV)UJ7+qqomWcnw&Y7d_y-gt6P82p(X#=@9oaZ8fo_A(h-wv8tjmH^--!L!dKLn1S0H1!Ci1Z&A zK<>T&fW$)H=olKyd0)}I!;t>|&bv!a-a^dYmA{@+*h0lQ4V3MpG=TG#3=Z!j(HJc1 zL%95?js}0NQ20f zU0>G!>1CaMGX!o_<$w=H;~6LF)(^)I69{&6*}}&sdZ)6GtmO$w{Xr-H9jX5|Ixm_& z3Q9eXY-Ga$Mf5rdTvdu*u#*1J7ziNVw7d;_WE&djaTgImgXo{VoDSL>9YVdmzqLwp z^bf(P#L(6&FW3suC#~)iIk2Z|bj6<9716QnJ<})DkzhZZ&BDnxx~NvmR=dB>ceVgE zy>)$8-zLdvd-32XvXn=6ey~rnXR!NqLaF;%#!oBOeH)>pdD09G+Oc#b&&Q@7tRFgm zY-(Y4%h379hh^ns)yl63>l~e&JEVMc=SS=>b`w9j8J1-D#7~ z4@YU5?{dPy&N1Bm<@@=BA9p^zTbIjE7Lyj?n8jdP? zTn2e0e1w#$Fr*{a7ezj4qdIRowdW+E9C|h??K;^r!hR~&gvoD7@3iHl4_nTf(ArMj zBp!e{qwh=7m+8bhnU8eE8ZJ6e$5by`sM3mcn=Y1JHfl~0H~= zW~tG1Wtw+;y3Kd-I?$Y)F!Af7WBVCfS?QijI7QyGp?MwCyie5aPK3$>7F+uG8kr3~ zlPFd0CNjW<&WREy^HiRY*$rvylISr%M-SIAX8P2fqp(9bj(fq)GFVEQUAapE}?32kE5I;lxR;`+&TIPSiSZq?~e?T91n45|< z>cT@COTKg<9&ps>T zGw)}KgwYl2eWun-+vy7BokPLZ|F$kt?L7ZGW@9+x@)z?tV^{T<#vB|mXMlUh8M=vn z<9Ay7teoMcM>z{V-{1#s?pJJy|NF3HmcFL_xEROK+rO%4zlVe=pK0);qs;T&H)onQ z_xxGvsbKO~EO+2VycoTv{K8!lOSG-M5(8)p29%n&1K9z7ubQ@pC z1u`S;rNQgHFb8tCd3hd~HNsw)SbaoJidX58(Q@vZVivIC(8?UXLMdL?o=+>c|D5+h zsjNRK-dy`)0F$}I!*f#H?N!vY{#6uX9A|h=fyn3AvKIwrdu8&SU~lf!!?x5mbGTLFj6w7@ zWs<%kJ%H;G&litIbQv}-lTs+x>89_ZjP&Ce{kYSZSiXuTgAnItbGjs(NUcwy=`;-M z5LI>Gido`Icbhr7v6tYbzS^p^?`OKf7nPaRSNb<5^;P_k)Yqf9oY(G2Jf9bm`epvQ zN?(PEwRJJcE!oUXR03|-Ib z>dyaibG*)#h0jKq%daz)m6KAbQN|-Im#(b zQ=1CHmmc)1!{{x(zT!_mHVLo*=jhtrgj8OwoQde?Al7uG9#!e<%I^8?FKbZJ=(TYrmWad+U|+BhHMbUE&s#)Uqu#S`>w6u3VfhVR(`~ zCb(M7IH$(v@?EVIQ0+Dnq_*>;-*4VzI61VIH(FNha3X+|oK?kYW71=b##eRV27va) z)!~17)RjNqrIf6~irYuoB*j2@chd#8!mq@+DA1+6Sk48Xe``rJP${vQ=+XVS{9*(6 zpSWvb{evFAN;^o{xXo7=rB%VwYz4XTn(g25h@)S%#(-5C1M(-)bnMlD!~pd2fpLu1 z5htijSM-h)32h5H4qQ|O#&1Dasb9nS72p}R->cLlh&eJ_MOe{UF41I;=8jw)mT6S! z>L3wCBWXxc1uED!#w~rVj5a45HDEti!gn7v>2@tEG2P3W=pXiEiS23<-MBB*se*2C zhYR{Uaa8fPrijwMO<6KtkMcUd}1=ogd>)( zi+;CKs!qUnSrSg-<39l!{{PcN8jb|p(O0LLaO}Jf=vO>Gi;)~Y!ZGprbzgG9_DHx% z-8E#DuA#r00ApRf0_)T}?5W&GjyW|u8xFc~xVlb+{rJB-6(4s!j$-+#urM)eKwh+! zX3Zh6NsEh#2i4m>{$ zTDw*ih?_-NvsK}sAMc|6YmJUfw58i|Qwzz~MZ@lPyK$SXuFC>Novp4;?u^?i9b6#4 zI+}1m-r@_eVoFN?% zfQ{*fo4?*6ZaccolhZiR8<%jKR9*=;?lTh(Qbb&<`sRW8ke}wcD2v4 z@%>xQy^FWGqs(dCi4vfgDCGvP4&|{YRBeW5A%deI$tqQzJv?yGqCZG-2LE$MH3em@#i|oDI$z7PEol0DrJ*=1^qcgFh<|{KW@)@Nayz7<^aEhq%MUas7es z%JdI@`tZ*I{_VB-;JX2D+;P(}UMR=!0?8;+745qx`t}Y+0Ln93#1cM($I?&d+@R}x_W!IKw4GK7D#(_J-#m5PL+6o2iUpUO4Vdv zNnO~#>zshKZkF3Wz=bevlqN+Lo&CNx^qD~os7MX0rv{~hco^L87%+_5*^ z;e1Uyb<}?%*Hg({eYmZ1*nIrvx*Vgr7^>8(ELpTQ)At$*RQ0YPBNm^}JL8&Hsf=1H z6=9XnUc=liQsPV7W#!pFOL$LZ=99A^Q553|prxXhiRhr(yztz6<^ z`v#%-#(LkVDSb1~zVR`;uK94cHJ6wkf4YbN6t)o=_+-9)>TR!)kB0^-KkBk}H%$C& z@hsZF^2(kK*H>X21BwlT1zmVut()lL5zZjMXy&}FzrJ#nYRQ^p@$`oAN)%Mc?Bo+& zXXsPt0WuT!?&^(Nurg0f>77MR75XE@utp!`q2!YIqk%;q6}hf4O02;cB^Ig)6L(vf z%cJB=Y5?AARlCj+f&DB_p~W~Q(RYRy7)a3Er}y|hC1S2(7bPoV>BJJ7yQS7>vkEtt zp;KwRD)3zsA7jYsjF}mN!#z_IRuG%K&30w84#rIj-}T z%Wcds2BR1zo-9{1%6Ho(37AJ5cN_6>-PTQX!6Bci+n!XJA7Ia;ld6&Q-MCwCJZEE; z!hAk}ZA#7!ww0EgDG<^@E7*Yg*LLcs^C#q&!#8jTlJxCz74rdH^rhd?X1Ep&gUL(e z=#J|MQrD;g&M#>lldia6pWRB2Vrcqhl8B7f&8oRY`hcHy^52{xDlcW~GW|FLC3=*c zPquT4(Z>6Dq*)oQvh?E(fYEz>)VK?1_^`ly=GjkpZjGDlwRwq2tDS7z<)+3M&rPK* zTRO&q+$|ayuBRTffVm%^(#JS59xv-;{!CI{0OX+_NRX2oYiMyV9S>x%;6H5~?NB%B zBjx;$=u39@Qi~?UdVZ-J-ZnLaM{{B@f%UPRM*^C?#Dxb=q^>ovXTutz09);?_{PXJ zpqh2tJFUqaVI~6TS45YS>WR;h*-wwcMB_)7Ifl#zd=&;D{PUXqPHwYmmNP}>>o;;M1f$1g?WvwPa}np2bDDB@ zk9cWa9RsruHo0VC5FYWd)~t3t47ni6mLHF-Xg`&w9P7hV?fcLA*D+hJ8{OHrW&5bb z6kro%KiWqO=c_ijafw~;cP+3b8ucFC$%SV|OEQ%=LM~oH;~wWhrWKNNeyF><|+*vxfoyz9k>IzKM=p&f9 z%$B^1#$0G4&{6JkySv=vE`8er^E+--Uof7Zcm(57L~88oe zK@)81Q-HPS3Z4o*(d|BY1B^9jNSkjE%EdG4(3tcwWlY`U5fH}U`}Scr`+qgR8p0zv zBaYo{&HxI@+s-C$$({~gj<)GFUbl54$JetUqJc8pB<=uXnqOHz1S} zpN90fYU!DPy+i|kQ+C4-tDu|r&+)kz|Y<0sO~qCJ$sT^tj_f;*NQ3BgR`x3 zdpTDNFP_%5T014N!;0dAayupe+t{pe9-~q zMYJVDaVI6}!vVvBl|ViBvZ5oo*?1el6I&r}8Xjp@Xw-JBu)wKt@y zls9#RU0YZ}+e`u?hT%N^UyN_a*MKzrW9$_g7>zf&xgk}?mN9<+$bgKT+ zW!jI#5DVu_`2ZFOhBAHV&wLxoF~ILP-nIMxWNdS zc@4jbHT&%A;2!8}6|fAi@d6JN*6INWtI;)mGCJTqdVf)!k9^>UimpT*%Z31NNp#iV zyr5^b`e8Urp8^)I zIpU#9&lsEDY3*1%jw$mfP(NZ}a>_lrNqrP7c)e_F>cz1`pMq@AUIso*5wL0~v02{GaoSv~WN#SRF!VXVY}a!imJX!eYKu~uYmwp5}ymg{Gj6tjmF3oBJI zqL|ecY8v%%35N9>TL9t1#A?6d8f|8 zoTje4K0^Td)VCN=2xL{#sFaF?ayE@-&aj-(nO*_K4mGO1l08+bc8i`n*txD!nU`{= z@J8Cm{LM1i{cML0QGAkf?d-s7xtl|m2!E}nY3Jz$AXJJ>sr*)>2*a;tK)z4k2`g?r zQ;f=l`y=lZGipxItAiAAMf!WK`kiX3WW4ay?PB1A7U_~|tx6xX=n(nMk6gd5=9?+7_M@_a?~jS=GAH6$TIQqzk)OD{W?Xg99x!^y69IU8CX8cv7s z5Vyob+_HU7a~Xo6Sil>+m3b~XWuc17%r6O2&t;}#+}Xb5`S|1Bw=s14j_&;TZpof% z8UA$-*QcJ&rD$^s|y;z_6&@3z!;hQ~KudUx~vBu0H<-qaDHnjm~tjXaY zfzmHe_16x}Q9U{B0W*|JEfG;)XWmWH(VVAbv4#giFf@|!+{Jb1*2aeL*gDxd@ma%& z#mOn#Qjgu-N)=h@!-kp)2?roR&Ke4O=jYN+Wpq@Xpo!Bf3$3A9NVA6febHINA0BF=fjQ##|!Gg8ywzEL$%wQ;eOWLQ-Y67&O z<{Qj5{u(c*LK|_C+bWF!7Ha z3p6H9knjqrG-CMo3;EHTV#U^&9`wQvrr0=d?#McwT`z^^`sVg@_Zlo3gOccdDOPsr zZALtp?7mBeoYICZnYgRW@n}R|9!z%4+{$%UsP!YNEt5Uprihan3~l!edv|iBeD2>E zU*+5Yg}ZQCFCSuYFFd2gWryr0k&?c%vJSPGC#Czt#H%~Rc(_D#i`@s?CMkM%Ig}gXL#-Rm`^7~%QZMN-H-OOkDT^<_h!?6f7ivd-vIhSdQ&w% z$;P$ciPxb0CRnzjX}>e251jVfplf;gm*i&#sf(KBR`%!MWp=b0=UA$|S~x1Y<^Wk=vN5lbhPLKd`Ixa` zOKC&uoaS+@0=1bn_e$nbf%yct1Yje-C*CN(7dHl$r+1U%}MsurWp>1OA< zfg8aU?YTerp1Yp6Q_15@vpfbmvPK;vP3Q{+Qi^sJ^j=$yTOn`9934Bm+ANUeJI21g zuO|zmGd-Di(XRq|?k)8_=Qj&e(PEN7ZAUf1?m6l0fiWj3#wXP(Umi}9 z2qd172wWmJ-Ubd9Vv0G!S3w^fqdP9hd~C|XA(08ON(FKrwax}D82M(5Jmc(EKh~~e zto_90#JQvpJ4_*x(%Em9HdB}IoSNxMPA4XYmBk&%=|nT!8j*~7`V(Y$_iZ<<6TJb~ zhFwCX+KsxD>B)%1g<359w7b1`-bIjdQMwjqsbIcV-Bm`1zL#gNrV1Tl#rr3DbG38y zDV%lt$eF97uQzjbh%RQXPT%HJnyXu9V6Oi7rVwf7Y7Uv2&RnJP<3DJa{U26BGCCz{ zy;9>0+#pF1qq@^1P(I`o;{o(YXyjyd(m9J-DS%FZLy;-P1EPPDy3~&yEVGmelCgTD`h(fRCzWZu8{{DXKi-oRZ8{@v};M zMj(lO{dg9Ca~}6%Y$#!KK6AV~Q5ZFIX4Q%9;=6=ciS2g(%!+OMe(U#Im8yf%_UfS6 zM0m*jgB7v?Q+Sbj$v;1Zx5mnNU4=fel?O2{`K>jU#bJq~hRx4RR&~5@()ak;jdu0R z_Rv4GXhNb9*z7*gu$cLwCK^Y7H>M>-Y4>C;H<9{c$TkoV%sYPr8nH%Zbr^{ZZl~UFr(`af$vo z4x~m=}h@$4nwI8>ngY=0K>^Y;Av&t&w%_DcqsvSE^{_)MnJt3Uu-~rKYW*M z#f>-{vAeu*1=Qb#2J!Y$2y&vE2p`iAF?n^UpL`zXrsevdq7-6B#vV)%VHZLTKcOcM zA`MvLxm45uq2C;YerpcI9v<93yrpI)H{G6fcz5Tq|K8zM_R{FYuk1uVt|(b$Oj zU7qS9v5d1X7fHIS*aB8Xc!{O*xnj2`{QhL%`<^9>x4`rWm;l()Dp4T~K{zat5S{WL zpaw{5Vh7kHmrZU1fFv!J?na>#uI4(YLS3aU*Evg82b>{dQ5emGJuE{?Hwa%tzWkPM zf=+PP-Vf6a?37WBg!oYhc~$;#!Jj`ijf$TW))9L3`~WV zr4Da2%tk2CVptPOsKN-H+IOLc4^*3MvT`d;hW+s%a27#ROAWk2>3psl;dmJ#ln?`y zNH96D^Y-8gozP1%~uXP*~89J!a07Lv9hqZQ#SIY{is3-`X;9%I4R^I z)~)8-IszL4uwfWR@v;rIeltfShi0iLD2nouRA|eqnVZ3i!ywIeu@|2ndIl!Sl&Hg+ zGPD=#C~bl}4%ujWS_}em9Re@!HoE@D^N*Ah%6UbCT~!uh#CNA_6pk?r0r^uiPkYx+ zZEB54qkscmqlQjiw|Cr|Qs}j*?xq$_L#Vx*ID_G=MOI6*ul#KZ9hV@Ustf+56M+3l z6NV8=fdgRWj1wqA8H|~Ip{8#FO*TR!4NcPMA%0kTzWlD)8S>>1JeQ8ZLf`r<=F9s& zcz=t^dJ_5a=P7K6dUW-YEh-y#DvttM@h4AzTq?Ow4y6tNX5Ebxd`;NcG&Fx_aJbSM@_!{qN&- z@5$;pQvFC%eJ08vaew12(tGK5_u&_KKn=qJc$RuJz4}Wi8TWmg!`^ZBcPw{?uDWVt zde47Iull4^eNk5hCbtM<$Sfr|l)_5oqU-i}=la=1Ms$DyU4s+4 zANE17LSXoLPm>Ri>lsTmw30|35+hZNol_V<%#cI zvby#_4yb`y=jIfzuH8e%hWIe#$}hsr;=J&eCueWO{|%Y-e>hAKZ~)M>7#L#;Nkyc~ z{%_tlJA3>sqHk*dRU{F8r?>2Vvr}M;sNj<*7*6gDvH>YTQGj*ieY1Z+flT+!e)KT3 zC!V{MA9CO9NxEPmT$a4leY5A^HzV!7*(Z^xnd!dS+syNaV4v3Sb6=LKXGZ7$)_t@4 zw7CZkSi3Cs;2zqhah>)5zi-x$?Hq@`>n0MWcv))f?wN?R&HHAT&ULpWOZdhdNAPjf}$Utku0o;rv(<*w1QAQ-7~ z+R%!W#~}w_Ww>VgC3yi<<(laSp+s#r8MQBbzk}M}@!vjfwU6d=L>9FVX|=CG0k_&? zh~PETxgT>IT-^7G?1tkt)2Hf!DYbWem3MO|>t?w1y=Cen*G#|AE0fw6t9#9Js{Q7@ zp!SpTAgT7no@=Hx@iJaB{WM2nQoZwQri-yJfgDH;3r=3&*E`7JlYw-J7Ir3z*#o3W z|M~+k>v+v{v0N$rKf7kS*n7>iG?{kIbStN?yofr}HPa87ms`DNniJrR*Gw0;KiPpu zzwtQLqV`R@W+GBb?L*0Hrak2T>uVjzJs@LC*>YcrkXv6feazQT`w7UzarrjiqC8xrkf8F33?bHbZCnIQA3SNNmzMHt@hRcwJ?0 z9$lJGBXkwsn7u+Vh!y9QXiRqI1^Gpl?xN3~$Pe>9gs4Dz5#?yqS)Cvc^4kNt9HdUB zz#tT!`_&b@XA6J8Hc*5!1GL1*4D0|VVCKR=L|KL=8Hh+&lrY4P{rEPFm)P3ev;^*j z5T9)#gY#{^V0=UMdOx}J6KH&h#T=jSc+EmV2Q8r~b3$8Ct$tZAH5O<%0Z$<>Ak}g2 z_Jf;qaI&1v(<^Og#a0loxO7V!mQ2Di0%Ga;8)w4jt+X9S%Y3R3)dtRaPY$FQ)m7ywjQQJ~%wnwX_yFp3uhL_~LySkR?}h^U$o1OOC{=ZM9E5LGeQmu>;Q_eY_`MpF`p1)!()=fYM;K#`y3yD1`m({NuVisWdDd|XG<0?l`nMjSuB^rV z#sQ|OpDEnH`5!&tA$*f^Od7RCN%|&@I&V7-3$^D-vd(+e7Z?mT;W$z2KLLrmp^`Mm zdj7gI5OvL8Q{$zazj6%umBHtW`{6e7L`^4e$=6Xdmt+hVr5<}uj~H-xWFP@C&Y*K8 zt9r1OA%FiZ?K!1Pjll+s%aHDzbHd4(F`pW7e8(X$GWZn=FXf)&4>_wl9WP zS+^jBFXdv4wa3~xzI&dfsFSA*MFMAziBrtOLO!IZWT`h~gPl07a6?$5g5wZaT18WX zt4`HnAtC&~*MjiRLIo`0&1Z_f&XB%~v@^1wc1C8iTR0;UyoNI(pWt(=JlC$oBKb~0 z9p4EvHPETknbaE>xm=1ujCz5_koW3BH?u5P&!N=%jj5buP5&oZde%Pb*K>d5R>Q}uHSRGFQ@L*$wBC71PZe& z6BR2;VVMKYAQ{fNy|?xZb2NHU?J39>Il2F0?9K_7yd7xx8yXtY++*+I*mQTd$wA?2 zEmI-a%BR^S1-%eD)-ND==d*{}eNC$vbJ6NxNxI;+pGV|vck}j?nkgXHx+~0xJ8FK1 z5w~@n9&sN<%NQY_>XsaFi}i^601B897nd~4o@p6z15;(h&EkiQxMOrdj=0B2EK?f~ zL)B{Su)ucImBu!K3K1u-rWwOA>6%zaJ1bW_sJVXHs}I{-Jp*!uddxg;1VTPQss1bv z+7e|jGBp_X49Xaic}uB~!9K&FTyLHQn)ud~#jrdVzY?qPCxTH!n?%QV(u@xBwdiNP zF-roQ{Uw2uT^I}55lO*|eq==gdn9$n=k`|M(Qko9u0Ekg&bXnqd!8KMZLl5Gb2TP8 z$)_@Wb4+FFK+`V7Ps;0oohkGQPBv=BqJXbH`wI5j{)C&pJ?FUTD}#LHe>2e+gS^pC zQB9W+x#;@|5Z+cfQBX322OqjYx#3ASC}K)J`A;TLwu{v}8~34%2B;H|lc4NRxRU{n zwDbwb_rZYiurn}vPGjFFwG&nb>$!L6>1mKXz*O0LY4qJS#)_OB_hl0WhlTvU1^B>&Fe1W zGH7M$P9=;02{r6|Um{QT%#Kv69IEv2c-uT1*;2PiWb5M9py3<{j(bQ>qo>IyKtENG zLC}*3FM5X8)?&4Ogn)6Nv=H#`x2 zz!*pY^*uQ(8I>{_V&JCaGnx2Vfe=AlN)y_`Yk0e6ZybJvRNh4-5W#KWee0Z$El=bk;VtXy-hfqiYIYOZg7j!})4S{ON z79u5T=ywa9u9YWk3C_J$-w#12p1R={9(+%epKsW?S05c;_;_uNRN%FwcvF0x+^a9A z;3K2|`&Z2y@S5hiJh0nPe?0fXzkyE3rkE@^b<=rh0IphO2Vd%lHtbo-%;obus)7_@ z4OKKB(&ffYFPK~#)`Frb<`a+(;ECD6mDF8zb{3ZD&u*2A$5i(ZK$-6?Wzy)8)zLmV zzT)EyJ+{1(Mvn_GGxYeoedDFaXyrcfGv-e4WCylD0g;Sgx}TSf??EQwCbjWs~L z$@lH+c9>&vy!5N3uyw4M&oM4Y$Gn&?LMXlIFC4C6a~QIOj}5C&dB9seg8-}a`C|N{ z_Gs6W0#HekB(0*RGWN6~SKW!-LBLZqBMrZY*k*^EH<%NE0VqK?0=?InHoT{S?qMRK z4_vxNkb!`6z_yb}fK&rr$Mo+v)D>WkIX~ynxkr9Z`C!zln;}yLIbxFKTHq(Of5kzk zLQm*ZuTFjsNQ9{Rj&Jw%Znwq{3^LA-K|H1BZx2$)>(^;fnxV%&$9#fwEu?`UY_<)9 zDY#GK5{;YCS8xNC*qUN+L;jkKMVKeSklElxgi?`erOaMt0|py>lc)K?x)gmHMaLkf z!+O%|f8$y_3`IeGm=ejlql`e)qXZV5fm|4lJHBtOd_W^W!8wuzfII40!4X-)JAE+l zl7w4u1T3pRb}l=`Y|u0`s$W3TVbqcku#BbWV;<`G0Hx+X|P**|_15yKYq z12UBwxkGB_Gz^V{^A}`}wl}ErmI29wlSroF_cWXIjz^BK`DHU+k9a;QPPE++XIKH) z7kmMTvc8vE%S$f%rWm}{MLibN7|~j}t(>|6T5ANMgD(<)2lyP<89s9};WK-d!DqsA zJA#iJ518pGW|AXobg9Kja3+O^m~QQZGMx7A9ZA);o0ePSsv zH(B22#2@mNf|?*$?;QqYQJCo{5C*6C&>)J3$^`T))DMr;RA9R$5ZCl z4}$C!aPF1QxmP|r1VoT{OukNfMFT5C7sh+>O2naM$p)s}PeAwWPiw_Bf79r7ua*al zZdK4B^Z|Cs$fx}gU`~JJ!>e6g0SX4MvEI6`Asnox3{qH?APJBwyP#Mmw1vR-k4vHg zFUQD2-JHKMebAK_tS2XQ)QzauvH2wtb`dZQ{*@Yj42D%O-hjW1@Pknr{z~bPkD!>O zxZ}IwIrrd1>f_)a}w4F53vobKgl!+xiOP33}5w z;G2uyG9XYf@eW8sqSRByc85~lWfidD;H#Fu1<0;+NqYzTb}Q-S9d8|9zJ+n_Q`-$A zAp%1r-^9QM9;8MqfNb3mLjAq5#{#t;-jh)GBGhLXs6FyBW+Y%OqP)Tq@DCV=7PP!V zj%iyyx?`z(f@bG5#o-uM{zSa#1w%j!K_eV@_|!r$@$RI6LV54`+jh-QwrNja(|`yg zA+=;104QeP#-1L)r%|Mrj6l_!F48^sq@}QkN zUyt^4=_p|JYunG4pSJch_a?EQ6BhvE4EFP;G~EHUKqxUoK3s>#3R1E#Ay$_*(_=+= zGgHgr3d@65g`z%0*95Z562+Rz}z2hTZ=gY+%EMbybO|_y_hVVN`Jl>ngq8`ZX-EX57e zAA8J&)Sd=6AvrY57l1e7Aa{OEF7VAb-$}{$-dmUN7E;WWaC45#Fg%ia+%1$;%L9}) zf-Ry7@jZj$E6IyYwTxH$P5cv_fG{B$r&rh+FCzlz1i6*8P2_DbTd8DYz^Sas46s0lHolZpIp)08WHXu_M? zpcIoPAsTaSyG&RhO$XH4eMI1%m;-1R7)kTkM{~cxnOc5yTQjsGI_5KJ6SaNRrb64t zpACSn{Gss!T(~k_BhVNH5rnnCjaK!v$sMd};r_N3$_Q=+Bmx$=^4=L{ttxBdbx=)? zYa)P95<@WgLm@I0_7$S4t!jDu-sEIuDUynrM8q}C?^r0zbYdtlj`R3w+)Xs8kXOm8 z>l)@2*OV!A?^o56Gul%qMGdG=d%7o)LsJ!~gbP>~*EmM5TSc6vnDejfp;m^b$>Zj& z_hUmr)AVwZ<2&mwHgIi=0DVDca|f*_k!6W@S{A4!#T`6_V9J zv#b?m_rF*tz4B^t(m$UKVs0Z|o-zMG-C{yu%cm1OS#KY*5JnCAXtyu_peIXrl7DdM zVM(X@m**ecaRPZ}egCxlgF+;sGA+&IAM}!+CjVgR%OJ`Q<{zwb3_a%Fo217vZ)$q9 ziTa4=A^8~EA5G6c=*rTa=O65K=(b2g`K%+S;bx?wIz`Db7;hlC*1kiQ)%Alqp^z3d z)#Y;`k}LnUlz%XLx}nE}yVL0LbD5#X<@Sx29?Rxwdi;MO|KRyg zK^MtCsC*IMI^-WXL;AMp_3P8M|FD*-6PuwAaD@M`N>r&)9~w?qAdls6Rsr(s=0;J} zjI$hUgX)C_*RWnm(~ZGALcf#Ia}4X4WQ~>ZaoCx#mh&TPyxyWohh;Ec%C8@x0BgVhp;L#(HG6Ka81%y5SQz{P$4DD+NpKtueMs z_k+j;)%<5xFj=6gut`$_g+to(L-&K~;hQx%Km@l>1PfuebJ;BEeW-8M;fA*mtv^S6 z@M1ZV94C4I%vZqRr*XAr=2%1bUAs9>UfKR67e*XRZ8W*gH%=BQpRb}vY2p-^H2iXQ zUW9uWuRk;1y9=<^b0KHoGNe-AGO(OwazmG@`xx>vS|&gCQs|DC42pErFQCxO$Jt3= z!AVd@?IvDBq5k;pIW#lH?L4HKtVK9JLr-TRe|laxMREliv*URq=Q8g7 z3VUo?8EBd%(r9xy>-jkRR(&%*_zxFgV5&$%27~4mxF^9~EpU0e?q?_nCPC0lLP}75 zfcpU3cQp?nW{*PfC=TV~5+5!-bBuwEfzo9-{nJmWfXN3#hEV8vTvC6!rFg+@dtlKb zf(7YTVX4n7EtG{sh%?9u0oVhl7AI%_$@rykY=`>ez0ZCF5{lbSt`afExYlSAD8d!& zACTt`=}k;91B1*%LfIt%%2z$YguG+*ySw z#^*v+@qw^}ooo>Tt|6GWuZ6(s2wQ|Kv&Dn@!v(_TxI$jZ^{@nkI<^qa&;ltUi2QD- z2a#mAr@AUxL?o(A?4LQog~)D#NG&$~X(ST+nxIsfn#j~pCWp&AbpwCqivlcCSMo7q5&Hnr_E<9L;h7JN;rV9%aO`jd0`Ol18!`=1 zoJ`@5=ic%fRrpoTaU@L(U7?qo^_&Ma8W#BFn6Lu%Z{%CHx2vb0#>ZC9H#?jfkzxHI z4$a{17oR9nFS%;{Tl5;3Rqp3u@*fC!QD7mz#CwI~Gif=(&g>{ZN;cHOST@U}cvK#N z3__4%Y!t!8MzU1iV}({Zp-?XzkH6(TQm>F(LHPytfVE1NjK!T1c6owB8T1TEpViox zm83SEcHPCyF`^sOX2G(L*SX_g$DshqUQyN;N79j((J%Q6dnFfK=5v#Go zsxmQ5e%M~|mR`0xe+C5YWqdOnWdGAF?zR03F9Tyd98;l1K z;RAM|F7q`YJ&4~50B&Gbs166Mty-u9;~+Z$s9!*c=9`CLu{m{6cH&<6cu)}<8+wd`amb=!BS%0P{NkrqP`5Cm4mD!+{WveD&jQVEo2q^-Mjedm`{kV_#O0j8Gl43 zP4iE`v-J&ZntU8210-8F3 zCPPg1h`Ba&hqj8iX+h(4&muwZwiWzK2C-nNqAP+pU-AaP~^vHvWpZ=x`y4lA4tYj;=F0#Sy$+T92C!+j=8M$ej z0*(FX-=PqcDGZw8O4WF2Aw_x1yOej~8yc9Vql>s?qVXU~8k!fXqb5{WqT9(fLZ*!z z(*~*=tq2iyGb;Rrl+DD09em1=DQ1L>Euu#|#z^`Qyh`@UJG&2r}RttaI zNNB8w@WB$wuinPexADN}+G(Q7&Rf#jut3OHK;6_Vu;eo`!)mM8i}inuYQZEG(20fZ zUs-dQ2TVILvbRR0gW1@3EgJ-l6h2K=!7LpkmsC|y23n;ark+xXv0R)FG&8CR?3ipP zzxvIEnvwZN5+uEan(p|Po#J9gA2x?-)t#Auy^Z=6vY{dml3VA63O)=KdkUiOQZW)8 z)Qwt2@p`Kr#@nAM_?`L>;1?;PrOhavh@2=L4oy!w1m+Y6DCOhC7eRm#$cd_s=kEKQ zBuiDo-2{SDv@pfOl?y|4_7s4btl{<$5Oia=EqJb~kY38g$K`H7AXTmu0>h^;DF4PY z(IlUWNpQc4pYK(;A$s_Oci9R_{w&}s+K$m zDf+uL)G7Nc>kI$=AIQhWyxRogsEu+rw&aqJ)50uj9%66XgQ40gE@-O1ESA4{QHzl)bw&0fhZe7$4H%)GyF|mu+n%>A(xte_+*MU zM$I2CPp3_ik0;%hfi`%XSzAgbH$2VuTWbH`ouaT@zd2t)2eF6;*M z>ep3L31Tzk#uvK06`~Z4=Gq_9Y>K%GNL+Q~@=66pI&SCPDj-Gy0WTv-^GVW5j-A!g z4DMM)tOu@p@0YvN5vJ>xblv;zujx||m_?Syvv_;XG9SSqsZ)+pK0{^A(k&a~F;nuR zhW?{(0g%$&b4+;qOs`<;-bfsMQHmW18_jJi*70l9ce>!roXcEh>_DQ0 z_6d1P1K@w_fsS8P%u6()ETu7c^ArA)h;97>N;C2TR>)afh9p5eBS{Ka)Hw-U1QIZ& zeIJWzCjWFsI+Iz2gq7)DJZUs=D)6JG&RZSoNb{&uDBbwhwz>pkXM>||*9r#2)a3xb z^c)34rd*5{8No<=0Xr8a2si|~j2dz%+h;_Fu>}UOsG-&J@K1~6XKV#O5D;%{=ND*P zg-jj{J=WtP>5(N!3N3o)3tk9Be>*Cjw=7QHZsMoVqM;SmRMT+nBT>ABqP*Opo^F1M zK1dJs%2|#L02p2Q{b3XXON|5AzGMAMS{3*eg_cG|{G#4{2FLGnl4t}Vo$>M9vk&8p zG%tJ-?ta=y0vMJ!BMY&ZLbpB8D6EPPF0_E`-PO#}0iB=*g^(E+JOwqbkQ6bI@3oKW z$oKLjF=B{(C%Y&@lpo{6wYc+pa8U#|jFgsqH{sB*b3HanTw9Ffx;61*?_(1`U}6%> zS+g)ymYq0?LAbq;WZJ$y0{Ib_!SNluYm-pc%#|g2U&HJAVCB>~SJGR*>_VSxW>QuC0%kTowMl*nzg&F*gis<21XpqtH zb1fwQo7o6N4f^opggnFEh}H>(&aiI|7^Oyp)CsR z9AQfnELD6b$npY$vzXVU`J=l+GU0Dj)8Bv-%|D1P@2XC@X_fGns%1T+1udu(TOnH?Q_+ek z$szT|T8h(MXvc^XE)tQKf<)pJ5lk*|V$pRcRF=1iqvWw2NQPia1OS=^L@26=5G@Qc zEgy_(wQ*QTglFFonsC6@1jk^CXcHaZO^0_78!=RwWv0v1o}nAkH(MYuP61p+jlAl9 z2c+e%)ZE6|!Ma2~P(LUM6PWJRbz%ZNunA26ur{;8#e^Oc(25!fz6tP!}g zVgs&_z^T4rFxvi9f0_nr-|Cus^Q))-z{D>JbHh3aXceb%`~zA>1rr$ZBQcXB1OS7c z8iZC}#nZxnfksVzS=i&6I^ZoMS-HB(ARfs(?|~FE@RFK*>+p1DRIpa1K{`i92+g=K zScsRId2#j(@`AuOEU1IH@aik7YERJTI-XE-u)KIao;`>MLe)MIm^CadUK`R%1<_TElVKuNkBnLOResbr7sBZkEAX+;H z&iv#qlhIl-j>}ophZz6OYHrOyOHfcY6bd(N_SGH~_t$S0WN>bL2*~KWD=NrBO&lyN zeS`o11RTc<$~*jm#=xXeu&jgDJblL@fk{UK0zpele=5jRF5^c3|i6U%l!gP_4?iSd>?wtn$+rN``M{BUz$1Zf{bJuRC~h>H(~Vw{3kXg z?*KgWeu;?8|`n-k;xo zOyG^OEu#W~#?1)4N|8X*k-EXP#D~iXzh{HJ*dUv*@IF}b`pdNuz_iKJ&U0*M&A6&% zwL!d_ZpnNPA1}M+LL4Q%9A5!%nxJQx4+747zHV58 zxgrk^?LRoWsiO8vZc~`_ES}-g*Kog|aqDq-;%~dltTc*01G?cP2cH3i$87x{^rzP&r#%( zYp$u%*LraB8U;}}ag#owV-P2GEs~ym2V9KX zNkFKq_DA5D5teZKy)xjuQ*#wQyVhRJinXX&J2LR{$Q<0McHA+wyP@i|KbZSYT#_OI-Z8{SJ3?>`{G& z41tWzg=nC_D8r92XkA^GSjhV({-8hpt>oA1F<6q>$=eq@*b|=B3VQ;drwX1l{5hx) z9capEIJ=E{h?Cvl4cvMz3sU1{_KDZffs`zrex4h4in`k4AIRr4vJ|-Gdpy$Gjz_3U zS2dZ!;N)I)HtW-6PI_2he(J9O4C|vtA#Uy(hXfF6GVbu2BrzIh2bC-dO!`y`$@UdF zl8W(&e(zG{Hm(l0ZHCoZ5_Wp*!H%j4OdTDlA{Y;xHUY5EVq0L+ZES>x+9PjpQd3%s z^tJn~;Cj}^RpGWx#*U#y%>LP|r$s>9{umnuzB1ag3w%p0M0&b6rC_`>6j0N?5`H@R zW1{}}Y!bM8D43s`w50rXr?GDx)nDS(VfyX$>-^+mY=(|rIpz}+7zx!e`g<3L-C74OeKRHiUfk0l=2O&KM_A53HEYbi$;a5Nytdpiyso= z!w=jSZlt(?=5)Q3C5MGQ5WFJVe5r~hV@T+96CFG@cqXOg7~KajLLYN91d`R<>nCOs z+bK3caeTQ_gWf#ABCJ{JJ=x+X!NLf;qSZssg`Cd`EJPwMe3e;%Z}A!IHGM+G^KrMR zo_;;K)sukaFo^k|CXgfw3dv}1(MUe~Dp03+fk1ho4&v9uJMn_Bi$VtiNlO4Ijl38= z(IS&G`-lf2c$n~wC=5EPpdNQh&bCooCFhdOS`h(qqlsezbS>>pUZYe-RuTEFc`@Da z0)Q!pmBEWBxkQROzIv(Q;l)tL6Or@qVy&$S)GJ6j%*cF$OdBbC!TvQbCU@NtUO0K* zolf*YKsG_LL!3+&0%!|);0?$0QP_Dg@eZjm24JzjWt````6jdAA+-3QSdsA1EDFSp z%GEC*tt8N+b%V0jXjDU^c&>ou5jOww%_%>H@+5d1*xzBQGPRhDToZGFu+OoDRC%89lq3W-^J)**ThuA+`q=Pcd9; zOx^{MMJ^hysmhySc5fH=+!Y@J)RjqlyDRNz{W`I$u^Adc*jplMLbg*$TZH0Uh$-l@ zSnt7B14io@kDuaJowT0ukrfhsZ=v;#?~WROaiS?sq7nRHZ1j&KwJzlomjWt27-XZ6 zX?xqj`mof*dd}b3K%>r>a`2o#RtRjivW_@YPLnhS&WogHutz=j9ypA*Gx-FDUdQ)f zeQ*QIpGiLe1plXPr*I6OgKH%4hx@@ZT@&8;QMm0VjH#=_+3ShDv1|QIUW#zLfZT~n zpE`!=ihz@x>+y=8!Z4&+Oo?hDIW|=V69F~!x0=R6BlI$*?^@HM7+J@6imMtKMXmR% zps5xlCSnfR8>`Fm4$fC}Rf{I8tuFCK?d;;w6ur9R`0{)3Dj1poaZET>arCkK!cwYg zKG?1U@cg2FxCa7@j6uT2fBb%z{wm*FT;CtJ-{bUn8nF2n-5}b_dwV!Ez;klup$z*f zC)w+`CkY5w+HDwR;TT;#Nh9t3=5QJi4mt!2Y|T=2-L?7@uyzQO-fN@`>Y#`j6d3B{ z43HvPx4~m*Afh2!i!yFJpY#qvk&W`Wyr@OsGD(yWNX-kICx;uhu^DON!2TJFb`5C<`=zTsMH(86$Qu;JM{aErp(D+o7)5Gy@0m}1JRrZsCdDj<S6azZ>#YNMz+E+r}&&OD-)_x*B+iLxB^mtf}cU-QxIBh9^jr$FL z*I9g~G!T@*Ty_JKB{eW^VMwA_@(X#ErB?lk z@|ki%)FHBdmZ|@pyD5`=D-7Z#~U=`Hz7AFSu`zFx3gH2FJn_H6`$!T1~?FKOlK3Fs%mu5rn(} zgv=z5fr)psbcgw882Ssvldz9XQ2}b;wWckQEJR$sBKuBYy=Pz5O%iIylIkJ`Lvf(| z_04**SvzL5c=~?SYMiBlYmv{uYkfazpy{8a9+*~%SFjm&d>K&~&pkpHD}XpRX_8Co z(+EJv!7MhSD4x5sE>nzTHy9q78ILID7cgQ3u3Sw_lCDB{kH_LL4GqcRD*T0Su>6>~ z_*I#Z&N%SR0#tH-%F`M?ltfB2pbkc+DDPl?MRtbU=VfYF^Ss{kyiWb_kd)U8gzly) z)ko%4juG~9wHQwl?=qw?;YNHL*2(-*@(G&=rT07}%>s^Q)L$@7xB{|MQSeM835>M* zNPO`_@I@JsEp6wyxQ90!*jO9Hvy(cIO+7EO$0`gP4Y;CHy;lcVFH8wq2YGWa?h;3t z58vlUo5+(T#o?dT@e}@;e4>}B!ig{-huCr4gT#qsG)o2SHNrj*u?+=;tlV(hgeEZ^ zkaF=<2G{q0YeGk!46aKy>uUpnFv5%iz{m=2d;3Y|;OD^KLypxW@k#HcrpN$=i zcQiq|v4gQjUfY2Y*%YW|Z0pU*E=hQr8})5hT3M5gaXOnocl+BWq;W~e(9n;pLvxi# z$f!m_MrFh~4G9^D1XaTW2|H(D)EJ2s(19D`d49Hpg}(^j#Bw&kZ@`-CO2of0-w~45 zFCe9{>kg*B;m7R2tyf@m3MNum>)b6L%q`hW7~*B9Sk82_z{D$kaOY<2gw>KW@gEyS zbQR%=llR$gCZa=3KArQqL4*^|$U?J0gn4lgEab)2UdOdH);~)GP5SU`G`UmSfyg>6 zLqS!SEnz#@YsD>_hcuE@wb)r~M1y%NX{ec3D&B&D^K*L7lxX9fhS4Xz(sJ`zNf;d8 z1C3F@-zb@10%KrSD~2Ke{9d?1dJ*4flYq9QLKuAH*y7|qQqP)@!?9*hGDv28QuaZg zw1S_2ieTuIGdOfsNkxqJzw1y@fI`J;4csZ~ThI=OLf<1o9fSrE5v|D_dBJZPW()X5 z^`D~MKnOHvWl1eaU;J*`g>r)ZFJ1Nim);n3H&GrC;b~<=>FMUtzn)Bdhuf+Dn9IeeE#qk^0oc%;|y(EAHW`t>aC`2Mxd zm2P*0JTtKv%8582pot~}zoxJUe=_-%_=8v7r14aYv5->C^Q6KoMouf(79)KgV!_eW|IZ1b{kOkxn)+-WP6D3CDH9O+NJejlXy11tCH8T?GF5f@b395tO! zn)n34I=Ufh?>ET3e@BztL&}q(L2Ot>IQDMhaA{zU$+usm%F%``)BdU9Rw0NEM-s>P)cC08+|7rlbB}e4W=YB1H^1osiA5G z=*Wg*3RSmB+M(688uc7JF2k*zwEG&yX*yAB1rQQK4L?j1&0OkDS}~zWDAL#zK&zx-0yO8)%mDQjfY=>G#?IZR z^^HnJiO5aS(`WEI2qGG($rm0TJ5l;VgxHy5N{N4!)>osBd!zXR;f(kupa?`q_ahQ# zOJ&yfD$#c9m)HQQK%ERiZ2Dsg^G$*PF`w5jGvvU>;f`JsCMv(d5V7(TGEe*#36jb10PGx*D?*Spk3J0RHDKPD`lcpb1FgS9 zdi2a60u#-CUWjQG7=u15*e6`Nbh3el%?4G-nsrbpJos^!c~hXi7Qvy{2Tq6dzyX-U zbpET6Yu?I|$U7g6?;^$V=f#ZT(O4piONi_I!h4w~j^$d5`1;hM8X63<{F2F1&oqh) zS;v5QI=ccgA)1gD^CQe3BGsT%1?a?^w%%%Ya5MCwS)#`K>;*Nx7LKJFc{Mn;_5Hlu z&kr4{B4GRz_ci_#^KTitOWJA<;0h&%1|$^8!2vANfZ2FBhLQfd^;@umALC}}ir%P# z0_~ruPp$%|GVkXH=2Nw^dnOhW;q1zQ7Mo$RKFue%;ivH9fcwDB2eF_N{uw*(?UGr; z=eSIEx(TNpvx}5#`i|7WXe}H8fyff0fTG#B74gO>N>JL|)@QldZ)~lPF%(e1wL)*B zK2py&N3v3>g0O$VJy-yZN&8771jxk@)ADDjGP9mkM1o@An`Q#b)69r4&FK3y6V^4W zOBlGs^aGJFNda)m_z4eBvHki5q}=?#tRA~WHy;sbWM*`9^B{Pu65@xI(e9}4*5A6r z5*9Xni_444bj-^*N0?7eoatj{Vk)>48pm`)i#{ZTYemUbh~$U>Wmf0CPNlVmCR{;H zDF`EchS_F>a+Mof)r58#v6E;P9seKJX|LFm{@Ns72fIf0QJ`r9aRuSf;yGYYDKym( z5PL?nft-^hV3dWSVC9^-Lg&C~?T?7PG2|Utr}!g*%ikZ zwd`PFkwZ#pY!wp0BeAy97}k^jg)?XqKalzGKV`&eT0Fjlm$q{x8XotTBJLP5O_e&Q zZz+wfw23bbUj$2?V~`niBb>U$k=V-ihX`^O1r7q(3~2dVbP~U(TIh|@g#S|;MMOkYpBBs+M#vYh;?#?`JM6S_8Er>4cmh+^cn&w4o?eEAKEwX7g z03;PLgN{?@jnNXdPg8d`L3Yw4^YkIkMmMs`tlgtO9#Ok{dKbv(fx=3sTM$V8)UIYU zdaUzeRGgG26TUhFgUY`;b zU5cVItdABIQAwB@yHH~m-MpeQ%^WSMjW7<96j71(AwZc#{ZTu~3bDQ?+x{oz|E zzb+h&AwQ;fHfRSeW-7G)=4cJz96qr}^)_r+VX!Gm1$BnO zYk1r3HDqsQFV!O8FZQjJ&p8s6&{t1WW@+9y*i~~ZsSL;LoKPUr$#={ytcVynkHn`o zqY7@R4m57T7aCbA@9?d^ht^ z<~oc;AwRlf21sd%L1uAw^lq*$H|i;uCLzWH07lwq!w%aBp3>6?h3bU%<|wKH>Lr3} zi+OvhU0K73EM-jAWwZRSn;micta%9z;YeQd13a6i_xq4Jd`KfCFO6W=FQB}`d$rRe zvv3z5iNP92N627J_VJfQQUHHyu&&>rZDk9wf;Fa)%UwQ^c<-nGy6LkS*OT2ZWM+(nVI< z1=oVC1}cR4Ngg@AFS}?#)dNBw!iL5O5XDUo2v$%~+5tg}X-eiGsWwPv z7>D0erSEB)sQ9hL&KMN@ZV{NaE_p(Xft7*AYiOdtAtHh#=fOLl%yaYhXA`hz<9h^V z4b2`1kN#ESVc1S*brdU+bxDz;F_E5MG@Ggoq@b2S2wfm#hEb18)iiZLlNIuuhiaBE zt7GC4z!#XcSJJU?ciA4d0vX=29QW0`#3$_RSpvrbeyQwQFr5l~KtehJT$++vmZ^)H zl8qWK{1$j2O&NiO04@^d>VsfR7x_dHRSJoRll!5_mG*_T?43L#DSHJ{#<$_hXj1lc zi|>{oG>t&}vT6 z*9sR_=)(E=bKXQ=5z|V}#hY*zsb*cKfe;>x_Eyp`f$T4}%Qukw- zoC_`a#I_to6DPs_Q#Z^J?`W<5D7gSm(%*2d8a=pdl0!Zk4--XZqKZIi&X}BN9kM=y7uC0m0-Y$*t_}576t>Lj1%uTrE zX{lsqqI+Wc3UMTM7%|;*At-ALi{ecIJ7K%@m@toj(FCw-uzkU2j*SyR3vo^!=A68Y znJnd8N5bgD_-qsM=6_GG5Ny{LSg(16k?f+iVva;p81P>uAXdRSYTzzCSRP$N4+Sit zYrLrQw4kZp8mi(oVZ$ruf&PscB)#-^hV(V(b?u|$LmIUi8ecf4f;WgEy?_p_0*{6p z$-o%(x<+EFBAgLx;u8sB9SQsw2uK7+EJWhnBTgAcxM|YR@Ys8$8`qR#4@fDd!jbHi zmJ$(Xq!eN=!?`Xw3#&xN`HR4di$5&nJ~=Q;pQL z#D4iZ65AAUZpHql>D5M%Zx7*_@vyMJd~_62kkdCJp*%`W1P(0rmt$>JZ9X*PBFs#{f|Dru z5zqVU?`0jPG#qOnj1*&Gt`TE7rUTC@G>{y@->@Ae$Pi19(%74F`zXhVW;|EB0NnOx zOHqtHl|o8A#Bp9UM8WvQW^heOX~}1STOS4`!_I}-rQjtigxmf>>Ksez9GeyI-IoAk z!TB1L1AUG~%O)`DM6w~y5nK`C>a&GSl&lU+`m6o&EGG|4*?*K@ph0jZU(`W|e)CIX zt;~)ojjguR<~}wF&>!j7CVI&gu6&rGCohYlKEqoGd`0l5FoM>K)VyJOD5>U{t%+SP zn26%V>V@#W^GC~4F0Rh8T3%0B&A6r&$cVl@BF#|N)=*C%{j(iQXVhmWZyy1N287{e zak&8w99$R-^-Uo~K@wqWXfjv@+ysc4-*gmP(S0P1s}Zn`>`AmiZ7GDuGUZeb%_XJb zhdq2LsgRVw8ZOPCTP=Y%NVk|W7?;Z|18Sle2^@8~NZ^n(3G7_rN@E{eu&{Cnxf4th zZ%NSA2;VLBAkB-=(LRHt|2ZPiG!Scvr8MM?N8{UIcwX59@pvfQ9X#GC&=?1jB&-IF z=wN)I)&m^`F3Dc-Sj?@xJOoh%)l-tyj8ECY+~R!2o+|Ul z#hK-Pi5%q2wYIIv{biSm+@DBdv-faJ5SI99a zgKt-X(alDpY?R^igLsn^*2E+6%Qzdbq;~0p9mcKwvsO(8&va!;+$$5m9TuJ&-4UvE z;Yqx~V9&uX%E-CD{-`?x$~Qmb`4w{Xc*8o_GA<7}`~xKiE1K7n$nmL)A6U}C@o0>+ zL!NORPx}Be6(q>PgcQCN{3$=m*{N?(Ej+-^nVfRCJJKSni(gUl_Sn{ip#nVDf<%92 z$~|Jgea=M`5?7NVLTdDZdPvHr&K9s4m56^m;**G3`tgo~M~_F4;IL8DCr*r*wy z9N)+-F=<=fb-cE;Tx?j^#v=ZBZWpOq=V!eH>T5d}6|K-#a4Zxe9~o{r-8LjH6pQU0d+%SV$V z9qy+Ni#RyBw_XqhEzznKD8ho-HT)BGX&)^D;J&1#z`9Zd!r-qKf%r_I755FeC?x{$ z!X75BvD;hZ13^V#S|&jA8=967ldNHJ_K#;!1@dv4IT$X*$KG0cQ+zBYA8QUIsc}4q zKKKHBu7YATEC|gf@sAVY7bW@i&GdJ+w7*Y;Ai4~trAp&oxgc{*&k|3~QudR%LfKhm zc=H@xV1nq!DGCKh2V-unhrVO31#OF|%SF^>!0y|(hXj{<%SYaR{Ak#mecj-2y!Yaz zOq~Wzwk&b&Y=&2x%qT}>M^lJHvucyYCpO!F9fxY(vjW;a1Z@m})=c-n6PP%WbZ=Of zPnfWdAb)(#`FDdSSh5ZrV--<&8Ve(_^^X^je|13w_WJ}pkV=Wn6*$Bs5wXhg;2M@uC5yaKrcuFYGjll7HQt!T+hbR z(v{QbdjW8PK{y=KN&FY+pxnW5Y#1PKJD-r>M9BM*O+Xswjp0inj>6bKj;UpU9TER4C9n@Aphk2$v^eCR5ewE_M9 zE3jKmUmRlM|Gmt=g$e*RUw}QRr@mobJU*~ILcEAm3bN;i1G1@}{sI#v;MLKdbVie9 zpLV1P(=c$LMBd5>jSr(3PTs*4Ps#TR0#T{;HL0p3BIqZlq4++YIUXg!0hsJ#SlX|i z@M)~E(6^MD)k4EAHpSl|x1 zu7WfG_b^}*qX`P2b3h}bLk|Xbj+x6nNDS@(O;Fw#axv*bn*u|ANSO5?#bTsZ9YX4} zcS#)f*1+q?Lxk}UUKrE(a|DYiNQ#MCT?&9R-k%?n*I0R7dkUd`XxUp~F z%ITxj2=u>o`)2L2W{HTxFSW;|1b9d6alVE3#O;T-6MLNGRtke(V2>yL4j5#x$AO8z z$Fv#t2OdEc13vP{x2Z@629m7yyGOF1+LU9CwJ-`KVcK%Q1VlWV2<_tRH{Dv?@-?A-it>95Hsh!62!r4p04L|#8F6`gh*jj^=&PJg)wmj=>Hm(-MMj^ue$6!3~ zr4bUHJqVW!(J4LaC0YaPYT*n!ie!#>?dh|iLs?3;)ydjeKc(98E9N7qq&e1 zBunt@CL~TEmEv~3h|ROUmm2#A&L06HNUvalFb0@e1avdqSYx;~Z=G&okbR z;rNaURcICMqiK;3+rEf0Xd_`Q1orqXnCcU+W%`|zPV`xbK8xn7gW0Ey?`#t7al1P9 zsY8pmQ!ilE;E zBJ_J{T(E^N#{IKjN2tIT$^O|(q`=vLM&fkbI=f6>pN*}vfu@5*0Yz#@6thf`-ah-J zE`#l}fu=7-UPL!Xgcv19!4ZIGF9v05_eKT85pL9dB90Jfl4Aj4XG2rN=oh=VoxCN7 z(^?ri3B}dfaCR8T06{=|QVRx(M>UIwBhgnDo60x1y!|=+cmhAv6_sHAL*dxwaO^YM2Sl#U!XqBE7h9e< zT{IEzu&Wn)GB`mgmba_;)}Q`1toBa5T`211YWL^gC)=GU@354%LMeH=D8UoX)V+hC zWq(d;nMdBnR6+g=DQg9kHBeCGzr(&*;T2NnPP|>)4y2d0)^w+i6@X}kf(EQFZ2S@E zh^>IP_;t|&{<5W1kf8h#7;07QsE>h((G}!9VIH3mo4Ov) zu>W-!IX>`haC{H8TaEtSCSF!#@JL;cRMB=EzUVvj&pLWXErbejV9{&G44b~*Lq};v z5}}K-awlu0x3m9v-t1%%Hto`5hA*4+#Bv<W-7?HC=p`H5n zUpmj%){{sVl>ki_vq&|+NeguZI|PD-=c~I)z`Ide@6zC1Nlxrg{Os6W-SIP08?c`6 zk)5wC{gX8SVl^pN$@p16Sm!ClzzXp*Je8Pq=Ghu&xOHe61hC6VTZ^83*vHP+j`&7q zYmXKK;(%{RvE*qWR&0(N51gg1P@T!PFQ6U?|u2&CY&$-2?Uc z#{=rKQ&4;88JOs3ctN*h{MGS2ejIoVLaGra^AuzpLTYbEyo`nFwDNTxEqhDs6q|(4 zY<)}}cU4av2Y|Uqq}4PHUb%?gEANhP)3FBL2llozlx@PBgcAnK6)$r~^@{jIpwkL& zvZL`Mqf( zeZ2zxyY1_+{oMA|hbEKWYnuFy84CR>q%5TTiK1{|u1JF{T6QNu&3&|`%_l%XZT>)T zn1rOO@b_Z?!$axgOJL&bB-OU;tHj4pP>(S}gS_`T(g5>ItZVpw{0+HJQ;K^7hjLv* zv|R$ZT-8q6(b0Hu0t)SX3@gx1@HZa%)mdi$UAkd5BQwl$(irao%p{{LqkOK=___57 z#-~EMvsTDYr4}p1spE`&-S(K=!NXhrYVGmBDOwz{}PikB)il@ehyw3ii0qD;~>s^U;86$L(?8WtTlp z19QYS!6fTo-gdwq|6#TV>ZSbw^$yzO^8Q+2)!e-8wr@6G7I+!Nwr-ElDFOzW?eQhBMIqX| z?eupG(4mSg>u8H;k2^8PYmR~`Y}VF7)-UGfZ?`=@C6hhAR9i2ov|r5e=6$wlj?W?t z4-*E@codj8hZNi~dn`0)dZ!}|j6J^cNOE7><4*@~#U7)~K-juhrMx!B1GPCG`c-B> zIfFSKdnA~9NYY(M$4{=Z^7;$gu*ZG&%3zPXuCVra#>CF;@geY!*Bt@uVUGvJvpcoM zJLVj}+S8ijATF!IQbz0upuA^B|Dq1OboriQtmw6Qt?}az{tDLk_7^;M?caw3sB2Pu zu=1WJZV#GH967A0v3q@NmdF&J^Tzz-0}Ftqq}9W zzqc&0_V@7m&h0Pb6Eg~dyJiRumm(E)El!$BkSe5Zd)#BlHuM2pS0~}>#Q!z^ zB;?4(umiJP_SXw$^v~M@lbqPGaKy)td7vIdsJG%zns~NbejHzOA4)0W!$+A+U_XTi z4u^~&J+_)p$=%3x&07ygEONV#X%6s|0s!3kcwzGIyzs6nFz`-5q6<aeXC8>XwPlldtC&zUDRmx_ z-kBMW8^Y8tAic1ZJzWSMn038B)c8Z7aTl&S$9KUo$$qQ>cV$vSWdv(i@lsqnusks7 zPEwFxcr9uK?27UMh*VMP^jNQfWdcdtS`23}k?Kio2qEcPSS}8uAgkESauD$!5sc^F zd6=xvViT(!x&z$9Ax6bsCY%N~_jBmJRRRf`+|sd>>&}d7=l6~RBJSD~(M66B;R8pw zoB1#>jU*~$|A0mmQR3d35F};=7lkVmd9Y65IQF&;g#r-HZx0nXF-_VFtJGo#n14_S z0NTG%ZDS?dXPExjqc_C%v}7KFwQn3T2D-;@4u=`XZzn0=dv9I7HDUd*``Fn9Nj--y zy;o9?TSrN?JU~Gs*dnSBU#1d3l0YJEqKj7pU!GsYnHq$t|CaV%VQj1>vFcbC<`{<% zKz3LN7b`lF1`F~+6nktEVKBUllIc$F#C-@7B5+Ua z4QLk_NlT6IkRNj%!kJorbX#WsE9_$nsRyCZHc{Kh*?cBygEO2AfST6ifEs_d3s-t< zfkrumgRC{RPE#GMYT-Cr3uOei0uljETi#W@qUeuS)r>MhH94WJDhNf-3zU%3Au<&9 z6{4!GYI*zK~}s-YeFnJ_i>fvoa*YxYST~>N(E3K%Rr|l}~^uZaZv}%{UyocrX!$uOvTA zq9zDSei*{GuphV`6-ZyehFQP@vEk^7YdfEfYT{mvYw)nG3US&vSS55)9AU5Kzd@<0I%>H-oOq2a`}%051EW{ z-;lmAYDh|cLa>sN7N_vq83YMpwGgePL@%h@DazcQZms>gyoC{an` zefw3@s>Gt?rAe9_{fB;wQnHsq-c3y zx1q?D{j?A0gtSyyrobfls+=&K3$p)ZBO=yYIw`S9lhCy3O(K|gj|5cm?Z`Y zB-OyGCxhVLOIE(o&)T(a4~%|W#`%TNJEG+ubghCh2al^MO}Z!GWoE6Ky6;Zc)HSHV z(~_87IWfQ=8Dp5a>iCY|nQ8W#F7n#1&Pbz+-MyM|2(AVja6(uT5;L3#;^@rHf-0F= z=&p)23rZGitks+_=+nqr>?9 zJ^S3|dX<$rIzzjE=ALord5~|}OzR9qaQYgh^#4%zF7S0tY5#cA_K<30$0ejFDM3ny zbllQWoYLwJDM69aA;x9G6ro9_TAIp9+v9Xo6h%>kQ4~d|iXzp!Yg;qaWvI)r&ZJD; zdh=@j-|zFRea=27mtLm7|GaNMWS?{P-fKPUxj)Z()>=j6H^^qN{=`?P6v!`L z%=*)WBP6`+I|Is5!Qo*zTAN3{tOdxvk5otSk%v?y*j>_+Pm|=L4!qEj>+10&Sliq@ zU%Z=+I|DJ_B@xrQJs16+YR~Nuzru(d@OzJR?0HKqJA zjosspU{!brU&_pNU^B}IEqsGfT`-=b+ZxYnt&OL$lO501|K6JM1jiwRQVwJ4B`^*d zp+628p+Al=ADbB*;T-#=%-k9Dej52Rq_6^NvvR(Y9UFE0| z{^xmYV$D$Y3hMA&QxB$gNiwE(O95I85YK{|oo^1HEGIEMbM&1lo|mAEdx|ds zT#Svwt~WfBy}G4+7L9Sa4VeJr?Q=e8@frN0($8RQx_;Il>)-a^wvkI~I=j)`Ka1}R zKJvpgag0Wxj1&vK;vu=g3=JTwOc(_(^t()p$^iGG1DxH#d@QI}U65}c6`YP%m$HbE z6}w)Q#GMsHb0yxItUtqzX?X4Xf;F6hs{7#l-dmaXu6r9Jp>ZFuO6dD@UrYT z$~9xr_nDy=HCaua53WsULiKMHkM!!R$U3$0_eJ3&Q-3Zv4K9A}0K&VX2AO(?nffwe z)+Odu)^&bIPEw0&35M^}$O0f>rO+gmaORs!B-<4ZL9srm=cN1bH3l$vJg^huI>#I4j3o^EXZ6ix43A5)|Qf8C4|YioQ3b zC7*-`#$Z^mY8X6Kf&4utpg>EgDDZ(M@fl>7eOb z1Oz2==%F4f)cXzO(7n)Z_Qycxe1KhN2zIfV^GO1Y^%r0qYmqFi!*BD=<9`rpUfU56 z{65_w4cN>61=DqYaS(09*wrhg#Tiyx*eh6PmHZAo;j@v?v^ZYqRSRYye|~&oeo=^r z)QN88p1?A;oLnA^-oP#y#$2jeAC&D+8dEet6DalEw|}8Xr?AN>E7V-c)8GU9bdpP| zG=E;%v==3))~#QhIwgtS-!}0MQsBQh-lgPN&_`GUtP1l)rEhIhae_h2we<>R4!Z<9 zTE;Q=-qLE=IFO73?x_Z^GS&V$`hgZaUl{e&Xz9GHQ=^0DLG@hk^vJ{}qVvcDk!;iL_NL$BsCPlh{g+@lwF5$04UFoZ$TxK{c^fZNZ}hVRPkmj zHbI|h-6k~U1#NekH}EDMcYK+b}3^|#PY&HICs9(!98QiNShA4rg8 zGF!l|-AvS@g>;W}=@F`V86og{@2Ysst^>)A_s?`c0tcY5Ylg9{*B0 z*0!)`^P3Ar_SQBpX^!89A@FBSbOsYUwq?7)Wx$TqJDN0khm@L z1ykO)`SAy(npNftcJB&POuv^98@F-VRasr4iDM;c_eU1?y3{8JI7K z%U3&JF!fg;Wh>_kCj8yvf6AOGMaf0b(cU=V7_3U{9@+|s{aRg+Q#{Uyrnij ze&MPFdy{>=>`ix)@iAX8z`p}^LX6t^f~PwJPyhSo3m!v-Cjiy?g7ba>X0~d+AZv-m z$LXJ?;p4l>79U6XcT(~3K$ha;|H6F1O(+4?`GVq&z|eM>FIYAr#hV28hw0bAXBh@L zsONma+Z&d&J72IHy_3z(7sx5EkTC0-zye6-8oTi(<^|4$r;)QGslj=H9jz4W?vsVB?5vESY zu2xTDhK)1r722s0Eyw^7;4hKS%-TF3NpbU78uAa`tlyCBj5`i3I_Nn03mf4eIrOO;{Y7Io3D@d3baK1{#n*n_Da+-K|n*oC24?X(x7|RnZv;l8hdu7&4vWxiJWLF&LL(KD^l|dmu8saUyRSr)2spF%#PO{f&xXS64 z?+P|qe}!FeEqrF`)9IoJQRc)Vpn|i3qaDWG&G+!N()IKRTQrcp;3p0cmhJqs2GT`P zn*obS*3&kV!#>!|4SqAbw`hj&GZ{67R|^gJvU38O`bKCb`jTGgXlVu&A8$XEIvndw zq8aPJFFT69aVHg@E^HcdF4{}OQeUF-MWT-HqWYzXL@(rcrAPCAUAk~L9KfmNEu+>J zK4x;xlHj1TUOMRImow$ZpY-yrUe3{b&-@52_q$*Gxe4ZElJWai&u@N@%nlKsW+mX3 zi*Fv7-&{9pydo92l-pURx&w4UN8;hg$8&5Ym(2l@mibKB)n75nphYW>@+@t3AFQ@eSZMTx99w3w`^ouWh$j+EdntQjX{_c*^f?0S&mzc9Z!_#;0Wd*Uw=jUDhk5VQT~H%D*E zr%&QXS}Bu(WtVL(tgw1gf(j+9crAYV6Rc)_89@XOqw-^A7Wlu`+>MG-%x{*h!H~A| z{N{{bWjujMDP>4ET)Md-34|1cEsm7BrH#-ANY8bX`OQE58-v`s`OWp$srZ`Mg+dGdT zasB{Q?l1&1NbW;hiH(2-#)k^k-~+E}eH!od>j_BGM`F4PNvgpSvpXLaq3aP7)l|WC#L%kY<3&GS(Ag`%Wf5dTvS8EfU}^L&UzaqIVMXxKkEWYQa0O>lz0iGq0}0(j**Z)l?zSFqb??}U ziLB#W2oZu7o=B_!(ktid`a61QWru5toVokYso?l_ztzecZN`B zYrH1=0*_rSAz*Yyfq>`f)f#m=gY=OZweTuIOUxeuc{6DeviM~h9#ouw{_h1XH0h7A z4W8&*=r^#jGARTLEz@`mhXllH7iqy>Cb6M+bFmYU~2y0BrBSdel>g(4HhjWw76PD}h}~3sK-iUG~rw zD|}1e_<&gYK5J%~hCEJ=B%i-4@x1RV0!l9wy}-Ab35tpnn~0t*eA?r*OgFpa`fJlB}G{ z;f*PBBj|_#??vRxX>unaC5K@lg7W1=n+9R*gBFxqP@Q281k6?~TfPZ$i`j$Y>WvWw z^p)6$1?;Jn@f_%nr|UM1hoI>YBn@O^Ux;s^>yJ=Lm>6LxRu%XoTqT3IBQ*9)r8&t~ zSXEKe3!PI&c;r7Z!u>eH)PE`T8&LvV2+H(=nBspJwR{@#92Qr^vLE_ET;XoSW1gRL z6qduY^@+2fc0xsI)0bxcSMWU^;&~o-d>ORIY56=h1`W|BbOAUOZLmVXVU*f6!YHlAfNu@)l^Yy9h`Bg*ZLZEy-C))IB=&;ght0Z5RbIgu@D9{{ zA_gq|0^ko!fS)eU&$5jc@Jq`{_~-mv;BPDD>%7?^a9F^9YcZcHH9Mkdi4h%`HXoP(`~*OQI@TvA zegseY>REU*sh`24N&V~^=2tjo_&wGY12@_^h?iFZ_BQr|a>hNQ^r)ar!`qcVA$PTf z|Ct3_3_k&?6Leags;onuiaW|Wc0|5ifkjN}VHweM+kk5pT5T#Ln#rG&BZ_~95gln+ zER7!L(_cvAFRGc@XJkcC-?&g(>a2zBLxBF?rQV6y(R}5YQ(dXT9D;@DUv#pRD%}HG z_t0-~(x}&W4|u106URVRr#-BUR}reD5LB33I)h)nAVCq#g)*9~9@PA{RMsKC&APpO z^WHNlnRR%;zz2(HuvQnM2t{6I$PYK^?>q;b>%H3EWckw{hl3-F~psX;C<({fNbwy8$`ekLtdjPR! zQ5HH`<3<(-xjPZ!P6cS1u|(e)s?t-6ybiNJ28z5YzE%_iu_OqZ0xF221l7#_ z|G;?K*`MQL@>2`{18$vgwC6U| zKg5(lhnlM}hy!ZtlzgYyGE-3!6_&Fq@kEc8b(+}q5{ZE0?@l$NzRRw1WX+LC5r&v_ z#(iv>3t<09(jw90L`xwt0tAscF<+C%pe&!p$z>52#E;1kFZa%u2n%M_Jh=ngWuCjM zJy_UFG1ZYmBYr}%wmt!xnR~3H>vKN=9qPbWY4W^H^*!O9!TKIDB(T|ZgKzRnpgRa2 zRE`~bku~|c9{BMWG1l!`-*e0eOX~|>^F}mf8JmJ`YOSbdX^&%6v!6W_w2x@+gK0$QQ6jb9BL`7efEuY z*fdn6cpO~2pIi@|*NN&Wu^zaye6{sGb3X)9wz9s*ea_gL)Mk~v4bEfP~Y>p z{9@~SCa(mZwz0macD5=iGiGjry~(~__VL5X_?QK~)V~9UCx_Yko_GEUJpJ#h?^&D~ zsPDP{17K#W>U%2xYVmQkt+*7`PJA48t;NUL{+(2Oy!w^m6lU(BSvf{ly$oh2Z-d=B$@7khXPzRho>a+IlP|0!&) z6ARt-rAp)9_#W+@Z~V`eJ}V5yNJ8|B5aeoDEsW zgZE@vQU*Sl-#!{}(DG>^Wy&!uZ8HN!(s^T+1rkt?fNvyC0Q(uHVTBQ;Qujhfjd>FN zh^HfVkro}3;WPmPBR*5}@pCLR=L;R(68w@dR501_Lq|gMrzZLCq_*QCD>OlU$$zdl zw_qBsgfN*7`~?K#llH-0d=P=`OnJfgB!Kfiv-Ef%I0P(0z`zS>AAtfax!@aN!FEK~ ze_-<|U9UCOF4dZ>i&{{DAygi_fJEoi!m~Fh6*weuKrj~Z%eZK&K%7`a2=OCGGfPu* z9BWo3dE|w@zp4%Z1HimF2`WYe7>tuyY8M^xDoe)F`Zv$Nhn6ltSkX@Y#ToY^`7ix^ zzd3u|svST0LZajTpsknv>E~^-&yRoh*++FXVmxw08S$A<2Mg@i{ef<5c^}k2CRzs0 zfgGNPM&~5z=Et(9uVM(oBh8(L?}&TcDwAW)z3fjeAY-{jvFw}lDLG5*dHWRj&n?Do zfI~CD-{neivYtmy1S;85Ex`hrlkpn}pNu>6%sn{ljx+-olmc`@AowG_th%x2|_8p8wDpzet|< zr!h2ww!AZqx8O8aA_>J41wU+hpAIl6Ag(Jkgcn-;pdWY0yx2pS?&fxT7@|0nc)Dql z8-26)(x&K(cG_e4bN6M)Ns_i33OPkcx=VP+$!_PdE!Uikno=x)iuYq+&xKLYBBrH|S-AUfx{>9zP_7$J6}jA4r7y)u8z>POb0{M2%|5jglRF+%RX?+t#-f zDf)$P{SX2BB!CU-h1AM8{hitUvIcO8Zh5I}0+BHYvpC~lMsM=r z0z4?o)XwG`c&xIN5>nE0gFEk=PJ^OLO4fZ?f)J{-$GdLkVx30-P3*cr@3?6nQ~LTM zQk0lwD1#Zum6;s30E$#eVjO*;Djo00yY&; z>{puSQCZ40X*gq2CZKGD6lUiTsO;SY7>2EM&zW4~U~I7e^@CO!aJ32?H$P>^Mu5^V zRci(PqB5>eE06z!bVsxvy%0??AMofWfLGS19Yen0RyWua(Co`{*YC(s>MAF*KMKA1 z{b9l;v)=(@d{4#z8~3s&qG&;PC>RxE#R9|kOg(U3&C~mYr2IBRZSjb0K z2ZGv)*S~!m1NpDS>%%MSL`KZL&jyS@FkZjrNp<_ET`PnQ%q`>fS!h(z|Gt&o(s=#p zwd8|sh}Zx51Yy}d7_WC|7Z$~PLL-UNYb{>y+DjPf(zif|?G>-z*R7R!{nV@cc>NyK zZV)_3NvrYthQ~41?HaF-zs%D5>1PtO{*UAJGiUkn`t&-9*L%DP9Bxaz?mlAUQ%As) zcs;UGea0=@zv~=6-A25AMZe7jr((-&a$OCYjYgC4`romFHkoGg7lh+jT!giz@+Yd& zM7%ykzS?-b>l;AIR>tea4_kaROHrlZqxu8I$2^)g@C^jAop}9ZKHbj#UE$54L(-+}Wi+G*&a9ewRUKrA4HVh5y&7RNr z27J#Y5EBFF@aCi?Ab!3_R8&kapaVy}j+WxDOjhMeL07;8L+%$iG z>(2+-{}H8z)>pI2AHaQmnQx4{cK1CJ-x$Lzlh{z7JRjt(KCbP`D%Btp8l(G{7u^)(J#LOZD!Uy4XaeKk=@O>@MLOs}w19U_( z;{e;3%s7Nid*|gf%>%&aB+#6OUs1%V`=xoIVjtemY?R)-yD#~j6Aoc7NSVDb$;pNjj8(g_l-gQ%L^GO;F5CnKdN zPfCHhE1}*>eLUq2tB;$fZM8oBkIyeXe=Y#tI(=-GT6j<2a(LU&$J^ul(tBRU2wK<2 z+jM?u{EU{mi2AsV^Go+a_sM!k2={w0ZLvNc0AHezx-y@-5~d0vcz)@|#mX&ojP3cQAHgKLEBGS*ebPH_@BGp(96=lPs$1o6S!||C;I_m;7~$ z_3;+vCmx@+S%tgs;n z$cN4XecSYpw?1F-_RClNajLJ9U#S$8eDw1e z^nZ}Acwd&KF*JZM#r?5-H?wfky7vCq*Ow`8mL}_5LwkS@F3cOt6zF`HI6g z3+C2ql@)aXz zVg%dAKhB~)UV3s%T}1!5jq^-5K9lAj|NZ`;K4ziC*5xZ^!z3ZxPUI`P-M3kNJc2N^ zrjH**@9@FH^ueJU`3EBDN(cB*Ch9RYUm-YHI6(Upo0NK<>CI15z3O?U-_4^wmNU>q zy7zp9U4--K3@`)BWMMbv!};0K=&8$0J%N zi$hH0CkEPie9ae=8i3{LGGG6GvP0YYw-EYw>Ri>o+v_~j)pz--_r!}u^}hTR#=S>k z+$r(RmY!#N_ko-9G`B$gzK+7SKziZ;!nJ+RGhI`#IWS4NtxHdIO@;c(8GyPS|I+5S zgZ$%#=Db8Mh5o$|h3W(WW{g6j7Nq@r@qc=r>D(s)aNG8x)$>fVe0ZO^b&KI`L;r4v z^Gr8Bff2NOp6TOST&w=|47)VNUSX}LQzn6aTJD+hnH2Csf2$4ZQIue1n5VM?I|oD6 z*!3aE#OD6^0*Q!<5_lk>A8R&quJ`Nnd~z1@Mj2h~JelV5&oeEMZMU(T^OD5DrrtHk zZVrLZwT#`!#?s&n9&74&bpj=~`)%WBQ_-kQHuFOst{G-{IAB$Z2m&^DTY=5_(0Vz) zV%y;5&P~Ii3F6mCy_vs#uHF1BW-+#P2c2@sQfDb*<3XqLfd`$kB&&`;05cV?x6k*i z@+3+E2c6FQ7&H8!$uvCI#zCh~&*uDc%{Cr%nt_s6maHWXIz4>03ZkVUHuoTWAQcZf zJ#i$d35x6P`XB}*bPEqU-9h0@Kj?JK3Yg9B%*q|5X6Pcl95NmJe3W0L2tK^;qaYu4 z1~yu?=U#vR{NAlR-*n{jEjag_>o`^)^}xPmbYb0m(g|ait?2&WoNxLUiMd!*Dz=@= zsg9^nT_X&eHwgg<>^C6U3N~3nU(PHaRh+bLW&{-e%!-hI!}}73M+?Pb30z z06%MU=bQGKB}^AM-}D96m9~1m>7;6B z_Z0$gR)$K46fh4I1jfoeLY>GYAi<6Lb)a78s^LNI77V#r{#$6dnA8EwQA>Hb-g7>$ zS}Te3kgEe)7GbIs5;FD@6-QR}&o@OitL*pK>0OF&Wr5lw!v@Zn##_nrPXBg7ok)-Q z*p@-UhN)=T_as&2g;vM>Zmr;v_-4`Xx3On4tb_36Q4fPBtDy8!{7+}xHmz^G!fvpn zLPv!O?mTsX?{Z)MiN4wP;uKo=6mwB=ZYu){X@Xvw$w|`8FjPL{<8*xC-s4YpMjFw;`NOO z@#!||C12{6@Vd8PM+MD@+FBCz*jP*QD5fZq!9iNRWHAaw1ND+U<*Tii{A3!CvX%9c z)33MqcsG*3NB^f4AM?mf5U+}M>m~Q#({0yFK9;vRlrRdYC8eQBY;h32z(}=OFIkVA zVXGKYMl-via5S}EGE;uB^^&t51fI6BUUKDlTOasfeS*Dhec-WVeAG)e_;;X90`-#L z%>bVM_ti^&gW^#Ds`ZlhJ^;*YRlVeraTXu9-js%qtA1zkQRCl9#mA>lDn9-%)Jwk3 zI#Q{Zti2zfTC11DdNGPieQ^IeF(=e?vCyh=93d9V{+t(Z!MFxKY_;20)72F>FQ210 z6hjKXkMR?pDaZRu4#SIH_KO3!#4G7hEXoY-w~#IB-=>=K>6&o8ow$KT{9rzMc3HFe zd0&+tRkP;(UlukyUCe`1F|b1txe-nPQ!oLA-O>l40on_=x`Y4<;G5d(Vna;^k$z|8~NC2*n_Y5?k&P4(TuV4@~{_kH6FfKJd}oy zok&kuIKisFdV($_&L@A&VsPZysTfRK4C95Kc_-jGi&q2Kecjud=lsX#d91rk`P0#=@SREbXf!h`c8ST427H+5H};zzbr(XH}y71f346dmp@ONBRb&0th^ zu+?G3&xRzJH&MokgM5LR3O@+5%qQ`JcVZ>)kpX*HSj_q}l>u{z9f(X?nBs-%j-bTa z&}|nHSpOM6obY8cHC8ebRut}H#>TX zg#5NVH>`1jm%aBRqzFvl4`-xfL4zlMZ~4$2KLx~4)mHL&qSnN4)zhtGfpX-dpe!8) zzxYe-hzD>u7L+b=qs!w1;e6YnEFlhC8A{p1b|?q87>c|CCAEyN;;^6}TN#Qz(>g(O zw`C|rDMOL+ZeqQhL#}mWCxf1+fu3Q|vui=~vcQmFJ;)f)M4;`)PENyGz#Thc?500l zef2P>!3YA%D%@B(c8S9M$Xxtlv9q2x(G6Mr_&-}6n_HHyWA!n6M3onMb5sB$Itvhy zbEPOPtr555Q%YP6g8Z6baSqKVu8cH?z(A_FY0|zAsD#^>xHHnc_$yd#7~5^^#_DTp zE_E7?h7gmpfdZ6LG<}Tmg`5U1O6K@4zPjcrr{PDAcJ}a2;kr%LPQyP_vC+Ya%uZrM zP-U@E^pM5Ij;E(%Lm#sn|9PQTu5Se!`b_KC`1#3gz(&sfL2Sgog|s^_>~`7MjfeJj z8vL`)6c2i~NBzbfYPu0sBIl0t!dad0GzC2{;*~-APxI-2TKb6fF}s-~=s&WR5$iLp zkGSKujCkLvDI@+RDbrcBP?k;;9<)$jI4B)zeJmpBC-C=!_XVKVgTNws*jgK0JLrjR zpi||2DNqjp)JcB#vm4}DC^I4pN55Z0xTx0Q&xuK(OhC?|(o9sELzOv&9P%&T2i%SL zgX@J~7^tJ4x{_!s~=pU?p_+)J#Rbrr-=Vh-xQZ!|jsKeMqKCzJ5C zdK?`@Jm$MmK#mW^f-m!0UUPHPCuZd&xCG;L--y)yTdbF&t6R$CvE9Z@=1OeWY*;7^ z1U6T|P{i%v@(BQ@)4XN~yC1LJr;Yz`j326T7@3BDWc)e=j0Ge&z0M*& zd9Qv!-h7kIwqCYv@sctgXWVZ{#gv*-XLjhad-5~;W{wbK<)fX#`87M5BYt2Au_)x? zW~OO)?(JsNc+FDyPx%NpE<5)jfU3Z2Lwvj zohpG=EiVmA!4)x(frpv;K@-!N7+Hq7{{(KZaxPk6n|a8H0e#ucUG~jf6uNOrer5;a zO2_DW$9;p};XarbP(<4FDSjA-{>N zrdAa~Wh0_;K^c^} z0;V|4nak&kVF$sGF-y|PeCVOa$7~mD0>sCE;s7x;s@WCCLuEO$Psu7?;!JMDIZ=7@ zdp9<%lQ&ZFvo-L%zN`&+O12+7=Kwz-{V<3C=plLoMu7OSRLC-ax<emv?4^6iq8Zi@z}bxzntPLDWu7Nmr!8zg7Iy;oUaq7ezP!1%A5roi^avaPxl!o-f{R1D?zO zJMf&@7CawD|10=;{jE0eQ?mWwp??80)(aEGy$WE7-?~jKF*dNpPxaXH8;1Caf2kpU z2KO?}#2sK(zo~`gJ@FO%xqp}UnoZ#qu*+XQ0SkTO#HG!PLJfElhR!x&?wJ7mwd!9u z;~r9dP)r?EL>*KFb6at3US<b`k5gE9w!zFhVdxuc;CJxd=#EVj<&!By zVoIR!_b!CP%OkvdKhP;O0?-ivoi<6vk|N{OViIIP7jU;(7keNOMbZ5C~(toFVplQ zaNkS^?ROOrZpNh)0xn zDk$l>#PyC`%A8?obaBbLl_m4mpHR|cO=%{k37KN;iRfQ~BAiNK7RU*y}A?5}Uvd5`Plp=$J&>}4tn;oGiU_mH685|b;bn0-1>M8(VDrEN4V7INw1w6W7#X9h1_|oh#~B3 zS95491Q?65c}0!owy_IVp)FRvc1nPa>0Cmfw1b~-KE&!U)I7ynyt8b+KUBU0{stNN z!gN_qrh|yrz?CN}!b1){n0UcwQlbERdI1k+*TEXq7pgO+vG`P#hUgunRV?>A2s{$b zd%4ki!3h&qatbJACjK@P0Z?{fa}J6@n?5%ud?6vlbiF*JmwWZ{<4sTv7w`!5lz%Du zD{(#ov?aqB=&*dMOepOM;@QO}X^MWz1d=2+vyPWOA68%IjF*k|dSWj=@dHg$6yTLfdU6$7wpDnHV6X;dtv!sCidjhPQfi@l3SFd96@3T z=|Scflo zr-zszH#(Nz-Nj>xR{o?n4J=1iwwiw{ItE{skX*{gSoajM0nN z$jEl#$a*D4resc|?~W9o)bj>FUqJ8X;~Xi;It)bu)jJX_M>T^z~YsT`ZzRG^fSU(Xr|x`63t%7i6y8z>vNyF=V_kc2ts>78g*0bZKNO{ zgHe+kC!NQxt`K`QqoABum|VSv9?P)q)y}AKCk#L(iR5Ju@(2OkD~M8-@Fi0p8F=0N z;WX7(`FysRc+OK!0Owz-!*r1{@*Dbh1H0jt z2YSs$eY*A07YK-kz+5^`4Q04(hDnw4p~5P29# z{-QcQ2HooOu9-O+eEL9&`AChQopFEV2-4(5`(()}`uvUS&5@5g;{5ZQL7AmB+>Zzw zA+HILp$;{^Bts-4mi@1&JawqMnEVJfuFXp2lvvvIQt}XSR?FxhptLY^NUiGPxt5bSEh9 zPhj>fao3a+FfJ?rU`cr3U#?MQ{v=U1cD1-(h@ZqtdiDy>RXsDz&cpGK{7KLZq2AcB zrlZ?DPijb-&};9dy;oqqHb)ZMD7v_1A$}wyK>bO%p6D(d*Lcx z7UyaHRvAuIITWC5*F+b<3za6Gmi8!o-C8_dD@v06qYUTtz!aKp7bbLTo#*aw=c1oqd0XR3lOD&BK>!y)oPlXw1ZXnU_0R=Ej&dAftr@3!EdsDDu(D zf|GUXOv}iH(aY=9uLzUJVfhs0@u!8!+;TzjWPItpH16SICR_)49-)kuq^IbQ2S}c@ z{kz0h1)KKcuD9SJ5Cq>Y=G-K>I;(GJ%pd!9s4nZWekjO5He2v zfT>)toF1&K4gJmvUW+F%{0g*%*Zr6J?oeIYcgO03`gX3lEZN0UI0Ef=aUJY?`%esD znNnL|`Z9x2zp_+C9c;?@z@OFka-%)(7j9Lm?N6{lFi;KJ$PBzuT@wfuT?^bO=8Z7O zId`njy;hTDndsrE-0K^O@4pha@QoT!Z-7!SD33zFJCuGE)Dh*3kMJin=Ms$z&1*xn zWkGcq1`AJP*fJe=8!P_ZXc_qNHtJ7&%rS>GGU1a|4}FQJ0Pn~OH-=0$oPtW%dwvd{ zqw5l4uhBEmYm7g+(S5{NcQhAl25)Vq&+$}>w-Ie+buL^o=WF|}cv)n$P@uVs) zn<|IG@B2oqd+a8d*NssLe*!}y9{*8 zG*ZC+{8x?wXq{kkDO?}|G=r>x;p(7*0ZJk`exm$Dki@e)t2~yw1A&lAu9I8>iZ)Sq zvod}Llp-Ts*Hp8=uizY+EAYvUu4C5gLVT1n&`oYNK9zxJY4Y}0r57Y&7%iOq31wYu z>E)CM=v4%Ix@ndi+q zWu77s8OWtq9ovN75IXEQ7#9I@+M`bW${S z&osF_JEa}^J~yfj`t}*4^d%Ac2S|%fC)7#1lP1Vz$|PxC5+TT&skHd)b5^U(=f^@H z-6+jt?%8QrDKtI>b{H}PM`b1&oNx-rH$gZvHbvQWriL<0YxZ|73+!MHKsiK$1H$|ZHEt}Ggf*CrKO`!-9Tx9;*%*hTY z0_NrOFajjEceUN`$ZJ{rB9V3Qq?vFpWc^=cha2%pPCez9Yxsp8pgFh-pIV7`oN>Dm zqxHdhYQU3sq2-7D1_$Jw`dR!9@IzIb{Gftu)ol?tEk}}%?Cd!E~_|d z^Efc8mOIOd$c7{spWgb;${i>Kzd#)jr#YJd#DAMG)4j45P)BKOr;J^2@(%9VcL=Hd~y5r=cCV18H0O zLm4H-K9FA+6}nO7m(J#~?-jgS;g^x%9_5#voQND)4eaWzSFMl=02SIZS}}jIzmtz# z@DWrCDlvtRuJ4er^rzuW$_}*jvF?vvFMPBdr~fR^g1O&~E(VCQ&vNk3@+{d%z#dgm zVY2QP3rjZp^)6wv_-SB(6i!=ksn2Pt>PwaaA9GxLoYoDnfYT5fCOD0Cn6&qtoTr*7 zGZA!*GHM?aGem?V^z_ zS*Uck){oWsAl}6+rB4GIKrj(TmUdR-;fX6!#N0H2P*R6ChQ|H#Nf`Q<8GnY~P^4M>_ z8G5Y(1pOtdVq(EGL8HGCknRjJa1twnc>t{+AV)NV7^Nct3`Ai~8w2draC#?umz7s!5cSB&6WFtV}b(y`c!WHgX#^rRJ;I1KYS3&TzjJLm9 zAZb5`?a$=10CJAJ6Y5&y$1DEG_}cp|UTd_kEz#HhUY&eR#xA`**y1%p$lk&yNnk14ZnM#{uPY6fH5#c)FN@{mlyj|Rwm5i|qC@`2+Y&3to z9g>EH9n}T3r2v*db50E!F!a`NiwGhhX<~GXf(MIR(MwZpzWA)7SniGJ9I9zQsHXf< ziw;6tE{Eufio*8SqM~Ze=cp=e`jCuL1wU3+=Tcwc3lQdI|8YOM#DoIa$=MY!nrARu z?##B+V9?tlND!L%3e3v|Wc7`sTF8b*Qkdny7{}S$DyPsE8RoB7b7V60L3@1`+lwNQ z^g{QR5ezaqV97DP1O$i^l4Us1f)YY7;yw5VMy$$5JY>-|qGvdB@)#4`+T_sGCO>Sj zrC4cAz9T7dHU<5ZY&*5tQ{J@dbY132SzxSgZuf$*PiRpavNrusjBCOzu&gp2S4yGN<7dwj6!KX^@kq zeTnnR@_pS7ak&O?^gV(si*v8SML7Ek%y7=Qd#Xq46&yP$xU zB|V`)zl1!!Zi^mDd(1D*gfoYr(K_&qQ@z}2Rg@KQ3Eo2g)!4cNdK~9p*|4cRx%*c? zfF)shzoJ;E{8}-D`|_ts&TlPJ?F$Vu435j#1$BTB7I`#efsdFMSkw6t8!uCX1yI85 zwE_&fmq5{}fUpBTSZWRh7^Tnp?U9R{>CY5X3IT)FQ1~L|2JN#YPVKQfpo`MPWxANS zsmZl)$s9%!t|-J4pk$e4Q#xc|-YxnDS7B!8Y9}7oWmg1e0&1)X=69-8^F8V^;c~~h zYQXfLFWh%X2Z-kC&|Jd8*KgRviR4Qf4`n?YvXEw`;)KV4 z0zMSM3n=Cqo0^?t-NycMRn4$rPDFy#`i+@2U7gvT>o(lzMDC&-Ky%>-HypvT!3O;B zBG>}`Otu-~sn#ma5`~EZtmwN@OtNpp`wC}C55O^RXlavy$Y9C{@4C3MrO z134{*BzmHi{755b%zcaj49=k(qs}X9j%7lZOjhfXtp1aUHraWeSqy!`h6OyZpf#<+ zMffsZ&?IA2dknszInJCADUb!aU~B7TVzgjf*;$A@mx_g=;qOQ{(5*Em5hy%Bpd>&O z{ovs z9L8tDoSBRY2`%yc4^5CeS5aU#3$6NptwEL(MN*O~#L z$%U1m=w$0g0n28!WxX)Vk^2$z#pGUyHPkJZ#x^MP(QS}EJ5*nT{yJ5kNLAo89M!T{ zP%4Kk2o1>&eu3X5LIY+MyaMxn{X`11Y43I1&%W2RC~a725B}~z|H1nw_^Yhj=mMM$ zIb`%65JVuv=K%1Nc^MZ+^AnScnN)m=V4dD@lO*@7H`#ZNQde z`hL%q1b7(YRVQF_jP;mdv$^tO0R-=Pu+?_R1OG_J3Jkb!ZfdwEHikyP3%$NEkTLJU zmcdit0}>Ab1M3_$uHpytC{o4o4`CC`q344pBk-wJe|Qz&s!z#(0#85#*b<|Kbdo3m zb(Ld2vX(iYeS@zc2fbIsBWwuB6V?ZkfNw5I8v?Xev%MqH-e|UmItoTgb$FhBTMk>v zj}m;AFOi9#nalnTy@nM64Y2 ztpcn`r3)iOB$_{r%oL`@0}N-uV;C&$c>TsaCo*skyp7~d!zv(#8c-|=yvzDk@UYhB z*6c*z%Bh#KN!%_c7(%7Vdj2)ABYc@-dfuhj$rswV;49)U%bf9K%I^RG#F=VaqFtYA zTcY33(k1D_&xCOhLh?eBb<;b|FuPT_52Vk~T{rxF6jES|*cL_K(DAzgDy0dvm^PyT zXKD$@3-6#&uHvou05?AF1B~Z=rwhC?QJ2%o0N_t(2pSy7EZeR4D0A&V;HH?J?+mmk zWnW}pw#Zxo`CJ-{f@VMfV@om|urbSeFCeQ~I@xbTUdBuEGU~k}|K5$QDDj+^R%JOi z?S(*|Nh&4d&d&IzF8BfaA2{P556P!Yr{Q1Hc|>u6+)-hyENAS-g*!CwhKhbKw~*&2 zvX*_0eQqVLP=(dQ*q58&1k0QxHg7cYX?y{dtse%XFbZ-Xe2j6Ewb3 z7UM{#>}1O;#7;Wbah02Cu4|hy2zy3cvLW@2n}C5%&iLa*P7~vHBCJN0u^;C39_Nf- z2I$6a{AJ9a4};Dpq+a)-FA*2>orc@^9Yi87esFR+It^S0fKS=CRXmY#nRD0@=O#VY z*dH=gS~}Q2xK6K?WWQ;6S-d2(({<{VBbKPnW<*Olh~F;$b+D-<@&wy_%3?dYr&OL< zUEelJ#%`2hHXO~iz1(>h!wQhhGYCrzBkIl@F99d~H-`Cu@jLM+5VeY9Q6-?vs+5$F zU0iw6Q&?vw+g-1V;9i)<4OsUiZiTYL(VP;oYFp`V}uzX?=CRDy?fz`+yX%rQaXJ%gCwtb<`x!kz*pJ%$A=h^q>{os^0 zHoY!f+;nr>D26J}v0V&muM3Mh$^bSlY0ucli4w2-XQfsKSeox+9x_mUjn80*vQWXx zU3;ox=S;!Q9#Xx~9(K|YbN9%$5u>AjqW#g^_Mo?*i}TFDcG~lYp)B>=fNqdu;J{9M zIO9D@>#yJ4X$Xt-(;u&2zjyT*f}s(R`V=dP7_r3jr>d!k_s+lz!47P4Fvw{;TBG^a zfEsfk=Dg~*kwN#iQMyFT_RTdSmG(^|U#42@XnH`o6ETK4@Lp{sjXUKfnIo{Pa5Z|KYInbsTtX^$ z&XsIZkcw^ladx0!Jn&M)j?D(LGHTo@G*_U-wz3nwn|rT~hpG1K*XKD6a&iLPLkeSF z_1SE+Oi;;f3&XZ9!W0pE8?)6k;q=L?Ax+0Ic!5wZA@;F; zx#4>z3DCQsUUo&n*S1t4ZX~!#yctQ_n5@l!$9Lk*ij{6o!(;yje$b`B0Le~tPl-2& zPEpF|lYIp1&`-e9#BEN>jD*Lfn+{v)9zWBUxP{%3HyqFc3Ce>EB$Li6zOsha&cRv`q1|W7+vkh)*f)H!)&5ZN@E&_BRP%Bx{jkq2JC$LIKE>F8qDxXkmmY*;?hWWTzAOejjrYVkt}KwzHd!a*DY=6Q}5s0CmeGq3w;hfd9SiJQ>H*L_2veP06p)gihf z6ZxC9U@07Vle~9z;@(1g&!>YIIxBJSak*#q?}u5CU%&Pzg6tGsay~@rPh{4*zK!`H z8*F8ngKt-@1M!x)oC5(7%aqihX>k%tQrO&eLyDU6hhRRvLw^@H0!CeCf&4MZn?r4- zh;-$;F>zH`RDov;>D9nW2VdZnN|_{b`Kg?rAilB+9J5Pi(B;~pOY2n!d{eZ;{36VO zFK910FiG$8=ZTue5W!U9k*b`*l`>)2b;6GUiV5}^ z13y)YS>vBPbNNJlEJYlr+J@=a&9V*K=@JDG(_d& z9CVqsQsy={#_yqLhZoMIcJb_6C1)v?45XdvK{1A!;eE>H$Ckl0)i^Y|fl;-eikv~*BFL?CZVY7QVi zM2+}LD@9Ah|8A4_tv8BiRRz&<3`;Z)rl}>sm1LhPWM~{z(9;Rw)ex~>_N#r=z`CBT z;K(wk{-{X6U`5iBzR@aqCv>yCL)_WPt}L@>i+7}b=&?2W&d)Ug*WnQP&2N{iO}2!G zsr4BAU~;dfBLV#%{~Xd}7EO_QnOpn7t~`Ond~5YG0LR*wfAQpsw(W}|%NNaDXZ+u> ze<>nbn3FYFsewv3#E5t>pl>t9B-nCiyT=o_ zt9b<8_ z%a;-O!fLsU$j8+~QF^0&c(oYhXHNaySp>Fp5wJ@X1291ja7EInBnon@B7ok4R+wc) zu^Q@i`TlTEdsvG!jo7rfQnQOz&Ca$kCtrn4bWAkG&`&(ZXC_b@k3r*7_b3X71LRS% zpd0pdjZ^;#nHHQuDJKb+$rWWO!~Apw z6@+h%l?Ug@aEaI16M|i1e(%(eq|*xAE$Y4y?UoN<^U`_S%!4k> zl2T|i`Np3(AI*9yt{#AA36Ys=Q&+U`_|hn7q|b?GFhVXDd=w%dKby9#e*Ky+4j$FBJ!HIlRyb$0Z`|YS^<+ z&Sa!5vL!Mf&=2wccndEd$IIII-umruHU()F&&5}WvTaUgKdJBptNInuC${5@%`I3( zJlJQ=VAPp5;Yb#%(M6JzWw%*ocgzM-n`2z!9$3|&dP03EH6h|lsk2~9!F~3iRx30g zpO38l`}8=N7Z$4$3*GW}zbK(}-$b6ICa~y7)ph(b@l<@PL!L^ylz|m9Stu7gf=!|l zqGcmJq;ubWi-mScbpCGlMCa8dL~@;=$XXpDx%<=;faH&Bu&m6-&WU;PcV#X;iO~so z&2(V#>tF3GyP7RKifO?gEv7|EfFMqx9K83|_>-*DdVgU%{v;sP?%f<&5*mw6;jo}D z6lEw?r$^u?_)?yY5>2rDW_OfIDE;YeDHHe_7|I1U*gsn{7)d5=2S_s2+75)OY!gOU z+y*kmq9JVEiWS@E720Zb59Q2DCPJe`*16+lw#ORwI(g!*vjCoBix1`tWO z)c}&2tpO5!2T;+Y_=;eE^D-thz0`Q?(qD}wfK5jok23euVuDnMCPV~^(b$kIP))vXSK1|yNxkA^e#-0b zpU1o_I)Oi|Ts=cIBl0b(AvINiWlhCg))WN+(*9oP|X5 zD*IRwzo_A7DK@^Wv3J5|@CD>U3smBW?;s$4=3TroKeDrGRspddm~sz1uoUZOez2J_ zK*2I`Fn8FEb>HVps=<{`WQmZ~pQ6Fx6wQqsnoBUXdF2_OHw7DNTY(Mp)3E{hue9Nr|2x1<+?E=Zv_n0Xy)kN5wX8gvQQ%Qgs-V(=Aue+F|_uX>^0>jOU1 z0n)aWmewMwBTmwl!_)X67jDMNfQj;aT{*1#7hx$RQVH0ym@9|RKp9*aRt|rTm5%+p zK<{FsCn#lXq$Ik$ z1WRJEs|j#o1QH)2w9fd%+aI=}G*$ufRl0-vta9o-K$GATmkU_KrM9^E^w=c}GX}+a z6_nKfiU993=&(UpqEI{t>m!Qr8$!JK_-%mm!eN*78~bbDzWtoZ3kO8Lbs~?*&$F@N zj(pts55IHjI{=1LWBnIo5wZBg057STKodJPD*Otz z%%GwG8|Rxf2vlhE!^HhG88IX}{sB1-3s4Te8P9bpFrBmg715C0nS9L4{^zJsNy3^P zQ8kqAJo+|V$=%RXpAZqrr}6@kr&=^8)2d~XR_zHir({r9u~X|#25t4}OA_&j=AfqW zK`^1K>Jh2o=rUQF|6x2+N7YLJS7z6-VBxgruoF@A)BYeD3%6_#8gp%M>W6@Ih^!WY zDmJoeYa|Ve6C?4L68bq2xT5{CR3fmB9NZI@<1RVMK{ylP0`jknd*0U}sAVj@9ePX- zbn`J#c|(uM>mSQqa%6ty0BAi*FMf@d9)nNoOQTD%1YD^d-GqhArsxbVVEznin9YIm zaa|ME_WFrje_7^KJFjNFXD@WmfyyWeE)xC06)}u6v70&Fs{ZS!BPEK%oD20|aj6%E zC*)7QB%N`w^I(n%LQITTk`R1FQU%~v9k8tJrA*}wf>`I5)c?<()ma02e--~5bYf|= z7o)Lf54X`+Y4j3kozn&^Y3}dLzCi}r8a+C3O{-Y$Aa~NGe?U|xn966F-tycJ#RY`<^1U!2>{lxElLAEtG>3( z^EVK9dOzen*N&JhZYgpklEZmt* zTK^0?ryOn_3NQQd25#lew9kcKF!m=(@ZcmFGX#k7j3!y=ErO}UQwQ;j1X?7~kRMfH zQ8Jar20|LvjRwGHN^vvd2Bd9T3S1xHzW(QY^AWgKAEa|H&V%05b~;~T3#wpSsO@(rh}XgE+K#k z5(r?f<`5E$Pr!^>FfBx-P=J-C;77lAbgQ^3g+;F@>GPxGU5F)DrLl`4vZKldVgHNz z>#}ivMXUg0e?$z}pjcm+Kjy+R7#3{T&0AA=%bS({NMHL1^X%&+8SaNNZa!8zgO?u>crbH;t26tI z;>ZdoqC1*euY@P^G3fED9JdH1L(fYU< zc5++n?1cDimst1iy(InCO?P(kSwM*%|FbN0lI;x}T-j@dyR*y^FS68Po|>$VfO(pr$906g&znyDKV%M4EJNw*09N#o($bB>URqVJq``}gd=Y9!yj)<)ra)A& z!FA+1a%whulyD(6M@}CTyZ>mGPa`mVS%s$fMclSp*;&Xu^sT}>o!#JVjw^ne&DGN8 zxEA@1@>!rwP;3FxcL6dGd_a+9KDi?0cOegkqRr7qn`MVp4RXQIU|6FQ$%BN0_7_Yw z#n;;mAK|k3tjK$iEy6lScw{gqSC%{V_sHamhH}pABfD@quz^cd7Io?Z=M9#Wk8^9l z*JZ3*qQpqKWzq{EmMf-Jcm)|$W=I<3_bs=D$!*2t=_0;reGxE#7RXp`LlE>&#HXo2 zP+JUD_fjhaddenvfv5TZiqF=ErITY_m*dydaDR%sEsHqAvPI-q^7wbu#k&Vjjz@53Y7WgLVCw{-&{=6X0PlWFc*cy zr#I1d-MYEB60hg7A>IA6%pppJ3;#hPH$5i6jweg1meQESa#vqCVa6T3gmEk-6TM6l{`G@| zZF08ZI+w!JreKs>Pdi?K?gwCEavytLixfS-cg1%^ie(s^M2ZqLja|T43WFYq+(Y(d zm)-#Gu{u(%)Jb12!cJ{a>7^Lt_5!>07$H6cOND48q?^qv4)a2u3S<#Mt)=J`lJ{2$ zUa3N?T}(5)Gtbo5(2ZzvXb##qvtH^ZVIuiEZniYpBlh5%{xpMX9O+GMq+~Pcu-_up zh?{@zpj1c_<&?~KW-%~=KG=Fbsilo2SiX6UzlM#8tB=rQz+Z1V#C$hgLhx_&vPv%> z>Scvq-jquMbLL46&?CDeK)(?C^#+sI_?(>oL4EQF>~fWI{yI+azViWa7BI#_i(^P2 ze8|ByS;T!$2_x`fpkY1ET{nB7r>5zCH!1Bq<8}hmq7RqBN|?b4%$m&8W73qT^E^fM zhW)m%{7e)fyqxBxO(*c7G692Hmt?L`^&xUCIs{0sqQ%TNk3UbdMkD08@Zj4gRhyzA{$*IPUFu!!DzS+peg$kcP(Gb5zv?i%8jr{3ORwIFUjhr6ixl1_m6$4%0ft9G}IldQ~HCH3F zZ2C8G83rz~_d9nw(-Sr^Wb}yKB({O4moIw_lh4Fm@VfU;^hmSx{vGY~cx)1zGB)~E z{0S%(L)M>DB_hmrdMMwV^Bg8YE+L3-!D(uG)hxutns)*g^;J*%%{XkPJDWN18e!z` zb^%v@h_-xoN#jSJj|yjK7{&=+$sv^a2zIa+*SrvD83r9kW0nU=^G8nT04EM3!A2=S zF(0m9kT)M2X%#|g`d`fr=&+6RQKdeA9GPUZeck|(bi)7ul*hRpecl{?ija0f*S*~4 zFj!WOM@8R7fxZRIUyrw7VzyiM+0Sp9#pf~tFm|pI+^om}ZhjABC2+$JY4Rld(QOu9 z$5S7C!ZaBk_Axs?Z2(UFBHUWkX|HSQn ze_SQFdS5T^>Sc*sV8u`0+jqV~3$9_(5By>7y-{8n?f|_!GAIST>G6=4ZGcc(ViF z>>zJ0v~PB3x)ZNKf4|O0y;D2Nd)yZ=@Los0*HPY^Y~SnHboYShyngkoR`sh}-&oV7 z-yC2*Lym(S5M9!*{_{2c>Nc$6?}*Sc;tN1HJiHzcui=l#U}eOg!H>wk#vj8~nCRAH zTQJeNxJM)fnP|!|;fUMxaeR&h75{EV%)tQGkdL(-uIR(#DB*%oMA&DdZ)6z=TAH1-XSn8_B*T)+eT1mCm$AohZeZb?5VpmwiBib&Kh^x2;Lxx#IxvIy>Jn1E3?Gvu)GGA)Kg0rb`|Yy|2O3P94$ zb#Tz_5UaasXDu{R(>-bJn&nprP44Z2G3WYvGf5Bc|D*0rz@w_pxbXxM2%9%3fk;Jz zjv5tfqM$)h6AXHz0i&XgiW;@G*kX;6(WnR$X95|A3qjEarHX5DX^WLcs9M7!n;Sw^ z1S?T0-f2(~w*c1sf4}#fd*{w%vgp_E|2!X$=FGkKEbn>u^PUYuI=of$5z{HxHM=q> z8R2JDaNBZHEMR0DAzMDWLDj{l>Yyq-yG)U&x-Ej4`i+t_tV2?21yrJMk#1l{b&E7} zMFu>Zjk)#fH!WciYs^7BkpW-$MzFb?ji~TPIVb zj?J492PP@P^`SG_2+Eq*Zhlg&bH3iePKPrIF`h(8MTobTrX!rPsWruJKR=6-phDMJVl)!%?x##LEr}gba5O3vVBi0eIkX-=-;3QIATFuG(GyJhAYO8 zzzXJ3G03pLe?RG{R3YbHGC(A2%U~H5^HylVKBJW~9A&QPe<82LkZBj51n1);`OB#-R8=0=Ugcoesqh!&GV~c5$GiuzhD8+DuP0q0qN#zs zI56gMJgD=g!|$5MY{kk=WA0sem%qLxO=7{Lzq<3+Mo{io4sX?50ZY>}us>}^eqeu( z8Ak^8r}_u0D+~RvL)fxG9RL+vov{kv{Wd-G9fAEltG2a#9oU~Sqkmw3@2a=(tLl@M z*8=#Xr!yrlgIa|1OokVferH_a2Q0;- zK;=>Js?cGhQ7u~wt@mHzg0nUifn5x|iZZj2MzSUkf)256%fJ$YBf!7kWHVM#lmS_3 z!grA&>0{06MR?>*x0{f~UXcg(+p2SkpF5+T*m9UdfA)0L@vrQteZlt{heo(548 z*3Iy6Kbnt*ALPgdH6k*r4#1Qo$AFaum7htVo#T0JIU@kpgUJ0zHueq;LG=nMhU zst)C;>i&rRRV`~l_X%zWsBcmyldywMbR>qmqy)0^WEd(TUBT(S1U{1W-+`jqvY^_e zZ|+14PvD|ftFV6q9_A9h4bf)tyVgV(BDD`ngL?ZN47nqjDvimfjJGyXG=sZx*>7+Q z|0rPQ2}XnaGK{%$G9~U$HRird&~VQFj0#?&H;O-v+M8GfDGF^_ATB=iL}seZby}3I zY>WsCIlRh&>f$~1-mLZ{lopegkSn;ahyS?vysS3Geg>{)*VX=QKu6W4&-ex4PV*lX zU%7oR)+;0fBo18Fv+T^|AO!dI!p5ZFzTU|oPqn|q^0O`>SDjqb{j3qJ>_}E?a9@98 zE)Q)2Kz(NrtUk%X`p?kh6}0Pkiv3ClS%drfC9nI>xHLH#a7pS8c91o=?*M^*K=KxL z9oFp@R&&63I#Xl6%eb=K}@q@urJREMN zPsSJf?PDRBJL1_)k@t^BbQ9=Qds+ust@J(p+;P#YYn*Y>={Jf^9-IQ01E0|Wa~tIjnev?sA{bMJ2?t9n3Ox1aepZ{vZzi;tTCA@lIX-g=C58`=Q6 zq^z2^aA40$2~>lLhxLA(J6~80Fo3Z-QT4$UI4*Z@?_2trYXf{iX9VBGmej7FhOvCT z5T+b*!Taiwk^uz_dNKwLcTI8ZCQ_%)(7y_ z?8-wUbcu4A!X=UvCXgTrP2fpRlv(8q3V}!?bSfT<#-VTxjgTQ9=Bot~YkMdkWo#zo zC?zs%bwASVcHC`e)V_mZ1E@3ce6s7?4FIP0 zRv-p;whYapeT|2j)kF`6AW7dlz+(uJ4ESMBPd@~G8ucKP(Od2;CirGM@BudANwv?4 z!Q)@tQJY3%4OzozTqwsV)1)K{`Af343UQ z30m1l;>1dS?ac=StLjQDSi%(h_1>O+@#351&?!)eJOrLb%#na;y-w|~L=O&6vGYxZ zeO{vxdRVV1awuRQagO>5w#9By{Z-N11b`R^_Y+fG%6kBCfg-qV&K`&j1}unrGdRy- zG-#^IaOnd>ukRaH1DOTRUyh`lBu6jBwN<@bx5?W}w47q^?B(etI>^XFTrb@S42Txr z%k$6=GeTEGb0KfQ$>riGg;k#N7n0hXA(w5Qn|{=gt1p>Z)H z)IJIQ&=I5kuijJEtB!MFP@0X5rW*i7GBv%Jo-%G-icu( zRTMuKm$=euEj?+=GY^S%z9Q)VZgY-+nONvuRVV< za)-oPt15DEMl#w1&T=Wt>+h6w=dX|MMO^X6;_ZKxU$*u`W6pgO>#U;}cLE7i=nNB{ z)~|=d-8m8~n~cT_Q{l)Mwg1LaXvdH(gI-FBX2`-PCG*jqcnIvnmXxEYvosTd+eC4% z_g^fydE3`RoL6Yfb|N$oRdyso9pS-*@RV!ed3#+u`ff`7$=r0xSVct&&zVklqz}gz z#poN8mSI1^+)^2eF^PGHM*<1B$E2t09Wom7+52uZB&jqa%LZhzpFfPz5PQlu@RZ)e z@xXeRn&7W~LeU5&xlgBV8NWp8mq^mk#Kc-6Pu6WP_}ga`nV4EJ!wr&gZQ6!3W})he z=&9BW&ZLt!>>-|U&1AZJCWfkI7^-6NGvHnK{&ZDR1&&02$ta%7W-fo#3CKX_Iiq-q zo7_vFB3Y;QkRkkm7{Uv9vI{PH6O3d3THJzgGf&@ zMb@m#03@b7K2*JX8$j04Yeu#vNmRDB4GfCUdXBlm@(PNx4jF_qD!`MI>HG5yiV}T% zV>G5e@SQ+?jsrD*bPe?&57byaK&VOm0b^X|uEI1o54`xda?29hZ4U|YsIH?!WkzFt z0C3U`O(#8A_j9MYb>rS=>4id8ll*p6m%^D=U3Wlry)~m)U3jl_+}gCQ7^+E?gu7aL zOA@7^A$t;r=qkeE#B3c*QG1m`g!;Y{r@h2&rQpc2@IN#q)m}i3)?U;8dl;jm3_uEv z^&Z~WqL*p~R&GZRhQip{9zoE~VlW~N^@M-)R%0%48~p}Vv48nHBYLbU4Wtx1W7R;H*{isM?rSdhc0R-K^{*V3g`VnVy^ zA)!iq8n&Kn1e@ln#M}9fbw3oV8z=6^a=OF3(?kpg{NqdXr_={Ir57MSIuTg<6O4ag zc_dXK)PfOe78Frkx>je2yi)$4<0>kBdrpGB#a1`1ZJL*QZvn5wCKOeKDzQ0{L3y_G#@vF2ZjYIww`hulu*?Wkw7FZRh*~*%1N3-TrYQH*PRM-PvJS~i=p$J}zY#KH8L8J4 zsU;lfWwgk(MgcA!-QFIz_S&<>43(*5xk|>Wq~E8oMz>(RuN?FQd(?wEC~iDO4N^&C z6s8{sMONX7LS4#tRAleudt_{+D6RBmO>7F;Zk?4xo$ntWh5gcYaG}vh@?c- z@f4eYuPz3;8O%bZi3%|2fL|=0BGuN3*ygJ|Md2N1@I{@)RX95~I7E!aUfn_NEsaTu zSmEldi@y>gb}+~_?N_ndvn2{WT@9Q%O(#5}zsg^%r&i;P|J-`|i;pOO@tGDu?>TYk zh40@ndYutVwk8(+#q{VRx{C3D*gO9XCi#eKffD#5z|l!Z)pVYeMWQOT(G6PJn8g?Woo@B^bTEGbo20hDfNb$rc8omXqWn4xT+$m{O#pb8l zr=Q@FoMr+-a-a)M@>_Kw(jXm*w{;j}#o0P+Uw0)3X26jg0BE=Nb|j~xG1il79pOo0 z=te)ERCr=ztnA$#8#>44m)mz?EosXRjaBs18RxZs!-K*81!e{sNCDFwLPU8rCj6?i zxwa1eJ{MYA>DPbc03SC&!qG;KJ?*a@0QoZXQ1y5R z5lJL*pw#0?Vm%272*W)dd-KI8mOTgsRL=P?cg&1wA`P6}|1@t2#l|(m!{Bs(V{HLshxm z6U${`!P^Zv+P`V%E=J#j?8XHzzWu-fHHp6L(=n(@<=FobP&@P(&k)r@Z8M=afZk3u zQysk!Z|y&f5&d$MO6IC0TO}WT05!7^p%)#>l_WvmybpVj++Pfxs%%-tjuqrHLGj6ak~%o$-TNnH(>@9_Ehx|(D3&)?M5&@<%Q z-`3R}$Kvd%(U=+7*UOmuH7FIpt-GNO@}rj#T7(~ZH7=Gor0-gG7f6Za4o2fjY&1Uo zXsqN;UB@?t`1-S)hZUjWN)$9{UxA9*w@geU!0jSZ z)XbTaVH&&BK0{z%@2X=1`}!EQnH=7^_5Dj5gpTXeYA_*#?Ry`jJ3o$e$>jHbA|zq` z8_+{JwLe0*gP@Y}CXz}y2?kHO)KjrMK^gJItjx8EO?(nJ_|_wJ3uX zYV>Y!z1rY%6_$Or{5t`(&L8c_DB-?AD!Ef7y;SnnJ7CG%;hx7>GJzitCmK7Dr+JzS zg{~h6avf2-MUSZD(_h_Bkvb|WEJmB|EW$)2JaG}G8;y%={-1xq{m1N8s-QbYANt zBNUInlf9_z41d7${|)>N=mdX#lHsrKkHuf;M8V&kDmiHb5_NPz28%+mwt3(aP>@es5PY7Jt874r1*p9NN1f;`v^ zbS#>Y>{fjxOZDt)TJ?4AuSNP-cwNh%!3mz7TJcZ9UcWHIZ<)t@DGYf){CCrufIvJB z5vm7J9`5sR>8yP$SQ`btMCE<_bGxj3YF@13zJ8p&+;PWH@dsd9`@1|L#%`5FCDAG& zfuHYH_9=({Q8xXfY>`ncV-U3QU`R1xk$HkVJkMXrN%M2XNKNtqw&$si<-(U{VAW_0 zQo6C%Hhmc$@%&sseXmNFt;l#muL=dK1{#gaNw30CoBlW^)eiudE3MKteGvA5*Kj+_ zI2uMdf1b#|aDUH;SqT_Mld+oXSVb-=8bAFB=p-r+ax+>FXd{Kef1_O%^ zV|w`UZu#^0iPqKLz%kf`{jPw#e5v#P6+FiPGUhDAGb)8slftFM_dX@hRatd4e?t*4 zM}gR!Y%pccsxhfmpTf@?0>>|FnOgjBPg=@zrPJrX`xNSh?XN?AOo2hq5#jic!HR0< zr?qS{enzsM{Fhjhf$&rK0;dR3(F|#+lQX*4*@O3CEn0YE%TA)TcW6`eGVm9Ya+Q=K z83U*FaP>GAiP{$4hrd9|lxPe1#wolGzfpLNN?t*t^4y1Cpf~$Wde>&+*|T_Q1l~uo z_J2U9R5sgj@sjT}9=s%*4+_v@G8j>VFMaXFzGClMS-b>Jimrg+%HI_I1H(({Z$W{S z;a38`ZX<$%y9&v#aJTsf=rbV{Ch@`}#R#6!IN+prFbu)sXy}9re8LeT=^)Q3$C_a^ z#5<+4NVE!9rr2}zLbF`BnB$z5%Gpw+zD$w^Y1iH0#!4}qf|qpB&ju9WOw~ zWyg7$;34)X9HSoX0dJz;8K8<|!4vx5U&(6)`;Qm`|DgXE&nUi#)RT40NQ08zZ5S6s zmelbT?+b5|AKQ#MJU>BoKej5GFrVPSjP73RR4m0K^#N6Jz0|ROh5=+M|Ee7Qs=!og zf|r!$LyjEm|I&2=h5pxANP4ddB|PfE5b2X1dCIq3cIs7==OmgV(??@5Nlc1b*4fPPIF)pb$bqeFY!P znENa+64;wsRnDi{5DQ>GjwJOBk~AzvVl*zH-VT17T3CnOkS6#gf#!B#xJEQs9wIpf zs{(_o3$RF~juk*;RILrHHEDHm!6o~nLy}gFgZUUopiObVs$v;eEPI<_DHLef`H?zS(lk)}G^MK7I2_4XY{Cha9eV1=^~%u2sy zgtK9+|7bDopR5Pjsecpb{e;pF9+!*yNH$$#=TJ$GY)U!?nT*Dh3Ijh3H)@4LoOOy< z;R~#5@zA!SKr24p07@;x|0yj!&D2(I2)2G8t}*=;9HH{2^&DrJ8*$i3A7j=Z@a+|5 zr$s-PXSeu!%X7;L?_njqUqR87mOpt9D(U?SZEDK`_mGm_uOPIL(o&b-))JznM1aKI z){Rvuur%}DbuG=oK-au8;14QGlLKbcjv+o&gO!CvttQI=Sd>S$Jc zMZ-ISD1#7HOGWn8M+xg*rjjGpf`iY9DX!%H>A%5E@k0o1RH2!_j$dd4u&)fvxdjKq zDCRVRN?je&!mdCmX|G1$XX7 zsb;(pj(j}0qcyO9Hy(u_@5416^LThw9z2S(z+Jn>K9sT?Dn)<+ld64vav|F8%{o4} z-j9j)v5e2r2hyaruig#(wxEg^FGUpvsG{XXYw9a#9Q-NZM(Ma&Qy=!e8jV+h{oqcO z<5+nlbFR_1^NO;HDDQ+}!*HY=sEQ1@Mxc4o!~+-@3jALFq>GYQ7p%Zfg6HAH@J9QU zF96}coZg>Y>I#`>1Rp?bW2d7(%CEpfhwvX*OhYPcOx)RLtu`o-5{d+$H5ZCM?Ok|O2vPiXwtuPIIgPpQ< z^5yPD0+hNe!wf&L7>|)rg$gd(e_rKN&blIcqBDFKUyJ4$%J(?0&6wQ>zl_E_i0AP} z?S~R0t4_tR9#0$9QxEmD5>Fzp`E5nZP!BFW&^I37l8$ltpW)b2++08|nk<`AN750k z$X{Pq>cgQ5i2LVns+;H=LC3jFVI3|JD8`2q%y55rZdK&C`MyPh4msxnZnHgMXb-Xf45d3Wya~9&{y-@N zcCCb~fU5DAt?(Af6Yv-97SpOcztYh#bG*c9#XciL1 zqez95%y1g8NVx?-nf#b-*AM9-`ZR}fyP28_02Pw^RCs6*_PWh5W;NgoQFa`Na~zHk zN)7DKF=`(HC1{x{#4?$waGRGZuEqIw^RbU&n(vrC`tv zfvJlAPVT~+cv_GO;E?D)Av1|4Z+<(Icb7JKeZ}NOE1`jK4JeOA3+x|&y?SUt5W^rq zi1Aj!J*8u~6~Orpz{eK%StXE@XG(n|0C|xdy`+F27v5YH{=O&-y926?3$MY|AnXtM z2@D?1OwxzCSReX|*_QM8;=6IR>INet4r+lgR65aj0-MTbBScg&5XBAdIE~4%vIoi| zZZ~@ay~T}g(08~gg1<-qU*TA~-CEKWu~PbI~Y zv^NAUG*!HiOo*c8w1VN-nV1;Dp(RkRep;#k^Is4d$eHrqsOX0FGyy@*rj z75ox(j*9XpUXH+WbM@%&NEXTxf(Q;JL-Z?<;OS7=JG}LSs~pD~!;I_!a#fdWa7dM(7AU0_Iu; za~3~dpgx{?>#vYy#H|JRdjw*QUiezE*nl7XnF5dkGWs#z>Ywka45#`JPTGNG>hqaZ zO)YPto-1xW0Dmv9`YV4|J=^kkq<2(3j=y(SJ=F575&SQN`D|#2>>{WLe^!x*7!}xw zREL$(OsQ{wAL_N1PpMB&E((5(6Cw9C`417~om}*H`n9}Zpg_Hd{s}9D^|#>1I3;pl zb1W|yCoXS|H!lv4+_yWH7c3l?_hL6M1lHT&7=EaGU2Td=x#@!e%7%C}hSn!^Lz~ z79$a7rP{1n9l!$=Yq9S*#HRk-(un)(jM^z+1Kw*_d#(I{A8;9dM6bjjh}qBm*+yd} z1@7nm1MrK2`g0?cgYCNoAX?vpuY`@lj{1lWhG}Hu2>+S)j7v470LQ!jWkLhijAJEvhk7s#Be)H zEO_#wEU_q%AH9rPh81we1w8Qb$!4Uog2!{rWuzVSpxeE z6e({<*=Yt1;Q-l>;|O+=9=5vbN@<@_FJ_L^D_>Dgt)YVf6E6;uL{elL7g3;)K7NGd z84E2Fu2KOnKB68c{*~}(G%h0-0y_UJ{8rI)+#f`fBT6U*ff)z_o(X#e$ZDE0;{Mof9&SHk$|F;csu^#PBm{$_yvE+hNp@I+-`v=D+> zfMMm-t8u@}7w!w|COA9qP93+V_~6tRJ#XRaygM})Z+pDL6RdjzZMh;nnFtrFBgjR1 z)T4duAkm9QsN@ipe6kdsVWchr{?!WpTn_$nIQRpM@RcFk+0Z5!zTMd)e?9$nsPXzD zyuuFa{@`Zn8fpGOs1aEOwBGhV4_ zt{n6wca?iu72iuA)%%2O{s#d~p+MuWkKTrE*=g+HVfYnCt#7Dcp__^Md_2D4Dz){id_fY#Nwx z^m|6|Rn`E@QHaBNPs8y26w~?zHrX)xrTcfJ?SI(qpAnjgM#!nBG}&om`cCx+n;@@@ z1%~_kFksKH&xz%(!WD_g8EiI?b7Z@m!(us&+OvQgcyDwuga=fBE7){O%ZB8y!|h)a z5Jc^C+|8Ot=?VS^e7YIx@jYRAd1b2 zI%nMNFa35!z&}ui&6L{$c%RR~W`*Aje$*V;i+Hx25!|vP{G}VumScij-VT1$8rX|? z_HsJ#Ei17$>L0?B%1fZ91CSA{qq~D6R)KULemY1q6n&3Dnvm=iX&4=n6j9bqaj|R; zFRh#6V%aC*Rba0h%l65mie+a@?oH@|IOY=`4=?4EycIZo-V zif9&XemnjU&)?M2C%gfd{V^MXQg5?$cI<{+{*s5x#dvQIxgPu@`F|QNs$xbuc ziNSCWMw<@Q(WWi*YYQaWlNi_fI2IGqQ#l*sr*c+cD(B?{n1LQdxM=F70UiqY2!Mwc zIvJkAmEAzlYY)c|bQrr)wkANEiCZI3i3C!@>%wnG&jI7LZ@jO6p&(=2gE3@?xPi8E z-ZbbKy#vH zu;o$y`2+q$O;Ewr91zf4^a|bRy(U0^h=-C?iz3m&5Oz%S-y0M*;V&vhQWhNnrI3I| z`=maiJ4UGFNR=F_k|8R|RLT2KL9Z;;j(vhY$zV)9?*1q&UKzS1ws-|zA7mceH#=Gn z1-Nojxt?Y?mf%d+qh3hA5t>3>g%3&-HNmfjghFU}wi6DIvECK+GlRLnyAa(mgE1Qd z?Q=Zv1Bn{NsB0yc3ZwxQU~n=Pp@H&&24Ywp3ZR_^x_d#4hx@x4XjDs00tTf%9PdJ5 z);b9H(NAx{5{T*dmRe`Em5yF{=iQ~4-Yda0UT~vmq=|!51N(A}(2XE2VX+tLI6*S4 zbbl9G=_*w6Kha7+8?@2_bVT$A7hrPMhx0w)I9aLH9n9rvr9$1^PBo2;siu+O`~+kI zg1-LWyCkxoxId;65Q-qlNn^R~E1@WtVKd0V!Wbn2)njD>B(2w&qpL8u=pNPQ|2{_b z_L^%PFrCn>TQS~e9Bmih7n3?Kz|%S@X+Nw-_$0o!kUn$E^1F#^pdE(iGzCt_Cf8fj6O_#w<+47l6j)`nyB`gsP>vf?LmjU_l)Qe z9GB|Q4?5&zdJ7$$(-}jW4 z->Bqsm3*p_C67ZB|Y82wUjU45cp%fpHw=9Hkm8X=_@svln9g{rlq1rZbCE-z*v3dglS-t^V01 zqu1Zu9JNpg`fwyp&pnJS7P5V`kuk}>=^mG*jnMH>vmnLDU@MN1-vI#&w&E&)U*HE8 zMTbt57rl*8fBhx26OEtVM%vHeAma2k{5Iy!#!pgIddXJ&c0Z>T886_7tTrrf=)qe+ z=xbUReGf8Df=-==W%5-2!F@UA!RyWM-ZuNZO@KDHs}Jf$!NR` zbG9!UwLR499>&Z}^%}mzEASoYHY%5u5O8n98_0>9kcSq2y9P7e_mB!ZXUG~fHM<;5 zr_K%e0_Z53Ci4Y(qNSG>7uz%HHO7{MD^jAo{xB{_wS9$~15Knv$0z2v#y-u-5q&K2 z{;*0~zU=-9+MerLbzemqj@=$BCZ z7W+XrN6*CK*V)tEk2|55f~}K`x%Z);!PcM6z~ztws*b`hqt=ISad`QaJz~-XK89T10cLV+z72#za|+neT;YT7k`7iT)$8) z^Xf8JPp`4mbY+qY?!4EnpDOy3I5|>#%)e6P7Z*zz znD$g_|HfXtZ*`l|&wfND52)l`mCRO2txBe=HGwe#RiA*|sEAYdPKXs33*bqvf|$-9ZLh^D_>0nIi52*75fuZ( z_lNUz@^K0RM1Jsq*&)soPZs3EO~PIvGdxK4jlgY&tJTH6k)AtUvbMX%62SNM_m;L> z?!p7aY_-S?Z;M@HU?;68(1W>dfnuf>C`tb4`4|A92*k|t7NPQo&Xpno|4pVf6=H^} z{;1zWK0GUwR8?uZD*tK7u3Ek+u9`#KYA%)cm;xMwK}S<`1Jncb2&aRQyu{?&mM8H4 zBQPU`(2LIKv-r*z$44K!CR)_);%^gva_RWrKCHqir4|Dk4d z|5xev@%>j-@w6tQl4?d*!+UOHXv7jNU5(#Ujas60HxRsYc@k2*m_&k}*o%@=H8ABh(?th!JY0O8PL_*75@We;z9MW-yEW-8Z7J zcB>?+l8;rgO(p+S$r~zJqmoxtvP>nNVr7QDe zJkEn*w;RC#^23c8OvftV$M&e(p}x0Ior0NrH`2rPFpwi2!h*y^!XVEd`G?^iIopJ| zjE~58v5W*K4cGGp^$@Qtoo@KfdK zA0N7eHbT#*cVC_^#-ck{o_^~sXg^TnGNTbHaz1q?Pl|19kjPBMO|yH9;A9lTxL}B^ zul_X{M@0n~9~{TAg5IvQu_(MHe!tQ`io>h0We&?YTiqQ?PsdMlJqXSCdow&n$JHTT z&=JmJFnbc_qTP?2TA|S4^n0a;GhQmJtb#@E#H9FN!MWnkc_t>I zLeil>-I=%Zfe2W*k%)K8K^}}GUjbo5XK~Q@Mfe52rL&O0cy1T$A7;d8Q_J1&2|2mM z8@HjOos{TYR20|`DW(uAiQH`j*8(6)$(KX@lwnMyZ>KjW>j5_WLnt zN{J6lcsaAwT)C>DN$W8t$A2gV3k#5izj&%m_&q&QADsrQjp+lranr%5(6*N5ga*mu z&NS+7s7XA7HRGmHO*9AYNIs4Fk}3n%jGIOs;4R~wM&-d~QW-d^-8AZrx-!o+>dQ|4 z#A(#W@xeQddJ@XQFXI#^k|U9{pGIZhf3lV7yGyK0PnCS%B2V9_7anE`vE9A=o)zp2EchdW**;T;=_d%93wVX8loIB>?HMr$> zmApfpgF9&43T%4((*rzIs=tp8Rz?7*l2IRj*efr0jyFJFam%ym-&K>Na_HY-zvHkQ zq&zOpVR@8N<$Hjt_Fdlc7$b0_EXo(MJZj=%9c$R1D%pNw`AoJy)>~e%MAkMeYw?#h`@}XHjz*AW06Vr+cVCWX&L^oAi9v=$y z15DRKbu%Jv!=@ndV$3p0=ljZ$M$%7gz?myeeuQOICzPCr&vy1jULneK&E zQzu*@RL4s5-}F^Mo{BYr1^|hbY$4xd=7?y1saZ`n;*luER|^0LbTU|`LInk^*}ed~ z#t5g~R!w$-x@lQp?+AlMuY{71cc5balU3|nqL`I_Ihd7pjm#=Y1hXn+s!Q`Q74isx zaOY|*>}OMy+U=p#Q&>VwNU$bcX22hP^}3+Wwz=Un70bdW=# zPzSZEcGm>hEM#AUQ?r^-5*NV<i|R^mXFZuv`MLHqSOpyfNrsYXi- zA98>8U4%EdD~GTlPRu{Rb*@^o;qA#t)sy2*Yt-JxX90=ZmyIuILbESagB&tvV{no~ zuwNe^2X^{PQkZ~`6~NJ0%d7TLgpwQ5Jo*Lj-SR8ICV0yvY%&(g31RQ{llKW;PcRuh zCB~~W+RM?>=N&m>Q7)y1!g*;oSqcgV$jh)lyaN}VZ@2$A3%hA++xy$MoR_Nl7a4XDTX{I1J>&ap%%nj>n~-!)d7;m8K4%3yNvsX# ztJo}9#6)w28JwW2orz-0j%HbFz-#w#N4LO%mEJ&$F_2c-O0T(xx(*x!=E+t4pHQgu zu>dX%RiJdFm44#IJa7iNsae63sG8M~=lCjHI2}K7_``k&PO2QTqz+(0JXco0+2dz| zuv}{BbUVg>R>;@v+K;!0&zfC}1g+2d8kj;PB?WUYmiNH)@vxWVcD^7XUJ~8bUNQ}= zOBTrtNrs-rz>r){%(MVy5!J0n0_7#LN~bT60z3X*G8T?qB&!{{%@>87u8Iv zzYS&Mz#^E!#?~b)2jpjPm+Lb90PN28HR%Tk*lgcA{gA_ljrt+i-Y#gKh9&A^6uheD z3@lF8s-_?f&^IG%Y9##+_lQzHgKLWO^ccjI%#$5xy%_wNK&??*vzi#EochkyavI_G z018Kp-uCaOLQIw;*AFFe(yWjxJYi2o9tRuh)U^vjpndPe67vv?(b#HT1n~#dEYf>WX#|yTo%4R&6u@Epg_P| z#e#UwL1vSJ6tL_YzLbXL|ZKswoX zk=k6lXfXSt@mjOG2}nc8U8_Pfk{)JjtjGSv?^ep_J{x)`1hW5npoNn3y|DPS_7Fmj zb_1xui~yC8g^O?9AZP|aTxkH4PTNidFJfw?r_FJckMoK8_s!Gd^$&VS;jypV9FGYJ z=4p3_-WDjKP{5sBcu**ijpyRriLVDOXIq&V$@b>Zse2fNTbM1Qcxr@Pd%_?T=kag2 zqkAuSF5Q@U5vgdM^%bMC#>`%dx&w{c!+W#8ar7+wM;z}(3gL|P_qA;#O*En+S;zTE zo2|rQ_EiBgE-U{K_&y`-oD0tqmZklt7_}UW%ts)}Ibn z)VPo|Lbpi@ElQx6V*u^z0xZ`ZnY8;ML>{fB*&EUwFbDzn=p0rN+&=^hmIzC5f3^|Yqv&z4 zQM;QuGG1a1cu~T!P{?`%;D#H~HZOXKlNo0j6oC5&9J;%dM{^XQc1LX9WbM@{ zo5#&*a=-jSVm?v`LOV)G8$}FFfe30(jPEYS+O;Yiib72W?P_m(gCybb1vx+$QN=W# z@LU3@G5QVmDR{eQF9-9rw=*&+BSTOv2KI1lN@sl)ta)D zXY#aAy03~q5DCCMG7h)(0MwDWj+P3bMd<$^t%RljsLSm?`UxKad)#LeS8LOJNC1#{ z6JlLpTkUYI6PN%HIka($C0EF|gsGLDJjDgq zt86Ro4sT!CY;ldEzr%Wlm~dI?H(aZZ|If5nodDAHBknyO&!I0Ud3P8w&?*o){0Xk4 zH{sC1%DUwWUj0mRVC0dRC7J2&fbDbafp>Z6l1Cq;PBN(DW)VPr!rWZV!x2wH_wMmdq<6u zHbErhm*GuB$qEr5YIq_pK=hX<)X-JX8}cn87zl(?S@Ith=rTz|z9vcMyP-H4hSxTk zmKtdq^8q-Pebj|~|6xu*$If^L@dX^j*9Fxeei8GiwU6$Y_;3vjCCfHGr|Ft6!3;Cf zqitg(y_98}5V6C68bOm$v*Y`+154&50N^yuYSw+mYBYjtRuk_WQons_Y)D<8FleQZ zk@|?hvA@Ki`UT{B%E>1)PvDC}h2i1I;B-+|yr|jtN#Fqcn=0@EcVxxn8#t=uKS^ zVui--%mfV(QjvC4M;241#nEsA?cz|t&9yV8t16&f7`B5bL8un0euWS5X|)8MKxIW! zNB+pQpA+sCEyeY=jJ{Vmyn0cKn(NoIC(tm(HIX4?p!?FsJrdFwLkxl z;%woYn$=_{a`tzp#5fxoj;6^<|M)SsLe8FiH8}ebyn4&Y=WsU2zzpXggM;s=A6%?B zyA}gE`)4|V zYTwtuKEqxj=bc=4SP0f(=^##}z#!n&FAl+gjHGhIUsA7toAJRX;ksMNmjCUoTVm?ciypN}{OYJWbX){+8{I;2Tq8B9gBsjzs#Gak+> zWADKjWIYzcj|_YJb?XFhY^^jxcaeWlK?5sbIE`DNSPHy~K$fgBFcI3Smj;|Djq@z^ zB3s=gUTjIrM3ZZszUmByiKo#^19s6wioJLBo6;&=^QtSBVNnBGaqM(|U|1im0b?kY z!VGH;hZWJj8Y+hz=#v)lzzs45_C|(SK()BDs?I?xdZ}lF9O94TXc_ZXv=r`ynb$34 z+tcQ<4%%M41NmFCs?N)A!XV;^{3ex+$ly)#8Uq?5(J0uI1+_)j6=v964o#z!8Qh)P z^0FC553K=*T}nTd7!n4WH3#R;AWwG7{cgR%Rt$!xkS3(XPGTw8dZ1wq$E*DHG|YYZ zk?-UTFjpU21MWPXIA`tjf@!$TVAJP}jDEMpT+w7bhk!C)uF9%K>aQl%nf^eG{r!(b#+)_yGDRKp1&Q!{3{g-l?F0S=*}w72MK)7!kb zLHCpgZVU2}I&NdOz41|YPdCT?Joe|Wi|2OE4NwI=5CUnpzWaVw6t_N-JT_Sx!jDS9 z4_{R)PO?g4!?N?0Y*_=YEd@W2ZDWGT{=}q8QxZI{=TY;ZtO`l~9in%0HI8a8~P!brer0+S7l1@zm8Ou3>RI7Yvy--bbDO8Hf zfpiF1tZNSBiH@;e#~QWLPrAs79E1;JJDyr@cM>*BCEkURSek!qtAP#VW&6?Fm@=Yo%uvJ&>X{j-n~(UOmKXhph@$ zEbs)-@ zSAwq;@|K!qg-D`5P)9vI8F>AhgV#8G-ZH+uZi14b&P~7OY#Jd_nmU(O-k~-}&N$AD z3Pz4Lk1_R`XsYE89njAT`6d&sGJYAP#xKedeO3)SEuDJCrUfLo00Al&>Ie9jQ=Nec zzJa_n17hod^jy-{bge1;Y*WhVnWQrPkZJeOm7plCzQ_wI5k8kn3cQu5QIW1h4IAL! z+b`ctNJ278j`?bV1VDgMCIJ$Rmn&f7CNGHd&u3s|y&7Z6xMiuY3CLv#7TmT}4~?s6 zI+vV+D>uTNc~j{|em7jU}3k;`r5=$uJIh7Brhe zt;IhPs4I+h*+(1>F%p|agglXYAz4Hg_+wsk>e;51)?}_|PBWFu1nFb(AlHo$?gJks zLeM8VoKh?HX@mE3(Im*@fI=8j^#Qv=;K3y5 zihVlT7w?r0wx_6-e$cTVdf0y}$B=HWJ^h#H)M#&~67c^h6anxL`QYHn8J|IB91!{% zbF(Si&`!qOsPuks>Wm5iS~UtUQ;pgpR-vH;_X0}vD>K#R(s%LB;zwceS?v)h?R2P+ z9m)YNFvP>2uc{02x2Io@DkKV2<@UY-$xFn6VE^0bMlJ%HVy}maO$KOiZ*OC+Ts0Nk zn_g7`V0!tFj|ZQ7lQL6N?Mo12PgX@7Op+O9_?T{IPEE1D&rDu(aBl|IKL_{r@#BDf z#Ue4}r`TD?Brg`1)jljw<>KYGUgXE+Qq)`xu}Rj$;NDDQ?oh?91B|(KibMJdZ2gnN z)@Nk$s^VI;k2tN{uq`_&d4<8f2M8QSayZ^TBYClSIF38J+i(Ors4%$qAY*P&VP>E} zbYMHKt~#&V%`7PG4%|nW$tw)*9aME47$-~Q7t`!D1T3!4isE}FcB2_3L2J98^#k3{ z>;#sx((n1LGmuUH#Y)^RDEjVSZ;Enmyb5}(2(!~3eQdewL&YiWe0?Z8Xa_h08-aq7 zA^c)8EmSU)SXCuXf`#QNgDYJQjjnC;+Fo>%%(Z7{`j8e!(zj3HDbUk1#v$T-0&L*Z zBk5zGoneMAfd-ub9erg1)_U2Wf(Dm%u}U$}Y>nC*0Ih2spTbffJ9+WMUFobVC^r z%Wpbug3NH}nZS<J-0SJAF_e$wQC=AKjcpV|t ze&Z$KkNd9xe|$tQBWB+$#HJaCQ1Nw!qH1<6rYQ?Q>*MT+Y3UTs&JuYK7P*3Rw=RoZ zh*I>an(&!Rix&WQEg8-mGXie|m#WtW@R}|YYgr?=yrS;`lURw=E3`Ezv@KC+d)EjK zBS4n80;VOXGoaEXKoTAkr`Gdg3Iy58fCB3Lw%}%X?t8|#+=AKo9 z!P9BjiAb~67k_&gwSS?J7G}posX&Isk0^+v)5(BCSf%xngrM3xFgIbjukeJ5;`Gpx zLN)}&=Iga%>SC2r%;PQ=0L#FW(qn!hsbt1i+inDJnB zE`WzupZhw-7|!lms`LgAOQ1$3 zP@N^^H=tp)p2u7z zYtyzUJu95pQ*fqq8F(j;Tq&|(jao80Zrs%ynv`70Tcn`qLNYMqLm3~+1ORA1K9sXb zFlvRQ3vr48pD_W)6eWOpP)i>46fwfF0f9vC>8O(uh|%hj;-N#GI_$gpI#H)La1pYA z8yjO?b)$vUZC3grhbHi;YMgvJ@0=K)w%kRIt0)B{G7Nm(DGb)6 z`Dh-%i!!r?$tvD@kz?=8Rikl;t{y&Pq~UPty`*m>>z!YryPI%lOE|blF!EYSxQUpo zpxzeAI2a)c4vs4Ag1f*YA9Tb?9laNT9koheb-W_OHp@I>aX*`PRJeQbC!xeOvciQ{ zfFP;^G~YJn?j~7<{p$G{L4o%b`vpi-s11C5$+sK7+bhD!L01tnLr>jfGbU`%aILHr z%$7nrVicdjG-5&Scu9P``Q@As%}|5o|_{L^OXBFxHcyhR7*4 z&s$IfNWDVNw5{}-EsH;Pba4|Vp4wdN?{vVN70(Q%J2zi zAl_vn9UplhPm)J-C3%{fc>L&p!Pnyt>jApS=UY=gODS3LN!s}l--wdn_dT%pxhE=M z-u!QIE6^7F;6MB%lL2XfJ?X&UgXvlq!EH{X4hP*NTna9tycbZ}7m@~MVVx6{^!Wc3 zF^+*ayN=d#HLi*y4U@U;i-#m|49b&Za*D_?4tmV+x{~nQCE+dVaG4x9N}w_86dDUv z^w`Mm^_&p*tqVY0UR@H4!Fl8z6LlQGi9dgIwvgCHjEVkyGgFXQQjmDJya$ObSs~$& z_*<)@tf$>oP`579_Zu%;BbB{_lMt~U@?g%Rhg=$ula8y25 zWW})(*5C*{cFUKQ=7$0L-5UMO%6V%chRMPvHlHO;O^ggeocc&3tgk`HV<9xy3yfAL~B~inr zc%MQL09Gp*8(>h2l~_R;6yvcRpU<=UV}$onT1ljI072yFxTGz}8cVTY$o|y!8m2k2 zV3(f!Afxs?c`!j+IbluiszIM{iBzPz96g_mzGb6t7>ku>ltwDh&&kqHf+C>7{a5{+ zsrx%q_4gm_Z%Je(`&$y3BfyN_YXqMf#D2)^#Y<{67dpqhrQye=lk7A*$xc(8ODTXz zse>v@K@=)S6?m}vuV=r_NE*7+igBaDhjf3Y>i$TdZR5l@dQvJbQc{WJ#dd!&zuZ5!#~hr@xPhTMWacwjna}n5IYU1;;F$zmB2ehkx zRy+z`#4|;sRZ_U50G;H^Kw3B3my3j6grgkVE)|<_61`6L$D%feEs# zs-P_Q!oIPV)hb|;Wz=2{vj*h`K4rWLV?7X|mPa|^1c!z?^ab|?VrJoByvbiL=EITN z@sYMeiXb9;lh{^epUw+a$KKvN%W-Q+lJe9P)K7RBrW7hr1g$%5r zB>X+8wh^v>QTQ8B?cP8f)tWh#*t z*FEd2MhXhwh6Fc~5vO$_-|cwv(%UFk#-N7m1DX>X9-2RirS$Yp6I5kMBuHT_i9~WG zxmWsyEiS?3keTG`V<>5J3jPe~Yefo_ zW+$NZ%ZV|RvOgY_&c3Bflm`1Jpj1^sl(vo{N{vQL=+oxlu=M%wX7y;W&dw*Uxtg? z937RGaU4A(ZOh>dpnb9BjLs<3-g##n_s+*M{zQeq5RMnMIr`Z_ZLahST3=Eq2uYzJ zn0ioKsh=J0t=7*DY6EyCYU?CLBvMkWxkU=pE<@r)?MWBLP|N;!Q2XZ8F1h#BJ_)E* zRS>nOV*eFwxenoDGtQhF$-d|cv5BY~O>=2PqHE)=%V3~48^Hl^mClV!V)Uee2HFYE zMe1pwF_bDru361;Vt|D0%y26WbOpa!qy9E6jt>2G4;YuE77+_5wK~i27wXvVLNzRa zg{;Q+QuyrwNpb#-q|d5|F6t30hI~z|2bOgmQ}j~df4&_1K>Tl!?+_I!Kig*`1^zP< z@c(>S4F45U#2sQ!z>@hc6!N%?1pKQii2uLm3;y9U&8@>wnLNG%th;X~o zZXb!os+cwiZ?u2LWvkO*(3c;qI&k-Iu!8thT6lyrDmkc_%wbm^z~I95YEdtE;BcfK zML7IeCh1a{cp{CL$TR$GNu3EQy{Jheq%;yHDV-sl3DRyvb}TE$uSNJpj^-Qe5Wz2b z)7BJ=7$h5DhL4v;}ZcIcoCrCPA*0prSQTDw72aXDX&__%|C`^ zP?<)a5~w53ZN%sCqirL&15$UMl~yQgp#VF_IVF+)y-Fg}dS#4{l=i}?xj!}lO!HyR zxD-pIFt|g+#t9hN*JG6*BXfD2Wg1AtyP~Yl&56{rEy|i8f%id77D@emG`eM_@He*(Q2t@v-{BL=c+pK)%hftL<3#b`jIay6vswW`qn?)-0#$c(+8iY9_ zJ+MaOQid_sYowi}sxrQKoqjC(qyrV<3m`@F zwHCUd0u^OaQX^USsERT$je=!)=__wwB}ExTJ~;%x5p8rfEEZv`q!y~IKG<5Q_P^K7nQ4vG43=;37k*j)QgGJ4D{7miVD^QSK8IO zMpVXtCK^|UMVALFu=40*^!S^2gv|r&Gbg0OshYJWQ;=fH{2oFOg2;+Mil0ncPaTKFgLi!o>Z9~K|Jlx1V-JJ zY^q>mWez$Co@6{tk*7$nd?-;XAI7U?o8#58&GC^2wlkip<20fRys%Ed)m{XIS9*-@ zv0El|xVKy9S!q~Z(hShkdbA59$x?|@%sbc*zvJyfGaCRWN<$FACVAEkfecFSG1Z6n z>;)SxlE_mjBTuDZXOQr575j=zVX&!+;U^UpVCkz@gtm9+B#q*rQy51_pmvEIM8y}9cITS@@CE;&M!#hhOzx0)tg!h$(zZ)NZS3ZmnuN)sngyTJVisoVZ zq9e{!e9pL;pp!8k-And1ngwmpQBki{jLZLQT>iJ?a2twTI$Z&64&zal58I4$Z&f3u z;WhL-vxy5}F%xODUnlk3;RO=xKTsw8R8pmq|2D|C>(tX#DzVkek5sZ%C7V_9x=LPE z$v;$bv?{kmJ>51M`fn*>jGR@7n@?E6i7S~;=nZFuQ$_$@ju>QWJu5ySFATQv4C`1s zNdhR24+xGsezTY3j+D=g+#+=NfKm$(5-w&y1Rr{frd!9I%{GZUn~~=!@n+;jN^EIF zg2E-EaoFy4Vlrj(9T&i3hNaL{VP%AqvGAE;)&8TkAfq-VKZqtT*yM$2ztoP=W$OV( zNLU`19vPv}MHqBXB6Uk7mzoe)4!mhCS;UueBKKP}N=@rrSmV0Ie781jGaPkbO3n2( z^Bv%G=lagkcRgey=CoUCR;V;F--Ac2&#vM^`tW~g#fRWAm ztWkq*iW^`&bDeV0sStsC$8(ekHN;I>2BKO<_e98t90dZHGfyyIY@MFDRY(iT0dv3` z%3>Z4**PH-DUOX31eVxT+))|`NGh?YrsCL&gGMWT*!NgxM>5d6Gp&&7j?Bj0b0o(J zx-6PZAOV&R8@2OU8&u>LNuBv@q7p|nt7&f)MCob{>=_R1^&D7a-a4snK@$^RS%Q&W zP-T!;)->Pb_A_MtuhFBTV&CKp2u(IDO(sS#ve2=To1Sc5LaVyDeE=0P^^1~+nO{hZ3pMPD5K z0f#a7H3!Hkjtu+RSmnQttKH`RO{q2P(YGFi4ZF0kG+cyrQzhkaWW`B60@)*3pA|`N zI;kA$UD~RhR1Eb@4E0LG7tk4Hf7^4Im3}O;+oxVBLp>|K04>=g_;hcFWgHm=OWSY1 z;pnj#hk7|H@|;4-awfPCHPx94gSO4Ul8qTR>Q!cn=>}a6L3tNO`CSf!-pyRoO`?Co zzI8?P=uS>e(`H@jzNT8`a~WKAvUO#etMpm)W=lP{~mctSIHdpa+XR0Dk(V; z_VS;4#Z8>OT;|%#lNl?m*(KzF3#u@zQ_yfDxs@~=@VY}oI+dHL1jMO?ef)FGKEgI) zktpmV%XQa2J}Vlf3;XCex?cNu+iPB!3;{#iN8U;bOPOhedZ=Fmli5t^-A}NYYPL|> z%q@Z;kIg)2yV{pdo7v2dP}qXjn$^Uz*i4+%k^YR)iOoDCH7PeKa%h`5^o*`;X1N`@ z%(0nLSlLYJ0BmL^;j>09`c0h8ycLV|sZA9>LM>-YH!yUeyPqQu+GghR0Xgy{bw=n2 z7vovm%tidfV`q@^A8jU)Mw|JI(_=PMV2P>pJWqMb7rv39_ zz}H%6^Q8E)AGSo<%2O8#>^)XNjx%h8EHKCpZK_;rc?_#f7KW%~rzAI~&uA5Wrh z$WYzYHVYp&3Zh^1>?0Du&M|Z7dD(piqakPvSR$4|n5cACUT^FZi25RYWwM>q5 zLu(mPEdL|V{L6xvmdO@Gx{l*)Xh$tF#9}hfJh(efWW1hv>%sqTdFD5RO43_6tT@*E zf9aW9rwESQdFIDms+&x7(iDN`CNy=-M-X=kqvf zxt{s>?EfD;^I?!!c;+=H$9v{8<|X&cIZqPFx=7`AJoDZqKgu)TV!{_+bRnegP52a9 zXvw~ZPu=s(Pg&_`+5ZPTbGf86xo3XZg`Ifjd%o*T%h4x`WW703wA_#N%#X%8S9s=` zGsQgiQOV6J`K?O6u9a_}sbr^0{&Eyd=LUBzd^`IY^Upt}bKDL8{DvlnlJw8-as6`~ zke$q4();PIy}aV5`seSz;)SW(_L8t+-}(|sencdzzsFuG6Xts5srH?S?>Vd1#h7;B zm1m`OVlNkela!MLV8>pDPVCxVmfN3CaO|ZNR`yal5cA6Ku86ajA7Q~fmA7jz#guXF zxz->29%JKX7m%OsbMTTnp-p>fBD{!#{ z7`WiN*?+mp1I~7_NTCj5DZ*qDUop4t+NlG(7HxY%LA$1*-o~gY{VO+`*6l$5A}+W=zHHmL4Y`5}eppqbk7wG$S!s z|LX3fDo*KB9e8-;_^wr4h28I5rQ+NG=wg8>elONlvQ)3Dq4tT))mc!wugcKG7N91Q z1f_31PxA&mLJqcN9L{AmT4f+8P3{a3!FmHexH6A{>iD3vp1j9!oMwbUjC)3izG&zA z=0V4cx1H$vcEFBjQ11Q@*m3KQICgYh-wOwLcu|7V!M%o28XiykY z!Ig0vR2-uuBPwdg?m*h66h~B0Msde&1Q*1WW-)*(;)ddA#I4%kh~g4J$^X9R+^Vkb zbOSo`egDU!xmDG7J@;()+;h+M@teBG!PE>P0laBwnN&Sx{?bh3$4irHB5(Fgm$iKrhar@q zqmBaUo2&RjDnynirGjdVro**MISw&LmjYvZY;>i98-7JpKaGt7R*||8!PYq$WTl=;sEo;}gyB4uum$6+ z)SdGaaVnu=(OR6o?9`; z?3MBARJ^(xB&@PVQ(R5pLQ~`<@gMaO0-2nD#y-ONMN8?mc1BZVLE)ADg3g0i2!dZ)1bjU$d3ZM6A7Ub*F8&ZJ6=ij%9#bb0 zpsb*f!zk$V7%8ZuTipg5rN*eaP^%LFmFHHK7CyP(2+$CTG5qB$Hxk z-vFt0DPbpM0#pk8^pi^_8I-5`uQQT~bl4@6^GbwFKv>y59fHoAr63mZbdbWjK9m8# zT#H$8gB(GB0gjIVj-PRI3XVSohN#P;Ea=T$n-Cyk(7X|kL~|~T_>X8#AQ8>y?Uh7x z(2Hk0J<+rQG$+Ue%>}VsnAw42)}*01$`j3BZfnq-1<_b4uuX-nzB><93;I_T0{uIt zpugWA$U8qS6S*Dd$NN9wN556lBdD!Rb;%=oHvpX>tW&QtPq8e5O*MJ!ob0oh+@&|U z3%rMXOIdsv#GgtDjUZv&h{g!(VS6TF4IJ@c{W-X&D3i*GbUDHfCZke)^kEvTQJ%2= za~lI|VPT?v`3gFFbptS8#)hzL<9L5k)}M2{{o>p5+2*>{m^O;Ql}y1;n9{#$JyQBt zeZf5z&{?D81AlqraX*M3m!ByTJ6n-Eq4)CKrj*6{b5AbIWOEto&&eV@wW96SQs3tq zxs{e`qFJScWI8ORS9#Kw5!AYGOhK(2h&^?eZ!)Ssz=3c8+2cTtK*q;`*1&@2TBw@& zBZxx4iwF;R6%I5G9B9J#Tj4-Ee4dd5=`@(-+uGf?&4I=_l|z&RP1QM6I*Go zFY1110tKqRb5X!`x+gOMxl>nb^Vzmh z;M1OIDBz3!l61GLI6MUfGH;fjvt29rfhj9^&MHO)|9AaSh<;y{P=B#z~4O=l0>REdI(a8v)8z>`~~>3tU%9 zX!8V@F5;)9Zn1UR70g(-*u)K+ijq?_$H%nm#^FA^ti)lu29F9exeM5w>*wZQ#EYL> zGyUAwr!L~@=Z2uxa=MAfGGK4i}-ct;jNr+T*PNCZ_ z|H2|Z4FwZtVYQpZ&+Y9)x3Y-8|KqK(7Y;X87}{0X%QhGB#9E)9+lK=I>Q&C-i$uxm zd$A-Xnmn!_AJpV-O=f6vvnHo?gd#HxaUVs8Nzq?cdiu)}8rf>siF|?nGDon~q?k*= zTB3f>2i&>j68>+ZqD&Pxaz>umKrVtwmh37Td8jB=FE=M2?15#+r-;TPuvJyf5mA8c zL-gfK>Mq~i6Gz6`%7{=S8ta)AqHzXN{-bCl%~3SAD@uw+QCpIt@m@I38_`IKD7;5T zU%QmRU<{X;Z>8`aJ%FY<)Rv{#Izm z-fHkfST9{&jL@PkmI5qz*OUTcUw`ciVp$E!nLJMrU-e-|N>LOuy4Wc@3#Al#t3egS z?<7v}>?TVN0#$sK8QWm{q#VQ!3uGoO9k*4apxWbLUW#hsuP5;l#nLfKJ(eNqwr=Tg z5$j)tf>^CA9hIg5@JGTa6ILDlMhaGOy(8Mz3qJ#;=yJw_tstE3yL0~q!WJ%R2VyUh zn_YCtl0xs}Jp0F?Txry;h)~g5yy7i?V@M|y}tb$Y6aSwDaYds`Sl$TD}<%$kHVDD ztc87I^v@jpL_axjb8;=HC)a{82_#ghfrKhGkWd8!2{nmsCdM&A9#f0EHKK>paF#_v z1mRE`X;tF}PcG%icqr|SyM6GjqkjWtco2S-nV0EsuO#r+7aH&l|VpOas-%25nx7N6a6LAf5M1dx|lbwhOutjBWLZ zvpu8@18^Ujp`r6kLmsh3KcSDjAvrNuaCEB8yF2~7Lk9OJv{mAua)Sjb9FJw_w1fnI zP$fDfonm%S1nX$JJ!tp*s0|Aug0Dx$;^vQnW_88bnh(4~rp{R17%PlAjL$6t#>f-9 zf$d~NYfgJjd;D#a=m@q|84Da0*)7*yw&1K@(-CsSa5#@=8IpF#tKdvwF@_28pdLpv zeDEU6ejX2%vBGb{s5jPg4U*xQg7Ds$86IY+0*O}0xl#KN+y}goi}ywp@vU~g9bn{z z`UaZK`!n3|<3JN&$aKRsyWz0XTb#SJO6HhK5a=8?(JVy^E|S!B-wJ>@)xC*CbuHBv zP~`|~_gta}ZoRYkTYvK#WaZgF+fxf-or{nKu?uz!Mh`P!7Xg&QO`_|a+Ps~YLbwQ4Vq#QE=+S$? zA6D9FD>(>&aqNIKO}hno3^iz5oE7kbp;+PVon>vt)fSJw_o*^lrfAb)eslDFy*`6nT%A&m zzUN>>=#K$d?b6wJr5?KWQZUQc`(Uc(W2%@-rd7b|=0Z&}8oTr7oq4vs69xkXPF0JX zw_ME&-+-|oTn-hyQ^XKoaZPfM>gWv zpJJgXrSv3EFcD4Mk+5u0>#|?;CrNwAsK_);kSR8!k@@Y*p&);9-Q_|1H0~<$r&!>n zj-1(Uf0oc+_K+?hL{a|6`MAYG8~`v&ip-N_2PSW+H-iyoEII@^@yqL|{9&%o_cFMs zNZ7%Yh48n|Apbl7d&q1tTtUU?E$n=(up2rG^rHr?#D$Zii@5XH4@ex0!Dq~=-503z z734>vk?TODvyeKcogvh|*KZ9iiC#WUGF_jP`|5CkA{HK*?l+o^2?UW0gz#O>x$Ijn zsE-?OuGxe0=rBw=IUw#Ys(BSmu{UsjJcLS^7aW;Fh|D2)Fhj~l-wgKokV@2~GZ}OP zHzTu#Aze#Dpv$^V%xTlS_=^>$*tOY9t+w$$twToxj+K`^7YAy$TC_Hwy<9$N+- zc`dX0pj7`HvYG0)U>t7M_sVCjx}~P4sT$0uRn<-Rp|fo!jY4e`##!?_bq#I&t_IgS z9gjYKKj9Qy2iY|@wDAR+Y>&_5r=$5PFSK!CO|hvK!*HvGv$yoPO`?KRs3YRT^LL9TQ#CnxGiI|C)0N=e1y;w}QWX8eG&e zG`PpcAOe^mxXF#U)*ZA!M&nv-onwW9v>#H1=|W${0|vv}em?M$s8yP`$~o z9hfUUAN-~@<)6$S8v!~63+aQ?qtzfJ}%i9D6$g7gl zf*dXOlmg-fX`>BDF*taOHRTBDiutYZ`1^5lFZ7GZW9$zA$ZN313Wf!N+qfn#RslM0 zTcY(Buzr~L+Lj9>=?v^stLaE}o`**_?lKdnGLUj%Joz#%&suJgOiT z*rgr0)K&T5PP+%AyuJN2oRmGP80gW$-Uy|c-a!0M+zX6gjZt}J3(gfAvBJoGyoi{h zaMc%!bn%b-#<~cW;EHZEnJfAoKa_GTU`2pcB9Ay4eJ8Oea4ro1X|K+h(Sopl*5r6i z?r#Rdo|w9qNe+~Tzv~#{G`y}q@wYee7gHsD7&$J82sV*_;dg8P&Fp7nRdrX`VTF^# zW-4NQR0B}lyd1x>*QLZqdofM{;v@NmRB^q&&yh^?<|4tp4+|uT#*qvM=C`jH{Jk}G z1J2y@p>8c6utmyW`HwgG-pmpRoX+yk17UI!$8s^<(onW&?G9z(FNO}wT?=fw=Bi4& z$IcQ*B#w5EwdVII8W#PyEc|&KVIV`*xLD_Ao$g$jZWwrJ4-V%35bL=|z-S$7aQl)S zxYau`F|w%4n!glUM=?Mj#NY^~@Y4QNDlSDX=ZZam03R^oq*XT`oUF`#GN*S-OYN2x zY#CaUEBUDwX6}L<>!zW632(yT`YTBGxtlO3g{gK-KCp|(be(n6EcOmtB$5d9f(-r; z2ZYM&yX6J#5!iXGl^I}s9#hr4)yNMp3l$Ik!HRGnq$2u#un!`I$kbGXH=(ol1BR81 zB6A1oL#)hh1!X@k4#9GO>ojEdRNyAZg+X3-I@;#k1Y`50 zuZ)P_jh&3HDqFN^hhg^har|0d-xeyRiv-MAiB%5gJlvR{lM`M$w03a_UyrIE1?9{h zk(byVbRe(;Aa9D|rwr}fg`(O{C$!UuOj~K^B4m!fk1nM(rrih3Ot11PxX2mEUVSyx zzAc1W*(*Z4O(KesXXr?d*O8sjk@d-rNS(1-0*C|VvMT&Kz*ZJrxoA@-uP61R`h(H= z;fUPYk=v2GJi54SQ8Tc;acEg>oINV9FYk}2$pUh8-PGSk>OTu5P;TQ`rbD2 z2ABeHtAiD}PM@#?UBf5)^2YF%v#iPE_)@#64)t3RUWW~I9*b$H-E#H^MCYJ>$^kp9 z-SQg@8P?>1=2MO!eT#)pd*Tzul16NMqS9E;XLCJD+Z!}=<{Z~0a%54(xiD2`BD6us zc8ZMY?`rZYxPcv<#g(A_}NZR8VY*0M|V zQ(OH6<(L(4@K@_gLt7ea+9QLNxC9?Hb2BopXXbXyd@{Zxf>mNTQjd#Ubx(18 zE>o{L3?|6fyyf@?b^V%CDaMNEuip+l03&nwLrfS-keq};Q4_bo@fN=ktqnN~SNZ}) z8rtS@KT_&zi8r;=_jqvd>T94Cq!qdRv&6&N%mQhDr8VUre2)q$liP~mH{7-rm}x|d z^}Mj97kI^$`3P7+Fn>ECIqliOybQUVh49a8`e0b}9S_W%hebbHNXd}M!w~TT$*~@i zqp_yLLJT}7(F8WG1r*d$0A0>Wyp3O4W5RCI#fB{@U0icevWpNc@WIH0@y{Ta(?hz5 zFqvB_!iaf2g|TRZ;VpUARBGek;_y+tbqQGan&Eay*WrU-hipI={bBlI2*CZ@;@4Hf z?L&4N4n;0Zw-|gKvP0RTuk(lH{x&T7U0LmyIlqD#)&7?AF)$-?A~-)^AVjRXfz-~z zTiRMvmtrUtc6HahO4dW627SA_ZQgKu)J}QBDMbco-Q_#vl`U$_FVAf#i>|Nzignj+ zVbwK#%4)xEK_;}_p{%x%k4M{ww5x4^8kDn;U?kf9n|p|@CR-sn={FCOeK6VoJitKG zJ}M7T1pA0*24*!fI&bZY`F__!eJk=a2%~jN#WH6*C0im|eH2R0S$4E~8o8WtYzEZ3 zMKP%lRk>Efp)Yx?=i|S6!yzZ!?bKu=73VI?Jd~eLK^tw^#%kYC`eq!80`1sjD;&x) z7iiI~F`|12v46rN6q-#G&Xjo@$V6nlS>285D#+QWtEGwSu|LXh&|d3>l*J?hoS1Sx z@h3WsqA6W_imp%W#mnosC=W*0SN3^xc%S7JzpSoU)I4szM#E0>S`EXXBE`1y6W*V2w^d~RVQ<`b&I;;zR!Bna_!nYo&e@mD#_O+P81Sx4OVBL#FO{{YclW=oiYw~I=6B^3;o`ko4*5oC4W6yeX zQCQVb*6*YNtC|8wHMGqwXXy27#=t5*ruYs<^KaX=thPCXNxY^Y*s^%|x$%m@@yp*! zTqQNYX3hYR(Bn}ZmrzeEXlN-{%;P-cNtP>BsINWhYg*{GgL}?5b(D5C58hfk9sTX# z*|c+P_I4gceN787&I7E;4d_`z*#QUOO8LNxKh4R(rSgzie0$J+E0u49`0X3_8w_4A zYV=`y;F+JMY^>f3a--?Xnjbj*`#Au4=UIa%p;J>${=zp7+a*`-vyMo-VxYmD1Fu5{ z*n`%-$z2Gc5{(rb3!K>83odO|-7iqYVUp}W=22wzc3qC>u8q07{#Xlumf*t#ij`-W z_ei#~?}%^c)Ux%`sdlDQvUhD44oY@vE~(uPG;}ka8t(5D)rDB#`CqhCL$p(;_kG0Q zsm0)HvbBtk(C`KcA)TW6P@Y|zBdngwwNnRcr!F6)kfQw#c7Xd1^&sWQm%sqGQw!ek zL29;iYH!o2+I$usxI=2E`uRG=IL>aT81&lh6zd_RD3$@KyT21i{rfQOR1v1*Tb)I?O~ zLMr4wqf@MbovOk&bn1%#2&A4mR3TL_UFiJ9A?(z0!9DpBxO^wmsg1AsrmtQgb-_;x zsS(_kw+AlklhUcb?UKZ)xo$@QwFT}oI>ma}*c^N_+of@B_wa*EyR~RH7TElw4;Ueo zA~2o=@X_u~r=-l#M>{9mbx@f*L+jmVw96XUZlgB#?Qw(x`8)R&Xwh>v-Ob?|aSQ9( z)RJcAMHxaD#5Sgj>0sll?BHqs4mO((%3ixY@ISp%0CTdhgT<)Koh?S~muGa4HL$TF zd_ZHBz7CdZ2gkJPAfx=V45R#`%z^^b!J*Q@=Qj8txZZTIL?p~WJGFyP!z1722BT3K z{u6F6)_q0?Spypzp^ZISk%ZtN?cjpD(jh4K44_Pvmf6Ma;9VgSQC=4Sa3ilqtR(Zul+)m%E)JZ*`y1LDs;=;@ViB_0%zNf>U3+A4@$0 zx%4%*LSsHVm!m5|+!M{8W1ZVdBGTvB{8-?f1A0c)XIagh-*adwAo_wq*n$NC{2u6cNvCglp$6VPH;W99y0M_iD z%q7i5d2qvQo<@TOiLSCtQ11+9@6MRE=m*?kWAjcS-V@)`>J(l)DA=+H+ZCNGd$P19 z0Sa6wbm#B}aai`{X!Awm4ets4b9OTL0BA@yWEZF)t3U%A@1+72ugHPEBE97&fSMix z#dyJ$I+Mj1W|TvC+hA_7qFwI%r4#y`#~s)ds*$T*qEKq}-bFGZe8Q2UwA#n3h|0M{w!p0+eHF zqEdtp{RMK+EdWI&eX19C7VuYKJb6~JHD5r7t#X(E>*Q93Y$c)2&U$Pn#(|X?*J(wl zUR5XTwDCiKU_*4+Z*ceNthxt9 zIPtgyBZb-L;B~+X&U7KAEx%pAl!zIQZ{hgnO4k+ze_0)b4I>zCgmK>Z(&esXhPc~z zuiL1{H|$HU)^20g>0Lq$laMO5EHLQ(54#li^#2((;VyArIU}m z@b;g4pnA$cNrZ<{i4yyY{XeCSriCeWoaC?LQePb;eke>vTQiDN;&tk-=HqiG0H}#s z_%h9Tv9vWD{G!bv{4p3;w5`|qIQg?A=1UftkKGOC8PSI36b1(M@GeRmP?0i@rWaK& zUHNukrp`cztsYt3ZorDfFm67i;9%kVFB2%@fk_-Z@<$J_)nG5G1w%nj1f;0<-ZU?* zo)c5+`FTT@dS3dGUGQnwsGEEFR%9MW6mH(xvhM|msz+LN$5DGv?e1Z3q;&VDY|WhF zYlhu#5iag3>!iNI_g_z`sytg&9eq_v|GXYQ$f*oB?^1m-{({8sXx+&2?j&&!yr2G% z1uPF@8RLS5{XMaDRgE8~^mlr;s!mUmo_et}Gc(ox++Q z51t!Wt>9;K_}dT)I0IA>QS;lDph0rHF|!GJj+JW2UixvwI~3jJP*U)*KNcuHHME?Y zg)X7e`OOaOK3lT~nVqDT)yta_VDk$&9D^zIJ>-Lxh`gDZNy@Bfi(P>D&N=)6D2&>`5(vi z$c;tGa>E5FK09{(wagYGV{zL~uv{|iRn4*v2@Fc(=~lg#j43Tgr9aFukf7DkOFv2)gJLQ9k> z*&vexB`}52FgE2M>=^>+Ou3#9fTRj0?=TsJa!5K&$>**&IH7pa(U4`mAQKXpRlx-@ z*C;V}#VC>;d9_+8$fmKr1`5JqS{*~-hF#1aLvO{x+}Z!@w}b{J23z99lpre|$4W;B z`@GGJz!IAFa8jqwJ9OeM4Msl={(|eiHpBPy9onJTU}Y|BPI?{)hhBz9Uv1hi2!A)J zC%TzOB7i}Y^mcg3k7lYWqSz@$n{@TE*Pxc+_LyTTaG3qZC3vZbzFWZ^>`F{+WuLbz z`+Q)WZ!7osAej3p3r&#~72IN`?8{8(U6o$()#p|0W(R-yB)DkH(2702Ki)osPOaBo z#6d&T9s(;O%np1jaAx8_2)i+YL&ucjRzr*!?xmY^ufw4oyn_H zP9^|1RMlTNOw8Mxf_*-MlYd@fFLIdq z{e<3zYBEQYdo;O2lMQcx7O#auZZ@V{?N5upHP?CYR~^S~%(3)W#jF}ra1}Ox+h7wp zIC$|jo#6M`CA?&1Xmk6&uftw&TdPhYY#`iMxf;7)Brc*8ARR?dPcgemsEpG;H1h7yrNZ(HN14(657&3_{4vZ3zj)F zVlo0nes@Oap}sObRj*?TVh}sNDFCp6ru##Jq@oEiMG z9B*5Y#*xB`g4V-J^OtDdx8s{J3|4=EBCI8AC4hOh9v^~oJXi4ZqEJm2sW6y}!;|%F zvndvRHT+p)Xk)yl-E$aOPSfYnx5I1Khc-3h10+ID)2i@i&7qC!@d~{=r)dce+bu)~ zJJfWLx)NuB?C`$Ws(T5)d%$=HFF0Evz^HS9VT$zCB5M($$X{fpuSlroB2h`+L}Xx_5^UBHz%A3cP+NMB~-I3zM+aYCmaFwyE~3dJZw#0lz1FP zptnA#$=ys^njXXda|W~|PC?g@9EGpW-}?x{T&l@9P5z?EX_B}ol;&^#3`I|P9oYGJ zk`?~|sle~+6`RCQ2*)7e96h6oTq8);X;(~ zgb1-XI48_@Jnvk`S9?eYMmd}$7uDfZ)0E#N^8#XXWh}(@D`PVCayof6euaPAkbJpi z^Hsc+)(_bk$QEa12IpD?aSgV@tb$vk`73C6nxy6^DM)fO(0432=K^xj)aFjGyS3+u z$|+}|5wK}%%E@@Bw7Yd6hn`sJ9r~!)W8?Am5V%W!bj8{DV@>IYd}KYaf|@bgZE*w` z@>{*7s1h83lPfNa%ad7hn2NnC zcA92TbW}s0Lui4u$!wZQ36gutRa6u8x;;BE)vXH}UOu`bwoeJN;@opPYZ8@3l$UBX z)c`qAUE(0%okx)!gd!6^LAH2A*+Gah@fp4uy6hlynRp9dfYr+>i2Cg-h&z8DNp_bv zD3OQ0<0_GXw1(VvK);3-vpaBf+sxr0@=RB8}S0g)$MWFP#|b>|Ak zH?-ZcgU2=vnkqMKaj`ZVyY(S(T4bXn0^5OC-!-tpR0Hv-=Ya^JNMO@|XjAO0zRg1k zX#I*8Jg4B|#>B*_!sc2!*Gw=vPwGetlOs`jOO&Ai=IMlOwtdF7+HRUd8B{$5f5Dh- zKcso5tq1A4n(B;w+d0`cBb*ZV12xgPc`g!V1pE>{bwcy_PtppjdXLE2~Xww{{$JnQ|5iMUL%~5~dCdq`Gn*2YkaRX_+mqsB^giAs=iT<3_rgo>B$DalKk%-7_)C0zfd=$vWv z45ww%GZ1?`P#p3K`j42?>$%_qJ?jGC?V3_oAK4=qg)`nWC}%uPYuaM09?sOr zHo5#NYMnW<$zpe5FUb^xmBX}DuPud;;CMGw+$B)AuEBMShuj&A{t{gDRU2qs2bD&C zhAtGV-joj^6J(LWTWa1>MdW+{4;=6;Bx!wdCM^aC+TjPo*3!nGE1O%H&NmWCM7mBr z7h9x=5>kXVxidD1JEk1W+lP6Bu_9e%AC*TE`O|zU0@lG04++QtjuomvJ@r7c6Yvyd zI~xHq36270d&-y1G!Ccq3*~E?f~UOJa98-MA0o{S0gPby+6^TjfZ5V;Xx^PcRePfo zFizl=xZImuthDBE{Lqie6Uh*|mV(l;-J*7|RaW_1*(vj0a_#TF3hBCBf6b4w#nW}5Kwuj8rEBok7 z<=5kQB&pAwj)V}ShyeX`gHqxdlpBC7oY-QVg={Bt-?YF*fvpem80`lI<>49napr#8 z>Ia;PF}*6YoFo5mKc1Dz5m4`kv#OBM=+Qn_OlSic^b z`jsJ1P<~%4^0GedX+>@k^_EIdG^NisAbx{^9UKlg3t*w39dm4K<{aUF^9V*935z2U zHKG}_d<@X3O<8DTzncAqLm*cSUS)+p)bFF(K)u*hY}E}$jSKKUyyS>46v33)8b1u&ohmIe1fS{@7B z{Th9xt}JDIj=xvhfn6_QOun*G2G&Q2J@Agp#v*$`Uu2IJUZ%MjCE^GOoqIaY0_!LP z`>WNqZq~MDDo-f`S(|A4X(xE?zy&DkJo$A)OVeUhbl-R!e7K))Qxqr3ihdlB5wQS} z!>!17Pyob#3m|N7O^+wy)CkPLbv|aQ;x{kO5yKi6z7%Ul7$6R!0U|OO`9qtAT9N+p zfGYQu2heFRc>o6}lm}3ACwTyYw~+@>HLbXzO?z39@8tn#=*R;w^HX^MI=(LtldK5O z|AjUkX+@UG190vIc>u~iDG%U=6zic)rB-CNJd6dR;UV!Y8YH)w5--aJ#=%Zv}>}zL1mP|?J<)JuN zRPAw*r$O-=L=1)CO1vazzg+1yr)SolIj?um`kQp9GduJU_5j&JwqEn3f^+>gGQkZf z$9Wv_=(bi9#CwiYpDmN0X9w+Lp!b25JMFtB$1ewgz|RQapermYq(xbAvRPiTpuf7)54M)${4HCvpy)h+ znl-13EL7lJ0JvoNO~yofk25c>r-`7QR2w|F9NVBEjzM3H)?V!&ch_uVoS1B{D9NQ z)l*D_Tnff+rp`JbPGvP7#3I)2$$YVy{EP#mAtr-Y>i*9fZ-ezlr(VM% zE2@{D5UXrJ6kcKBw2jy=V9;ES^vWF;Syi(`L)%_CP4^xb8`V&7TCEZjxOll0(*p1#+te{&+Tfdlv!oi{O>T(zaBq|aO+=>qf z1cWtTtxi5ndw*dacDH|ULu}F7Hc(C~^HyW_p+n;rdHqmcyW_PYHfnYA@L1*Q^%b!* zRy%3)4c+0~C7$kJ)qMaQfd25jSg|X5Fg06$LP3f8Vg3Gd~~> zqK6t>s~8=XLD?f(u=$`?*`VDv6pWF9j#{)jXir+y7_?=_$8)Rx>I)j?F5#(2s8Zk; zddiuvz$y0?o%-wtpi#F^feBp4;lq2s;zJvL*b5(yYADZJttwmMuXx9K?>&Gq&Z@40 zLa%8u{b^)h2qEraQo8-hE-#s(`<-ubVrthpgh}+Vl171zNwLsg&-Yk;F>}EVdy|5o zUJ-1%9vC6XzAO1=R54#{?l>e+gvToqxrwoL1$CDOoI&?jdwS4FhbdYl-Q`fS(_ zfr^OPy^>4t^<09lciO`hSq?S8ev!}Wv9f^GV5&MA;sp|Ey19&lQO{r`limVh$1!ge zadV<)G)2K2)`I=pYr)8;1^L3wM;cPOW&vnMQ1%r#FYUjDq4;_u2jd)>zgzENzA|H=Oh{Cf2Gd95GH~d zOLK@&E7N0A%)c(slJnmQ-D_%x8RO&uF4uCFmc74GwARl{IleN7D2T@rht=2H4qd5ni0bjmA7B_+X8@jgU~Kd z6A0U5K)$a{I2(|CwHfAd9Y?+5uMUn;IaYDtJA zPn~Eqrj**Xk5DSJ$_xqAYL_L@LmZ-a-(^ z3jgz>5NQ#Jl;90U;iS<(;*4%c{L_$TsWbXRkml!3mnSgcJ<=vTWxfsl{h302oAf8( zt6NdMQ-+;SKTMomVc?WC09W)Mu$y3bO2ne4K`)ceyHWLDXBNSP_bHcY5$_JUjKVSe zBCn9kc%3A5joN_w^U61@hv{}hx?GM8eEkJi55vg>sd(VdKfAgZrE(c&-Y=E!)B+-v z#d2*28k>HHRJJ0IVu~ATiJ}-rMy|606XN1#5r7SdWV9L3(hIBr*Exerjx2cwF;6M; z0QEZgxej=mBID$J1R3LKDigclcl5!qSi?qupI?6iLErrYpp7_x*?~1b;zN6WSO`37 zz`Pj2-xib)zLT*cXL(2AJ2yXua#Pb(fK2$e`*z@83Whz4MW2UZ!mYNBVb2O8Q1eU2 zu)pIMABO#v8Dpb1tS5#wXU4FLo=albK2q_(r$vpUwm$~Ug?BmVg^a5057q*LVP6pN zcHr8Chhaiio>D6uD>?=kK-*E-AnJWqga9WOJji$M+Se?{p*;@q z#E>7BUgiR4WXbPGnrt|LG2Y<-ciwmxIIy#b#K4WzD_`V?cTRCv zJ4(d^&-;FB94j$j3J5;EPSUXh2Ymgz@abBVa`7ovn*jsqz!9A%$k?L4hb6)ia4aR5 zS}aNqAo0{@qE7fP9Fkx9a|3n_-vwnz)V9jpH+eq_vLQ;-@2ashwMKID|FTB91^N1T zFFKW8V@yVkWh2$W%2-r@lbNe;ct>fj5~?!CM_n6qmsB0O84XQ*kcfX()U)vG_lt$} zGOBloX%zmd5neR$nhvzq=Ol)MUdp2lW#LAIifTrvsF#5@If+B@Is8>Ka<0cGnv7(< zh7+?r@Js7zo(2_WsD^q(S~WM|6RHU#XXF!2pCDzV+^AHi7Rua{5-?)DlqiPxwS|0wU? zN_3C+44-ca6{Eb-j597`D(#~Ymp!B;m*O{sWib~H@IIO&$+S2Uxtg@j5J(p#VjqFL zAB^h$W^ArfhE$9yTms3UlCQ#?Q7Dl>s27t!pt5ks9Z#dVZW>G47)L6BBP)GO{Ct_R z3HiAWex|1oNHc0_rCqm1$v;FOu9AM*K3h@JFR9+Pl3p<{yOQ1!R3V-Q&QtI|ZTcK^ zz%dCO_*V>0Bu~(H_U)q4~(#zuWYLG}q%?@wB*-XrHG1zA_Ac;KB-DAf#_N%bz)0wT!NeKT;r98eNd zXa=#=N-+wPhGMlO1$eby+c(&<9I^c5)issfJdHo%JIumUB>Z($jA%*uClnI9S=-YM zL%S-w{8O6I*q18*B>ZI=nmG#cZ^u@odX5$}&9pG+jbD6<+^)>H4MlF`<4OEqO{B92-YI&SE(}^PJ&Uz~ z;Qwt>AaMS_Jw=Xe7M5&-mV%^$|7Do?k!E2KL>@(Ca79sB(n|aRMea|i)2Afe1?>AT zl%zK?)85h-yJKJnq9D;2`8$yKnO(B4OT(bfus3qY41i{n$`wtR)X=^*|zcH^a!I$nxOi)9WY-xzrhoe!V^-i3Ss1|rO=@SN_^-0+ zaJ9L#^@rgH-~Hd>2X{ZX9sB@pFW?8&n$_h8-?s6bpZ+jEco=m!kHH^Q_`!XAAU`nm zDK!`}pnpC%07M22qg+JeA)jm@$q(|$5B~YNj~~=-n;-DFM`laTK>XrU0QQl(Ms3&{ zKN#^qk{^6Y=3@`Mjz?ZA2O{Vsk$+6~%beD;Y5+*Ihn(XT)J0d3%a z%N*jEWRE!%{9)$s5H=PK(f$9x92UI;Uhv~W5c8?34Lk#-&H0=k=riXtP@KlsECSKF z_eWt4cWQFpttkFo8godsZ$?VE-=-?VI5lyGIQ`h7qb@*|fvK?MNu(9eYEZGrfF0UI zJ+m4Ii8O7v6D!SR)~w_47ax9QQ9%sJDgmdvTw=1Rg6w~9MwXN6Z+QUn#tL&atIKj` z_xD)N)+Hq%J`ICJhYetAml94?LC!!O&fu2~%jwStvYbryrS8RSh2`w`sgLEzM8FCp zP`2y!by_iD4%KZsu(e*nGfnAIx0{77=SnZqPI$%U&c#Szu$d!?IWC6lE5=|(d_tQ_ zU{XtWEj6qWW!a)ThC1FMKd!TwapL!P#ob1 zW-g8c915KCjdL!7>*z)ot4%{kp=iQ=TzkRAmB=EvND@Q1umwoyOu_HMJhtb%^XN?g z&R1acs?(*w$Ly~+N&Q>*Z^77{X{&wk;kujfVXu7fDQXR$i(g2EPm#dK`Jw;s*!w#< zUqBK^V*(Pg8-RomAV~OKK(amGof$U*BpVbYDey4(A|8U-@Ws6XHlwS+qokxv5-M^% ze(|Ym6PR%u_L_U{OsZ=KNyP)3MElBSuc^`kqOPqcKoDnCqO5GUz4Bg^a_u#lk^Qdc z+{si{A=IC5%~xcvC$3*up%c4ZxISrz{~fMlysx|pRi~L=q8-3-@!`35@!@NJSe~l; zbjI(_%T2;SrcA}}KZpq=6F&SxSZ2cqAOEO&&qp7R2u5xX|2Q7r#KPHA_(uvzAN=d@ z0BN7V{|=HWpiTD~K~Kp^S=F zwhH=b1>G65VU!$iOvY?Lv&&f}5B=K{Nf1OadI5r+z+P~(&WGo)-#c*<^%U$2qsJUT zcxmwx?~u6(`!L%(VQ#`c+>{#jA%v5aSF){`r&r#1Ej0Jg#`ZY9gC9a0_p<8bG;Y=? z2P1J>0ecl4u~&@a-$B?LWMuG#{zEYO3e6M9+l0|Ytzh)=O|4)w?0*TPY}2~Gbomh6 zMM?;a#eBICh?I-$aAy`bAGL6fDWK1OfnXOuTGt)5rk%G3tKU6@m>QxP$839Q=}5?C1|9Q zAtq7@!t+S>YTiGKXeB*Ov=S@49=L#W0=(o^B9?p%AqM(;Pm?#9v^3q1|7Rmq$q7JQ z|0o{^;B=HcAE2Ye8TvP*&Pg44us3~_S7{N9a<;$7Exsa{wvhg&NAj;QzhxRJFKI## z*47O7TIW6`U@WbNY6d94&?}ySz(_lqkpi_$h?uXT_~WoQeS##l3zxR;!s*DA)&(d3bJ1FIHQBUQ-Zp5mPLnS+`9zZsG+C+1 z3QZPk@`5H$YjRB(qOCXF7hMamPaleuOax-8ednIeK$zNfL`&Lta+unhVgX5%spi9Q5JytM>pwf9JKWrEr<>cS z;H;lm8@SStRkf_IODl8XjI7271dXCZ=0DS6E@WgnWc4NsS1jEi#Glq+UtH=sFQI07 z;`Qc!&IcViY6-i*m0#e6Gc;VE8h*jRVehr+k70B~&k59AN1i+b&Q;$|k7#hl{;awx zABuQ+$x!||G6^q=Z&{1$3RB!{>7|V*5i&ybwz_1fuFCOrB%gXa3(ToMsd)?brRYAW z@OQUw)dZu4CfmD>>AM?K?r&K;R~0c{JAvJ!sbbEn=ymjjB)V6$(>lC?`p!c*d4k1iTbyrihW2p?s&JuI_eY?01nT42?rlR$ZcLyt(}ULO zleYs}1OAUeD?37+4H6}gc2*#Dz*M+Eii`kw`MIXre5yv69K8b+G4dzv!7Uznda>ff^&sjpw&{$}|e10u$Rg zcSs!$=kv6#!DO+uJxZ4*PrU4aPpQ zs^&Tbls)k&?o5pYFRB1@qLcd=+1l9LhfFnmATj3&%ANX_L&ImN|Yh9T&ed(~s z7w%L%t7R}1v?F+B{*85!R|bk!z5a+Rkx^mX{V@*}&Pl8A0#jklNnT}9H$OWNsu_qM zw4y5a2UhfOT17ok5l_2d%68)8fG?Upgk5tq3b+t;_z}40!jj_QjMnp z`XJRb(Rj#=U3h?~1=6~E9n~z+hZ&@o;9$OD{*HXTC7rH!l3?#(4(r1q*xAg7{2Uzf%V>~) zw8=k~sZVpdxK6x#1t5(m(rI<{D;{@`IWAE3{wzgG_oB33wE%e(x0wcNS#-|_G1 zsKa?3zMI0o3(y<>u?9cokzEXzsB|BE#66oI($sq2fQ4gun%}K z5-0ectk}vlIb4&2HQ8U2y*25j$u61{XwqJjJWV#gE0z7I$+wz(rO6XD7|!7caqh0> z{Qf**ue=GQ4SOXv{KjJrV6Vg^!0X+w!A|XmJOkpv=wd`$>&V~)IMu0{+@MNaN#QIC zQ5G>O;z-0>zb^{nYV96fhS}$?1b=UDO_>FKW+5;(M?#PN0}sL)#ao6OW!y_Faz1zj z_!;Bz6tvTu*ig(R4!ZRe$p+VN!=8CLris~sF$|f9(mOjWNhD?=XdNFul0@QhE)rL{NIcO+;(d@i zR`^z}lqV7&3Hlpx-u5dY>3y^VJE64G`7WUELew=9{cu|7%ISm4D8fbf6Be?S(M~1Y zB+e&`EO1VGU0Gx?^uOZ_U|uWCvgDo-B|{3Md*jqfHwggFm)j?b=NC82$m*Jrix>qd$<2vnW$2m&#p0f zc+96Pw7DPS4JS(Q5(K1^3z$1#45utIR(60V@h=*66pX&EIsM-jQr>tOIx`AcNVQ4( zi_q&WO0SsK@t_XSD@a5T+cgJc9lSg9WZiH$4!^<{-d#2v7-!A1EB}$*ho4XZYulz} z{bHe3=qujB?s{xU_~3$3B#t3H!g)b}(jUY)=#TF{M9~&-5g03*@gic3sbn;Xq6l6L zbeN!3=U5qqvFbF4KqdO8hmebtI2fI_8CkHNJvg)pVF{n**CfIh<26?JN`oGX zwn0(nE4X$_EVs7kgtMBCo;941ELIOWJd#}b#yNn&ORO-@pJT<_eNL$6ud=oY=B~zh z7WthxuN;Cb22U6oke*K%8&CY=X&j%59h#dt^{}EiZf7i zkU&2rY%93l{s_5X;_R`5Jz*tG=8&bF0UQLvOP+Ppk1UmOIxk+;!J5A&7+$h6_ajq1 z>ecGa@z@Woa5bujzgCa@pO=Jc#>wO!XZOetMrX1ID7Tymu3)h2Qvll1`s$M1>qnLJ zO67I`s!l=@q0lf=8vA-7&U(r2iC#J-qfr~-5MJ7QNm+Dt`18ilW^aCD<jpeF4WTq^q-;iVOEb z5%EzKa3QfXNG}ae&JnK)RUM+qZx^A31xEIz%0C#|n|1S{6YNRYe4rM>&4&u` zt?X>tt>xvPFH6D`Y*hz>@g_=1SGvW3aTs{iE+u$ciO-w8y(+VLA4=V*`Wq>0g~ZJY zMm4Y{CU~k@S|eZ(-P&ez;IcP@^(h$%*|tHr}Hj^9@KdP zTFwY$q8K?EzO~@XsH;d8W55!~5a12`&$VW*H?E~aK40#XwzrTCrtk3PKQr+?2b~g z!UItg9tr zp9GaL%03NCa4NxW0LS$~P5D*g4CKoOoowHYp828Jef<+N&DTVMJ2B+o*Q%{I4uG`c z;7<1?A|ShJ(n*tmCR-NEZ_Ccb=vKkB>t8S05#RmeSAd&BWEOF41Cc3M2$8ASI8}|1 z-dSEXMqSI1RA6C++QF64( z*gbJ1!w18LKLJ&tC;RU;%&vg}ic0g95D8^3p@y7ck#DVtcp-v+8pFsW*8+9&4B!VC zPk%BV*8(-mH0?7&ogvicH$qKJHA2n8dc;L5*!ulOC@?^+Q34PFn+CC4WL+{X=6>kP z*ux}*N{ta-8GBAhrlzJK;Fe` z4(2vSh#3I|6Wnt=9QfI1gCHW?{0IX0etmbEAz!PYA^*h_7PmAlO_GgY-SU=~xK+o5 zhv?Qu!md9LVG-JduR^dSQh&2>>4-MpY=mO>_onj7>1Wr&OP{o z6cY0>2w(G$C?n5EV#A_~u;y&U_9Q|WiAzOd1hNl{E-wpzh7d*@J;#c{_>8R0$m%Ud z_r^D9V!es9W0j>D_v$~@Sa~jNZ z$oic%-jP~k1e`v-#;6I*pHzz(yP0d1-jqW9b>F~UwUjztjBl6dzPq79QjG%DPc^X3 z!~uUX1a?L*ut@18_Xo(=q#+P%AaK)KIzM=}=dt^zD0rt*AKyoJS3T2%3-b zv$VX+jW<2N{pwK=_<%7OY^q&KSBYL_HYox@#YUs3Q;AE=1KO&xQ+9)P{Bc z@s>O~LRW22_T;;LB;tm{ZH1_FP>0hO9;u?oFF6>9+LQjN+@MVr0f&xFiU3({bBKwX zXl}|1Ef2)Elr=Z^cEIWB0h6`b^!?%S5DTsLhfl@FwEf|7N|B!v ze`5CZI^KuuXjR7|d`zq3U-*PN9zqiIm>CmNrfVLr$v%Uj~9jm&5O#O;%Q*ck=KGkasJ`E!}XSHoJZ^2<;*!b z^{^%+B_{`lE>DHbJF~rHlppfuzz9^MUvU7+?yb3c`va61Pfgfs&_HsFX-p zn7eFv;mKzYF0E}f+X;b-AUru~fIv++TYK5Q6HH>H!kl8i_>3gk?Cy0DAQ@{+Ent>h zpRVCG9$5&gIle0IY^5zVfxPS~|8l5vmFK>SKyQ=qF=*Pf=rsIkjo#I9wmz^T3gL=wZIf%VG* z4@*6Xrkz~fO|1cxn%XleF9TWQ_UxzTppME|n2lD(VsRuAT#Z+4N^rGu`xq=Vo3YUR z5x9}==>YEp;1G}!%NC(Y=i8{S8|VRpE2nqEzFPR5EInjbUbX@Jo(_kdo}5SVbb!7m z8<@<=>Jo!c1!j=lhqxtJ!%M4pdobvB5A@WUuj>vTq=G!`2NViUH!Cypma}^cD77{u%J7{y|3eK zJ>C-B547g@m!a0tE0G4o+3Ysm9HOVf*fv$oWj3t_YC${oysTh+s z+n`qF1o8xRwogJ8t%1Z7r6CLsXJ8_6qzgEmFme8!XM~fMf>_VqXB$;uja7F8^T_6t z%M8{2sWYqgPt`G0Yn7QT{OT-E8Q{#;UdEZ-K5wnoGkY{jJ0(}k%tlu_-SL#5!F>U5 zv_k)f?FQ4q5uDkm-vYnq=p>lnGz~72XiyHF)`YX*3E^P#G`VU7>OUVjg+rzBr?1I- zYS)DXD&xVJz@jF~3XKy6o?eAtKw(oA#YjXqhUJT~6ClvzFSy&Md1x@)2rM&}(%h9n zdnEeL8HDk9N*^>cV9kJ^gS^#vJlll0ETsWWD0^Hm_j?(vauc{UIOknY-B5T0dxEDR zk!T#BP*BuRS7-I{(lAKdGiRgayB9YFo(Dg`$7~zX@1scSM)Vf2$ptJ#ncNuRgtU!MWc#Lyb>h{a=GL=wD|}t@(oQRn-8=ipUDGmwxhp$XfsSKZ^;A9Ck^s| z%j#Z|hd)^nMnDd2?u!uq@=#($?v;oAt;kGyfcwcbc>o)qA`jPEk!$4vciq*<11_{1 zFAu$~$hq>+$BHoWPiQl4(HkibuF5QeUNqje?jB9<>B2UP zlx-5O!Ztm)I#pMIX1^fYA-5pgS%TDMJ1unK^s}9LrzP2rjf^hanXAuWaMKOGDBFqa zcaU9Kfi9LW)f%{1E(6<{`>4luwz&prjTWfjQdHnP@^_5l#UMD(Y&<1+p2y`puk8%Z zL(ytaSO|U&o-bsO_z^ZLd&1rRPoLpah(2SQW0k!2)ivs7A5gpIc`9+gHXEQ-81EId`l`_ z{U!SeIMndA6@E+>4x@VI*{7`xZARX2@#_o1wQ%EC054_s=!K!p0c#3(tYPt54WF46 z_T`*ee7qYUt@*2h;l(R(HCx*toN4~Vp<<^HED9%^th%9ikm==kBRu&_3qNr`7@L4w zPmj*8jCItDMt`twdJ%0`NFd({`A64x%gweoZD5n?5Cn_uyXZ3baJL<#?fp@kFm6BK zGws`Wz;0FHq?8J0qTAbBAq6U?jg#ovlyNGv#8jBab6*{#vcwlqO``9c^J^WR2aIwO zEBWn*@K^Am-U3tW^8jN`f|qc*XV{(xoO9%EZCvJcZ-yEm>RZ=vG(M)*z++;lVL#?h z>jN*2YSo9i_?TM5UHF0;Zbw2%0QHRG6>&#Saj&<6w;?x^KzG;!=Pm{Ae=o`ql>0@a z976#ueD-8;(p6YpbGKV+-CPk}UJ+fS(wjt+cpJlZdR-1)^f7&^s>n`X0$5yjI(JbT zJ3R-Lia`fj+!SO~b}CjVRpCPV5gLW3+6gb+2j63bdueg>Bp^oEEhbdk-cBhL70AG2M9I; zFzdD@iC?e<4>^LR+eTzj=Wkx)gKt>6Z48uJw=GLNh!3QAsMcnsL007~I6f(_Et0J0 zPU8|K$liKJ%@@&?lt7%r?h}FAUz0wX?5W9ansn3T-$!F~6PuGVIVq2An4HO$WIt&Q z)?rwu%z#wje$q6iwn-`X`ToD!?;nS@eEa=}6}eIn_A`;|u7y4NbjfVM>x3*D{|{m- zIJ;NDW>l-Kgqr(Wbu;N=RyPHIRpMscx5!@GgQm6)>Z9;8mXb2(=-V!toDwD=L-yK6 zy0!T<5fs3ZzrPi!#huETWqZVuKv34OF)r;H}`IbLvad1GS5- zx_#XGh`xjrG7B%%XJL=#0p6+|_7 zu>hN0g6g$PiTO*0MPJ1ZE;e>IVq3Yn-Tm1Ahhdr>JO2f$2KJW#I|<22*q0S#66{>qk%YzX%MpXY{a%gZ zNzW1cgW(qJYF~n%$fKR%a6+bGTN$1k+f>AEY=#IMFsTJB2cv&n(pkF9#Ug4P-oYlh z46a*oZ4vgU6z&N9+f{ z+3oRcoPLj67_)!U#&c2bl`#U?4o#17`tU0FX67+59|*giIkPG8Pb#3>^RN zWO(@HgfCG8r`Ro61(z)x6+yk8Y3^$rR*;U{Q}Q^QeAo+BtAPZBuG!6v&7@ukAOPNB zX_;~z{ygeh+U70>>9lA0{%09mMn zigbx679rULmW-L^8+1R%8C#abeR1R!96uEc!EEI*69_vYbecE`?cjZ}Rks$E4Y$YS z4yQ}|Z;(r%>oY6_JlM>z6H72b)uznuS_Tmp9`=`6>@Nd-gv&`(m?srJ;Qok+3!52s z!e8N=TwjDXt*tr9>%iaK{Omxe=1{Mqlko!#8k4L%oTYx4rzyek-JaEBI`yF3-RM{jm1B zKp$i{mf5W0v?b;P+*rYWag4jbmkm79FS!BHrr7x<{}tTi4j+3`7%Fk)jayGfs`LmX z(F~|FwBZ`0B&s@E2ZLB!-M9h|*8Ckq8#`EaFYzO=m1qfhR8teQPs|1RTvt%m&~{L9 zWpsIEbaCQ8%w-1#ZmqjPx4Xi|w9oMNO7>g&>ti5ZSDU5>qZ^y1V@BI!q8BH2l0H#a z3pck|k;$aGbSmfVsY2y{gB;%$mH+d?tW?g;S)4zsf&DN8!CyvRNP^ErE2#u;x0RSV z0ykms#y1D^57|Wz(tVSyR+3T;rvSGWO~D@6Ff7HJ=)?2b%S(jy%;t1pg`*35_f*9! z<67;y6U{0q5@v09IWUBhhg?5y$`|8z#?+!i57}UU<_FIzm2|2&$xvjD;5)R0IY{X* zboJ5VF9ZYd)7o2DVzIWzALk&`P42*u6JtB1$Z!r!cB-n($!C=fp?Y*E(DVV2Xj)C0 zGm$_;c;xvda3*?)^c7T zQQl8qW^tfWAYIyt+YhJ#m`Z|JLi**jldWQaxG#7}CbqgvqgrHKM`UBS#GY}9Uw>i? zW-S9`&v70)BBcdgZznEBzHBu?qxBefKjgzZ829U_tOCI&D+j-2g(pF?!wJnv-BaT- zDzo4Cqm%*Tp6)MG<}VYfxdN5tNoBp=AINLxr19FvOl38tUgO{A`x+0`6nhn|c7O1g zcH$Bg$GYhPP0p5t@h6*R;VV{o{=+2Pw<(VW=9j9ujTb*%S7`@2&bk9cP*$4mp{~&Y z>NPh_lRRB>PRO&a6<~s4*Wf&315?p8#Wb05dQnF&)ZxU>fDwtOYo^`_lhTuTGqIeK zb8{u)cj(-Ffu0YyFNRQk!wUa|eG2GA_IA`BR{PA1=}#DtARi8wrI)!x%tRY3FoQsK1I8(+DH~hJV8Gb;Eqd76fUy>z(+wDJ;u}bA84`D+ zby-=^klfLKN+r1&GcuE0AE0HduuyZmBzN!0|2@f_g*u$!V+_gdisqf6coUMt*`LH- z>^6kW#8faJe`pfS`%!_JNO>|_C_b~DC~@?!UV<|abe=licFqR;R->HDuH zqBrmj5N<#cTowmwLlhBa3pMwvX^+2s6Ql8(v;$_LcACU0=r^)WrN)!pUNyz5Ewm8^Rjz4pSPOrZNB+*f9pu%?MuL;Dzdf{prHj~M-G8%9hq98#*ZZwgos8Mky{DdiJd^&&J|SLb-*2$aU6$H6qm5bs)D#7 zF5rIK;E1@fjOKsebE>*;cRCPezUTLmRNs4RId!%=b?Q{rxj;6AS@68&kQk;)h|O)j zb11@0h9`5(UPmT4=8zpR3s;o$hsU@a*e;>eC93O?-QNQfLCkQAcqhzBoFniK+|6){ z)zYFEEQz4Xd5vM8RVBHMHKQL;G?JxuQ*> z@b~!2d!BZ~%41%r{wusszjlxsP$ufCqzFfk@CZh%LH6#)qem{CN1iIBFGrRul1?7E z5L}qddxHuSyeHc$F}pCakQH=$)u6K2?@0v=%Q@Q(Z-mmQ?l+`vGRB&o!o%9c?PB9#rO@ipCd&!q;j3k@U?WW}y#0 zpdx(uGd{pIHZ)`o%iRi0LRNp!WCIeqz#inE`{@TuGs}wRoO*-~EftcQj`=EzjYG5g`Y3ydPyHs8=Rh$ttFeL)erKDE)N@ zT(&!61Q>zg+Is^IZwQ|B^g5h()W}0%V(aN&62WqCTGxQs{o-%>hfMQ|J_$8m2v1;a z9A8>y0-|vL!=VXg0{aRx(z|RGLT?mntq{Ct!lIKO*W^J>?$u<5Caxw^G#QZ(h_6eE zkV{&RXKbdf$9snZ-?bYy0z9tAdrYw&FDXXM&3sNqpt+2Fd;9Mx?Fm)Wgr~Bi<)Lsj z+JcVhl&x#q1&3La4&EeD|L|7n)Oe2Enuj%SyAj{)yT|0GB(k+E@-~jL#r$trzn_Qo zgPrR{UdpdQD?IJJ01%f(-j7A|*rT^fA{$F0AD|FdGq4zfbeL!&sv;UcYj6VLR|DZ=hi4BW_yOQScj zMp?T$9$lv5>;^G95WZ-alS5(GOEIKqUeXvG>$^_ zvath;J9RnGX}M8Q)^elpUiikPXbURTG<~B2A`pn`e&P2rEOrWVW8@*IL}b1+6JDts z31*x1wb7&VQ6Hez`snvctuHDNLH~6KxeWK^8W-(_V8)l-wG0f@_UQt z1b$6XtXxP{z(+Z{66=ooAwIl807x=iT)T+OjT60^^uRW=vF>aPl|v&i<=11qeKXeE z)qXpkL#zMTHVMsZlF+==Di{}?ri#Dgby5`)o7beVdDxP2I31E0V!$oJhRR_!GEW`< z$9=yDL`0mq84Nj|3Lk(WQqd9n5o#7*gTtI?TYUE~_@_Xn-rdMrbv+8;as|)6cOZDU z?leS5gzA4okO0c7Bs^<~-2^!qGpvJAq58LwS+`-sO6sL`kLnD*9Tl4T zIzl#TwiSk^Mzi=MFEn*qH~!cqR6n~b+ZaWbz9y4y(+Q<8Ql<@%*L8-ab9d?YVR|Nn zASqn8s#x7a@FXf_I^@VV|NJX_h`xEAFn^m>YF)Q#&8A8Oq8x3i?4@xd9nw|Fg^*8! zWaT;e>j4W{dOA`7x)cd*$i^~!=W_S5=B`f5l9KtKb}GaAUeUUcdjYtzG-?}GFdl4T zxy=8_dgfE`aG+N`_8W%CV2slU4c-N1hKM1`wXvh{;Z=M@bTGTB<#P6XhqyMMfc}@`*7NKJWM^+P0^dANc0}9<(vYP zh7ou?w@sxLS=3R1I=uPA&9raq6pY6I#FLzu6YqUDMM;cNX2aa`(f$7fhA?*SeY_}h zZ^?i%DXHDs0xw`_$`6=`l++>sE;}PM?JGQROsGI?(&W%I>O;r90dDOjp=pd^9oo>n zu;0(kS!J0Yltv66Ep{-#qf%r|t9#pK(|3R-vZ(}5RR@R2Vr=t6ey;;wQhDLLdY>n) z+YoN!%Mi0aK5NHIvHTgZ1onzipOr>%YQZ)qvLsf|t+sB~l7o$|!QdCKHkI3uoX_9-(9Yl9{Sr5~1SCTc2pf0ZdLoa0IBttCAnF29lP`rY45MR9= zh*2jGMXzX%pz0S7+72?_X#O9NkpLUf|2nqdvL* zWP03{uKxDWBi02N1M~+b*PhIu$E2&hz5K~dM{!a9Yn%$Z1C<*E#c`GlP3tY6Nrmp| zsbC4EOr1iI?Jzc7Y8H_L4@@FdG9pLB(h#aWh$Nwu5kC4|QvJ!O{LV{L|MpO689@nU zc;PR}O(b`rFcQ~A zsCS!IWJkS!%h~Dw+o<;hPf%Y`Y(~B7CS%ll8Ba3maS4768s?I_Lsb)j-Hc$7ptrnF z!e%~-%jW#NV{NY0#m>^L^yvp;DCt=kGW{c!30vKO)oK4&Wx`h9#q0P`Wx`hH;~mx{ zUX&88;$O?tS5%ayq64&|eUQLJ_{2Q~A) zXg@WZv9aX99RYA40GNu^Z~!o)Z#w{(`T5QPP#CH|lu9Ud@{`0**jOFwpg@G$14OT# z1mYBILxgczv#k{8)>3n%LKB+y9u-T1!#~4T99V4&Cttp}Q(=wF+F-(U1MklUtY>0j zo^nPrvy87MZjUrw(|d-a~?;>dn1^^a!$U08t-^A=lo$OKx~e4 z&Rczwm@%1izF3#0*KOd^a!!p@xPu`kny%uuh8X3XGpc)w8-(t?v6flp!DEmS+k)T= z`cvwE#JJl^Qj_$?C}4Csqdwfg`@P#i_s>2_gMl^xrS`lyG&KYB&zfz24ow{ky@B20 z8oJvWtTs7*mU8_51k)I-hX|~3!Y5PdxO6bKK_%h%kN0jz&%KY^-*ees!#>xK!>+d0 zUG-Z6T|fbcQ6X;NjP}4$xf5`Z0_X2&{0ahqB?u+~0Ppl_2O`#e)P6(|fQxnnz}^7h zL z+xQ*9+YRt`R(SVl54`*AB)k(4;|K#Yjkcw`Ef$s75lp0v?W3bGJYraKq+=ex5bXs& zl=tp&>Wg=x&#Grv7FXoR(Y>)PtT<+xpUR zr0HgC&cwIUj#y{ig3V1Qgv^2pj#TSXw=6aiF)DDU(z}cm6`WGBc31pL>xMK-KnXaS zSP1_1@U>`!M^|tK=vjOK7t$>xvYVnlr|ns3m} z?9x9(Wg)W4oT7|nL;(hrE~i@Nl@Vff4mc+loMG>&&>Tv6zAtfSz)aMn_bj+n6#p*&|Hg+yo8s7=GKpr5^51Zq1>q~qVnn>d6) z&*&fmlF!FjiZ?hPV?Gitz9mlS7Kga^+cByf;08zB34O+S?AfqH&n%y&=gQbPRvbS+ z2HW=D0`5rmDM)3x4^A{Jg)juhsub`hRm%B;SX5MsiFqlc&%K5PvBF8dqq1=%0&p0& zW{~x)oRmaNx;Md;?!A%zItIwJ%7&O-IW@Wk#^It(${ z3tEd$n75weTUnn9q+0#IxKnmsztspbknn*8)I}Wmf#^~oYji2JmXHN9rerb!3?LVm z%St2b5p+-*y^sNJHl{%+pHMK#u?Un>wm{NA^^BqFVMEYJYzSNAmm(<%Z|f9lJioiV z5P%p5$I#fs9Rn(7k5l}h9h;Dp6@3*7Z-R=(+S5SXoZj;L>LW|sGcmFMEEIkl?-3?9 z@`%iut-r7CjrZ7xf%kLl`wn;?s(T4*v?zI)uO!!ZZOOxYCCAwJD2ZdhZj{wsyU|~v zdqBa$p3MQs4CUNoKMo^Yw~dYb1RUuGva-`!EhEkOHB{|+UhZnY)j~eTy2;s~sU5RO zkL3sY>uW{K`m>&O+{pyMG@8R?i* z8O=?qX07aKsjNy5Uqwh|5*;lGc1*%#6Dl^!GCD{JeA{{~%A=_$e>2z?DG?k+Ln+&v zRM;k}Q|&p+{YM+@<2*;})XDyh3p(`Mxst4W067H(Vgfb+)jHoW=>OzX?wg zD|8PAXAHfaGC03D9s()WL}_M|y^u3n%b^SNg`gyn3?|spS|RCCw{=U}(%ShDGS(H) zyme-5t;?@OPCm0F?bXrdnHBPREK+U(oggVpDM=A^%hak>J5_Rl2?i_Q$d3-bLMF%T@utm6ul?!MXfs%vI*eI*gO{^Vd6YGj&QZ}(l z|7ja~vtsjMVb|&Ws;T+0$ik%1HJ<*)`zbfpY>UUO-G_HcL1$6CKqM}&K52Vub|ma2 zGd0@}SJWVHtP);**!(z)1F9*$HTBBOgsHbXEn^%Yprcys2Y9jDGTc%CzY|$g0T1I{ z65!+T0)StRMAkM51MIg9@0*MS3^}bP-9N*p+!h#^OhbU@g1{NEXOR!jMuKtZAp)5( zU%VFH3e3Dmc0@$b)Mj%oh}^iQV!+y#hDtoVS6@ZoKI0DVSv>{zo6GQ2RdCbsE2py$KppYZSd zVf|J&Kf*t=@JG&cg^!?c4Jj^>e5KLk_)kRZJ&YP*we^PCyk8Yv3ftZnboT&Mz81iV2;Kff&QwO|cI4`E-297JF=HH?>qE5Q zd0H^OMQAh^A=?+Toqmbh4J^9^%Z|7AHH(mE@o?s;c#2&E)mGx3h)8_Qw)Bdo3ps3! zfuwykf)i}az2IOO$l+DS>dm4GjNxuCZ?T!1pwk5%7ZbDl8 z79$UQyCF4z_wRU}x&iB6yaRL3K;m6EQex@f&}6YDuWB+^lOdWMqsbAP9ID9yn(U*= zo|zwFw`vmA zq)wAbnvB=vDoqCb_*zTshm~?jU($Yna*h&mKHp%R?Zx|^I7gYf;3}OTL9Bq)H zs%1XM*akAN9@G;*6~f->bf0>hqBVA4E~H>Z-YbnP!TcCHD;~*T7Wt$s^0m26ZBBj- zD&+%aRxjyjkF*?x`LdFKDq=@s>R1w4Q4(2D5_t#ihcWr^ja2cJj8e=wU};w%7P5qw zBPiG`<HnRxMB&_uY((p3PQ1Wi&kU}Cz?_5%~jCQjd0I0>^F$91E+9bC}nTS zBj)N?-*9$fyMh)ph8ND=Ek!}jrEyc*p`p46hIY9!tww&}L~UNRShE!;YF{Zot`F5+ zBtLLv+9>=Ge;1u7yaWrEFF@`o=(u_WSFOb8PKCOv1Q?;`dchzL)!!hzz?0pPqy82G zi2S%5L-#9;mHi65!-1-kIK+O1ynan|NI5Y0L4KmYg7b$7usDEfd=Ryx^Jgptb9SBU z{rN!ZS95q5X0(`Pakik?{AY%=FpoARF2E2@i$<3Msfg*to&#QCK#NWgh?!_Evx9G$ zpA0))(w8KhnH(V1MSA=8B8=Od(0zmA<|D`{RRAecMI0d01p2J7XqB;30SC031Ec{V zMxt;(5}tAQRaT#ti2z4u^}=sJ4W^bd8?GWJgS5gT8C7KGZp8$^ve~qNVRVwV!iplY8Hj(mi2FXXpqRaUHA=oIMFne2-bG(!K(tm|YFT z>d|FzDb7VxvUJd2U8mG#PMGU%pTa?EVB}%k5H>-Zj(TPb9B@e`9S5M2$LC?o@x#K9 z&AXIE7MDeqmPNkD{jEBbne*0PXhJ(>Mc;+OFT=r{*ixtUVMOY595zY;MxNb+B{cR# zK!xs>B{b<8l{ubD^M~RflTh797)7+yYy2fU9=I|^vzI>ajgmerGjr54TndFSN8v!U z6}k~4Bh@Tdh8hIESjhbl?@=kXDa!&Ra?V7S^nQxOdZd77J>pmfod;C2SN(K1A`e2< zg^#k#jq#IqG5&GEMKLNXY$ai?usuiSM?XBkM7Ccqsd^g7<7?#kCA0GOuy`Wa-=%oZ z{x>1zESm>wjV16@{qfm$#-_xGb3O?!vu&$zrA^SjhULJT>roe(a1~Mt9NQ+)te10? zCV4h(gAXRid&Ot$+wBZXextkFkh#EmMr<8A?zg(}9@NT+Ey4S^*^QT+HN>7}W*FX2 z2)58es7h!t*hjR(a=nIqDH_JRna6=0i|ITjBd&NXQyY#!uZ3gKiw1u$PG*+Gjq&}s%)~yEz4MP{1VVoZt9Vep}3fYc`gQ88d|yDmOP?6$&P|=f#}xCXdHmu ztpaJxuR%o?3>evJZCm0*)(~3)6v#rLpjt}g7G-Fc*c%+k#GujoXv+lI`UGRuVCeTQ z0YubPg<{ok=+BegZMa|vb(6$wjU?w7u^DOd9gAd1Z#7nc$u?Y%J}HHNk^xL~bo+c2 zqjLPjBM+I(f0K_zLBdN4(HJ=8bQ7CXY}!8vuD( z(Nb(D=Zgs3-*%}SV=i6|iM&=4`MD&rj*@~EK~>+RVs_ zC)jI!dF9%}(!3l+S{gOeqz3Xw{Pe(RLlYj$infHptKcQ(WMvmFJ7PKVY&g=lg~HG3 z>ruO4GpQ^`o(-os-rr{5cfk8l9gp3?>LLrCih^51;mb9{NEF0-tYe;vf_PtQ-|K4R z6chx^vjx;v$ED^XGa_?vTdy(ZrMY@fkbs# zTsr{;GmSWiYg@bmX6}MfY#40JU-wV(X5S^Pa>B5BHNDv;n1X{?^K2^tu?|pl5SOmF zQd?|;*gU8WynuUlHLzTUlSIpkVxcfSsu-+Gk7HmI-LrB|nk_U%3&B52(!>k#;NN(m zn(FKD0cX#lwm0nu`djIrO{#5xsjYfQyrw&B0X8oVT2s>``++sd`E9W+5PWXP{NAK7 zO`Gq-%jP@zg-1f6k8)mHal=F|wx~Xez04TLBvat0SVFn!1+qY3>=$?(+tyE8vZ~dR z!C+87Pn?tO=dC2eCA!qTN%yIqjR9hYl7Tz90{^I6#g6F5QjNXl5m)t0#i^R z;Vst!)&2tNEr<6THSq|Rxa&RDTV5o%+VYur%TW<7OgcdGYml6J%TW-NNsL~M zFuTBNhoQCr)!~gZwd7&R2Qb5HI5@@riq+1x*xbAKIPtH}(8SebiYAjanV`wlnp~#I z1)99B$!nUtqRI1`6l+qXNq)7Z%P! zd7bdT9{cC)&=kGebOV^~P@Kz-f3S)QNUU6ktUU*qciiqJ9Bi^-GOx&nv9tm#(`iMi zTZ$j6)*x&O{D5=+&kKY9N5IaI|z?bL*GU_fGE5uxUe+xi`PH67}15_l}4Jp1M#!@ zGhz4jUN3pSvNW>B3*n~|S=#(}@27!6rB^-%N*F;BM@gdpE*55Kzl;C*cC1>%|GZg7 zkEilCGIdP~A;^Wik(D{|b6`G&|H%Aqr()WRTww)*77#%Th#TA{@KS!BWW_nPhf3D& zlbz^5T$+mm?@>3fxE$88&Sru06s>+OSc| z>+2t{fRMqJMMCG2P6bXxsvx{lBY@F1O>-EVYe-kjAGK0*=_bID2E*HWgz8U*O(FuQ z9w4fu-Tu8o2Gm>{`{x0v1WQaBT+9_-zb|p24dR>>K-+vAGfTU~f}sH`Qy@L3yw+&;hk`WN<_&1%l1dw57Vv_IUramX~65 zLL3KkJjhWnUyQjr#dmmfZm7PSG4F8G(H1;@f`L34&NeB1TF&dhxDXlPl8!sW9Esfn z2q0Ss0{VPS#}YGvnoHSX2y`C5!C=I!L{NYd$$f#-PI2+?9@+-DiHEtPjb{W;Y$NVc zeBmqGhSUx5N8Om`qi#fXbaYy9RKwO|5JMRi=~Q|R$orem3n{)&Mfh=Y9FU)zT?8AKvkjpfK;PJYZq+>7z+)+hAQ1_YpKReyHE zO~2t+r}4SCmk8Q^Xuh);;tDLYV0cl1uqT{o9CC;1xs67#)_ult7U*J0Cv>o{ID~D7 z#b29~7?}Ei+JQNrJcd!jLg1?+2{PY%=&LPo#|Orrh+h1_{)DC;ErT#UYiS@}@X3mn z__$_z>aP!-Nn7riJ?uDB-!!q$_PZ+sb*A%H%-LnW$vJ;hsG_NPm3P8BpxY^swz%n) z&i>qm3Mae)1RKL3YW@LS81>Zx5c+*+={MfeFEsU^q&sptw&zft@j-CSdP6I|E7VaW z(p_v@@U|EL91rm;+j}aW7h0`QbQe^dC@umMUQ{eRk+z+U&nAe9qhc{+K{xtKRa)rK ztXOUm^GCDoU$$uTvN&O{OAz)QcDb$Y#Xd?RYymU2-O@Z??ra$MR%}}Vo3@L;-_0@u zIsnfCbExf^j`$crLQk8?x=SmgcXO4VDy_vsLC28P;4W zkKR>{_!0&4Ug>c^5e7+F3v&NX4 z4CYK^5^*r=Jn3UnVnQx`$w#ta1iXam9L9Qbn$X}3@P_r8-x3Y%%dFr62eF5!t4BT? z`++PMITg=>1w|G*EXXpZKOQiDD*si75PlQ1Bs!5bYCJmu2J?EEPDF*3B`3O2g=?;}%ff=ptui_3IS|8#F`(L%IILWCEMUg-T}GYGcYM~~^=DM>lluVUI3VhaNC{H@M> zQm1y`q{#(DBHM{9l$j%pg{nifLsG1YL%4(H3c{dUaCX}pPqfql*YzHNjP$(~ilEIKvy8cZL9&~_+E`S|f5IY|& zPWS#iz>f|G_cqV`1)|gmqQvnE&(rV>|3mC$sIci?zoh(L|2L31D@nOQ&86`FktBN3 zcqsVhkO(C+8f1}M?6HT;4kZaW=vze=BBtLzOyz**s(8l~|Ar2sxA+8<`9&w|lWQ#3 zJ#32Hh9W*f2&P!&qCQGIh&`zR1m$s#feL%)8xVu6JeOnupN)hCnQ3?1q04dKl2 z1^_sQ^IQ2ty$^2iuErola3LwM3?OG!heONny%JJYw5s|KP86(kcCdN?KcmEM(VWl+ zR2_fe3hk~~c|}217+#dO(1ACq_9w{8hIynJTr$l#BauX)hz~zTG;tnbJ{P>@gE@&G z#{UVt08KFlcm}M6 zGH1bHCRG+F&j+h5q`3NM&=qg-r*8;ppvh>Zp|wgu0~&$=(WPieoDi?aUF9j;F(V->5e{Nm=0B9@qkG_Z?Pxwb2 zag02bU(D3i)C>rBQFFP0|GWp00AybHdamWw<#S^?hn6+`j)`oAJR8@fo74NW8}S+1 zJKAT+i5!x-0^-_LMEcjR+f#{{OOH=pLuvkGCn`0TON%)-NsI7QT#XhvVVz75(EAcO zYMR#tV0r|!^&ZBg3lcDTxV(#YXCpu;UQ|fESqq-L8O>nYKpZ0vpttTYdPDcPGt~=L zfD?q5ECvo+nsLbbOZiPK)3U_j>8Pvdl;s(z<|;jyLreJ?%}r->@WsxRCd_rWSbVPg zTQ)!3r}bD&Mq%3uj#_mFoCqvamAX~bZ7=1o7rh!^>^<*i-a2;$`hmMV`3V}XANTtV z07Lof?XzV9;5@zv%`u}Pm}2#zmx3QBs=Qk zo|=TnxLF+^rL<7rl5gQ4%<#@0q|-MMc39)^xgElQM@)IEaVYn0T)N*etk=n~+-M^F ztfLy_q-KC#fA2OnO!LADjQ31|%1NGT8H{lS5&(De?Q-13GUt~MocUV@JK;~Woy_@8 z%W_^S+}y4aN4Rreeg4GyW@a`Bj}uC4BhHKl&|p4t2c zzICq7({GnvIp)&p9>YSR2FMwD@xK4Jwq1uz*@u|WB_6~}Rkdx3#T(F#K zL;mn?TB}qpWFs=f0N?@wTp)nvJbo<)5-5~s9%Glx5~&VG!-LVlUT?v4ZbAS9fRQ3F zp>aKKC2Pljfa&W~)tnwJ%>GjTSf){_plSK3+upY3yU>CDLC&<5(Ud4()B)1 zgFmQpW=SO`KBNBUP~EZeebCd#Vv}Ui%IcGZ{vt^*)3d#vPdC}6A)W`XYC+uGLVt~}qD~_3i8lNp_MXJCS|wexSu)unA_dmOynFQi_W?*d?>?G^pg?j-?>z56%j~=x z)NPOo4Rwp93pp#Q4Ru#P;-jwQjF7s=u1ru@inOBcF6Hf`E=zk8n@L^XJsw*~jRf3? z$VJ=R+YV*qZ`<3v#Z^adt3HqqPJ3{Rd4qm(Z1fY zw0HA2!pq^!d*R09KpIAbWk6yDy&1m{8DjNuz5rb-4xIYoQpynplFL3oE%jR+XB{l3 zEES?^+-Y+G1JP=buf#1b=I?C&#vM43H=W4))p%Bv(Ak?(r;HlP{%l15F7DsF1ozM~Fcs ziV#{>!Tl%bF4jH05ycv^R6q-+r${}3Vf7pY=kSLc=sJs=(qUok_K<2^)M&5G#ZSa9 zN7H6}=5%CPubasn1Hk2P44U9l_&iwVAu_)J(SFPry zsq+L=XY5uQ!$4`J^asP6^bL3#Pf z`7N=J#Wb2>C^bj-tGijdy=2C9(d)2^C?+y+QijkudSH4B2oupTKmZ(u^Uy1yJ9=eV zZUP~?Q+gNZ`I_O`^Jb;z+0kTC3<*?-&LE< zN&#^t8wJG5MG|;Gw}zWDvzulwplw))Z3%#_R9$w(-gS#~gej-o)JRpOoO?Cudc2!+ z=~YJOj-9Ej3#l|YWrX=)X+q}~0!ehiCEE{=m9$Uivb5LhOSK=24S=18k*%@2uwa%{ zDYTwiBM8tJ#gbx;xPfP{B-qd^FZ|Vly<~XsAapPq_??102+Y;*V~$6u5dY+~17bJu z<41@%zw`?L{Hl1_TSx(*F;~(?4VrNS!!M+cfGmN%RBvL)AjR?w#WX)-lAxM$y*-ch z>CHQdQXpK$3DiA+WsD+NMRHLQ{7y1id*r_O(G6Ni?G-49!>DRs@tuoc%$9V2b(CL%R<$A4x0j31Ux za8ua;>QM#vt1jCS-1)NCZzz4gHf+HNZXP@3<~(z`5!~nRwGse6nnh%b;O4!S5L_wJ zN(}xztQ}&2I$7HL^QTsD*9%)CLP^AcBQK{$w;ZMu75Ku;j7mv};>Z_!2l2w(uwdqR z5S7`)^NT#n8y#FDU^nWv4P?p|sc$qBaMK2O;QcyvSNZ0_vxnGuaDCIH9Jb&u9J>aG zHSndhfM!RdGqFGNr5kY9MMQGFs(ZL#^6!O^AI_jSX!j?U;}RX>PZhTjn2t2+6d^Jq zH<~qq*FmN zhZd!qX6naUyg#i22R!FQHq%zc5`yWcHyrPs$jVrV<2hbZ2YUVSQuaF~fY@P6-g!O5 z)A`&Sl;Ze~(rLo1+0>6|!=^QOE`If#%`q z3)O3rM{b4tDd)z0>rf`XE<>EYdacpZ%!7DhdR0IK|_FeKY!}O7!$otH$ zZMq_1jwyIBNWFD$*-BcLB7zK^nBcfWa3fGY%2RX*J?b`C$m*LYcx*E? zV`ppmWRWGv_G<}m%c&Z?1Bm*Afdvx{3QcN9cToKFc7uYDr2B|qOvkE5I_?P)l7x^J zGe9O}trgN*UT$A^lO(oPEk)B!N5dO4+v=-(0)mY;2gZ*Ed=hLlJ_LAsgz9)rY%I8A zP=~%~gH%FiEt8m&8S_K;Huas~VC>`+HrfGpA3^LfB?nG|?XnBxxj_U`Pk95(J*%(V zLET03B5?Yls#@H`&_giz06X+rU>_!a)igih9rbr8;2Lpvsq3z5Xj&Py z7NXHY(;i@haBoj8L-(rs^Ji603@~>eLUV@tf<9{az~MG@12@0uf4ir7+q0MdEu&Ge zw7$86)Yh?@wRP%3%iY$-RU_8+-4cJfT=O<^xBo2;XOY^vOg;s52Bgl;QfKoE{(Kge z>3{IIw6Cdi|M&fQ_cC<`rM6w9wnHQS95}FAApB#2zcwCkM7R%5^ESLWgp1IS0Z?|I zOgwgzdjB2p*I;{o@Sgs+eGEKV0?)2euJJKHJUvaz6?ggHDsJ4s>p%J5?rmz@T`-m{ zb?zp0UO3#Jk5f_h=D4(PU;mvyFBTz$3VT!yM9+Fu<>4)_Ls`@I_9v`vJ3pK%vA}zKeRW{)>TZ4Cc5l{!k1m>Y66~MGTyw^gv|&a#IaB z3p3=0|lev_UfD{?Xs+!KPgGa{pV~-;?h2zdgXz zwp(c0gZK&T?kcc$m)f(W_E8P~5{$s3)QtPV|JJrS^fLe3{Y>p4sV!S-JEXzin?h6D z!!P;YY9HM|=QJ%t`UJw=rOrL1&WX?YTRqU!`9g*Nts-!KWYaV{VBH+QYx zeJ zm->(zKNi+xpH;IBTV!2-_FH|~u|wA4@&=2`#A&cfmvaQ2pH-h=nBbZ+OTn7zLu~0H zMKO+#Y{GVKbD|~AU1+KMkb7Ty5~EGcU*O+*;Q9glyB`=nofsYv5DfRzLKY10^ar4J&4w7!k)7K!~4sj9w_XGWtd6f#6UnBjG_9^tiMD zR}|kCJ9rTpp6&dy#+ko)u#9_s;X=UZjIlSGbe=RL}h#5V@kpPNk)fA0a+RQ z1sztvnf!EV!0wK;o1t>fe)@5=i;2C9a2CmeRXA^t^A)>jO}uN}jn^%D@9SVpzO0OW zAi0TA)Lz2}gmnPQ37FdhDB1XSHkgcitw7?@1lX8G_{`ag_$BeZ!24kzhCkXhX@-xL zqmvcL!j`!%h-`R6p8|R%V1enxPr{%t{3`HneqK>f$b19X@nX*Q(Qw;QnAe$x1%B5- z#q3ZEx;PR{TeK?FxEF+uvt1!b?IO}?q4)U%py^>kQ@=h-*oUC+dZlkqI%jG(%p!t7 zU-5N-zUuSf-aZ=G=&=@f2o1793^9r8i6T!VS^Kjnu}OC3c|X5eG2! zPla*K9%0?Q@o>W+LebhqB=o|5%P>6NO-De)GO!!CGExJo5n+qYfU6Jjr8B`rOJT`a z9`f-IJjg6A{>Kx!-MDtcY*G&_G)t(cso@K{9YY945=RlzV)I-sMQnr#b-$IdlL`{< zy$WC+yE{u6P4IJbf1Zj!DwVlI5H$eWl(<);zqVw;DY%NHgoI%qCT?H1*SkU`&akFH#P@T)(^kN(0-LaG!q1t|f&!c87ufjGnuCn3Ax&Dup|RRnPfwE*U6 zd8CvfnWzmq#ebWr72=}_iIj>#iMi~QrA?($I$o@c(KhsU-4G=Xh^NIh#1l%{Xb;F8 z{Jv6?Xf^ODYGTan;(uD|pj{dB&@O;5+kGJzbtdSgQC9gG6q8FdxH*SBmKZIAf*FpM zU!Ie!cq#JKHs{UI(NYKB*yjSD9f3Rf2&$`7gaF7gLo=06eGd(HL7+3;Gs<0G02f;{LkVuqpLY;|UX_UAPqhmKqKLgIA z2~FS$iYW2Bk4)ACHu4AYiNZO72f~cY0|@l<43esB9!eTrn8@gJ^Mi0IlL(c8kWGq9DZ@d|rKUW8v^K`Hg1s-`SzeyT1 zDbTlu&sgmfX_t?+i*`D7yUkj)~!30pZM;^B`g>ZZwySkL>FXrQw4G%+x&k!krj#XquX8LhoEB#)?AT{6Fc*m-M_rOK@{;1@W_@%D zeLz$Q5TfkeSyldXuVEk+ZK_0!9WSHdQYZ3OY>Q|m*%v2aOBf>Ez@1VFwL-j-b^l@| z9JVYc06PPygvw(TtOGD97|{1_&Pz`d4AEUwDGx|#NHv!ZS0Nf9QH#n+EVFeTkIzi1 z<2+v-b$vxz>Wqx(4x8|noGR!&Ol(az|Hg)Z3%rzWT{M{$l3u&{>sktKCitSibmx}i zUX9(8u(NLBH;fAvLos|0somUi@8CN^_0IyWrEb=W+b7~e85s80BUfp(8_t;#>R>ws z(B~ME3~Q%UUD0qa=afXCzzukoW%tdM3cf!3GNi{9?SX-JAfwSi!$pf-%Y5U=(nT z1;0Zy(2*53RRjE!(u0qUk=~WB0On6o_k;JN2bFwkAY}<#jON;l_>mDC4x4QV&C-n6 zBr(5Cjvs}ejM6g7ICiV7swFY%^hrrfw)t7Ixna};P0YC{K3m67zJx9Xem4cw?8m+2VBzgo=GqnbZeu@OP9=Ug>_wh$fKrrFTI)4vq`LK=)O&x~wB7uJ*do zY~xtKAKnR-Izr0`na42zvxKZ+vL`R+L?qFyJc0p|Q%FJbzIf>!`e75A>?}=o&lgh2 z*R0F6#r)~_B!J|qh zpUe&kDRJCES!@N0CFez`k`M5rlX=mJFP_GW&$Beg4=+F@FXv>?9dyYsRQVZS4Ad9T znM`l;-8)n{?x1`6Yrz-!&eeB!n0Jrz-4XikH1qCOzI%=u${n>{|df}aS z1z+^kOb7ABD85*TG0oe38h*Wja}TYnB*lJ({uqB6bVnY2-EcwiPxNfgORJA}qFh

uiI}tS$9a}xeiR|C} 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

Gz=NuG?y<#tBV&%j^%*=oObwM_^B4i zr1*bD{Hbn+7hthz4e5<_ra?v z>Xc5}SpnnIfr(j~C113+G^ci;rBORR0L+xU1baH65WWf8?Jv`xtPq;7uo}%^=gSSK z4+lJq!v^KTUJ}^e1+vgf7Ii!0xmg%B;Gj z*x`L)Zs>&bKLc~@*kmEP%&Nn7d^@do!_QPZg*otS&`W-`1WqS)jyM6OFS}I&XAIT9 zeln69xkLRtNF?o?_kibK{b??KfS;`P{vUV>=dQcQG;#9fjAoTVS-=7~_IxuoOg*9`pHpcOpOdajf}hd#X1(Zh&}-&=TtWM>XD{ zk#hqqX$9hxQYGb3s>>`}hZJDJ$+9PJVV`ZM&%RwP0B^`q-u6M8dhoD*%(XZxy<+`M zNd|{xs13(9K}$z^SwLABAP7tzJx-7AaXm&8gNx(?PT4PUuKtDVT*`fubqnEaY3~ht zxws(CNu!crASJ!T&PR-SaEn%)CBdF4k^6Z$Q)f8g5sY=5D@&n^!7btzL2t?M5Q9lo z`VQ_&vppMond=6c=0~S&wAYD)Lg1aSx$u1U04mf@s)?dSr3JC*szK0&Sn^go@1rX% z23ckwoGr~d*ww7wtwp7bG1`JBV0iCiXU%I`b`z7xrt0BPbOyxK#A58S4Z7Gvu440| z#VXnr+hU3-UF`gSQxHHEaBMnaL;=Ax9nyeiwew6{CBq{zTBB5Qm(55ednZHn9n90J zb)+cHk`M_km!MtH330TmZoa@ct0qsV47~wyeNC@IhlZvHjvksd9LziY4sjablG4Yi zwu1TD1oa32rEWTv&F~Xk)9UcmV*8ySq4UrxZ?v}0f+On;9fXlK`fR$~B~q8H}UFe^(1@y^*0=iws_4 zT1N@9kr^^3;1-BiuKLDRi{>h<5KjG&*ai`IE?A;Tl)+&(W`20^65rGrOn02meu(~v z%|EP@t&0@_S!DW zo~@PNGvG0d|F#H$<{I8MPjsR%ZTzH{Z+aQam@t7j@9P;$TW|Hx0j^mgSc=vTzUe&Y zn;f8TK*VH|uX_S#| ztO7M6POBRP6|=gGCrdVO?TDRB1y--0tsU=MT`;s?gPrrdGWy+C-+Xk)NZeurR>hc( zmTVGEiFr*ljMliw5Usytm!olIii{QjBY`zqYp9>6XpRILw2Dv=T2Gms^B^^NOqYqg zZOSZZSB8p?VlbOel!2AjWfnMPrnf62VuUiHeNd*-0Q8PZ%T1>b;ms~Hb zB~zkB9~xH_(}d)BQLwekwxAr=y7C}%`BE5wHgCo0PrdAK^E65+r3bss}JQ6zDSGSdx4UHCH$3YsjXGXde>Y1VS z86&trzKnEK7n22bjh2N13x}Z4o)Vz68}0~m^MnQYsD``XX5MK#V$2(5s>|Op9X+@{ z-pWZZT77m6+jMi(K&L>uDX?d5hxBRA{dJXT}yX-l;$7sv6o=cOataW16*FehW%jaw4gRyau5*8U)#ZH32bmyz|rwv)2Q zson5JBcH3!b3`3KyArHxxu)e}{44v%C$b0YwgHy0w4(e2j;$fu@f@p%z*wJHRxLwd zbgOF!eC8R3Z@v8zmGCVq$gTy@x!`4>uptUAo++y4YDecHgTvsZWbkq* zze87Qa+62$qzd(2ZG0z-Iznh9l}v$K$&C4r>8c^OCYAsj(DLF6_J>_g5`5_xGbZzp z25nC4q#72HPEzklC+){22;!@D;8g#MA^W$Lzp zzsEw=qJK(>8*FrvHK9^;PFa%9d7;pB&bT8Jlu9Z)M{I=*9nF~vQP0NqK6;lPL1_w5 z$*B9!)QJ13TA(^*Hj;}>Km13qzDcmA+JTaQ31-*>Cf}fbN0ST2qufQHio|+y^~&*M zgeRy5Rlj!o1JOrpVTNu&FYWMzCr!>S--C|4t5E;kwH-hIfv;-ba=bkgPv8Xl*0a<8 zC*xBW^A{Fq`WlU#rL3Q}0~T2Yc1`&Jfp^{&5^>5PCo-4d=Bcv)Ze+GfBdnJK>L@4Z z7r3lYd&ANhV^sBz=oAakpfkzq`OYI{5hil{nA+b?&f}dn<2&G(q1>u24nVj|67w_u zQ0fqwo;kobzc4L-JZ>w5QK;$?>Nw=&L4%I3gdZtErcm!tC8#peq8pL-*Ie)OTreik zb2%&r=$T7?#poV?u%5l??bv#@Ui-p&_Gd>>K`r;Zj*qG8%?Y?q$^SAIwGT|krBg?Y z`Mym(@*b`)?eo>jHgz?2$Eri`LYF@HG5)kXfj=*9L5JI(tG{+hZ5J}=qA#~&A^ghq zdLcZ6v&(%5RnWWeRCE-!NmkyAU&fC(ltrdWk%8_a?=ijvaU#0N+mE|i5#M5@6!~qP ztCi`x$WgjTbBe1KEO@4mqmj z+trE;mtK`3SGkM4(n)Z6L>H+$(PfPGWh;$RKeL4YdA7_4cuX>b`Nu5vF06(#jBjFu|4mMbg=lMzadvV7AZhOz2dH6 znyEq7&}`3L(Hb7zLk(bkHPKzeFjGUOhT*T#8ZO&I4KUK`1a}STriLY)sIfia^BgP= z*+UH=rTVeNMTg~UG#&n?Yxp2q!^cM_r$Yg1c)?vmy{Vy(uHp4)4fpS%h8ooHH+K!E zn;KTq6SqAbqcvQ(hZ+!*t&VZmkYZ|>plc|M)^Na{YUq%nB9@B|Z$SBxs}IvPOg-13 z{-plBr>>xZ{p#l&+y)vB>h@v7QN&Y_#~`YnD@+iT3E!|iEy$)qi0wo` zRUhP`&G)ODkbqM!1pvE%vvx>fo?P+EHi;1XTo46OwtJr zOvqsZPpLw&eGU?CVM1h=6#0+|*D+z1 zPFTl;(M%|ogdyoC(Q#@~7Smd|>%bn8X3_>RtyZV06Lmg6(@xfDpPRI9O#6}7cGyE^ zo3vI2W6srS516#inRb;&a6IRH3($jg)J z^@zKY@l(YvH?s0q)3xE@6G{j53hw}c&JNUXTN@J-XBs&Zw!&yM3*~r^fB25r(k+Br1tnEkC?2mkd zQi=XIRdBoU42F+x9#d0acVUhJ8Q0EuSb8N(Gb^38$$n_aZ{E{=B|MlBb<$L^)POL| zdMx1ru#or1B>_!e(`GdzfEg$NKrqmPZm`3t7aIz%SwRY#2 zYsOyXo7voW&SChRC(%E3yHanyYT(Mob08sBHRj#N33&AK)UD^cKocauP@MXgljP3I z3VF%_l4bvcv9SB&w7GOM9;#pm7l38Bn7>x7VnpWW?0L*8$l~X7Q^<#LzUbpvHFrnk z0rN0VcEap;01rTiaPF0rU6v2+n;Je?r&JK-hVJ@@^nHCAek>n)XsQfXRViaqZJ5SHoSKlt3s@C04 ziwm?u-ZS6SopqV080Rz?OfgsEzd05trdtBgvHBukNYqR{^&8qxI`ldAHn;NKD&5YR z6ySoH3eR|_*}pi=lB7UT#0+%Ci{PBD=6vh0BY02s-r)Q~4sqtIfsnHcu7L=>(Y_+(Cr!z>R!~I7s||E21c#hJ9}H9;n$Een zkf;Ar`f^n~0;p>V2a28JkVO3U8C(Z32w>~_b`;|T`fNTOTy4+W)-3qjh!Bk|Ch!)9 zd6!*9jGSSf?Qk9O+27z}g=fKMQ9E7&>+gp*H@|bg;YjE<==lB;|ALu?(Ch8@lH9hx zo>;gZ-%{1;9ht9Y==T%bdT_i?vQ6qGpP$j%Np@ztyIZj?B}PE ztWdpJK~Gm-j{nl|Gy2ybRnYYrM#?M}*4!pC<*c*Q-KhVJm70~#GQ$b8kw&qZ$8WZG z)MCzuQrXGsDAnm<*J+l@B1=Jzrs*C6L4NHZ(G z==o%mr(dm#n>>XSwW1XN8F1;HvjL6owCFbcCS(DVu_vgz!@Y#(skv=Whh3&0!gp&- zz$mo*ws+2{q%E=a9wcNYg1{2`9`1$ecLR3o0;L@0FW`q4X}70|d!B;qsOLC!NruI{`Wa+dfEdIhq&rTL8)y@z1* zYjHh~74qwe&VlI?kJVlJoO_rxyKG`j!@p-UEd2#P7LtdTkO-iOdI z4H)dGqcdcoq<$U}+Ax%fv$onF7G^K=v1`sCmT6=NRvFxQ;q{) zpt%dVN|&z2QG*33PG+<%tl}yk(?_yi!;?P}#v7O)JW6)B-7AmG`}hb_lhAy^8fSnz zy1YqU&anhsJAW2xQTuV+2Iz94&;d@Fqpu_ZjVY?oLk>(0!}J(y2p`1^Db9W#RJ#yD z7^PYaUb`r}N$bxh_C)PA>4@N5qc!wX^`Qg<3Zb!IYq}7liz)#;4f6$}3V6l~V1UF{ z5@634J%A)ov4Dv)($XtM99Ut9

^tzCKfuL1D_0kL9OEO;zP9llB{I57;N6inbXMA3SHV22iER`F_fx)(l_ zGE{I3RNd>e>VZ62aUffkd0)(N?GqVsm76WB*uo68V*iJ7>@mh!G88gM)pmhw!zDBJ zKt}igL`qC`N1?j#vm$Od^Pu~T*1O{!7OBy-h={9nLY1LLqsI6lBPp~7HFP+gza1if|Ww+Q_cvV0szc>^@KBBd&?~OfK3SNU7LDS_vv$tV3mkZ zN(Qg)f)HcvUGjUe_Ik%ydlaPH#vq7O4KZKcQY|=EuZ>1;ZUx3{1do3Gd)C_%R3-@J z#1j#!>rMU@_5NqD)O&QaUI=$v_hxXVUNAvGR6eWS=36p@;t&j7=SZ(x*L*;B@m|8q zFOVd1&2I>QgX!&o4Pk|gL0&&;1T=6=BV>XE3R?}?`^(5n*Nte4yp?*UeiFCM~bes+%`Q!<9OnlV=B!kW%S{|2Ju3bchMVbZ>) zIU}5dE9Ck7<>3=?hgtq(d1(m0Dr9Q@tY3j#6j_Q)>gPJqc|YjO zg(sqwUGUym({H^6pt-hE&Y|y)aHq}#8_@bx&{!bT3z0p)q2(J)>$SKU;`HS%9lSq) zvb-9{lHn3uq$7hIeTBkbh}V#@wev*An&>GmQLp{4WPmG3j2qYj!1>817@R{L`?acn z^^@2UFyGmF_>Zl($Hm0O_GfX(hOhMCz_?(5vW`3EjmjS42F0RdvbY$(3a|Nxv}MrN z06%scK*u_;HEMW3H*h@umu<1o7_+Qd^1A0byKBGgkX>;Y4*|30J;mh{ z7(FV9@-rcgP*+qTH1;9XJ75V*iknl`-w*GBE*lc@N66@XTq0VcoO)9)*vG8+1ic;rt39J z2%w6#wNt5TJ|0x~k{;Pb=}F=dHnb+p>MRaw99wxh)m+ibuFmV zMCczL5&HC9hGo(mvfft32qkR^qv(84ZAhw$s2H~@tzsVi_7|$ULs#YM7xZ5~B{5i* zzKrlnV>;OCGX#XTY@=k}!qCtfesHYAq;im8I-6p4%_G4i-pXMAeCWPE^^ILQ&|8;Ic| zq*d={pb@FKOQ81;NGfgCki%s}|08!S0JCHIsluJF<(y4;3xyJR6Zd1Y^u0J#^dt{k z?GGg(K~I=iz5hukAk4)Yb8;0_R3H;`Qc>}O^q7v)Zb0t^lpn(5Y_Z<96P|~OASTWr znKuOEsu(cVozw;lwf$H$*$e-Zt2*SG(Ec6dtwjG{3Hg0FzQpnS?Mw==VFf-^MYM(f zAsQ#n^>+aL%>^~l$=i-AM+kpk5cT;e|m^iv9(G`2+|v_-!E;gzqxX7$k^jdDG)fYv~a zMtpuR30vYZh6QfX_TJy#78baV7qlGB=O_yFqMHx;_amWtzYhRQ!d*iDch&vxr~fO5 z{;wQRV=>KzT6QrOp}k_9*iFeg^q`2S9urHyBzV-Tx2u4b9-a}h(gx6FbXzJ|=X8EA z!E4MNSkH~r^bH=LpGhh*%8`PfP-9v}&g(@Eb>(?L>sn$i8(*m+Wo->g+4_lAk+31~ z@p$INs)kKbTOosJ@Ti+Nw^5Nsyhwe}k3zwbde!s2fhHbHAK{red>wNBd#NVH^j|lB zlaHEyjlVOle&5VHsALZokIylE9LrjG!J#z!lHQB2$(a}y3m;b=l#fg78uIZ~NNxNV z9g(L?{RsLmE{OUs3?KLFr}_8<(o!&dWT1 zvsf0}LBqgW)18ElBxR?n7Yp@xT__L)6!9k@qwyy^ngvkWizvU=^iC?N7v;5Gy-^Cv z!y*DGLvS8=Ky63tXA3kj0du@P`;nU?{sRaRf}E~}$Vn}c!MR~&4B4V1bYMC%IG5Q~ zNQzpN9)2H`W(Hj^XZ;Fk@#cTqNDFtYa~|re0!GQ0s1L0OpNrBlq~YH4@-{|ze5v*4 zA6JX;DB%Unuz>l2nuSu%L@+f`0ui#9D)jWJGLi}P0^k$yLbFI5eIANGcD(eP_#+e5 z{2%xuQ}YMdx=B}d5_d7J2Pd(=P#amMsD5@JjZzN zeM@kR%08|Id&kb*=yd7j~a+Vu?#Hy04UkSFPPXU8%x7N zcpIt3u`YNw+Oju~Y11-w!(<`j6-R=M-;9uPJMtbQE#r@Vm`>mJ&x--qx&G)Ykt$C5 zcEgLPui01oJtS{C{%8y@BmU$n;k-n<3jSouRr)*YY?G>5V+5Ygk;~ zvHoPKCLrsTcKPPYOqg>E1c5l&>QlNw0zV9RXbfBc1@JWPvCylLe&hpWv(Q}{T=72} zYcSx9fL9O2UBwj6tr&wzaj3dS zh`xX`SMA2CkzWS!qrRfThA}0KscOM73Q~_Rj<l zq`!Ilj))R9V@FZ+sLo{%@h!ypn^8mn5^Rc;%VDV~ciE#3W;UCXq3%MtL?-0@LEXI* zGJy0A+`1|N;;;S&Tv!hRTG zhre~RO2J+DbM0@njlVTJ4v>S4Sk4xJ;zlg44MKmb9qleu7#@upV1snU#r+UthI|62 zD=@dMK`{3&FTj|_Ty6W9+YtUMGN~uaM2bJEFMCqanBjQeCcdR3#Zb*}j(4QXNrtc! z81T3fGx!WauJqSW>d2d^xJdy6O!KV^PQtiWTcSY|{n+ambO$Egv^^Xj{b)Adat1-G zmt#?9Bs4k39_FHacD|q9q#~~RfvBTBTt!mC2e1xET>X`L9mENgbI2Q&cgSe$;W>Ro zn8*stqF7;a$s#RGqV_PUIbsAt*<%n8A8oh+0jAm>_JfsEj&WJp^>`WK!SKM}Z6nbl zy37a>FC>_Q{%e=JJ)Ik(vQzl{TsFydC z>7r%eJMAVRl=lxq@!P<|QF|5oy;=LuH`36m-nmRLu*htYWUfGa1K;!bWjUh`f&@n| zcg9MrEW35NjpM(dG?@UAL2mEf;<26A_1F@2=q}o!yVUO?hULU)7YXP@m|xQ%OP!Y! z6L*OuW+J4-;2hCEwjnGw0kLn%(N#a4<(uDxC6BewNfS^M z)0Dyui-Wl6`YLE`E(|ut#u6kqF-TxNzTqSvUtJpGmq3OY6s_4dU7YwVGL3{Ni+I$s zlRuJuqSI?Jkr6LyGu+a`Yh@V1;kTyNwm#~`1hRSsyFvT8j6Wa3GxifqKAvDGCSUt0 z)U1ip>D#)a)4QSGh;`RSKFGv#_0B3*jjpO>R{=sZ_LNR9O2zSiroV9n;6|VG6;cO6 zdhNFDu(Kt)HPR~q$X50WkzGW#$YP3Yb{-+;Zyqw&2Q`~`fk^*NkG#yNGwB&>)@ZSei^Sy2=n z0^hI1Bs)01=SEV&z67ay3bAe6dBAtlLGVpnubqO8_zXfJ1+*+RK89E%5t|L@CN?u& zx+#*&1d+NMWX0xEORp2urgjBtX<4;P&rWS7H$l@Pt&!$(HMUJ8o)^hR>9%98pl;~~ zP@KBlaHUvdqDWE=r!VKwHn=BzBa5h6o>kD=kRSX4p-YTDaYo{8Ak>v76mMqlIOlr` zfE>X9%aCLsZtF(ymrm@E_t0V4(ih|gixKuAm2 z!rXnny35e;h{`Mu1W(3Fb(ol1JoU=+{aF)7m}FgXEJ7rz{wrghjx=ce(hIeby>hbnT)l#w(*&I* zbROKFAN;_#WLoAaLh{ekZV|B$qA$TolmXO9$2x2+Pab0GfN2jN^Mc<7ICT@j^!hVh zOq=w`Cx9aZ(MVmxj4@driOIsG0VpUYEvWgav(KR}!JXx+TZuc4@vHZpRd!`LwoT-- zZ;73fSGBLS;wU-OAio|+04^2Oh8GcH&=8+ z8U9XSu4~F)r{onVW6)hHgDRK>yO&3CEiXOlUn_nKt_er@R`jaeT#p-H?Lsu7B70;g zBd_}Bvu?e*6pL1*SxZX@-_O_HSaAp7D*=2zU+b&oxqZ@_)7>29S5};e*67sb6&1bQ z)VEd~mdE3)5u&+Hj;BDruD-gXP(oqIQ}EhZS5}ml-aP5L!rTvibt!m@Qv4p&xwm|( zul5D-rK~PyZ7uWU_bw5DT&(IRnorBG4`iN7y}?%yik9u+UjCflfX$SSbva4u4FnvJ zH@Ziv4~i2pPazd!6l)pEy550wM8>wMwYkOh1Em0Q@-rQ&F#A%yC| zv~koPvW|aQjQyUx`~q*NV=V~0qcC=e3cRR30mnU{h258EDukUvgDLE`@d{zbtAVA8 zub{-pLHskXg%Lnc+U%Vk{xh4UYnr zdpO=%qvs(rdAr^2F#o`8ROWuBcJdO!;QsKVkN z2Pm9VR>84Q(AL6>oHMzPkTWS-LoNyagx!D+valC2(W=%B znkm@816}_o?1h7aQ4V)7<~JnuXHdr=Bljj`)Pe`L@hz-`9V5tj{K>c>7#atQ0FDqu zWn;F{Nt@9hwPSnQ+DQ-&;cYBChJtCdX*vF|p|9;QdfU(!fXKmC(n9Z;m+NzfPv+&) zIX+$5kwp$q2S5P3$I1@)rMuS|S615*hYDBP1GH-oiRaYl#FdhGmH6>^yK=^Q{YG2N za_^)qc$R`lPw)}wdc5y}|G<8L%Mgex*+@uwG&CGtdlVz#Yh^DKD0q#eD**6YhY{dA zvj{N5iR|FHS-vG!Q`a++5eHIYM>6y5#LGNBY)Q9(HAQw6Hj&{tDegE<8bVb=IO=U@ z9XG8jGASMSIfFN9cj{*dk=COfJi9`J4Q4L`uSqbp!RO6*gLH4Esr5-S%LK6;Z z45hd(bgWPQ>8dnc3Q5(Ymc5p!)pSqSnx5W!ecPT^XY_}ab7@0(D=j+m_Vyp*=!?@E zMF5X(7>!qO?fqnW|pDRJjy*@%m$ah?44~G%0=_tu)5nYRB(;N*QymTD)oL)LJ9za z^%=<7UGvna_VULA_UN)0P2pH4b<&TilD|hg`C(E03*J0z20VgRE&6*noqO@6+VQ0} zTCt_RR@$~z^VE~=yp?r)T41U7Pl6qRbsQvZ)hrKN`B17}lZQP4_;42EHo#rNp=Z<+ z^6-vuin?DO;CO6SA>4*97ssF0VrnYioWTf75)G8<>kD)b;r>5AQ6GUn)rglr;Cb=g z|F;GE4d5(dV-m#J1GSkMkd)da_(7WlB|s!i0>;+SB;eKb(KgTlrG+9rIM(+gOq|0< zCcY4w&h-M!&Makq+5hy0yMu}L!nwKO@r!8QJ39I zwyf1fLJ-#0AvH#X)%*H1|L;-XtQH8`>U}-NIUV4RcG7;%q!w6?ZOtiw!Mm*9S9=7; z2i5zA<%JK^%ZHHi@RLl+?EyTNr~tDCHtRdpF;u}W48%vMSDre~^G zu%numLE)n>ysv-!TvE#h(@zvGwHSdmU}p=K?^wYv??VyLz6)N`auNoC1lzd-a5I!f zoXAYW_ioE{3ErZ!sh?b7)JQvX_3iH|})rhWjuptus4_$f%c}(ZvdVq6aa%!?Tspm^)z&;z9^1 zXDGn6Vx28|&!Bz1ZrJ~}&qWH3Z{5^XP@4?mQLd4kk{l&&*4ZZ1xrjI8e8LVI{i84T zv@wq))eG_QvNoBcH7#iUKM!)1C$m zSmEBgO?yOJurXU+Ow_iL7L94vc^<5F8xv)1G{#%@k60=?LK3^P7lF+7sOV-dsOUZj zY~6W-aaXJIcw=2Q_%uOdJ$CkO?4kKOwmI**hDI!TrB?b}!I91)#5JP>`Z z`IAS))ON6);oTuRP}p7;W|X8rf_o}y-WvogU=p0Ky)8=cl8YikebEL9k{l&3)Y&R# zw2y>!-P=Qg&fGqYT+j_jxCQ!A)5vj#tIG_SluJ}wIp%8Ps$1%c$NzRTJy-pFV$U%% z(LtGJhd96NaLYg8P4DU3DOO=P7PQI7%9zg|$yd_=u>{NjV_QDa7*mZeB-TgZn6HRe z$119BA4xa-n+BsRj;UTKA~moslE4yL9P>t<*cC_$z+})!+60nT_lyxIY0LL85Wa{Q z2vPe${LeQ1YBf6{O(wGS{0Uj5H^LX;c;EHBDF~2;sU2H)iCoU$Bh)%Ij7U+Zk1FH# z-Ixl2w1t@fz|~+_C&Z|vF43v+p_mL>MbJZ|Gq}HKJ@1iK40Na>9eusp^V|pvPkg6K3$MG;1E4f-t69k^P~=<$i^J$sKXb zcmO(o0binGSV4wiLPUJcib@31j^V6UTG|zQM|9l`0eI89054Z(@0*N9i~c$dj>3ErWHyB$1BeY!n{R4gyny9S_yA-Dt-M zvZ0Nj~P*s};beyoY(4*~mWZE6J_37{Os5tnbAKre#?P739-(3%z5O==Ke zXqgdPzY~eSI*m-*e*Be4MNpQn2c;Plfly_rewUD3mEwg)_J<;g3<;^uAO0-d%55Rb zu_GSrEUaw@J{M(HF^9Wm6L_*&=mUJoSsRT)oN^4ZErRn3NR|0nEEU-}pPp8oHdHTa zAvA9RGm=L}v;NTGH8_&!&yDcg4&&ST%loc@BljGJ=JuBa4{Vm27H^ZwG65eolrmVL zjG;%BbP?h46T7hmJHzf6X76c2$H9?JKfN9N&VKg`yYcH|?Ki8YzqrZEcgY91Gj`oS zcrQCE4TCR*)57IfVMBE^(NAJ3v4ar(2kzJIVzin^ISbVQX}Ez10-e&6HH_=icykVJ zu<@gzVF(%7aWfu;YTEbziJ-*})$8`nlZJ(=wh7Ea<{~-~F`z;_nE_M!vK=`ldoM=w z=z&H1zq5k}!l&XH!{Fh(YzRL?{TT8-`6r5S>#&Y*CWU+AmHO;!(DV!Oyh%2Vr|;81 z-{{PfVc+6EYIP~1s2Cko0n)(hniU?z1*35-yOe`sTV6XDzfV4Rc^U1OH}wBnUP=4q zef8BL;Twterjwsj$0Dt4(jgDmhRVB_*l(iEl&y-el0$6 zWLJCm9C~PYivcgB*F=gr{s>5k++BX0KuO`JPI=$uY>;a<8s@`k?5}X)nPQ=G;sNW|3p`-Z&{DVvy%ExK<00;tZmU`rK%0cnz(dfVju(h~LS$qw4X5t4^*&`;NjB#m?%WGZ0ZTy2XsF{#4=~jan1ZYm5RDzBCY;<+j|&VD z8II8STisLRZ>^gCUx3JYL>Ib5{N)3_RN@a%;0KQDF5jO{$91~W{ugi;nh(Nek{TRT z!l6w%#3HcdzEbI^rseOtj`;Rp5#N54|MYh(KbDUb55%)WkDBWae!@xI^qEeBh@>#S7VVmbIDxIKu<90Sm#WE0=sXg zC#g@m(HTo23^0n(H@;cN$lzaGhOy}}Ou23{fDd`c$tCS-UQoRTivVV+$13!xnts+( z%rdi?1l7xS@U&TiBykzGK-m$940Ro1<1`SklxDvojc}n^z$X-DvxrhV7zYwbwJVW< zn+!j0)EruBXit`|TdD<%A+EMo#@qAMkkQ)xyqEc^SFq1y5KzKwsK6Z{uu42EW-@$% zT+t4P@?-5#o(Hb!mLun>Z$`CO7-WhWEYsTHU|Gx!$I4zG9ovh6#@qVdBUb?X1N3#tu%P*Od=qb{*q z9qX&zE;G2F2;$Pm;z6X;AmJT*iE!xyBYBA+uz^JaXXxx&6GUqexE^1O#as!_&v++_ z56L9>*q>0DIM-%pRv|C)?0%UJ4FG_~d3wq_N#M2@{i)l_8+FdliS2!W-`z1G_B`Dc zZLj{s_O5!g{q~-whxiNgrM(eS#`zTM=(_+6YT`pOP4M|=kj(4hN{W-0zL|X}D&p49 zafB{4b4AXNV7_I3g6NLhYxXDmX0H*RG+Tr?w;sTHjN^Q>#*)~BIHeJh!PxPqgU{hU zp#yQGQ8VZ>?^R-;VB@D)OYFCMH5Bx1EO7E#2d>8UT`isL*2Y3)g}`y%MLNV$^gL{& zGj4qz&oi7=gI92B#i*B_moavqyKj07@M5U4cNNjgmz1Lz2`f` zK0ui74Fs2CrBnDdI<-0BEn_y=QaHWj41d*u>{1k2Ji*=>p1PBbdcoFgLx2f~G_M;Gl&N#!FHwAcbv`A*u2_x~An zBVnk|jxscrM!D*7vql`)Qbu+_ocG4BfVkBaS1~t=_95?o?~CMp%+1SAkZRJ^+M8lZ zK|c}wC$W@<3a^X)uuQ}X${+3m-s>UqsF9!j>Mp#oL4%Z%@3zdbLk4ZtD~Qb|)qg8G zpbk7FW@i-t;=g@_$Vv34g~C>7n@ipB3BW%W4Q|I?_swk5@B`Ic>y9x2 zeypPHoYz1_)TuJ9vGVm#4ELal>`2#UNh*Lzi}jo{H6v*|qdN*#b5Gwcf%qBRNNA$bD!>J46B4}>G(yv{Yd@xe_eY6hwACnli(JJgY^M9ONf+k{Lh6+9)d`%n}(ee&D*dSOh;?K@&p zS{2VTrIiG=Gqm;1)}+agBKff~$(Kfw$Mi_6IP8A2y(bXRDlp{(k;S z%8u@!HSe<%$%#U$0er(O!MD>1S=EjWx4l`tNYlfB5RsJ%o6Sv3mFJ#Qp-we8Y~f2)=M;Ga1FcZ%Oa2)jw6?@s5jO6WUjQ z2itP`9YcIIvzWvgI^;lqtVbPmCL(Lge^=A=W(~}d*D-Fhk)Ng4z$}BLZ=3diMyP9c0>`d= zTXqdzwZN0g9_M+8L%)QW_stap4n2XF-c4g&vPpaEdXkMhKvi#yj<7P;S-|tOl=#e` zJX3#N>6#cQ26!f|p}(mAW=esg|BjFX86b_8BO_PN{rO6kI*o{MHKBF&7f~IC?&};r z9}VUAY_+)qblBPQ7!iQAn}LhgSW3`rlRytajgMG*a4c2K=29YC71zb+D=k^n)Qbs?JlkuCp>ij4U3=nqdPEkJbf2f(5WP#!fMP?My_e-~HWDJ<^b{`D~^ z4+Ts_&!Ig0Sktl@${btbQJ=HKX;AE)LzeRy9e%)vm?yAr0J-r9W0=sI1bc9&TJ`}d zy}zCQn|vbbL%SzZXYvQ|qd7qK58r68wbM>bW(g};!f$T>xAE;~L9y*;m8chPRuKPT zaJ!}>Bq)m=t9^y3NwDmj4uXH*OgROkjSsg-CbJlSjalbENa;i&sw$RF=3R*vlemKv zd?69cC~T24X;XYx%JJ$wj8j8-X&gy z$KC_KaE9ri_&t{6fH-+a+=1ud0Mz*P)rJLPIesPpIfV+<-|yGB1V>P60hd{}9IcWR z>a*oj84i0m0ObA)2+`J!7h#ExPZxbSJS)`a1)Vgf?xTu{NR}hGajXZf)F=n`-#C$5 zpOA#m##D7++DEM+s}kA34+Au)tNa`rqUVIRY0=^iT}xs>Z)$^&NX!P_-bVOk%X_$4 z!JB)r6&CK7;U3r)$zpUh3URZlu^WNK6$Xp({E;vp#frt4nQ|Da2cc1BP|Tnu8$WS1 z|NlqYxxnW+-v2+XJ_L;?wZ?*#Y%;Pr#fr7mq#F9viWJi*BW5Uy(1e;(B1xOa)4RgT zif-$E*lIJY!>{VFEv4FGwyL3HrcQG`VswsOnf~9O?{(eJAq}?Qzb|q>_kCZ7@A><^ zzSrSSlpYqRsdqZW9MgxZ0mjcq33v!<;k|G`GN4#qLF_#nj>zcJ{DXn5(N48^{V&))vd0q`U0!G|_Wr z4<9pgFu6PIV-Ws_9YnUujphdO_dVuz-p9z{o`m27&F3d)wtM(%Wz+KU$*7oM2x47o z^kdVHOD%mF3{D&j2Ezv{!ZW3qeL2G9>J0bFF#$q zavBZE`DPP*pyDpCH2}v8!0(wK%F~z93w%ER4}NgHR*l~TxNokkRr3b8dX?t-8wAo+fPUe5NqugqQ7q4Dw8|}7P`m|xB74B? zV~+u{sbXA%%`J*oje@5+#lA^rlpPNTk1EfMI8%T;-+ELk{YCUF^E9gl!CAS%QupH( zFBw0Zm3v!nII3}OY_DQ9-;id_u@Zj3>iq3tc6P>5Cw=k?ErH%zg|1YLw*jDh8XrcJauc3$b{1 zxyJ%cHD3Vc6s;tAQJzVhrP{r%P!+-Z+{yy!)bd!XpvJ@^Eud@~;s_T$fy%5fK+ z52?^?hVU^<9}>X;(il*C{CtlZa)GqwQTz6_F>1%}?WfE9I(2h1egV!Gvo}lgBktrR zhkYk*DU(8!8(H#zOPs7CMvuli;sazs=OXBh$x zE_)7UKguV^SJb8SgqHAfbtJ(9R+8p6y&$0J=Gx<~`lhFB3QyF4R4>KjE&o6!cV%C% z^a^QZaY!cdWwqVgx`S*)V`{}%qY|YgbamMoib^DYRG+2lD#Zz_nQ=wjWSb^Isu4xC zESB-NsX72f3?@{Wd6HU`>ep2LLb5FsvuR59s4**nSg4O0y+IyrVR#7Az|rG&$NojQ z<%uxA9}&8W3r1zPd?X*7B8B+%zgVEgx1?Dw!@*?PBT#gA%lpXHIDYlG2}O0?;g9p? zI&#bwRP~d$+r{1DcnYAV!iad{s#%z&g0P*WPetp#pRoPy>R8y`+`|i--&y8EGp+VY zb|!MNh8xSv=}oz+cZRBepmX1e7p`QNjp{Nf1oBZ9pBQ@(_T1O6d-&d!r)wNM<#=b@ zz`6(Cp(KHKP5Ol-#Jq#afp@jS4JO-C3Aotf*6&-~dg7=Vj3P5-b-Kjl3KbCR9=D>X zLXW$*=pMWC%)er8p7?A(Zt65l_sqNS>`%tcON#2cOCOc};7tgTi}-ork^OBugH>1; zp`_qbDs)A@I%A)H86*AqsN%W%x6wW}$Zi{Y>zkjC#`}-AKD9r{`ycfe75Dd(m7m?; zQU6E$z!VC|hkvQK!#&mEO$7)R(K9)7iPw*+0{=o=qb$F4xmm`%lNmd0U?;P5cB~wK z`kGgcedC%I2TD0U5Ljl2iTeBx8xZ>M32DfZsi=4wF(No3#=K+(CipU0 zA((p%M){Z~LQK{KtQc2ESqi&9OXe<-sb;7*E*NH8vM?-D@tD26xRkf1YY2;`M3`gh zrFM^dgP^y-^GTfCu3Am{JeGEZelS6bWVvDb-PYsoE2_}rZY#P+8&-Z0Yr~P&_l&%4 zbJB*D>yY`snKqo$uWn+G)wyBH`J>}u%0-w1_O3N7r{3;)T@jm$_^U+H`dgk)gHPV+V4GF4bAV-0vne^J=N45(H zS+@nw;QDlo&@H=qRnZv%LJE4omZ-s4!@Q#iZV;akAgm%>sIe>vabV)<5&hFt(^o&u zQ2ZZHN>9)+0*5_)yJ^}DQA~MCO#BPJ(q8q=+5}QDVD%rtaJykgw(%Y+2dZ= z%hSjA?*8^L^!fCB^@UpRSV$W~j3BeYIxd;&*(_YqI2q8WZ1=Clxmra&JS=xpj|vG( zsA(+->bv<~xi}T*ko)Bh7fheB-tp{W*;8vZ3VJ6PJk4jsVpjmqO*MIVV4uO$=-~k~ z0Qq_VB-W2OMs`ad0+34!g{QwhCTHr*6Xto_bU}o$Ui!lzRPmEp-5=R2`dQ7_nR9Oh zAg4JgRnu=oI^Wo(5oyKR-2}RZ&PH1D6dwMSJ3X_pk1&##wENh%>4}jjFS(oj6o?()`lCe~ zrMR4~(?V-j+>U#oq0T{>ibt)`#kE?Xv%mE)7K!A8%fQf8X|>{SF0tfQtL;C~DxdTu zqnHubJ@T~Ip-NLWREXh%3IV;LlbKY-$F!=f_5^!z<3fR*xpsjeN29mONiqaQH~g0O zeR_33Qr~V$?xZ*#Dc@NBz{-X+-@LiBdfdcxZ%XGT+2{pBk!un%VeAaP`5n%XXxTy$KuKRlGiZl&KH9nk3C~MxXhEYgL5-R> ztJj3wVPS+O473Vv5m!vn;lGbPltvkpV?XB%&yjLb2dZ^etB!_1MuaGF+!Ogahxs}; zU(~;jwNITTzMm`Kx|=2t0Ss>GaG*{_al1-m@U-9JxIxeQ`8SxW(3h6h8Wf#j?Ol+- z_GJ>xhefu%5yD6Dr&;~s0GedyXpL84=JG2A1*R3gW~MZ!G8aspm^q}0bE=wP#XcMR zwwTb-Tb|muLMJVgGvT;9W+RWtR8HvFFu3&<&f@t39c-BTjaK%&k8MarlNeUg+Y^E) zO8ot@u*&$?{}W_cMC-PfWuuQ70^&$_`5*Gq-KBTn)#Ohyi3OICr#L{9U-+Jk0p#Mt zv2%XS&q5-(?;N3iF0HQ8q{foRZJ@bpUi-HQtX^xq6cZ{g<%T(Y|1+r!xqX-5cSsER z4Qj5V^cnoocWFA68Cs2TAsru|U6E?YZecR^V0D{%!0Rk~U0%l*$i4yj{a3lxTroZs zox}{@l&O|0Tv11Ia85&3}V@rsK+&>^wHKo z#(J7P+HhiLiTmL1kme=8=xn-+j)Kr0CtQ)!a<1|4v(ioZbMZ8BXAslb1Bz)#_wamWHy+bnrrYsou!Wx_`eWim%LGt>;l<&XQkvD4(`Ppum^i!@oIp zMQi~Q_w5zOwLks3#kDgYpyj*SjalSB(e{-1XzQhZ!x9r*$|$L4`u6HtU2!RP1s2_U@N_z_zn`rVDFH zD*PV%{ZkpA1918slQf1S(|{1o4{*d=HGziEf;f+^~vLUWd~Pn2r%rCQ1hN~xH;wy;#AFSX4!{YyH5vS>I$CF2b0*=6jQj@g5IDc3G~>VzO%p)x`|8s0DS1z*?G0r6-#}dvTad z+WnnJ#KDW~D5g80SYGB%CQ7*{9LjLfsLXyVDLFA3U#D$+r(4N;yzr+ls#D2cYyaLw zTr&IJWQAufG6%Gf#OJde3O0~ zr_dOq9FX>gN2I;`T1 zRt*QyWp`brw=M~V%G6emHcHA&AQ^)gJQ$)`-|QqtF@%slSha1E=#u=bm~M5`83CFp z`|HD!iU)eRQ8RzFNVY?_nT|I8M&0z(_TgXJF}FCS=vNf*A6o1G#=d_VC7vHEYYnzh zhbJgKyVDnZj1y{BUx=y!5Z$-HaKP3ouHN4|zQ#WrTP01e)%&R8vC*Gv+;(gA#;r<* z5ep}ZrZs|Lf0k|W0UU^C4f4FyEkDj1ck8E|eq_qUz?{ulc9%Bxb=r|7+VghLL!#4? z1&~BOfDBEt%RXU{_M2{Fv}|hj=oI9?LZ{%BoKV@iix7Nn-Ic65e zC1>rh8HaA*LRl!6ctDqQz;IyP(6!AED{Wk6*xrM8kgYcwC+WcxCCPX=|JL1NV5RvVw}W5s)z zj>7|);zfzq&R%FBxuNqEZp>U-%;`Wiq7Oz;2IMuKlJO)TQ%q1$+9X?-n`$D)H6c&{ z7IFTnz0XayzWTC46^6Dki2mF_jo}gipz+(Ks)5W~GwJP9(Z!fgPQNa0=%!pl-2y9l z@Ajv+f3(?V$twqi>e8y@;uFd_+q!EBK}Pc4u|rN5-Hzbok1$lya%4}c>~$)lZ>e?q z^N0Gw$6?+>B&EPoc6P51HQhsJd6wZZ!=Pw}LCGA7u2JIr*57!xOGtMSNu$s{GVKRA z6f_yG(hpbrXwd)%&tRH|lUEDGDKrXi%YQX)T*fdA9D=Y|K<(_+<=*CEXlQYJcZ$i}Qx2BzUQ#TLYCIMsXH z_jVkB+}hKzLLXP8^)=LVvuT|@9=e~Z-Y&I!2ASShx@mU*qV5~@{zSWfUH1*TpJ?}Q z>prFXF?Ro{P%BUb8S3cnvbQhtD0`373E)GeN!~zXUG1wBzu4!`2o#3HM)ly zMYDXkzZ#*`i0b|KC>15%zCIl3@xiqcbR;SJ$-Cm+&$r){ckX9*AR2q{z93y*oG){J zaPwn`!{BBf{cCX3qbq|OT_KMA4B9nD26d4YQ5FCYC7+5Wa`T3=Pi=Y_jkxv3>v+ey zkLW~dGS)41cb)F-5hO7qVe^4Z?}697_r-%V#`dxWrLOag{?^M{#zSkAL}(PJcN8ReNB_)*Po1nluWmD!Md5lRyuo_>2^HZ ztou#=LMRYW@eVd@yC2YY-@;f%RGM~}sD~abFe{$l88=XV+bm5n_|`^n1s0KxQinc+ z?Y2~hzX%-`xBsmH+t-*C-#GSJkBm7q^eLWYDQNnRU(xjKF)q3We7YA%#?3n=;xN)y z)fM%hocXaR*Ka)!(;|g5Jz%K^Ll4&*p(S`x*|n$nL_X48r;gm9U4p=e-2&_sNOrYR z0}|Jzmv*cj#BPb!@q%zvrcK&Edg+B4u~1$_^0+Aoo`*ClEGUlDySoH!tVm@CLkYE%$dG?B+rU;E++Iz~?> zoX7%F<&WX`vn!#mzMq7S2JG)N`Wq$ru9bY(az4OScjwOsV6`{L|A>Bd5)l0`e5|X6 z&{aqh1520?tHjtt39(U1g0Mca;6yckk`D4+k2nN-z12HK{6FJqELsRMh zQ{RUy(#e2AEye=ieM<(rVbPewqDj9D3xmDNZF}D<8~c9e9#{y&K6Ss=RUUrmE)GM( z8o{sm_LfsYfcB79nTj|>=Dys(FqTD$j&U-rVj6N;Sw(X$`|(S;U0TV{-g(h)XNTKH zz#h+dB**lA^u9rAx(U4*{*d^Zu6L~0Ihp|nn@~FU^!I1Q_pb|Aqo9^!3x4;O0%wl; z(IoTX!W>*ZiH)#E;-(yljj%@IW<4`OnW0}b?lenj=9!hKKTbR)AUs| z-FLHipjH6fjAx?nJ9HqzyBn_cGv$1qCfW5(h}YNSv53(mq&R1iO5=Fk*@dOIq_kR1 zWnZyqShyF|dc7g8wO?Var&QKzS#mokqwc7m!@k4w#sMz&<6ocWA6QI-G{{>@4K)_p z&kYaIdXyM)p2?mKEV`A8WzjZt8=FMo8%qZd;HeDsV;^QjRdb#@b zB3qU{!5d<=0dwVz@!7OS#@+p4*8y77`^Hpsw_1^r{NDG@V=My~AF zO*pjrkTm^0YCx>YenF4vhQ74suAr|?pSgo>K_b>8!LdT;et6e?$7;rk$mye5o`KM`>`%W7GgYVGsX>yC z!(kp$T|u)No2dd3L@*2z6~n2G*RhvE7Qry7vjw_HheQN6vK?J;W-iA_h&(`LjyQ~? z8nt!PB%ncbqL7^yBxcekJ%~=3BY7#tk!J8wLN3j446BL#n(p}37@wSO19SQ+w;=WI zFA#h}Ltoj89h?%p#J1LWx%=JlO$&{(LIKutm#HW&;;!0WQLT)OvL|LV^Yn><4vW#z z;&syEb?zr7ALK?NTZoAqi&sSu4>E`)pJ@*+901(ps|tw7@+JNrQbMarn5#iO1inT8LJ>l?aL%#e3XX3sxFlo;OQQlJk{V!CjKtg zb)pF-I@x82baHFfJe~M61bnx=fam4g)=S$72SxjP)fntgRiX0-->+5NHg^(K9f`9A z`%KH&64y#~R~495Bf$zAgRv6Ls*1rgf@{$cV=fU~k4NdIJKP`^CU+7GdPfZF5Knjz zNq2Zx>h`-+`ZNt;?a)5nnG3*5$ITYlZwiO+#r{?84t!prRH;X=3kDfqTP$tLJvV`6 z?TE1Iw|1oI53%G|e1D3JG-4D>bd`RUyV+z>`s$4%T0p|M%DO{q4H32+4n7iZk*Rq1 zh~T^QywX)42vDFvGYl1W-RR8+3nF@3?-I+~45wux*~4zuPeFgM&@aGWnmZ;_COa;t|Er=6-90!hsD5?cY6$esb6dR%=mFf?zJRzE?+jxMvw z)ZKpqZ8taC$|vOYCF-oMLXW&Zcq<7V+TU!_NSu^Iqm9VJ6;ZNp(H4l<^1Ho=#owsS zLtJ*kiGo<(c>_o@?xI_DPFDI!VPJ14{) zG=;*ue|q8fbA?BS!mg|c8gICB1TPzNa@_jhP~m4(V4(A}pKG9#?0SK`Y95=?%%q{w zjh5;EXrpEN@3!}irF=bvF!}i_^f?=53Ghh`U`$S-8mBm?gHj-@kInw_*>Jw{oozno zDAfejLXjof?;j^A{c=ZSEp>s95s4bA_!u%FQ=-|VNaW54w93`fXc@K zY>9h+U7-MmH|D3GFMPwayplL->*G?IFP5Yw$H%gqM_^W`hQif0ej00g7jK_81aVpb1HI-&gL`BF5 zmO>_7HBY0fa&Qw_COZ)bx+x>+SQIzO`z8EVxs_ZevPe}&5w(T3O6*w!>uPX{Dzr`w z5MpU+sh_jCpQXYIvnEFK?e)Yo=}0kD;-@f+8BX%iTlw(F8W77N@;o&vL6lUQndin2 zfO%8mMh)Gxj`vcbj!-strv7AbO5BhE>KOKMKO#ZDI;*zcw4XK_%fTjc^s6&}lR6U> zkOjbuT*b(o-LHZ>D;Wn~CJ`L!Kn1cp*rG1=hg8(sb*`rk6Bc5jhjrf;-ecdZmxSRk}xZQ6Y`Eg3u=yU$Y~v z>8Rn`X@J`i;dTzUoR=iY&)gv1c0J#6%s$VnWR3hy<{D$6X74Jw&s<|=R=1Yw!?K&J zL>l{(Nqld{*UcN2x~X63*Ln6u=7qYCtsbwU?&3FS1v!Eub1nN+03>Dlx&Th*uH&6S z+0$@@oX~Uk8e{$!LBTi3tO}9dcb5EN?p*6{_`5w(lY5UghVzY86-d@H%JP{n_-vVy#klSQUQ_>px;+heTqT z52{&25!p#uioH}JidPe&(t0W}vP7)eLpQEZVbTbqCWV_8(C}FpxPgcic$BDYH#O?^6M8HnJNu{?7=Q2a)$&o_w_*TaWEF>}O{;Z#@Ic-A$xBhdo%bM^F^ztb z=1-$U$*v*186Q@UC}(r_uS0lq*H81|&0GOe7~beGjiX_-28hVMd*r+qNM&82Dsi#s zKJSJI>lr(JJC)`zJTb_J`Q?UM;?PD#Kx*OUcNGEoMHK=zdonY%J#HF-(WZjC%H8q+ z!?(M_%&Z}IEl(^z;G?i?qii}&H_Jax&5`!A^)cBgvrdpmyrq#@8fLEXTP(M@ zIQMHhbJFNI&&Kg9E?Tf+;d3qc)Ig&dfkwI)Ihu8i&8_WWskmu-&6&>)AMPTQw4%Vx zjNO%m)5g0RePFH?7)C2-zS`{BHavr-X%Ny>NM;bv#pVEn3HeM_6Pnhq-UQ<9A~`A73yx?*2KxXjEp> zCe1n?tHANSe81#|xLV@0K^oWT?Sb}|Oxm_{NDTbr?R=`(QpWlGfbuT`&i~3s@ZH^= zNmlUvw-bp#6fvsxa%cGzawK7D`Hl#!z1yJLx&^DKSvOK&w!-<;MkbT(llYS+t zjG-a;DR+MxFsbuR+twMd2uM@(WiZY{ACyi1p<+6wFINs@Y))oW_R;WWie7rzXhrD74xB zdhlIR^6J*dnz5xl_rYm?z;03uSs-41)PBvRc+~#(n|{>(xWK{W*V>*sW+MWvriw-I zGw0~nFOKCj2?!BTs#*Nw4DBz+9I8gn##YKgz3HBqt~SsmV%c!Fs^LqV5}m z@{CG$DlufEl&k<2~B4Yc4T_$*$yek9+MsZwrkV;aGLP-a7w>B*9jR@SEm&hX~@27#Dwtm_8_pjm zU(h24#u+8<=Y@N4vV z<7w$W+Dcg#3-I+%38^J^y<%MfVBfwwR?cwzx1w9=r^<3IhsGuDfe)pBvETJ7+9Ytn zHOvGRsNk>vwQ1=FE1gs5s|F}yx|E-pJELC_ce*qiK_@Lr+9wh&P@v7OA)ka&#_7Ryt=xT8rMRV4Rvbzk zxT(|4BD)Eq-M&l`Z}WRC&6fJ;asZV#hxIa2BARqveYmZEl|N^I-7GdaH?ewZc9aFP ziQ)U1@+NdaX|3x|>y>rrBdzpBx_n;g&wC%0^}h8J2%(@|#E9~r8ZCG4PxrA_V=QRd zJuwSJSyo&WjuJ1ObDhz#+{o$(sjpt> zjm!5$^7c2^h}{?$iyJU5K7I(Hk@A=XF;a9i;=yTi<-**)IW z>5ccp$I7Y}L>}^S1l|^ zVc&-n&yay$pB6B^-!_BR3;&Q7ix67Qntrgg(SH`jP zanQ?5DsSH~`1CW$A<6|{W3T?562Fi8RgUVDFR=%A2>OtdgC*Fi?l$Sj{0tH z-!T4|kq@=XE`4~1;Cif;&VXt8l>%u{D44y-3<1yM2dDF3iNN#czSCD7i5GSPY}9F= zUld@e%t&^wznj(G4L|Z}h z+%h{imipRz{vhm9_x9TwX}Ohc2+mVJOvuX%flIg7-!GDMLw~)J-5%yh!WA=a`c@!7 zXI?Mp{qyAF?n+SCBB;9+V&Kkouc!^#zo8BE>{B6Kzc+_D-$y&7{!PZ&RM+_vyjbS) z^7f4^g~Z6Qe{cf;3_Dx@4Cf$VRK>Y878@^`iYMek~6DE!kB~`DEvBc)Pq! zJr7#mwu3IVqQbAGPj=3<$}FzmosDTg?iDONySB2Go$8mC%k=W?^&ILdEcDx)7akc;@Qy~Eo@H&PKAM#k`LUnb^T=2;DR zd@)xTInlraH#-13H_$II(`%F#xl`OsXf0!t8o?VSMjRC9)5fLOZ0wtJKUtiTtbO$x z#YA7l5S=FHEijsTqPlFU9+f_<7Af-iH^F3|{_f9^DDW~(byIZMQ0_`u`Pm;eKNqqZ zC1~HcIGS~8YdKPO)O}vcI&ZY+kF~wtlI$vzutW#ly+jiBVY2gb-epZUIzGbEoyV=f z@B*2qMU|?NH)<2&*!OO`#>-KNS-B5!M+1a;Plo{uY*1*kq6$9luyuWmmn1qED;sUe z3`U8;C*J8RC;}X#8W96K&mta)MV6Qo9DKk1hs7xynPk|LqM;vj$Ckn(CUrZ0|A8|# zzv;6~4cL0@?x|j&UWmjO+O;?l6tHWikL?Pu^HtQ%s*%Orru1@0LZ^gFrZhPxyUxMviK{h+Y zK}Gg6tbf{8s`Ov1f4as?P!DM4?Pup5ShCYsm=U8nOrFu0c*h8+QIE)iiCCm7f)0Ah zts*24szpmLiBsjVctLnAeQ9Tx|`Au9_*(CKuv@Ha+A!tu0sZcQdRu zgr@=NW5@~u$`b2Ro)j{dyI-6q1q&;E-? zR~LXs!jW7zuL37HE489c)oH23R?FvWt1=?al9ZeZmAj{KTG^w_7uz^pxC^Z@Jjyf> zX_%JRW1r9bUup8gtyr5p$RZYGv*4iYU=LPp9xO(CZV+H)|ADJ*-{397OXi*{ZqUe3 zW8y~yD){(A1~L<{4!=_oFeC0@X(-L_0q~f(fK28ZGb9wiHdpkF^lREEQtmeUr_U5s z7VQ4$JkOd#PcyVaF@-8>k)41Vd-98srNu+uNL)S=(9*Ih(sf>!x)aQ#6eC{eg`x8nN|d}AE64S(2i4g#|8{j>{C0-Db(3bGI)7j$ zyl@DS*B^^lAHiDnU*9IPR1j`#h@>t&%5C)K$95*LLYtz4J4>5gwlbjw%k=}#ms zi@R;!pWAo*t&~7-Z}YddNZ`?ytuoy*aX6eW)3=Fxrl*%84A`NwT)HBI8WzQ!5Cfw) zgO7O};0a##&|RXv1S+aHu7imu33#xHm9CT7Bdh4+lM?&PuZNjFa*Otar`mJJ#^r6< z_3}1>9avjdX{ia{)0kMn7O^$6LpTB7`HXNBA@T+gR`{fY3J5Mdg@0%MaZ5rn~B zerz&lw#nRwWt#J|;3J56Wh$`{JUncAVY0pRPRatPp$^WTb8B14hR^w|{`aDPqP=M} zK>q|9HW2XJi$!4Od@C7=BUL73tKFbU;AD-uuK!v^@sLw-FbYzmGN9hsk>uI zQ}d-XU;gm&Ha#O^6^jO8kgC!qg~HN3rLD!eqHc&FDf(Wx>CZiacc3#A^Dx|hmC^L( z(lELDMmQ}Fkjv)ugvr(KNR0gVVULz+gh|?^Wh3F(U!H%o=2UlANh=ZES0k3-a5SOH z*Sh?|8DI`a&#_TDVs&TVn>HvI!t#02I#6>2ikhuIVqHl8MGaf%|*)$Xb z8rO-&7`;4x&!ug7O(POf16(J{=nB9lDI?M)$G|UE)|b7gaa|gGBEt|3a%1)`3JyS~ zA?H0!1algEtu5TM&fB~dmrrAV`JS@kL-b`L!BFl-b5f;ALf(?|b*eT6giuZ>bnv|h z_l@aLpsYUy^7v!I!};)E@#oX66)niGtkE^P~*$PXo4+>dJzfuJ0=9QL~zix3Rsv zq{h!9KHLL3Yh1rGWipLJSmK8;%_y(u6J(u#!o#<3xUX!Nt6LAE?Ad!-+17movNIID zK2o*BMQFkDPK$1#UGahI?Hjhf;LN`eNzp-(uqXX=CBBQhkvV zTVmG`ZbpewCn{0tqnLdSUUzGaS5r(jp_y=w>#kDW7#6Ek_R%lJLA2Y@{JIK6aVM%R zCKjW)KWG*<0u5_LCs#(~|7r5)mmT$l@t`vtv^{o&>}x|DUsxEz%y1J9mnb-L^|T*T5J0m42r(E?qZ3=`~seRnYdnG9lLXwpJRkB4)BgdXsq9n4PN{ z1q_25r5Lyp_p|jmoHx;RRah?y6G^Y*%3R-~i!|4#GiBxmyAcLGLX&vfEP(twz4|5A zM}7tyRH@GUi5MH#(=147%r`-a8IsmE_3zi-bn_FFvD?LQjBG_DIPZmhgMsEk(yUJ6VGmlJnje*2Pu%5RnubGp&>u^e^Qw7& zV)4RE8TyVl8|6<)L+FneoxJPp{q6EVw^bV{(?NjwJWZHV<~%V}opN38t!Pm;5C zM334x96UC=O>)-xK-Rut*pz5+vdipmG-9vof+MIiZk))Msyme`_ElPU#B_iAM=FBp zepLu!F(~p&`^kx?blIFr7wtAiuj;WVP-|3h&2?}faqzAEO~&fLfjsw&znEh4fHE(M z){jMa_+^%&O5H{#2eCC2vGY{Fnyvhy(;4#Q4S4cK&OD|qM84Gh#xl~X3*hL!O?`#@ zPOi8&8()-7wTjB7e_%UAKBuC$3=hC+PrmGf_VbaI|8r)tODSr+>1CeatzQMXeZC51 zO=zRUlNV@k)*qDi4aUW;9vXrbZC3fQ)&o2nx-Qn^9CGiN3=F6Zd0H59ean2qeYdu6 zIQ!m_3zM^Yfv$bSDPNrOQ$O$m(qn!YMB{2fPTH@z<@iv%tHi@oJJ&=b2TxX}HV4mY z6RFRkS%4=`=`oCXQ<=}f!c%%0Eb9k=c=$?S;9G3;y`N;uHHlxQdj0 zG~%APND+EZo_X1yS@$eFqKYT`p|@2LdawMS(2J`7EA;YonOpfESF}|HtcDYY=<8I? zatvMGCR;Hm`;4r6l=$DTe)zVD>&4##0X2Hd+vhhf_4qb; z{LU4AbbL)4D0dFd)D6wp&*(;)YWwi{(Q7V0_=+8cs%v{Ihf$-T8-@9*)3?T65AZ9` zeA5L=C|EQQml*U=+L|1_rtg1^P6kqXNVR+Geh*8qvC6;cdk8ixXxEQutUg^r`G!ox z(9H4dnK!8ZHu{~*Pq>1ekbs_Tf(&H*=(CDgpjvT%pmGiH{HjW{^}%4304sIfxii73 zZ)O&MRt)h|>ElzQ-|3ql8Y)J&(wg)cv)*$&yAYEYT{rJEm~$#NXj6H7Sx61^eZf3` z4!^|Hq!IpjYFQQ^`uE<~k6JA)P^xv?0HlFXXM;nDV-<vtRc2-9uixLk_^AwmW3i$5b_1}jAgWyYl zeO!XS2Y*J?(^Of1Xui2nJ`ewa#}W_elgm+0o2X{fz$V`R8j|c}e;tmsO>gikC6u*X zF@?H*$Sbf--v3fb@=B%lBqq%rEWqP5Ot$AJ4rD%BQ#}~kZ||hxH(RyL10VFEAA1WT zix<`F*R2hmvBgZGbtcEGv@IjUIy+h&0dvDH%hz3E#oBu9!Ym(lZU*Bp^&y&Sw}^1> zST@x@c`z!K=H%M7b3Nvz2C!64p+hNc03oKuz4$F56XvfK(zb5_F?puqL~Wn$Rz`dkj~V@Edg|1W4DDU#iI0mo4x({p{}t0;u19YXyV__V+9n0EnKcyub0EEmNsAs=twi z?fzHSqnCXJP=B$b_YXweiOFYrbu*Jxiv*4G%RVfzl*%>AL##u zG=DDxA${eWkpMM-?^33ilAZP3NDIfPnW*BZsn8-C(Y*uY(Sp6LdCbV}nKL!AOLjFQ zqBOEua@GdO$}d{@ga0*{2p7DXQwfd#Y4W;wNY=)EUO81=bI24;cdzAD-x@k-wGLXI z&{qRSLF2+NZa z_w8DkhS^1YA@54Lfrqr;xF^Vsq$NAVEYAGuHdSL@et;%ShP_E;rs1OK0Y0< zWgGF`FUH;u!Ib5!l8BbOuKPH;$EWf@q4H}hdHSWkZ9@r^zWzZ9@JzO%O16T}AS(&Z z(UZ}n6mjFER6)d8d-)@ns&(7RY=!hNAH8sUN)}Ia~JBa+nILT*QfJG2PghZNjE|V*qr_1vqZA z{Y7CV%7Ja`HpSi$`*jk&vj1tR-3w0UY{HEDbx1gff$jlDQ zP&&g#@?x3<$usI9d8Sr@T-XoAF?6pOGB?18j{``IFX&zcg=VSya_HVON|JAFV>$<7 z38%;|LbQ{M+coyoNgU1oR+dY*r^upZ#^R_MB}D+iO&uTMA>>{UTSnQF^G8XH>QaL~ zNsV5fym}A$$so4Oqu?WF4l~zzeq-n6^_j7a6EhQGR9=uNRw!3+RgeS^>>nW}X|nMp&w_7De#@1I;ec5uhqL1PBB?D!ef zR3lTxEw?wJd*9Ope?UEeOz@)I-L$VqAty1uHUvie<$TNC3@hSc3EvHsWGg_I*Fi;^ zeS|4fr`wcnE8U{mUX!q5X4HCHcku{9gsw6poo{DUY7pmCOd4e#ll~=-VhaK>n@fQ_ znzBTR{kP4_qY8R~DF1?&$Nx|u{K_5rxP=x9gl?f4j1sGd<@;EW>*Mxq{~MV|RS2gKlMfDw|@b&AHR7pJMVu3_L3!a`UL)+Oi4f z`j{LJ)fp+Ezb1r`h%lfK-(P__fz(TA5i&f;rGV7E)=%Q`@;n(-(3ASsVgC&oOlPv1 zG5;*FjS^R!5)T;?$380SDm8y>Sy;<*O8)Jxxwp65Ti5j+Tvr1jM&4gpKHa|a^x66J z1DG*0m0{{nn%W7HflsJ^+1Wd4QNM-w=7@61>9VsP(3t}9tN`W}sR=`YfkMg)e&zdV zGSwXNVz^u0Cd(W5*sRdlr>z4Fq!7wp-@(HG4>dT2ZPo~H{(k>JFi;NHCDD*YEJ%=_ z`%A)FEs%D{9t*+r1=XU_#3tj3C#gSRKA|*~Nv~AfX-1tNl7AIcK+l(DBffgp@vn_7 zZ24|vR=;^v3R~BuDKtd+L8r|k*rv@!c?m)d$|g65We(?_l3V6*k&Fg*#SWt__lBlo z^H12Dk{R*gzqLih45ud7AWEfsSIZ~@3_N0JnJN2|%4I56S#e7sO7gQTNbn_nenYCC zACZK$5Y6s_%WN%#f#Izl;X!UrLu%X*kE_QY6V!Mo`^;Qn&bv;~rPQ4ttU!Y8@!4*f2^wKD9vO4>r=tGtidTc#Nm9)#gdviSi~eZ5&Hn0Jr=miROzxkoJIHP( z=1)Ev=J)^pc~oEB>w~)s#Ps$zd({WQooPM6on7%G#`aA2JcH^|KJYfVw_iYBEdCc{8n_N*39(3ok(zp_fbqxxEJU*yPigqfmB@+G9h48kY5B zWV(?7$d2@B%=(WYauBve1U8H+#Q~4BLV{p;@ZXP%G_gH$UpDxFywGIi;e(aodyO~y z!GSjqVSg|3BP>N}*}KAo&3zoIqvvbvd8wVH;6FgdZWCLTMe1P~ZKfY*`apS#uBY)+ z2m`_UmFua+Pg0F#Yq!+kOENFNaTniM6oD8~6Il1QoX)_bo5Cy!jH9Qu)?>dN$f89I zjWv{|v(S(TMto`Yh*8`?^#g`}@gDLrhRM^J`T}ISXPuSru9be_YPy#5)Su+OacO4W ztGvZh&Qu7_fYZo<5PhHMcp;DQ(6@7uK{pPC6(mvOYg^_$vJi5>GM&Gwl z2=(eE?uI35G=l}Xuh)K^P+6Zjq_jS{_{d@WIj%f&;ZW?u(E4tapuT%z^{_C`Vk6R1 zIl(pY2yPyg&+ob~cRgilU)BK4s_~FAaav`tj5AoM$meJFn>j^(?!E;EMu(WD?^kW7 zBI$N}3WgXC4*ioo?E0-FCNn)XF*B}iVpR6wjNg_Vp&eY?fo**z@l9*)VwCx?%0pGY zL*>(qWisP17Yt*9P~snIr0C6dh9Xu=(}U4|zc8oF806gAyi*>0ra5Kd(kwTeDO+{C zd1w2!kk z7y*T=VRuTEZ{WPG;@v5?9>-yneoe<(y<-5`t84qRm0Za2%X4V(W}oP&s|z;F)(uor z0&1{Ec$K(AIWH06dy@*Lc-#POFp@+wqZ`$M4P_KFFauVBV)I2f-u#4WFdXkYdwqWK5ZO13^MNOEn}ntbpEUWPAQMl-QxT^ox@|z4T{Dgt`1E@x;FKU_I^t1bo#rn^mIywXR_TL_Lr}LxDpp z@MoRXDKXaaU5{d^35iCTUfmu(Jr=HDTxZ%)YO2Kym}F7{=l*sQ4TSf&AIm&o_m7~p zdM&+vfHdnP7G4+lmK)Jkd#?@=IMgqlP-Pmi8WR5`87Jj zr~qON))v{#WKP1po7aro|5L_M1@#zf;D}ROUkV2Z*f-18EXq^Ls=DU$SpqoDwcVkgWlsK!P8x{24r9O1? zA5tJnyz+^+lZJGZSTxb!HV!}oH@O~mZ;Nr>WW2vl0BpLxC6}}3Ly{^1R~q<|VdnUu zqn~RzU9&yR54H@Kj3DwdAPgJA@|8@F(K8b!>yNG^SW7NGzdUpCP~wGQsMt__e7sx% z7xghX%-^pL4jgA4Hzd)+bLsdQFGGY12+;0^x40B0TS{H2offV!0U86J>g7}=o0F07 zO&fNpaggI(1r?L z5Vw>zO5D^2Z}1@R3|8-_8U!P2k8V^Knf)F;iqF5&K)I}$7MM;*M4*(zD3t6Y7$g^cIo^BQNZ+< zVzB68lJ9dwXhno6&6<9wOyp1f4CRCaS~Y&qYzce~n4j(u9= zcC?@CvVXE*mJbCYl5TSz>cfQG)VY712^mf`_XO?S8{8^?UaBWi;)HMeTpK^@?v{-c zjz7P{7LZ(VFf|V#9L)!Gd3}z^TnQqJ=Z;6xiRYF`yhw2^(v=j2U2%%Nx-VE$vfX#6 z$n#ZJUdE>E=F$4@vcd-#TTXU@^RpNr2!$#I1fHnoy=I4$8A%PRk4fN*dSg^y_AXa{ z9s8|v^}CHpp?^$`@($DMZm z6mMdm-3<6i_Jy>CYfrc?5L(1pE7d2dgsI`)Xu!Sd>3wf_KO@{5j=WcUdT(HI-yQDT zLV5KgPdm@9%wF63*|~nK{f-S=B)euLur}Mbe>Co>BacjWoyA@9-s6Yxwbnz&CA&`0 z?c(D%Z~N$24zA$F#@2juhR!=Z5V91%4iBtXS@rqh!7A&Py@JyRcl>>joYoa}ZJ!KE zb!-^YIy|#w`@d3$j;(LqO3#vAeYgVmyIHcN$O{4?>sBa3Zcq>xtbblyO4$$cVL;oH zCv4(pBQwS7)JSwbVd#S)*w2O4r?b5vKEKwAQM}TMKj5GJ3L?VKshGNu!X$mA@-}Y?#%#a=k3^71!lvE-QBf4zxqWpR>HQbczSPfj(JznJU znC^*bwKICB886L4TY6au5CYg{@)F4|ZKTt7n=2TDweBu@ud#;7o#~CwKR7)is$8UN z`?4im$Unr<>+I?UhF)T1hvIk9Gq7HU3Zu1Pq4Z7zI`qDheFY`1l(iqG_u-3J5V5XQ zd6Wuu0Rd*-Y;nb4^MpBa%WjYyvw48ZIyJO$&EI@O8dWaPtMpjBapH`L|6{PYIXlJ9 zBrc#2{iPdfaT|3h*8dXv-*`F^`RI38?WImZY@szY-)nc2n6k~SzOk{n#-g&*4%Qhf zsk%(rug05eQre_mVEEd6sEOYzX-QvSo@HhDX71|N?Ew)v3gin=W%=y&M)%KCaYC=! ze2fRey~q>!p}SSV@LN$w^u@G>ZP&nHiC_9B<0YQiZ!C&2jX~c!o^8Us9Eac*N1|-& z8RQK!;==c0kCxLi=~g>fB#CJD6g*RATq%!NQJS8W!Byu;Y~>oRwA%S@elVd@ z-fx}sp65Iq4;FV|1V}Z94nGZnReGNZBQA9g7+QqJe+EXW-baalzmo?;?>rdKzU#q& z5gO@zDjjDBFj$zOy8V@a-H_ivTwC@OduCV(7KrKE@lhh#d85$gjF#52Ovyo0TUyvi z^mDfFsc;eWj&gwTCKu`&^y^eLN*r7Oy-IoLw-3<&{}C}$+y03G)g_5aE^Z!z9iN`; zI$YxQ2}z<e2)am9j3M37?0fOYC_A|Fd$T zgGAWX6MS2*T{duAYb=V2+tR#+yDHz77G2v46E;h;An_?9;61^R9f`cODA{owo;Aej zc%SHpMjV^*i;r{imW%u{fDtfjNT;Z?Y4J;DZiCvSVa`k`?PaWs?kri zZbx+AzG32N=bq8JHSG+gotCLB#NYJ{H!w%W=#KTnI4lM?ZgvKxoT8YljphkE=U*y9 zhUNI43smO(i-%TW1d5^=uT2nDpU(=o)gz;qErP+W3ww?2Va zHs%CnC>Z&Uv)1}yi2$K;lAc=*Ru7XodBUf=m9&7eKy?)C3%zBoQR}HpyAKk6r1(Em zai&%Msa`24(^&_p^eo+GDvr=Q$Yd5QI(d`|th55-M=2VuOQnCLC?iv`i*Kbjw9;h} zR7{>9>2Yes_^MK_nTij;C16h`9!Yi`tb$R+L5GX4lNkk#uOa$W;aV;fe#{F0bQL!$ z|4)leV~SIbC$LpQ|<0WpS<{>81t;VvR8h$7j_Ru z9`L+E<4YB~n@E@4F!;yl60?g}N;1eaHK#I1!TZT%m7X|Al)9)=86|=u#l!{Ui3uzq z_Ct`l!HX#ulGexC5S|s37Xj1O#>J(=>tg}4VyxJpYmHr_iVNRRn8Nm|2wxC2mS^@m z)>j&(oKvL2>9H_;c92wrHvY_$7hq4P2F3%4tu6?elxtWXm`QA{h9svXKMoYi0Jw!t z@M{VjGx|WMsUE!~FHt@!6!;@0?&{w3+;bdYOmalie zZ4?I{^eymE!r>O`Az2zBn{Bl|)~C`h^0Ad1KwVaZY>YSZuGQ|J&E72Qm)<~W_r36F zl07PDpj&;^hqom~Z==NfhyA+5?G|4C#%2l&s`jYrmf`I*dux4tFj){koBdk;(JSH6 zdd(^Ff!n9-p0=J1sLgP__UKR9`Bnsc15phdxoi7I+9fU*$r< z+=!2#kbmjx`Pg}_9${ch-Azu`K8y`4c9tONUtt18&e^00!Sa!DKWT~*U)kdq#$A^! zFBqhGJ2E%ekyLG_?C=Amf-`CuVC{@9D!1@BQFCSA)6)06 zI|ikrKDyn|@M{IJF(t0=I(frjVX@e>A1@w_5=$&;Br_2wt>kJd)n=6&bm*XxY=fO{ z75hkJHA=j_NhP;fMgPK4RUE3i++TjL%cI%v_{)+0GMmCgH^>KdbeXuqr`!CYJ4&o$~QJiM^)phb$?Qhl!y!7op zBSe0+#=s3;v0#X^f1TIFl)Yy`i6#gdX@k!h0w74ovP~q%`9;UcRVsJtX&&-o+#rfd zHGOc4+RLrPQEP8l(F=}qzlZa1F!z31;d^)PPYaH`p2ompPz$qi+V;1PA)I*aSt&!=GrC}+8uSzsW#JXW zd*fI8GO>{nQeyHmRyw82=a#NlWNxymL>oZX5#*FDR@5OTR;<2Q^G+HYAioeq8OFC( ziI$360m6Xc21OkhqL7gD<@y2pdEiBfEB{xZFk?J=weOSw$aJA%lpy2Kgl$9aNm7|@ z!Lb#e*S=4AY>a08)r?WeZfHm!E-O}Mu6g~y9@+X$(3vJ$@CUAs5!Z!s*p5C1t5bQZ z#2ZtMZ5m_jb>Df#E3Uy4^9QqcY%e~;$kFMZnWm7zHa4N%G$m$gO@(BWDEje?IwkZneH zlaJKAJ1JH$$&lzG1#6?e6wI8~arz_+2=Lk~Se21Y1f+e)>a)-Ld+Y#jn*ab3h~quLi=C`fWf)rvz(sJM%_~Jfu62#N2)mkC4mgJr4G{5%T@|G4=X=>6$5o=D?SaG z?O0azu_hcamt z8H14WGYHElI%`3 zM%RcIA3n!4L&NB&E+3ZsNiQD=JU$;4*sSX4r?l-~xI}i;0#)tWuXcjkeZADMmsEP2 z2_q(w%v1Xy18=_nUb#uq1Fu)qiio)OYr;mF%KY21+}l&_tsCgJW)jt_%!O3wk|U;DPR>=x*YrK)?*B4F zs_xi?7WJQ;X$xUDT?5Zne=R)iy2Lo0hi4e@>`Sl9AGcmt=t6wohFIvI9E)iH-adYuX8(f%aS96Z-GmP!-d&lJT*d&m+Ll|MoEM7hq@yLugLOt?<)lM6;A^}Y- z<7G|h2Q8CQ8BTq%7-nCSt8y<*vXAa`%Zr;zduY96#Nc|_izf|Zn3IbSI_T@)7*yA} zvE^pD=e8mYL+YadLo}GqK(6dJk9lsCyMJ%(w?>emYZ;-5v8LtYhFQ3bjs@gW*^wr1 z0c%4zmEDG3VaT~z){p$chV`CKP1)}uR_^(o5wKlz0#?Ldldrn|v2I$XCIr~V z3iEU3@tQmg5fkt%O!JOhk*w!%;g=)jxEhvRhI6ae^C`PxA(b-W3)rxCv3qo*o5 z^pq4BvAjs1zD!)8UMq8A1cl&YO!;7%-Cy>?2*oQDbqKO50TIiMGi;S&y^Kkl@dAMW zvA6{dt%!WRh)OQzFe##@YJ@0(=%i8biPg!1vtwB^G1~DodVbx+%-Gb#=*U4wj9z+0 zz0Ytnzqj=7L)5l!ZsJH*bbqqD#*$-3GM3z?0MU_sx5szx>=fksu_Oh{lz8E5!LWGA zZK*ETKAXyk2!54Y^p^LU1|6!eunrMIUyflH*0uD-gdaiGxKXL}A5-bSkao|WY@&qE zcZ1atCNL(q>}vtN_5B!ay3%~+VmEC${`Wk~qBOC^>T zsxy#W$rT&cs7c?ymgmlABMR-UZ-%pgvc(hJ02xX z)tVrYq`k@~x&1KR=9vGyU(uwF(y~vGt=3?u>t6jp&O8)Trtle;ZBv;kOpQ#RpX&JJ z)a0yhsf4F#kj=~#I+OK^MojpAm{N%LyWkvkj8uq%l|x0r-GA&Yify*Kg4v#ZdNrss zeU=P|e(5jQ;QCW@4OYLW1V!ASO~yVqzo5aB6Zr;_1gZM~4gMn6;D}#*MG#8M1R-dZ zxZ~$}(Wx@3)5cULQduoMRYKpCS8i|D_@2n9Av6(x{VYr;@hOmbVrDuH5~AQzXs_H| zxT`1}j7LW=DlX9sYi70f`qCd3h`|)LC~+nVD+m>@oC4NLz#j(F$0NZ99Cs_-Fm74; ziQx9a!@Qa8o5JX(u?H;KOKZ^_`Jxd!)JVsFP_C5iV9V$pUat1WcOQ<9YKKXBN<(JE zySrI2JLhG&CCg27r=(N{{g~2}8Sy7yrcq5@Wo6<6K&CXR7#x^Vml?6p7aOHwM~0@F zd4)B=HD^#ob9=In8uZ=wws#QFUj|Qu^|i>f?A&-w6x|+f4%1DG3^YjF@Ik_>FPF=z zdEuQjMTa75Q6h6|`rY+U^f>(PTw}%;OGxT@?n9FOIZN!(@qo3DUL_q!rL;n1SXYNr{VF1}?IgB!(Fu?r13(f^}+?;nEUa z!$v@OeB7~t$1i;RDLl@U9kMG7%QV&)Z|VMKgKrA5rNtJFb!?Cv1<|XJgqlp*aFvdJ zP>H2KCzZaSa`_>g13Mr)zRoFh-mQUIl|tE}u}&>N-F@NtS@Cl`pt~hJ+$%gJgMLkT^tPqJ!`?gz@*E!AhcK69)BJK1cJyb8nbpFm z$in%v6U3l}#;E*p)(h-@X=;X?Ew-lC~@Ee6~zw2CbB7 zwdz1_)xJv6gZ0$zAmbtm>Ys31VAr@qoH>@&J2)%BL3_>Kwfhm-2%frg+x}{@jG4^-6XgVRiDXmI++AJhr7O2v1VpZQcJ}iI)^8Y6|BaavR)+> zh~a!o#RWIUVh;~$Ho?M%&mHu?dYJ$M2V*n?!JjF*+Va)a9M zcxb(*wmy6=wRFS5sg9RRQ-fA%-Vc+m&v;*NBWE_qrz1_{+m}gXbfD_y3qtPqpa&%kq^|@J!ED8tSLa*qm!qU?V`!jr zW)hB`qku9Kpn#2R6+%MB$`ly8#bcpJl=#h0eY5<0?-klH&d_?3ewDlO`=Qpka(Koz zH4`QJ{x#PMmb#xCU+lB`^pVdYpoqrNK(5i~$S+mHC03)7T+~c_fE`07hYM3G013o50 zCgt#8wS6nw#McBY&U=erwE+H=QwsLEpkgJiZG>0r@=V$LUqZ$oZ5=BysA6rw3_*c_ z62SR6AehZ~A^%bDTb_t#2DjQlqh3I$1u#wZ-Am64cgT_Ki7R80y?dFF z><`;OvS$(eK(c=Hx=sWc=$kyESIdde12e}QF!cBWi{?;Wk%N3d75RV~+ZPSw+A=uu zcx^x~1J6`us5TvM?d3k5s_A<~P$S7J-DRVKKJ?uQ;BRlA1H3v1_yHd9F9>i&Z+Twp zS3me)_V7=Yd@|tCAM~La_Rh!Mb`YUmWa*10z|~Q$KyMM5Y*>`oyDaWMXUZN#Nj%_? z7m&j^Qdxm{N6P;P;f+W34JzUXd*ZnSyULh9vf7`S0+TH#t!x$om7<~bmHBRYs9et@ z{ko+W3iJK8OO1=0mqCn8&*Q!DICuw;(|`cnF*25;GTx0aP>8b#!M+>%UU<@ORHDN1y4t&Dgn;-7CZ>kUS+{Izc`Bk1Lv zHv(ZA3#243ANcbg@6R{${(PNaPv0K44Tme%+(Lgj-apGRvOqLSJadd3S73s8T29>( z_u_G0I6yyyG|_{W?%Fg8xb>S7^m9sZR%vStM@kH5eVKue@_Dy%xBLtOf?=sBPX9r+ zAD*SY!UI9Kok15Tl65wkEd}t$)<91?wx&5gwgx=_1LdZogSxkqyp2JmY+Q_Iai={O zr_v}x7-6z*nF&pw(Q+M$mjr9{gfHIGC#7K(UFt>e~c>XYfp$2WPcS|ZfUzlC%XHPDifj%`#pRf-4Lq7nC9Pk5_6$n8p z;2`OuTMITo2(=4lrN%ucWGRoC)O;d%f=UcvoE`0-EqB#|?Ysg(4rVVe&zj$D`F!|d zVGZyAVF0*BVAi?=2LexWlFKUx!NgYhxeC`^3Tz}QWr~a7NzVLOLOGDX#s8CA`aQ2n zjx;K1a;?cP)38y44T>((#7V_H%nYzzR2Rl$-2kV50;b2V@y3muw>?P1oR(#&gEYcv zc~F#|D$QzB@#sr~Q=1(RfA~Lhev{@wwoHwFH+l7KdP^k8qvu=r!Wl<;rxn_oLRfef z7+mQ#JnkbHWLhQ&{?!T`fhInBu>9ezvZr;}(-ec_v9#y~#pI#Xq};u*$~Q(kAt0^P z;I_E2u(UAWSd`fB0j>PU42-dliCv1|tr%abGvG3b+lHG;d=n)bc8-o`+oFhcQDVk* zGUqX<5BkJmVe8LLTU6rSA>PF^Bg&%;^4yT=1{;9#ID3S2ElQ-ejr~>P$3KWY#SdG} zQ%u_&+0elu1IcT0=GCIwK;LhGK2R6gIDvH6&dbM6@oOb6V?kCXvEmDc;dn83RB8on zNQ~;McaCQx81Lwl-%;YSxw(k=kTvtc+Ei3tkYDBQ6TWub_s9Ro+PT2lHJ$x`A~`z9 zIO8&mOLXX9f@(rS;!-CBCrp{3GVas5jS2=c5lYOM8JS~e$Hb+Aw4$Y=O}$aXEp#Gj zBouK=;~uKIPbV}~2}=Io-?P>}m&wq+@8_RSKC{o>dtILO+}E?7wYHSYDAFKHG~x%N zhZBH&oENn`KZhOFRSLvde$k(py)p%CP>3fpx4K@}&|lFujk?!X0#my18d>|w&IxX@ ziGU{Ai?;K6icq^9W#7J=+C&?6sWQ$WUlJ+Xd8OjdXh=Pi0C45MmFsrpk{v6EXQ-m< zm1FOYq37$Cs~CaCj$iZok%aETA=kaH_AK8;kyk)%QY*%p)2b)iZ}}B>mj26hZn;og zCFXR2(f!mFbG>>}a_MAiNpWX~_LI=RRoD4g;YgkgXO%hGae-~zFdjOZ1)s9b<>w|l z$N9%~mX{raE^n7sXBhhjZLNYiGl87L6`Lt~IH5*WztHMN=I|N;ZzzzBl^&VU(`TkV z26}oMyK}9ZX*vdgl&ax);3o|^+iK4cs(nxQwp9;gTaOlEv?c;mro83EWz!rP08j7H!UGU%O#4ELVG^KecR}d~h@Eoj4Q!h7+ojo$oVLZP94F;Ns@y zoq5Kg-TJ5u8T)5WZaOpBc``RHYyb3SqT1YvG7S=A^BK5F=|*{@rrJAP26UMC&8D$* z`l6D7sCj{gXqwGzyDtu_8IWNjI^=)cXe9T$8TZ6xREwvTbXDNc9GJpc3y&N%1%v(p>|+i^dI zvR_KFbI-FM6yLt3+gyh%PJ+U;#Ii@Ao1p+n%-;9<%!!x7k8LeFl7t2)M5HFMtfiXB zifU%psNJF`E(Fox_H59B<_eyiS`b8|y*4;cPEo)(I=b_bzT~vxv>-D`wZF}jC4f0a z&QSt8>~QIIQiT1Gv%T_vMNTyxmOb*U#xHM>Zp26>(QjGqF8+jED*LR0z_IvJGdj#P znCC`w4LUzYW2ua3zE~@giA1DIZ^%YUcHBV+9y^f@De>4QdF)tCWA>?>el9$lvx8$c zt$5{tZ=9T7Fm+SpR@kv7zXm&JZtbu$%-L;Pbj(hexF2R`zoE8fCp(Wex%GNW13%A4 z%+M_Evxgw@oKQAvaCKDm8^=2KvPV#%hYkFB24cl?n`>V!=RECW>3MhoLE^WAWgGqG z3CcH`hQ*~YxI8{H6Uu{%HcGPV1irnbl2baWv>#%7TcA4}C9KJV_MhN7J*3_;6RPyv zzzB!jSf>=lSCgH05kCzo_OYfesZkR;OHYI|7^SB%7n6m3%wHY)KK=|PYhEm3&Q{w& z)8w>Yz~sct6P^h<(!beNE z>3&K%w^^D4q#5K?ae7IxM_cx(6K!#EA@=N4Aj4jVx-;yRdJSTZ5XkG&8))rXpH|&! z_l7&p1q_EQ{DA^==J9JP8&<5!NDvXPKi?q~Av>x;OD5~wTZ`QHC-Y2RN`GsUm(PB~ zm8V$;R{@=B|gKIna-?W`so6dY%xHl(DCZ{&T>}^YTwm)Wt zJ+i}7>Z4`c*x@NogGCSf^3T}1o@U~A*^`CYW}YM;EXVUX{Lp0QD3Z)bBH5tzbB@E< zoty02N;~^cW6yjBFwt?=gz?^SigI!(IreL-I`9r|v} z54h4-tIQcv>w?}}UA5QlE1>Rvl6LC5reiM&|hWX<&1Ld@^Tgo`ajiQ@I;B&d`JLoTsaFDq5T&|QKzW64XE z!H`qj8}^&FOyMbvlV%s{;qGZwI=rZcH;414N-Tv1KBC5k%}NN-B%mTX8V;FiU%Sj% z7DTa9Bddx|y-2vq1&KHYfHjay@tCE8A$3hO(Qa1u-mSC?UY_jk{b7mrXqP|sziTE$zGXcYEv%Sui)7XUSDKmIx{dsI<@}qV9G?&Ya&YAeB))6B zCQZ3_QIV+QWB5mBYQ>Dxf4t`hqV(6tP#azMyJkMOk$`SF0dkKvRz+Z=gi_Zs3eLGX z*MUzI&bcVYc`50)u`D215eOIBD+tuOPEZm9t!6CPR`ZSH3-;o}+r*$)N7!1#OsB&m z(KmM3qz*0BgnRT8R~+KQDYcr{^*Ny7v@SOeuclben4gBf-3$q4#Uo~?UhnNfwa@#e zSw=@0et1B01q+MC6{1c43F3bSc^$&@@(MNm_o()g(0<+bs1i@K%F7um@XPMucRXH} zwA^@+b2r|!4&4YpHUZHJ0F*$gta6=Yi&|hQ9P-e93bw%coHFYCx@P=3xvFU-C0%FZ(2ZV?)vHHty+H%a&N+BV~?cW&e1k zx3U6=IniuggY^LX`v?NJqqlQbR?JBH?%LAkDtd3}^48U+Cw;3@@DW8`CZ2iG#oBuI zZ13~Yy=&mCxqU=B&tF<^I3HO?l}(hpY=083&-1(8fAvzV!#OV;(}nsragw4A$`T9` zJ&q1h*WE4JIWZ!6BdPNzG{m8zK8DnpC?5W5+) zmC>w;p3cenC49~54{8AAkZXV;F*aM_MP+f`tk*d%LSpmL3@h2W2uY2QG%VZ17^7kT zV6=pZ^P}yvzA|YN_{V#is00K1lUQ)M-+mh=KAf!W`r=SVo-+Q7&WjJH@kf0jj--jg zq?k6OY~Axxo2Bh*25^>6TEiFy9!4!%SkTLM^ zC$Y!iK?VfE>a9y<2T~cQiW?pkE^Yo9G`1pv(nnJUFGH)9hoPq0NhgSQpx@qUIpXsp zPk$ucpKny{^j!%;uHgJy$x7(2L5DvXqAM~Ha^FNCuH5m86(_e=oq~~>Hg(4(=+I}f z;twK#&rxLJREZ^YD!QS&(IP!v&Zj>o^z_-K`-^QfzVmpk5y^Z}p?H_>W~XY3 zZKOiq!3H*bA`-Umpgh{Fq0jqaf;9jB!_$i1Pjivnq9V^07KxUho}WTDpCjdDp=WmI zu3{iwT_7q9zRzg^3>yr|$uXyAus_<~G&1;@R&BNLS*2*#ubueWt>(Gjqzk27>1kh6 zdW=K%a))fvPB6zY6^&BREPFB*@Eaknxb6%(3(LM($EO^(ROwBk=Xzn|M~XCDo}bL$ zy;>A4mNCYjO1m!y8vccYv?v-i`EagRE9f@MEpajT&Lca18QZtvlps4m3D zGRq@uO7!rKq(04$b`r3s6l;S*{x^7k=ir6Iq=Aq@nAIe?RIt|Y*@bX?op=2RZ0vch zlRCatYagEMs;%C2Nvi}09cKO^g+80%W}Lgmt7~32s$nv?#b7x;fT;(U#>^w&|MY+x zBHU70FfN?@cP?O`=)CC2zcZ|Ta>L5wA4%}}85fF)+E%a8*pO!vT;$maaJ>HEK9Q_jJ4NShN&qatFrEV&u#E4u9D zKJOu*iKTykV&VJf0P*$L}Kub6(D|^h!5RALF-9p|(ipV=6`& zQxC)Qf#2E}!f!U=K|&s%=J*X`19OngR%)b4eE)aKW&;mV?Gbj)MU}8JjITt_p#ZjM zRCl!bvF;=bX9~Kb4T|ogfdco`93RCtq7S@(SPx!xG|HwJHWqa&mkp51^U?ym2ttX6 z9+|>M^Q9DVWRMvBFZnVL%go?r?V|=$yfm}JZmyE#$S1U*>?|R|a*1*BmPcLXU?Q`!cbTHqs-}PWG>AB*NrO?bb@#PnJa zQ8_)Ewzw6rU489sMpVWpl<2)OyaNM@ImEVifC>^f6l-WWA5Q@aW-@Eyn z+qnUV;Kz3Z#eFx!qSR`qtw(9Nsc-Hk11ZDAvU^>_^wf;0xNU=6>{eKUlIiRY@G-F+ z4kFsp{mSYn0~;@Agyiarl?7OIlC>cQ1hBLqX~@n*OEW=AXP&o@{m^mu0}xuX3-|d? zK5dzMFd#1cp`DN({p4WNDvRDhsE#V~g~Y;n{tfZw1exW({7@@XVn?N{ux}2SJAq-lA@g&8@Uj83B^Y^TovDBF1FL56D(p z^rHJBg$Hn&9Y}xv9Mp;lnaXkuKD}AkCNqss`*oPL-x^< zkCG=Wu)Fi)ZlhDFq{4I&Sgt3PXN?Kd&E}D4E_IMN zCOD)@2GxBJ%c^v#80(WOxynn!e65jgTobjBYV0OX@nWibYaqFJ(PT8JNdKd(qu}N^yQ!-b-uY7)hG~g4ygfa`>g!Iu9{&nI`OV zLvD3L?rBcJYcOlfO68(Erm4f$9Dp50!bqARfjUEv7bH?;xFvV6Y{dl4T@nZV^D$gz zA`wgMe#rN@&)#E%ekJ{UZ<@~&rZ;*zPtN)tw;NHq`uElomMYnCn||t)TZY|e!;bBb zPg?|_*;XbmKlHv&kJfx*yIP?FVBA>`2`j{?0$y7ksnL(vfICoO#0S=b=WO3bpdmgX${xEx$ZlVS00Uw#=^P&M1eN77*-s?OZyOn|Xkj z?D#;?1_y%(I?xk$!umt{$@S~%#li-wiRYUMw zb){u%1}JQ>%kAYfub0$l*~Ysm%4bXg`;AlqdJ+(N>hNkd8wA@~pwZU9;obicugkNW z3P1X0z_(*<+)|-XZKF^;f69*R4@-7lpru&8U)Jpdl`r*ZxPCcs8(<3(WBzV|$^$8u z`N}N^7Qz%J%FlH{OCuOT%YK|2>L5?F_YX`v_J18abTuia&VkC?AH|oLA{E8E zz-lU;LI1S8Z{Y4Q#77?=VAsDWUnT1B#RL?0#|uT%aWgcEcyWmElds{i-Dn*a^_RT* z2a@ad)sSu?tb{^>pArvcH2aco%qgWE|1!0kxLyx+f3xnx#1=Z)MyHs%!$BN7@QwCl z=V=sZ|KeN88y0n-5O?P;Ie(Vr66pRjlLon8!Nn;hD1Rr}@uoeS#H!bU2aKFWv!5nA z7x7Hr3t$0_lTwN^KTIZ>THuIjS4(hgoms6`u@s9CgOp}zyl%qfJwFUZ;;3c!!gQ!l zSgrIT6%W1l)8Eo|!$0%A+e6zhvuXI(^52Y^~NRobJA~SZi%^o89hf z+PX8>*53KHTKK+@Dy_hYi%wdJeE*DJ{m6InYWsj*A9*wVEryv^ZSY7{MvHHDF8?Ss zJjG2@oyft#65kXzca`xU>lvH*bD27q;lNKSwrgG*5S|#CPpxU5pCDcChcXHz? zD6v2z@IulriWfpvsb;Ix8lI1_d7+aAq$k63oQJ+kF>Ay|H%^Aji;7kV@sk{rskh{O zH?JciQWYX5@$J}h(vyNN}Cx7uYFW2aQ#Xr#lE1*&X9N9-7J|gATw%XBQA~>-5 zYnbS~&I{^XpNJZx*w6p9@-E8QCuRfoRt9yAtiLy;Gk%WgkQtV>{933kG<(rDcSu8e zRHCKEH^818UpB*_;7FgL^5orc-Lvr0$w9?0|AL-)p=C$0yCmH0s?6)7{FKlaz+uA% zy)MRSLic?1$PDVBdtR~ZQJKCV@y0l`dQkSJE*T}XAD~_s*xtr+eA&wwE6rl$coV8R z8)eYcgvA|@oT|m>F%MC;q*gQFGgM12t~$}`vteB48KuXCDMa;&cuw5DsysblZJrGT zB7B*6Zk3M`!RA%MT8-u{!=k_W-GX#3FFZ2_TuX0d#xwvH(xB>Ely#9hxVAyP}~;EEHP=CCp}`p?9uar|+}D@O&lC zV?-^Pm>~oW()cMmZ91B!&X!nb#0NKxG^;&%VPa6XV?fs(I4pHj?tec)cK^#!=iWBSee*?n8%hnQeE8dkzuPp5;x$c1f`o~E zTPD!a7iW4GIjWDOq|OlKg-_a4x2ypz5M9R`V6Z<-KstZQQDQG)hcg}t&KeVQMUb-tkA z&Z(Q-_kT*FRiEP~_i#6%NheUppUsIm0xZ#pZ{7yeXAtS2t5xU-Qj-gGnOIa$HGs!= zbZmjZ$ppYr9e+ex3qi)RIYhxXg1Jv0|JR}%pJEv3AN|pt&moabcr8WxV$vz-ij-8- zC>cUz#k8#C&b!T}`i1g>9f%}Xa^8p`z#B7$X^U*Ns6>i1I@5z5a4T%l_vp1Z%;_rq z$oC(D0O>x9$NhOQs6Zb`&N8r$uF?l~O`KhGt>M@F7XT=U5^ucZMHe!r8F_U5HsT#X z=Rryjt}1viO1KHjPW$U`X$L*M#L@_0v>>tn>tZktLJ|ZDUK;m+HEtYRS|#o(u>^ zPI1*9^3?`gwGMyS{Zu_BC`rhV_(|4wthLV8Gv=}~d=_=vg6GNkiG%+8svq0Q$O8b-+3epH2(LG=$Ou z9NyZ-e4LKL7xfw+uAayG=lQ)s;Dm|CkM-Ff2$jRW>3!nhhG;y<=+Vr?*GzltBNcpavP;0@1BY=9DbOKZMGBPjOX?|xYtuQz#__Zob}D_AZABtX zX>RLLGellZec8-KK-9dvw9= zA*L&IhGqM!JK+g|E{(pN_|>`~v9+}nQ~lxPRuxxCa^pU7VyUoNngAntDSd0{7s#Zi zNYJHv`h4Bem138NXInE&pcRp>F{o~K&zuwn=N*;U=*Hs>;5mbGu|OGsB*Ri9em#FGbMl#&PJqXlN0~`B+S{ z^Dqh|%M-u-{sObpt86rGS5AwP_HI5PsBJn|0{NOcSjoX4d$NZhWAsAPv1S;RjYGF|(zi!g4)1Q*sUL^k<# zeIZZ6lIsETN1JkTaevkMTCM#{iAzeOsW;|}F&T=FST-3?B|{gV?Q+ecZM%XZpk~{+ zx=lWrP3|Fe&?C(7PfH(5`7OC#uB*(WuJ{pLSZ;+PxpnulU8csT$Si(QtLuK?$gCRl zy2aY-(@xt$)KMyvZpt2u{-yl=>O4&ReDW{o8!Li!T4nGEzswKHY0o&jGX7BoAC*M^ z*16}f7S5)vyyJ16_2j{P&lUoz&CH2grq}hj#^levd$|0=95r~_q zQf6uPPxfeeG(hDi+s)GGV`W-yuN(Z!CYSaaJ@=aeWL6rc%Qku0N5>T#iPcxReneF| z6(8K2Du%$8kHch~iuxySUrY>}k(IN&0H4!7it*`63!TR95ZH0QpA10wIRXQ84bzqT zdAcGIE4j)y(C=0LcaR8QGpBG?ObostpAzgE@)WbyjbfMHFRZzKdLK$>o;GceZB_$h^k1Va&nnm2<1hMI%KFHB z@rD?g46@2VxA}g2K$wsVn#{I@Ls~YO4K_GtVEemck^#8A%;*f%crA_H3}u(TAai25 zxX0^_HLi4Aey~k*Z9=0(a}hF!r?9n${!mc^bosQqVtRyS-S7CQ!KcfO z0*V?m3Ag12no@SA`9@-YqU`q9G0#t`d|WQPH0^COfw0VYZoCr?%b5>|CN*P>(on-$ zecMR-VYBy{T@cYW+UQNRZnY!WR21vhR%)#__K}={fQ?d#H>|{`*}rPHSf=1@N^k$* z-`Zw0zmL$)1y%pi?Yzx5msW-8R^hF5=AYSwZD4cgk0#mkh1vNm+DAj5fcS&>)o1>b z`(B98_jTy@pZ;L-(<6ETxVYYOj_X9rl#yZNSqdxI>QSLVOgwOPoQSsQJ4!@LcHRq| zLaE7)Kbj(ZxQjM}AqPE&Ho-}C$Nu{$L8eVF)4|O%b>Vf#hxX%z=FNg*@YQq**3BxC zIkr4V4aOjI&`oBx%8)wT;I!eY0&RF1baE@;6^~!$lhKVSLz_3sDEyj}(D9xv(11*LI8}WJGG<1okqvD#(ZCa&YZqR=&#b8zAB&3nCBs;O^C9-5ADobkyDkp zup{Q7D|fVH#qIt)lYYv^TBW}`G!}ZBpQXBU*VAW&04$TX?#2%*BhWGTo zP8_Y3d+HA2_8C_{J+Nz@3bkQ4)?JyL)zf=_cl3{;g(;HJn#URLcDyf$Amrl*T2I}D zv6gGBSU&wRV-2~Z3bjojq7;bA7e&9OrQXHG^5^nDB^~XnC#wyD=K2GzTB)7K)+oc) zq8|%e?j0kXO%aRl9ANUbk$zt*1G=PDwFkIS!sf$_;^_?emrZ9XeJb(iCpFb>vEZi4 zy5z^Nx%F?(3i zG+1F1i9uL#$Hu!2NDn|;Dxe;g-T1WkdXT{p&Z*yNl9M^}c0g(_s1pww(5U&`CR$>R zZOWm7pEl?-HYjq7C6hJgAJ5I8u{W0=!%)B^v^nPtVKN>ehnML)K+(X*Aoi*JDj+sL zi|C!aT51}4)r(#XOMhs$Ax|uX9M<0IM~<}{0?TG;`>dp-v}95O$ECCcKv7uTW;TPF z&Wf%a{z>n*((Q{X)9aR`N3TeR9Sov27+4z|Sy~$$TRv{|vddR#u9d1awGeJOi6Jg8 zrIg0Hyxe|-2P_YU^e&T5Z8;E)vD}^lA3!ng3%$G2aXR%CwmX^mCK*dfmRoNwYGUc&a+@0%Uw?-k~2!!{!TUp2pc5{}aF zWg^28$gnUy`jsn=O$S>Mx^G#X4hN5u9BC*^5p#`)UmOB*`BJ$a2P~!3HhRv8w_MsC z-MO>VBo3XzVq^67yI}O)?kH3At~NY!z_`)RUwORk63omn=)%D##oaxd>+V^)D|6jF z>$)=p4|=vc+NY>V*WE?doiPn`>-g1l#0CjsfveQz=|L6$;g1KeDKIKtVc0rT=6c~Q zsQ4KwgDxx6nRdspIG9f{olIw5%#JnT(icEV)Z<^eqdC=ugOBch7;pWhLRU4 zp|nQKm{xehHG8X!i5!Qf^&N*XBqBSn*#N$We4&g;QFzEyYF$ z>E0n}h6bk~a(h;;_gWl_1j?gukf<$rIiv9L$n1mM>@<)4)hpiCLrnpxhOS|Fs@p); zoImf$K1$y2c~9RHyW6+OpVcoiJ#t^<=IEIgcjl9Qi@fm6CsdVcZIut znddZFd*f|*;dSnz-uOkHdW?z&rP9HO`yh?jv?}_x5z;S$4s&awVG|yf$3=q!FE_00 znc_tuFRXaz1f^6Rr$(iq&R{`ai{PYYNKkVPIXrdR-y%)G( zOW--ZZLtIZzi%z)bJ(l`!xGJ1r76X8z4HNWXZnn8Lu2&L z?^l`81GR`fBTfkuu$Sm1oY3N!j=qW8oHyl`*iZw0ejJGpfO-vAKc2OE)Ccf_p=$Qn zUlDBWVZ>9Sn;w7*J|Z|$XkQVUrA{Aw>GZ)v*6&=mx`jS4e+_-mW1TZ|HbR%Zv%qCM zxJf3l@RI1RX9b?toizhlY=Tu-PplS}jsNmjjLVoMnBbVjtvPO{HU{qHM7K(7*Gl#b z@Q{cHPybxqE9YRk0mKY=rk*e(o^4k`DqIa4(mo`yU*}bC7$hUhPTgL9?uY(iZx zs^CZ^I-b$A8KU9El-jw%;KttemqoVipZXGPsfR=MUsN(U+ZGF-ILB~5p?VVIMzBfX zTglG-;Cm%9p5EAUezJ29?vf8)Jm{>pug>Mzydk=sf6|7nU!0Nbw8Z)x0a6gaVl|1< ze+!Yo%O|e0j-ec&EbWv;j|}@7M1CRgiV)eVCm^!Rt}gAwBNBfy(K;iKNLN&dyyZOC zejbs=-gsw;+qNx0x!I>>MFA66}!v!?|ak+4S8XO*|((`io@e4u;lKOV4WiViIUg>eeO88nOBi zDfoWdy3;3KaB<6A@=3|?Uw3B9FMFSp_unIkgFNcP&vU4M_2EL)n;abUy&UQl3@JAr zMkk^Y%q_#`^XMfEmDsU6Mz8r5!tM9{?rdtxy@uWpU6zzk>nr!{9fj{r9}}6?g!+Swr;PLXVRS9coxfWnkP%*6TFOtwC1JR^ z!*Fv)Es8d!pWa!89)G^Su%kMyP_(TN&)J*-wyho|&6Js2Jxo_rl3fXq)^V?YOFHZ* z(^yS5s2EgBTQzLTrV0oHtKrjSd~B|kDU-6YBvj(!bp8VsR8;Yg7Q3@d8WF-qg@;zE z0G#!Ler{9?sy$V;A#+2V)|zWS!Ry)0{8h5tG@Ktay8MBARvNpEtsWj((GqO?hUikIKwFm7C$OX^qm2_4{L! z^AE2&RA-Fr$}62^3{1w;Xuu~)# zt=J%{g+p%HODl$?{o%u|wQ-9NxG6EJ$}9cUtHdfVwq{_AjvcNQBXzv6EJ1&HirU8K z(xSpVYbY1N|HB)x8=QFj2%o%_xXx)7+0k*&SQs`xsu}YDi}l|}Jw}M|-K*>d76uuTwfCjMXm~@_v$D%uTmJ@(dS#aNT2Dlw#8C$7IQYGrH|MJDFi1M8p`~w zA3Dxr1At~q(HmD1Zqa9;By^5cpKZiI`mJ?VT>97tHSf5IVOva$j&r4NqJ$}9aRWAxLh#A~aSi=-rMjr$9U}oyU+5I-0;p=))0MD9w zlfpVxKx&-c0hlR}pxhj;`X`F5vTM3ZZM$)4fmJv)os(7-KyW0Qu~MZ$RLUODa=InB zuT;16HOd|@s9tXO3vA`d_uZsNNc<|h7Of%v`{h{b{p-vD&LI^Fah_OW#%KDuKAsY~ z6+&TKP#L{!Iv2*vjxxe>xTsPRWwu|xj__eqK<|%~N2m8w%EqmhbEOXKr<9?gsMOZ| zlrpRomHKeI_2C+3IJ5b}G`~?%$}~5Y$NJQX7JS>q9x(2R{HqCu)viNHA60&dBY zfbolicu&>DM0<`q{-JK#*Rsj;KueSA@T+S+Y!6b6QYfRPAj%W3Rh3|zZm#;52Ho~7 zvn6!!aw7#8-SkXu$syUfp{l`SYDqwL{!Bl3;H)yHWLyn0&^(1z6(b81TD~3S_HJeO zvekL%r^q5bII`&k83I-2`Er=UC!akjRz5rwVaa*=N5HGTlUk1Y8k>9oRBE#?b20@jQfDB ziP(T$XK($MgkiF(HEG-kHb%*0k_aUSFx7RxJIKC|Pu3mXwAuROD;nE-kHupH6dQ3c zqtg1!l-|bnd0a z{nO_|)^)|hx=6xZJY+B6%I;NQnhKEer~f5V_G!v@+7A+=!*4yMcmlIvb((}} zmGy|Et*7B(IKf;%a^df^uCK${e#!q9XP=N3Z&rHW$;IG-vuVfL%HP=WLT!cB$zq@7yt-P4)Wd54484o;opyX-JLy9_f!R zyj_!u`~8$|mY3}Mvi=6+Go(;HRo3VIE)ge8Jp8(1)ly-XL&wmk^hi5Ld(MzAluv$= z5{SnANf=n*n^`Ct$rMDx{c}@9Y^LG49FAxkd+vQH@9<gNo+<5y|&f@gW?T$(Zua8g6O`y40gJOI)EX>|czJv&4>KEV2oT)Hz%4=VX+ZW8w zT;Pubay6s(pCXX4v$eH6TBV!q?d(~P%4d0^%%9gdI9B*=G)kgG|9ChP^8ytR2Nt@c zBR5$ecvf(ksVI_J_VM zx-||UKM9CiA8PU9xOJSHl4$>e)?4cHt-F8|pBd0j$bzQL56+ID{b1v^&vdMR%Uj@-kIy|V#Qc$m^^bXttj8+lT@2SqY`pHp&r!IwXd=}w4X5^3Qj@-~CcnH>e!_pZuKl@!Yh%kFvj zCb$W}Dhl5Wi$3|K6Gd;U0y&&^T<`VH>k3wZsi5q%-)eUCXvB>sRr)3|D~P&H&Tnt! zqKyADd77MmNEPWY$)H^xryS;~M;ULncX4m7bOZP9lQ<*Xo7wT3A$DIvnrjefbAxt` zPk&QCVER#R>lxA6b?x))*&+2(j?uuK75W;h1@Bh9;HFjz*&Vo|1-Y$c_izInr288c zHB1pT{xJuQuHT_TmSmIIC5=!Bh?&Anc2 zD1cIf{KW$=u_8-0+FM#A3KHKxLI$nuAYD+Nj7&>!xse5d(4QU{7^ZTmG4_4#XeT<( zj-{Pw<*oes6%&CX{tCx(PGuH(v2$mWtS!u<$xLj+Q{(~LpAx9YZ zaSRI=_I_LArA+ZV&N_-~F>#r$bM0z*pxMU{0^4x$1M%4w_S{WaYQ+qnQh+t~rbM#=-XDf6H zv0#LaNU`;IH}5%q$2`q*lJ9^sD_vFZOjLO-=NkA{J+HSl1VIC_UF`pN5JWr>e* zu%t~WXp(SIGM;13^7|Qxhf3loZ9!r3g7U(4+JsoxD!y1@*^0A}X7QMHO#3X7PVf4hDx5 zD4UU{Zlt@RPl&Y0&(rCl3k8wY`1Fwi+G4Codc~gNU)!hufONEWObN zpMW2=Xqr`A(I1HT6JxuM16@3ONQDC1T_i*cGh>6pD#r>ll3x`>0<{dmBd~%pj~e+T zt1yPXm*!WDWp~rRvBvA_QL`HA`}LATu`uOJvx6vhD7y?UM_hGnHWL(cV25p5=#J6@ zoTCw`mH1FgS~Gfq^PWSc-mx;#2W`0nDO!ezuM3$%;f_|C$e!te)97-?jCxozgR0jH z35@!YkP>rfhm()EahRkA3U^1pEcs?AH_kzs{;#0?A5_bK?sbp;dKKH*1{;9XAVpaz zGtCcHaUGj^mIbQLgMk}mdw8m=S=9F@d@@&6xtS^tQZeUo_K#+74H6*=c)y<@sf*KA ziK=Gshoyrd8y+Mnc$%0R!L(z&@T&6YHOZ;9ga*|u-z6q=4&$!L$NqU4j49Lk({)7MH>M*5;(?B_IvTIo-dO!v*W3XBWgUutC&o778BBXrR= z|8jbIPe9d3S%O7RE>;K^Ja*&=E1m9L|j!)!loM=6*njXDNGt;SSW(% zWxsxlJ8I5gOf4rYF(NR*J=Po+`o-g<8DxQ|K{R<;GeOuJ94oNkx>a{H=F4y51J`oz z%6!|ldr@uJkdCP|W`_7~C`frZeaDF_mC-K`by^Jm6({G|&^4S*L+bA6v48giLjhUc zdb2}6>h7zN1@y`cvgHC3M4>mTV!Em!TaPGIzrKZCN03mg(ynz9I?&rJHuC83Dn}!A zJ%PRs`w+U1xV-o^QI@|>cDjfkB z<0zGZXq4wLc7)ezB+j!M$m3XFqg*vA^&0t=M23lt&sX9S%79^N=Qx_YD3i!!kaxCK zEZYB$;!Gk-wbi0Jw5Vr(-moYd6*6{3t&7GRvd2-5j!jYT(lT4y>N+{8Oi|OiGDWp3 z@?3BCwyhhMf3j6kK>g#VG=TmsX;rWe{v-iMrQ@&e-rTCEGJU(+QXU_Y4^AA$H-$}N zY*{Hfdnb1uFlr5<5*LCjHjnVn+#CdmRlb73Us2`Q*nY zhOs;>OHSXJ_sRL?t)G97{rUX%N8KemUI4@LrUS$=aZ@JFXcFRjb|8oa2{mFgipg7JGR86FHnJBdq%7pN3) zv>F`oF3d5dVvRZ_E2G`#*}EDN zNu5c)z2>c_|0H>;7IF;}i+|>mkwa(lg__c6`q*MVpH_U>17~IDs`;M8_tAv)s#z}p z(4BBeM7~dw!cYlrM=!{?c(hj3i@Bbg)a$`R9kzEe642&bBL# zzOFcl#?fty#pndC0Ma@^Ag|Br1QY)N4cg({AC@0gLSZoUQd)WTv^s~52(I!>zHeZJ zTdHRn#8zw&y*ngFoaQ9C9EgP~*?x0%<4Sk<=(s0`#LB~Oiwt4nz#C&S_@ai-ZynN? z3|1U`nmy)IE%rG*uR^vHU<}ojiSbESh%Z`1Kcc_R{{Mo{uiJpV2?@?_=Rl%&52czA zq%yR|foCR9c5nVT)bcM)4k(oENlKCugJb*^>h*E8*` zE~o&#ZMdP!|IlXRIHv_RLWl%eaI@L>(JPZv-_|h0M8jb|yX>xW<2ZC!_GsMe<^{dZ zRE4;qZ|v1|)m3R=&J@F?gL$QPF;$*c|ACS-h7v(|DxD7=4EWGIP=Pv>tb9HVYxrbH zTs_yCwDpy;41ot{LZT1mDOkHSd$Q*7LE_VqX3`^F{*NN;8ehfuqZz*OjI5fNL`Xqx z;j+aBLz~bQ&_;+gi9n()pw(q12^fTB^XpyqyxWY;tj+LhZUI$lq^~Ed-mvJZ=`OQn zlvGekFNnlEl?(OHmLDk+y4xC1`k>Oy-dkdzW5? ziQev5qfGOqrPv?%zT+@jGo+l| zAou*c!Ye9Cu*tynr{a&9_5VX9`6z+-VHllxoQ!fXy>)Gj3qS8P?RxiteQ{yMQTr)Z zZP3kHQ}o)k(htRziHAbL0_{5W*8d+vY5!tC3+b@pkKIzq8VZJu}lk97nw!vL7 zH|fKU&u4#QPnG?fd+r?v@jm%vzw{e`L@)}$zS+Z7hn>VNo0_Y%8vsOQ4O>6s%e#|Qp@*$4zvjpPS*+ibq+~wI z{+ZS8XzO=uI#=#4=Ujz5JA&tOp|zzNuL$o9G8`zNBRg)`$tQ9>HGL%?(4` z>YwM%Zv8}JXLHTX`lWEWuZ5wd?Q7-R=!!Ow`qF|&Lz>m3#&MYs(_#Ff#N0wkC7JzZ zf!m)b9~WN8{xvPfglMxL4BU8J`@*V2Gs|iREM-Sqa+*$xlvLvWc6iuvkS<9)!E7t;suVT@ZU5M)R;Ql_o3nlQ0TnYm`-!Wf)TRr-zr(0~j7Ki^JO;2nMqij4 zW3+7kQehMYEddo&s$q&F`r>t#^v)BiQ}Vn}_IxfT*jo`u>zxRsSN4)k3rPK5uX6O6j|qsznfSHdoJCbF3jR2W^Wb9!&ZZXYXltxKS7Eu&AVe zzLIOlJ7uulynY&qn%^`LeP#->*+`gHvZ;Rs@;SD8xf4!10;6rUqv2fVOf%V(f6R9L zbeB8%&H~gx)5>H0^U#RdB^(k0A*@GNM%$_@_e=e~%ISW&zwh?2jPAn$IJ=S)4y|^8BIS&2deoYv@O<%Y)Q7qw*VK#!DaJ9;?pU_tVGWo zEYRM@Mi@guh9;(zhh=1#M&OWW)tBXz(rAl)i>(r+#bb?_^hzrY?4h{WY}jA-aiwE( zto1-%Os4cB-34>48Uac*+KNpVeupz%`VrNJ@2tzV;88^%T@Go#+c$!er?16N#!-p* zNm}ufl;S7+Nj&sYL3V(6D_U`l(bG7Qh`qnG;@=`Ji% zLy-%f)zLhP$24g8pe;!BX0%6@40hvM3%MtqF3(J;3@ZM_>vVWpRXTi7!p5185;lb^ z_O%Lj=*WaB*~ek&%uP-p6@bm$q=LbW68*hRTom5N&(=@h9Q{#p`up6c!!Zp(#ktnO zZ9P0ts|)oaGgY_2P2$z?7OVAI8{7X<9LRXB3WOZ2Tru3$6a%w$_$SnIynK0eReReU zo^Fs1+GcYNj#fAxMlJhbgwAvEdNNv5;;>NJ@vR{77sSfNeVOy=Bd}l|Whn}^+xN40 z936Eh`@jC0&V0@nU7|7Eu=Tb#Y7pOVfz?7Bkzqcb9 z3?}E_dyOhW?xv)eX zqZ^CnWFYBuSnDFM`K7Rm$@_?S01<8asw3XhLIr9Py@n6a#a0isU<3iNwt@5r&NRES zQ|P>mGtH8nW}`C)kK$9fXs;n#?!{L3(XX^z9F#Pd6aU7Q%|~bfgaehYGVh4rV1QoU z;j_yQ&U~&*tR3n6016HkbCv^}Gmb>bqKOB(RVvrUbl9_ZhUBuOw<~J89W+fe1XdLF zA8mCBZ`hC5XMbt(YTF#qz8d2(QKp7J-c-4Gxa<`URANO(Jdv^h4m=Z`?)Tcl#$rLZ zeUuQMqIAvaH-KN56O3MN97Y7dv6G?H93)Wf!r}W}6}Rn;Jgt;QgZwV)e1&>dXrTFD z@1_%RXkOSlk)f*}>)cHD*cGQnC9kYHG&frkNcx4_&GCmMQsqkU);1P`ltmQ zyQr!|@zT{!W0s~dR8U%Sob24kp6DaX!coB9FrbB$_4I2?Hk=H&mwl1gK#b3uN_PBH{y9}4G!?L$4B@)jkJ1@0D(ruj4|-AuxA5pm?PF?KfoS!Eb-DlNoPqHw1xg^aOC^Z%>1sVj>8f2 z?7{kTAb*T?{7G0j&Aa2jg#!t2hB2JZN71{ZFW-<}^1Rx%SS(C5VM{=cT}!B0Hw4U! ziK1Ven$L%eiy7B;G_xCc&+C^-JPm*-LxqC=rK`$qpaSe^)vMu~6UW3BmIU&IF-}2i!&9 zdeBrn{+3OjaW-xrk8}Ph`EhQUACD4vOR|l$l7E(EEsI-tJv%|afGOIy)};s6Wglc} z#Qvw(*T-^q)Yk9QbNhK3opm9)sIB-sfRGrLNNw?t7M(oawz^)Tk(ukadHO4S*Mf~ zG-|lW;Tzr-mt(p_J((^O5&&s1j6{0s6D?c$?PYF_eln9T(XhCdtNSqVles#!F5aeM zgYip>VZ}X{$rd9fVLrE~G@4vfY`ndR0}eM`itV=V0=OF0L8bZ=FG)tQ2h$&zN8=34 zyqd8BI-KULCQl0j^5~8ls8Id($NMZiyIp@^>a}PzP4rEEan*+4&Lm z#$`A)>vpv-esQ=;yFIjCWqa!%2ibBo1sj+2 zVT0)*hcF$L=*G!Vp1Z-}Y$JPk?t^>JNlw)aqix-fwm$K;9JV4AlTPV_EmbgVJqbGd zV(Vg{po=|pF>L+V?1)z%Ic&`x@wLPGaA#}b?=+snRtg)j9=6hy_!?~eZs^xGf1PVS zh@1D=dXo=H^ud3Z@TYE6Be>}4M4gBe9(X6W(pMcr zwc^L*e-Lh4tfJoHuiz5>sVGfS0>7Duqn&qQ(_SdxZm`C(GJ6x-T9gFyx4lXK9 zcHC>fE{nNZEGai+n7^jPZDHcIUpaR~uLT3FFwK3efTazUmFG0dt_%G4d1m>AZFv1t<$iXo)_hv*s?`VA#AeC)CvMRGmjSJ;As=j+OTkI- z3Yi0UYJz=mDaCOq#wx-En&Lo0ST^=MadcpVCtWDQPU)aziY!$*IQkyj&NRa9PJyidjgE8-3&_709Ibs{#xGMNDmB-s>&p-0W%bAY6B zTk#R0G(bn!WWg=G(?|tVnUn1YKobrzN%YYrB*Ac=s&dlgLyVqd>N5X( zwjbC@Vn2`XKVC=((I5^VHLea1o=haQmdLGctr?rL>j<|%-#wS$O1}xY(fb$o>1vOD zx{A&wA+-1YB9I34Q?4J{#r`oo65XyjCPRj7HvQ;Jp?ja{XOv3OWIThHw2F5IWS5w? z3!1lJk;xFKBY`LNQ`Ipk{9{bY{OZHM5#6|m`b7iTzn`knK0ih%FVwPRfjqK`EHA?5 z%a6JI*X6(@kzA@PAv?PwhmlZk=dC9@>s8dSUUpZ5OBQmvg?T66pE<@2!y^Sla1lyu zMTP&O-W!L?)Uhy?e)90r1E>%rj<~=UX7t(XPsV5l^ewHyuAxW$-K829JR808 zTSc>AD`ZVt9J~9ow{PSn?F41PM;t$4+J{D%$4QDWdDTVr(IDE+S1Z<}yl0lM;?w9Z zZpn{-(AWeg62yhT1An2tsAYv_>l#A~N+j=L+0lCzCV2_dg<8pU5%Po@iGJQ#oaD8@J6%VY z^8M%YARJKdBY>cq=M(Wp^e@i_u&b#Urv!(;&oeoZvuS|8K|J7z8^zSg?(N9$tv`cxTEP{oR3 zX-ceBF^!f$HUS37T)FT(PpvVcN@1sgR3XkwUBLG$5oZ}Y|j848l7GQhpY%1(1Z34kg!polye zF+=aXh@MgQ9Q44Q5@ql1L|fnOI5;SK|6I|ig)o=PzjYt&U8r1(1?Cz>Cv^#F?rrb8 zBBJZcXAbbD+`67t-71j6irs##Toi>0^IK}k_w^zGeGvhDtT#|v3D)b?tqb_(TF)7g&#xs@o4!nrHWPlTK*J-n36!sXbSvp_ zENmto-9(}7vblEgyNNSLq=K?*&ap*5S+!l$nS;~fLTPVrl}u|hd0MKmdTkxO*NK{5 zq4tj=gm^ooz2UsujkM9D2f4`*pm>%I#-ohtSVUZ4el6`5$o#LNip#97xVPaknm}n7 zzq&LY@*f)IP_VC4Ps7VEYx4Uuwf_}eMvdhB*1KtdjSIWy z2#0+92ejpi=8t!I@4Z3`Tuz(OBNqcUoDMyus5noq<Neih7u1-j$GnK)Rqt6yX`MUFK zEh8Z@yjn50Q`jD#3M%&EC3zoZsI2soF&7TVzF<=0P#@jV4hKc{9lPbxP28k2D`ohX zN7rzZ<+KDH-ah5KchH(lxm=F0!&6+|+umvMSb zm+8Qcv~z9u%BdPM*gJ032NXDNM*wD!m~p1*P&sbrKiQw-*6`kc<+u%}a`aN0Ic`DX zpBtK$>3}Bj zo7ES|UKr;JBN}Ep@ZRu`NGSCyu;w3Wy~CU%`F8S*q#|Tt8e~tqp@S`myI2#ureX30 z-k{~w+K{VbwdRX~%9*N3(b;yrzi*Ylqn}Ny0GMNi z4w$#b^%{$l1Lx-v16uv_UlDsH_RXN1Tmby;7YYqfAJ;*l6AiW1u6AxW0RZPZG|S1y zZwN+ic)AqH0i~Uvv|J&dq035}&+t<^G!>u@oke7pJy|%!`diklyoKZ5E$|l5{?1!K z)yrGB>&JO-!2y!Y9%rh;0Tyj_CCqoQf1=K#K|JYgReyE33X>YX!BrTy^VhlxbyI(%dp7tHN}A^>B$O84U2wKi<2J9(}bvVGbMd$|>uTYN--Dn}=iuxgTi z@upI|9q}qy{mD*tEBmV%CJrqwy~{V3-nzK-$0vP#+fi^VsMJ>>`o@nezw)F6BQ46u zk&+N=>YpF&Y<>zgFeAd%9og;7Rl0=p>`s>ZT}88@4>WF;l)1zZI0{<_s#{fDc+`#K zC*v3&iQ-LV^u10e!c`LCVdAD5q0mW6{QZa6#27qXE7ffKX9NOMhFLFHi1zd{J&0v9 z7Cfd0Cl{Kj*#=hkDlS1qvcXIw(V;Fk$X09KgU}s)?=eLnCZamp$>5PQ+@PdHa>>pl znH6K%`zMt5=ncJ&Pg&BepPV}#|GU$S^UtQ(OADQj4-;Lh9Q_bB0xw47FcAyoKLApS~6NO^lK>pV!{N&S z>i`8FvqDUK+D#1V`yclY>UkA0s6YL^167?erm;j=8n__X#GKq;Zx z;OMLEzFL<(A3}CV_dQbBsp14lp4&@F3lpdrOR3heL15Q(aIa=r`VPqj!9Jr`TyYLk znG)5INV@;H)i&Ly(x>;N2hwHwz>+lwm0Yo38imlaF8%3BYt*$BrxcG~Ii;Ktjm<1n zJ8Aop;eaPH)?e>?R)G%yzL8ncd;QSo+ZNKjeSukLnsGoNiG=GiPh~gf(jEQv;lj~$ zM=uxMyXmm^m*wm;U)udM#fju;UbM>iw`#L29jFHq|vvnq$ojE@~z! zI|}XF#kyeZLFN4?)4!j?!suUUGEs(2e?V=6IU!PkVI3OqIO$ZPT_s(yI|RYONkwuk z169h}wUPvVtZ`QXNok~X^DAS22&~nxj+2~zyn3VkVfnP>|lz6qWi-;`&PaH1X~QpTxZT*uI{3?XyzR2S>slS)w8_dlbf#$5ub&g2`_y z6{&5t#9P5+!y3V4yW*udz=2m<0F5r26`WX_oPW^<@i@{U%BTIk0c`afki21Fbo}#f z+!zh-Mms|XDR%$2J3FCLLoAmKW(0~ZNyk2jjZeGT^=-9dewJ(3J>v6egvE*ga8n5GT-s6HcSH04bV&K+YDqz7qqX<0?o z>GVpg%SaiZXsms*1K94vu1>4bTM|(@ z*c~p|YVh#jQ$B{SVRgk1-m?cXUI^+&V$S_ZGGlL<8+vknYJ>Jw0}dF_yq$OPR;eaa zz#d)O77N3+@yKv&awigqoui+?1HDTHFEkln<8-xOPzK9rXweJuYZ>gBE1cZasQfS~ zp$-@FGdrZ1FAVECVI~AQ=)?@6ngJb^(UEd1X%H0|$E~FxxrzFP8L*12Ryx4&jec{= z&T0kJ+u4x830}sxtcE!TM>mpcn7tmc9q^I2XU~rruykzZ@Fv>_K#J$vK6aVI@m1nX zj+)rO`T45^O_;d6&iQiv0msK2PqS78hmgt_7B|vrva|$@P|lj6i;8fKm*%RXWn1W} zo1Nxfc&|9-EqN#UVIAj3@3J2*Ee9L>~0{ z*A#+o3*n5RG6x|MvuINf`W!vwpKp2|KVx1b4F%9u0MHfQ_n==qKzMba>#bwHA8hco zpzriwfZmUSdHU~OD05%*B^M)}p9Nk}7Ic`wdc0^lKY~FGk&s z;QQg*$SBe`CoHp73Ej6ORf>loon^CNO@QO9dg(Y?vZ=4nU9OBK{M3=9o}{cQA+v_A z4XdN#o#dKOrjxI%tZQuM(0=Pqvtm46vIw0>irn+QE*BBnR`+PknYn(A*k2KYrFtH8Sx|=kt2#le z&+d!0=SzmqgT*RdzeeFHA5}|-1~-08RDBy;FYF8S3z@5D&Q+(#JfR0nUrHnmAF;okNim02AgoCsXk%Pks5MF!?F_%0_Xfuu^Ah7`11w9 zFeoNh$T(NQuv?C{kU*IprC9gPIi;y6IT0l4AV4((e=AZ)?{(4D({vhk12xmZ;A*C- zggM9RWvL?g7`#!suXEpP#aZFa(rDqiqR`sj*JbD*(ums@_i$Mhojrzrer&`llDFj5 zAFEjV>N?3>S~8bb!|*9cHn*7$@zQ>V+p8Ch%bZ5I7(Pcd{iIeW)F3>Hu7`E{f-A;Y z{s46y|Ne1Gv6G&Led`u^VP@oNCrljl-5cl^>K*@?3vpJu{=htCEN&Vrgs|+|iwYB~ zhiV|O1Ld@egN#){Uz0I;vnA1A26HDMvp)ji(QzqI@{e!gUz@+J5R(+?4-a#L+N$$- zs*3GSyv_6Ycb(Cx5!3|{lof;Gu*AE!yRgKW#)Y7qbde3(-yWdl!wG7;ijaC6faBMF zdr7N)#U4XLcXah{-1ORM0WkO1&!l;!zrw^Dhr8d6-O;Ii%9Xu=FD?w3rm4~|5au)u z)Plg#Z@(y-A1DxU7kwK@Ir9{c^ZdW`Kh6&Z#^e0=Y>m?o2`P8JAT0Hrb*>*cDL+r# zVSt+_>fvm|Olv&fXb`XrDY(0E=-tszi|$p3l1v3T|FP&zcQn4}K04<6a6nmK4(KBv zc8Y${{$5XiNN@ZIHvQ6}7N(s%4Dwla%lUwUij}L3v9ijLx5cywrSxiy*1p_R`A+{> zow-4b)nDJ{xMynIL^@2vk;GVuy)}O;9bRMd&ja@B3=X!*dmmGdo>BvkJn*UGkve|g zd#L+e-yQ8a$064p%9z{vwJS&0$K&pfHYzGK;Kj@~qd)4syF2>uuENUs@~;#?j2`zkFZ1c@8R$=W`m)d2wQ%!qE8Yjm3qu5wFUsJ-v~5Va3GF$959 z&9yehBZNv>pH5oQ_>$HkzR$d(L}82LG!mEs1%#}9dSPysMt^=I^)ZW~!@rsZSxh~I^5QekqiL-CeQ49c%S}tYi zB~fBrj4Pmp3CjlkZU#kwwReZuS>a7nubrI?JAj=J`S!WS)s$;WZK=(2{fLGivfAE5 z{aSoDX|72=(<233c`2hgI{JUKy$O8O#r^*ul+}2|jn>pqfks6eJZeyEgT)#yT`)@U zjCiH>qLsE$5=2E!Oag3|PsK{B^(xxK`>GZ%RIVy$tBBt!YQ1~R8mp+S0$TY$U+fs8wh<)Lis0axXvNJVDk+Vq zMqqm;S{B$l4;!y2)OX`j8h8R0`-)p=4=wOKjE)xSHrWC%8{9$PLQ(iT4nJo!+qh@G zM%ml6DYf8VUcZ?CWvL6B^uG$6rexROMJE9foU-b?z%v4ve2HB?8YYqjPT8oB??DQr zO($OI&FYUsQ;n%i%Jx-2v?9f@@VY|9(0F(7RuzatH1OG4D+6!hti6B>q?u}P*3wA$ zArpNKI;f)qxl@_6*E~|*QQ{cu0A4rU@s%f;+}ttGU0U2y!C)=o-y^jD%nM$@F?t#$ z$<@?ll$f+39`7kv`0@TQj2HIFg~J2xV7~)YAbD*IK-i zf`I}a4d&wzqdqE9G6fayE2=op-B|S7-839VdDBPHi}+*uOne0xe5!1n{?KKu$ezPQ zl~MljH8Cdg4k$=hJhqfiZOPfzofCE=BhY!6qYpjIv;*0GU>EMHqmJb@%UrqOItxRv zDgK>)0`P(UsUQOQOgig~J*CA=9HnLWhCUPF`PQg!mHK9Ag`G?uG3QP*8sXP_XYR87 z33*&v(6_!8@d&uLv(jnrvft=uOUx1#~prPBWuMwC<6eXpCn zADHMeOcak__ucp4kN>DEcj4$ajHLs`2dkq^+;?yK>Pn%gh~_%W7gp=ul0!PmxnoOS zg3e68@LQ?OfK=ve$gebm5udhlgrTMqFk`h@LGWVCP%8Jb+`ZA@SL!N3-xq~6SVKjv zJ+;w&EoaqCAz~0?RzC|FrfC@bs?A6RJR@6M1<;feD*}N@QMta=EbGBf$yqbRf_=pc z$-oOPXb6=71+DMcNdpyT@B7&pS7O)h4i5FYW;zltBZm zal1{1b)Lf4&b}v~o5#d|cxHWcUzhija!rL8Fy!6-*9bn-b?n zdRlq-GG&dlCBiW8Iv=_uyS{JLM_1AJ)Vr_qec!V~Ja34~&SaS*r6A{E)g)ooN2UBB zxq+w(c3KFFqjdPvL_RI}Qe-VUmQ>q6f5U24Df3C^TBr=%+EA5BA7XfI0I94HGwYmh zuk8{%Ug}xvt~!XXSx5>#?n5U99~V3aKY&mpO~4zHyC|{w^pJNKB_0{9ykQ9j!dbb6 zQ1V-@#|v^Hzy&i!0uzhl02N-gC9J;LhLv zkHi}PaiDN4PKXGHGT2g4PwO?Xy&B(qZOD3>KzV@z&}G}ji2kjrD>Hdz>vw!JiYBw0 z^B4O(yHzu7#DT!yZ~Z5Fn`ONjvM*vdup&q!E$avxEk@iWC-y=d)79sWg-8F7vl|3R zt$UoGNLKfcQt4IhL4KH)jB{FC-er;j;?ETHLA0vYX5aFzTK@Py&`#=lw%}m1ZufJV>3%pCP5Ufv@4G!@llBw_Zdh3X#tz<_Mm}(i*zW$#6Kl`&@mAPZ|YDsIg#$Mf$#BZoEzrk}L*#uSKphh_G zPc&00(SDTCHN`I;v==upu6u{i^9m|T9Dl8kFP6HE%s063a7{IX(jkyN=`kJE*oXbn zYD2yFAf7OTN>ql}0rgprLd{#RnY7(~ON_1G|DLgwm*B_5|1?DK-oGyO%xj!`#(JLI zfe|Zgtu1+7VNt76gzxE7d-F=8*#TNKvpJqrc(qc$`vE3WkD8#eMU|8hEhyfAglsHvI4$81Z^-kmVJHt3LWdpM4igywS~N> z_n!-2Duxd^?h`&B8V=F7b-M)kdht>ozNdEU3qFAN@Kt{veBT0pNT(ta;19G(2m}6L zy*zwi2*i#@?CTXGwiT+3^y$&t zdlQnwN?7`Nb2~!N*$U-ey8GJ9j^E`!w%P?XFyE`E0{H>2;r#Ynyizw`C4HOkDe|90 zgy!t&&u_n7fRH2B#;5*;t~H%ba?FcGRx+JK7V}#%=r(=wdqw!Ia{9e0{GJznuL-~7 z`uE#!)HG$=?7JBZ^NQ~c8J0Q6cn4xGTAFZw+~)ty!R^srGC{*xM$8@DJ~`|!&a1U1 zG0hZA%qdnH*rQ-m)i2{SPyM{_N+KLU*W_l!pq%ZFBeL1+D zJqsJ%h%ZCW;eno?W3MyR?IBNa^bGtDSS^l;#4ZTn$s)psr2@2$z1O954G?ve`h2Xe z2@={O+GN&Vn0d?pW~VTym|V?H@2XVhd`y*Sg}vgNWmw6hhK6o?ylx3)GriMGLxV-4 zzG+Qpb-V#-C3x_mdd#Hicu;E(?yv_E%Zx6YJ04UjDz{aN^y1mSQ1zj&q=vqTNaU{K zc{bJW1-4$W*;YX>ZFf0I<)VtRZ*C4fZQGq`6boJTWH!bg4?x@Pp-O{BQ0*q_FfT?> z>tz+`G_Ho*JvZm2Q&B3KsZ!~>R9Y;Ns9k?6eT$nRYB>wCB~FLm8A`G{D*0R(EKl~u@ne@XC0@dN({?x-$BY3Jm z6CU^4m*g)7#S#egIr`<`|5y5jF>!E2u@;F2{d8bYrgVGR6N>7%0ff7XYNuJk9DK|_HX%-5_*lXp zi&G*{E{M~a1r1esS%+G6DVj7`DV?AHJ)u+%V1|#0-)H!*5zq-B>n0iF0^0Qj^#|igm&jvrQS4&#;g0RKj+@3_78QKA0}GU9>+|LZDGf89XI4!tQPM z>6L**Mu_uE_eSeF9>w_cQ&GV^!?ZzNW_%6w9-DJ6`2l8QrJ{)_KNiq{=)!{b+#x#Y z0%g!-!vYI+Ua7}{yF#^a&Y`h?QsVV&t$MDJ7#{egwwI$v>`S0sqyKxsgGVsE%_9`{i#&H4LfaKc9Z)H9sVB(9n0bglBxudef5Zo3*JvgzM@R{n|;Vv>HRH= zgYV0iQ#4LOE$d5L=ShP$DYxvA7LLuDdipujYyGY|FqrJDwQ;Cq$GYuXb{Mu2b-J&=Hmxyxl6+HI@Rg&Aa~8#h zm$u8@1uT+_jFm>v?%&OG11?lrOW=?855{UXU+&c}@^*8Q2KwGpd0 zn3$m|GtPdpbdwXB+Exzc;8vF4PKGw+0zx^LA92?4V5?02zf z^W04Q-d@0|Dm~#vCgyIq96D%VZ#+i&;x_Jt?Gf?6;;DPJtG<}QEN+EuH3arI)N3_h zMe9y_P@XAiO;Ejh8H%SGfJ>IiQ!eSwYG0S07in)FUsEgd5AvR)O-Mm-^Knu6tc)aJf% zAQ@GvH=<>TGhC^!#2HNb2}5X@I0rO6ReWSuUbP^D(M74wEyrdKN!4eLXkc$hvhz;V z#JJ2><3=n=M!(?uSo&=qH)2IHiuhHZ*=}4Wt)mRAz&R>Rtsm{rm%~q8Qjb^lqq}%3 zf>le$SEbS;EhVYc-T4cz@v6Q1s3j!Lct<>$oP8A4O_EfP=x<`oc{)OhFxo92c*&~P zx<5>i2KSmNrYD#@!+w)l-|jz13%2KTlvJ{7pt`5!T3(etHoA%*a`~Dm&(isb_mZ<; zF#yA1Z8bryD6t_*JUJuuyI-IETAx+sFRFiWuYAV|WKy&b^dRK!Bz#iuYnfUzvz|d2 zwm7r$G#bw^G430%lP7BMZ`zDD<|g@hOyL$v(N+Xi&}@Ny#s_Ky!kaP+R0flURMvH< zD_l!0LY-cdJx{7cdv4I%?v(IwjZ_F!lE3Y?zQGfz;Xh%z!b1iE0~(xwB+&FvMS3$~ za3W@iRp(GjpM9~ewUA@oaoln+3w<$;^pmsfb4m6XK5e}&y9{mM-kfS4z@Plb0cB{3 zW}fHe5&Q4F{X9s#*Z#Ig@NFhUDeR|&2~r)nmr`zIiwcyN%&18g8nK-7Y<(s*d~NEC z(1LQRe{XykYRLfWf;?D1&hrJsX6|EOM&ccnefcGMYS;nvN~zH@QYm$$N0qeU!(95} zM($R0wJ!4!V+Dn9zCZzg=)_ncSC znQz>vJE~MqrRn`FY1m@dLT+dG-{a2Fq#~KF)T=A)w(JaFGO$NV9r8zv7bQ-=x_}z{ zsAXWXB7Je>Emg%UfpQRy{WxF0BF_pu6qAiy=2-##Y)(+@|NPR=buZis#NGsoW22gv zU&C+O;}_$nIW%iBO&TI>sj0r~i;rfGRk6(G>Jki3gNjNR$y`vb;47AIjO~)F^8p78 z5YG|h`l#&Td#~rXGJx8+lG_Pl&ED~Pl>(-esY*o?ETD*~Ly^0OH~8TI0i6RtG&sE{}eC^U80s>l*p<9L!l2?q0RqJ8^_ zZ{zG68A$HxGfj^Uu@9Kx)-S{~Otj660~8-lw?a>E3AH8{P^)nL5uOS9HY;juLf^vv z3mB=iq`Ys*$Q&cyXgEX`mqO)m@n$+<%^#Rkuaj9%ups`d-GFC&`Wu-+^L8B8 zZ+vt?>EY3-<%dUSRpP0Q9iN_7dU*P<^25_d!DW7qRS)7#Nn*Vhs}p{&;PWxRy2Dhf zhlY~LUh9_B=%&!W)nmOE+ShmMNe8=?uNd;~8`R1iYb{PCB`76_3*L(@74FlM7`>cQ z!D_Xs3S*vOOLf^s{DEMwWjJIJ7V{ZEqhv8?|3Ojr-f6}Z4<=xWe@Zv%Uk~|xN6_^0 zhmp}7`Md5^k;m)2L_kjnn2Sf$N2B|VAF=l0y;9LROkU0=Me^evqzOkpOXl8osdWEm z^Zu@DRwn4X@bKdUu7U{tV-_-bXZ^*zRrlZ@{caif#ugZjd2BW7xbjTJH8hWsWtEZ} zWSPVG;Yp_AgYAWfX$@=vZ@?R{ z4Ceau7-3HfNiAQ>3|eJH&O!f;QpGM2qn;CdGZhPYqe`oV`}C+<3m?cI%2Zr!mCmD` z#ySq1tgDZxyqYwuG>7IsJ}N~axW@OfLuSxaD}Fxhx3Ve?kQI}yZ4pOnRvKZ4r3HQ@ zH}wzufWK@wq;4@k$bjsA(tfXTck!F6b5T#f4sU*%sn{llCpunm$oe%H3;~wzt0_O- z%D?Kq&u8}!-I;u3?XtKu>(F$(tUkTiO|n93v{bwS@}vsi9gu(b5brXB=9de-=dj=n zdS7bY3cS^27xb+5>E0%+YO+)B^23c1-`*~#NDnia5Xm zV$*({h?lDFPV%J2|ER%)i$1My+tjrOKV7NGWY6^>Ij^QUbkU>;zne`tC)I(#WM@Bq zuxQBh&Me%RT8 zze-M5>haMgzujNOhr-Mvdh%{XC$|9wr69G~D-T(yr;~yO$#3oDIoymlnxmPvK0Inb z?%%(7kMU76a(@m-fNq`~*6*-r&-5Ypi^8-^qJRB%CiiRjq+B*Rf zeo0U?NhRQ|NK11*z;+KCJo2Y_BY)_VNBZ`MTGqX4YTU3X?YMDeca0iDhWaBQU=*!y zRJC?~8J1p=(Nw--*UFh31@HZ$5zn0SX!dMVCowyWuj}Tu;(M712zZ!tvfW{Vdcxz| zmNhkh0OlNpV+@1ALTYrC?m~E0u{Y*FEx*Nx+yvdQZw0G(;UT0hcqsiwhm$xhIWU50 zG(0i9mK}$XlnDa!YYgSFS@xZl{A&oVXxn9I$n9a4Cnuzb zGZCVVj^(Ax+;JqCauJxEj(X*r{>2^OA^h}TK&X&G4#Hvpf@uPP70Hf!O-7}qGX0k( z7dE0A*h%Vx$4@0Yeq^t=eV_1aa^Y$miT9IxE=?Y{^8HkD&lSmqqXur&{4sglYM!q` zP1Gchdr9xsB#-;^8Og7{-n#YqrF_2Gy4eN$*=PCr+p*eO3nztfyq`SzN&a8T+a<}% zb-W;MUwFr}r9Gdyi67QSe+0p|QyoB|~w zL}d>w^qVWg98=Q^_m^{WVvhA*+_DD>y^7E{`*CfH=;L)&w8qei-7m@H0(+jyH9tAu zytX%3^RtSZ=aNUsIb4Nghee+F_|23*eJqvv*(x1AZgo{C}< zpBwvY(_L=s*ZfdWMBZsrWE3A8KAp(_Ix^Sfa`q0Y94jq`} zI+!Yc@ph!~b;^+EUNJ|$_n6Q4Z9u7y!hq;W&B%Sjf{ zekRov$S~rG>6@n;ntEfHaI8CoOi;NUtK3NCgldl&z7#XLSEikWXuY_O#i|$Ajm?xr z^h5ZwRrc(~bvA-N#w z%6rb*jlr5|=z&DOTOP_v&AP{T3!xS8lJya@yLYD8ARb?j+W3trwjy~7>s8d{dW=+*{nF*9Wh5skAeQ&=lU}5sReyaAo&`>&z%pWc(gY0h6 zA{d7d!1{H`?GI(I+PZ`>|8c3uwfI{w8h?j$*UF3b7P(*-=+?2=IEGFU9amPW@_{Dt z+K`bKfp&Lp#Y)L*@bDhWTfI^8F_3TBCgdYf4lL9LmQ69>hYNV8*7MGUyNY>7N(pEh zD1H5Qcja03V1XXl+rC+L)ON*TKgGkC6SrBt#O9mlxt8bR+EqPzj=8q>j39Fhs7lE~ znfs)FzL^jgP2ZX0xt=oDezndRq+NNpwFby%$Xr`l&jG;X@&s8Q*eu_zJuG!Q1n7x_ zShw3Ea~jq8rwe-OY@e%>*y5~sLUE$Kh5wMq;`q14&rXt%b-dlA`6j_<{siK|N}wL* zY?f3h;Hqw?;G+SK7sS`^ED*#Ur{<921#xJwIGErb^==OJa5P&?4%eL3qwZ2+j%v(s zmn1uH(JzKtjptgcsm77acUHITgxAyhJ^}L~GTNxVhLd#pKSCdK$ky`jTo64b%o~u~*V;&4EBV->QIylds&l!b}BgAzqZ?Ywo z>h7nD9|YL~5}*XYvd~BEV|5t4g1X=+GpUI_n~4_AGIO1|Y=K6uIawRXOdk(pgfp`- z+GedYcdrOVaz?w32XSf!5@-=YEy8iF*hpDyG)ChZkMF8YTkPNV^A`IKHSd*AErVz- zFxM#Bz!OsaGTd(8cRdDSlf34A@b;iMNrW|WAAg>@4~DwlI`UT;fFcaFaf=_iiVI@K z-DZG@@!*6?ce*hoSj}FEw=SyHy2}Qklpd8*n$0&$_a;8HQC{%Tg!-P7(S8o2U9qM_ zMtijx?dO8gZeK$OTv~kYuJviV(Vehcb}5D#ZC9&?|CFben|-92xpMnJ@~-&wQm};B zM~Q3Bj3w`lZ&{&--beCg<(&MyJv8}ySyIwtzmwM3756-ccZ9kWhY^sPm^F58<|Cl{ zF%d4Wj}Gg1_=qJJx7J5v`VoLAwE#24ny`<9GZkw$))1qZIk>bw8atTM^@A%J^=`tJ z_;N6~tRIXCx1`>&gHbF~(ZwCwgsvj4j^tC~EsDz=U|(Tw%DQTPbg!25)G^|#uD#w5 zo~bk~G6~VlnqV3sE6%g(V^WQwN~JZUo(Om%w*y{b1R>sWwK-bEP$5`XtPYzqz zz4m@^T+;m}9!B-vs-np{YePF4E;8lG&S~O?)qW4I@Z(p9{wDf=lB54^r|0N@il_ft z=)VP3d(JP6{*eekvI;QZdUC$}?N2&r(m)H2Tm#mCY+~ffR$kWDiw@#Ga)DeI)}go8cokS^!Bum0yo3 zwP2X7#~g-tZL6J@zf0nJz^aazqvh_J|P!PeZ4TZ3ooW+Lx)siM?>=uGO{#6m9hQZXLGUIP< z#oG*Pj33tLjOYAb{+A}`Z5pLazyMwc6YzK01Oh=nEHLNah~w z%F@`9za~_ud3<`unhDX&ElMXuM{iL+Av$pjmKe)kU0-9fRiX{(@$u=gHKpUz^))o- zLx*}|Rv_=u%y0*i*Gd3eR$yQI`f6Oxlnm5k@6TQ>|LNPx+RrUIR3s$4#cEt){3gkvAjlH6`ez5xC~fB!cyrZTon=+nQgeIzaVri>CWPGE#rIlJQ}=epD<^>{ty4RQE^T1 z&tST{JjtR#=MBkaaX_I=W$Tvd7qctzxG>gB`7pw1{k^37&+hjrQ<=y3kHJ|a^*cG| ztVrKPV~4!v^Mfp@zWwb5HssrUXdw!pQ1T`{SL{o(bz4N{P7hFM6X6~wKN~~X$`H1;W6$v#$w3yT`8C%@v+4GbX> z3St=_#~X#>J7eSiJ3q63cj4b4(3IGi710O(X?h>$VHwgqmP{FeFBnY`1im3HX3K)p zgnwGU-gJ01I-C>Gwxhe^{kTQ;=l_3y(cwk?UH8}jU4L%W5o+7UCoW*543|9^vP@xo zU;Ui^I1;k={^m5co@Q&*BIL|5>Sfm7R1{Rl@~UNS^ zl!WO@+?ufQ(YUBu-8O05Sd@HRX_1916>p0!eoax6wThaob-R;>><|4c+sYc-7NpG&H}YA$ zBy4v!m*kL9$T(Zh;}tu^{0n2%S9qY9%NGs0xnW(Dot)H!mMqy~S{uTF?#*`MI|c&e zFalYq=%CWInvM`iS6IVlWbQBb#MXl{DKDLjb&7OFm0GSN$9>hisy8rTL4c}7j9QCK zBSy&Q&+x5U-yn*->nHvQ;8EfWdj}N8{)?fK=4Y4}rjDA-oVlzmPH3knyi^yTE)P3s zsbJ)LW+0fx$<%YY{PPIE{cv}eF{@u;KV$prFY8pm(ut_;%h&R;jN4DDDdy_lM0vbK zd;mU){}u6Pa@Nj5a!1kr`Anj+bsyF&%LeF!Q8Wx&J?y1n9}e3%ZrI}S=@+`Il`_;g zzGEq?(I*Z`jo(PN&eM1;=9t+3gain1n9`eIx zs|x7FsH$|;(_gY7gP^d&S0gQ2E2P)i3eEYb{TxrmX_I6Z&9ly~35(YE4q2ezh<_6z zI)x;M7;m17Q|Wt)YShzGaSivc*Fm9hz6tz=`2cJ_9pEuh&=$`p#5!P^ z?S2AaS|vmM)kpoWJ|eU2Qp@z45Vb7D-BHeXUJ2Y& z?v+5jRmYbCyu+DlcIaAyiP69x9}x{%Q?K^kq?G!2tUBSJN z%08{V8s-!)3QK6v8c(M$K8=3*qi|d$HpR;mMOeSE^3s!NmiqK*khGiJXVD4*si1}| zv8c2dg8Tb7&D~n~Duihl8}*RCc1D5x(XDJ0{8Oz_!0Dc5w8mV0>9k{0(T+ccOP=BJ zj?YLAICAo_X$PmG{tHu?;Y+Br1WehyLmDd`(gWR~5>Z6)&n`4J7BP8^2}H1mM|kjd z5_sQ6rV8hqQD?z<;QMP6>88&EpDIm(5`QG^y8}##bX0NDX~Y9a)9QN80+yV-h*78$ z(n;xwVP8JeDAQh7A>+^8IG@>HteC8Ot8RYoupGE45y<~yc#w#glKR+;UEbKI=NvvW>3gt(g zek@jTex&qcMffp=^c`%G=B8}Bywr|&0~Lm(sDB%2!`r-7)32V)4y6u%U4v40_38d> z>6*C=nZ7qT{y8nO-L`?KGE*;RPmn>4kNE_VO%nJ<{|BbaTw=)^n{oB zCPCIHmY74Q-M8aI+-9}JC$Vj@s4)Dhc9Bdpg*)yxajtYe<3(>N#nQ%!Vh5SoU1Z*R zvhtu^vas??tt36~1b7{TV55I_Jxrtn?-u5%<98#xo+I<5*mUy~`VY9EL` ztF35a{?z;~6&t*1bbPT!y$9>%?!Bw~+NIL@sJvxp)1*=m(~E_TitkNU9lhh;;8sx4 zt6CzBs0N<}lCoL`E_CIs1h@@A$%;qQ8Cgg7W7A^)WMr&M&047)E0Y;j${Akb1A3ii z?I5t?6nX&~&UPh7LLHiZWBqP{Ue6Gm&2YebXLzm4*AGut*i|-+@>8r4cg`hV7aP?* zm4nzd8>9it?aPJqW%WQVCO#anE2G$21BoVYJcU>By%mH=)e{AY?$%h*F?DjC zRDC>y8qZNHnTlJ#qg$+Ghs>>!!fx0oCe2UK#Js$8bH2Ae{~W8a$WI%h1HQbU@&j{{ zTU#0=7g#0b61=+%f_S2FjlUrrV8k9`_bNU)vN@V-ZDyM#?Hx<1Q#h@+aU4kkqt2$i-#T$vrc0Wl3&0+4>ZQ;U}yu6x-1mbCH*#erVffSS{Q$v?%CUR+wm3T4PVT(9GQnPVrkx}=n;5hAK*2#L>Mm~Eh9#JDXyF_15AD}RQz}G4} zgHWC0HtMN!>y|fTLGrMp_?Ymb;37tTEtp zm^thEF^RHTGwcD4eik(84jgVS^0NKyW0C*(t^c^_|KPt(-?#f;$2-m#*k`=s2VeHS z4{RFT7i3y$t+#7%XOuZX(`M|Jo+w9ZNoe`2R_~ zqhU1_J}cfa{WSCy{HqDG&DCL4kW=dC$3Z<+76FTQZlv@fFy-ua-KGOxtbnCL1t%F!j!SIm~l48al&lJ_Yx zgt-F_v1v`f_TN-R#GF!@75>Ya&n-2TAIyUQOl!V>t zZI)!VPW^^X)K+?h#@x{TbM|A=)8dQkAM3yM?#YGQep&FK(061aXG|iZF~X{Hc+m}7 z^s)(6t@c71w;)+X?PtFLa|7zMKgG&2HhKY6nsT!YM?FBT!vtGXpdyCPw#MWXO!27Q zg6E4c4cs$wh6wfyQ7cBl<9H4cKXym`0Y2rr^t`KP490!3KRXvsJX3a+J~VK~Z30s* z%;-*#!hbf~0#ET{QzWVpUW9EKxhi6}Qd|A=VF#QQ&>hzwLTUn!1P1vrR)a{?pSygGa{w_Kl|A~Z=J2@}LTV5BzFJb%%U-b05r6VqUTn|*$4xdI z*B5OtZr&s5w= z)l~F=2B8*yV`DPM?=l;hk_uRLCz2KnU`Pdt61zX~D-YD$cX&F~>HLw-EhMt^JCps& ziAic5K&x1n*L@L#3*f29!6Tw`V@vnd-cja!ot3_63w&72)1CQ%I+-b}NO3m@XVe)PxZ7bF{+tu0p7fu76tu4q zTB-|U!@6Vy_Kgz#H!pNgST!thi{4+f~E6{K-8BA>q>rvvh)o~q* zH;Jup4|QTN zpW4=}7c!OGJvo1WwTPXS6LzHroU2SOym4H->Snw``-G7aqkf|HBnvWorq__`*Lvusy&Wy=VbJlUNzOO z0RdqGdsn&nwAOu>i+%?S&MC0sdHz$r$LHvSmM06L+!Bb~Z3g9M>VpCF*|$DO&Kl?K zPqlOqdRl*sf+06QdSHQ3BeDBXLRTY}COa)6h)o!usW^MJ3{NWrYPV8p40)N_W7L5s z(H&R=#YsW9q23f#m5&Q8CX=&!1=znLWWBoUZt{vAG8|gE4_y=gS1*f6Pm2;uM(doG zEk*5G-bpN8KGG{}+Mel^pl_R3ms8rEq%NM~*YLQDZxnX1t95bHGr2A{oUct~MO~b~ z=`MaxX}5tS&+ez(J21NqOFApT+?b+lUnvdL+<+(s7G^CJl4u)PZ8Ek zk;vIZn`0Q3H!e$cZ1_Se+hk=S4VuKy=EN2VDwezL-pGZ4T5bfZpU&{fa2feM&JL&{gVGl|NV0P50|_FWsUR$yei9T9F*_>?!}+kf7Ds99&~US&3)#2&>cAps1Sds7Q9cy^YF^f{Djt=pda~)g2RR8*7%E@Q9l3@7wuSD}}K} zHO))Elp-7F0V3ZS1L@w|@PSFOLBLsh^KEgelfj;4eHIkg(r@M)97v%-o`8?Us_|Qv zRi@*E_9M=+WovC_aQnw&CLVD_>sOQao!tM7_K(MnY27Wk@Z>GpK0dk?mr7~YC)80_ zd-@H!02rXcf^&x~5Q3tL0iz{S)g>8Gy zB8ciJRuP`iux}--h0~BnLp-Kr=bI>vRCis6m@_4tb3q0W~H#QQ{9P@+h&QHnuCK_e6;mrv)!|n;zR&Kaj4E$EF!d zDw^+;)pBD4WSegbPbKcwXa4Q6-Gz&o7h73KS%s)R{p@tI@g6s>{*aiyj3OKBhDIIPXefsSCuit z7-x9Vh*4xJd~U(2^pmwk?e*2vMQSRio`NS31jmmV$!jzY5Hy)VPuDZmu|=bZ%xFPd zEoiIy1a#}r`V=)FmbumvZ(@LZ^Xor;SV&W2$PZh!CK|e_5o>vdoIAuAQmqaPt+pAK zP5bHs55fuwdozDXvjMQWWjrJtcL*K`l5aAjeN@lUk8&zB%w*@O`sG!4U6TPl(%x^j zaTPJgA<{DI)moJJWSklbDup?B*YkQFv`@0@QTqjzk_)erh;YhJ*9m$S>;1T>nOyhC zH$RV9oeMQSP%$Hw@fIXgH-pK3%NOUl1w;JVzEB+F=GWa*X_*L9n9QTBXKaic_p4`( zNtM0+SP;>htmROOA;l=R=b-#9y^j)GPnYvXt5H5>rPM8N=_$g#x^FIfiee&QWuDpq zu_M%iJLQ7n8@}T{eWiKs>D_t{C;+S0=eaxjC}1roid!aqZ-*R}5UCm23-FP8vge8h* zD7`ewdC#b+oQCQ{qjU~pNq?Rz@1yN`Zo@9UVVvjw+~?D$`gkho7bQf!#e4?Tuh1jz z_gxwrn7EYOpszLe@$|K0;|VJk7?=r9{<{XI^CRvGndh=q zy%CaQu>8dA+;_dH@e?yMHTym-N`z2CW%lRR+*N%vH_vtU@$?ZCBRD&#dCsjR*=;|f ztthegs2=*vhjqRFZ)H3Fx)~~881Fy=9+`K2rI^Tr{O%ZXwX?7>w;$7(H(x~X@;w(VrgB7Vw0m(Ri>PLBxzjaSQV#JHJP%BzEmxx*qIz#MH#rI40V(Mx1-;6FR=FxiDxK?yMpcL z{-GLnSA>Vx`}2==xL`gyoLg;)Dqfi7Em!^$2+8RjgDqrHG|Fyb!QvGLx6Q*IFAW-9 zD!cI?BB^(^v$xxi#HuC>FfP$Y4{4j{ZXMhQ_h@tL3KlW5?|&ew#^w?ig*X<}kfeO~ z?0Z0&q+?Enog<&fHd1g+|w* zhzv-A7$<5LKo=UF8}MJY9_kBVnl$J_)TYuUF7V@IbPCY)1qs!rWOb6dn^JCTBTMdr zRwwcxrd1#OcfF?<{T0SMSm`8nAkwMDN(M-F?h=Rrw*}0@>5DEZq#-3r+*h}VX^6`? z_YY!j;BC}m%j|vC27uSq zXvummeOZy}w@Q6hibPfJ)%#){3kWrO0kuuX#z7h(pEmV^Z?Lhk+`s!a2&}P?$)b<^ zghrunRMvK3p_MYE9sg88#zbRwu1NT+?Tm!i`Hzq8fRdw)l0D^3Zg(&J0dKA=O?Dk= zJ~>)bX|4~Yjy}3!-(g>6`|Pu9?y`F8N;&(Y;N38L_ksx3u`ZE}uI1aX)rxTFERaIl zUp2EA?avvJCs}f?&DGV&B`>S0kz8Exv^AueN|gFoC)fs3b#PiOf}65)t;J)I)%|>u z&kisp#Zu?umR)2p8({*ooK5;d9Bv97q!?9|NzVz4B`rQU_g&FD@UZ(-P~18q_~IsR9_pi4iocDA9kax5nje>yS`YX?9}% z;_lzM=Wivl`4j6lFCP(BU9&37Z~tm3BW{1Y)QEqZ&r*)UC$3GUo@i(4%D#h55k9o zN7nV+buWMrUIl@oE{r+4CX*O7XtA&G3YiUBYYxw80l$JEasmo>2vx>=VJH*ZZ zk-SeO6U69CA6lA8{OdloGm&%xj&W2wfbQ`|R;nxkN6YD~MaV&Z!_!v!6plAYc0Hyr z2p4`X6DuEwhj^$k2b&%$JW%)sU$|CElp>lfVXn;q(>qI5TCFtmGAK{7}GXy}}^r+4?D{4f|T}e8HakJ&mL}+pn2Jnz-Av zeZz&7)uWPKI>fd~2#1RK@M6+bqQT+AG(PV3o2R-*d9;eh}agOqQNkjL|Y2EM=? za+ab=4VgiwEwl+ism|B@nYA8ob<%FoQ9!_v*%3!*;|C4rheAWG9BW>&^IsLtm;`2b zp$Q(2fKAW1m)6pwQhYt@ObI3pAR%=cuwNce*{FkrwJ(?8A=KeGWAamIz%`LCno7S) zBYV(@o5auV`|U_`9|&;=TLF&#SmTECHG7=odFV6Q#VE4&4M(TG_^V{suCxsD|FM5S zzF9VS(j#B@1O?=i@&WR@8GDR;20qsZWR;8)EgJHg5QBDFE6;VUJMDSk^M@rIbCw7I z-(Qo-6QJaT903BBKV?|;Q5{%r1&Q;+J_In#R4f(U+p~ks;|{=I_Izn)B+XBU;(aWM zkI!SrAiBh7&qX1E3}2MHwLcLoi-xobY=*3wZX0q*jqcf@Y7lHC!CL!<=?|Uyw`A8} zRWz!YwI4(U9bK=4svcV_>=!3V>?OVo{AtHEBRS+o=;pnbT;?2%}P?dBP`W%($mWHf1w)_G6u1on9yAWU7e5Y)Sqx(sCJFVz# zl=$W&x0bjW;bpa6LMJIicd9+43)XY3i$>RAk8oh0&#uvCCx&$pkFwKj=Tm1;N$C0= z^`P)-BiQC9qg`w$!Xar`{HoWO|Mll+kF<0WQn_Sk@z4NAS8QYV3@%ByDag@ni1%nn~2_#h?TmD z)RyVD5h6h$kDw}*Y0;!G2xX&eeUl_}3QkpXz9Dz#4Gif(L?J(`xiulYME zp6j+qM(2WNKOa0yOrd9&T%&K9vfFo7>;*VG7ITi?lGI0QQcKnyoa%Uuj6-ehlUprM z1{ll9*DN}Blmd)E8@%N;JSB|AGdwvh(lZD?%<4AY8qeQotWIRE(u_6#;%{b_!ST;K??d z6YnDcfpX2skP{Y4(DqbxWCt;V|3wK62a+NUQQ0>xE1W{&JeIgGvb3K|x}TCg9?kE* zU1Dr}g8#U80i;jzJWu)_{<6{kQH`~a`%u)g2SHTi+Z16878HZ=tMf0^xwJ-~h&C3^bxfYt+%I{G zC+TkG&l##t?$Q8z@VA{2*oVBTZTf6bcUbF++rOt?;&oF~FF)Qhp5KNo(aa~Yhg(Yk zz(BRCGO6S=t!HzSN{m;F=Ctpp(x_k?c2qH`ciUgfwG9xY1+BbrNZ^`A<=mO6=)`_-rXpV>UOD%BOyk{Zgbx38u?dMUN!V*(-{1b{wB z5#3?i+^TaAk)l9lSXfPW6p^Ua++%LcmbkSV;|v*wHb4lV6wGDa2mkt`uETuWe~h~h z8nnS~J@EgS;4ePoCrZpXUdjW%VPi_mnA&j%!Ap_emT$oCKfCW&I4dh!&*otDvTJU| z30>(g(*)%lRX9`Xa4N#y!6`thSnak{((7MfmTztoE>rxA9sI|1C6kz}78ZX_3%`5Z zS`b@!j!0ZSE8be2J(3C7HtyTkGQ>ee%CslHO`qIjtjdwrD4x5;MzLRfLUxpBY4kV% z=$jWZUa(!Nv2h;PAwo(#Ku#tbD%gJS-nfR3d3pRsWAR&Uvb&YiQ8sZOFIG{Wg8mtY z#rcx)PE@GiubQ*|rF5dQD}NUzeLoM`sX!Jx96>F)(-P}}GH27^Nr-6LJGdg$kOO8j z-b0iMgLIjtYF4!-4Hy?WE{wL%MdHgUPt+7cq18{}E*Xh;ErrE&j~85H;8M4pTsk~r z4N-=&PC{KR2|Zj6~6?|mMhVniY zJ+zn~nkP=OVwdZu=7}m=pB`0}spx0r&a>I<&J?OokGGlmDWxhIBMj}Sd0lMM|MX5l z7-3FG7P0O#bF2%-J%y!gfg+SOFsWx4bycY}IlJN#m+jV|QCane1xdMW(cUy>gP0U0>r@^1c*#N$barNp|h5p9|}@7O_FJ+!TY-PuL{pQpUnMky_>uj6&+l*XVPcZ)KdgV@e82$DL52dJ5l{w(C z8*O%4&J8|Ydsz5^2?A?gciE`JnQfZ*|BV^F3?2Qn42{vB%ABX50%#Vw&ZjNW=`KzF z;}hs(Ha)4zvnf=F5hb1G`m#Ns@06fov4}0mIE~N_8XSU2>MuX@h zv00bR5fl~w__ap#KpQ^<_unmS(5{~`8d4db=%yIMcwX!3nFYKjnA7#CMQ&q~%9oV# zjmp0I`VDj)cn34pm?<<ZZ%TfJl?-NDIVvZs^zggXF@k+Sc!xoWBHCVwFhIk_LS<$H&F~4BUWv|g2XE%r8pQ%6n8;J)FtBd@ z|0w_el>hJJaIiCJgRi&o|4sb=OHEa7qOAV0{@<^6BUpv~Ulr-Sw!;p4H|5?B3+Zpp z&^DC?=~Xof0Yr(9F7T)MyI0N^b0qHEMvK^G3+w}r%ScURLh(K$$>940AeyT}# z`0b9vea&{-G<=1dpfuH4dE$HSSFbfOC{fvp?`z-^VF7?Zmbi2F`M-_X$ISpxB`Vv@ zO6O!H@e`{O!)#UV+@V-jBqDG~xJD*t227&Mc4ZWp0Sy2LWZP8wa(&H?vnawUclo1? zp_U)RR^zCWQ{fp?l1CDtrQ+(A0*8MP*KCD;iKX3eFuhI$-3{>%F zEFRE*2=Fk$Da%~%k>h=AZ9|Z@n<9KwN&>6gbJuuB8{tMfWRJE01AeA47`KjoyRZQf z(cQ~pc5a5zklilSXn>s)1>e^zl7M~H^S>8-e_h`>zw32>@u53rhUXSQJhb$SbdX6b zz23OwJO(g1tvNFh<8aAwW)i|V3fPaUWFIBvQqgfrZ8%70_7!54E^Zy6fJbm^;A=S@ z^W3jK?F)St^Lg=Mi}`flN9ET^r*|uP(A~kWsufd1MQ9;S}EnW(jL&_ z7LP}!CIal=7knnLpVsyT>^i)ho}3W^RQnVFTS~ufpn&ZJ*lDi?)NZh3(EzMR?U_J< z%X->%}cB)ci|$B+&h8r`*iK5@}Rpt zy+pT)Hu0VFch`^`L&$*0-9-Q3S9)MqkbYAS)?~lKgL&@tPx?Shkw`t-M+x`fWk|>$ z$rR~pzPpF5gTCFMsBcP9-<05PLj8uB~kd0gr8Ui|$(Oemii2kQlaZ&um zV^c$)N~QUpKB_u%z=G=_QXA|TM<+B*NHGu61qxhp;5I%8vN=Yt zh1v7tW2z_#gk!L#T-Q?Z#x5ak+-!*%=84Q~1P+j(DuU;b?6RYi*q=UDXW}qHxH9B2 zA`W$>18Fo@I2tGWO zjO-*!#T;{oxxr<$)eJAA3>5~64!Ywh_3RJ7E1~s*BLQ$ME8XC2atx>y0-U}K08b`j z_hjM`;l$iy&B_|a{zf3Zs=RMO%?}uTV$l7Yv{&#S4!5Efmthzwl5bWEptDf3*gab@^^C9?=_F< zcpJ?#70jY9A#Xqg7af^$JV-_IX_U)?_!tzZLN_OfPP-BY^}bIr`lH^Y4b zz8Td3WCVoF% z&~ZP?l|!t$4iYmzNW=Pfv0AH5rQvh&w|lwC2Q9&yPz@v?J)a-<5(za1C!sc5pl>33 z3fJu(F-Uq%D*ayfJ1SqxT`Ct%1#!_ggAJJfeJ>>D679%vGKqdynrM8TV$Yu<{IX3m zge;A?iB*-}+tIv8Qx4CnInqRl1ypkr?nPpLmkSwt^qQ`ehWO-iFC+}Z65-;3F8@uz z=B)fcvDYuPFwwQ>CJTiOiK|VX$*#7^hQ8_?8;es(7^B4R%X|Wc8#6v801!Z^u-4Fk z7hCQ9Pze*) z1tr;uhGuh>8r+e1*m(3@Y{Yu_K>^MCSP#LO+uqQ86+Iv_Li2C;?F-G{+39o8d=b^$ zo4*m7-8FNN`kk1j^s+a$9`FzEA2mtd8zt{>vjwCsGvY-*vkyF^&MRTVVT)}o^Jhlj z=mGlx|2v8)n@#!1%rzp3x~?qLB_wr>SeP5`iFbl8Gl}wq2+Cdhf_No!Jjq`#wO%~z zrJ}bj6H}SHeJ3Bb?vXj5?I&R7!`7`*X@j79j_^(Hz`DB)v)NVz#A{y&?rvbMPt0E< zsi?M#=-tVyrBMm2`R6uL^T`0Ln*)HypcoDV8L@&o;x5m1#*M~x2wK?KJE*V`8`vva z8c4sN{kp;NWcQoyooAlim`SXd56@(_9RgJk^x~MFW5deKGxT}|fl_!^Ip}?WmVMC_ zx^=R`ZKdH#s=FWISj-!Z$CO#8vo1MNvE$SJK5#NNv)QQjbqy1bBBXbVi6mWY8zyrM zCfLXF%%HCTAo%C<2U{S>c)|4_9Ik@)dLf&zeiU+*268*v$lkd;H!{#+5y2n&$`+fI zs#25PkI1z^fL6GAl2)x`_eTq;s4(33 z!fVfl!}qM^G-LSno07BOtZ1}{T2~>>j2nlqK46AfSUnGKHuzD(JSA2F7dt^2C)8TmUHfvWE-bR2J6bij3}?2R?5t~sv{A;5eNvWcFf9j5g@YRyH|?+W#a_(F z{=rh5;%M>;cOk9B1+`~rzE8D)56ZmP<>6nn zsdj%s1$XAn;Py$k_!SE*Jm5cexEMaTmN;o_YV0#V|2Kck);Rh)lPWeGx}mAfoCkB9 zqr^8JjVJqNn-%|tEf6K9JMNB;a{>;|SeN85Cw7AAU~If7^IoM_aN4SI+G^rd7BqAG zBn93TgD(X$o4HqlPgR?pE+cyIMGQ%1Hb10)dpsuAI2Rg^7jZfP&u2aI8RL0n!~b?X z+ZB)J2N!t|hd zbC~1b8ySbe)&!BPwCu$qk?cyFNPZ0l8FinDWbam^#Kf&7qZZ0(E-PA|O^lnW*hjqNWXrQ7*X588PQAn(l;Zd_ zTQcx2i`e|MaFmo^;IgpEw|?nU1*+n$5?&_pWmk4Dch8;=&_@)>nxw7={1!v&3x3vm zJJ$DWNwT(E2Rr7(TY+$FiL+JUsOnL%PKgx|T$6k!kk5(QH2+;^f z*=b`ja;)mbzxb>XzIPrY+`GpJdyMb1>GSTAV(2&P4gEDA=Ai#f`W)U=IBG(8GF>YI)k(zZR+Tz*MtqBUxSUgos{@c8&&vNNN0yo2=PHhpIs0-EqhjQHwS^i5zJ_wofFm?A-+<>Fa@ zi;gp6CAE~7YV)DYD~HS64R`pe)v8L@He7Qm3+-IcUYSJqZl-$wqz_bX3ZP8oni4JO z#Z5jJ!v4i;i$eTFV~4Er^TQd8n)%^f*1~N*xhM*sM9A8Bu7AP1nWL{HlbX@P$GV^2 za#-5*8I|p|@z?xBN$+ripV6SQ0WVW_Nv9%D_p6wugMYGIqWGG_IlgviMby9N)pdr+ zKm^bM3vk}B*`#*$m8p2OiouU~qGfLd@>cLn{}g0hWuNhBHeo33%QZr?K~sWph^0MK zagCaSr^?-1-^w4Y0T~mk^(Ircj1TTR!75A| zwo^Ez={HpfQnJCYzm41II=U(|XljSBa(<-}y!u-~n?%4K zjjl<7BLN^ywO~x4tYf!J+%f-r)j)`u$)XpBl05OrB{D?Gt_&){?iaNwHWM_6R3o~X z`t##hdv(z`#;OYANRg)kEe6#}1Kc-o9>Tcr!V}itU562X-j)?$GsLWB;ov_?1 zH$OEM_%H;6d zCl|}%1ii_WeS?o;In0!Or48iTAfgL6EP^yVIj`xXYKe#(yP*$R-0lc|S^A|9}Q8NHlN90HG@?c73LB)MXm=dGC8f>+rQM3pz%L z(~k`qS@p+=&lCIn^+BL68*Cr)Y>6Q?E3lJE+;Wkz{r7x2*50{JE#Tu_soPf-Dk$r; zzs0*0?0CFqI@a;NK|55AKDNyM+QJc9t$gY#Y}pkSi&){7@S}UK@-ptz<8nR5QGO&y z=#P&skWimzvhhL#m4(5wD^AZzsPq}si1T+|q)?F5ulJ#Nx-0%2A+^k%D!`J$c^I(1 zLVqslA@(}-M0xlq-R#3Q<6q(4`x&D+%YG2+AVVtv2*Ay0U+3bnEhJwZR=|Kzg;hADz0PJU|8E z8Y~ujeM!UGg^8+be#+tr-|-*c_8$*@pVw#PwlQhoNDS^iN~WBd=zo1ac0|&mSi(}y z$Kb!?;;b>faNCeo`ozVtPXK*Qze8S~^vB_(NAtT}Qln+hh40KqlrWB&vRgOqgMvbs z+@!4679^sW!)Dn4I*sDDrPRhFlDnahl7v5qY6%_5c~SsepH<6so>4HB>#XS5@_%i!tS^+Hg@4WjDrEzuBv* z09Ms%eMX6gXQ&f&4A}O=g?w&ys1^(<#cg~5T^oRP){J!1+#zf2yH`&e4iwkMN?Gf+ zsc3!}sw@?%x|)DD$(u-yzPPK~{R%QttRw( zRF-JsOX$=%!(G0}&F1*9ZUAoP2|A`WEKXq%{f}hVzruQey~WFGEmwNeCXQuBZvszEHJe zQpVX0AlJ7be#{3xENLNzKHr)RfKw?2 zBBr_AmA$LZa>O8>SEc#GIxE20poWK_C)$@weZ+UZTM>-zDisZ{KCh|_tiQW4Ryk~1 zj#Afvr&E)&wv@kikR_0Jek{#(Pz`M-JKxp!&p^mayBEsL7le>mLwX>DOI*~-=M0U^ z3hnadL-%s=G1Y&Z{%_R%ytY60JtLeVTx!q8kJ=c;{roa0RsQzahbk^ydTf1=779-)S#X|g9v?3wBo7(z)0>9ZOb{9YU zWsl$oS1mlx|IhOO)BOKr>yGNQS)B={YZqsK0EM{Za*7B=GVa9SBURT+HwWzi2jU&g z^%D`~Vvg!-KMWeHobRT(D(wqGzHybf&-fO`Q@|2^00*ybITab*xV`-97sZoY9j1m* zrG4?Fo-a__l)KVC(I4LTEL*BZXu8~$AC>c{Igdll(RY)S+inbJ^)J0+V>*ueyQbj= z(X8OlZXfc!=kbHVYxJ8R==c4*Jr65zLwL^sTW+@!nT`Y8p8JX9B2ttz!)O^W%g>9|dF z3q&cE3Nh-KE;(yIFFIAGo`cz5VMTmAfv>24T2dn6FE*c&9H@SGO%e$O{|l zSYmaBI7O6ra+8Sg3O2JK38y^ z7mcFMZtIgQE2=+H)klh`*q{?{?dkmlzyF?S$^CJ1zAi0ag*!;+eBqLj!{BN5re|5{ zskWwdNq$W$*@&T;K}-*7^M%~G)&p40r;u{C72P357H=^UGmCM_Pdh@goyJTdTI{{f zJ+i=T*NRht?+srTW{gVWyZ`I>=-g8vxb>`4i}G{wfF6MQ zvqudPpapc5>-#8ic%4=#ikK!ns}+i^P&Z;HIoGDHh}RGAb~|8?7Xqr?Zqt%`w;5f` zodCBgid*Da_Bg5?WSzsY7q!f)ZBunx0)=^q=QMG+@g`#u33_=Vf%+Q5-N`skrb8UVP%+Rs%?rZy zckmnq6y$?PRbPFAtYOxxt49i7L}OVE;6K^*z6mcDHTrEcle3oU0l;h&J!vrbkI=Sd z&<>sax4U@B_LrL-{5liT(YcCD$YG9-C|BIg)QO2*r97w-Wk=vmr{iG@7OWYo?0lYt zCh^6cl&NO3U7ouIq)d?FM zu@_vOMML}^w=keLu#%lO@kPsEO$!AXIgtQ<*5X%pg%4 zg&18wYV^ZhG_81>j8OT5R>Y5hpVrV~yT)6<_8p3+q1@vp3sH0K+AHNuuPkh6(&#R; zM{nh(t5B49@SNbxsHN&UYnk7tjAM$JUo{*@jYK8 zGsQiZ(NGrWrWPJHyNCS4-bbL{d4f^yhkBh&v~OsEv-7$9FQMtSI1%RG1RJSnzAhSF zyVCRfr(&A+6&~^T)wa>LoNK#6mlFBOxoHSG*?EPEYObw;|8c3fbgUZOy0QF&^g*LW zCp&*k2}*Aw(XgdBO{JM?X#hNOz-M`q1^7GQgXjV(T8NRWhz zYps~%z5aA$3KuB33%4k>9}3g*fk_Jxj;dBTSzS_y0&rAu#$Hm%ru>nz=6X{zG${^% zPwHaktvBYaINvjGO2bdfv?Pq@o5}4dE;IJwV?YzP4g~p6JW#R-g()3zz5WCP*rXuM znqq0z4>{C2M_*7_Uk8F0KlCeVs3;+)c*8dHkmKc*a*=un~M>TbiOX9W&0)u{Q;6NTGsJ5lUppsM*yqZ1QD@gSfK_rN|L7WKW)xQ^p68Llbf zN6Wu?UjyyGe@M)Jb5xr#m!GN~PGc$Leu2egWQotBsvCC~<`wCuAC;zQZmIQLl~%_A zpSx7efgEN7dX!HtQWaRE#HYLHYrWCe@N}6wiLZMz;eDqf$@boVq~R@Z;f$-ttw6t_ zKk{SWQaZOUHi+vw7VygzDY8F0i}q9e75zmdl}mtR!sbwjq%z%uM>%4q?T8W?O!_TH zYMl{BiK-_4Msf5!OBBf*_v^W@$!#Pv9I>2^;#U|lr#|L`gH!TCinvPWz1D7gI{n0Q zKYQqNnXqZjhxxTTO7r6J~WM~8USQd zkQydaIK!2d2m}~?ZckzQtlQKdNlm@fXp73{i>@-+5@+>_eiN@<(68mInF^0vjwi6c zt?{4Rpk@V9v0W2{ize0uv@r@+DP_3mQ95t+C{0FFqn2*OtRj&`l@(HX%8Ex}6&!2m zd|2ZSpCSz%?4d{^a5U9v3n+fz=sYw1*ZHi+u)vL}EG=-0J7zr+6i2+7jAn$!P&4r! zjTeJk8Xl8fcMKxYdP5Qy9WlszyA?TK)pCm`2N3~1oDL-nd)tsXo-7bt@tK-=Sco4$RVL?Oc%CTbd%?rANB0f@NWu(qQJi=Bo@Z57+PCKV%cS0_akd#$+!SXvaiX`pZ!qG5pWVe$1AEDE5cUFq;4V;D*fT>hf&W zg{RaHYKZn_AC}gQ8!{Wg1(QL#^^KJTy`)+8t{6j;DTw&^le|f4nd6ccCLuTgS=3X% zV_)AG?$PSp%ysHiwkkiyqw3E%^m#Y+MqvyEw5a_X)S|%kkh-yE&BLbLu(ZvR<+Gx^$#}z}fKApJQ7J zPQgysv9X0E4An9CdQ*AsFS`l8CXq~yl-XG_u^M3#N8apt`*_awVS)q?UF+GXj)&bj z>c)i(Des_`^d~vPHVW_GC&X#XewZNbt49CfiyyG}QdG6zzvU7>lkECHje_!2OKbb8 z7q^)8T!GD_U8h{BTLLeA(2}h-^$uH?i7U-)j)i-PM@z`B9JOK z_v&;+Ysu>e=qgLT@ENwGe{QFv0OK=YbKrcTCjdFhRrZyX>)pDdT27i_P$ z`6(IaZ7}*i4vKFe?me{ZZ3V`ZeIZ*D2voYWHxIjm0F+}qhtg$je07`B-#lb#!c6|Ke=4T^auw9vhSs5I#_kyTBPU@eXvSuu?1j)tPnyZj9qkz| zv2~BNpEpTFiajbWx=j=)*@K}{t?-xo!E0d_U9wqYMfRkXOferNtY}rT>uM8-qhJV3 zr|)hqTPlDh^66;qX(CJUL%PwRF4~EiMQK-N&0pU#@jaPpBdSi+&tT2?OLQT3=~l`>0}!rQwT+;+Z~#tUEZYD+eALI-}Ni z=;g$8i-McHP(?hgc6CXQr20up~DEgkf{8&&-F9D2!`Lw|}GYBxm>JzH4+VDbjthR*1Ij(`2EwiXgYM6t~%hWW1{C7v?m-<-~Fja?3DlIn?Y zt&uHlnizMnal-Rc}8^#xr#{#sc0Z z3l91R!mDO19X*T%V!Zkb)vFgB3o946daCSw`ajf{oUzKoXSnLDSDior{cpAX9t9Nc z=yX2#Ua`prF}=Qfzo*wO)uQi^@ihu`b@G7UgveSdyWI`g$m*8Q^<9*z!QQ9u+Qp46 zI}fPl{|1RN$tLo_wW^;K5iUgrq}v z@|sp$FRpQZ_Z{jcKAX47f^uvzKf0;+CTpA!iTcocxm^~eD!t&m4iM#ZsDsNifQ8P0 zg+B0K&%=K}`c(W@b*4;E73lN4^<(Wi zspQ_BoCZvPDIr#fwgg^Ne>8x6@U#lKY@pNr5EyCD>BbvK@}eR^<-HI0t8d4F>eJ^{ zrJpZ4gwGd>hf4aBoNUD|Hs9;q%h$%Zz0s8Rj5L5-5v*+3GLKHVMuuQ*Xiq4rDl~F|UqZeJrNPyWn(tJF@Whw*1?S zy>%y#hBnVeRL7**hd!gxwPC-i*F~h?wqI4^n>7qguo?8J2R>9F9#aH%GZ9`?^|SZH zXT%E5QBAfymANf81py*5K=qf7ibKsyiV_kxo}zlmHpC({a~0Ul(HA&3ck7BtX)!dO zd&%4xw#5qGBdsi_9BgQ~bK!S3ksN2?TDHxLtz2dvFT@slBs7puiv0BaxDT^J#PhzA z-Iqkq*gJ`6g?!*xy+v`gGSb%BQzjn82;rlDUj|wDbJlSkI%DQN{ZL3=Qw6w2I1!bc zLkS0U4%}#z7#iAh3qwv1nnmOvRjfNsgnn@dOR~-Nql!mg6tOEhr5q9+;iI87wPIRM zo@1{;nwCrjIrTDk$mRFZDcJI3BC-2jRa)tdYTYu!Nw7qi7bJpZ?oL$o`)lSPB{|ebsUzv<^cg!dp5@yw zr~Pr-uTf9A*4dT*OrXDHMT{5{GpIWlu?>{8=AjX}-gk8txF@pT(EG3z@X+0Wz1K!P`0f zXyr%lXW-E7x*xxGx{ND^I zBGqPc*9*gS=9l4Otoo3#j`&l{4pNY9s3%D@k%Ib4MopWO`F+VYk7W_mEYpb-v_#HgU~I^qlpxx|En$eR8ex zP;h7L0}cl`k8|oFeQ6UPcu}gF>J@k)8C{M!WAtd?kqjM(387-%_hjUI2aCI1f);vj zgG37SA9b31_bEXeuLqjiSJ)I_=0308qi{tI4;P)F^;Zg;+^535Sqt2!!@bSlb8qF~ z?)i=#jh649{w?&mwq?)stA9(+&wVF7ukEtmzg3~S1}#>#aW(eY_b9r5zA*r(O7*9P zeZ`$2xj2|Bkk@j(2M`6E=?nMk9hVty08${18kGQr%G!pyknyv9Wf?y|;VWthh_^~E z+_k8ZX2IAhnUJrfv9yxep*L}?#434Yr?`@6qZBz*Rmm%^V`3v6jZgI|6}IS*7g)-2 z6I+h_H~Ws&Ca*Zf7d-M$R`9KS=Iop4c`pTHS)WX4;C%3}KOQsane_Z`)*YLf-@uVc zV|IRKOf>k~hF6!5Wl{3HUw?YnqQica8KpBT(hZrV4PQG7mygXX2!+%0Hhk;0Df?~k z)@==$*Bid>9W&@13am#pg~l2(Z&*7Y`*!}(F#q4Q^Km-b{Mz)Z?=|dP)USLE>-MRk zq^Hlujr$tLW?aM0ZyXkF-e%RkR%ltnZ0&6dJ6Z|jAE;rL&lERNE;dc7<{z}0t4md zs2q4}vil(P+80U|E*JyG^nMI7<_5doUfXTgN6eiVlkv%hfcB7?<7*F|Ii~g?z*0LJ zu+$znb5iXAsPOX9!6&9M4|}ON!fwdwmRgbnn5S@?trwe+2pAM<3unqi6Tu`kYF+ce zI)DYw&?DKhVn&a_VY6N_fn~kShTdg;uf~ASne#<*+48a3hPtux0QObErNfpD`>J4_Ou~==5hUHDIn1ZAn!>4&z+pJTnje$d zympkdY*CLI>|~IxTgh@Tlb|t;IwpsbU|5Hqwa+()A#-RQ>be={tchrPlcEGY>RvvN z)^^P7Trot|X!d%eS`q}x%iMXtkU0@7b9lvO)~@%!V~j?wn!?=2e@OzvszJ%FUt^zo z^8i@Q4x0P0=4{17DS2_pu9H>3CS2pd(_!i2{eH)(yO?4!exizvE{-SBt8U-W=a_i^ z5}j1${_$`~ITD%jo%~N)kCU0$s5`rlHrFI8gEgLPu(`f%uz4isuGszDL$t|eL$d1+ z+>T-K|5!z7=5RAMTc+P#v;2$7v1|uDmQxTLY>?;h6s{=a<6TCvUW^>OWal_vv}R29 zu<8aou>40>(V&LM;hR19(NFyJgQr$4G)BsjEEM2W3o8Lv`>j_l<`a# zC2PDDhCAkdzcAmomLz=1w<=&~r}pXUhq;ojeso81S4RxgReB~lTuiDbO^ZpjVpVx@ zzK4Y@!$F+GGW!cS`8PK|Qg}0xn$NyD90hlM*n*S|Du(PUI3H2NrViy20hbF)F@*go zE`k7?B!I2B?jsO2oF9$k=6PkdV&Oijgmb^66B{M@PQ9ak)Kt&f=P!wkHm!!Fjbip-r-^fmknW08L#MB&PVtuRdk zaVlF9-OQlmeS&_h>^Fc{J&ns!?i=X%JXX_?t z!g^`KQOTR<=h!p|1M2zQ=XUMMy%DZ2h3hZERg+E_TDjxG_5N_ZBV2FhDnqr$5D5(| zanF+IsTELHXh+qKRqM1ifDUZ9=UX8I#WKhWUbSxP50Z~=z(xa&N4D)cG$l>+-$@0S2!(k;cn{s*RQ8soS`>p`+!c&CsbDP}W! zE~8V4W8bnc&SAO~H-Vm;V8XGnr}{YLlftkOULtQ|F9W z72AYjE8W$z1c$i0TKs1=VTgaaIj^Y#|2p>|sfmPoE6Z{hC`nN^hbk#L26Mo~zy6wX)Tf=>bRA$wCKdaW8{0PBu`J zdEvQEj!yESmw3Jm+q>DPu%BQxng27rwoc`XY6{VsyNww5B)6$*%3fHPTlIy0B+{=N z#zyE;1b+ezW-9-~*UxNo>3~!XE6S_gXiUa<5Bg(kY!9 zVvY#=ACHr5$@AVD-7s}{64JZ4!-e>s_4hsBU%)#V`+)h8CVkD!5t~@Fuj;_w_?e}F zH4!FkCJ|#}xxi)asQvuPGw8)8LCjE*jS?lQ_bfD<^3DFePqVQMAB$8Y%)jG~fMSq9 z(P#Xx%4GW1`LfJLwQiqhid@g*R2YDW+t4l2?7- zs-P(rU?MaPXJHnNnhZBUDnP}I2|Q4Pc6CaXb}jJv=mzZ?RoOXT1t124Frp-&c!Jp$ zvL>U%)%68L7$RAZ{@1?vZ_-$rW2lATIFQB6S-z||ioSyyj1+y9)KDjl67)mzxXjg0 zSC2gOJp(bID6#Rif>CTF8H~0Vxpr-CrSO2cHtUD7VB+sG>E_&Dc|$ayC$~gJ2=k`% zd^Vdevxz&075L1ePHpNNtd<+EFW|N`+R7yl7q|Hi<$i2$=pY5HU%x!;{-S>EtQr_f zHCG?!V0`ZQi#4SDjAz_Q>d05qwchWFs<9Q<{i@lbq#F05??UdI+N@TA-lNg+dCfb> zjrf-Hn(2XQQyJD{0%b2(*Y!ZhwFdMTof9qym`4Gf&rwluF+n(N(i<<1V_SK&B)LtU z2Iqlqdcrr;B#7I%!54%KCiJeK?wDVxeKWNSWwbtx+ZtnhN)CB>pDeY@9?-Je{n~UH zu`=0lfI3X;DYXGX3bCjmd~ssx+09=@|GZp|JbAfN@5;SJX~af1R$4dU_=z8SHR&IK z%523iey4`2ercDXH|WA=R3JZ4rl_m!_mO0k6+(W&fYQ%<^!BTHy07^XU-P8{)cnHV zz1n943@Yc0%yI2ZMHrmr*O>%4M+I;UEl#UF(!5@HQbaKPIA%-~Tv%8~uP zt9asm1I?3m8TynieLypWk8;mKjeWYgiSOn&{>#<&WeHZ?Dks1+1| z3_vW5RJ&jH`>tYJYo)5fH?~EgG5bguJeiMj6?D_pU1mz-^Y6e#PvRL2tUn`sFyX@X zqw8dAGsQQJ0I?r+ReV!dkTaYsqF+nqyBa8JS)htqB3w4j9^0(lVt3(r_Q=Wj`PV-~ zo&hh}k^MN$4sd?XdV0BC`)XTLe?5xW?^HoZ`7DCSlkK3AuCGQVe~#dOl`W$b$L1XVN0%&WlpKZ z;>_r>=9;j3|axM^~&V_@s?eTFoU*miXa_VjWb@EBDWRwZ;z0(iF;>G6IUf z3`a+L(m?wd`6{6L#A$Jqs_KbaRVoo9flsWm%$=GRv1SjNQKpuYhftigff;YFO4* zG|udtIaL0H;HSipS?8m8Ay06d_~29xO9+Ssz8N@GoBUVt7^%I?Wo|4UBYF_LU-d<$ z8rDFlCajcFm_loF?&g}k$-2??JgNaFm_~K>{Me-U?$}-Q`$zVBQtesXbnT3pz&em- z@rmLQY}w53C%qKyShH4~q=4?(OpP463$b6;Z80Iu-I&_Rb~~9{#m+gi*~GMkTB5z*KR{8$&y!sTQ%)ZAVOwd`d)QZk`@{)SyS$h% zP2gMwkyFJK5#daO;KbRYr#brFvHFzc6+=~`eU(DT$*#XczG&>$`=l-QJ6#vtx+!EK zpHZOKC&NttAv8yd6`X}K=XYnAFuLBZT0j;kkZo7=+f!g8H5cp+>l55={lVpAMfE?Y zUk}EPJ$XQoS6ukddyKS-rZ4vRRT0K!D%wv2MlQAy___8(;dj}~$JlJZ%JO9A_w0FW z^32L7cUB4#$MhuG6D_TuT+Q!{st*313~9{%==x9^Md&J7f+)M&g0rZ$S@}E)1$ESy zl>)ZGC`w$ul{d!SL_1V2%nMcLBm8{c6h6CKpGo}?m6!Oc=y>b_8@rD){zR`4$Lge* z&D-M02Qy%$)5_fKQ&c8#?F`W=Y>kAnld8qvb^4Bx=(_e*AKCX!N~^__K4`UG;u_f> zwXZR)*7dPTpjcV5t^_{)l|8f1n7>-XPJ-w2%>99+f2nh~ z#KI&o3(<%C{x%=pCbq43%Pv)mb@2wY4Fd{wwaa9x1&fFIB9O5_r`9&q+q5ImLm93F z5C6uc^o9IoUR*0dfuZAt_{Spr7 z?kFNLIiEsZe-iWR)mv@3U98cNQ_-=8y+Q|vCo@$+`QBUbto ztJJ$isZGijjhZ$nH%-lU^(aDX&kxyT5NF(-u-(06IS}Sh`*1)vSD7R&+tbMUt=nYR z_1krBntb#?zg;J3g9ox*XA5@9%G`HVX_VN(4q*xMLfU>HXn80pJ;lHg`q4YjI^~C9 zJJ-pWlMRp?hn=CW)4=?>Md53xf>8k=M_1x@5s4z*7$PHc&51Y6wKZ>b53PR99@ zQX@AA^-6fLE5Os0o^-1UG-58Nz&^VFXPcqw@44Mn{ja#>D)pj$mB_l~gJE9{Tbo;> z$h?1&?0nPTctU?(H&No@V+T~zRj-^P1jj}()=8P0i7XI^WLR}=ZIcUu3A#42J5(72 zZg%8q)lQ#NdXSeBJZQ8B2nsi1s)iNRZjA=+1?DW6_M|~%;lV|u?Uh+yT?^c5S4!Y@4xp*LV9y;wwfK!cMOZ=~ z+J8|rVi1ig_WOC*+w_qoMYab(h^Ge#qyP3YQwI0wl82zw*r2k(W$v(7d<2>aO~q{m zpnr-!vO}+VlDInut9N>?9{Ty?cHe?|Q?N>9VE;7pLe4f!mT}@Oz{DR_SiNvt|MybE zwhqsJHvTj}7)yAK^Ntl8ZGjg1RL{xU;Zg6W0@d5Ciw$3ANkws-l8s26%U#5cg<(hOX_UCd z)O;!Fiq3Pd{gd~2Wy!89`86hc=#;V1xY-RI-=I0C@uVRZBxm^>FGx=CWy$RtM>fwl zgD%~nkjb;L{JLGuk()}fMF-I3v-#1wG09!|8PDF=neOa;g|2aSYjNCyx_wS7viY!b|Ue zp>7UUS?k*$KcgJ{+;xwBWRIP~c1Ub>F7xFEJ!xO<&6cdc@kqE-H^g7Y4?LhFFDf38 z!SBk<0Py>y0Ka6{tK3N5PZmYl33KpWUc%3^qMk(w**6#L=dEF}_5~tcekh;2L=l=q zMHYH*$6)*Es-jtu`gC@@0=eK$(i(XowvayTG3h-3PIGOa3Q_~TIo;m)ZrcWsHXs=U z8c6R8K)w>l8+&YMWzTEO?YM#`%W`Xaxh&1S#ig&E>h|4`pye^V2|>$3{NLvLWG@b| z-oxZLDvuZlwt@TTmX*{TG+-q(o9wieQM{ytITEpyjH>?qwiHgRkg31S9dqKl#`0!i z|JLwf=||Xo`9>g$1@>iZo7na1#;X2ya4ZLbglEj;c2n}+E-YVB6DAeH~FhJu$L?pCGV(W5X&3^ECZ~f zicjms9@5W{YUL1KxL#!eM2UZ8;(%r%cav9*uza92)03BX1`RGHP$Q2NiJ*|qM^-?`>!PpcIPM=%(YM(+;qA8G$2MmBKb4#sM0B`$3LEF-gOw!U1(8|12 zn7*2#;7c1t0A*(Vcox$r8)&;N=6l#Nb_oPNB+eya9VL#-m$q3hv5V^|Egfn`Ld^6n zoN=A}by0teT|T3(o!%FEV+N?Q!eLjS8ezOn1Je(=)0}U%?eev`t%9_kqgS3vdcNO} zN}gT9WX2mPW4G)2(C6v=>Pw%U8fj`)ybue1uLw~S^{eH(xg3sauY5zesfdN4+CJ@NV1e7d&e$@oT*12~C7zSbnC?aIM=HdFF1fkt+#qw-CSUoyd zJu3Yx@U!66@_+B27?rByc~Xnr8AaEroAqv=fx2gdm{r@Rcl6E3CNGm*bArBI;QLn6 zpX7{VBs2Q&4=eqj*@*pIZ}qlUITqtZ0!kyo{Ib0;;`jYMLL*zTyDo}n(X#%e)~t0P z7DI@QSZq_-(UP!$HjrIn(NFI8ST*6atG;IN)v6{SqsCn_31!x;me~Vc`7K!gQbESt z@(m{HE`zOm3M48WNLQ1cNh@OwrkjMq# z>hhw8Hk$-;qiQff*W9IxB}t$bb)a4qgO!*z0^ET>-;sxE`7kEJKy{UFl8LoYBm7~G zbeNi=W)I8$H6~_1VDOK0`5(eRk@DY+>i5mJwo_Dd2t3E66_6@ufi%C-*YZEhpaAN* zN$4~8`8tr@ti0qHKz<}=yeF)emH5rcAmR(ZEvq?DuCjRWvY@v8r4wziI^cbjWK42gdN+vw7lOoh3!+;EiVHKa?FcFWQjbQIv!f+3kwf@ zo$r!L5!-!YC(Sc0Y2BfvzfKW`pMa-L4)ng~oy@mfGwt^NVgUM^dVDGEX}EPkf9;$n zt;{nqu~{}XvSuevwiXl%L{Px|vOfi4>V4XMy7sNLy;0Fy0%o{m-A@2dH3BHvk+xsyfP z8!*V67S-A~OYyni0Psy`fZ&%!v(u~!482e zqh9s<-I~n>(C!DUWR9w~ze=$w%?ij4z#OY|8)JEiSm=iAG^8&s2iv`}8CKb8FAa4s zkJ6$!)!d=e>g`NO#KMx^zqrllTkf2A*!ez|j6XSJHNc~fXo<-v4f5R6d*dTZI z0LAvFn5&&+hT13p4U{x<69cFOK2uKyHuPsQy#qFo8*n#3B&JNdmvO11GKiSbvffya z8KDdjUe>s$2A8aAa0zRYb{@CKFJWcq&A0uODg{&9fd1Sibcoc_%H!6v0cd? z0y+TAh9a;a0BoA!`Vdt=pe~y@wVVvf=%N~>4IZM#GKT_O4qw*c#RGkf0XG&CR1G{G_U@)TXIMq3gSrQ&(K?Md=ky|TC(dH-Y2^@w2sa4^Y!ws zkF1j<=z7VfZ*`AS=YFE@ft5RN^jFrq04`a-CSK@koms)NeCEyn1pW%i{LYw4rp@*K zLpFs2gh$2)_-NK5iJLpkDleVIke6Z4Y0Ni{6|8dk#_2QiCQ7{iSLNu&jQl-grnoLS zV6b-$kTBcd{8g7h<#fB-PVqVPMq2F)MQLzAzNa>4NApKT!tDa7vEWy!*S|?2BX4+?)#G7jMsbze=7K~Oq7@&dR7-rr+L<`k1i$Mx({PuJU z++6NGPnA$=fhwWhm?}|P*`a&U6U}%Ufku~>DhT`!}= zef76__+79}L5MKCNaoh`+VX7Gp9lL99&2^2pUzApj+U5ua|lSV2D;qMdq{@ELzFB6 zeWO5MDbR0fpK`PS`@cRIe;3E3$|?y=TrpP_oL5@G1e2wzU}3q&F>XTduHIVk%e#V) zXbQrd##qP%?87nzn2P?uPb>^7-St>V`QgezkR%{DSQnO;;2MCLtM<31IVn{X%0!ET z(#rX&)-?+(vX|Ax3$aJ6N_H($no`$S$*xTjDsX^N)=K+W^mb8^k2;0q74^X0YL`P+ z9wo0D#nU)(M0;e)>PvQAMq)?4w^4eEkl$!sVUSVP`e%y?Ovc62v`9Bs|C&sKd<%4z z6(kaiQeo}@Ng-^XN*v~{J0*-LYU30*Kv(uyPX0O;p|mV{^<;a`bKoLb^yS@sz!yN2 zJ(dxZv#3JEA2(i&v2F^J-c`C+2woIgX{-r*Y6hZ%@Lk0<1qgNd{U77g8hQI)n%#(d zsp7w5$|WenWak-%lRSfZv1?GF2k;AgrTBt`jr)n_MybgIQ5=_eZ&zrO{K>NfOOYo+ ztJ1A_)x*#OhTfO4)?O&lq+~WV8Tz#2L_0Nip&GsF69iLc*xjq=$cWAqp0LE`VzvL} z%6F`N-Ke2zx8PI%#DAanLsKG3q(zG;6T7|NZmM3f#_jsmKIV-;NM&y5?AUkl8-V+A zxkt#R=ys_S1`@I3>T+YS47%O+1H5KhA<4@a3HVAEGO4&ze&9mNM3zl;yZ4VDpmM$5 zpn$X1=X&4lc8?8IQj2X>`o4P#t>rEf2&2Tb4sVLN|9aC0PKkw99Ju*9KoYpel(=VK>E*GfV` z#Ymu#IQ0;zBjiWjYZ)Z@PGfObT|GjxYC#|X!-L+_RE(HKj6xP-ncMdq58@h&GuQ;= zrNsY6mD{XNbEwmcN6_^YVz1kMbXz;9Ib@L9$E_VB7oKkcX9imWi2sZ&qt-O{hsJFPvTi>ci0 z*!~t!F>fTtY&s3E!I(&AgWVq+X_HKdJ;Jk3_FYb6<$z^1?F+ zKQDyQ8({Xd){s{+>31Gc0LjdDAY|pD#4+^`0x{Y$;=Nj+2Ii&Ux^!JF3Jk(h;^ls( zM!VgQ1{y}}z7)D4bciuPO_|$F6Vq{3d7;y1T%VKc1JGC``>3*hSg5>hH8HTJaFf){ z-%&*_!LM`%HfPcM68H6%x_c{kEw5PrJ7FLoFLAF@Dpw;#*0HL*b!(kW@N{!a%alEa zeZO8wV4c6!!d$(>>nyw*X73`s%L2vY8jS<-Pqx2CQ-Yd#6U-TQwHx`v7Xi~ zy4{8Y_NFsz*cw193*!1yGHf+uxdBadf0#e6mAb9pHQ<@y@6P zA|atfkdG3l)=0$YUZT;`A)>?^uSsEHZT4rT67>-z7If}WwuwTqGqs=V8u*zf_l{fyRaHO6~XkyWIS z8RK$a%)@d|h<~K_G z@?ZJpw#_&9-Z9qP6OM4*jd_ABX^(6zk8i*>835Ae1hv_WY-%|jf!)4JIg~n(tLnO> z<_Vr@otDm$sL?X1eU&mN*&ShH8E9?5RiQ{!&_)SDQ<-y&H? z$794QiA}$Vkr0Tx+`T)eNVy_w0yx|uND?Ta<|8QKte6r!iu&N^&Tq#LNjR3A|4r&9 zp#MU$^Hy~gfSy*0xOa3S5{SFhBks6>xWhr*WjfOe#1Tvt;+Uer4$Tro5fmA8xl=Bh z*^y)$fcav)jW)cE^mr2{J>J|dH+es}yz~=~zBU4+(-04FMc0=6?8lD?hk+0 zh}WvcYgh|Gy6J~C4fxf*(JXuhnW2>hE<& z^VGw?Mfc~ij^~}2cD0A1ms*=@)YA1@?C&b5T;vec_+Q_H9A+1hLs9+?!tX&pxv)a( z-`ZC!G5Fo*6Um}*%~pMLu%^NaQK7s;F9Cp|yY@BpE)YG+zH>wfp7}sq?1l$N7!U6= zwF6S$wyV6vM=WDHjU(eLLoe;o7e0RdU6$88lH+yNItst>FuizIVjnsz0+8Vx=!2b@vH&oM&I}@ zi&w&dhW*%O`JTlj9@wRKm4E2jrJDY@(V-Wi#yZtlCg${19`8B4txe+;cNX)Djg?rn zQ_jXphaA+(s-4t2`;Kn`1_5R53x!Fnm|~p8;FqCMj#=n&2AFRUbP(^=VuEQX@ISYZN!pW{gz>MY{*Q z2=HFJSIvoe65XSZ)IWkJz)*EwvoLa1*pB>gJ z2XbZn^Q?xj$T><(K0Ouz@j3&O0zRkT3xb9q=NUt(Ac!j)SQec8&AVj!ia(i)Om?ls z14<|lrv<>Unkm`ZSWIT%K?~$utDB;?+0jj z`zuvYa}u|Sa)nKCtK06cD~q`%#+Grigj|7U3`GT^sc{QFEVXRn4LD-C8!Q6)aL;|7 z`wCW-n|h{KzcpHRl+>xoawRss%e0`U1+(H*k z_6e3#$YObYxY5nce}YoxK}azMOYoPR@sJuSiHCT2W`r)&QHWi9n#v!$9mtB)ODy%3 zYg@=NGr$&?bMM~tnH4Dj7V*Edg+*RgR^bbN8RnZsV<{i5V2n)~ZSk}J_=Q{aHp3bQ z7>ej4>a3k2z*xS?AyPQ)D=hGrxz9%yF$pay2-ErLSnMEL#U!oxVI-Tu+h{c+G02iZ z%nrEwPw>nK)RGJRA96 z@zku)u(1V0@CJdT)8%_^8RDHK4={^ zY;CG@ZOe{Q^qpq_^o9|yC$Bz1KRCD{vsgzpWZr4Wd~U0``aY9%9t-QP9XsOh$&Ozb zxMMBs<+-+ToTfoGYA z5SSjS2}}=58LOM>4hwH;+*Z^fHEe0y%OsFu(;+TxH8gvL5hd3Crk~LL@XxW(HCY16 z>b*dTs#d>tJM2tg_L+H}fvL=zPN%XJ-+#|$UbQLmQF`2z&X5hxk11HF2&)DfO*dyN z*7N0>D7OvsuoNTAv&j4JIG3^1)po{A$261bi6zvF_Qwij#O~jjmnnh1=+A<$s@F+KF%z&juetoSq~VYmT4^k-x1g==KsI zKAtAtN=c`?03o?>i>+Yrn3jYaw6rh=Q`WfY%VJ1-Ajb=gyep%f^t`Ft%cNac;1Kqa zM_sdze8GJNxx2pJ zc>nlUA<1bNurWy%_@Bni;x>IdO)h!+3NKFX3)6MsO0OFwCW2kqu}XVM<2fF9#Nmf) zFX=-Idr2Sa_maNF+{Kw*GkA1m%)9|v*A<2j--&wuk{$)F=Ul`Qar*J}a??%zK}e7)P7p+!vDoAv^`6`0tRJmwxt7zA%F~1S_c@ z5Xnb~s>%q3n`k}bVTo4MoXR$)Gl!IC6R-W5d8VFL7DNca*qes%DKk z!#>DQ=68yc4Ab*w1CPl{%sRUX)YQIEL}n~5!f>ls;wRjpR_55ZfKqfKG*-I5eiA%9 zQmo-#fSz_ZJ9wEi4a>-1!(ig znurG)RqfO&=*JW70s6G$d;0AF7el%$*{!AbH-Jr4&Cn;-d0x8^X=#@6tN=YR9=ST+ zmWE}3ZVUALxG``Mw{*rxH|+$_-TMD10z^6h!bkUJ?G&K!g=OFbnoD~qocK;mbDGU5 zA~--`l@~xz+w#8w0oA%IzlsUYlaS!h?L}2vn^2jZ7$lDolugVRgT%NAndQb=Ve^;~ z8=@hgDd7XHOc2R~p(eZjXUw>HFCwH*K?s%D3+69BukSlnG|69{Ab;5}NcP|;SO}wQ zn>%R_(BF5d_wt&>3We$Gib>s?zLo$!c6UF0ZByy+dovT`H4=KixABBX7wPpNE`Xg$ zJ0__I{m@TRhpEvh(bOp%gfdZL$dzis6Kk+z=1^ttv+9`YYU57bLd?WeE=OsVWqAgh z67IEWB?Xk?s-bMpW3kxt2b9^q6Y0pLry4M66QnQHBSl`+Xtk8Bp&2ODxR#}TwK;@t zp8yeq9xrY%`-R@;9a2bdmWbT#cLG;!o24X=U8@_k)_=Xh~NCDrFl#K6w zXBH&8?gyIT+=8xK1=)~OeCeh0sDvE?T1nF!Eq{nJ2nb=9cdKrM5&~X}O4KhOs|m&Y z6dZ30Yd12$HA-A;o7oAnR1+t9tOzl49}2{LD082&S6gpZ$%urF6~bgktXAwEf^S+l zrM6RQ+i1X@ALIzd#b~xBY`k0#vtAX`;TJD0bHbubrM-6Ti-G2oCD82W-)K$+{+S?n zqVn_)Flh?Ra@lmxEKP=byq0poF{=1c6f?{2yLe_f(qJbFlS%qnfF$V~IM55jT@&)O z+IK&yx_!D#LK)@Z?D$Hxf&JT1w0x*39gSo4P_k=XtAbNrRr_xZncNtwM2U%3m8Wpe z)&j~DwN&k%JlcCj@Qnnl5@KaMa0YO;qVf&%j?cMq0F z3oM*TKZx^R_Vh$cFw%Co@Qmw@{9InqTPoP>4zip1z4%M0PPb?iEykGhI_+gQs>N(z z`#TwFI*OR1guidtpDufRvD-kO>TT}_-R}NjC2hryW0bh-r^U-iwl|O%XPTS{tX|{p zf4MIkLt!F%wvJmGPryh-3zqKF%RI24HZy}_QaomF8Owb0k5}Vw64wovaMM>K;GU+Vinf6XpaEO8q}qhZ}J z!#bUIzdgQtFtlGM+OHAqLnDdtJBMAksIlJ0r@BE*kbTyRYIl%fOrLZttXtr=P%F1< zNG0P*&iG7-Da{u{Mx=O(sG(jMEt=`=0;Fy_Lq5|kXL_dNjyCg5m$)Y*rW3&D?dX}V zBd!JUcej2=-F87YZA-3^{pN#IH|KkMGV(w%&H#MNhep&0<4F3cOYYL8OQF-1uZm8g z00?#CFnnvE_qVcwA=$<5)PHy?9p3x%Znu6(^{#v&xcdjCPaLiq|s zB_sgJK>|CS;Yq*s4~GAyH<>S7GRHSHeg(=6*z#VQnUkwo6&6w zC3Y!qvX0{B>nM^wq1>ws%?jo2z3EPIutG*}q`-ptAdheN+S=ZuZ5s>o7ecmj(Z+G1 zd)b-Rkc=#J$bubJ9TEmv4GYR(Y&-_>6Wc59fbG37ViL8db&iGrc4IG4L*Yh_T(_IK zo2WYgx_zNqSiT~_xFA%MYuDq*W5 zUlbID!bs=ogvM!!?`67=cy0P3y{CtCsKrP$QFZH1HvQ&WexuA?_^u7Lr}thPUN*P1k6YmHLgr5HFjh1xdXr$-F%luWqv(=f^VJ|JG;53|2F zQiB89iv=}CXCUEIPL6HI?93h;y(hx#4MvyIgZ^?6t6yHZ?BH~CD0DQ_$TZsbwQNPp zi8q}(ZL@qM@LQ^4x2f?w5nHTQ7mZa7%T2JOEkJj}lxlW6A#UgP63(2~mEj8sz$R(0QSkiZ}LB%xH6jV%& zS23S7hEC`90Fyqa^(HzuQ$2@T(71FZcNQ;a#_DBf%q^*xIV#h>P-sNGY&O7CxA7BD z!>VE{w}c*+czQTa_-S9^iR(Tee1#s2K0uo>fzKM3OjEjKAGEFfFpsuv_v?c;cm&JM z)ovMPS9?#@kc?=6vvGk5O*1!zI3$s8@x~hh5KzxU7w)Tik(jIiN1V4%X{bc z!rQj;>e(uVm*kp)-IGO~K+z&)>*xkN9a?V4V^W!ZAn=xotIO4!N(o9RNIm3h%sIZc zSyelCa&c~dV>k^fdwtdDzVRyU$&nPU69?5 zg5aOTY#XOUeVV|1W#`Q8I|WsdPx7VEtFq-hlh*Bxjhs@8e^ra?9r> zI4gfv+i!aKWp7$+zaQ$+MH}aL$=OZL-L7r*E}TVSFIiEX-IJH=w_csFg-_Uwm z^3fBRWmtX0;jKp`=bo@$+v=l83Xc+(E|iB`@yqk^lVp&=VjxrY8^2Qeg;{8^gTba) z<00v!QKdTliFKa&pHCHjK2-R5SK%k;Rm7jMNovKAZMC~Z;-=#tFUxHU-rQ%8f|q3l zSt%Q=z#pbxR@uOd*RO~o8q-=pMMi@57Px~Vk13u)gud=ZrlF$5K9OdlK%&$;b1U2^ zGy)M;yBD|q6z&bCZ=K)_^aTb)d;?WH@wjs6m$aVf8&WM%V#jBBXry4wRM8%mqLn zmjI{)K2y&}_kzIU*jEZMSR*bv1frS(l$v?aWYC~bwc_GDNJQ1bD=-zw;<0pmvK6WpGGz(@S4KGNNUEB33qn6aBpg^(0 z{BI?rtRCe4TCOUB$OWyH#UH>fg%4`@pstM0)~LE@=(ZO~>%vKHm(br?HmR3*Vt4u* zRn$H&3JL)fgv)MQi5V)!o_U>h2I3SsMTtL;yo(1$o`r7Ixi@~F-+4u$egJY@v6vIbkGzxS0cIzs;baqQ=F9V+ z?zafBmHM%E&^gc+b3CRpTlJQTMJHCnLgxtsQ2rs+I_{@U^=FST)`Ro}(9FJmktlCC zzy1&2L$Pum-XT;)Pc1$Nf8{Bn>Z9`nWD&(5o_<4NQf(Q>=?9#0EFh?5x9l(I!pvK} zZ809*^Y&zZ?l3EC4vX<>3|~fj^gpO4ct7s>xAXA?WUO>EM-zN3)`Vl}Ra2lI+u;>( zI@eMZqpT5J6r}95*mU-Q8lgSECsDG~%zV0viG*wO4Pcm;I&4fCn}WY^(>}?o-sFKs z(!}e>^hm9x^iNv5&!pnrXJ%4P6B=Gg$9X+Ay8H~oxub6Oy^i?WdhKSPl~-V5lKfOb zm`=>ozJyc76?Z78C{~eww4-_!g#-bx;3L@*9eVBeruk%u?>!v`tPgzYP3u%{f<@sp z?b=0l7g5k9xmuy))#ZMPoedbDWl0!)vmBVWx#@O~Z|lviyY(ulbQoyY6X2_C#kRUI z3i~ks&5QxQ>2^~Fc&c{%w?4I?+Z{SksbaX4%8;1Pq&l;Eu6;A7HUHgi@Bp>AwGSdX zU+@!GCOwPwUDR3IERa}!!J!gd?JLZm%iQN(!zf(oi(ET{@Kd(2jtMHENj&XL?u0T~ zoMp(*{d{{4rUS?@VT|cCih<0Y?1U-lOh`8H20&DidPT}XwjqeEK_-^Dg&cZk%0Uuw zj!+SeYZ8_J76M?MnN&{lsw?fL)2CUw^)BoA=7uG7%@Vb`_*Md?pKX5 zkJ3)8iOga2o}*Zzi>tGV^PkdWC$WFEkvR%s`J{O?{mtPVIlO+}zcVC$iE%@(kTOXA z&M;?dkPCSWykWlKS6}1*GjAJLUlcxA@z+AV);~cvJI(Zh*irp%(-kz#Xs4Umil?5G z+sf(zJ&qpnE?6NTaZ_BQQvaW@GKq^0pKY*mgE)4>;|!430jzYUJX>)VHEO?(FiCN$ z@KJ9sWsnBkWE6Cp703jo6IGl#MEXZGA~EX@vgG4}1=AU3U}uHQgg|QT3q^rgGxG&9 zHRCQO71gFSJRP~S?0zw47xbOR#SAxDm#-u~HqW2*j#Rz6DUgLy2GcNr>~-J44>-(C zZO+jX^sb3H;M>i8?j=kjM2P$JE%@nQCR##5iwpy8scQ3ykfnl!$*wc?q}9qzgzC>D zt8rA*nCP%U4I@6kY;-zeyYtMr=Jfpc2RA%7y1HBh-w^Fvovm8)xVio^n0EW)J!K7< z!PU8>>WLEDa_`Pj2i7Re#@w|Ds3`HyJU=I*1WurBCUr|~wQ@X}f4QWH+UrH_!wb}Y z)Rb)1EZ^dm(0x-n^P<*A1f+&ogHK*{|9TT2^pZhZvdySzj@}8tN`S}XaYU#!_E#1(J zEWWmt(aT@h{id?S0nIgYbc++nLRWjXZMN#1$3*;(3DOjrlzy&VKlLX@X%^|E^b3(T zS~jfhkgMNNS7Olj<-$s_sT2<@-QjDsdl78ViJ}>|g%nL3M`D$DH;JIVcVc3-v+BV% zcZ?gMd!Z4~SJKGr-3yJ>`$jT@35d@TCDgc=zSLC1UGo@5)+YWo7Y%^vD-8;)CDGZ* zGP!Cr->@+~umYO<`+Ze$|J+0OfYaSeoP+-U(=HyreSL%h!buD4tYw9J1sQB1aRE>} z@Z30@G;Sl0-$eo3K-x#}qwYC+#55CUp^T|*WXB_RH*d3t0rr32IDiGXr9D{Q+dEhy zg8dtt`>}bKqtC~8_y2hB{ekIX*@89h!hZ>-M?IQ{sZFMWVe4J)OexhEpihxvB*U~v8V18o$S zo-0tuMF_0YLl$p=Rl407n|Wy0*lZ<~e&SG(O_C2!o`cLS(0Kv?kq z%wNCJkH0UynG1?fdQdt8|IuBe0rXXvrbSzs*I)|CCc@2O2`pXb)_Xwv(o7B>X{f;0 z)F|*+O%n`IdI>*;ngB92xi=qOzLx!lFT0Cg>%f&@eD%kl!Ykkp=9?^c%>GFs=Bn?B8Ag3M^t7jdU%zNj;SV>zyt;)DYt0f zTDJw;>ZlIJZ7SK!bBk-J#g2tFsN9v(vKbUF)anxCrLy@=uie(UuaC`5%BNsfO_s=R>LLX1qm)L*(iC){P!pPs5L@8h(NO#~BzG%M1j}1B6jJhkR=o zCE4|gssZp|S>k}-V+L^S2bFtya*ayUl{99`e!o@pg}toq3lBjc9f%UQKO9G3C}}u1 znwgTv^fbe?OoldnO6zsHnHg^C-L=}=hL4fh=1>JMDR@BL?#N2d6h8N;+Z|AHF9k2# zLspJNb+_B0&wK0U@$VPHIm7-EhjV^3$-+5hcYvjtJ1c`q3k-~YF3?leTCZy%`P5qsbNV!}|Q?b0EZ$2#zI!L2!j`U@uZA=+aF@tz6RZ~`}K2|(a z>$iyG=aw%kPb%*W)-?r7ObynkKPFUwKw@Z8n@Ln`r;AWxhi{ z?x3)m+<5=QmZiD%=YWjMjkXH#k2)x^O%WV5RT_8Kiqcd#HOuwZTtZuUvPz&M457Zs~p>#uNuYIAqVHx*R ztQfTYW%f&>ZOB?8cc2ZnaZ;_DnaiyU(c=%&lWgLN`^-K_!jyWD#>CgL0AkI0(p!7~ z0qU>#v+yx4m92^>&F;u@f#h_)d=IyoQR&=w^+}X?ntQiOd7NygK^dpo;)1U`D@?*PjMLafQL%#1!@1>(BYkRE2`SgiLUXt-l z@(*8IWm&6C8$G{quQ|$l%2l^2GWkuO`&4pnTnTxODM*4*xu5vXdy<4Md<~GH`^zkm zrf*LBWBQPffcM37Kw&SS;C_2Ezi!7X7lRk*%k0sYG=l#AEer?}ZJ*>uMZ>W&6cXpx z6z{R~Ynpyl7X(1P=MKc0O-+&rXR|vO5MubMWe0iUZE6fV!P^|czCa{}!~{ty4H14- zv_5mx@a*0<3&GLFDYiJ>4woOIJ&JDF9ziM%3WrOOrh0F2>oDNncij`S8SNH~+r$|l ziLFSR3RwG$&TQK_Id|Jl+E!PzeA>2pgO-oYOP$tcxX#z7I(lzL=r=>Bv0bm*vcj!f@+*d_sJ-vH{oAMiTZ^Vk^8MA)6oTmpluHxy zbWyX-MbOzs(1|YiI@Pvj(A3`Of`8eM_u5w1wERV&0vM_yJM`{dB=sf<4|`wF?_q0u zchnl$#)fE0rGBIuA`V5i2Gxd!2Dnjy~{~NBD-qg6M%*U`m1gNg3lK# z^*->+di>MP$#fn3(|;p8;}3dF=Zp)ihlV~Z`g8`Xgb`2hqv2PRezE@OJAX2q*T;wB z06J;X6vMMLYn!}MD;*qp6$}GF9Y1k@xseV}C_*{Ng`Rdp^YTAkBmX*GuVb#BwULg2 zYJqxV`J5C-bfJHMFzdRcn@YBm=6lb%$k*_R|cfzJFN+TI1uuIY^XpOC{K z<4iD&OLWv=(z;A4(McOjB9RjY6SPJY)4HXtGL;z_1T%7moStk3L8PH^ZIo)LCUGef zA_*x%ln9lm+dd{GXi0?R{r;Y{_Bm%Rp?%-~e?DZNz4zK{J?puzXFY4J1{jeg&DDi9 zLl-qQ)C_%c(l{MMy5*Qn3yvAO;L`80%6g}vV}`ys;gTcalx;@swVW{Fgmd(G*HKl= z8(;NsgDPN}ys%LAyqZo{iE;SHylwxgN7)_^9Q@$0)D~!j+pc?AbH7`<%ei*R2|#yz z(5`TxOb3aPs|G~GYWMm0|=6CmDJtEWSk#ix$u2a-1|5e)B}NZ};N{b$~VZ!|6r zYQL0V7PGI?>HEqH8c=JOAt&pSCl!sHj4|X1r|e+-c=8SEm|w_0oqZFNJNg2_FcFAF z64VW3jTtK6QZQWgzBMNUG<0SBs@HS}4^<}y5&&44WndVr5n=1|X(EN5?K&Dym)x_D zK{vxLho*ILtIr5Hss|O}O(gJ16$711;I0--nbVOoC^hOC=e#yY2c_zj7q4!yb`_1gWC;VYC z?+ydjp|7zy40Y7AZF_Ti$m_SsgL$+C*l=P7k|e30a)aD8T13{}9SXk(Q+5*J@?KH3 zH@*Gbco(S~s@5cd;Z>JsH^*+Y;4Z4elq~kPbDBty_rTaXoOV52wkqPXoc`=)|2i1% z!-5UcABepD6RW%FE;@iSefdOrpFZB#j75$of2|J?uUgxbvu5;b?E^e?rYoE>2~hXEaN{jK5YRLAEZi*s6wy8H&D-2dfCP1I=c#+ejZiUbV|0OCah;(B?F>SglUhQ zhyGeB=?2BJGaKBJC z=V`77{iy_Hn;yfwksaocT9SE-ksy`*Cwx%_JGcuM>(@;E`m26ve+LaA=ji4DJ-%DN zmNSnV&eX4q_|>}ppJ%*zv6srAXyF#WN4OWn+b)(^DVzXI@wT7Y9RVJ9{vgTBas?5; zz6xfN(AaYIGq;e(63$M8 zuf6$&neS%br;AT}*{?|(BeXp;DNe}29W3ZZq;RrnzmOjgo=JxFTg8JwKxr4(0n zo7gVTwwi4^+;;M`Gk(NWhpIh#mtZ(ZO&y7V25f(tXo#y8G5*ml_4aKVnBJ{*Lt@nM zk&O?i#ikN%7c+8H&8VjB{B|)Xj%vISrFN5EcdlyuY16LyGxnNP@FIX#DtJ6O+LbG8x>vjWJW_l7akWQ|Id-H*(aG=fuJd|P zxI$b|nMg(1VL@!|#crtJ2&>t`aJzdI6jXGFlds8U@V;1uB(5^^wD{Es4dDKzo)4pu zaBT{@9ZiXxdzMGPfNdf5wdKQ2je*zJH5PRwK5XIJAiBohf6K4$fy)Xdp5fCsDX{}S z;x38lA99m)*L-6y0AqP~ylrpQnQC{>6s4$zuQh2w*UQA*xm@I;V-lK_(JaIdr!h^a zRM96pw+r_?v&$+sBGtxl>FgN^_1=O@4~y50fBDV&o(?YX3e9PAy5KRl77Raht^Cln z;U0hS(N@yN)G6B-N*!$BJFafM+NAY>1FBpJgb-xc8>ETA?NOy0M=v!P{&GXl4-jR# z=4HP)Omr&}j^4yKP!^H!J!BoeaE0Q7q%4G^(?ZDO>oD(8I~>?9ldvK-8SYC#ooj4gNdUEQQ9{ z-6!NSh@{;qmTKET87iwmjX;?3`c@VDQ8)yZwUsvlfC`1R1 zR}Txr?MFB*PEbRr1MgM^-_EkCT-ElGIISz*TaVv7-v55R;T>x@qBQdx6MA9!SS7q( zqT3)g;$`3Cf&S2(sK>rjq3_f>*Qrl++#G=Eu>f7GtCwiBvlrKBi*bLJRS=bD6xp)_ z9b==68hT%rW1JB@YvAx{Lkn!nD(`%R}BVQQKjEHGG(ErGZ@&CWA%aI!Gg91zdmCkQ*73 zbLFLT@$g~*!AUtxHNVtUg49|FqK3CgZ+WQM?apkweLFLH)%mub6g-8| zwlSEybEW*7*E0jKf`eYS*&Hr$cUQ78X+Xc@68YNQep2 z+(fnZC^`xook*c(&O`{kHym&4C(GwcLaPL{LX*D~zj_Vf&qSIK%NRfSeVGSxMjWl4 z;LbZFqSZaRovS_U+~7CfR$-oNE;RE}uiRKu0O?bR&agi@Yw(UO_$|K zb#mp!<7|rvK9NmOlUd#4wcu-zgrNZ_t#DVf_%C^YY55~yp6#qdrd6x{;HLV4*>VSD zZ%uDcUZ<`9`nP^@;srnbxwifri=+0%xo61}8@pA@7Z=2n2T3|6uiHM}_LRv<|HPw5 zoPS;;%yKc4)veyK-^;DSCjImN8T z40YHn1Hg)WNQ;TDm^uFm%^H$-!3E5ocDfEpHXNBly<*eGHYOv8Xd2;B%H3y zQjO11W&QjBK&Uf}FoeN>^7B@W8I}w{_uaE?rad z#)lV>E9z46f>`Gf_ZEadaq(Xp;7#$nJ- z=04nTr4!0(RaIqHMh#W8T86e*T706(pK3&genqAp+9mi26|%q8cUo zv^h$^s5TZewbFwUd58<2`2OZ`bQZSyn{bqqfT^1yS)v~5G%u8%-3h)mY89m)5Eog` z0MB~7&w8g*%M$5AhQft%k*{`U8_j@q5f{17V=w(Ie^7~ODhQ9fYol2!QtA{^^JG4F z{nwM~jqm4^O4=a&;~@?sSyJV3%{xR4zNyE9I$)UN;O6j%OHhjExgbN%Jm-&BM@IWQ zD2*2TJlkk|U->Lu8LZlszRc0R3p6mFptAWU_+)#KXM%_GAZLR2=Pu6#@2uN=6P&z4 zCK%PX6$%Y6bG{nGr)jG<)9gk#@wQRi#pl*F;9w;`F*_YCjJ3H0MRyqOKj9WVh7(V7 z&MTxelSqKr;R*|wM8-{KMfaL`){>RVo_foDAvxg54b+y48HV8pd zq(^A*Ti;hf2}Fb@Zc4-PJr&HBG|4{k*yTD6$naipcAl4UCMT*xeP(lT>$^`Gs!5M7 zt4SYMag3yO5Cxgs9$h&~)3x6^J-`AAwXv%DBM4E6!ys>McWsOnWxoYi` z=zDmxk0$OssLN;w)ve+Z#wof6u@YZ05kw|1{AXqNZ&bCuneM*%@WH$|vZk+pP!m?=P!8UaVa&$EQjz zY=?mH)QED}GMCuM?wi{DhW9}%edi;#gg)|Sm+rp7I)w~@^vtUo=tXOzpCAvD5OAi> z9?GE$V!xcCGp=!iud`F4aHZ0*t#M0XTuvl3Ph@L!e)*mf&Gnhr&0O+0ynxCyY;=kv z^CT}Grk@3wTdfE-aPs<1+D5_eCjzddkPH{*@B{-6I#`w33OUJn%Md3B#>)^zSu5SK zXMuItl#p;{Yu}A(x-s%0?-4Hb=T^XPMK63$^`os0nVi#BON|)QeB4LJT3B?2!0*>U zx=(2rNMG?H>p2HV34dx&eL4okWADBFUCdn3`?};=y2A~g9{O#H)#g)~=(0TMEs3aR zHkwR*0}F__&ZvZ|Zgun>C~18r^Dpcrm-pOdmAkCa1a|8AoB!1LO8AwL$?p5 z%*u5cf3~>s=MT1nomot%dsfst%o@8;NNatj+?YKLPo$9{$G=|nNQI-cynvyCR~F0+zF zJHCIno3NX~yKKp}di#!~P3(i|n)C!XfJOEX85r8Mz|={4LWQ2qHn1jC>bKc#z?IsO zDvi%QrFn`QpALF`%1_E+b^ig05c}xHzTgH=-R*e?uoec^3;P}9B5vWw2B>j|)TJ!i za35lLFsRIN6b<`_5c{G=Z_b925mY;>j9IknlDP zP#lQ<2nIkm&;Wgzf%p^Iu^cFof5R>kFP{LTEMspg-i$6}Kmf83|X zLCL9y&4B99vTuVGQ7Q){UHuAtDsLDPom7A^m?Xsp#+FA`LZx`GluAO^j9LaB7B1z9GT9$-F{Kw-|T)_=0~W+ z)(x7{Z<+(2{O6z24s`t`b;EbP=|**+!=6NG?CSP9p)Vi+1p8g1w_Ur92fEpAkEbj> zo9k-Oc`C!{HqsPzyP5nSdpUo$Z`b#{A5&9$ktsrV^~ilMm}Ah<&vF zVLI!^`=!D@nt=1Xw{ji^sv}w6q8gD@QzrQRCA%n@*?Y2#5Eb#PX~vzfL#aCAps6d1&vgoTN?iqP|HQOB zwgg#qi5W&Evy=n2eKjgI-4A}D`I_L#0a~5g$~5PFbgFzB zj)niTUnlk@8`McL%blrTCvp^$|8a4I$0jnWrh057m{7^b#sk;q!4_d7!g5gZy`f;` zL-}g1tA>JGZgfob7hw4K58kC}&V%8N&pixptE(CSLQ7Lgd2onN8btPbQ4`3wvhMUN z4-d$z>c#B^AKjUrt*Ys8ebvBM-TLzGbzj?;v#aRKx1+wuJAIifQ|W>E`MrC>J+wUQ zL7!!A!QJ6pP3T1ZrCf+J^Q84#5{^t5%O6P38TaiX#XH~v(aKAHc>x%w>g zuDiVHF0Z=FGA@=knR!9Kf|3WmKck@YUrO~d&Bh?8LNZ3waUE?Fb#xjIE;Jh&6czkg zahKe1xoJiISP~0PyyN|B+(jaV$$aKA_TqKFCCM6zg%iuvj^^yaHu59`jA~*hMz_IL z<_HUoO!a^zdj*WMAUitmRY=K!KdskNx%a)-q6wXX%$c8o5gd{6iS!Y;W|7x$1X?9> ze%J-DNe(Zb0$2Fm}p^BuY3AQ0_p7(7e`XhX{e<|-?PfX9lQ>% z=*lcTqi)C1-W?5!7QKPF2ud~$nW5?JM^>Orq7Ow`=Dw}#(l1t%|N z2@hLujM?;LP3oDN6#p)_WT}lpNR=iPY7;{@#DggkN_ewgV*vZqT*mFQk{CAo=sS{R zhR}0gIO|Q<2XHPiW3n;c_P!i6sPJfR!f|ChS#E83YYOCb6yCb&S5e5R>5Oc&sR@_K z0!>ZFsdrV;v`;nDKJlwQRP94QiBEo0KbY^)X@29!q-y#XvY}0X=06(UR5Lr-^v@{0 zCcL*DZhTMv0sH6w*=zhOkCN3P7NBXB0iZY?`*ecE1kQ)!UVC0_mOriX3NQV%%E6J@ zWU~WQf2?ymX>KpAjIQR3VCXpG=GKL?xXqtg@g}zfs5H6qI5qr&=EA-_=nTZk#1%-W zxaI-XBQM^vvwE`c@;^pmQFP35u~!tIHa%JLl@kl-9A(K2hs$gle|TLw7PAhq4zr`l zreW~ohDVVtr+2#bKsqHn{ThID>kT6H)V-LvG8L(C*PcdvL2T!Poebp7>a;xX_y=vL zOgl&kGy61;pyc=mMJybx*AjWe+8wm8{_}z?vHIVaC04zg0~^T8d}2AhX~a5g+y9YR z`ZgSYb&goKvnVY*i3boX%j20coG`ghOb2$Hu*Jh%zUG_opHG@L zJ^CrTyzK67IRkEq6PBC^w(|dV=zVs#Sy!qK^)kXM5Pn#)oCiP0EnISyUz7nH^PW zLHgL$)jn}9@FovND-37v;e5_WpPBpal~WKqa@rpqex!Z}tKPt3k78q)2LWy|R{aRy zxM-ExpGwERc|GgRGw9Mi+|v2my?RH(q1(QChkX9ksyOvZ;`7c#pOtdmwYYD=7h5F; zt|Uy)so`JHVxo1EoHWkz$!qHCkl4COeq7@+sV$qPluo%vHSs_mSdOlY;8Q$EZ*iy_ zzc+CcpEsiK*@tTMUaz~kBeojG96*P*f-rARW-+Nv9yODMA#D7$@s@0NxHdo30kWMN z*0_HJI>QZ=VB}xr{HLy1nr0~fx-Qa@b%r~bnjrl1PSIGVS+Vi)=!-So=E6qIxMguC z0KTr`{}RRB?PcPve7oq3kFV+*S|kftdC^>SY$%s$?h?p;{ddqXfScmu#tDft>e#|w zTUbtz4psS8?DN;(7{ z)|g57gdLG2i8J1HMroT;1 zw6YVtK8n;tj|9XU?z%sxDMngVQMj{rW$~w`|7&H@g~y9dS?Vl)9*>_faU;;?OG43* z9;HOxdU1tGBO?(4`{8R%d>O>9xGS;?Q6=aU4fZhRR=a_R97zI2%?Vf4xqD^jhTw*E;?|>&K^lUoV4L=FSK( zdDkKhPHEx(2#xZx_@hqW)a12&I`60IZ8VB$W~pWW9@Voc+xJx;7%(;WS-Y#wv4B-q4%^0|8Sw4>((_U9QY5aNb~#d8XI>S0k=xeSN-!>zP$_W#h(8;jiyf zZBk$evI#H>1)~E`S9hM~v=?>4L2N~XzYq-h)-HXhRLYCoI(W=-#>|*Yi6}N7n7<0p z;f`cM2v)d|Jb8XF^w7TGt}O*NScU%Dr0I?;XtU1ZrJoCK&F8$YA0&e?7EEdpo!qNg z_L3aY+x-J`SL|@)ZQRUz8!wbVCxhEG(I?RT@~o!u@wsENd54W{4%gIJL`t7@P#YR^$nFH+%&W<(~SLz71CTtgS#*29u_V$6yrx zho#dnrS}(re!!W1zzu8slYdpe*wyqW77HXXc`%bmI#2KvWjHte_Z!LBD&Z~JCP3$% zAcewHl@ss)4`+&pMteXZ_% zC-3(P3&kni%N*kGB?aJwR-|u<@ewQ`f^+ubBL<`M7aviquB3;2>kN&AFDV5T-{NVh zo&r>r#o5hVQ%Qa1A_;TqNmAu6yIdpPWt}TMZfgVzHjFr^!@ki0%4BvmP-9J-v^PW1 z*}5R&Eoy;3$%Qi?QFt?JhF(7rj{R{~!n^USdI`VQ${$F`A4tq6u2#?q|A_j*aEKt) z%pI~NEiT#p{#S3Abek-}#TsaUj|%Dd>O@LZ)EL)EVC?5_S@Oa!>{9YeU3gQfGVnAJ zwQ%Cf6=q1ap9DN4BQ6!+44w$N)`NRNH<`^NbPEEa+wiLs=$(>@Hlx1|(kQugO^e~^ zTqTm}AMBrD%kO3`9b;=#!qdKV9jg?C#ufC*92;e1&_$ru*&aCAcshfhx9dr!C@B%cVJ@uDAW$IIb(0p|-cu z=Q_hId4Bg2bfT7SMtZqUJJ^jE^jKK^1NFkoUi;h#2hEI;v7LcXlP=lmD>!QCi;XN5 z@40HS8MD$tIrOZ_swKF1X5ib^UuugG4G#`HEGw%`{nQ&TS${w=Y-=)Dv_Y)P-^tJiMb z6VZJal3ON%$+Pt|g=7x^i=8h!Sznq&c!xLJ^O&ALM)j70)H#D+ESBV$lbBCoe8_ei z_7TnRQC&K=*Xb4{JCI^QtzsJFImNzQC7&Sjx1wZ_Ja{N`I;F!2@J8qJ*`kI!zMI}1 zelR(IBPdK4J*-Q%>Z!dIjTopJ2JD+#!W164;jL&O-UC75J+;WxLyT!9Q#pNszv|B$ zQ)B|6a!9G{4_pM^ zPLgiN88c+~6w7qcR{BcI2;pt#wy}b|YoX{>_zSA(d@J1hIBL5r&(m-kE=LdZ&-Qcv z26BEb15K1$y?4}6ayU0Rx2(?O|G-b3TgF`%x9t8MBe(3aInFJ6T!d2<&Mk|#-M|Cq z#x(B3RNYI9s)xXRHS)Lp#=abc=s>kCaGb)sKex&tL^B#ENv!^fmrOIGQUH7`NY@3vNWS(;3QvmvEE z4kz~Ok^zf-LS+vav<`V;x0y0_bEA~oxu`+ySXQd_HnWe}W@9vQ6kK7NQ$JvX*nd8k z%z?Y`h@n|k*SMX&tse9e4n2`YeN2s%7!p2inN`?!wm+^r+8D7!k_k#MoW zFAtR};9$s*(ZQ?Wzd~5NpWnhwh8TpCV|?TGaP_=={I`e8y4;5^*1%DZWj%pj`02vS z@de=cbK!k>NoNvO85dOM7^&14>D{%Ck+|!^NN4qr7-_=&VkBqI**~TF5C+s$?cp#F zQyDx`!7+FHcexJ_5R5vu#6g#@e~jO+kgoYJVI0007#9>rFuw3dgV6+CFb*az;K00L zu0v%6W?Ps0@XDhB^QQu{n>^mo13po&2m0>*sCV@3n+0vK1Fb4u^lTkYCHz#$Mm+4! z(PRsms6iKq_ zPLQKjWbgl2;|5zrc7PB95KN!ZVjbVA=FdKq7h#B-gj1J?B9Vt^sP$v}y>R&b466SY^ELe5Z--TiAna-@23A31T!lv=L8dfMKh{0?uPfTG~ zQ;SObKzoCF!Dc-R+2D*`)T2mfJTjO|L#Nf zbu`BzHEYuk?hsc8u_^bvu%L_97SVjT&CI<0yEPZ*NSb!1&%!TlpHd9-NCqI=%;eF5 zb0K)t^e^5u=*K&PA{?_IKLg*;BK)3|cYK%mDfW-)iP)Xj<}F?Lu37`jD0ZQmPIa48 zD?G`ahTsG@T~c?VG>(SF!K17Bn1s0>BvNVpOr$3-(S`O)(__nd)Bh214x0~7>c4on z&fr3%BcV+VFYo*~!3xkD8{k7cg6Ku=SNOvtAlp?T;p^M7egZpvawF?$qHBo_lHvR1Nx@ra))VDQD#8x( z``xcj3vW=qFp=_<4+sBBHS%0zv7_}Zg^*jghJsW=>F~HQpO}I({;t-GGQFsCG&J9W z9MI(N#3R`?ma#Qs^CQh$8`iCE`8ZMKWt`{X@>44GtkPPxMpq_Wqn=kaklx)hq2w}( zq2QYc7No?3+u-=g)J)_=Dk3>W00c!R)GAAc?nfb9@{cw;c{SXW>ci$JKqqX}Yj9#; zb5oZcsRXh8Zd3|^moF{G6nFAz#GPQ%&G_m^_`xZw42iyAdM&5Olh}jnY79 zw_1hf@X)%Hi{^GI$8hwUim*6cQa5fDZyO2cYPWz1=b!P*c-tZJ z$L5`)?Q3M$D zg_mHRbQvgYgfoOu_51Nq@ATzlJ59neY!YSZ zqS$e=@OCBxg9VegQ~h~gQdg@D`eb>nil?Wnl_;g# zLtUh%Zos-FQa-pBK2@>a>oz7{+!tfvD9U|8ek9{?g`eZeU)aqBP=wtvHufcpfd?bg zTMTbq=Tvhk_u94WzR8tIIp#sW>^Ivw;ir9jtyTp3#bq4pt7_kUZ~eUqMY*U6}}p6wFI%+WJS` zOUW%|Zyy0PogEHEokQ_qtLGV@N6P+ZV=r$$A@wHP8 zDkOUoZ~IG3&*iO+snmnyKs^xh)V-jnv;Ftn601JGOeatLZH#AANd_eTE&~dlaT0}VkM1S1S z$guA#!&L-fZarQiAZ@s7jj#X0ffF8x$f_fNBmWM~RxOp>_L#AdbA+Nv^UI8#U`%`G zS~eP(rDK#(Ec}J{?(YDUgJkn;(bVNkM={f~ScOe5s$tVdWoj5|!v&uipnl~!$X#N! zM2lrnpyc7XMy0Hc$&9~#QHgL6k+3-Yct7>nJ;{vHz$}Oz@EJ}P&x{U3mo$wM?=7?bi>{?C zH}3-2Os{>W^{Rbra(AiDQE`>n9-3}4WvGtor3VwfsSt-K45?cA1Cc9zjFX>b-@n~I*$qN zdsDUI8wZ0&AKzyy|Iz?l25~HA2YNbHTh>D0h$2<}E zpa4F|oU9iNw43(LjTV|p*kxrz-{CFmCJZMjdSq&GX3?jcHjQH8*r)pELvtLSVe1gE zv_ z?~=ztCD!zY>TJ`y?%G?^&o20{ntr2{rVn#Xr;F~o7fJ*r+mC*a6*S#!Ll?;}f(4h?KA380BddPB*(|h$p_qXF-wRX5J=?NT|GjfD%#*tJ#nlfUR24@}ih{$k5`TLHhPW=vv(;(S}7Q- zL}E8L8WauNM!_O@#8kA>h{D6h%4yOJPqdkHm7_c6y)tu)!ehM6e|8EDJOWdSO-i?9 z7xD9~klRnPZ7er-c3t=GcSB;yKi&`$m6Gz?-LpuHC(pu{==NzhyoUE4gy6hFkjO=0 z^5QQe%l&>OCrfBHvtJ47PUg&lM%BVbLju^szbto%;0|?3thdm0amc?P0A~qhNja9Aa)DEJT*>T zR6a-1;(tnkh_7uEFPWtvT010~y#E{WIXKWSS|o&;cqmXK{sFTKlLX={>kUzT3zfS> zj)Z0UrDSdbipKFf&2BPSVM#3iT z)E&fbc}tiw!S}khILvJO5+{l8I9*e_J=bnmh$Ke>Y3Dp7d>@mJYI0{@nw-3lIDbwBLqbPWg8C zS1u$8G(SJZ^(zGf0XYOUIf@N3gcN<-5F&HL^U_cpE2~?E=fIiO3kM=Wx97*#%^&Je zsUGv$#yyEjqqeXfzGsJyTI?s`7zwTSagft`P)v$$1Zb{ zkW)M&R7DdW=F;Lh;%i;8Op6YS*)H%%bioR#OvOE{K`K%{8o3%FNv70 zf+*pj*V#;&xqiC22&j~Y7n}}jFB9%)_LIcWrI)h&#Ggh7Fe6Z@+nO|p1H#l+ZiYO}OM~hYkGn#u&jY(%eD+XX;+P2nrj+@i(905J0z0A9)^xXQ-8; zpJgKmuj z)Px3XK!FJ?WWtfEqB8P3dPXJ=Jam=O5>~T0zi7*2zY@H=1_fZqEbo9{s0e&~gIgY6 z5PPvQ0y-KkgtuC%s#$A~rDk=w#eustBa`jHHT@Tuuh=`RR}6EoB2Xr0Ur+6DayfGG zVPvMWBA=5F)2E9CNiX?W*cOF{Z`5m@<_a5JVoE?MymkCfSR)k$8sH2QhSKoZel8WJ z%)yv-W=clyq^`=*gb2kr&uEet8xgQ(5 zl@j4UzYVyjb^|wWJ{fo~Jh_`a0H8|a7=9RxoKIsU%CZ=`(~OWaqjK;mmnD?El-*LK z&c6|!LGzv0=Cv0vyC?f^^Vb^-p%5wLQeLV1%4g|{3#Y4>)DAsDrOeTzxl^V9hF=}_ z@$+(civFn!vS|fj`Xv->58s&ToL;Mu{A(T(CYWM^%mGau=ERNSDindNZ~ZnlBcas4t(N%BR=6{qulUMc};D%*c_giR5Ncw{fwUaLPDr^{b~C+ zCcMZ?W)Y`m^KQ`t`cT|^ANJ1nfp64#V1Mn79PIX)!9L+vS=cG+Lp015sr8!lWI?P= z7n6I@pf(H+-qFM$RiZ&P?IksuJBc_RU^4iw@7fxVf@28Nysb0?mk{a0wLxrY|GTKh z-PVAn+2VhuB`=fe#{x_BYX=*lZI-TrwingEyi!SZrppCW+LqTj@a5gqMR3>|io)1x ztF#BzKR(t`y@m{hF@)EynWN|f0Jc-!HU?0qYZJk+W$7We?oV*>v*=L4Xy$S7GS>W? z1_j-*U)=787zm`b38ok?Tp)B$lG|^Ag3*QgfgaPMhtaAQ4(P9@;XXC3DTRm;0}^3C zm1NX#L_ooDnK){txf*_6H9f_?6{qYW4xyw;HoGO%R^V#HlXuIRB3XpZ6t7;d3YBG( z9&0b#T6n3=X2${M1!XMX7*Ko{)PE}8cCAedvoAt0q8JCU>BL0(;=&{#?lv-Abk%n? z6L);!D9!c_R0FAR@g})tP5P+9k?8^F@Sb&hyytuvZC+WEI=ayG&=#B)Squ~yvEdbr zT^=fL(T#SO@!WgKWY4{@QgQgN2Zcs&fl~-qy6A&vrLIakb+K=Zz5hK~)p)E}L6@Rn zMZ&YSBX0CIJ!O{KWGUl7;mhf#8B6pmc+f7KZ8*`_y+?Vt>-yI=g?+#64wFK3BxPw- zG{WPka{U~An@Z2;k}mqichvbuJGeo))33?;nWu%@!>g|9sZ_%!N!;vQAqkRm^74az zVbpI66!Mm585Es9!+>C`M5HRgdG3&WBxUSsnAg@J$u z{7n2eaTJ`_&8aEsbY@pfn>e;v38q5;CMw|1JzNmohoySS-hJ05Qcu-TxX|ujWnj8- zlukQ*HT=x3i+Qq!UwEc;-^QV1QVX~XU$OT~GK&eUD9to;5kFXep>>sNMob+(K%q>C zN0e>&cY4yIC&7RTMbaxiLB%NzxPdLd8KZ~qb-Dx5D%9IbDGRnlXYHleciNv?3MA9l zYLESCiCMr|y7aJsE8BV!YxsPaz92)M5}jiQk?@AIUIM@8R|voT%0X{`0WIB1OsqKb z0~G|f4Z`hfBOPw_HdAJAV#hcL4(k(^{{(S=LjO7`q{d$_chr%YMAvB*&PoGv|3cvJ7+)VXiQ^!m*iy?q0{ zMPRAj30qtTZl!9Uc^(tHT{vP_nByO8`j_>c^&{s$2P4a8IcLezi#KyV6XVNL(5gRC zFyxx`mf~$68OEbg2OiI_juZ(R1redBy!3|OByvPhB?)v=xal!RdH0};_cG}pk@xbO zi=FrKE4Af8ASA|b$QZD_s+4_^0U}|g@%(mo$hMm!dd19$=n7<;y1d~W?+s{Yi!wq} z_<}42aGh@t-@C$*euW^9j@MzLbiChZMn;=g1>slwxO&VQR*5NR>yvIkUCMF+$C1%^ zn6>(*yMvX%+|1*hU zSl(3(9l8^xnP=rMBZk!y!{hlh!f$2{Z`#9;T6^hs9!Io?&-GFwT(UDjT#xGN%5TZ? zdI4ts`S)c`Ti29{Z20G5G5P0qRSpIB`cpndz5nfHal92xmRIU3Ci>zCed}4SE|2AQ zF`X@k*=0%+cT)M^aC~(1$OIehqYsr$^BFE!i~!4nH36c}yVEoO98toQrnnx1Eco zy+rjMNX$R0Fc1=D$_UKm`qrAe1;FTml7}x=Yi$aHJ~VAKQ&JSp5o^YG+pl_t03T_3%ZBX6D-@1FxLHK`Mvrv)!n zdrxZwo>qEzg@`ZBxvRk^U&3LP-iCaQus9 z;p{_UJPUl^$}bK<3vaY1pW|Ol<(Hg`oe?!Va(P8~krnF5ylm1A>B4h(k~z$7x5(!s z1FRb#y*Og?Tz>hD5g*|;s#C`0W6s5Tu2#>#S(4ks^rb!f*&a6a@-&?FYn#CN`3^vT zC&@}(?U~{YlZZEzNd;gT^bd?$;l=)X9V4y#ZZf~)tC7s_)hLjkyURcKB(ighihs*i{*e^l60P}x&_7--^>OV`%Y+Ymgj{Y+}i2k!Hd{<>s zW`3y5TiZAr7)^CbFBn^vWIV%=#S2*7#7Mwo{%1_>MZm5%mh%;Soq#>IXP$s9i-s}? zSPfawBhw`_dG7>_IjAJ>Yf?vilYq^?Q1A(#zGvp9eEV)EW7by-dDtv#HXKn`?HLaR zw^rc8nDu$;y()T--Y{dp=?W1>-m?r7R8BC{$CRbuT2A$tF-`4<{2CKh3*ELQQkVp?(JBIVg7reJ+V(2Q3?(?GobvWT4_KBSEr8NWb>|aQH z{#s(e`oj}@eVpjSy^KTZ#hQWaS))-sQ_7`dG=Dabt$bf)|JyCcq*f&SMtyrNPXs%a zs$f}SASb93G?lMc8J^sS5fDf*rP&QBdmkQ2t5o==CGz(Z%9^?A0Cj-xQO(|X+7dLU z0_R@mDHKG5Z*kIUya%}lCP%fAK}a}*aQz%y<97{tA! zsXnM=lxFvgmj!)CFC;zdun78|Anuq4qJ3*j^bh>D&ZOzZjH}l9UfL2=6@KIUFm67D`sbqxg@tRp#Cj9ptIPFwAV!5xvGLJIcNB z>qxdx?55hnp*MT7$yZ#nTaHYSaO?JPH(VPjvAk)%@W>{;)xnQUZHlo&Gn z%Sm!9uc7ip+QxSzJebpvsLD8RRP$dR}cusI&jo#QfI7Tl#_A*;t~U`qJ>L zy&byZmwcK!hasCstTe$e3O+EWcO(ybF+%d;=Q$*=?t)~K%An}F24Rv29Bu%ZlpAmy z6XMEMu`F>nmmmSc*8j}YD2K2U>~m){JR#=Tq3+0!2yw=)MhM$}NQ6*7`mq1kh57hU zt+nBjAy8vgj}|^YzXz$`oCQh#Vkl`3hj*!}Jsi~KKK$Nxpjs(W5vqIRXG@=+yrw~V zcD!upc!AN3J4cKbjXy>7NY{?HP}(X(W27;hexI&q#+#^_S^fq;H%j)jK);{4D-%m& zZf!f2MgsjH_B--NoM#m6)#6WnA~t587OXoS``hr8wjX;@ZPkef>ha{xf86IqUihIC z0ZYjo1QhAm+q)S4%P4l}Ct5#)#?q&NP@hO`M0r0j{o#Vn7TyoweR#xRi0}q?k1W>^ z-u14+X8ArCaI^glz|G8^y^tr#~F>d$$Yn;U{6jlo0 zy>!v;J3~iYqH`>SNh*+4fgjIm3SvLg?KbN~>?H$WV>H6YdS!=2gOnL-=~GSmija%N z`TMFqq~4ebD$KNzdkyW*Qt#2b{c6(N9HXZ1V8aG2RdI@Ak_`D{ewkAPPapCwM;3^g zXx9jc7K0Ca^Y&VB0S8tJ-wDwl%xiF`Nr$J@B-~W5P(BLBHr%_cFwwS2+vr1ftHmiB z0CuKe?9)!q6^ADgx>DWsLfd@GMsX~ChMhJvw=NX+Ev?4q^_WXiLoUlX!&J_E1%^}n zfIV!$3Vb@3YfyadBu(U@EY-GFR2ElHX)I?M-A^O|u#z2Mg!D{0wR?zU(+Ie;(`vx5{X!$FHIOIfwQL@nO zvy$)C2@-rl1#8qmSep-t@pw>l?n1?xq0hk|M64GSZM{e>5@)`3M|r>Q5Sg|@A;~Wa zBGFI3BkGEr&_&~45L6s4@|o&lVLbt#QDM!i6Lp^jK>7geO>;3LZpw7ygqM6);uIAs z6%3g8lqk)jpzzdU1$Lv2zpZWn@!Xj1!HGLyS)!0d#6w}GGvY)ba|r=SHxh>wa)KQTjHB7N-&{bt}Q8A_yYmP94e57-@(M9Hz5ZcHCpmPqYU?)H2%F|7|s@uGaoEzg9(( zNGD7Ap8VKu--P2Y7SSd2ih`KNg9XgHrvGj%G}BR#nVSopBx75N!6VLO_`)Jv%GmC0 zOI*K6Ke&zlnc}Nu%gaPo>dzJxKvo2&w;-;xa=5!MXOc*yXE>&D=RPIU4?3oK#4!!a zu;+=AoPC=}4bEqp4iMp)rc_J=H;#`u69!Vqq+8PCc?aegNJX;@q^1PAC6NE?0!Ld{ z!ZDD+(uKC~H})(gh>UBp9I&95QhBtU>Y|%nc`NAlO*qwabOca%Npl{tlc%XC1PPnQ zi>lz$ucB{p2<&LAcDZw17U|#xIWqvrz)VVm>;Uvx(wjX<7tOy2k0*%jRq|*-=N#KT zvTc^Wgvlg*5;7w~x@6D$DLM36cLab8jsCu|1zK+RG#n$YsrZ5*+&ejx3WoM9z-Ib8QibHsMUV?V|uQX&_Br*Ow@zaeUHeMn^lE zO!b;T8{jcZS8WVF&90l4gN{4z6FT&kH6QG0?7#b8z{SdCzmpjU{XbT%hW>>gbVYxS zwO4c~m(H7A!@kYV->8-@051FgkvVstC=|z%I~a5J(sJxJtyM}FU8l?cf)DC)+TW5Y z{Cr^Gan1y({2`PkTi0UjZ7Q2bq8Y!(=np!DOigqJUIQ7?4fMusd_U9F7z%{=}A7 zn=6MD$;jYj;(AHsY*jI}>gxg+EVG{u14|E>-?TqL_Sjx(Aj7#|%(VZdULJWQr$OX) zYqIo%PB}`xhG`U!Z^!K8!Y^Ohl-b1MxxBG}e&)slHomvO#^g2llIP+SG2X23>XZPk z22*rFh_5m~GhDS-HhHLVUp+5Xm&)|AUU(btKW@8N^|jKp>r_jc zl{+|MYpuosv%h-}P?4!|zE3!X=v1JWDSqOxsjgrg-_JC)lOFPPp>u3&g6e7|_*`b` zE)V%7lZxK+`hmqY8ZAGJO>k9sRI;Ul=+3Y3%RO1bvxdG*a~N z48*c$(raPe&JLamD>c=KYDBH^dD6(C@t(0I)7JD0 zfq2ZB8ecpdN7|`223`@?>en67*)0JFO>0+x>@fB$lJ5nruY9)Ja!~`<$;{E3-hep@ z4bNaiH|CC7zwy(m^d?v1j=o0p`LsC>+3JO%Sd>cy-kp`x6t=$a$mpu~Z7#4`EGJ9p zYJ|<2mH(ba2Naw;1{xuLUSDX4y}LdHKIe}{2jcov23z&)WeXZ>^b(b%d!B1n8?rIn zcHa%l)NC#p61vO~^>sBn+M8*yg@{d+YR|qCI(>VtzRk3kj=l8l$BbQ-c>(5zJZtw^ z>ivG-h}Uv8I}%2tnP`8D-8LlZp&C|?Q z>a_e)wn{%Jnvq|MstUrY{8DagUi9xHyVtcteyN0O@z@@9t=S?Eu4-4R@bcf&FI49X zDl*UQ)s@EeQ_ZBebg}-CCzo?X&!?LGKQ^7AGdGMfoR0DD1b4 zQolFWnSh{wrk0Bx6mirXI%bH@NGSn{6$jaI!;&%Q{zA~w~lRZ3??~y!GM)Z)%HTsIy9SR_8^c1-6^_O!}@U&%tfs(n9U}liM-HTAEqjZXkQ$coqcY)fdr0}b(D_OtyFW${yLItB1>q3?=0@OupoX1q%XyGFQ?)=Vn>9&|z;(XV zn!dPJM7x`VXED*WViv~<8aA*8fS#vMhJ@@T3J2_x-qmve%jNwZqBm&&J-0|8d4h3~ z$`7JEdqU18u$JDFEg)@A$Qj(l=baYq37NL2oAd4FsN?Ai=r|H#zsHmr2&bzMW21Je z)}MaQ%KJUV|Mt31#kv$pUsPC=W~9g@G_MpS*B6QOMHpBuGkeTxlY8paCBb*S=YEON z0^&dQEqx%5kFTAHl*1%@sUktilcS_@^5eC$HooX(i%%-8L2~4*!l~uWcAwiMtHm0W zD>&1=vv}!q1+X0Jv%dX1>IRBqUXEB0A~}OQx+)!;`;|E8xJt2Ni7iX;V5N?$gze6` zk8K!IVzs~uiq+z6&wEeZAWI#WFjFY#@ahgzR&PQmJE<^TauQ!@Htjlnp^2!m;B7dV zIEl@gf8eStR+Xn&fzgO??D`oGYt?_2mz1@Rio`kgZgNoc?}d_bVNvldC*{M+!+UQ1 z!q8SN`L_Awwpk{r`E1#^4G}Ca-lDy~3V7*<4F$z~AfWXlta{vq zyg*6~N{U!|nYeESwHmWx8dvih<|O8~EYCvTxm#pPU1=#Fl@wQn4yOBV5b1EnbPF=A zGu*G!J&i~?BGs0=R1y6S67}hl+c!9(-6Z%ygTRsSTYpm9vhWk5&5mw*oHN=N4v0Wv z29^D>zErQ_N)48}_Iku$U9Zao-fB9k-b34|_04qa>4> znqCpkQC?}YX>QZm!b|vDd%q-eusvsRCu9Y&g*Q0f6I6~u=CpdU*?3}*`Ld6>FMP4E zMs1v6g9?IL23CvnVQma66B-ol*X~mVtn<72l|*IHsdySgekIqEN*j!J5>{=bL}HQM zPpIYmtOSw5Q_~FNIJLX2X$MiuhKF#632`(dTPB7mweLJb6k8t$bTrA2f(Nd8A&&>_ zr6#LBUT0)4#0(xJ+FBKwsG_=W#JwR{UxYs>5doHTE-{5U)%>l9($4!aUj~p%!{kvlDur0kH8VV7}}DmAS?aklduutUAlKk4=;rQCRvIi}C;Dop0qz%e*OZnL%0 zoRy}NRy+62`ilGBTOqaT)$m67(!?&I&+$L4ZI9<35|PewIie^7u{ zVQ@il`q0a%j0jROu(Z7`lBP)GO|f7qeKKDR=ZhKgtjGy`$V7x&FLZ20MY3*!caVycs&W1e2Bk<~Sh4Xx++pZ4G5_NCPB?(T#K*i0 z`5k;>pbJAy``Vsf$DaF*)!o~*x}fCZ38>GZFS0}ob74CcvUQ6D6rxpw>v-E>-H8WU zH%R5jr|xa9B|H%bQli5ffFX^4?f}K?6`NmijZqsc9;y*?Jb8p-zUi);5`c<}|02?< zW7w8bzA=j`byz_B<4vo&QevQ5)I^0Kth36QWwz__rlTD0n6zajoG;Go#ibX}NYQV7 zhRse(BbI`dwDvn4YyG!aiM=S|9Tj7xHWgk8l?9xo(KHO*Oc|%yrui@Ll7108~t@U*&qPvbuj?>%=c<-Q)=#Vh7$DX;% z2jkioM?4V}J#?4KFvN%=(=t2WR}Zc&$V)MU%l(NBe`*GqVxhu8YKIlNl!hSwjvLRq}J_6@H~lbgY-%7lO1wimp9iRBBg_iu#P zI6#G0@F0s<$8;`IlexpZR9q7#ax)j{2AMrU#mCwW9>+d$adG5+q|)nb|**DajxIOGvt`R-VkSpncOTJu~0*V<-WfOPDU zZMx3uJZSe>Bl&_fjbDWr)jV5}p*Ny_%&~jT>ojPT9K`m$!B1@-vmi1d05o2xk}1ZO5H zKgcWhObogRwFQ|fJ!XFC8t-V|`$V499z+S&|7M)jep_@3VyCv>2i!yvyQqzWd9&*0 zh+n<~8gZS5fxS83JTDM_f>`;xUTb_ezkL^^pB}pQ*#eNFMYj#!~}z=^Jmlmh7@EQ{OFVKTmZPs^5c$RK{W5a93Wlt{7ob#TTZKhAcAafSvDzF{e zmC%}9iN6Wy09+0J!adb$P_#>_f^qVKPIP=RTSzp%_}dbZkAz(RS-raP{+8lcmbLkZ zb$a-cf2ao4K&>AB)jw40dYI6|+5TY`6g|A2hnX|w9+0nms3s@9S0+AnGm!F*hZ#IR zB$IkueU={_8+_s2d}3@Jn>}%c{pP&ocH2te^A${`KKV~grRL^Owcb+a8C6SWs+7Bf zksGO0c1{M7?n{s1e_PRDGg7wwnw&wN)jMO!u+1IoP?kv7FdmJpCErhINc7=60xkeG zUby6!mg}e0&SVaN41X%9zUDlmk>#PA-0hHsZCx{6?3%i-Tt2rZckK#JOLy{7MIM2lFsL`Td0r276X zUwkK?+}}QomYBGBg7rp(46m(ogMM1F5e@G_V`2F4vFyER9VQ%g@Ql8B z9sHqMqiwV8aG&NuS$v;-MPet`I97HO(l^KF?$)y5zJ)`Zd`l}YL^v|sno%~jxM4uNELpR2g zkJIh=+-+Od9~e*mK`0oyC_a_F89~g)iGhm}L!XadwZQQ7LSo>@V^T}9t4*Iz1pN-K z8QRf!q}pk$N~G2&1};tnquEnnNqqA4e8jr8Z*3YzPbQ!e7rFF7aNxzFb)lq%0Q`Cv z3{MGd@UT{(7Ki)&`xSzeVk&S3y3{vDU)7!0Ge+i+;;8_baS1j)q0vIy;YXk9JEBt@ zWM#+9@~z3VRnW)=G)3Tf^T2o@v~IRIyxl6x0nxRhTP=jIdQ;C6ioGW9*47&ea^6X1 z^r0zk@oji?9*ms6VEuy~GXKFYZx%9&QHLti8cpiKJ1F_;Hpzm9a9LTndZ6RYGFK2< zT=^U7%@o52zH(%s8x5%3Lz>$WMD^d&v;G5f_4~4FVho{=%tO#~v+zgcm7o-d6@x#D z$P`bWK^S9m-~C@c@6pBZknh=2+b0IurNZ6qKE_IqNnyQK4UwMX$Q?PRsd zYtS0!qLi>n(Q&j5adLNBz=5t#^Gns(=3fe9qtjn+svq?FpwG17d4>L|(mx4tE~?Ac zC~C;)&H_WCeu9pGx)c!2NxEu~A577#Ykp%N=a|Z7)nT*hktfr{n$S!!Z}Y?_ADf~F zjzaOFDMEhzn*YfS*x0w}MDswy25@icp+bGb`QI-AlZ69@qP<{fdTLgU{1fq9l~Ck%Rd6KH_M9X2 zt|tFocpeRZ?f$>FK;hnf5-L<<+6_mu;9E&IcFm^%*xu&Uy|AIERY7>A?=k!*KbIky%&Y$7-psOVC3ID9 z?Pt%oM>m`cn$dw}k^CA7y1)W$Xl%pzt}*VAmTcZc?2`5 z)&pK8B2>4BBMxyp36x=JD%hOndtL6sgMm6DH?}JRyW;PZ{| zf&TsvdG8))<=FiJPlv6Mwms4?Bn>7FsiqT?q^)|i%czNHa zgd$Q(d4yDwOa~nll2Z;Pa=5k$kw+()_xoMzy7#{Ko*6xU@8|vF{r&ndd+&8$YhCMF zr)youn=;9ck!q?)b@nioDt^UCwbet8R6CuecR_sUP{9EJX^S1%$hjOp7?JD?VHU|w zG0KYR<`4|mle+_?Taow04`OG<7s{7!53H=}5m>piM_})2$h;aCMwIUfeDHl><_bU`*#e}i$s>d%XLX1cFOt5aN7AJ<-SqMG-&FwA2R6jlDcy8w<_4&B^=8L^hVa>9=R7IpH!|F-jOm0Hvw3katO2yI%;BKsym<%4qi>@e^_e3ezmt=Rji4OX@;|Z0h24snX*pJE^?W^&60irnIXZuw!6M{& zy#$krxNZ4V_N8-0{?3$$y-EY384gDpElZn4EJ5B^VtWqbl-$&&?*q0i3zi8PXkHQ; zAS9S$zv1Rnr+^=FvArxtSf!<;85LB_UF_MknQT6t$x`^iY@>KRCvBlwW=uF0h=xdi zN>Kuof~M*I4Sq2fZqtk@gJOoII0L~N?E`8a5TeYWx?FeNd8oUrn6t2`8&&3#p+qyg zC^plnvjV4)k*Oo6Sv6Rp^jwWb|C-!-1dW%8!A%Pzi2=8WsZzu3VUxrWd;2eHa8f35 znwkvM)d=ZQ99+jVOw%>+ik~o4j_IMI@gh{3mcu;+a$cls5@d|~+hl%kL0T$5L-sT1 z`DM8H>JENDS6itNG-roZOom`l(;?>}GBtGlAPO?c!yjN&;f&#=RvJ|na5*yMd1<^7 zN~GaKPD-fMUWV?_ny3e;Lf*=gxP#hl#MgY_+Cg1`+9LUe_tJ4rC_BMcdI~EIdM0$l zw5057@jl3}AjtDjo)H4~UfG(kECvb;t%AunNEuA*ZeB{$<@pa1L z{eMkq;x>$;n@BMCycaQX8L4^4%;R2vRC?WW+EUP#6$(FdwM5xZDS|sTn7ra$<|RC+ zIUF6)BH1d(jr!-aHr&~c8iU&(ml{n|OO74<<)wU%o&EO;fzg0*t_Ye3<*d+!nIy7F z4idyL_?^^-A4%rgjG9HIZWi?o-rzfirOxOOTgs$&0RSO|<2$s^ zE^b&)q_MIM3;7wW*exH<^%}m?lch8#kr?8X3WPFOiaFtJvU;Aq)d$|mjcxo#p>P)+ z`Ua#Vmj ziXGka5>k#}ocnyyjZ=?FXnKNK@uH@jm$6%X3lI_*#2>RL8cW2t_;F5>U?e!a!TST4dh>XC=56_RnsI;X5xTa&4=L;sN5-ucN5%zpE1~g4Ui(qcXblE?s#umLil~=Ow{?f zYDB0C^CYs1K+vX2xGNNPy}ECZ8@<^SPjVk_CZKOpXq1`>e|SjTHHFrmD&<7cI0pMD zryWs_g;T^sHu<*;SGcmVur1=}S@%<}47yIhwc!w9u;^>&d^-%8}z3jjf9||KiJ{{7W|^{Mr?QwV0*UHpxzhOXi%AL5IZ6i zV>aQvqBV=re%Wp$L<#0P6q6|3cU{kH2)6oywLR~w7alG{uI17;Ft5r_bYV-WUPNczqZdil`h4pO z%jljWVYvw9sVV8Qo=>-7SxVH>Wl3$&ZjxDWM$Mv9H+3KBvPPX5TgntN@I!0tviPbJ z31_%wj}CZQ_%Uu279X2|t^?!$Q)~JdvFi*3s5`uhgD*It>5ANwtGmciR896p%K8I~ zshmZ^3!6tXJGd1un2@uJ-Pb`PzDYyyTba59--1UL?+^Uzg5JJyt)(0iJ4A^y<-1MX zgHMP@Veadp_e3W=E)t!oUnu&)nAxTr><$qoW-pFT*5~LDcEla(vl1o{geTey80^Ih zc!kWPFG7FN4)m6Y8xBFI)Ru8V2r6@px;MWYGwMc2*Br=R$ccVEn+Sqa8hK9vYt9j_ z6-FtlmDytnOpIVC%mJcfg6&^BhKBS>%m`tDj23}>#L&(^UF||k)M994NU{Lat98wy zH4V*cE!QDvnw%9iw1QMMD*9N3`KDz}qpC2QYJs8}tXy0u_Jo_R*K-nog$(U&Cn<_%(h2H?#ED)Id%~yVk*Igvk(w1e?mTT~$`wFw;IwLp0> zl3b4T{Hq9r&;G)x2G{&TZ;TIRav_KMFW#jc`~u}0lMBK>xE6m2mhB+(oNzmV#e;!d z44EBVP9kHtRUtwnH~+1wRtiK@u7Z5 z3IyQ6CJ`@0pv@w%$q-utvCNp*l}022j@+%yhP-#T`ZwsxSt%ohqLhEDWb%uk06zeo1E8~sq#<~6 z3E`Kom#UC8%;T4GeQRUQ1}x3g2BeZ4@MOo|mcq+Q>jhg(f0Hu=udDYIkn*S;WPN7@ z%3l^3g1;KQ^|{E{kfJPElLK4Ff4j}MpD|6_%8Qo{hk<>;2&Wf|ebZpTk6$-(;}*~I z&vDo8kD_o)d97IgL3Mbq{Bk_OSzexM$EXoLtXx!k>}eqM1hagwx=16Y#+L9ZnF zR5J=&MFY6&gLRpq@?(9~7WS_hUsaR+C;} zuNbzU5Rl{v&MHEdYgyO3>kem{^%bAa?aq{LErL@-eqa;yIh*r{*&^H63K0KcT0(8j zZVNy{v4h}fHc>(A;tXSGx_xA46N*qSl1=Pxp(%nQGh{|L4nW8g?L|)DpOQ)eYJ&N) zWlbDq#+|<|jw@weJ1v@4;H0edSazlnm2L)Qwz-I(=r*Lmh!2R1)2%GI5f~c;CI1$8 zp9Nc^K2Zkxx2aihNS<%;D-y2o(x5CnhDpeq2oRw{-e1n)45;)3m?YpOi}HTFbTbOC z^dT`gR~8H?l>BxcN}|7%w>8Sy-C%~VbPD4VXIr|Mgma1Xj67(=T!A=?5e{EZ z%oH%UTI$GTAk>H_Q3^~0i*9DG<;IThiA)=UQvnRBa z0%CJOi9Mddc)r4%dYoo2xokx78k#N~gxwGdm z$WO%j&Efj=2N-50nB+ea0XduJ;s;9EN_QQM)OejMIhLTSOz3^QU>tsWD0lI2bIa=y~tt84!khv!hJcg2gzZtdT zaW2tw!e;}Ix=Y~hpoH)#65?>J?pYP)K(m^1sxaTy0>w3#+vXu$Y{l$>6YyN|qIcR{ z4Hl&$@m+LZ?mri6M?NQ?Xz&ig^(CB+Kv$Hw^?UEBF9~2= z%9>O!`goJ;tKhiwkN8H%l$3rO#?%9`Ty?j0{QBnoxq6=_L{A9J$(tce4u7P7I^42+hfp z%)}>jypAo|zS0JQirB@X&Za46&KN#8;38eNk>}O2t^>nm;y_g+hT!@ow1U*lvHe+= z+hTA{(CKt%WdM>6;VJ}1(Y}1;g5=RKJv}&S>qfffTU=faTD(i;ZLa*_no!KrNE>i= zU}QQn#d^L;6?nv4G@&djt%tw#52lJEVFwzMdMr)P95CIzqev~|aFIj`G$r{CEu5z;mDL55O)J0^3>lCUJvKFaD7I*Lx5Rv_>MdYEp zGvu_$qQIU^;cIAd$TR6syeM|P;u1wJMq|O9>;@+4$xLJ}lIw@Mj1_QXpW%U@ zSASwXU5PtZFK?lDk_aD`p7)Uo;)Cdp-ytxW;)%WYDi?c-opetgJBvsB!B`HK6HL8k z4A7XRuETYS)7Utzz!Z?W}gvka2Vpsxn!)X=gpRG1>T!P?2z}8JSPY&Y``E;h@^_AzwN=fo zFa=FC3y~h8cnv!a$<{{uN~?u299x8$72&%zrL6?R;`Gy|6(R5UXL4b|_U+iw0T!H% zB2M=W3AkoGKVKR@i=**KdkoYHH1mi%;4o@B9)uVMABs#8;TwETLYXovxrjk#A}UCy zAd#^|dq6fygCT|mXmo|S^{Cn;@lN=V&DngVa-9xtsPUC9q%ygVSNbK}#QXJ2xl({{ zxM@kQM{*eDs9~}=b+BA)A7>P9ZFBMxy=sc_ zjbgJLM3_j2EgilH|H#FqVDj}Tn1%{@H@=F+#>b+iV##w(i%ImV$XlB{9UJu?onLvWhJZiL;mpB)OCK~=H0 zF*`q16=hIG>9H!p$WZ8D231tF?#S9yglTd-wbn_53iDKL1s#Ej8F?P|GDvz$`2j{C z4a6_g3LP$H^hW8!Tlf)UH1QmD`MZkj+-VRqzLbW{$#IgZZaX%}l*M5G8)>|rSc^1* z-s_K}{#$H(8FSRju_9JsDrzZMVaC(~l^Zp|tm$q(s1ACLpO17eDDU0FT9EC#3 z;m-1^AzZ*IZCh{d!DdgVOx1Swe`YR*I~-16<6|L0nc6E?e0n%$5njzDnvmzdKV1De z!-P3$KD$dUvDbJ~D&(ncp{KZTNbCI{Xp7k`x_Y>3n@N#d|{DfhV|^J{h9S zAFt_nJe7uvlulU;@0Irxxcce{jhRKv&S);|?j$>V#YMw6PPcixPJD(AXZDvhPR^{3*U($c61f(at^p1X@t4zXQ@<$ndnMYCrVYn&y7@d zoKr|g14zlk;{`QZ<>js_@zOh61H^!czz7FhF{h4Zb)HTEnN&~X$KSf(E1p{1Krh>6 zhho0LeoHP6A%O9Bco3FyusXu!2y_9IMaXl0nD(bXeT!E^^!Y!Wj`OkW3EZq@D(1e3 zGU$SsCHy-49`TjNMK2u}%)@$(p0qLIKn}_#xAkj^rkT z-0%yWn7rYeUl2_j)L3C&Lux}lQ^6+>qs)%^ZRSjaum-}IUF%=Mubgg*J446}fy2dx zYzw-o^tBHpK%*&6QpAZHb%9DvoSCX$R&*20}HKd&YzBfZy9R`#PoTYK@ptk zDi+0J8nB`_V8df(Io9ME(3oQ%%JS_a#Au#+4071-o{)&s-zjJg^cUc)ji2-7eu_Gq z(l>X0^s872EW^%R!dqot2C88!G`?>&j3QXGlLLncs95`ZlZ=Co^k$+#=+hq30Bwxk z3nR3F$@{zbVks`z;32=DJQD|0EOn-sZ*yID8>I6=4oT+H2>dVt9AXj18ToO76_0?( zWFzGHEQ_ZjXilD^(-BnwPBc@GRc}j`>0M$tE6KW0==|ydBQk>@g&4Vi!M&a;_LPap z0{P`pez}xiE`wGD+RuMB*i6G$ayML#D@cRDJoI|)x$1|*eTxGroMFI5RkUpo*O+or z^$2i~^Ntt~n^Ua=4G)9@I2eV&DfX$3yO#=t!2A^axbyi7ZO@igaTh2q&cq+DY zaA06+F!{n~v3F`q;SquI3(~8eV1Au#R;_>oO+x-(jn`eniflVv>Whr8QDuO&%>=_0 zrfV!h&@=o3>9VflM+~|nHwUx&FLzZYVJgh3&i9#$eGQ^QW6lqWO_3ik<&PQ^%mxN^ zw7ia#3tq9ZpOoXse)@k@_EjQ#kf7=Ds)$tpto5fL>S50q{P6~SNf$E=c3ILLE$g}m zuVD+~h0)Hv!LTm&-C2|kVn&5Ywar6rwk8v!Nlb;{DT;aSBLT8xHr*FlWalIq!#Z77 zOx0zEelevxER(QdNur}wy>>_?X{#cg@U?JNM>-Ye;g}K?rX=RKDV+k@^VSA;=Z5cb z@$orw5cB>h@(dYdV-*KiTEl2>W+TBNn^MjwBgP_~mVM=|m}^q7Mdj17gYOjjYi3|w z&kPWUcgf^9;~9()(~j~|DOpomh5qEE<;-F>S8cTwFgQCkxG>D3$!HIQ)!(=0U9~6p zW)kN{S(0R~r$%PP`5nhy*` z7J%3*;M-`zQcO5kPcMj-q}$%ZnGKj2nJJS{7O4OS56V9b_l3YD3x&a-gD=ojHhLp8 z?;uD2G5p%aPz1wRN^Eu}jX0Ft{%rQYoXBABcucm7FEETns9=lbGsFhkF)HWEmjCig zlY-va0OMdl3PNj>KzT2C!dAI@$egqcQR-JltV~(iUvC-%!bw09s9I^>cnFF=E@H?r z_B*OOY&Vs;pzM4VOnNYI#_bEVOj&l{mCdRp@-;t4%n!a(7u&lOEA%;9# z_YlbyT9V9bC$L##_0{irPr{~To=+k_ZfeViE+qz2;b!X+H1$UiYJcQ3mCE8ftyF^E zHbCaU6qa{wpd63kbL;%+^ijMwnUpsap3C^_50uw4Ew*x;x%Ua+2#6Q!2Aid!c9<=j zxjy_QJqKHJuV<}4lS#k1oZpdBtutBphMf|oHzB-!@r`Mb^mS(SQq+$&n& zCc?IBuBX8cAaq>v)F4p33b#4k+tj!Cq+?1}Z!S7`qwAC4o(i?DU!%D?+SUQ71~*hkUU`n z3NKUv3#(!aIYh~&Y64JA_G(j~jk`KNV*fY%24eV4boj*=bM=+~1;3`C2ET9r>#+P@ z68xX?JMD3|e3Kl0@x{D2 zebr!XfCLcqvNoed_aJk_9P@@+-2NWV=wS}EncdTg@G2cMQxgd}eBsJnk1%HQg)4;v z3HAs0rj>R64Du56=IG;0JU$K3OhO^tJ3r@@o3eN&$(0j{u!{|e=BwDZiSW&LQ>~Of z&pcxxb0je;-k$)6y?06YID{-|bodB-Gu}=XQ{T+bUJdgeLQrvz@31^#mD5D`E1CO-f#}cA;o$BR;Lcw7b3m)=to@k#r9~V zXCyl9a#fG;5T_ofOx5$=Caa#p2xY4kQ4frf>e>2mL_If0)f4h=_A@=?i*T~Y4F;wy zUeuy|3(jeHl!*aqD$MA@914V5g1+)-yf!W7=1$!IzEC<*WP#?-mmr~cBRcyDKdHsZ zX4W|9<-Ler92v&QZ&aVS{4nIn|J23;#y$u)!Ay9VlTXYOalfiOm0db?Sny>t#V)9= zY8EPqrC(G3n||iqpU_RGp^k2Fzp0N#!44K}b|-1uOaE5?qiWL6T4U|&!@MZ{a~jt{ z|GvMcAGvSG&wK%AXyuP*?(Hfgb4R2O8^8WN#cf|jj(y>aS$*l@;@2~i-SMlz&N|{( zW9%SB{90Y|-^4GOiHps5f_$?_KZsgVQ@m9RStwMAS98cfhPwH5x~d%G+scCDF-u>( z|I=f;`U;Q380V-nV8mTl6*i8hGR6Dvnzg$ZGQg1cCwaQE;2V6ut|_iHDn~Gfa8MiPR|O}sD}{-)5xkH33DfNXwDa^xniOkatzf@sKt9uC z{$bnLfa9bAgp{mFT5a|gLu7A@3&i6020omd^T@ylLn0ekdh%4%NP&R51Zrg8$nNlq z+1*`d>MVIG$fvJ1(@1`fdRUY`icizcSywPf74I?(!{rNfKVHawVzP^q%>fQ7=m2m# z$-TLqE(5a}IL5o14DKd_yGe*9VTy8*9pRF$>pw1 zFa}9GyJw{9L(KxpQ!~fIfY_m#`k;m@L5XH#uIxj_nic1JMX)gCPfFJXI!C0(vg{TqBdvBlRoL_@-A)7&e1uhvfQ4Jk3C!x zy_MVInnT!e$t(Wx#+-fJfUmhrw)xJ&i`ZRm<+jXA>CizO{-Y}9JndFR7%xVuUP|Xd z26n^1c?sdu0N}KDk?<$;=YzN}8FO5~PRHHFv{-ox-QWR=gg0V0rrESjMy{9X$9?yr z=AnQ)-LI>E3}I6WtC9Vi8@T_Vcvq!Z!UDaU03m|T5eZ7xL^&(Hn|yJ-2<~MjBsw2rHef~jp)iD7uMk>x7%OFzB6}B0)MJps} zzBr0*!1>gmENu0G=gHzxpQNCt-2@tQA<8?p*eLubmEzdfj5$yskG}-H^;wn~HJ+^( zy*Qy24r*0ZyoMUY>?Q7Aw}N6(b2-RV;ZpgDb}1OU9bJzDcEbo-VNPm5+mfEfSq2e# zOq30D-0xEb4i@PgWa#pGzQtFi4LA}tI;FLs+;RP|h(mW;mZ4Z6*zg1DWWCglP&Qlz zEt`vA`n#KRp$xP3pwBKvw(^=M{?r-!^wP?LaoDBYUj!f|AWF{AO7y{e3&%e~Li-&h z!Em*tsZMeA4_^Q+mVUu2nN$Sf0JkuMd65UzAM%#mHV;*^)$G$`YvJOlSZIWG=RlY> zt^3I5Bi7wEQon0yJrF9jCuTvsQu`+L!FoPD>`bst|Sx!X9VtelZ_j`GMBF|k1G zIin&{%@O^`+gNr4lJ^%d877x9khC;GU@ID;#{wfFN4%VdNkbORW3P})N0nxvJoU-- zb(r*Y`=YavkP!sWo)(XRs%Zu1k?N*?OHR)EZQ60at;qMc`Q!>Ii|^)AtWf#beN2{d7Z{i;K92P zHJaisgt+mLZ#+{TNX1UHn2TWlF%=N`RtVd^oQ0ZuW&1i3>_p7yfa9KbVF@v6oxM5nPE8txr#zDI%18Ws7V-LFm+Tc2#v?{Mumjwys0ADvZ6th1UL_ZS*ds}D_jhDGLxT~4qXiOx z;d3!d?o6trQoJAQ08XHkYZR>%#u*JGi0I%D(M6!}CIBR=M7!FMOGpcHcm$`S0Tqt6{6?XJMW2$-iD@|9#M&OlP7KD=y zM8A1DV$GHlHNh1fD+!x)z_}a|J3B65Ea)~;$YID+R^M5@fA7AJs;ge5;Gs~u1O!(h z&4@u596^`?1p0a&3Zc=~5OVnqF$i#wf4m(TgSCYmi!p!5TLc*+)w&#g*&P`XhRuu- z&`zGq#pCqz6041kcc?`S)O>BYhHoq3`kH%A!N#&owiSOU@enpzP>tXeElQN22x9WI zwtaYaPKeour;4l}^mHxaIAu&Cx=d^c>6gg&Hmx_WPDe||qK`B~*{06;#;_IF9=Ys0 zZod>qkO7DkucQg(WTU&zMt6PhePlX=K7g*$^GFeUS#YkWqYB_SuUw%0y_k#GnS>Oe zTm<>_$_;ud?w9PeRiOM*Xu20H`l4K_9gp2X+Yk5T_9s~)-fVt+61nDPTaG8lo#3wJ z%#Xv-yjHe(uJ%EcWjYwy#3iueUHina7HB3LvY+g&tYeMFJK0m%z`U$r&s4s-BRebD zFFgzO4aZm-4MFhh?OUAu$rvOknBqAGKkzQ8garJ+#atM0(SB3t!U(uY5=EVWn|6dc z6OSa8{=i-WML0!3&rJ}o$BFUKY&_{u$uj%o8TtX=;v;#eYrFjRENUrz-fa1hyLlQ1 zz31F#EdT?j1uR$2R@LXYeq4#**#V9nz%cckOKF4_DG$*Jnbes!_kw4 zM~nu?21-_?;-v3`Wd4i~aI+Ii`XhS{@Y-Iy(HQ^ttJk;dhWp2$x5FSafU(Jxd&y*z zDai6R!c@vZHC4;^n-qwXi6~otFbWHE!Z4cj;WLKcjQi| zt+<$4=I>~rxh9J{N_SEQ*=zj)XcNL%>rX|;9>;OCMC=38m>XgHORoiehI`95M6$Kq zu~}+uWTF+7V@}Ca4>~7Y3ovs@#G?c;9>K{iZJvnrY0hYtGdjBRNaHz6yI;7h%?CyY z%3)dC?r|)Ov888X)x%~8_M-BQHRydpp1$WXg0b^tJ^+ir`_Du6r8VI$b}S^G0CN}5 zfC*}ZwnA<}mWnEc1Mk_}U1y9=CJaVgOURd5)K$1L;yLbZK^wPY<7U+>X76oiYE!^A z{mpq=$tO;y_ZROfk~;DsLZqaKbJ3uOK#YOI5cnu2U$9ST3rgC)Du-9JutQyc#bl8R zO{PpJLE)xjY}-Xn@F}|7-n(t@0ECGVgyI?qdGti2$)2@)xl;m08MOU4JlgYmzS@=w z1_!7RucWU<=0|f&mmU*eGWf+jTZEhJbT_C)PeC)60P;}riv%V9gr9?(cUM(%5RymSy51uKyr5wO(AZpGB9N6arn z!SWEN>x<(TWVUMm*M;2;4pWmU%-7H4C;C7A^t?0LDhrG!rtlfQB=L*+s;frFRI-DX z+RPj_BeV5`=w{B;&qz4xl_@qK;J75zBI9SK{aE~c{tR^!a4#fm6pLsZs9B&7xgh?K zD%>H}Jkwf}dyyYf&q}_ROLoaQQ&r^3} z#_<7Ln{^gcjixyp0(-M{ntob0qlcY-Nzf8=dsxD0G0_FB%X1v2TN6eQ)J~=0x(aa( zJf-~r#7HZ8)Tx+r;2LBqoy|ucBc>)(7w&dg157kqN8?tU*Wn4KT^DK@Rs%tZ>tYbYG1MSm8! zycvf+)SLOm9CNmMGt8Qq5g1Kpqv6BOVLnNv$fE2yGn>m*N~tUxVD%5)MD~F0r{JYO zm7Ah?wNYOfmNNwaW!N+#m+j7D6@Gpj9&x+TbZE58uP3858S&Ydjq!6PT0~bVl25zu zRpjJyrX0ta(DbkSJ5D5y!dS4PrFsz96T#c@9tcP{5GmD`XZ<^pW&8&P)%xptzlRI`2;huNare{ zYH8$-Tb)?-TLGUCtAt0RdZD7KXWZkb(lkH17IndAbO_}a^)JxdK;eR!Vy$#~C)jb0 z!k&5$R?r1$6y}q=Y2#YPx44Xk!!b=SNHJKp3%{yY1}k>pv+D=G2Y-jR2FtiGQ?jx? zw&^4!6pg@13JB``pGd}2bc~FF?!*UnGzY)~|FPa|;jdKZVIfiBuXqjFUJbh*TP|cH zgPP!p>e|@r*)R>yRr8|S-&^Xe38d@HYB0vk_*`ncDsw`U#?sU1rRa8OJ|_X57fY+6#u3;9aGP zJ^VbWfR-#2k+t~g5O=~ryo>AxN+gcnzfmpx{q_(TYBn;E{B zN%f2n_)%ehKyc2isca}f_lYU2RH@hVaZ6_k>!|#Xs$m6VVJ5Uhn}LcU#u=b2=IY9j zNyg?=B=l9q1@~Yk1bSOtH3F7B=V-C)$MEqFEE|Zk*PI!H5%TWwu&erem$1xkMw@(y zxI5T3NL`H$tFa;P?TwxhDl9@z*eajS%F0x|1ta9CI%z&0+qiQo%Y>X23nwFiQ)@=T zFXpvTu^EZeH&1j4nNq|v8CxPhnq z2Xeog-0wCwW6Qtz*7F^)oQT381c?N_zj!5k*uf7tC(zI!bLS}az+Cjag?CAJg&P`^ z58Ot_c)bWh#`xt@HWwnA%-_M}ZTe6gBq+S~N`oywXtz@!xZDY>?UJ{An5L+(QA7nWEn3rqy%`9qz-8A5%K-_@BYeR* zseHIe2~OQ05(mAH43*6Wm_y1=#B>>sQyfdCKQo)I1k;0~OvmK^cK)^x*39dkzfGaE zhhq{KOd*B$EgllU=79FNunNqK!KH>hGdLB9NnM@G^=DyU6t`!L&I%66%!0>dW`$a< zd}tnC&5@>=lU!kiVISlmi)wa;HrTQH6G|MFp|QA>3-zH02Z|x@m9iw$LjBtpW(8)&o z$s{v(F?S$Tod_>&7kvUlzvFe?YSB)fIDIQu={BJkU{^CuS}gXKtGNx&5n&{Uo~uZn zaYKd}JsO3UqUtU^&SoPE&}s-xUt{3eu}wk-w$>Ch<~Y4wco>scR3T)_85gtYyTW~P z(z_%scu9XiYbpGI(7eMQ~X-%{${tEL=s6{7$xyHb+50_ z0gA&kNBzd@LM*M5>FnFxHPSfEN82N<^^N2Gt#u;zeZ-9{Eq=_6-1zU18&0c%Jj8`u zx)8k34l}sN^4`Wv5wjD*xEe$v9V`N2iJ?{D(*c*U?=lvnDl^IkrM1HrqFkB=!lW|_ zQTN2QpCT#P8Ok3^<&U*}p*n5Et8gnXn=d_DNhKVMBe~EONH$RgH}tj(blo`iN!;Lh zLXXKo*IRoO2d}OJ=wyZ_;|Fb~?96?&@A&@Sd2-?@%n(>uG&49!~phkGp0D ziXp?I!BOm@0Z62^1RoPFoqn*p5Wye~{!3KpXz9n66F0RhLtng^x;=Akni>e3tN}Ev%B?lW89v$q8X9F$;EJ0zo zO6m-J3!YGXF#Cc*y?o=Erw9@8fiT<+nI4Ju z8qmMLZ`@1RpW<6`MZ=qm5B>{v%;e9-eUB*GKgc)kVf+aHg+FHbAoMqn;W{DPNusld z-Q+`INU5?VA%qOlAv$LoJcHBVewqTTEQ|f4WhsN-h7*Q<5pQbXHz}7MC`S`8AVRPz zV1FIS*j8bGz7FXm3~|>*gT^?PoLasi&;WrB=0h$@aALT&{AAP}U^kQW(ChL~kV9`~ z3#i{Owc-ox9MnzyO}g<1#>2h=oiq4i{Dv*E1mH3$Dq>}#fd{E(?8nS&NV^1Q-c9II zhzl3lIO2-UCq~`<5BT|QERxiar}^}mP%*=?WI4?06L)eZ0y|b@JklpI=(+hiSt&jy zu#UkB-r+EWgFT;P4{FsV)rFVZXS{aa71;J`w|YLmP!p!S?BUqXRL=#GOA7ppe@i3 z(#{sR9uk7fK^v#e> zrfn9QbDj|H4J!?KeyOML4`TaZ*0hD?O=4&4#GEAqmt+Wb6Y^Aca!=GHlQR&2+0&Ha zy{TYdXX*IGgj--ATU%(%YELJD!VE&tv8S+U1il-^!wnREgl}BWC=M>a-^YjFBUqWy z*)Y9_byhr@ugZGccdR+)ee{lxLf*WBAgBja5HUuiGKa~=)JzIHb&Qx+W{W;f_>U&~ z{2cY!{w+H0Rm=NKFqKn~~^kJr>7U?1yBE#_2X5;_};jidGs@8bb5wbw*@)2whuMlw% zuOxHDFoNn9Hup=5__%}D>OKT_wVA(DWEeLG8vE*D8CkXu>G=n+zZ0w zJP^b=cpME4C3n3CzSnhg;i$sl@+Kja%cUUIfev1z9ONNyKuAJE^j`hql{^4mE^q1` zx8dH#>%_QV;rC|wd$p)>g8Juec$-4lx*C5Oi!^*kjJ_`Vi#0-2^7LL zl2D5lsXUE>`NrNI=v(aK!AdHRk|F{oBY@?0Pm@nhrKPwX_Ethh%8w08-wVP71bIdj%T!Md4UcL3v}j7&^og6Ol}3 z>pix+Lp;v3O--;(MWEr_8t!ixA8jgtj51k`;+vXHCB*F9^&?R5CGVmV&xDheQT`T% z;eAEtk_aAG6`76wAOxQ5RUyQ+Uz{#>zQ>a7wAE>UdlHLiTGzWEh#Yt*-)qU^+Sj7# zeNuv+f9HteuMU(S&yFa=HvEU*RmbVnF;X|r+2f)O2apZF^ayRZ_&vxu9iP>44t4Cz zE^Rg+V;5=Fbn|mxG>*A-M8hC{LK%rOx`sTrUygYtd{44uTsO7XDi8a<5h#OGnuyuy zv?$mna*q!d=q#gO9S_FXV%YCo<;Ag!uAl3aPdZeS0o4@HCz#_h;|zNGvmDtl)4N3P zOL`Aem1FrN=($%uWTF+jj&2zYF>WZ-9Y=E|H8eX%N{gqn#kIa~g!8-C!Iu5x9oB_E zW>SB>SQs{h+`wG>FZ~&abV9+t_)a@=f;3t#W+Zbeocuw{IXZNNZ<>RFs`7}u>_ffFZ}PJ-*2^p((h!hzf!Zh>+;z;25rMe%cT{tTKkGKs4fz zxZwQAlw`;gsEWT&g(Yp9=i_(?f2PWQvPd)1a0)u;`Rg*6M^G+C#f+TDQP($S!#aEgXSQi+|{(K;gZ2lauTzN(QPxW*3%Z#y(U&({2WCSwuu z^J)AHIiJo6Iv8Nlo6f2|1VkzLN{cA(VDjaAXhkgs^8?2g8$#GHJ;@leU<+7PEPab5 zaV`C2b*_*9dYrS{MWZY|5Vny{i-0(62g_e}eSG1quJ!Q@Ss%Yo_+d7OVxoZ@Dl*rJ z)biFVAJ$sR*vOzZPUeSG)d)h~F_(}-q;CTg;zMB`%M7Q`;gNPq+|RtbNJQrOs=e(F zAzP^&`LreCgcWD8%h`|OtoA@$Xkf@Y<9X)R6ffdeQVXGL$Gf$yfNz_@YC&j>(9G z65qJH5Cp>~F_}1VwyXt>{1*&xk|ya9Z>^F4ai|d2|D)1WnNPu&bbdjmlY#Zihv-N2 zRhm`Ed+dj^R88mF%}to)e(4g<;*ZXOW#aAdRIm)oInJWW@GCX)7A?*sl$TK~+$4}u zCixcPlGqDExA&F5=+#Zqs0WlvFazJwVRA}oqoAiZs={JHPiqW~gb32LR?&0~G>(3B znP^iO$fbK~nh;I?aEg!SWJ-r2tSyV&yHJRqhydYU5UWY=4NwvAZZ+rmF?RxNQ4JW3(c6#Fc0nqov3fjAx4oKzHFfM1o*P|HIT^VQ)t0 zOy6Rhq7t_j7ekmVVjj&+49yARLW&kPK*T_yC98-K?(1`1X z`o?ijrfY{G@Q9)VBk;yB{2*D>b|TkN1|i=MPnao!Asja2WI3!U z#ccXOjUqaCa%Q$zhI{Tr^9IbFJe3bE{{$8N=b>q!iI_U}bVo(&uoDL=2ztWn$s6)qfC|k%Y;R?^QwHfBU5HB>j|sfd>yBXsHx0u)N7v5_Ps9ae z#Rsx(8g@&e4}xq0K^ElsO4qp*zF?qmx@W=ub322v0ccZFLn0 zmk}fSb3A^U$$l8hmvIrqnU`}yN{s!;{9Hyfcd}7mrd3lRTS!Pkx0)y{geLmqRn#Du zqd2j6wxIxbl+(hT;S3x=?of25_ylWBi|XpCPfdtC);&L02wR4R@)@!CN5+sc@0O4Mz1#O(4uh1TI9w1Y~tk= z@-98d;RGcX@=ol>1iz-tn%Nqx%--$}nbo+@rq=slpy&YB2yqTSn2j%63U8SD;p(lY#T8vmYrKU3NPpn%V!e=RsA5WEyMSk6T^NQbgP(+TLT8m*PoCQ>YU zn*lx?Aj!;c9m&!P*U&m33>Id!RnM3vH`@TlM-jUNA6p82tO;qoQzU){`)C3Ko$Ju;=j?ELz*B3c~m``9Wi4YO?=MF{#^rgRGJ)*Ud zsJ`ZXn@6d>0(Hh*o$Q6;T6Fx5V;0T;cirwQeHvAD_yXC?>G;1jttWtRfiDcNeZU#l z0#C=H;FS~R@0rK0Vj}Q06+3uY8v)tR<ER5fju&@@lD4{(6!oW2 zY1(iU(IKFmZY$oU`x6)F-o=ppWT%DpL1wn+!h7#*)(GnlPFX0Hj8HPXnT8T64x2=? z(OEHhMxZ<@fjjmf1T*wWy)ya|$+g5F@uW8+xy<&JYuL|%FkuAQKnH$gO=q{O-{^aj z?KiN7lP!Kot62&J#v0j2x_lmbMraa`Ay!lX`BD=spp>(yCsQT{2@5Vmb5BdIf3tTfeZt5nqMrF^dCOE9T-gl>Tb_v|fcdrIx3( z!q#Of{|Zz6Y)$+M6Rrh{dyRUY15-E@mrl9n12}&(Al_fCc3|!99YtsstO3^$i9ESm zgd(MY9kH5H%!*ZQGPk4BswZ6$!exKG(-x}nUDX{LF5b17ipKoIdQrH3`WAb3`PDUoHe37R zXM-`nR+~wEwpE)e*5S{fUp}ceZ$0!`wV7a0Zub1$)n<3j7uDvTM?vM$Q}$MyJ2&B5 z{*=$F&ALqd9MKr0u5R{qwOQI?U$xoUbyu}{Di8*}ejwj_4$3|K{rA=8+?IISWzmN8>jn32Mh=({1jpSQT zJAQ-gh~*9uQkR?!HMtsf&_aA=JxFNqNe!l!}y6<4T98 zb&KnelWYaszr@u#)!p|!v~{g4rCAQ8d+VY^>oG66DUr*dXS${I&e_ts3r=+?b*hUJ zUPGE-ZgNwiX9qo(SW0&&rFQQ-l)|so(K=4vndWXvD)B^1shLu0I@zK0bX}C>sOSgS z<{0r7T_58I)&&1#(I+iA&iG0zuCQ=V_$_SZT;}ZzE9=39<5>i=tM@3N$B)5?uX&iy-|D z=a?+PpE?S`#+@Pr>x1Bw!w?+dCaA%?y(Jh_g0IV^T#d+K0}#C6Fa%F=6Qu71J=?o! zlh06sm)soTuptQUe)aF0yt&xbWaThq39joPO8UdfM1fR)}CVNhf z5aa^wg2NEh^Lv({hOfSsU=JlYSHl;zjNM@kHJ$>G6Q_uW1irPfHfCtTm>`~!)3Fb=|bf!YP!5zGd7E(|yzv`xb zwOo=D+a5KtyKVJdwfa}Da|G0l0=i8Ip<3h}tRUi7mf&q}f-3QJOYqZn(w?_lXnSxy znu`{j5TS*$yqv3O>CoZ|%Qu-SmHSBrve3%uP3P4!-xWrM!3Thz%Vxj%Qe3moRmyMU zH9?WSL!148rGK=@g7=;j;V=~hxBNTm3Mv~8!VvH*hglk)P4CtPaa^9GT<*BXrE#^% z8J2#C^h2JZaup_J`Mc1lo6D&VEpj>7Qt48YOOF{cqJ}KbCYK%Kxjb9BJlCO2St^%% zJF67doFQDUmR;!doU`dU;rWiCJ3+ukR1joD4NGnj6Z7X-g4Zj-UMDz)e#k{jm1Aik z0+H4XhZdWiYpMK^9-|!UNpU@MmPq2$$Ps4E#Anl;l#We&roq0^sxDB4_e0^ts5ot{HpsYjyOKS7o)*jfHhb^f_N@{wP6qB8Q z9fs66H>rRnHNUlRbzPJc)0_h@IO?jMt8?9?4t3N94p363M@caVzjPQK04tF(p+NCB>xXgu{@!!cFQVORAfaY8xd*FMMy_ z-^=P~H>nRgsI0zfB@NuNGtxkMNy%YIt-i}8tMQgpiIQ3uCB+mbGeXL_r_VYG?21k@ z+D)pPC3UQlI!j5>M`-OBF-%z`J~Hii*LdYPJTlL`5I5XO`heq=A2ZNQZs150^acQe zr|b=MVZ3MZZqbrveD{i*Iz*E>mr%#iMtW+Vd^?F^b+wYj1SW zReLkm{_VUt=0^&8TZ_K(G-3W`MgQ~G7o*JgCi-lP9+~J%Bf973_NwAxg6=(D(I57? zm>1D4PWaqL70eT2-}b(GzHyy^<6B(sybivpm1Uln+qA1^-pc1Dv&TU+5acE^-?#&( zk}vP}SCCLXBTw&fJzcL)m-1-|o;vAf1z5frg2(GX5xG8lKCb&YUnAFbl9SmuOcez^ zC)@U1L&71?{fPij? zA^CBEdvv~bBnaRA9dGG_>mLswI9t2Qg${uv zm^tz2|9O|_znrD$&ndbA&>S2}8~zwi92*`XPrdz=w@>7S=Qc2ibM%cTo+-qqSmLKD z@iqX0x4|+6Y0;@W(>NaevrXjfQj5L?7t^3=n*aoQN|LK-Qv1f)agupK(3@HG2NZpV zqG#4y0AjXw40v&0Og#F0LH`);Ou=?k^rsYk;vOo@qDxr1I39hhwEa$(yz0YAyL^s--zgO15y9 zOxKbxYsoE6$-AZGo-+ULcirwjUTXDIV8D0*{6-?hTV9`<{3)CymcKqkT5c?%=7O)bj+L2Q0g zibt}_XM7&{AZ|^2GUyCL5ANo}g0!#`i)*LvV6=P0SrH#9$7r1M|ylcbyz; zn>n$V$Jc?m{&_bhTWRuRF}J-L4aIJ5-zjrrGGLmHv6!>!!2ENJ8&f2-Z(dA0ht`4V zk^2!H*>Wn!tcb;IUkB#ZN4e|dVBeI+V*Y1&?d?q1!@;mqXG3E4i^Y7S4$O+0T1kq< zEUp7{M$LA9GB-v-ed@pr*KFtXSWIsnm_JLp=d_cHN9Oui%n#qFT|zH>>XxlU^z>NF z$LqixGtZ4F*7x)CG3~sz4$Lioy0sz;O^aeNTh)R2Y)#BDv6xlMYH#OLKe+3xPYL;B zF<-6&Gp(h&ow5XVL@efAbzv@ZV@ejjX-@`E2WrPsPRHSFt1=^u9uJ+l2-rk}=sp!)bJ?UFlCyxd21oM16`sISY z`!r?#B1P}3=pzHJ+GU|SFCM+m+hqP_i+&K90GK})KrsKwCKtMNo@d0PXA1fVi#}h` z+bDX)87}k`GXLZBxV9fD=$$P3m5TnSGVj04g)ZZ+`SIv4tS0lnpQ>#?O3`Nk2zfI9wD)S#Sjkmg=aTj__ z&%aG-KgXgsSM<$V`x)u31-^9F{!%>pFhSpUine_t;vAU24nSwGU8J*Lvsy1>#l}Z( z=1gvxvz@$o;iqk}JiRVNXIY{*DbWSWQ;Tf7XQbgirq%bM5GPQud1rZA5m=-PdWjM0 z()9M2JtMba+kTBbx=c#g3CTjA^hTSyaL>r;LKjYV@LBmZD)x;b}ezaGln8qf5L6#F&?oIYgIvSE7E|_uOkikBNwnbV55D|a}=I9 zBf0kS)SH3@adWIZ{psZB(?gI1jG(?Qm%nnC%a_k))z`&Wy<4h&0VG)Ui-PXi$*LD$ z8P)f2==)JwmyD*#!Ta2z6b3HdQuO)1xguf*);=R1{X9Yc{v>7oAw_Sm==FV+n{|1~ny-mRpCRbaTl5}^UZLnc zo4S~n&ZMP9kIcfIPtkeuh>n1>3o}kIzz!<9P0ixbcRUi;_5sT%x-)F;(*@nr6F`Wr z*P@UxZzlXkH)x1LHu8>5%VTYQSUl9Fc~{;@9@(llvpeg!UCbaa(s+gziMbMEaxxfm zUujN?Hs*eh2Vi~sQ!xJ5bE3wd3-dc+GBZlY_#-{clt)?2&JXEI+_fM{)*d9akmuuX z7!^5h{YizBl*%S%PTG+UL%Zqcrb8_SJ;z%*?Uc^gdekH7OsbuZWV7|%bQpqzp7&2w zem=$?C18IVcKErlb~v%o(C|3UQxtSpwo5vI5pFu# zt{#?7Q>F84eWe4B&4tk)3E_jwH#fViR>mW9AC9w|B}-{Hzn-8*|0){>WnX&3ngFHayhWBs-K8nxIWJBCk9*mmV)MgQRsnXR82JnU9fRD6!d;cD8g7C z!X$+9=5+8K^qfzR4tganlzTI=3K#UgVoSEwl5KQp?!AAzyjEs!&Xj9?Ic)-GNrIES zzL@AEE&4X778NZ35Yo^2+J!FRwn{G4g;9vFq2#%gzNa(M;VKgZ-P@MZ_g}`wYnG7> z$D3K{cDzt>qnII_7}>p#tGrUVI7&ANdOkm1DYqo$kf-Tqj?oVkav+a(V0*jFoF~8h zn>%xnq39WIn(El&EzM;p0Gii->Cim%R@4DNQ~RrSi8Mi{zoO}zkEgl#ROjqyY4%o{ zH-D`(p?47SeEWpR^UX)?>$FRMA_3AzB>@PB%NIQAi1>6q@4UqU?A%D1*Ao_;_9rW5 ziShv6@R9+QRUSvX9z=8=b@Yu}2u=d!Jg$&D=qRZ#>1CJxMEz|l)cGR%>-QSH#JD!Q)j-Q6-|?-Y;zEGi0m##;21=)1uDBU=029#`8%^1tJ)I<(h_ z*~}93?iPKRqCcwWt=@Mr54*_8>lT5_0l(8HH*~$oEX>cjaVEEdj6%TZGpOq ztA*dC9jrE~t?}nzn}gMBJ!kvc)vF(WVj~dh{s;>5W{XGKBfM__;5iE@1t2_z=aE9) zi!5w7VQmyP-NLRSj0c)fF5SWcgz=5tfPM6`R?wNSjtWb%-*VLo0+>qJ z6M&fs_=X3wj^KmM<{m!iDTO_!A}*U-?ejdul{Y_OUM=*|Turz2&e4!(O9Bw8Mda6RtW>t3+(Dzrt^H@{6iLgI*3oL9kI*_n63cH&0 z{RBLsfU%bTXmci^eubXSVkZ!=|7W2!gJT<5orkbF3VUXXiu2btfb|oY=ezDYZ{&#c zKSMYcAYc>$ z-4rl|GP#L>swzQwh9w3O@T3BY2#Zec?S+xU%8y4u1nBP^t_D=h2+!UiZT#0oM9Xr_RC zve1%%HD3#*<^&u~K!E}dya>RdGXO|az>zGmi-3=I2+Gz9WpXQF#R}`qLhA^)L;t~iwUUSCMBMn0l;|#JSl+gyB|`1(+O*%ux~A_8Daas#0z06!|&k(%*}%U zsDu6Kcr;F7vndoqKoE@>D&RK)t|nl`XM*x80a*lGuYlbIbR*yh z1$;`tnFPGBRZtcaZ~_7S74QfFi3I%isgx)nU~g*x9wh**&Lpef0Rr|HPg3^h67~U0 z{q>2UefmNNg_@t%}uhNWC{DFIUzu=_XwdJ@o4 z0cUgupaTJ$-xZX0ERjmUFa@+o0Ki8;6InA{W2>_r_G*R2Ulx?2HLLMzNV<`$vA>he(guOnG15iwW zUjcs&0bn=*-))c*Z{Z?yb1eZA6mS=&=uLkD+AH8Y>}@vP3HWHepiID?0CN@rcPpUT zwE#3H;A92t3j)xXfYs{+r5=_k&Hgk1@)R&^C;)~4uPwn^J|*ClwSto041l!+3>HB5 zSLV_G3HbPJmgv5p10o3W8Nwb=*wxRYPz3><6tIAR`w7^&MzD?z5^KG=jj#%Vd9FP> zwij-HsnZK5htUhSRm{nA6te>{KU$3x^N0N(qvlmL?}O=z^WK=?$>+=s{{*k#8^{aK zU}lmkV+ednmw5p5+wFXtIZKuBn%IXy6IX)CO)g!#6}}rNKdowg{CzX+K_62r`JDFV zA4|U_>7!m;kZ{&;rJ4w;NvlnFQhkF|Qv#rhdrMEN+TuDs?mDj?ce8|YK9mz!8L&5* z$?7a$qzQaugufwYG4Qe}4&$&ATw}r-%4>)ehR9>a@QHDQDnP5>VHn8mluIlPHVm%#>VKz-cp7 zYVVP0u@CZjl6B+0yKaR`SobSV-TWkeA}_?nNBFBL2V!sMu+JlR7jklwjkot}q=eh9 zjl&RnPI+uRPf7?6b(i^n`#dVITJ@P~4u0@}63mo(b zp5jz`^~A%fwBH|4>9mMS7qRZ>t+|eT9hEkj9IK!xf3?c*|JVMI8a%AL@bavwab{4W0W zpUBULXc{#=`S!or{!+&uR({^y|3rT8PxwD2za6EAmEXHR{}cH=gn;^g$o^)Q99Djz zpZ%g13s5 zTCc6P+9KdR0puczTvTofSiH=-UJ#XwRP+CQ-ZL{hv)SCx_V;|BzmH*dcV^Cc&wGF0 z^PY2VuK)iP{_eQBP5e!ZbOe6`p`csjKgL_!Uo=6ybvAWGo^Bw25SaXx#LU*bEUE$0 zxjrJF0dOJXcHI>{Z!-biLr$pm0@cQRF90!r!qP`a+7TFHyE5bu%GoG#8VJ)R2OtV) z3tM`REydm^{M>KX$N1mguT*6ze#JI1F2Mit6a_zGS*ux$i-EtBXfS&d>L&=bxW?pa{56I=u zwag-pK^M{2o8xE7>3Bbz?}JS8&miW?YzzSeG!8h-3%*+;?OD0bgV^5l3EFE3p7$>B zz_WZu3-Gk`{u$o)XLj`c1>X11Y3cppzz6hDEI+C6sVxMpClC|h*8aG5GqY;d5yapW z(NhU>lOO&YqkLGf6#K`+pHo^I@9sN1__~iRC88hpQEdjV9Er^HT|_#m|M3YT$_jUU zD&!~7yju>>OLh{e{n^DMar&ZV`0n(;x97ta;A1}BM||4)J|=rWv!(U&_$kv&S)$ss zcA@?Y+kDPzKeQRoD0%j@iDR)sMWDk-?$V5Hqm7Y;p`P=<>WhN4>$z_;cKk1LDJHXb zHz*bC_)ogw{KwUQf|SGZq%5;4@Io2a;bm-1e2PU|B?_rDof*7?A zp3V<>;2F~bJlYIH;UD^XB8(UC4@QacD9B>*s8B-iFO(4cSMsjUp+v5>K-mn0WjLg_ zE@wL0#^-)!`VvJH&_nEG94UZ$$nnzBCFVc20`=o;)Hm0!|08%SmbDY!rVm<&cS=X( z|E`&8?|WPR(RRH2x1x{KyB7al$#)a!%a-)*&|mZHAIDz)vZL=mUf_BE)Au{r|BQP) z??2Je_ZQ6fynkg!-+w#{Zj@{MExq3ndR}^{YSW_U`Yj3QIRW|r>YvBDLH2TO|M&t5 zRX#TgSI3GeZ>`XgMxCET8X>sityvzk&z$?MlKfmqR37F}e}O&VyPCV%c^%zG9KLl{ za2}mxwF|dbpZxsrO!dO^%wYo0g#QIRW~KBkItt5RXz&DGWu&x)pQ98!?`>`$emLLf zBfV^UuHqS)?_=Chg=|%lZYX+zu$K0O%BNi{wQyl^#GiW#F2=F%`)!v#7&qVdGt$TO zwT+Jq1=F%k?ZZc9oISJRyUWPGg~SKUiGvT}+H~F$G6?^Qg~>J_|50gNSd#!q18kL( zTot6073WRP5^VJWWRdG&BAkftZZh-jwukA(*F?aF=3@S=qSwU)B9HJD6TWc9VdJfp z7@>^Ie$Q%&0MiDf+4xb)D}u#yjuinpCD?JC#|?)HY1p)-)mfhyHs)*8G1*z(R<7!KpkO*z=g9o z_`@y0&(47}kc@q>EJT)6A9A=O4Mb>oWVQl?dX5jt^212B=b_rhTnEGQP&)cFmpTst z)vjTi!`}ta7dSx2!J8Q0HfITuK}-kU-+XIf4F|R4^=rT(V<%b|D$G^m3;B^mTfr^T zJYWFFU-HR(J*;DlM1ru8Jz{6D?_k@OPmPZ0>7;#jRz5ipB55+_{Ivak350=d}c2vfQ;;901}B zrRY6ahKOTu2H-i#^HLOsH-AoKz}&SCc=!P;KwQ!gC(n|vgi4Cn#mHCkTp*mqgk5Ss z<^7%1)jQ3q6f0c&E``pXC=E-~lu@OWyVUGIGeoIf1u#^;k~+3ozLJdq^-!9)T4h+7 zkqMoDu)vPd&$1JeJH{KcOrc24PF`?mT~~6g2u2~!`AmCs7|dEYBjb}7lA<3|rAnUK zn>!|AJpEIUd}uEza)J#&tp9f9n_$kxem_}_+zZG9AV=B))cP((!dOqF* zAL`G1NfG}+HgW)e3_c4#a^^blLw;l)s9^0)T^3<^6+=^fNw7P(6D%Hp4uTqZs3B@X z^gnVCw3s&M6&J^N`giEl*#RNefBW+NZvwGw69OdKJfJMQFpgz>3f2HCE#>!l-$Q?brzg_( z@E?oDw zIhUMppI1I2e~Jg!#ebxKyXt96MLx_?0wuH1wXCNd%tn$uv;&aVd>;6Z;X$1K&HWLJ@;jFJ6!|sZ z|D~HBwFQ(_*m{uPI>KIX418K)j4@y2cUCj;?L_dWJK~G%^zqUA?;v#k1n3DHas$2HyDJImmhz^6|^B?)tDU%%x-n=;n6~u zw|mJl06WnR%o5p0XTGl)j9lwLZx*ML7i_W)kL7Wkp>eoTiEB0d`>$is*f5N(41a~t zNjUPfU{y;A2eGf%xy9`Caa=UUC`-~2jIut)47fYt09aHsW`KS@4vN?>L-hp!aCVc6M>~(wq71)^Qmeh)@CeD+C_L;W`RIjCn|B6KYH|ICmIqZ>x;>I82De?0&A$sOC=b<=6q!NN#;`^W6 zynl$9h^0GsBK@bJNI=GftjU>5G9=y?w!=~71)GAsB(x8Kxmrk}AeQ>fynYEdqRQg) z1HuOvWSMt$j>AWc9|RvFq*pr+#o^=I#R?xBNV<}q%+L`S!=Z}Sm_)b7ki7(8@3DBu z3-3ta4+bDU|6jybCI8=BTaYvhlj%LjsBA1a$O`MAS0p{)tl$cEqAF{=<7+2>VqcgfGbJsK9;uFe#^~`us{K$LJuYud#GhBUk3XgV zOEFJx^JhQdPg!gQ_6&_n1z`_|42OoL7c?eJ?g?jZYXE1mv??*a6Hq$nm_~kZttSKx zMnQ9=TA>*h6|%gdU5g57A-TE`7y^?7+=~j$Y5U0}4tGqaC1Y0J0oY5w3*+&pZ1HeG z5BUVyqPP`ltIlt;h;#4v!l}=_29nJtEO}(2zmbU^_x4|!SUzC&EcwU{B^eNp!-lsh z9<{2|0qpdT4gwai)90MgyY*W_$-I(eDg(R9`p@z5L0|#K`w-(DA(U(NXBpoePh+l< zG!B5X3E-_U0KNEW%|Aw>%GSYXJJmdGbUb0iajtNA5XZa<a z<#{{p--3B@(eK`w8S^AI|D-KpvGx<#N2v=J``8ByNYX-?+JeGVRKy(tmqwEbH@L%= zja2JMK8IZ}&4YH^T35`ayDmJ|AM*ok*8^w^lO_Ox<~v*4)OdHI$P^C2uop4DcGd&5 z(_UjMv?OyBd;roBL#CdoZH%+m;$-!89*QIC{1*Tf{7JTut}T@CBU4*=!~|Gctjb9Z z4NGl@|1>tSeegT>p&!hXg)&&eR5Rm!g*NmjWu}&iMBrmheujD& zToR*KbNc@IBCmttC5>z` zPQM1!Iz~U4P`fuZm_29wY$De%(L zUQ>?*_{d}Co!_{*4ri;QDU2d=VPbpVvOfF2Y3~M=#Ot$W_U_b$pm9g+U2FDM)QuUy zk{!hXU@+loA#WK8js8cg8WgK8;U5b+(7)xQ|3XR3g2I&A?WqH>*C|*SzIkk|$To87 z=H~h=!TZSrFo*XO-uDeao}<0*C*&{LKOmvK1nz#)ei|)W%%5*RjqStYIm{w+%yzvs z9~5qFKaH3^vFLNK(05sqi=tnUqNbu~?0MRY>!JS&89$<~fd5!+Ok^86{d3GTt1=@y zatQa_edtq3YJQuhF@qY*Q9@?P%dWGz!O@a(;~XM}l#kf2aEbZruS7q7^Do3Yf1pZ% z1FzG8ckOCnbDvvZ65e*y)BJ6Y?FvGGFty>XrV=CaOn>rMK)l z1k}>7rY3Pcji=Zk2h;Gbj7?k-L1(!epsf_ZrP#oH_MbpuYxOi!Zb(eus~!3xMg;kk zLnRy!u}M(OHRDRwv&w24F*UN3!I|)aR;qRpc1T@m-EryWdC^R-QyL@KN%q4=_4A3zQcn;>jN3);6ncAeVUbl{TY} z>ZYZbKzg9nq+*iv+n2jMIQQhpQygVr(F2CI8*<9bKC%IEQlD`eh$Bq@e}G#qc6&mK zr{mzgrv-RD`SRc&bR>q55XavnXbe^^t*Sa*it|oJppdOC7?+*DDR?Bpg~PQ4!w%0+ zTp-3Al5S9~NR<-v;w671AuYv`Cpr4)Q>apU%$)pp3}8gF0eIk-`Nm4xhYH$<3fn$l zzPSn_kNTt2y!A(Kpitj?2n)OxbK|XQq7l)-(#j=fK}6(j*E8TLnQyM9_P6GnWBoVx zkAp{0euTeZ4`&2R;90k+y_Wsz;_F#`X%#RoCY?&V?-D&H9#Qew_A@eAw zfjEAA^yzl-V|}~$5f#4ib2rtmrgCL%@z4}ym!hZtKQ%eroReJp|}7S&^|*fCtd+HW19D5p$UIJH3t zHL*_DnmU#vPJBQL&%MsY>os=}Lk27&9MeqE24=-_7iFNnF)OGo7*FS7Z*uS;%7Q-Y zXx%{Z+6vv+6b+eUJ`oPj*?lM?cbB_T2Spnug)dzJ|tnRmg=6B@^!0b7>-G#|g+ z##kJi{_s?*_UyVuy4|ZQOO@}1c|}C}0~Mo|0S1;Xb0%>`OOsLn zHRct7D^dw=^x#9AaWA={_VZHmpHBYM9sUzh!uZSRC;uK$0f16yaK$~U0F*fbJR%$j z7_Ev!A3s%+V!8ZO%};seahb|z$tMqkp7tcQRS*UTS_kK1RocECLe+mh36M(wG6`EI z+$G)?BJ?X_V&xgnly>LCPxnNj5F+rL*JYlppy&fAeri5EVf^;f^5G!Ze>>lK+}UkL zZ`u<;PDk{6Xc~@^@mW1^Juyc&qaF--s4PwHyVWuHk_gbm(J@?Ph-a|`_sYZ`Um2eAlBPZb)uL<%s3B+h%?4Z zJg*mL4_~>1i0}q-i_A|Sg(y!Fq4mmZJL27_bqX4wQ1PzM!H0Q_VdE-Jc&DJlgz@ex zO5f#D-^FTBfCDHt27OY`ahfXUSY36M;NTLa`%s-wuqs#zjSNi(jjYr&%bdsIZxoas z%kCE^QqL?~5%o-$;g7RDyh8Pizc+P*<@fRw;svuxo{Aw7z={4gAN&h&d7`5LWB5$q zPwM0m@h4GG06o7qZSpVG0YDk^=bVI%u(R-2oD9K|GGokQ$K1}#Qr0s&K5;9Ru@l4m zowoHU$NP+nU#7qVZec#d6T8UTmeb%wC?2*LJuW`MnNCS&hVxJyqtAH+6mC{;!Sx=^ zXp1*NT~YDS9}In@|GO|FE;5VBi8BZYsL#BHtKNdnAY7qgz80K81|((|K+?i`k9PPQ zW^@}YoRG;v17=7qH5Zfj&Tw=TuHw)T{&TDH-Yox5lWfqr5_BMzl>Ui^Onb2on7Oc< zdLZQQ=2U4wMkYev)M9xShW({^D0{xs6~89TU&?%NAt)*H!Nu|cgGC=d&HllED9(Y~ zXoKW9e?Q-R@Ns9v+drM1LIF54Z`wTIpd6DfW9P_;M;+@6VM<1+4LXG2l7HX$d5YU(70|;cnHvkVIHq6Qw8Y5 zuq|9+_k7D3xL_btP#*C2iMjhvkO^7E=+;jjNK~c7|6%?}>E9-QeDzQV_`}LgV_S#f z9ArTPIoTjW7G_U-U=5?%eb2X~uA%wvd#kCFR~}%zV_wBW5^R2>zY*g%(LXXxIb(YZ z`X_@UY}wyv2fwp_oBxni1B2S?2inJ;;*8@n^WM45`8|%)UHp}A>z@HXoBlz-UYs-F zzp8&8=@-vmqV!%La`;o9c@Y@U@al49Btlu)SZ%YjykJrmv=yxmaHl z5%VlS6q%ABzMy z7v5S6@bHmRLLpv}s1Bd`>DpCQ zXG*@Hua&fg2ujI5^95K3(n11-K6BipR`tykOE`c^teBXHK4Cs`H#m;_h1jH#YYblr z;{SldZ)Z7K9>^u=gc7oJ#rxpUT9mA#I_i?ui;|GQ2&RXUt9AgaZHq|2=r?A?Y7awt z_62FRe~BlgKcrMtokh6k4X?4AHNos)5A34{YKaJ1V4&MCUyyD;G{1h!)9t^=BY%(e z2maS)e1vDglhve8C3&*a;z_N3J#U4qEHkH2o|7LK;+KMRNfZdEyGVhPDcN{q79Ipt zKJ%LCN*(A*9WW^3a;XZnTncA(7Y3k3$^ziL@&N8apIGZ6vHbLYc8BGX^W^%nwS=lp zmQV%o9I+cf7Q8{Ox80r+4D=mKQme@@PVOAU9fN@!#5tBv0*NGGOB z2_ymrZVEe80oim1fMk6?1-p=feJ_c2r;B4f^lL|cBxYYz-mzua5_C|no0`uy@4ePm z0&((vH6UtPzNd7^zLJ5hB}$SI-IyrVM~EDgcPb{)>8n|r$bh-mm|JE8NB<4`Iw@O` z35*?pRux2mOghPA+1H2P5MC++2<@}4?W|9h^-Gtov*{B@gUIdZ?kCkJOZ)%Ee7Ybr zu0HuzHlMIQ8AxE#16lz%QI<;b4gWXeox6^A`A<-r?wu=q5X0Oh=FMTCqP_X3mi_<# zoA{Y@T$}j0__hwDxB{Tlxvg)YeZ^DqGM`Z-oF+EB;5~dIqTU zW;tzv;Z@9pi;N(dD@ERU(C@ZLH&|mn%S>(2tSbj4Fx+12#%;N!RTlEa>#h3VG zr@^bB9TI)T#8b?1GlyQ&0=^!)wKaTA`Jc?MZwh)aBU(KTa5bM_Z%;kvmfzb$1=}#+ z>q5h8&OOi@)T1I}0^YpW02<=rdGUwD=}0gKl4y?4wOqO5^_-(IFYaQGxO&brxmL^`kUu3k-G9Ov@W`Lb zpBh?WGi4mCM-kQ*_0^Qi;BV%7V5FGc^LG#wsTeNbOneN+Kk`H5f0(gC8J9ak;uFqid6>^)t=P5-)@N3i=@^l&9R z@hCmqhaC^s3s1Y&hXNT06fh|V4ox?Q|3U!*^iY08@NuJ%3~QPBjX2*HfZSORKw4fO znjjubT)*mr^#TCYKIjb=qmQ+Uxl;P!ND<1O6>PhHb;?EY^jG*FLHy@2-jIn_m@ie| zRVa4M+M-Qn2vHs(dXl*Ri-UW9h~YoM_>rAJCW>$z zB3qfohFUM}J420~dm3wx{(z40fhO_!52$8@i)Rnan5U3aV0;qnzpfE=kt@=h&A z@(4ThaU`#DBrka2XMYEfZ+Y-ximub$)2|BRu3&eq=UWos>r@9{MSa$M7nYCx17US?4<|C)As%!=I|?R)dT)V*y`GkF%}E%emzcifhe}G)x~K5 zu)4+Ol3SqQ+t~l(DUPa{4g-BfAwxE}--lBlGEVY6;8RwULZMj|dtd_iSoZ!OEtiBq z+*$FFY0kVFM2h)Z^eE!WL9UP|Vg{8dp*nN+bd2cNPVCWqmlwtYnd&MEEkz zQR7`KYs51{}3ZTD}!C}{rk&29GIcD!OPKJ&m3@zLLs^+o- znQ`jNAV>Dzrmk{pR2K}-v|SsQz%m!8@=;RmAAq22#dNci8AZ$7clQNz)=dzD$w~}j z`Z@u>C9JQ%^#u=mb)>%Ds~_)q%&i}Ld-UT8-cDlrkpib209+%7?Aqr|@4o51f77?| z_haKF|NUI+i$2-CPkck5m~H`lQ6IhL3TgrP&#dW<`Op4E!k#J9I_^Io!2b8<_dh7u zpkbNk5sgqr3Z|+bz`TQ&mz>1&0{yOBkoTUFwGq|fIYY#!gdn0`f7ed_L_C+v|ao! z27hyWX!XlQsFV+<)%{bxsd)vk0ib_FtCfoOP}Ul(DMIn;C~z=0GAvj<85_K(?hFr4 z))uV9;)q?^NsZc=mAiE9q&KhxsaI2@{JsvquLZ92v@u(FZ=*KmqY2t69|n)Up%<<@ zf`{FZh3jJNZf;-=$*_na_d4H@3Z3=oF72XK_*;zM8u488J@Xfv1QVI+a`^LZx@q;Y zf&yqbo@j`TpYq%eeSYLct?P5CrCtU@O-%wb?)8aEu5VSJ|JUnV-SJULjM74d*ndW}zJLOKa;D%sz6`l!QS6rd;FzEB6M3n7QHn5OoZq0j^i@ z|4VdC3W4t6dWD}$Uw6(?z8ViB-HA896!aMedOXc{n?u_R}GDoPl(#AKWMI> zf(iWDqngj}A1=MvYB1QEKYIZ7k^HR_-ZA!#=ieyxp6Rx3~1s z=6DmdU%z+!9=WGI5#!o(T^>CLQg5gEgP!7TMR<`j-fzNzr zGNiB7`Vqo+VEL5lQUwJd6WI&c&Jm!nQb_lp90Z&`0#N*fd`bd-KR5yXr7wpfE%AE- z`X^{VLA}h%XFL>dseR(}r^!>^Z`+iovjrA&_qA=yQ# z!kte(pCT{yZrJe(7LKlYH_OMs9Z98#qalh|6ojY>pZUSt3NR}?IYa@r{2BmOPYIFm zSubCu5W_=DPv`{;T!%TEDBCRFLL!0M-)2aWddj5~*BM$e18hse(MkGM8Q{Kb1= znmI<%Ae@`abp~ku)oB3g%@wYj$rwc>;PU00>052ao`mq{C(f^Fb$`a=%&}>8cZ<)( zQYw~URN~5A1ol_OQg8?bvE#0lf&;IOg3Tzy6(`TMBL$Z_4lEL%f@5)zByem;*o5XD1ZIj;sZjIYEg{i=Q z33fD@|E}6Y8(6Ut`xP8ZB`uLvv~%Z^A{E03mh9RL{*$5|9Px5|^tO2ZOQ4@oRc6`e zlW^q8?|y+JPeK{vcmXHnfnrJQ69W=Pu|g&DaOu~v2QRU=1**5!PJi9)trsLZC5;%0DiZ90mQk4*lHMzW5fG9Z^NzG7oO(}d7_K!t~wDsfgP2q z2>G)~z$V0*lKW}NKYs2iXoZJ~Cvl7wp1l0xPu!pQP3VsabSdgmhwr+36HOt~YfUK+ zW^aFXdb9l|Pk+w&)?mDea4IlH-Kn>eqpgG$!Kah#c@X?iPWof$*6Q#~eyZee5Mpa} zxX;Y`gIXO9fUS%Zl)`wbQtKcG=RjGz!fvjrume9^aaiMH!p}GS9{kMntvQx5gcMpm z*NcN4npaP{`HlAHXN$+~?7;p!2P?Q2{|<0>aQ?X+`GFgUdGvj=e6Q&H$Dg+KeVk73 z3!qx@9}?sTK){6gUS~ZqH!{GQVtZ+i%Yr0G_Uss#CgDL+-b!TpS9r*y58EG4m~)o6>@gG{3lG4}nM}?=$&F`-mSBeM zi+O_l$FBf$v=N_Ee{ucu&*MK7i=)a}?H2uqkqWjhfb9VNhhvCsXFfg~-a{X&^x!+p zV!MoaqWSm)_Ppix9y_4+yz@I(MYu5_%@)|&cMQE72i_sx_G9xqUVizx?8_&s6*ob4 z+s^kr^(Wz>OE2rVeQD2p2>93)|Cl!pRHhI5hQ2cJ6>~MLa4cH^wDwXkb?ft~JU;=_ z!Q_cMKQn=Rql-TUUy9vBo}lGKs75mxBgIpr>3Yb{2DZ0lakH)PESDJ1RJ#;j0pODJ z6X-zb%t_usUs6TUUV3uAGXZ>8TJTAcJdXgeU=lb5CSXUV(*!!(JBx#^k{Y3!OA2a) z*PIm6{g(hh#?KCbu~qM0_{soZF7c=Ky1>@CAWD9;k7DD-?Wxp3d3y3j-9SWv?ofX; zh^~N@D9_fL8n8&I%T%l}_SPU}0S2D5>*-IMA*pds%nYM0**ZW_l+3oKfjo_}3k6V6 z2mmsHmi|BpqTfI$H6OUkPuB}J29IT*zJNeh1$7Bl$~51{1hm9yIAQcj6!GXuq?`(; z`4u|E{%Tg115cjaeB!PW8_&ng?`_ySC>c)D#@!y@ah5fr|3$s!t6zmFi3yt2G8miiqTCl6?J&Ywg zX$k*LRtHB|_RE9s4#R&+0{By!!+&NQ@TdG-@E-tw{%v4${yeoge^y;|fc$ytPvg%4 zm<4Yyf3Ep$Tl{$d`01KJe)F2+XEgdgAotsg)BENHW z7$fFc+9AKsj{h&<=c)wwNo|gw{^`(F1Z&YY3{tWDlyFUM6=bpGZusl{WW%pQMr~UQ$ zc?n}?*ZJkF&u84sv!8i>dBUYCC!PrmORgznm6Ox&qVIA z0$un}*>oO#>}+ERdfJJNhtbQgi;RY~re3gf^7)uct|`)9+@3V)#8B1p)cW1Q&FX7+ zBd|Ob@p!J&6@EyMeu1abqZ=XTu^SwZ=Lho?1(eMkxW@Pc72yr~Sw&d1oQCtX^y!~B z(5p9|mW9B2*t#OLEW__fsJH(5?FVolXPIm)P$vV43tXlzFZ6NmX7Y4d9ro2yr#A8> z$)D6oUR3K|Co7JZsk>?NG}H`~2zO_Id`wD4Rg^Zn2inrZ!;*CaX}fUhU3$3Nl2Ff& zFYTLLzfP-v3)72w=r-$I$ZkAEVF@0aZ>?^24rY&_Fkd!C#wg+6Llt2i^$J1>1f`oN zvJ=7!(qzG_FD3_&+e=mO2*;g4b%iqsWQaL}8vFnsxI*HTGChRjv~J7{ga)UVg!N>9 z!9H#FB0Rw_0b_Xj@Nlo1Ksa@4aVX;iz&`|qYLi&RR)H8|DmiGD)0Z~jD_7F*+54bSjxG=S zv=iUvSA!HG*=BJR=K+jIgc?p;VLh%J2y?_u;tto@0fs;3g*l!R2Y@&T=2S+uV=_ZM z&%T6o!o-MikQD>(2WWn7)VquTOHYw4m~=89foB>;VPD!IqDGrFp|$z z=75}_^>v=Lx0fY~pb=11XEq$)8fcG{3usvY4It^p8?uA&-pFiV*6c}OOmp=p=&Viu ziIxAk<)tnsn~;deOv(nLr+;2SK7z=U3)5Oxa9TCKYYWnA_8qLvJgiGnQq8_pZDu8w zIo0e-(Pn&ryEXedY4z9hwUC~Nx<{=pldNscF7#X1Z%e=3(Zh+uYGaA9n(WI)$@?{+ zDoYE)4g3(QMwD8Z8-U0J@Z-#X{URxeoH+BZ_&}B}C*7(++F~H7R9mR0OduiIQYBj? zuk}VkYrno{o8H(o5Mf}7e(d*wWWKAN%ev9D zhM_rDgIPH+;H7vx9oJ%9yP?BOP%z6Z0Z@3o7hcbf9F4cIAwdnGz;VuXGCT{1)0Yyp zOE_!+l2cWv3AHC*pkrjecz|Vbel{Mbgy!N39mBhwnf8^v70S{Bp`-w6E&T;+wb^%Z zFbsSRXr6HDgZ^+y2;qMgAq(-9ge=7sgyh|h5%R_H zF+%cf4(`Mz?>QI5y4W(`0-kTHTYvs~&F)t$Vlva)`djb>7 zSW3R(i1t!Gu7`_M59g{L3R~_W*zO)`_8p|v-wob!x@xW)Ox)&w7EA5KSF%(R5CfLt z-A=N{$Pt0iAgG36nI+-UtVhpj8o?O+5q^N@56$xhXr3R z+JWu6nCfa2_p3u0sD7Zhl8jY)!FsK>JN9{nJNY0JZOe-@)A3q+R7k!xhM_Q_6CR4QY&^GMl4?AtHg)ECHr!{~o!3qlVj$UnW;5B1~1CjWID*0ZlxJxCg z?jmo|n7_+{%`G+i(%Ym>14oVjEZVHVSJGx9uAmL?c91r2l(}fb_dT>>`!3q7h3ZR4 zn?GP)&`lf4Q#;iALtn+wh5#tq+$COeE3~=9dRO#pJZ-)`q7B-tAJbmi6jYHmF*a#t zO792E{LdoEJbWcdp2Za;;oT0BH?|VqX_FW|T4KgSRN%GDiUXpN?csoea z<;ysd5CBDzrZd|Rm(^diA}*I4-UdkuFK91G9-pMdB}1F>CWfVlCH$BpQB2J~O`CBy zLb95DnOfZsV8ohzJ+%6P)ap{oAUkGhb?bl*Iz)HKRmCQj-*^-~@(MjXCfW8KYxs~I zHx(?Nb^|qig&rEP7XDk%=P-wu{i%qMQon0z3c+K8qm~(c7M=iIZ0xJ&b`SX6``^;@ zi~Wk{M?=G;<4VuGn|Wb|%j3KJr+9o%VhsGxV$)~&5p3FkE7+8G+v6yN(jFMy7su#j z!SCy}roMq5pL*MGq^^O-w?=e2TX!+(11Q07r=xId)Wt $_%znf2Q!BM!tdMBZy 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 C)n)yz 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≪i2IaT4igO0; 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 +-ZHTVZhut+ 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℞bu$T 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