From 0b85f1da0b21fa132f185213ed7e5ad64ff6abea Mon Sep 17 00:00:00 2001 From: shuting Date: Mon, 3 Jun 2019 15:07:38 -0700 Subject: [PATCH] update vendor due to build failure --- .../policy/v1alpha1/zz_generated.deepcopy.go | 41 +- .../json-patch/cmd/json-patch/file_flag.go | 39 + .../evanphx/json-patch/cmd/json-patch/main.go | 56 + vendor/github.com/golang/glog/LICENSE | 191 + vendor/github.com/golang/glog/README | 44 + vendor/github.com/golang/glog/glog.go | 1180 ++++++ vendor/github.com/golang/glog/glog_file.go | 124 + vendor/github.com/golang/glog/glog_test.go | 415 ++ vendor/github.com/minio/minio/Dockerfile | 37 + .../app/js/browser/ChangePasswordModal.js | 301 +- .../__tests__/ChangePasswordModal.test.js | 134 +- .../minio/browser/app/js/browser/actions.js | 5 +- .../minio/minio/browser/app/js/constants.js | 3 + .../minio/minio/browser/app/js/utils.js | 68 +- .../minio/minio/browser/app/js/web.js | 9 +- .../minio/browser/app/less/inc/modal.less | 8 +- .../minio/minio/browser/package.json | 1 + .../minio/minio/browser/ui-assets.go | 73 +- .../github.com/minio/minio/browser/yarn.lock | 40 +- .../minio/minio/cmd/admin-handlers_test.go | 2 + .../github.com/minio/minio/cmd/api-errors.go | 18 +- .../minio/minio/cmd/api-errors_test.go | 4 +- .../minio/minio/cmd/bucket-handlers.go | 2 +- .../github.com/minio/minio/cmd/common-main.go | 2 +- .../minio/minio/cmd/config-common.go | 2 +- .../minio/minio/cmd/config-current.go | 4 +- .../minio/minio/cmd/config-current_test.go | 2 +- .../minio/minio/cmd/config-versions.go | 2 +- .../minio/minio/cmd/encryption-v1.go | 2 +- .../minio/minio/cmd/encryption-v1_test.go | 2 +- .../minio/minio/cmd/endpoint-ellipses.go | 2 +- vendor/github.com/minio/minio/cmd/endpoint.go | 2 +- vendor/github.com/minio/minio/cmd/fs-v1.go | 2 +- .../minio/minio/cmd/gateway-common.go | 2 +- .../minio/minio/cmd/gateway-main.go | 8 + .../minio/cmd/gateway/azure/gateway-azure.go | 2 +- .../minio/minio/cmd/gateway/b2/gateway-b2.go | 2 +- .../minio/cmd/gateway/gcs/gateway-gcs.go | 2 +- .../minio/cmd/gateway/gcs/gateway-gcs_test.go | 2 +- .../cmd/gateway/hdfs/gateway-hdfs-utils.go | 2 +- .../minio/cmd/gateway/hdfs/gateway-hdfs.go | 2 +- .../minio/cmd/gateway/oss/gateway-oss.go | 4 +- .../minio/cmd/gateway/s3/gateway-s3-sse.go | 2 +- .../minio/minio/cmd/gateway/s3/gateway-s3.go | 8 +- .../minio/cmd/gateway/s3/gateway-s3_test.go | 2 +- .../minio/minio/cmd/generic-handlers.go | 20 +- vendor/github.com/minio/minio/cmd/globals.go | 7 +- .../minio/minio/cmd/http/listener_test.go | 2 +- .../github.com/minio/minio/cmd/http/server.go | 20 +- vendor/github.com/minio/minio/cmd/iam.go | 50 +- vendor/github.com/minio/minio/cmd/jwt.go | 1 + .../minio/cmd/lock-rest-server-common.go | 27 +- .../minio/minio/cmd/lock-rest-server.go | 12 +- .../minio/minio/cmd/logger/logger.go | 2 +- .../minio/minio/cmd/namespace-lock.go | 2 +- .../minio/minio/cmd/naughty-disk_test.go | 4 +- vendor/github.com/minio/minio/cmd/net.go | 2 +- vendor/github.com/minio/minio/cmd/net_test.go | 2 +- .../minio/minio/cmd/notification.go | 6 + .../minio/minio/cmd/object-api-errors.go | 16 - .../minio/minio/cmd/object-api-interface.go | 2 +- .../minio/cmd/object-api-multipart_test.go | 4 +- .../minio/minio/cmd/object-api-utils.go | 2 +- .../minio/minio/cmd/object-handlers.go | 4 +- vendor/github.com/minio/minio/cmd/policy.go | 48 +- .../github.com/minio/minio/cmd/policy_test.go | 4 +- vendor/github.com/minio/minio/cmd/posix.go | 111 +- .../minio/minio/cmd/postpolicyform_test.go | 2 +- .../github.com/minio/minio/cmd/rest/client.go | 22 +- .../minio/minio/cmd/signature-v4-utils.go | 5 + .../minio/cmd/signature-v4-utils_test.go | 17 + .../minio/minio/cmd/signature-v4.go | 12 +- .../minio/minio/cmd/storage-interface.go | 2 +- .../minio/minio/cmd/storage-rest-client.go | 32 +- .../minio/minio/cmd/storage-rest-server.go | 9 +- .../minio/minio/cmd/test-utils_test.go | 10 +- .../minio/minio/cmd/typed-errors.go | 3 - .../minio/minio/cmd/web-handlers.go | 140 +- .../minio/minio/cmd/web-handlers_test.go | 57 +- vendor/github.com/minio/minio/cmd/xl-sets.go | 19 +- .../minio/minio/cmd/xl-v1-bucket.go | 2 +- .../minio/minio/cmd/xl-v1-metadata.go | 3 +- .../minio/minio/docs/bigdata/README.md | 233 ++ .../minio/docs/bigdata/images/image1.png | Bin 0 -> 330055 bytes .../minio/docs/bigdata/images/image10.png | Bin 0 -> 53887 bytes .../minio/docs/bigdata/images/image11.png | Bin 0 -> 46089 bytes .../minio/docs/bigdata/images/image12.png | Bin 0 -> 42895 bytes .../minio/docs/bigdata/images/image13.png | Bin 0 -> 75777 bytes .../minio/docs/bigdata/images/image14.png | Bin 0 -> 46042 bytes .../minio/docs/bigdata/images/image2.png | Bin 0 -> 69020 bytes .../minio/docs/bigdata/images/image3.png | Bin 0 -> 11671 bytes .../minio/docs/bigdata/images/image4.png | Bin 0 -> 109927 bytes .../minio/docs/bigdata/images/image5.png | Bin 0 -> 65551 bytes .../minio/docs/bigdata/images/image6.png | Bin 0 -> 49350 bytes .../minio/docs/bigdata/images/image7.png | Bin 0 -> 59429 bytes .../minio/docs/bigdata/images/image8.png | Bin 0 -> 79352 bytes .../minio/docs/bigdata/images/image9.png | Bin 0 -> 71622 bytes .../minio/docs/bucket/notifications/README.md | 15 +- .../minio/docs/config/config.sample.json | 4 +- .../github.com/minio/minio/docs/gateway/b2.md | 1 + .../docker-compose/docker-compose.yaml | 8 +- .../docker-swarm/docker-compose-secrets.yaml | 8 +- .../docker-swarm/docker-compose.yaml | 8 +- .../minio-distributed-daemonset.yaml | 2 +- .../minio-distributed-statefulset.yaml | 2 +- .../minio-gcs-gateway-deployment.yaml | 2 +- .../minio-standalone-deployment.yaml | 2 +- .../minio/minio/docs/sts/client-grants.go | 4 +- .../github.com/minio/minio/docs/tls/README.md | 14 +- vendor/github.com/minio/minio/go.mod | 86 +- vendor/github.com/minio/minio/go.sum | 81 +- .../minio/minio/pkg/dns/etcd_dns.go | 4 +- .../minio/minio/pkg/event/config.go | 2 +- .../minio/minio/pkg/event/target/kafka.go | 130 +- .../minio/pkg/event/target/memorystore.go | 118 - .../pkg/event/target/memorystore_test.go | 125 - .../minio/minio/pkg/event/target/mqtt.go | 84 +- .../minio/pkg/event/target/queuestore.go | 24 +- .../minio/pkg/event/target/queuestore_test.go | 24 +- .../minio/minio/pkg/event/target/store.go | 7 +- .../minio/minio/pkg/iam/policy/actionset.go | 2 +- .../minio/minio/pkg/iam/policy/resourceset.go | 2 +- .../minio/minio/pkg/ioutil/ioutil.go | 92 + .../github.com/minio/minio/pkg/madmin/api.go | 4 +- .../minio/minio/pkg/madmin/utils.go | 2 +- .../minio/minio/pkg/policy/actionset.go | 2 +- .../pkg/policy/condition/binaryequalsfunc.go | 4 +- .../pkg/policy/condition/stringequalsfunc.go | 4 +- .../condition/stringequalsignorecasefunc.go | 2 +- .../pkg/policy/condition/stringlikefunc.go | 4 +- .../minio/minio/pkg/policy/principal.go | 2 +- .../minio/minio/pkg/policy/principal_test.go | 2 +- .../minio/minio/pkg/policy/resourceset.go | 2 +- .../github.com/spf13/cobra/cobra/cmd/add.go | 179 + .../spf13/cobra/cobra/cmd/add_test.go | 109 + .../spf13/cobra/cobra/cmd/golden_test.go | 82 + .../spf13/cobra/cobra/cmd/helpers.go | 168 + .../github.com/spf13/cobra/cobra/cmd/init.go | 234 ++ .../spf13/cobra/cobra/cmd/init_test.go | 83 + .../spf13/cobra/cobra/cmd/license_agpl.go | 683 ++++ .../spf13/cobra/cobra/cmd/license_apache_2.go | 238 ++ .../cobra/cobra/cmd/license_bsd_clause_2.go | 71 + .../cobra/cobra/cmd/license_bsd_clause_3.go | 78 + .../spf13/cobra/cobra/cmd/license_gpl_2.go | 376 ++ .../spf13/cobra/cobra/cmd/license_gpl_3.go | 711 ++++ .../spf13/cobra/cobra/cmd/license_lgpl.go | 186 + .../spf13/cobra/cobra/cmd/license_mit.go | 63 + .../spf13/cobra/cobra/cmd/licenses.go | 118 + .../spf13/cobra/cobra/cmd/project.go | 200 + .../spf13/cobra/cobra/cmd/project_test.go | 24 + .../github.com/spf13/cobra/cobra/cmd/root.go | 79 + .../cobra/cobra/cmd/testdata/LICENSE.golden | 202 + .../cobra/cobra/cmd/testdata/main.go.golden | 21 + .../cobra/cobra/cmd/testdata/root.go.golden | 89 + .../cobra/cobra/cmd/testdata/test.go.golden | 50 + .../x/crypto/internal/chacha20/asm_ppc64le.s | 668 +++ .../crypto/internal/chacha20/chacha_noasm.go | 2 +- .../internal/chacha20/chacha_ppc64le.go | 51 + vendor/golang.org/x/net/go.mod | 1 + vendor/golang.org/x/net/http2/Dockerfile | 51 + .../golang.org/x/net/http2/h2demo/Dockerfile | 37 + .../x/net/internal/socket/defs_aix.go | 8 - .../x/net/internal/socket/defs_darwin.go | 8 - .../x/net/internal/socket/defs_dragonfly.go | 8 - .../x/net/internal/socket/defs_freebsd.go | 8 - .../x/net/internal/socket/defs_linux.go | 8 - .../x/net/internal/socket/defs_netbsd.go | 8 - .../x/net/internal/socket/defs_openbsd.go | 8 - .../x/net/internal/socket/defs_solaris.go | 8 - .../x/net/internal/socket/sys_const_unix.go | 17 + .../x/net/internal/socket/sys_windows.go | 10 +- .../x/net/internal/socket/zsys_aix_ppc64.go | 8 - .../x/net/internal/socket/zsys_darwin_386.go | 8 - .../net/internal/socket/zsys_darwin_amd64.go | 8 - .../x/net/internal/socket/zsys_darwin_arm.go | 8 - .../net/internal/socket/zsys_darwin_arm64.go | 8 - .../internal/socket/zsys_dragonfly_amd64.go | 8 - .../x/net/internal/socket/zsys_freebsd_386.go | 8 - .../net/internal/socket/zsys_freebsd_amd64.go | 8 - .../x/net/internal/socket/zsys_freebsd_arm.go | 8 - .../x/net/internal/socket/zsys_linux_386.go | 8 - .../x/net/internal/socket/zsys_linux_amd64.go | 8 - .../x/net/internal/socket/zsys_linux_arm.go | 8 - .../x/net/internal/socket/zsys_linux_arm64.go | 8 - .../x/net/internal/socket/zsys_linux_mips.go | 8 - .../net/internal/socket/zsys_linux_mips64.go | 8 - .../internal/socket/zsys_linux_mips64le.go | 8 - .../net/internal/socket/zsys_linux_mipsle.go | 8 - .../x/net/internal/socket/zsys_linux_ppc64.go | 8 - .../net/internal/socket/zsys_linux_ppc64le.go | 8 - .../net/internal/socket/zsys_linux_riscv64.go | 8 - .../x/net/internal/socket/zsys_linux_s390x.go | 8 - .../x/net/internal/socket/zsys_netbsd_386.go | 8 - .../net/internal/socket/zsys_netbsd_amd64.go | 8 - .../x/net/internal/socket/zsys_netbsd_arm.go | 8 - .../net/internal/socket/zsys_netbsd_arm64.go | 60 + .../x/net/internal/socket/zsys_openbsd_386.go | 8 - .../net/internal/socket/zsys_openbsd_amd64.go | 8 - .../x/net/internal/socket/zsys_openbsd_arm.go | 8 - .../net/internal/socket/zsys_solaris_amd64.go | 8 - vendor/golang.org/x/oauth2/oauth2.go | 2 +- vendor/golang.org/x/oauth2/oauth2_test.go | 2 +- vendor/golang.org/x/sys/cpu/asm_aix_ppc64.s | 17 + vendor/golang.org/x/sys/cpu/cpu_aix_ppc64.go | 10 +- .../x/sys/cpu/syscall_aix_ppc64_gc.go | 36 + vendor/golang.org/x/sys/plan9/mkall.sh | 18 +- .../golang.org/x/sys/unix/asm_linux_riscv64.s | 54 + vendor/golang.org/x/sys/unix/linux/Dockerfile | 53 + vendor/golang.org/x/sys/unix/linux/types.go | 2 + vendor/golang.org/x/sys/unix/mkerrors.sh | 2 +- vendor/golang.org/x/sys/unix/syscall_linux.go | 6 +- .../x/sys/unix/syscall_unix_test.go | 3 +- vendor/golang.org/x/sys/unix/types_aix.go | 25 +- .../x/sys/unix/zerrors_linux_386.go | 11 + .../x/sys/unix/zerrors_linux_amd64.go | 11 + .../x/sys/unix/zerrors_linux_arm.go | 11 + .../x/sys/unix/zerrors_linux_arm64.go | 11 + .../x/sys/unix/zerrors_linux_mips.go | 11 + .../x/sys/unix/zerrors_linux_mips64.go | 11 + .../x/sys/unix/zerrors_linux_mips64le.go | 11 + .../x/sys/unix/zerrors_linux_mipsle.go | 11 + .../x/sys/unix/zerrors_linux_ppc64.go | 11 + .../x/sys/unix/zerrors_linux_ppc64le.go | 11 + .../x/sys/unix/zerrors_linux_riscv64.go | 11 + .../x/sys/unix/zerrors_linux_s390x.go | 11 + .../x/sys/unix/zerrors_linux_sparc64.go | 11 + .../x/sys/unix/zsyscall_linux_386.go | 8 +- .../x/sys/unix/zsyscall_linux_amd64.go | 8 +- .../x/sys/unix/zsyscall_linux_arm.go | 8 +- .../x/sys/unix/zsyscall_linux_arm64.go | 8 +- .../x/sys/unix/zsyscall_linux_mips.go | 8 +- .../x/sys/unix/zsyscall_linux_mips64.go | 8 +- .../x/sys/unix/zsyscall_linux_mips64le.go | 8 +- .../x/sys/unix/zsyscall_linux_mipsle.go | 8 +- .../x/sys/unix/zsyscall_linux_ppc64.go | 8 +- .../x/sys/unix/zsyscall_linux_ppc64le.go | 8 +- .../x/sys/unix/zsyscall_linux_riscv64.go | 8 +- .../x/sys/unix/zsyscall_linux_s390x.go | 8 +- .../x/sys/unix/zsyscall_linux_sparc64.go | 8 +- .../golang.org/x/sys/unix/ztypes_aix_ppc.go | 34 +- .../golang.org/x/sys/unix/ztypes_aix_ppc64.go | 34 +- .../golang.org/x/sys/unix/ztypes_linux_386.go | 2 + .../x/sys/unix/ztypes_linux_amd64.go | 2 + .../golang.org/x/sys/unix/ztypes_linux_arm.go | 2 + .../x/sys/unix/ztypes_linux_arm64.go | 2 + .../x/sys/unix/ztypes_linux_mips.go | 2 + .../x/sys/unix/ztypes_linux_mips64.go | 2 + .../x/sys/unix/ztypes_linux_mips64le.go | 2 + .../x/sys/unix/ztypes_linux_mipsle.go | 2 + .../x/sys/unix/ztypes_linux_ppc64.go | 2 + .../x/sys/unix/ztypes_linux_ppc64le.go | 2 + .../x/sys/unix/ztypes_linux_riscv64.go | 2 + .../x/sys/unix/ztypes_linux_s390x.go | 2 + .../x/sys/unix/ztypes_linux_sparc64.go | 2 + vendor/golang.org/x/sys/windows/mkerrors.bash | 3 +- .../x/sys/windows/registry/value.go | 9 +- .../x/sys/windows/security_windows.go | 104 +- vendor/golang.org/x/sys/windows/service.go | 38 +- .../x/sys/windows/syscall_windows.go | 12 + .../x/sys/windows/syscall_windows_test.go | 65 + .../golang.org/x/sys/windows/types_windows.go | 153 +- .../x/sys/windows/zsyscall_windows.go | 207 +- vendor/golang.org/x/text/cmd/gotext/common.go | 49 + vendor/golang.org/x/text/cmd/gotext/doc.go | 63 + .../cmd/gotext/examples/extract/catalog.go | 84 + .../extract/locales/de/messages.gotext.json | 186 + .../extract/locales/de/out.gotext.json | 137 + .../locales/en-US/messages.gotext.json | 82 + .../extract/locales/en-US/out.gotext.json | 154 + .../extract/locales/zh/messages.gotext.json | 203 + .../extract/locales/zh/out.gotext.json | 137 + .../text/cmd/gotext/examples/extract/main.go | 86 + .../examples/extract_http/catalog_gen.go | 57 + .../extract_http/locales/de/out.gotext.json | 39 + .../locales/en-US/out.gotext.json | 39 + .../extract_http/locales/en/out.gotext.json | 39 + .../extract_http/locales/zh/out.gotext.json | 35 + .../cmd/gotext/examples/extract_http/main.go | 17 + .../gotext/examples/extract_http/pkg/pkg.go | 25 + .../text/cmd/gotext/examples/rewrite/main.go | 37 + .../cmd/gotext/examples/rewrite/printer.go | 16 + .../golang.org/x/text/cmd/gotext/extract.go | 40 + .../golang.org/x/text/cmd/gotext/generate.go | 31 + vendor/golang.org/x/text/cmd/gotext/main.go | 375 ++ .../golang.org/x/text/cmd/gotext/rewrite.go | 56 + vendor/golang.org/x/text/cmd/gotext/update.go | 52 + .../x/tools/cmd/auth/authtest/authtest.go | 231 ++ .../x/tools/cmd/auth/cookieauth/cookieauth.go | 166 + .../x/tools/cmd/auth/gitauth/gitauth.go | 149 + .../x/tools/cmd/auth/netrcauth/netrcauth.go | 123 + .../x/tools/cmd/benchcmp/benchcmp.go | 184 + .../x/tools/cmd/benchcmp/benchcmp_test.go | 59 + .../x/tools/cmd/benchcmp/compare.go | 156 + .../x/tools/cmd/benchcmp/compare_test.go | 133 + vendor/golang.org/x/tools/cmd/benchcmp/doc.go | 37 + .../golang.org/x/tools/cmd/bundle/.gitignore | 1 + vendor/golang.org/x/tools/cmd/bundle/main.go | 467 +++ .../x/tools/cmd/bundle/main_test.go | 74 + .../x/tools/cmd/bundle/testdata/out.golden | 62 + .../testdata/src/domain.name/importdecl/p.go | 3 + .../cmd/bundle/testdata/src/initial/a.go | 27 + .../cmd/bundle/testdata/src/initial/b.go | 23 + .../cmd/bundle/testdata/src/initial/c.go | 12 + .../golang.org/x/tools/cmd/callgraph/main.go | 349 ++ .../x/tools/cmd/callgraph/main_test.go | 99 + .../cmd/callgraph/testdata/src/pkg/pkg.go | 25 + .../callgraph/testdata/src/pkg/pkg_test.go | 10 + .../x/tools/cmd/compilebench/main.go | 504 +++ vendor/golang.org/x/tools/cmd/cover/README | 2 + vendor/golang.org/x/tools/cmd/cover/cover.go | 722 ++++ .../x/tools/cmd/cover/cover_test.go | 94 + vendor/golang.org/x/tools/cmd/cover/doc.go | 27 + vendor/golang.org/x/tools/cmd/cover/func.go | 166 + vendor/golang.org/x/tools/cmd/cover/html.go | 284 ++ .../x/tools/cmd/cover/testdata/main.go | 112 + .../x/tools/cmd/cover/testdata/test.go | 218 + .../golang.org/x/tools/cmd/digraph/digraph.go | 541 +++ .../x/tools/cmd/digraph/digraph_test.go | 121 + vendor/golang.org/x/tools/cmd/eg/eg.go | 150 + .../golang.org/x/tools/cmd/fiximports/main.go | 514 +++ .../x/tools/cmd/fiximports/main_test.go | 253 ++ .../testdata/src/fruit.io/banana/banana.go | 7 + .../testdata/src/fruit.io/orange/orange.go | 3 + .../testdata/src/fruit.io/pear/pear.go | 3 + .../testdata/src/new.com/one/one.go | 1 + .../testdata/src/old.com/bad/bad.go | 2 + .../testdata/src/old.com/one/one.go | 1 + .../testdata/src/titanic.biz/bar/bar.go | 2 + .../testdata/src/titanic.biz/foo/foo.go | 2 + .../x/tools/cmd/getgo/.dockerignore | 5 + .../golang.org/x/tools/cmd/getgo/.gitignore | 3 + .../golang.org/x/tools/cmd/getgo/Dockerfile | 20 + vendor/golang.org/x/tools/cmd/getgo/LICENSE | 27 + vendor/golang.org/x/tools/cmd/getgo/README.md | 71 + .../golang.org/x/tools/cmd/getgo/download.go | 184 + .../x/tools/cmd/getgo/download_test.go | 36 + vendor/golang.org/x/tools/cmd/getgo/main.go | 117 + .../golang.org/x/tools/cmd/getgo/main_test.go | 173 + vendor/golang.org/x/tools/cmd/getgo/make.bash | 13 + vendor/golang.org/x/tools/cmd/getgo/path.go | 155 + .../golang.org/x/tools/cmd/getgo/path_test.go | 58 + .../x/tools/cmd/getgo/server/README.md | 7 + .../x/tools/cmd/getgo/server/app.yaml | 7 + .../x/tools/cmd/getgo/server/main.go | 61 + vendor/golang.org/x/tools/cmd/getgo/steps.go | 133 + vendor/golang.org/x/tools/cmd/getgo/system.go | 38 + .../x/tools/cmd/getgo/system_unix.go | 55 + .../x/tools/cmd/getgo/system_windows.go | 86 + .../golang.org/x/tools/cmd/getgo/upload.bash | 19 + .../x/tools/cmd/go-contrib-init/contrib.go | 289 ++ .../tools/cmd/go-contrib-init/contrib_test.go | 35 + vendor/golang.org/x/tools/cmd/godex/doc.go | 69 + vendor/golang.org/x/tools/cmd/godex/gc.go | 13 + vendor/golang.org/x/tools/cmd/godex/gccgo.go | 34 + vendor/golang.org/x/tools/cmd/godex/godex.go | 211 + .../golang.org/x/tools/cmd/godex/isAlias18.go | 13 + .../golang.org/x/tools/cmd/godex/isAlias19.go | 13 + vendor/golang.org/x/tools/cmd/godex/print.go | 373 ++ vendor/golang.org/x/tools/cmd/godex/source.go | 19 + .../golang.org/x/tools/cmd/godex/writetype.go | 242 ++ vendor/golang.org/x/tools/cmd/godoc/blog.go | 85 + .../golang.org/x/tools/cmd/godoc/codewalk.go | 523 +++ vendor/golang.org/x/tools/cmd/godoc/dl.go | 14 + vendor/golang.org/x/tools/cmd/godoc/doc.go | 119 + .../x/tools/cmd/godoc/godoc_test.go | 508 +++ vendor/golang.org/x/tools/cmd/godoc/goroot.go | 74 + .../golang.org/x/tools/cmd/godoc/handlers.go | 151 + vendor/golang.org/x/tools/cmd/godoc/index.go | 11 + vendor/golang.org/x/tools/cmd/godoc/main.go | 338 ++ vendor/golang.org/x/tools/cmd/godoc/play.go | 9 + .../golang.org/x/tools/cmd/goimports/doc.go | 43 + .../x/tools/cmd/goimports/goimports.go | 377 ++ .../x/tools/cmd/goimports/goimports_gc.go | 26 + .../x/tools/cmd/goimports/goimports_not_gc.go | 11 + vendor/golang.org/x/tools/cmd/gomvpkg/main.go | 94 + .../cmd/gopls/integration/vscode/.gitignore | 3 + .../cmd/gopls/integration/vscode/README.md | 21 + .../integration/vscode/package-lock.json | 2065 ++++++++++ .../cmd/gopls/integration/vscode/package.json | 58 + .../gopls/integration/vscode/src/extension.ts | 96 + .../gopls/integration/vscode/tsconfig.json | 15 + .../cmd/gopls/integration/vscode/tslint.json | 12 + vendor/golang.org/x/tools/cmd/gopls/main.go | 21 + .../x/tools/cmd/gorename/cgo_test.go | 11 + .../x/tools/cmd/gorename/gorename_test.go | 385 ++ .../golang.org/x/tools/cmd/gorename/main.go | 55 + .../golang.org/x/tools/cmd/gotype/gotype.go | 341 ++ .../x/tools/cmd/gotype/sizesFor18.go | 40 + .../x/tools/cmd/gotype/sizesFor19.go | 15 + vendor/golang.org/x/tools/cmd/goyacc/doc.go | 70 + .../x/tools/cmd/goyacc/testdata/expr/README | 20 + .../x/tools/cmd/goyacc/testdata/expr/expr.y | 202 + .../x/tools/cmd/goyacc/testdata/expr/main.go | 14 + vendor/golang.org/x/tools/cmd/goyacc/yacc.go | 3592 +++++++++++++++++ vendor/golang.org/x/tools/cmd/guru/callees.go | 257 ++ vendor/golang.org/x/tools/cmd/guru/callers.go | 195 + .../golang.org/x/tools/cmd/guru/callstack.go | 141 + .../golang.org/x/tools/cmd/guru/definition.go | 205 + .../golang.org/x/tools/cmd/guru/describe.go | 947 +++++ .../golang.org/x/tools/cmd/guru/freevars.go | 223 + vendor/golang.org/x/tools/cmd/guru/guru.go | 401 ++ .../golang.org/x/tools/cmd/guru/guru_test.go | 331 ++ .../golang.org/x/tools/cmd/guru/implements.go | 364 ++ .../golang.org/x/tools/cmd/guru/isAlias18.go | 15 + .../golang.org/x/tools/cmd/guru/isAlias19.go | 15 + vendor/golang.org/x/tools/cmd/guru/main.go | 225 ++ vendor/golang.org/x/tools/cmd/guru/peers.go | 252 ++ .../golang.org/x/tools/cmd/guru/pointsto.go | 290 ++ vendor/golang.org/x/tools/cmd/guru/pos.go | 142 + .../golang.org/x/tools/cmd/guru/referrers.go | 802 ++++ .../x/tools/cmd/guru/serial/serial.go | 260 ++ .../x/tools/cmd/guru/testdata/src/README.txt | 2 + .../cmd/guru/testdata/src/alias/alias.go | 23 + .../cmd/guru/testdata/src/alias/alias.golden | 47 + .../cmd/guru/testdata/src/calls-json/main.go | 16 + .../guru/testdata/src/calls-json/main.golden | 28 + .../tools/cmd/guru/testdata/src/calls/main.go | 129 + .../cmd/guru/testdata/src/calls/main.golden | 125 + .../guru/testdata/src/definition-json/main.go | 68 + .../testdata/src/definition-json/main.golden | 95 + .../guru/testdata/src/definition-json/type.go | 3 + .../guru/testdata/src/describe-json/main.go | 29 + .../testdata/src/describe-json/main.golden | 134 + .../cmd/guru/testdata/src/describe/main.go | 116 + .../guru/testdata/src/describe/main.golden | 255 ++ .../cmd/guru/testdata/src/freevars/main.go | 40 + .../guru/testdata/src/freevars/main.golden | 25 + .../guru/testdata/src/implements-json/main.go | 27 + .../testdata/src/implements-json/main.golden | 135 + .../src/implements-methods-json/main.go | 37 + .../src/implements-methods-json/main.golden | 266 ++ .../testdata/src/implements-methods/main.go | 37 + .../src/implements-methods/main.golden | 37 + .../cmd/guru/testdata/src/implements/main.go | 44 + .../guru/testdata/src/implements/main.golden | 50 + .../cmd/guru/testdata/src/imports/main.go | 29 + .../cmd/guru/testdata/src/imports/main.golden | 56 + .../x/tools/cmd/guru/testdata/src/lib/lib.go | 37 + .../guru/testdata/src/lib/sublib/sublib.go | 3 + .../tools/cmd/guru/testdata/src/main/multi.go | 13 + .../cmd/guru/testdata/src/peers-json/main.go | 13 + .../guru/testdata/src/peers-json/main.golden | 12 + .../tools/cmd/guru/testdata/src/peers/main.go | 52 + .../cmd/guru/testdata/src/peers/main.golden | 100 + .../guru/testdata/src/pointsto-json/main.go | 27 + .../testdata/src/pointsto-json/main.golden | 29 + .../cmd/guru/testdata/src/pointsto/main.go | 75 + .../guru/testdata/src/pointsto/main.golden | 96 + .../guru/testdata/src/referrers-json/main.go | 24 + .../testdata/src/referrers-json/main.golden | 234 ++ .../guru/testdata/src/referrers/ext_test.go | 12 + .../guru/testdata/src/referrers/int_test.go | 10 + .../cmd/guru/testdata/src/referrers/main.go | 36 + .../guru/testdata/src/referrers/main.golden | 64 + .../cmd/guru/testdata/src/reflection/main.go | 30 + .../guru/testdata/src/reflection/main.golden | 34 + .../cmd/guru/testdata/src/softerrs/main.go | 15 + .../guru/testdata/src/softerrs/main.golden | 8 + .../cmd/guru/testdata/src/what-json/main.go | 14 + .../guru/testdata/src/what-json/main.golden | 95 + .../tools/cmd/guru/testdata/src/what/main.go | 11 + .../cmd/guru/testdata/src/what/main.golden | 41 + .../cmd/guru/testdata/src/whicherrs/main.go | 32 + .../guru/testdata/src/whicherrs/main.golden | 11 + .../golang.org/x/tools/cmd/guru/unit_test.go | 105 + vendor/golang.org/x/tools/cmd/guru/what.go | 283 ++ .../golang.org/x/tools/cmd/guru/whicherrs.go | 327 ++ .../x/tools/cmd/html2article/conv.go | 331 ++ vendor/golang.org/x/tools/cmd/present/dir.go | 217 + vendor/golang.org/x/tools/cmd/present/doc.go | 52 + vendor/golang.org/x/tools/cmd/present/main.go | 150 + vendor/golang.org/x/tools/cmd/present/play.go | 89 + .../x/tools/cmd/present/static/article.css | 161 + .../x/tools/cmd/present/static/dir.css | 186 + .../x/tools/cmd/present/static/dir.js | 41 + .../x/tools/cmd/present/static/favicon.ico | Bin 0 -> 785 bytes .../x/tools/cmd/present/static/jquery-ui.js | 6 + .../x/tools/cmd/present/static/notes.css | 32 + .../x/tools/cmd/present/static/notes.js | 161 + .../x/tools/cmd/present/static/slides.js | 626 +++ .../x/tools/cmd/present/static/styles.css | 542 +++ .../x/tools/cmd/present/templates/action.tmpl | 62 + .../tools/cmd/present/templates/article.tmpl | 98 + .../x/tools/cmd/present/templates/dir.tmpl | 108 + .../x/tools/cmd/present/templates/slides.tmpl | 107 + .../cmd/splitdwarf/internal/macho/fat.go | 141 + .../cmd/splitdwarf/internal/macho/file.go | 1303 ++++++ .../splitdwarf/internal/macho/file_test.go | 389 ++ .../cmd/splitdwarf/internal/macho/macho.go | 468 +++ .../splitdwarf/internal/macho/reloctype.go | 72 + .../internal/macho/reloctype_string.go | 49 + .../testdata/clang-386-darwin-exec-with-rpath | Bin 0 -> 8416 bytes .../macho/testdata/clang-386-darwin.obj | Bin 0 -> 464 bytes .../clang-amd64-darwin-exec-with-rpath | Bin 0 -> 8432 bytes .../macho/testdata/clang-amd64-darwin.obj | Bin 0 -> 768 bytes .../testdata/fat-gcc-386-amd64-darwin-exec | Bin 0 -> 28992 bytes .../macho/testdata/gcc-386-darwin-exec | Bin 0 -> 12588 bytes .../macho/testdata/gcc-amd64-darwin-exec | Bin 0 -> 8512 bytes .../testdata/gcc-amd64-darwin-exec-debug | Bin 0 -> 4540 bytes .../internal/macho/testdata/hello.c | 8 + .../x/tools/cmd/splitdwarf/splitdwarf.go | 408 ++ vendor/golang.org/x/tools/cmd/ssadump/main.go | 190 + .../golang.org/x/tools/cmd/stress/stress.go | 141 + .../x/tools/cmd/stringer/endtoend_test.go | 220 + .../x/tools/cmd/stringer/golden_test.go | 432 ++ .../x/tools/cmd/stringer/stringer.go | 643 +++ .../x/tools/cmd/stringer/testdata/cgo.go | 32 + .../x/tools/cmd/stringer/testdata/conv.go | 41 + .../x/tools/cmd/stringer/testdata/day.go | 39 + .../x/tools/cmd/stringer/testdata/gap.go | 44 + .../x/tools/cmd/stringer/testdata/num.go | 35 + .../x/tools/cmd/stringer/testdata/number.go | 34 + .../x/tools/cmd/stringer/testdata/prime.go | 56 + .../x/tools/cmd/stringer/testdata/tag_main.go | 11 + .../x/tools/cmd/stringer/testdata/tag_tag.go | 7 + .../x/tools/cmd/stringer/testdata/unum.go | 38 + .../x/tools/cmd/stringer/testdata/unum2.go | 31 + .../x/tools/cmd/stringer/testdata/vary_day.go | 39 + .../x/tools/cmd/stringer/util_test.go | 77 + .../golang.org/x/tools/cmd/toolstash/buildall | 68 + .../golang.org/x/tools/cmd/toolstash/cmp.go | 157 + .../golang.org/x/tools/cmd/toolstash/main.go | 637 +++ vendor/golang.org/x/tools/go.mod | 2 + .../x/tools/go/analysis/analysis.go | 17 +- .../go/analysis/analysistest/analysistest.go | 1 + .../x/tools/go/analysis/cmd/vet/README | 33 + .../x/tools/go/analysis/cmd/vet/vet.go | 83 + .../analysis/internal/analysisflags/flags.go | 9 +- .../go/analysis/internal/checker/checker.go | 6 +- .../go/analysis/passes/errorsas/errorsas.go | 9 +- .../passes/errorsas/testdata/src/a/a.go | 21 +- .../passes/findcall/cmd/findcall/main.go | 9 + .../passes/lostcancel/cmd/lostcancel/main.go | 10 + .../passes/nilness/cmd/nilness/main.go | 10 + .../analysis/passes/shadow/cmd/shadow/main.go | 9 + .../go/analysis/passes/structtag/structtag.go | 71 +- .../passes/structtag/testdata/src/a/a.go | 29 +- .../x/tools/go/analysis/passes/tests/tests.go | 5 +- .../passes/unmarshal/cmd/unmarshal/main.go | 9 + .../x/tools/go/packages/example_test.go | 2 +- .../golang.org/x/tools/go/packages/golist.go | 30 +- .../x/tools/go/packages/golist_overlay.go | 210 +- .../x/tools/go/packages/packages.go | 63 +- .../x/tools/go/packages/packages_test.go | 26 + .../tools/go/packages/packagestest/modules.go | 4 +- vendor/golang.org/x/tools/godoc/parser.go | 2 +- .../golang.org/x/tools/godoc/server_test.go | 21 + .../x/tools/internal/imports/fix.go | 5 +- .../x/tools/internal/imports/fix_test.go | 1 + .../x/tools/internal/imports/mod_test.go | 1 + .../x/tools/internal/jsonrpc2/jsonrpc2.go | 15 +- .../x/tools/internal/lsp/cache/cache.go | 40 +- .../x/tools/internal/lsp/cache/check.go | 222 +- .../x/tools/internal/lsp/cache/external.go | 29 + .../x/tools/internal/lsp/cache/file.go | 157 +- .../x/tools/internal/lsp/cache/gofile.go | 143 + .../x/tools/internal/lsp/cache/load.go | 166 + .../x/tools/internal/lsp/cache/modfile.go | 16 + .../x/tools/internal/lsp/cache/parse.go | 90 +- .../x/tools/internal/lsp/cache/pkg.go | 8 +- .../x/tools/internal/lsp/cache/session.go | 146 +- .../x/tools/internal/lsp/cache/sumfile.go | 16 + .../x/tools/internal/lsp/cache/view.go | 110 +- .../x/tools/internal/lsp/cache/watcher.go | 56 + .../x/tools/internal/lsp/cmd/check.go | 76 + .../x/tools/internal/lsp/cmd/check_test.go | 60 + .../x/tools/internal/lsp/cmd/cmd.go | 363 ++ .../internal/lsp/cmd/cmd_race_test.go} | 8 +- .../x/tools/internal/lsp/cmd/cmd_test.go | 149 + .../x/tools/internal/lsp/cmd/definition.go | 137 + .../tools/internal/lsp/cmd/definition_test.go | 101 + .../x/tools/internal/lsp/cmd/export_test.go | 11 + .../x/tools/internal/lsp/cmd/format.go | 110 + .../x/tools/internal/lsp/cmd/format_test.go | 65 + .../x/tools/internal/lsp/cmd/info.go | 84 + .../x/tools/internal/lsp/cmd/query.go | 71 + .../x/tools/internal/lsp/cmd/serve.go | 169 + .../internal/lsp/{ => debug}/info.1.11.go | 4 +- .../lsp/{info.go => debug/info.1.12.go} | 10 +- .../x/tools/internal/lsp/debug/info.go | 58 + .../x/tools/internal/lsp/debug/serve.go | 396 ++ .../x/tools/internal/lsp/diagnostics.go | 20 +- .../x/tools/internal/lsp/general.go | 15 +- .../x/tools/internal/lsp/lsp_test.go | 13 +- .../x/tools/internal/lsp/protocol/tsclient.go | 10 +- .../tools/internal/lsp/protocol/tsprotocol.go | 109 +- .../x/tools/internal/lsp/protocol/tsserver.go | 19 - .../golang.org/x/tools/internal/lsp/server.go | 4 - .../x/tools/internal/lsp/source/analysis.go | 8 +- .../tools/internal/lsp/source/diagnostics.go | 54 +- .../x/tools/internal/lsp/source/format.go | 13 +- .../x/tools/internal/lsp/source/identifier.go | 10 +- .../tools/internal/lsp/source/source_test.go | 16 +- .../x/tools/internal/lsp/source/view.go | 58 +- .../internal/lsp/text_synchronization.go | 24 +- .../golang.org/x/tools/internal/lsp/util.go | 41 +- .../appengine/cmd/aebundler/aebundler.go | 342 ++ .../appengine/cmd/aedeploy/aedeploy.go | 72 + .../appengine/cmd/aefix/ae.go | 185 + .../appengine/cmd/aefix/ae_test.go | 144 + .../appengine/cmd/aefix/fix.go | 848 ++++ .../appengine/cmd/aefix/main.go | 258 ++ .../appengine/cmd/aefix/main_test.go | 129 + .../appengine/cmd/aefix/typecheck.go | 673 +++ vendor/gotest.tools/Dockerfile | 53 + .../cmd/gty-migrate-from-testify/call.go | 198 + .../cmd/gty-migrate-from-testify/call_test.go | 35 + .../cmd/gty-migrate-from-testify/doc.go | 22 + .../cmd/gty-migrate-from-testify/importer.go | 102 + .../cmd/gty-migrate-from-testify/main.go | 262 ++ .../cmd/gty-migrate-from-testify/main_test.go | 53 + .../cmd/gty-migrate-from-testify/migrate.go | 375 ++ .../gty-migrate-from-testify/migrate_test.go | 300 ++ .../testdata/full-expected/some_test.go | 150 + .../testdata/full/some_test.go | 151 + .../cmd/gty-migrate-from-testify/walktype.go | 33 + .../fs/testdata/copy-test-with-symlink/a/b/3 | 1 + .../fs/testdata/copy-test-with-symlink/a/b/4 | 1 + .../Dockerfile | 17 + .../code-generator/cmd/client-gen/OWNERS | 10 + .../code-generator/cmd/client-gen/README.md | 4 + .../cmd/client-gen/args/args.go | 120 + .../cmd/client-gen/args/gvpackages.go | 183 + .../cmd/client-gen/args/gvpackages_test.go | 116 + .../cmd/client-gen/args/gvtype.go | 110 + .../client-gen/generators/client_generator.go | 403 ++ .../generators/fake/fake_client_generator.go | 130 + .../fake/generator_fake_for_clientset.go | 169 + .../fake/generator_fake_for_group.go | 130 + .../fake/generator_fake_for_type.go | 479 +++ .../generators/generator_for_clientset.go | 178 + .../generators/generator_for_expansion.go | 54 + .../generators/generator_for_group.go | 247 ++ .../generators/generator_for_type.go | 599 +++ .../generators/scheme/generator_for_scheme.go | 186 + .../cmd/client-gen/generators/util/tags.go | 341 ++ .../client-gen/generators/util/tags_test.go | 148 + .../code-generator/cmd/client-gen/main.go | 66 + .../cmd/client-gen/path/path.go | 31 + .../cmd/client-gen/types/helpers.go | 121 + .../cmd/client-gen/types/helpers_test.go | 32 + .../cmd/client-gen/types/types.go | 75 + .../cmd/conversion-gen/args/args.go | 83 + .../conversion-gen/generators/conversion.go | 984 +++++ .../code-generator/cmd/conversion-gen/main.go | 116 + .../cmd/deepcopy-gen/args/args.go | 54 + .../code-generator/cmd/deepcopy-gen/main.go | 85 + .../cmd/defaulter-gen/args/args.go | 54 + .../code-generator/cmd/defaulter-gen/main.go | 84 + .../cmd/go-to-protobuf/.gitignore | 1 + .../code-generator/cmd/go-to-protobuf/OWNERS | 6 + .../code-generator/cmd/go-to-protobuf/main.go | 39 + .../cmd/go-to-protobuf/protobuf/cmd.go | 428 ++ .../cmd/go-to-protobuf/protobuf/generator.go | 773 ++++ .../go-to-protobuf/protobuf/import_tracker.go | 50 + .../cmd/go-to-protobuf/protobuf/namer.go | 208 + .../cmd/go-to-protobuf/protobuf/namer_test.go | 50 + .../cmd/go-to-protobuf/protobuf/package.go | 215 + .../cmd/go-to-protobuf/protobuf/parser.go | 452 +++ .../cmd/go-to-protobuf/protobuf/tags.go | 33 + .../go-to-protobuf/protoc-gen-gogo/main.go | 32 + .../code-generator/cmd/import-boss/.gitignore | 1 + .../code-generator/cmd/import-boss/main.go | 94 + .../cmd/informer-gen/args/args.go | 77 + .../cmd/informer-gen/generators/factory.go | 258 ++ .../generators/factoryinterface.go | 90 + .../cmd/informer-gen/generators/generic.go | 184 + .../informer-gen/generators/groupinterface.go | 118 + .../cmd/informer-gen/generators/informer.go | 186 + .../cmd/informer-gen/generators/packages.go | 352 ++ .../cmd/informer-gen/generators/tags.go | 33 + .../cmd/informer-gen/generators/types.go | 42 + .../generators/versioninterface.go | 109 + .../code-generator/cmd/informer-gen/main.go | 63 + .../cmd/lister-gen/.import-restrictions | 1 + .../cmd/lister-gen/args/args.go | 56 + .../cmd/lister-gen/generators/expansion.go | 67 + .../cmd/lister-gen/generators/lister.go | 371 ++ .../cmd/lister-gen/generators/tags.go | 33 + .../code-generator/cmd/lister-gen/main.go | 60 + .../cmd/register-gen/args/args.go | 39 + .../cmd/register-gen/generators/packages.go | 137 + .../generators/register_external.go | 117 + .../code-generator/cmd/register-gen/main.go | 53 + .../code-generator/cmd/set-gen/.gitignore | 1 + .../k8s.io/code-generator/cmd/set-gen/main.go | 56 + vendor/k8s.io/klog/klog.go | 196 +- vendor/k8s.io/klog/klog_test.go | 81 +- vendor/k8s.io/kube-openapi/.travis.yml | 9 +- .../boilerplate/boilerplate.go.txt | 16 + .../kube-openapi/cmd/openapi-gen/args/args.go | 76 + .../cmd/openapi-gen/openapi-gen.go | 57 + .../cmd/openapi2smd/openapi2smd.go | 60 + vendor/k8s.io/kube-openapi/go.mod | 2 +- vendor/k8s.io/kube-openapi/go.sum | 4 +- .../k8s.io/kube-openapi/pkg/schemaconv/smd.go | 8 +- .../pkg/schemaconv/testdata/new-schema.yaml | 1184 +++--- .../sample-controller/Godeps/Godeps.json | 10 +- vendor/k8s.io/sample-controller/go.mod | 20 +- vendor/k8s.io/sample-controller/go.sum | 12 +- .../v1alpha1/zz_generated.deepcopy.go | 2 +- vendor/k8s.io/utils/README.md | 4 +- vendor/k8s.io/utils/pointer/pointer.go | 2 +- vendor/k8s.io/utils/trace/trace.go | 3 +- vendor/k8s.io/utils/trace/trace_test.go | 14 + 705 files changed, 66451 insertions(+), 2925 deletions(-) create mode 100644 vendor/github.com/evanphx/json-patch/cmd/json-patch/file_flag.go create mode 100644 vendor/github.com/evanphx/json-patch/cmd/json-patch/main.go create mode 100644 vendor/github.com/golang/glog/LICENSE create mode 100644 vendor/github.com/golang/glog/README create mode 100644 vendor/github.com/golang/glog/glog.go create mode 100644 vendor/github.com/golang/glog/glog_file.go create mode 100644 vendor/github.com/golang/glog/glog_test.go create mode 100644 vendor/github.com/minio/minio/Dockerfile create mode 100644 vendor/github.com/minio/minio/docs/bigdata/README.md create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image1.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image10.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image11.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image12.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image13.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image14.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image2.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image3.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image4.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image5.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image6.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image7.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image8.png create mode 100644 vendor/github.com/minio/minio/docs/bigdata/images/image9.png delete mode 100644 vendor/github.com/minio/minio/pkg/event/target/memorystore.go delete mode 100644 vendor/github.com/minio/minio/pkg/event/target/memorystore_test.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/add.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/add_test.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/golden_test.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/helpers.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/init.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/init_test.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/license_agpl.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/license_apache_2.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/license_bsd_clause_2.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/license_bsd_clause_3.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/license_gpl_2.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/license_gpl_3.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/license_lgpl.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/license_mit.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/licenses.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/project.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/project_test.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/root.go create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/testdata/LICENSE.golden create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/testdata/main.go.golden create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/testdata/root.go.golden create mode 100644 vendor/github.com/spf13/cobra/cobra/cmd/testdata/test.go.golden create mode 100644 vendor/golang.org/x/crypto/internal/chacha20/asm_ppc64le.s create mode 100644 vendor/golang.org/x/crypto/internal/chacha20/chacha_ppc64le.go create mode 100644 vendor/golang.org/x/net/http2/Dockerfile create mode 100644 vendor/golang.org/x/net/http2/h2demo/Dockerfile create mode 100644 vendor/golang.org/x/net/internal/socket/sys_const_unix.go create mode 100644 vendor/golang.org/x/net/internal/socket/zsys_netbsd_arm64.go create mode 100644 vendor/golang.org/x/sys/cpu/asm_aix_ppc64.s create mode 100644 vendor/golang.org/x/sys/cpu/syscall_aix_ppc64_gc.go create mode 100644 vendor/golang.org/x/sys/unix/asm_linux_riscv64.s create mode 100644 vendor/golang.org/x/sys/unix/linux/Dockerfile create mode 100644 vendor/golang.org/x/text/cmd/gotext/common.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/doc.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/examples/extract/catalog.go create mode 100755 vendor/golang.org/x/text/cmd/gotext/examples/extract/locales/de/messages.gotext.json create mode 100755 vendor/golang.org/x/text/cmd/gotext/examples/extract/locales/de/out.gotext.json create mode 100755 vendor/golang.org/x/text/cmd/gotext/examples/extract/locales/en-US/messages.gotext.json create mode 100755 vendor/golang.org/x/text/cmd/gotext/examples/extract/locales/en-US/out.gotext.json create mode 100755 vendor/golang.org/x/text/cmd/gotext/examples/extract/locales/zh/messages.gotext.json create mode 100755 vendor/golang.org/x/text/cmd/gotext/examples/extract/locales/zh/out.gotext.json create mode 100644 vendor/golang.org/x/text/cmd/gotext/examples/extract/main.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/examples/extract_http/catalog_gen.go create mode 100755 vendor/golang.org/x/text/cmd/gotext/examples/extract_http/locales/de/out.gotext.json create mode 100755 vendor/golang.org/x/text/cmd/gotext/examples/extract_http/locales/en-US/out.gotext.json create mode 100644 vendor/golang.org/x/text/cmd/gotext/examples/extract_http/locales/en/out.gotext.json create mode 100755 vendor/golang.org/x/text/cmd/gotext/examples/extract_http/locales/zh/out.gotext.json create mode 100644 vendor/golang.org/x/text/cmd/gotext/examples/extract_http/main.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/examples/extract_http/pkg/pkg.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/examples/rewrite/main.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/examples/rewrite/printer.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/extract.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/generate.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/main.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/rewrite.go create mode 100644 vendor/golang.org/x/text/cmd/gotext/update.go create mode 100644 vendor/golang.org/x/tools/cmd/auth/authtest/authtest.go create mode 100644 vendor/golang.org/x/tools/cmd/auth/cookieauth/cookieauth.go create mode 100644 vendor/golang.org/x/tools/cmd/auth/gitauth/gitauth.go create mode 100644 vendor/golang.org/x/tools/cmd/auth/netrcauth/netrcauth.go create mode 100644 vendor/golang.org/x/tools/cmd/benchcmp/benchcmp.go create mode 100644 vendor/golang.org/x/tools/cmd/benchcmp/benchcmp_test.go create mode 100644 vendor/golang.org/x/tools/cmd/benchcmp/compare.go create mode 100644 vendor/golang.org/x/tools/cmd/benchcmp/compare_test.go create mode 100644 vendor/golang.org/x/tools/cmd/benchcmp/doc.go create mode 100644 vendor/golang.org/x/tools/cmd/bundle/.gitignore create mode 100644 vendor/golang.org/x/tools/cmd/bundle/main.go create mode 100644 vendor/golang.org/x/tools/cmd/bundle/main_test.go create mode 100644 vendor/golang.org/x/tools/cmd/bundle/testdata/out.golden create mode 100644 vendor/golang.org/x/tools/cmd/bundle/testdata/src/domain.name/importdecl/p.go create mode 100644 vendor/golang.org/x/tools/cmd/bundle/testdata/src/initial/a.go create mode 100644 vendor/golang.org/x/tools/cmd/bundle/testdata/src/initial/b.go create mode 100644 vendor/golang.org/x/tools/cmd/bundle/testdata/src/initial/c.go create mode 100644 vendor/golang.org/x/tools/cmd/callgraph/main.go create mode 100644 vendor/golang.org/x/tools/cmd/callgraph/main_test.go create mode 100644 vendor/golang.org/x/tools/cmd/callgraph/testdata/src/pkg/pkg.go create mode 100644 vendor/golang.org/x/tools/cmd/callgraph/testdata/src/pkg/pkg_test.go create mode 100644 vendor/golang.org/x/tools/cmd/compilebench/main.go create mode 100644 vendor/golang.org/x/tools/cmd/cover/README create mode 100644 vendor/golang.org/x/tools/cmd/cover/cover.go create mode 100644 vendor/golang.org/x/tools/cmd/cover/cover_test.go create mode 100644 vendor/golang.org/x/tools/cmd/cover/doc.go create mode 100644 vendor/golang.org/x/tools/cmd/cover/func.go create mode 100644 vendor/golang.org/x/tools/cmd/cover/html.go create mode 100644 vendor/golang.org/x/tools/cmd/cover/testdata/main.go create mode 100644 vendor/golang.org/x/tools/cmd/cover/testdata/test.go create mode 100644 vendor/golang.org/x/tools/cmd/digraph/digraph.go create mode 100644 vendor/golang.org/x/tools/cmd/digraph/digraph_test.go create mode 100644 vendor/golang.org/x/tools/cmd/eg/eg.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/main.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/main_test.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/testdata/src/fruit.io/banana/banana.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/testdata/src/fruit.io/orange/orange.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/testdata/src/fruit.io/pear/pear.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/testdata/src/new.com/one/one.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/testdata/src/old.com/bad/bad.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/testdata/src/old.com/one/one.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/testdata/src/titanic.biz/bar/bar.go create mode 100644 vendor/golang.org/x/tools/cmd/fiximports/testdata/src/titanic.biz/foo/foo.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/.dockerignore create mode 100644 vendor/golang.org/x/tools/cmd/getgo/.gitignore create mode 100644 vendor/golang.org/x/tools/cmd/getgo/Dockerfile create mode 100644 vendor/golang.org/x/tools/cmd/getgo/LICENSE create mode 100644 vendor/golang.org/x/tools/cmd/getgo/README.md create mode 100644 vendor/golang.org/x/tools/cmd/getgo/download.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/download_test.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/main.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/main_test.go create mode 100755 vendor/golang.org/x/tools/cmd/getgo/make.bash create mode 100644 vendor/golang.org/x/tools/cmd/getgo/path.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/path_test.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/server/README.md create mode 100644 vendor/golang.org/x/tools/cmd/getgo/server/app.yaml create mode 100644 vendor/golang.org/x/tools/cmd/getgo/server/main.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/steps.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/system.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/system_unix.go create mode 100644 vendor/golang.org/x/tools/cmd/getgo/system_windows.go create mode 100755 vendor/golang.org/x/tools/cmd/getgo/upload.bash create mode 100644 vendor/golang.org/x/tools/cmd/go-contrib-init/contrib.go create mode 100644 vendor/golang.org/x/tools/cmd/go-contrib-init/contrib_test.go create mode 100644 vendor/golang.org/x/tools/cmd/godex/doc.go create mode 100644 vendor/golang.org/x/tools/cmd/godex/gc.go create mode 100644 vendor/golang.org/x/tools/cmd/godex/gccgo.go create mode 100644 vendor/golang.org/x/tools/cmd/godex/godex.go create mode 100644 vendor/golang.org/x/tools/cmd/godex/isAlias18.go create mode 100644 vendor/golang.org/x/tools/cmd/godex/isAlias19.go create mode 100644 vendor/golang.org/x/tools/cmd/godex/print.go create mode 100644 vendor/golang.org/x/tools/cmd/godex/source.go create mode 100644 vendor/golang.org/x/tools/cmd/godex/writetype.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/blog.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/codewalk.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/dl.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/doc.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/godoc_test.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/goroot.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/handlers.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/index.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/main.go create mode 100644 vendor/golang.org/x/tools/cmd/godoc/play.go create mode 100644 vendor/golang.org/x/tools/cmd/goimports/doc.go create mode 100644 vendor/golang.org/x/tools/cmd/goimports/goimports.go create mode 100644 vendor/golang.org/x/tools/cmd/goimports/goimports_gc.go create mode 100644 vendor/golang.org/x/tools/cmd/goimports/goimports_not_gc.go create mode 100644 vendor/golang.org/x/tools/cmd/gomvpkg/main.go create mode 100644 vendor/golang.org/x/tools/cmd/gopls/integration/vscode/.gitignore create mode 100644 vendor/golang.org/x/tools/cmd/gopls/integration/vscode/README.md create mode 100644 vendor/golang.org/x/tools/cmd/gopls/integration/vscode/package-lock.json create mode 100644 vendor/golang.org/x/tools/cmd/gopls/integration/vscode/package.json create mode 100644 vendor/golang.org/x/tools/cmd/gopls/integration/vscode/src/extension.ts create mode 100644 vendor/golang.org/x/tools/cmd/gopls/integration/vscode/tsconfig.json create mode 100644 vendor/golang.org/x/tools/cmd/gopls/integration/vscode/tslint.json create mode 100644 vendor/golang.org/x/tools/cmd/gopls/main.go create mode 100644 vendor/golang.org/x/tools/cmd/gorename/cgo_test.go create mode 100644 vendor/golang.org/x/tools/cmd/gorename/gorename_test.go create mode 100644 vendor/golang.org/x/tools/cmd/gorename/main.go create mode 100644 vendor/golang.org/x/tools/cmd/gotype/gotype.go create mode 100644 vendor/golang.org/x/tools/cmd/gotype/sizesFor18.go create mode 100644 vendor/golang.org/x/tools/cmd/gotype/sizesFor19.go create mode 100644 vendor/golang.org/x/tools/cmd/goyacc/doc.go create mode 100644 vendor/golang.org/x/tools/cmd/goyacc/testdata/expr/README create mode 100644 vendor/golang.org/x/tools/cmd/goyacc/testdata/expr/expr.y create mode 100644 vendor/golang.org/x/tools/cmd/goyacc/testdata/expr/main.go create mode 100644 vendor/golang.org/x/tools/cmd/goyacc/yacc.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/callees.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/callers.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/callstack.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/definition.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/describe.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/freevars.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/guru.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/guru_test.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/implements.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/isAlias18.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/isAlias19.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/peers.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/pointsto.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/pos.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/referrers.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/serial/serial.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/README.txt create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/alias/alias.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/alias/alias.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/calls-json/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/calls-json/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/calls/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/calls/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/definition-json/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/definition-json/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/definition-json/type.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/describe-json/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/describe-json/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/describe/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/describe/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/freevars/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/freevars/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/implements-json/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/implements-json/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/implements-methods-json/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/implements-methods-json/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/implements-methods/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/implements-methods/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/implements/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/implements/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/imports/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/imports/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/lib/lib.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/lib/sublib/sublib.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/main/multi.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/peers-json/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/peers-json/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/peers/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/peers/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/pointsto-json/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/pointsto-json/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/pointsto/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/pointsto/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/referrers-json/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/referrers-json/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/referrers/ext_test.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/referrers/int_test.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/referrers/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/referrers/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/reflection/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/reflection/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/softerrs/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/softerrs/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/what-json/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/what-json/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/what/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/what/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/whicherrs/main.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/testdata/src/whicherrs/main.golden create mode 100644 vendor/golang.org/x/tools/cmd/guru/unit_test.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/what.go create mode 100644 vendor/golang.org/x/tools/cmd/guru/whicherrs.go create mode 100644 vendor/golang.org/x/tools/cmd/html2article/conv.go create mode 100644 vendor/golang.org/x/tools/cmd/present/dir.go create mode 100644 vendor/golang.org/x/tools/cmd/present/doc.go create mode 100644 vendor/golang.org/x/tools/cmd/present/main.go create mode 100644 vendor/golang.org/x/tools/cmd/present/play.go create mode 100644 vendor/golang.org/x/tools/cmd/present/static/article.css create mode 100644 vendor/golang.org/x/tools/cmd/present/static/dir.css create mode 100644 vendor/golang.org/x/tools/cmd/present/static/dir.js create mode 100644 vendor/golang.org/x/tools/cmd/present/static/favicon.ico create mode 100644 vendor/golang.org/x/tools/cmd/present/static/jquery-ui.js create mode 100644 vendor/golang.org/x/tools/cmd/present/static/notes.css create mode 100644 vendor/golang.org/x/tools/cmd/present/static/notes.js create mode 100644 vendor/golang.org/x/tools/cmd/present/static/slides.js create mode 100644 vendor/golang.org/x/tools/cmd/present/static/styles.css create mode 100644 vendor/golang.org/x/tools/cmd/present/templates/action.tmpl create mode 100644 vendor/golang.org/x/tools/cmd/present/templates/article.tmpl create mode 100644 vendor/golang.org/x/tools/cmd/present/templates/dir.tmpl create mode 100644 vendor/golang.org/x/tools/cmd/present/templates/slides.tmpl create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/fat.go create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/file.go create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/file_test.go create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/macho.go create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/reloctype.go create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/reloctype_string.go create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/testdata/clang-386-darwin-exec-with-rpath create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/testdata/clang-386-darwin.obj create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/testdata/clang-amd64-darwin-exec-with-rpath create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/testdata/clang-amd64-darwin.obj create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/testdata/fat-gcc-386-amd64-darwin-exec create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/testdata/gcc-386-darwin-exec create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/testdata/gcc-amd64-darwin-exec create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/testdata/gcc-amd64-darwin-exec-debug create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/internal/macho/testdata/hello.c create mode 100644 vendor/golang.org/x/tools/cmd/splitdwarf/splitdwarf.go create mode 100644 vendor/golang.org/x/tools/cmd/ssadump/main.go create mode 100644 vendor/golang.org/x/tools/cmd/stress/stress.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/endtoend_test.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/golden_test.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/stringer.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/cgo.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/conv.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/day.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/gap.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/num.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/number.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/prime.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/tag_main.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/tag_tag.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/unum.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/unum2.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/testdata/vary_day.go create mode 100644 vendor/golang.org/x/tools/cmd/stringer/util_test.go create mode 100755 vendor/golang.org/x/tools/cmd/toolstash/buildall create mode 100644 vendor/golang.org/x/tools/cmd/toolstash/cmp.go create mode 100644 vendor/golang.org/x/tools/cmd/toolstash/main.go create mode 100644 vendor/golang.org/x/tools/go/analysis/cmd/vet/README create mode 100644 vendor/golang.org/x/tools/go/analysis/cmd/vet/vet.go create mode 100644 vendor/golang.org/x/tools/go/analysis/passes/findcall/cmd/findcall/main.go create mode 100644 vendor/golang.org/x/tools/go/analysis/passes/lostcancel/cmd/lostcancel/main.go create mode 100644 vendor/golang.org/x/tools/go/analysis/passes/nilness/cmd/nilness/main.go create mode 100644 vendor/golang.org/x/tools/go/analysis/passes/shadow/cmd/shadow/main.go create mode 100644 vendor/golang.org/x/tools/go/analysis/passes/unmarshal/cmd/unmarshal/main.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cache/external.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cache/gofile.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cache/load.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cache/modfile.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cache/sumfile.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cache/watcher.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/check.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/check_test.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/cmd.go rename vendor/golang.org/x/{sys/windows/mkerrors.go => tools/internal/lsp/cmd/cmd_race_test.go} (65%) create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/cmd_test.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/definition.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/definition_test.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/export_test.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/format.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/format_test.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/info.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/query.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/cmd/serve.go rename vendor/golang.org/x/tools/internal/lsp/{ => debug}/info.1.11.go (78%) rename vendor/golang.org/x/tools/internal/lsp/{info.go => debug/info.1.12.go} (74%) create mode 100644 vendor/golang.org/x/tools/internal/lsp/debug/info.go create mode 100644 vendor/golang.org/x/tools/internal/lsp/debug/serve.go create mode 100644 vendor/google.golang.org/appengine/cmd/aebundler/aebundler.go create mode 100644 vendor/google.golang.org/appengine/cmd/aedeploy/aedeploy.go create mode 100644 vendor/google.golang.org/appengine/cmd/aefix/ae.go create mode 100644 vendor/google.golang.org/appengine/cmd/aefix/ae_test.go create mode 100644 vendor/google.golang.org/appengine/cmd/aefix/fix.go create mode 100644 vendor/google.golang.org/appengine/cmd/aefix/main.go create mode 100644 vendor/google.golang.org/appengine/cmd/aefix/main_test.go create mode 100644 vendor/google.golang.org/appengine/cmd/aefix/typecheck.go create mode 100644 vendor/gotest.tools/Dockerfile create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/call.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/call_test.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/doc.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/importer.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/main.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/main_test.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/migrate.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/migrate_test.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/testdata/full-expected/some_test.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/testdata/full/some_test.go create mode 100644 vendor/gotest.tools/assert/cmd/gty-migrate-from-testify/walktype.go create mode 120000 vendor/gotest.tools/fs/testdata/copy-test-with-symlink/a/b/3 create mode 120000 vendor/gotest.tools/fs/testdata/copy-test-with-symlink/a/b/4 create mode 100644 vendor/k8s.io/client-go/examples/in-cluster-client-configuration/Dockerfile create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/OWNERS create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/README.md create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/args/args.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/args/gvpackages.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/args/gvpackages_test.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/args/gvtype.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/client_generator.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/fake/fake_client_generator.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/fake/generator_fake_for_clientset.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/fake/generator_fake_for_group.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/fake/generator_fake_for_type.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/generator_for_clientset.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/generator_for_expansion.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/generator_for_group.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/generator_for_type.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/scheme/generator_for_scheme.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/util/tags.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/generators/util/tags_test.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/path/path.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/types/helpers.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/types/helpers_test.go create mode 100644 vendor/k8s.io/code-generator/cmd/client-gen/types/types.go create mode 100644 vendor/k8s.io/code-generator/cmd/conversion-gen/args/args.go create mode 100644 vendor/k8s.io/code-generator/cmd/conversion-gen/generators/conversion.go create mode 100644 vendor/k8s.io/code-generator/cmd/conversion-gen/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/deepcopy-gen/args/args.go create mode 100644 vendor/k8s.io/code-generator/cmd/deepcopy-gen/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/defaulter-gen/args/args.go create mode 100644 vendor/k8s.io/code-generator/cmd/defaulter-gen/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/.gitignore create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/OWNERS create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/protobuf/cmd.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/protobuf/generator.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/protobuf/import_tracker.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/protobuf/namer.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/protobuf/namer_test.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/protobuf/package.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/protobuf/parser.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/protobuf/tags.go create mode 100644 vendor/k8s.io/code-generator/cmd/go-to-protobuf/protoc-gen-gogo/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/import-boss/.gitignore create mode 100644 vendor/k8s.io/code-generator/cmd/import-boss/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/args/args.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/generators/factory.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/generators/factoryinterface.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/generators/generic.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/generators/groupinterface.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/generators/informer.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/generators/packages.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/generators/tags.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/generators/types.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/generators/versioninterface.go create mode 100644 vendor/k8s.io/code-generator/cmd/informer-gen/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/lister-gen/.import-restrictions create mode 100644 vendor/k8s.io/code-generator/cmd/lister-gen/args/args.go create mode 100644 vendor/k8s.io/code-generator/cmd/lister-gen/generators/expansion.go create mode 100644 vendor/k8s.io/code-generator/cmd/lister-gen/generators/lister.go create mode 100644 vendor/k8s.io/code-generator/cmd/lister-gen/generators/tags.go create mode 100644 vendor/k8s.io/code-generator/cmd/lister-gen/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/register-gen/args/args.go create mode 100644 vendor/k8s.io/code-generator/cmd/register-gen/generators/packages.go create mode 100644 vendor/k8s.io/code-generator/cmd/register-gen/generators/register_external.go create mode 100644 vendor/k8s.io/code-generator/cmd/register-gen/main.go create mode 100644 vendor/k8s.io/code-generator/cmd/set-gen/.gitignore create mode 100644 vendor/k8s.io/code-generator/cmd/set-gen/main.go create mode 100644 vendor/k8s.io/kube-openapi/boilerplate/boilerplate.go.txt create mode 100644 vendor/k8s.io/kube-openapi/cmd/openapi-gen/args/args.go create mode 100644 vendor/k8s.io/kube-openapi/cmd/openapi-gen/openapi-gen.go create mode 100644 vendor/k8s.io/kube-openapi/cmd/openapi2smd/openapi2smd.go diff --git a/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go b/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go index 3a4633b4eb..903ae1f40c 100644 --- a/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go +++ b/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go @@ -26,46 +26,21 @@ import ( ) // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. -func (in *CopyFrom) DeepCopyInto(out *CopyFrom) { +func (in *CloneFrom) DeepCopyInto(out *CloneFrom) { *out = *in return } -// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CopyFrom. -func (in *CopyFrom) DeepCopy() *CopyFrom { +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CloneFrom. +func (in *CloneFrom) DeepCopy() *CloneFrom { if in == nil { return nil } - out := new(CopyFrom) + out := new(CloneFrom) in.DeepCopyInto(out) return out } -// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. -func (in *Generation) DeepCopyInto(out *Generation) { - *out = *in - if in.CopyFrom != nil { - in, out := &in.CopyFrom, &out.CopyFrom - *out = new(CopyFrom) - **out = **in - } - if in.Data != nil { - in, out := &in.Data, &out.Data - *out = make(map[string]string, len(*in)) - for key, val := range *in { - (*out)[key] = val - } - } - if in.Labels != nil { - in, out := &in.Labels, &out.Labels - *out = make(map[string]string, len(*in)) - for key, val := range *in { - (*out)[key] = val - } - } - return -} - // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Generation. func (in *Generation) DeepCopy() *Generation { if in == nil { @@ -150,6 +125,11 @@ func (in *PolicyList) DeepCopyObject() runtime.Object { // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *ResourceDescription) DeepCopyInto(out *ResourceDescription) { *out = *in + if in.Kinds != nil { + in, out := &in.Kinds, &out.Kinds + *out = make([]string, len(*in)) + copy(*out, *in) + } if in.Name != nil { in, out := &in.Name, &out.Name *out = new(string) @@ -187,8 +167,7 @@ func (in *Rule) DeepCopyInto(out *Rule) { } if in.Generation != nil { in, out := &in.Generation, &out.Generation - *out = new(Generation) - (*in).DeepCopyInto(*out) + *out = (*in).DeepCopy() } return } diff --git a/vendor/github.com/evanphx/json-patch/cmd/json-patch/file_flag.go b/vendor/github.com/evanphx/json-patch/cmd/json-patch/file_flag.go new file mode 100644 index 0000000000..fe69d6e2a4 --- /dev/null +++ b/vendor/github.com/evanphx/json-patch/cmd/json-patch/file_flag.go @@ -0,0 +1,39 @@ +package main + +// Borrowed from Concourse: https://github.com/concourse/atc/blob/master/atccmd/file_flag.go + +import ( + "fmt" + "os" + "path/filepath" +) + +// FileFlag is a flag for passing a path to a file on disk. The file is +// expected to be a file, not a directory, that actually exists. +type FileFlag string + +// UnmarshalFlag implements go-flag's Unmarshaler interface +func (f *FileFlag) UnmarshalFlag(value string) error { + stat, err := os.Stat(value) + if err != nil { + return err + } + + if stat.IsDir() { + return fmt.Errorf("path '%s' is a directory, not a file", value) + } + + abs, err := filepath.Abs(value) + if err != nil { + return err + } + + *f = FileFlag(abs) + + return nil +} + +// Path is the path to the file +func (f FileFlag) Path() string { + return string(f) +} diff --git a/vendor/github.com/evanphx/json-patch/cmd/json-patch/main.go b/vendor/github.com/evanphx/json-patch/cmd/json-patch/main.go new file mode 100644 index 0000000000..2be1826359 --- /dev/null +++ b/vendor/github.com/evanphx/json-patch/cmd/json-patch/main.go @@ -0,0 +1,56 @@ +package main + +import ( + "fmt" + "io/ioutil" + "log" + "os" + + jsonpatch "github.com/evanphx/json-patch" + flags "github.com/jessevdk/go-flags" +) + +type opts struct { + PatchFilePaths []FileFlag `long:"patch-file" short:"p" value-name:"PATH" description:"Path to file with one or more operations"` +} + +func main() { + var o opts + _, err := flags.Parse(&o) + if err != nil { + log.Fatalf("error: %s\n", err) + } + + patches := make([]jsonpatch.Patch, len(o.PatchFilePaths)) + + for i, patchFilePath := range o.PatchFilePaths { + var bs []byte + bs, err = ioutil.ReadFile(patchFilePath.Path()) + if err != nil { + log.Fatalf("error reading patch file: %s", err) + } + + var patch jsonpatch.Patch + patch, err = jsonpatch.DecodePatch(bs) + if err != nil { + log.Fatalf("error decoding patch file: %s", err) + } + + patches[i] = patch + } + + doc, err := ioutil.ReadAll(os.Stdin) + if err != nil { + log.Fatalf("error reading from stdin: %s", err) + } + + mdoc := doc + for _, patch := range patches { + mdoc, err = patch.Apply(mdoc) + if err != nil { + log.Fatalf("error applying patch: %s", err) + } + } + + fmt.Printf("%s", mdoc) +} diff --git a/vendor/github.com/golang/glog/LICENSE b/vendor/github.com/golang/glog/LICENSE new file mode 100644 index 0000000000..37ec93a14f --- /dev/null +++ b/vendor/github.com/golang/glog/LICENSE @@ -0,0 +1,191 @@ +Apache License +Version 2.0, January 2004 +http://www.apache.org/licenses/ + +TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + +1. Definitions. + +"License" shall mean the terms and conditions for use, reproduction, and +distribution as defined by Sections 1 through 9 of this document. + +"Licensor" shall mean the copyright owner or entity authorized by the copyright +owner that is granting the License. + +"Legal Entity" shall mean the union of the acting entity and all other entities +that control, are controlled by, or are under common control with that entity. +For the purposes of this definition, "control" means (i) the power, direct or +indirect, to cause the direction or management of such entity, whether by +contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the +outstanding shares, or (iii) beneficial ownership of such entity. + +"You" (or "Your") shall mean an individual or Legal Entity exercising +permissions granted by this License. + +"Source" form shall mean the preferred form for making modifications, including +but not limited to software source code, documentation source, and configuration +files. + +"Object" form shall mean any form resulting from mechanical transformation or +translation of a Source form, including but not limited to compiled object code, +generated documentation, and conversions to other media types. + +"Work" shall mean the work of authorship, whether in Source or Object form, made +available under the License, as indicated by a copyright notice that is included +in or attached to the work (an example is provided in the Appendix below). + +"Derivative Works" shall mean any work, whether in Source or Object form, that +is based on (or derived from) the Work and for which the editorial revisions, +annotations, elaborations, or other modifications represent, as a whole, an +original work of authorship. For the purposes of this License, Derivative Works +shall not include works that remain separable from, or merely link (or bind by +name) to the interfaces of, the Work and Derivative Works thereof. + +"Contribution" shall mean any work of authorship, including the original version +of the Work and any modifications or additions to that Work or Derivative Works +thereof, that is intentionally submitted to Licensor for inclusion in the Work +by the copyright owner or by an individual or Legal Entity authorized to submit +on behalf of the copyright owner. For the purposes of this definition, +"submitted" means any form of electronic, verbal, or written communication sent +to the Licensor or its representatives, including but not limited to +communication on electronic mailing lists, source code control systems, and +issue tracking systems that are managed by, or on behalf of, the Licensor for +the purpose of discussing and improving the Work, but excluding communication +that is conspicuously marked or otherwise designated in writing by the copyright +owner as "Not a Contribution." + +"Contributor" shall mean Licensor and any individual or Legal Entity on behalf +of whom a Contribution has been received by Licensor and subsequently +incorporated within the Work. + +2. Grant of Copyright License. + +Subject to the terms and conditions of this License, each Contributor hereby +grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, +irrevocable copyright license to reproduce, prepare Derivative Works of, +publicly display, publicly perform, sublicense, and distribute the Work and such +Derivative Works in Source or Object form. + +3. Grant of Patent License. + +Subject to the terms and conditions of this License, each Contributor hereby +grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, +irrevocable (except as stated in this section) patent license to make, have +made, use, offer to sell, sell, import, and otherwise transfer the Work, where +such license applies only to those patent claims licensable by such Contributor +that are necessarily infringed by their Contribution(s) alone or by combination +of their Contribution(s) with the Work to which such Contribution(s) was +submitted. If You institute patent litigation against any entity (including a +cross-claim or counterclaim in a lawsuit) alleging that the Work or a +Contribution incorporated within the Work constitutes direct or contributory +patent infringement, then any patent licenses granted to You under this License +for that Work shall terminate as of the date such litigation is filed. + +4. Redistribution. + +You may reproduce and distribute copies of the Work or Derivative Works thereof +in any medium, with or without modifications, and in Source or Object form, +provided that You meet the following conditions: + +You must give any other recipients of the Work or Derivative Works a copy of +this License; and +You must cause any modified files to carry prominent notices stating that You +changed the files; and +You must retain, in the Source form of any Derivative Works that You distribute, +all copyright, patent, trademark, and attribution notices from the Source form +of the Work, excluding those notices that do not pertain to any part of the +Derivative Works; and +If the Work includes a "NOTICE" text file as part of its distribution, then any +Derivative Works that You distribute must include a readable copy of the +attribution notices contained within such NOTICE file, excluding those notices +that do not pertain to any part of the Derivative Works, in at least one of the +following places: within a NOTICE text file distributed as part of the +Derivative Works; within the Source form or documentation, if provided along +with the Derivative Works; or, within a display generated by the Derivative +Works, if and wherever such third-party notices normally appear. The contents of +the NOTICE file are for informational purposes only and do not modify the +License. You may add Your own attribution notices within Derivative Works that +You distribute, alongside or as an addendum to the NOTICE text from the Work, +provided that such additional attribution notices cannot be construed as +modifying the License. +You may add Your own copyright statement to Your modifications and may provide +additional or different license terms and conditions for use, reproduction, or +distribution of Your modifications, or for any such Derivative Works as a whole, +provided Your use, reproduction, and distribution of the Work otherwise complies +with the conditions stated in this License. + +5. Submission of Contributions. + +Unless You explicitly state otherwise, any Contribution intentionally submitted +for inclusion in the Work by You to the Licensor shall be under the terms and +conditions of this License, without any additional terms or conditions. +Notwithstanding the above, nothing herein shall supersede or modify the terms of +any separate license agreement you may have executed with Licensor regarding +such Contributions. + +6. Trademarks. + +This License does not grant permission to use the trade names, trademarks, +service marks, or product names of the Licensor, except as required for +reasonable and customary use in describing the origin of the Work and +reproducing the content of the NOTICE file. + +7. Disclaimer of Warranty. + +Unless required by applicable law or agreed to in writing, Licensor provides the +Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, +including, without limitation, any warranties or conditions of TITLE, +NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are +solely responsible for determining the appropriateness of using or +redistributing the Work and assume any risks associated with Your exercise of +permissions under this License. + +8. Limitation of Liability. + +In no event and under no legal theory, whether in tort (including negligence), +contract, or otherwise, unless required by applicable law (such as deliberate +and grossly negligent acts) or agreed to in writing, shall any Contributor be +liable to You for damages, including any direct, indirect, special, incidental, +or consequential damages of any character arising as a result of this License or +out of the use or inability to use the Work (including but not limited to +damages for loss of goodwill, work stoppage, computer failure or malfunction, or +any and all other commercial damages or losses), even if such Contributor has +been advised of the possibility of such damages. + +9. Accepting Warranty or Additional Liability. + +While redistributing the Work or Derivative Works thereof, You may choose to +offer, and charge a fee for, acceptance of support, warranty, indemnity, or +other liability obligations and/or rights consistent with this License. However, +in accepting such obligations, You may act only on Your own behalf and on Your +sole responsibility, not on behalf of any other Contributor, and only if You +agree to indemnify, defend, and hold each Contributor harmless for any liability +incurred by, or claims asserted against, such Contributor by reason of your +accepting any such warranty or additional liability. + +END OF TERMS AND CONDITIONS + +APPENDIX: How to apply the Apache License to your work + +To apply the Apache License to your work, attach the following boilerplate +notice, with the fields enclosed by brackets "[]" replaced with your own +identifying information. (Don't include the brackets!) The text should be +enclosed in the appropriate comment syntax for the file format. We also +recommend that a file or class name and description of purpose be included on +the same "printed page" as the copyright notice for easier identification within +third-party archives. + + Copyright [yyyy] [name of copyright owner] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/vendor/github.com/golang/glog/README b/vendor/github.com/golang/glog/README new file mode 100644 index 0000000000..387b4eb689 --- /dev/null +++ b/vendor/github.com/golang/glog/README @@ -0,0 +1,44 @@ +glog +==== + +Leveled execution logs for Go. + +This is an efficient pure Go implementation of leveled logs in the +manner of the open source C++ package + https://github.com/google/glog + +By binding methods to booleans it is possible to use the log package +without paying the expense of evaluating the arguments to the log. +Through the -vmodule flag, the package also provides fine-grained +control over logging at the file level. + +The comment from glog.go introduces the ideas: + + Package glog implements logging analogous to the Google-internal + C++ INFO/ERROR/V setup. It provides functions Info, Warning, + Error, Fatal, plus formatting variants such as Infof. It + also provides V-style logging controlled by the -v and + -vmodule=file=2 flags. + + Basic examples: + + glog.Info("Prepare to repel boarders") + + glog.Fatalf("Initialization failed: %s", err) + + See the documentation for the V function for an explanation + of these examples: + + if glog.V(2) { + glog.Info("Starting transaction...") + } + + glog.V(2).Infoln("Processed", nItems, "elements") + + +The repository contains an open source version of the log package +used inside Google. The master copy of the source lives inside +Google, not here. The code in this repo is for export only and is not itself +under development. Feature requests will be ignored. + +Send bug reports to golang-nuts@googlegroups.com. diff --git a/vendor/github.com/golang/glog/glog.go b/vendor/github.com/golang/glog/glog.go new file mode 100644 index 0000000000..54bd7afdca --- /dev/null +++ b/vendor/github.com/golang/glog/glog.go @@ -0,0 +1,1180 @@ +// Go support for leveled logs, analogous to https://code.google.com/p/google-glog/ +// +// Copyright 2013 Google Inc. All Rights Reserved. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Package glog implements logging analogous to the Google-internal C++ INFO/ERROR/V setup. +// It provides functions Info, Warning, Error, Fatal, plus formatting variants such as +// Infof. It also provides V-style logging controlled by the -v and -vmodule=file=2 flags. +// +// Basic examples: +// +// glog.Info("Prepare to repel boarders") +// +// glog.Fatalf("Initialization failed: %s", err) +// +// See the documentation for the V function for an explanation of these examples: +// +// if glog.V(2) { +// glog.Info("Starting transaction...") +// } +// +// glog.V(2).Infoln("Processed", nItems, "elements") +// +// Log output is buffered and written periodically using Flush. Programs +// should call Flush before exiting to guarantee all log output is written. +// +// By default, all log statements write to files in a temporary directory. +// This package provides several flags that modify this behavior. +// As a result, flag.Parse must be called before any logging is done. +// +// -logtostderr=false +// Logs are written to standard error instead of to files. +// -alsologtostderr=false +// Logs are written to standard error as well as to files. +// -stderrthreshold=ERROR +// Log events at or above this severity are logged to standard +// error as well as to files. +// -log_dir="" +// Log files will be written to this directory instead of the +// default temporary directory. +// +// Other flags provide aids to debugging. +// +// -log_backtrace_at="" +// When set to a file and line number holding a logging statement, +// such as +// -log_backtrace_at=gopherflakes.go:234 +// a stack trace will be written to the Info log whenever execution +// hits that statement. (Unlike with -vmodule, the ".go" must be +// present.) +// -v=0 +// Enable V-leveled logging at the specified level. +// -vmodule="" +// The syntax of the argument is a comma-separated list of pattern=N, +// where pattern is a literal file name (minus the ".go" suffix) or +// "glob" pattern and N is a V level. For instance, +// -vmodule=gopher*=3 +// sets the V level to 3 in all Go files whose names begin "gopher". +// +package glog + +import ( + "bufio" + "bytes" + "errors" + "flag" + "fmt" + "io" + stdLog "log" + "os" + "path/filepath" + "runtime" + "strconv" + "strings" + "sync" + "sync/atomic" + "time" +) + +// severity identifies the sort of log: info, warning etc. It also implements +// the flag.Value interface. The -stderrthreshold flag is of type severity and +// should be modified only through the flag.Value interface. The values match +// the corresponding constants in C++. +type severity int32 // sync/atomic int32 + +// These constants identify the log levels in order of increasing severity. +// A message written to a high-severity log file is also written to each +// lower-severity log file. +const ( + infoLog severity = iota + warningLog + errorLog + fatalLog + numSeverity = 4 +) + +const severityChar = "IWEF" + +var severityName = []string{ + infoLog: "INFO", + warningLog: "WARNING", + errorLog: "ERROR", + fatalLog: "FATAL", +} + +// get returns the value of the severity. +func (s *severity) get() severity { + return severity(atomic.LoadInt32((*int32)(s))) +} + +// set sets the value of the severity. +func (s *severity) set(val severity) { + atomic.StoreInt32((*int32)(s), int32(val)) +} + +// String is part of the flag.Value interface. +func (s *severity) String() string { + return strconv.FormatInt(int64(*s), 10) +} + +// Get is part of the flag.Value interface. +func (s *severity) Get() interface{} { + return *s +} + +// Set is part of the flag.Value interface. +func (s *severity) Set(value string) error { + var threshold severity + // Is it a known name? + if v, ok := severityByName(value); ok { + threshold = v + } else { + v, err := strconv.Atoi(value) + if err != nil { + return err + } + threshold = severity(v) + } + logging.stderrThreshold.set(threshold) + return nil +} + +func severityByName(s string) (severity, bool) { + s = strings.ToUpper(s) + for i, name := range severityName { + if name == s { + return severity(i), true + } + } + return 0, false +} + +// OutputStats tracks the number of output lines and bytes written. +type OutputStats struct { + lines int64 + bytes int64 +} + +// Lines returns the number of lines written. +func (s *OutputStats) Lines() int64 { + return atomic.LoadInt64(&s.lines) +} + +// Bytes returns the number of bytes written. +func (s *OutputStats) Bytes() int64 { + return atomic.LoadInt64(&s.bytes) +} + +// Stats tracks the number of lines of output and number of bytes +// per severity level. Values must be read with atomic.LoadInt64. +var Stats struct { + Info, Warning, Error OutputStats +} + +var severityStats = [numSeverity]*OutputStats{ + infoLog: &Stats.Info, + warningLog: &Stats.Warning, + errorLog: &Stats.Error, +} + +// Level is exported because it appears in the arguments to V and is +// the type of the v flag, which can be set programmatically. +// It's a distinct type because we want to discriminate it from logType. +// Variables of type level are only changed under logging.mu. +// The -v flag is read only with atomic ops, so the state of the logging +// module is consistent. + +// Level is treated as a sync/atomic int32. + +// Level specifies a level of verbosity for V logs. *Level implements +// flag.Value; the -v flag is of type Level and should be modified +// only through the flag.Value interface. +type Level int32 + +// get returns the value of the Level. +func (l *Level) get() Level { + return Level(atomic.LoadInt32((*int32)(l))) +} + +// set sets the value of the Level. +func (l *Level) set(val Level) { + atomic.StoreInt32((*int32)(l), int32(val)) +} + +// String is part of the flag.Value interface. +func (l *Level) String() string { + return strconv.FormatInt(int64(*l), 10) +} + +// Get is part of the flag.Value interface. +func (l *Level) Get() interface{} { + return *l +} + +// Set is part of the flag.Value interface. +func (l *Level) Set(value string) error { + v, err := strconv.Atoi(value) + if err != nil { + return err + } + logging.mu.Lock() + defer logging.mu.Unlock() + logging.setVState(Level(v), logging.vmodule.filter, false) + return nil +} + +// moduleSpec represents the setting of the -vmodule flag. +type moduleSpec struct { + filter []modulePat +} + +// modulePat contains a filter for the -vmodule flag. +// It holds a verbosity level and a file pattern to match. +type modulePat struct { + pattern string + literal bool // The pattern is a literal string + level Level +} + +// match reports whether the file matches the pattern. It uses a string +// comparison if the pattern contains no metacharacters. +func (m *modulePat) match(file string) bool { + if m.literal { + return file == m.pattern + } + match, _ := filepath.Match(m.pattern, file) + return match +} + +func (m *moduleSpec) String() string { + // Lock because the type is not atomic. TODO: clean this up. + logging.mu.Lock() + defer logging.mu.Unlock() + var b bytes.Buffer + for i, f := range m.filter { + if i > 0 { + b.WriteRune(',') + } + fmt.Fprintf(&b, "%s=%d", f.pattern, f.level) + } + return b.String() +} + +// Get is part of the (Go 1.2) flag.Getter interface. It always returns nil for this flag type since the +// struct is not exported. +func (m *moduleSpec) Get() interface{} { + return nil +} + +var errVmoduleSyntax = errors.New("syntax error: expect comma-separated list of filename=N") + +// Syntax: -vmodule=recordio=2,file=1,gfs*=3 +func (m *moduleSpec) Set(value string) error { + var filter []modulePat + for _, pat := range strings.Split(value, ",") { + if len(pat) == 0 { + // Empty strings such as from a trailing comma can be ignored. + continue + } + patLev := strings.Split(pat, "=") + if len(patLev) != 2 || len(patLev[0]) == 0 || len(patLev[1]) == 0 { + return errVmoduleSyntax + } + pattern := patLev[0] + v, err := strconv.Atoi(patLev[1]) + if err != nil { + return errors.New("syntax error: expect comma-separated list of filename=N") + } + if v < 0 { + return errors.New("negative value for vmodule level") + } + if v == 0 { + continue // Ignore. It's harmless but no point in paying the overhead. + } + // TODO: check syntax of filter? + filter = append(filter, modulePat{pattern, isLiteral(pattern), Level(v)}) + } + logging.mu.Lock() + defer logging.mu.Unlock() + logging.setVState(logging.verbosity, filter, true) + return nil +} + +// isLiteral reports whether the pattern is a literal string, that is, has no metacharacters +// that require filepath.Match to be called to match the pattern. +func isLiteral(pattern string) bool { + return !strings.ContainsAny(pattern, `\*?[]`) +} + +// traceLocation represents the setting of the -log_backtrace_at flag. +type traceLocation struct { + file string + line int +} + +// isSet reports whether the trace location has been specified. +// logging.mu is held. +func (t *traceLocation) isSet() bool { + return t.line > 0 +} + +// match reports whether the specified file and line matches the trace location. +// The argument file name is the full path, not the basename specified in the flag. +// logging.mu is held. +func (t *traceLocation) match(file string, line int) bool { + if t.line != line { + return false + } + if i := strings.LastIndex(file, "/"); i >= 0 { + file = file[i+1:] + } + return t.file == file +} + +func (t *traceLocation) String() string { + // Lock because the type is not atomic. TODO: clean this up. + logging.mu.Lock() + defer logging.mu.Unlock() + return fmt.Sprintf("%s:%d", t.file, t.line) +} + +// Get is part of the (Go 1.2) flag.Getter interface. It always returns nil for this flag type since the +// struct is not exported +func (t *traceLocation) Get() interface{} { + return nil +} + +var errTraceSyntax = errors.New("syntax error: expect file.go:234") + +// Syntax: -log_backtrace_at=gopherflakes.go:234 +// Note that unlike vmodule the file extension is included here. +func (t *traceLocation) Set(value string) error { + if value == "" { + // Unset. + t.line = 0 + t.file = "" + } + fields := strings.Split(value, ":") + if len(fields) != 2 { + return errTraceSyntax + } + file, line := fields[0], fields[1] + if !strings.Contains(file, ".") { + return errTraceSyntax + } + v, err := strconv.Atoi(line) + if err != nil { + return errTraceSyntax + } + if v <= 0 { + return errors.New("negative or zero value for level") + } + logging.mu.Lock() + defer logging.mu.Unlock() + t.line = v + t.file = file + return nil +} + +// flushSyncWriter is the interface satisfied by logging destinations. +type flushSyncWriter interface { + Flush() error + Sync() error + io.Writer +} + +func init() { + flag.BoolVar(&logging.toStderr, "logtostderr", false, "log to standard error instead of files") + flag.BoolVar(&logging.alsoToStderr, "alsologtostderr", false, "log to standard error as well as files") + flag.Var(&logging.verbosity, "v", "log level for V logs") + flag.Var(&logging.stderrThreshold, "stderrthreshold", "logs at or above this threshold go to stderr") + flag.Var(&logging.vmodule, "vmodule", "comma-separated list of pattern=N settings for file-filtered logging") + flag.Var(&logging.traceLocation, "log_backtrace_at", "when logging hits line file:N, emit a stack trace") + + // Default stderrThreshold is ERROR. + logging.stderrThreshold = errorLog + + logging.setVState(0, nil, false) + go logging.flushDaemon() +} + +// Flush flushes all pending log I/O. +func Flush() { + logging.lockAndFlushAll() +} + +// loggingT collects all the global state of the logging setup. +type loggingT struct { + // Boolean flags. Not handled atomically because the flag.Value interface + // does not let us avoid the =true, and that shorthand is necessary for + // compatibility. TODO: does this matter enough to fix? Seems unlikely. + toStderr bool // The -logtostderr flag. + alsoToStderr bool // The -alsologtostderr flag. + + // Level flag. Handled atomically. + stderrThreshold severity // The -stderrthreshold flag. + + // freeList is a list of byte buffers, maintained under freeListMu. + freeList *buffer + // freeListMu maintains the free list. It is separate from the main mutex + // so buffers can be grabbed and printed to without holding the main lock, + // for better parallelization. + freeListMu sync.Mutex + + // mu protects the remaining elements of this structure and is + // used to synchronize logging. + mu sync.Mutex + // file holds writer for each of the log types. + file [numSeverity]flushSyncWriter + // pcs is used in V to avoid an allocation when computing the caller's PC. + pcs [1]uintptr + // vmap is a cache of the V Level for each V() call site, identified by PC. + // It is wiped whenever the vmodule flag changes state. + vmap map[uintptr]Level + // filterLength stores the length of the vmodule filter chain. If greater + // than zero, it means vmodule is enabled. It may be read safely + // using sync.LoadInt32, but is only modified under mu. + filterLength int32 + // traceLocation is the state of the -log_backtrace_at flag. + traceLocation traceLocation + // These flags are modified only under lock, although verbosity may be fetched + // safely using atomic.LoadInt32. + vmodule moduleSpec // The state of the -vmodule flag. + verbosity Level // V logging level, the value of the -v flag/ +} + +// buffer holds a byte Buffer for reuse. The zero value is ready for use. +type buffer struct { + bytes.Buffer + tmp [64]byte // temporary byte array for creating headers. + next *buffer +} + +var logging loggingT + +// setVState sets a consistent state for V logging. +// l.mu is held. +func (l *loggingT) setVState(verbosity Level, filter []modulePat, setFilter bool) { + // Turn verbosity off so V will not fire while we are in transition. + logging.verbosity.set(0) + // Ditto for filter length. + atomic.StoreInt32(&logging.filterLength, 0) + + // Set the new filters and wipe the pc->Level map if the filter has changed. + if setFilter { + logging.vmodule.filter = filter + logging.vmap = make(map[uintptr]Level) + } + + // Things are consistent now, so enable filtering and verbosity. + // They are enabled in order opposite to that in V. + atomic.StoreInt32(&logging.filterLength, int32(len(filter))) + logging.verbosity.set(verbosity) +} + +// getBuffer returns a new, ready-to-use buffer. +func (l *loggingT) getBuffer() *buffer { + l.freeListMu.Lock() + b := l.freeList + if b != nil { + l.freeList = b.next + } + l.freeListMu.Unlock() + if b == nil { + b = new(buffer) + } else { + b.next = nil + b.Reset() + } + return b +} + +// putBuffer returns a buffer to the free list. +func (l *loggingT) putBuffer(b *buffer) { + if b.Len() >= 256 { + // Let big buffers die a natural death. + return + } + l.freeListMu.Lock() + b.next = l.freeList + l.freeList = b + l.freeListMu.Unlock() +} + +var timeNow = time.Now // Stubbed out for testing. + +/* +header formats a log header as defined by the C++ implementation. +It returns a buffer containing the formatted header and the user's file and line number. +The depth specifies how many stack frames above lives the source line to be identified in the log message. + +Log lines have this form: + Lmmdd hh:mm:ss.uuuuuu threadid file:line] msg... +where the fields are defined as follows: + L A single character, representing the log level (eg 'I' for INFO) + mm The month (zero padded; ie May is '05') + dd The day (zero padded) + hh:mm:ss.uuuuuu Time in hours, minutes and fractional seconds + threadid The space-padded thread ID as returned by GetTID() + file The file name + line The line number + msg The user-supplied message +*/ +func (l *loggingT) header(s severity, depth int) (*buffer, string, int) { + _, file, line, ok := runtime.Caller(3 + depth) + if !ok { + file = "???" + line = 1 + } else { + slash := strings.LastIndex(file, "/") + if slash >= 0 { + file = file[slash+1:] + } + } + return l.formatHeader(s, file, line), file, line +} + +// formatHeader formats a log header using the provided file name and line number. +func (l *loggingT) formatHeader(s severity, file string, line int) *buffer { + now := timeNow() + if line < 0 { + line = 0 // not a real line number, but acceptable to someDigits + } + if s > fatalLog { + s = infoLog // for safety. + } + buf := l.getBuffer() + + // Avoid Fprintf, for speed. The format is so simple that we can do it quickly by hand. + // It's worth about 3X. Fprintf is hard. + _, month, day := now.Date() + hour, minute, second := now.Clock() + // Lmmdd hh:mm:ss.uuuuuu threadid file:line] + buf.tmp[0] = severityChar[s] + buf.twoDigits(1, int(month)) + buf.twoDigits(3, day) + buf.tmp[5] = ' ' + buf.twoDigits(6, hour) + buf.tmp[8] = ':' + buf.twoDigits(9, minute) + buf.tmp[11] = ':' + buf.twoDigits(12, second) + buf.tmp[14] = '.' + buf.nDigits(6, 15, now.Nanosecond()/1000, '0') + buf.tmp[21] = ' ' + buf.nDigits(7, 22, pid, ' ') // TODO: should be TID + buf.tmp[29] = ' ' + buf.Write(buf.tmp[:30]) + buf.WriteString(file) + buf.tmp[0] = ':' + n := buf.someDigits(1, line) + buf.tmp[n+1] = ']' + buf.tmp[n+2] = ' ' + buf.Write(buf.tmp[:n+3]) + return buf +} + +// Some custom tiny helper functions to print the log header efficiently. + +const digits = "0123456789" + +// twoDigits formats a zero-prefixed two-digit integer at buf.tmp[i]. +func (buf *buffer) twoDigits(i, d int) { + buf.tmp[i+1] = digits[d%10] + d /= 10 + buf.tmp[i] = digits[d%10] +} + +// nDigits formats an n-digit integer at buf.tmp[i], +// padding with pad on the left. +// It assumes d >= 0. +func (buf *buffer) nDigits(n, i, d int, pad byte) { + j := n - 1 + for ; j >= 0 && d > 0; j-- { + buf.tmp[i+j] = digits[d%10] + d /= 10 + } + for ; j >= 0; j-- { + buf.tmp[i+j] = pad + } +} + +// someDigits formats a zero-prefixed variable-width integer at buf.tmp[i]. +func (buf *buffer) someDigits(i, d int) int { + // Print into the top, then copy down. We know there's space for at least + // a 10-digit number. + j := len(buf.tmp) + for { + j-- + buf.tmp[j] = digits[d%10] + d /= 10 + if d == 0 { + break + } + } + return copy(buf.tmp[i:], buf.tmp[j:]) +} + +func (l *loggingT) println(s severity, args ...interface{}) { + buf, file, line := l.header(s, 0) + fmt.Fprintln(buf, args...) + l.output(s, buf, file, line, false) +} + +func (l *loggingT) print(s severity, args ...interface{}) { + l.printDepth(s, 1, args...) +} + +func (l *loggingT) printDepth(s severity, depth int, args ...interface{}) { + buf, file, line := l.header(s, depth) + fmt.Fprint(buf, args...) + if buf.Bytes()[buf.Len()-1] != '\n' { + buf.WriteByte('\n') + } + l.output(s, buf, file, line, false) +} + +func (l *loggingT) printf(s severity, format string, args ...interface{}) { + buf, file, line := l.header(s, 0) + fmt.Fprintf(buf, format, args...) + if buf.Bytes()[buf.Len()-1] != '\n' { + buf.WriteByte('\n') + } + l.output(s, buf, file, line, false) +} + +// printWithFileLine behaves like print but uses the provided file and line number. If +// alsoLogToStderr is true, the log message always appears on standard error; it +// will also appear in the log file unless --logtostderr is set. +func (l *loggingT) printWithFileLine(s severity, file string, line int, alsoToStderr bool, args ...interface{}) { + buf := l.formatHeader(s, file, line) + fmt.Fprint(buf, args...) + if buf.Bytes()[buf.Len()-1] != '\n' { + buf.WriteByte('\n') + } + l.output(s, buf, file, line, alsoToStderr) +} + +// output writes the data to the log files and releases the buffer. +func (l *loggingT) output(s severity, buf *buffer, file string, line int, alsoToStderr bool) { + l.mu.Lock() + if l.traceLocation.isSet() { + if l.traceLocation.match(file, line) { + buf.Write(stacks(false)) + } + } + data := buf.Bytes() + if !flag.Parsed() { + os.Stderr.Write([]byte("ERROR: logging before flag.Parse: ")) + os.Stderr.Write(data) + } else if l.toStderr { + os.Stderr.Write(data) + } else { + if alsoToStderr || l.alsoToStderr || s >= l.stderrThreshold.get() { + os.Stderr.Write(data) + } + if l.file[s] == nil { + if err := l.createFiles(s); err != nil { + os.Stderr.Write(data) // Make sure the message appears somewhere. + l.exit(err) + } + } + switch s { + case fatalLog: + l.file[fatalLog].Write(data) + fallthrough + case errorLog: + l.file[errorLog].Write(data) + fallthrough + case warningLog: + l.file[warningLog].Write(data) + fallthrough + case infoLog: + l.file[infoLog].Write(data) + } + } + if s == fatalLog { + // If we got here via Exit rather than Fatal, print no stacks. + if atomic.LoadUint32(&fatalNoStacks) > 0 { + l.mu.Unlock() + timeoutFlush(10 * time.Second) + os.Exit(1) + } + // Dump all goroutine stacks before exiting. + // First, make sure we see the trace for the current goroutine on standard error. + // If -logtostderr has been specified, the loop below will do that anyway + // as the first stack in the full dump. + if !l.toStderr { + os.Stderr.Write(stacks(false)) + } + // Write the stack trace for all goroutines to the files. + trace := stacks(true) + logExitFunc = func(error) {} // If we get a write error, we'll still exit below. + for log := fatalLog; log >= infoLog; log-- { + if f := l.file[log]; f != nil { // Can be nil if -logtostderr is set. + f.Write(trace) + } + } + l.mu.Unlock() + timeoutFlush(10 * time.Second) + os.Exit(255) // C++ uses -1, which is silly because it's anded with 255 anyway. + } + l.putBuffer(buf) + l.mu.Unlock() + if stats := severityStats[s]; stats != nil { + atomic.AddInt64(&stats.lines, 1) + atomic.AddInt64(&stats.bytes, int64(len(data))) + } +} + +// timeoutFlush calls Flush and returns when it completes or after timeout +// elapses, whichever happens first. This is needed because the hooks invoked +// by Flush may deadlock when glog.Fatal is called from a hook that holds +// a lock. +func timeoutFlush(timeout time.Duration) { + done := make(chan bool, 1) + go func() { + Flush() // calls logging.lockAndFlushAll() + done <- true + }() + select { + case <-done: + case <-time.After(timeout): + fmt.Fprintln(os.Stderr, "glog: Flush took longer than", timeout) + } +} + +// stacks is a wrapper for runtime.Stack that attempts to recover the data for all goroutines. +func stacks(all bool) []byte { + // We don't know how big the traces are, so grow a few times if they don't fit. Start large, though. + n := 10000 + if all { + n = 100000 + } + var trace []byte + for i := 0; i < 5; i++ { + trace = make([]byte, n) + nbytes := runtime.Stack(trace, all) + if nbytes < len(trace) { + return trace[:nbytes] + } + n *= 2 + } + return trace +} + +// logExitFunc provides a simple mechanism to override the default behavior +// of exiting on error. Used in testing and to guarantee we reach a required exit +// for fatal logs. Instead, exit could be a function rather than a method but that +// would make its use clumsier. +var logExitFunc func(error) + +// exit is called if there is trouble creating or writing log files. +// It flushes the logs and exits the program; there's no point in hanging around. +// l.mu is held. +func (l *loggingT) exit(err error) { + fmt.Fprintf(os.Stderr, "log: exiting because of error: %s\n", err) + // If logExitFunc is set, we do that instead of exiting. + if logExitFunc != nil { + logExitFunc(err) + return + } + l.flushAll() + os.Exit(2) +} + +// syncBuffer joins a bufio.Writer to its underlying file, providing access to the +// file's Sync method and providing a wrapper for the Write method that provides log +// file rotation. There are conflicting methods, so the file cannot be embedded. +// l.mu is held for all its methods. +type syncBuffer struct { + logger *loggingT + *bufio.Writer + file *os.File + sev severity + nbytes uint64 // The number of bytes written to this file +} + +func (sb *syncBuffer) Sync() error { + return sb.file.Sync() +} + +func (sb *syncBuffer) Write(p []byte) (n int, err error) { + if sb.nbytes+uint64(len(p)) >= MaxSize { + if err := sb.rotateFile(time.Now()); err != nil { + sb.logger.exit(err) + } + } + n, err = sb.Writer.Write(p) + sb.nbytes += uint64(n) + if err != nil { + sb.logger.exit(err) + } + return +} + +// rotateFile closes the syncBuffer's file and starts a new one. +func (sb *syncBuffer) rotateFile(now time.Time) error { + if sb.file != nil { + sb.Flush() + sb.file.Close() + } + var err error + sb.file, _, err = create(severityName[sb.sev], now) + sb.nbytes = 0 + if err != nil { + return err + } + + sb.Writer = bufio.NewWriterSize(sb.file, bufferSize) + + // Write header. + var buf bytes.Buffer + fmt.Fprintf(&buf, "Log file created at: %s\n", now.Format("2006/01/02 15:04:05")) + fmt.Fprintf(&buf, "Running on machine: %s\n", host) + fmt.Fprintf(&buf, "Binary: Built with %s %s for %s/%s\n", runtime.Compiler, runtime.Version(), runtime.GOOS, runtime.GOARCH) + fmt.Fprintf(&buf, "Log line format: [IWEF]mmdd hh:mm:ss.uuuuuu threadid file:line] msg\n") + n, err := sb.file.Write(buf.Bytes()) + sb.nbytes += uint64(n) + return err +} + +// bufferSize sizes the buffer associated with each log file. It's large +// so that log records can accumulate without the logging thread blocking +// on disk I/O. The flushDaemon will block instead. +const bufferSize = 256 * 1024 + +// createFiles creates all the log files for severity from sev down to infoLog. +// l.mu is held. +func (l *loggingT) createFiles(sev severity) error { + now := time.Now() + // Files are created in decreasing severity order, so as soon as we find one + // has already been created, we can stop. + for s := sev; s >= infoLog && l.file[s] == nil; s-- { + sb := &syncBuffer{ + logger: l, + sev: s, + } + if err := sb.rotateFile(now); err != nil { + return err + } + l.file[s] = sb + } + return nil +} + +const flushInterval = 30 * time.Second + +// flushDaemon periodically flushes the log file buffers. +func (l *loggingT) flushDaemon() { + for _ = range time.NewTicker(flushInterval).C { + l.lockAndFlushAll() + } +} + +// lockAndFlushAll is like flushAll but locks l.mu first. +func (l *loggingT) lockAndFlushAll() { + l.mu.Lock() + l.flushAll() + l.mu.Unlock() +} + +// flushAll flushes all the logs and attempts to "sync" their data to disk. +// l.mu is held. +func (l *loggingT) flushAll() { + // Flush from fatal down, in case there's trouble flushing. + for s := fatalLog; s >= infoLog; s-- { + file := l.file[s] + if file != nil { + file.Flush() // ignore error + file.Sync() // ignore error + } + } +} + +// CopyStandardLogTo arranges for messages written to the Go "log" package's +// default logs to also appear in the Google logs for the named and lower +// severities. Subsequent changes to the standard log's default output location +// or format may break this behavior. +// +// Valid names are "INFO", "WARNING", "ERROR", and "FATAL". If the name is not +// recognized, CopyStandardLogTo panics. +func CopyStandardLogTo(name string) { + sev, ok := severityByName(name) + if !ok { + panic(fmt.Sprintf("log.CopyStandardLogTo(%q): unrecognized severity name", name)) + } + // Set a log format that captures the user's file and line: + // d.go:23: message + stdLog.SetFlags(stdLog.Lshortfile) + stdLog.SetOutput(logBridge(sev)) +} + +// logBridge provides the Write method that enables CopyStandardLogTo to connect +// Go's standard logs to the logs provided by this package. +type logBridge severity + +// Write parses the standard logging line and passes its components to the +// logger for severity(lb). +func (lb logBridge) Write(b []byte) (n int, err error) { + var ( + file = "???" + line = 1 + text string + ) + // Split "d.go:23: message" into "d.go", "23", and "message". + if parts := bytes.SplitN(b, []byte{':'}, 3); len(parts) != 3 || len(parts[0]) < 1 || len(parts[2]) < 1 { + text = fmt.Sprintf("bad log format: %s", b) + } else { + file = string(parts[0]) + text = string(parts[2][1:]) // skip leading space + line, err = strconv.Atoi(string(parts[1])) + if err != nil { + text = fmt.Sprintf("bad line number: %s", b) + line = 1 + } + } + // printWithFileLine with alsoToStderr=true, so standard log messages + // always appear on standard error. + logging.printWithFileLine(severity(lb), file, line, true, text) + return len(b), nil +} + +// setV computes and remembers the V level for a given PC +// when vmodule is enabled. +// File pattern matching takes the basename of the file, stripped +// of its .go suffix, and uses filepath.Match, which is a little more +// general than the *? matching used in C++. +// l.mu is held. +func (l *loggingT) setV(pc uintptr) Level { + fn := runtime.FuncForPC(pc) + file, _ := fn.FileLine(pc) + // The file is something like /a/b/c/d.go. We want just the d. + if strings.HasSuffix(file, ".go") { + file = file[:len(file)-3] + } + if slash := strings.LastIndex(file, "/"); slash >= 0 { + file = file[slash+1:] + } + for _, filter := range l.vmodule.filter { + if filter.match(file) { + l.vmap[pc] = filter.level + return filter.level + } + } + l.vmap[pc] = 0 + return 0 +} + +// Verbose is a boolean type that implements Infof (like Printf) etc. +// See the documentation of V for more information. +type Verbose bool + +// V reports whether verbosity at the call site is at least the requested level. +// The returned value is a boolean of type Verbose, which implements Info, Infoln +// and Infof. These methods will write to the Info log if called. +// Thus, one may write either +// if glog.V(2) { glog.Info("log this") } +// or +// glog.V(2).Info("log this") +// The second form is shorter but the first is cheaper if logging is off because it does +// not evaluate its arguments. +// +// Whether an individual call to V generates a log record depends on the setting of +// the -v and --vmodule flags; both are off by default. If the level in the call to +// V is at least the value of -v, or of -vmodule for the source file containing the +// call, the V call will log. +func V(level Level) Verbose { + // This function tries hard to be cheap unless there's work to do. + // The fast path is two atomic loads and compares. + + // Here is a cheap but safe test to see if V logging is enabled globally. + if logging.verbosity.get() >= level { + return Verbose(true) + } + + // It's off globally but it vmodule may still be set. + // Here is another cheap but safe test to see if vmodule is enabled. + if atomic.LoadInt32(&logging.filterLength) > 0 { + // Now we need a proper lock to use the logging structure. The pcs field + // is shared so we must lock before accessing it. This is fairly expensive, + // but if V logging is enabled we're slow anyway. + logging.mu.Lock() + defer logging.mu.Unlock() + if runtime.Callers(2, logging.pcs[:]) == 0 { + return Verbose(false) + } + v, ok := logging.vmap[logging.pcs[0]] + if !ok { + v = logging.setV(logging.pcs[0]) + } + return Verbose(v >= level) + } + return Verbose(false) +} + +// Info is equivalent to the global Info function, guarded by the value of v. +// See the documentation of V for usage. +func (v Verbose) Info(args ...interface{}) { + if v { + logging.print(infoLog, args...) + } +} + +// Infoln is equivalent to the global Infoln function, guarded by the value of v. +// See the documentation of V for usage. +func (v Verbose) Infoln(args ...interface{}) { + if v { + logging.println(infoLog, args...) + } +} + +// Infof is equivalent to the global Infof function, guarded by the value of v. +// See the documentation of V for usage. +func (v Verbose) Infof(format string, args ...interface{}) { + if v { + logging.printf(infoLog, format, args...) + } +} + +// Info logs to the INFO log. +// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. +func Info(args ...interface{}) { + logging.print(infoLog, args...) +} + +// InfoDepth acts as Info but uses depth to determine which call frame to log. +// InfoDepth(0, "msg") is the same as Info("msg"). +func InfoDepth(depth int, args ...interface{}) { + logging.printDepth(infoLog, depth, args...) +} + +// Infoln logs to the INFO log. +// Arguments are handled in the manner of fmt.Println; a newline is appended if missing. +func Infoln(args ...interface{}) { + logging.println(infoLog, args...) +} + +// Infof logs to the INFO log. +// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. +func Infof(format string, args ...interface{}) { + logging.printf(infoLog, format, args...) +} + +// Warning logs to the WARNING and INFO logs. +// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. +func Warning(args ...interface{}) { + logging.print(warningLog, args...) +} + +// WarningDepth acts as Warning but uses depth to determine which call frame to log. +// WarningDepth(0, "msg") is the same as Warning("msg"). +func WarningDepth(depth int, args ...interface{}) { + logging.printDepth(warningLog, depth, args...) +} + +// Warningln logs to the WARNING and INFO logs. +// Arguments are handled in the manner of fmt.Println; a newline is appended if missing. +func Warningln(args ...interface{}) { + logging.println(warningLog, args...) +} + +// Warningf logs to the WARNING and INFO logs. +// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. +func Warningf(format string, args ...interface{}) { + logging.printf(warningLog, format, args...) +} + +// Error logs to the ERROR, WARNING, and INFO logs. +// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. +func Error(args ...interface{}) { + logging.print(errorLog, args...) +} + +// ErrorDepth acts as Error but uses depth to determine which call frame to log. +// ErrorDepth(0, "msg") is the same as Error("msg"). +func ErrorDepth(depth int, args ...interface{}) { + logging.printDepth(errorLog, depth, args...) +} + +// Errorln logs to the ERROR, WARNING, and INFO logs. +// Arguments are handled in the manner of fmt.Println; a newline is appended if missing. +func Errorln(args ...interface{}) { + logging.println(errorLog, args...) +} + +// Errorf logs to the ERROR, WARNING, and INFO logs. +// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. +func Errorf(format string, args ...interface{}) { + logging.printf(errorLog, format, args...) +} + +// Fatal logs to the FATAL, ERROR, WARNING, and INFO logs, +// including a stack trace of all running goroutines, then calls os.Exit(255). +// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. +func Fatal(args ...interface{}) { + logging.print(fatalLog, args...) +} + +// FatalDepth acts as Fatal but uses depth to determine which call frame to log. +// FatalDepth(0, "msg") is the same as Fatal("msg"). +func FatalDepth(depth int, args ...interface{}) { + logging.printDepth(fatalLog, depth, args...) +} + +// Fatalln logs to the FATAL, ERROR, WARNING, and INFO logs, +// including a stack trace of all running goroutines, then calls os.Exit(255). +// Arguments are handled in the manner of fmt.Println; a newline is appended if missing. +func Fatalln(args ...interface{}) { + logging.println(fatalLog, args...) +} + +// Fatalf logs to the FATAL, ERROR, WARNING, and INFO logs, +// including a stack trace of all running goroutines, then calls os.Exit(255). +// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. +func Fatalf(format string, args ...interface{}) { + logging.printf(fatalLog, format, args...) +} + +// fatalNoStacks is non-zero if we are to exit without dumping goroutine stacks. +// It allows Exit and relatives to use the Fatal logs. +var fatalNoStacks uint32 + +// Exit logs to the FATAL, ERROR, WARNING, and INFO logs, then calls os.Exit(1). +// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. +func Exit(args ...interface{}) { + atomic.StoreUint32(&fatalNoStacks, 1) + logging.print(fatalLog, args...) +} + +// ExitDepth acts as Exit but uses depth to determine which call frame to log. +// ExitDepth(0, "msg") is the same as Exit("msg"). +func ExitDepth(depth int, args ...interface{}) { + atomic.StoreUint32(&fatalNoStacks, 1) + logging.printDepth(fatalLog, depth, args...) +} + +// Exitln logs to the FATAL, ERROR, WARNING, and INFO logs, then calls os.Exit(1). +func Exitln(args ...interface{}) { + atomic.StoreUint32(&fatalNoStacks, 1) + logging.println(fatalLog, args...) +} + +// Exitf logs to the FATAL, ERROR, WARNING, and INFO logs, then calls os.Exit(1). +// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. +func Exitf(format string, args ...interface{}) { + atomic.StoreUint32(&fatalNoStacks, 1) + logging.printf(fatalLog, format, args...) +} diff --git a/vendor/github.com/golang/glog/glog_file.go b/vendor/github.com/golang/glog/glog_file.go new file mode 100644 index 0000000000..65075d2811 --- /dev/null +++ b/vendor/github.com/golang/glog/glog_file.go @@ -0,0 +1,124 @@ +// Go support for leveled logs, analogous to https://code.google.com/p/google-glog/ +// +// Copyright 2013 Google Inc. All Rights Reserved. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// File I/O for logs. + +package glog + +import ( + "errors" + "flag" + "fmt" + "os" + "os/user" + "path/filepath" + "strings" + "sync" + "time" +) + +// MaxSize is the maximum size of a log file in bytes. +var MaxSize uint64 = 1024 * 1024 * 1800 + +// logDirs lists the candidate directories for new log files. +var logDirs []string + +// If non-empty, overrides the choice of directory in which to write logs. +// See createLogDirs for the full list of possible destinations. +var logDir = flag.String("log_dir", "", "If non-empty, write log files in this directory") + +func createLogDirs() { + if *logDir != "" { + logDirs = append(logDirs, *logDir) + } + logDirs = append(logDirs, os.TempDir()) +} + +var ( + pid = os.Getpid() + program = filepath.Base(os.Args[0]) + host = "unknownhost" + userName = "unknownuser" +) + +func init() { + h, err := os.Hostname() + if err == nil { + host = shortHostname(h) + } + + current, err := user.Current() + if err == nil { + userName = current.Username + } + + // Sanitize userName since it may contain filepath separators on Windows. + userName = strings.Replace(userName, `\`, "_", -1) +} + +// shortHostname returns its argument, truncating at the first period. +// For instance, given "www.google.com" it returns "www". +func shortHostname(hostname string) string { + if i := strings.Index(hostname, "."); i >= 0 { + return hostname[:i] + } + return hostname +} + +// logName returns a new log file name containing tag, with start time t, and +// the name for the symlink for tag. +func logName(tag string, t time.Time) (name, link string) { + name = fmt.Sprintf("%s.%s.%s.log.%s.%04d%02d%02d-%02d%02d%02d.%d", + program, + host, + userName, + tag, + t.Year(), + t.Month(), + t.Day(), + t.Hour(), + t.Minute(), + t.Second(), + pid) + return name, program + "." + tag +} + +var onceLogDirs sync.Once + +// create creates a new log file and returns the file and its filename, which +// contains tag ("INFO", "FATAL", etc.) and t. If the file is created +// successfully, create also attempts to update the symlink for that tag, ignoring +// errors. +func create(tag string, t time.Time) (f *os.File, filename string, err error) { + onceLogDirs.Do(createLogDirs) + if len(logDirs) == 0 { + return nil, "", errors.New("log: no log dirs") + } + name, link := logName(tag, t) + var lastErr error + for _, dir := range logDirs { + fname := filepath.Join(dir, name) + f, err := os.Create(fname) + if err == nil { + symlink := filepath.Join(dir, link) + os.Remove(symlink) // ignore err + os.Symlink(name, symlink) // ignore err + return f, fname, nil + } + lastErr = err + } + return nil, "", fmt.Errorf("log: cannot create log: %v", lastErr) +} diff --git a/vendor/github.com/golang/glog/glog_test.go b/vendor/github.com/golang/glog/glog_test.go new file mode 100644 index 0000000000..0fb376e1fd --- /dev/null +++ b/vendor/github.com/golang/glog/glog_test.go @@ -0,0 +1,415 @@ +// Go support for leveled logs, analogous to https://code.google.com/p/google-glog/ +// +// Copyright 2013 Google Inc. All Rights Reserved. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package glog + +import ( + "bytes" + "fmt" + stdLog "log" + "path/filepath" + "runtime" + "strconv" + "strings" + "testing" + "time" +) + +// Test that shortHostname works as advertised. +func TestShortHostname(t *testing.T) { + for hostname, expect := range map[string]string{ + "": "", + "host": "host", + "host.google.com": "host", + } { + if got := shortHostname(hostname); expect != got { + t.Errorf("shortHostname(%q): expected %q, got %q", hostname, expect, got) + } + } +} + +// flushBuffer wraps a bytes.Buffer to satisfy flushSyncWriter. +type flushBuffer struct { + bytes.Buffer +} + +func (f *flushBuffer) Flush() error { + return nil +} + +func (f *flushBuffer) Sync() error { + return nil +} + +// swap sets the log writers and returns the old array. +func (l *loggingT) swap(writers [numSeverity]flushSyncWriter) (old [numSeverity]flushSyncWriter) { + l.mu.Lock() + defer l.mu.Unlock() + old = l.file + for i, w := range writers { + logging.file[i] = w + } + return +} + +// newBuffers sets the log writers to all new byte buffers and returns the old array. +func (l *loggingT) newBuffers() [numSeverity]flushSyncWriter { + return l.swap([numSeverity]flushSyncWriter{new(flushBuffer), new(flushBuffer), new(flushBuffer), new(flushBuffer)}) +} + +// contents returns the specified log value as a string. +func contents(s severity) string { + return logging.file[s].(*flushBuffer).String() +} + +// contains reports whether the string is contained in the log. +func contains(s severity, str string, t *testing.T) bool { + return strings.Contains(contents(s), str) +} + +// setFlags configures the logging flags how the test expects them. +func setFlags() { + logging.toStderr = false +} + +// Test that Info works as advertised. +func TestInfo(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + Info("test") + if !contains(infoLog, "I", t) { + t.Errorf("Info has wrong character: %q", contents(infoLog)) + } + if !contains(infoLog, "test", t) { + t.Error("Info failed") + } +} + +func TestInfoDepth(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + + f := func() { InfoDepth(1, "depth-test1") } + + // The next three lines must stay together + _, _, wantLine, _ := runtime.Caller(0) + InfoDepth(0, "depth-test0") + f() + + msgs := strings.Split(strings.TrimSuffix(contents(infoLog), "\n"), "\n") + if len(msgs) != 2 { + t.Fatalf("Got %d lines, expected 2", len(msgs)) + } + + for i, m := range msgs { + if !strings.HasPrefix(m, "I") { + t.Errorf("InfoDepth[%d] has wrong character: %q", i, m) + } + w := fmt.Sprintf("depth-test%d", i) + if !strings.Contains(m, w) { + t.Errorf("InfoDepth[%d] missing %q: %q", i, w, m) + } + + // pull out the line number (between : and ]) + msg := m[strings.LastIndex(m, ":")+1:] + x := strings.Index(msg, "]") + if x < 0 { + t.Errorf("InfoDepth[%d]: missing ']': %q", i, m) + continue + } + line, err := strconv.Atoi(msg[:x]) + if err != nil { + t.Errorf("InfoDepth[%d]: bad line number: %q", i, m) + continue + } + wantLine++ + if wantLine != line { + t.Errorf("InfoDepth[%d]: got line %d, want %d", i, line, wantLine) + } + } +} + +func init() { + CopyStandardLogTo("INFO") +} + +// Test that CopyStandardLogTo panics on bad input. +func TestCopyStandardLogToPanic(t *testing.T) { + defer func() { + if s, ok := recover().(string); !ok || !strings.Contains(s, "LOG") { + t.Errorf(`CopyStandardLogTo("LOG") should have panicked: %v`, s) + } + }() + CopyStandardLogTo("LOG") +} + +// Test that using the standard log package logs to INFO. +func TestStandardLog(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + stdLog.Print("test") + if !contains(infoLog, "I", t) { + t.Errorf("Info has wrong character: %q", contents(infoLog)) + } + if !contains(infoLog, "test", t) { + t.Error("Info failed") + } +} + +// Test that the header has the correct format. +func TestHeader(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + defer func(previous func() time.Time) { timeNow = previous }(timeNow) + timeNow = func() time.Time { + return time.Date(2006, 1, 2, 15, 4, 5, .067890e9, time.Local) + } + pid = 1234 + Info("test") + var line int + format := "I0102 15:04:05.067890 1234 glog_test.go:%d] test\n" + n, err := fmt.Sscanf(contents(infoLog), format, &line) + if n != 1 || err != nil { + t.Errorf("log format error: %d elements, error %s:\n%s", n, err, contents(infoLog)) + } + // Scanf treats multiple spaces as equivalent to a single space, + // so check for correct space-padding also. + want := fmt.Sprintf(format, line) + if contents(infoLog) != want { + t.Errorf("log format error: got:\n\t%q\nwant:\t%q", contents(infoLog), want) + } +} + +// Test that an Error log goes to Warning and Info. +// Even in the Info log, the source character will be E, so the data should +// all be identical. +func TestError(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + Error("test") + if !contains(errorLog, "E", t) { + t.Errorf("Error has wrong character: %q", contents(errorLog)) + } + if !contains(errorLog, "test", t) { + t.Error("Error failed") + } + str := contents(errorLog) + if !contains(warningLog, str, t) { + t.Error("Warning failed") + } + if !contains(infoLog, str, t) { + t.Error("Info failed") + } +} + +// Test that a Warning log goes to Info. +// Even in the Info log, the source character will be W, so the data should +// all be identical. +func TestWarning(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + Warning("test") + if !contains(warningLog, "W", t) { + t.Errorf("Warning has wrong character: %q", contents(warningLog)) + } + if !contains(warningLog, "test", t) { + t.Error("Warning failed") + } + str := contents(warningLog) + if !contains(infoLog, str, t) { + t.Error("Info failed") + } +} + +// Test that a V log goes to Info. +func TestV(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + logging.verbosity.Set("2") + defer logging.verbosity.Set("0") + V(2).Info("test") + if !contains(infoLog, "I", t) { + t.Errorf("Info has wrong character: %q", contents(infoLog)) + } + if !contains(infoLog, "test", t) { + t.Error("Info failed") + } +} + +// Test that a vmodule enables a log in this file. +func TestVmoduleOn(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + logging.vmodule.Set("glog_test=2") + defer logging.vmodule.Set("") + if !V(1) { + t.Error("V not enabled for 1") + } + if !V(2) { + t.Error("V not enabled for 2") + } + if V(3) { + t.Error("V enabled for 3") + } + V(2).Info("test") + if !contains(infoLog, "I", t) { + t.Errorf("Info has wrong character: %q", contents(infoLog)) + } + if !contains(infoLog, "test", t) { + t.Error("Info failed") + } +} + +// Test that a vmodule of another file does not enable a log in this file. +func TestVmoduleOff(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + logging.vmodule.Set("notthisfile=2") + defer logging.vmodule.Set("") + for i := 1; i <= 3; i++ { + if V(Level(i)) { + t.Errorf("V enabled for %d", i) + } + } + V(2).Info("test") + if contents(infoLog) != "" { + t.Error("V logged incorrectly") + } +} + +// vGlobs are patterns that match/don't match this file at V=2. +var vGlobs = map[string]bool{ + // Easy to test the numeric match here. + "glog_test=1": false, // If -vmodule sets V to 1, V(2) will fail. + "glog_test=2": true, + "glog_test=3": true, // If -vmodule sets V to 1, V(3) will succeed. + // These all use 2 and check the patterns. All are true. + "*=2": true, + "?l*=2": true, + "????_*=2": true, + "??[mno]?_*t=2": true, + // These all use 2 and check the patterns. All are false. + "*x=2": false, + "m*=2": false, + "??_*=2": false, + "?[abc]?_*t=2": false, +} + +// Test that vmodule globbing works as advertised. +func testVmoduleGlob(pat string, match bool, t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + defer logging.vmodule.Set("") + logging.vmodule.Set(pat) + if V(2) != Verbose(match) { + t.Errorf("incorrect match for %q: got %t expected %t", pat, V(2), match) + } +} + +// Test that a vmodule globbing works as advertised. +func TestVmoduleGlob(t *testing.T) { + for glob, match := range vGlobs { + testVmoduleGlob(glob, match, t) + } +} + +func TestRollover(t *testing.T) { + setFlags() + var err error + defer func(previous func(error)) { logExitFunc = previous }(logExitFunc) + logExitFunc = func(e error) { + err = e + } + defer func(previous uint64) { MaxSize = previous }(MaxSize) + MaxSize = 512 + + Info("x") // Be sure we have a file. + info, ok := logging.file[infoLog].(*syncBuffer) + if !ok { + t.Fatal("info wasn't created") + } + if err != nil { + t.Fatalf("info has initial error: %v", err) + } + fname0 := info.file.Name() + Info(strings.Repeat("x", int(MaxSize))) // force a rollover + if err != nil { + t.Fatalf("info has error after big write: %v", err) + } + + // Make sure the next log file gets a file name with a different + // time stamp. + // + // TODO: determine whether we need to support subsecond log + // rotation. C++ does not appear to handle this case (nor does it + // handle Daylight Savings Time properly). + time.Sleep(1 * time.Second) + + Info("x") // create a new file + if err != nil { + t.Fatalf("error after rotation: %v", err) + } + fname1 := info.file.Name() + if fname0 == fname1 { + t.Errorf("info.f.Name did not change: %v", fname0) + } + if info.nbytes >= MaxSize { + t.Errorf("file size was not reset: %d", info.nbytes) + } +} + +func TestLogBacktraceAt(t *testing.T) { + setFlags() + defer logging.swap(logging.newBuffers()) + // The peculiar style of this code simplifies line counting and maintenance of the + // tracing block below. + var infoLine string + setTraceLocation := func(file string, line int, ok bool, delta int) { + if !ok { + t.Fatal("could not get file:line") + } + _, file = filepath.Split(file) + infoLine = fmt.Sprintf("%s:%d", file, line+delta) + err := logging.traceLocation.Set(infoLine) + if err != nil { + t.Fatal("error setting log_backtrace_at: ", err) + } + } + { + // Start of tracing block. These lines know about each other's relative position. + _, file, line, ok := runtime.Caller(0) + setTraceLocation(file, line, ok, +2) // Two lines between Caller and Info calls. + Info("we want a stack trace here") + } + numAppearances := strings.Count(contents(infoLog), infoLine) + if numAppearances < 2 { + // Need 2 appearances, one in the log header and one in the trace: + // log_test.go:281: I0511 16:36:06.952398 02238 log_test.go:280] we want a stack trace here + // ... + // github.com/glog/glog_test.go:280 (0x41ba91) + // ... + // We could be more precise but that would require knowing the details + // of the traceback format, which may not be dependable. + t.Fatal("got no trace back; log is ", contents(infoLog)) + } +} + +func BenchmarkHeader(b *testing.B) { + for i := 0; i < b.N; i++ { + buf, _, _ := logging.header(infoLog, 0) + logging.putBuffer(buf) + } +} diff --git a/vendor/github.com/minio/minio/Dockerfile b/vendor/github.com/minio/minio/Dockerfile new file mode 100644 index 0000000000..4ce2cf272a --- /dev/null +++ b/vendor/github.com/minio/minio/Dockerfile @@ -0,0 +1,37 @@ +FROM golang:1.12-alpine + +LABEL maintainer="MinIO Inc " + +ENV GOPATH /go +ENV CGO_ENABLED 0 +ENV GO111MODULE on + +RUN \ + apk add --no-cache git && \ + git clone https://github.com/minio/minio && cd minio && \ + go install -v -ldflags "$(go run buildscripts/gen-ldflags.go)" && \ + cd dockerscripts; go build -ldflags "-s -w" -o /usr/bin/healthcheck healthcheck.go + +FROM alpine:3.9 + +ENV MINIO_UPDATE off +ENV MINIO_ACCESS_KEY_FILE=access_key \ + MINIO_SECRET_KEY_FILE=secret_key + +EXPOSE 9000 + +COPY --from=0 /go/bin/minio /usr/bin/minio +COPY --from=0 /usr/bin/healthcheck /usr/bin/healthcheck +COPY dockerscripts/docker-entrypoint.sh /usr/bin/ + +RUN \ + apk add --no-cache ca-certificates 'curl>7.61.0' && \ + echo 'hosts: files mdns4_minimal [NOTFOUND=return] dns mdns4' >> /etc/nsswitch.conf + +ENTRYPOINT ["/usr/bin/docker-entrypoint.sh"] + +VOLUME ["/data"] + +HEALTHCHECK --interval=1m CMD healthcheck + +CMD ["minio"] diff --git a/vendor/github.com/minio/minio/browser/app/js/browser/ChangePasswordModal.js b/vendor/github.com/minio/minio/browser/app/js/browser/ChangePasswordModal.js index 40fe022b2f..ae00e44c52 100644 --- a/vendor/github.com/minio/minio/browser/app/js/browser/ChangePasswordModal.js +++ b/vendor/github.com/minio/minio/browser/app/js/browser/ChangePasswordModal.js @@ -18,157 +18,237 @@ import React from "react" import { connect } from "react-redux" import web from "../web" import * as alertActions from "../alert/actions" +import { getRandomAccessKey, getRandomSecretKey } from "../utils" +import jwtDecode from "jwt-decode" +import classNames from "classnames" -import { - Tooltip, - Modal, - ModalBody, - ModalHeader, - OverlayTrigger -} from "react-bootstrap" +import { Modal, ModalBody, ModalHeader } from "react-bootstrap" import InputGroup from "./InputGroup" +import { ACCESS_KEY_MIN_LENGTH, SECRET_KEY_MIN_LENGTH } from "../constants" export class ChangePasswordModal extends React.Component { constructor(props) { super(props) this.state = { - accessKey: "", - secretKey: "", - keysReadOnly: false + currentAccessKey: "", + currentSecretKey: "", + currentSecretKeyVisible: false, + newAccessKey: "", + newSecretKey: "", + newSecretKeyVisible: false } } - // When its shown, it loads the access key and secret key. + // When its shown, it loads the access key from JWT token componentWillMount() { - const { serverInfo } = this.props - - // Check environment variables first. - if (serverInfo.info.isEnvCreds || serverInfo.info.isWorm) { - this.setState({ - accessKey: "xxxxxxxxx", - secretKey: "xxxxxxxxx", - keysReadOnly: true - }) - } else { - web.GetAuth().then(data => { - this.setState({ - accessKey: data.accessKey, - secretKey: data.secretKey - }) - }) - } - } - - // Handle field changes from inside the modal. - accessKeyChange(e) { + const token = jwtDecode(web.GetToken()) this.setState({ - accessKey: e.target.value - }) - } - - secretKeyChange(e) { - this.setState({ - secretKey: e.target.value - }) - } - - secretKeyVisible(secretKeyVisible) { - this.setState({ - secretKeyVisible + currentAccessKey: token.sub, + newAccessKey: token.sub }) } // Save the auth params and set them. setAuth(e) { const { showAlert } = this.props - const accessKey = this.state.accessKey - const secretKey = this.state.secretKey - web - .SetAuth({ - accessKey, - secretKey - }) - .then(data => { - showAlert({ - type: "success", - message: "Changed credentials" + + if (this.canUpdateCredentials()) { + const currentAccessKey = this.state.currentAccessKey + const currentSecretKey = this.state.currentSecretKey + const newAccessKey = this.state.newAccessKey + const newSecretKey = this.state.newSecretKey + web + .SetAuth({ + currentAccessKey, + currentSecretKey, + newAccessKey, + newSecretKey }) - }) - .catch(err => { - showAlert({ - type: "danger", - message: err.message + .then(data => { + showAlert({ + type: "success", + message: "Credentials updated successfully." + }) }) - }) + .catch(err => { + showAlert({ + type: "danger", + message: err.message + }) + }) + } } generateAuth(e) { - web.GenerateAuth().then(data => { + const { serverInfo } = this.props + // Generate random access key only for root user + if (!serverInfo.userInfo.isIAMUser) { this.setState({ - accessKey: data.accessKey, - secretKey: data.secretKey, - secretKeyVisible: true + newAccessKey: getRandomAccessKey() }) + } + + this.setState({ + newSecretKey: getRandomSecretKey(), + newSecretKeyVisible: true }) } + canChangePassword() { + const { serverInfo } = this.props + // Password change is not allowed in WORM mode + if (serverInfo.info.isWorm) { + return false + } + + // When credentials are set on ENV, password change not allowed for owner + if (serverInfo.info.isEnvCreds && !serverInfo.userInfo.isIAMUser) { + return false + } + return true + } + + canUpdateCredentials() { + return ( + this.state.currentAccessKey.length > 0 && + this.state.currentSecretKey.length > 0 && + this.state.newAccessKey.length >= ACCESS_KEY_MIN_LENGTH && + this.state.newSecretKey.length >= SECRET_KEY_MIN_LENGTH + ) + } + render() { - const { hideChangePassword } = this.props + const { hideChangePassword, serverInfo } = this.props + const allowChangePassword = this.canChangePassword() + + if (!allowChangePassword) { + return ( + + Change Password + + Credentials of this user cannot be updated through MinIO Browser. + +
+ +
+
+ ) + } + return ( Change Password - - + + + { + this.setState({ + currentSecretKeyVisible: !this.state.currentSecretKeyVisible + }) + }} + className={ + "toggle-password fa fa-eye " + + (this.state.currentSecretKeyVisible ? "toggled" : "") + } + /> + { + this.setState({ currentSecretKey: e.target.value }) + }} + id="currentSecretKey" + label="Current Secret Key" + name="currentSecretKey" + type={this.state.currentSecretKeyVisible ? "text" : "password"} + spellCheck="false" + required="required" + autoComplete="false" + align="ig-left" + /> + + +
+ {!serverInfo.userInfo.isIAMUser && ( + { + this.setState({ newAccessKey: e.target.value }) + }} + readonly={serverInfo.userInfo.isIAMUser} + /> )} - className={ - "toggle-password fa fa-eye " + - (this.state.secretKeyVisible ? "toggled" : "") - } - /> - + + { + this.setState({ + newSecretKeyVisible: !this.state.newSecretKeyVisible + }) + }} + className={ + "toggle-password fa fa-eye " + + (this.state.newSecretKeyVisible ? "toggled" : "") + } + /> + { + this.setState({ newSecretKey: e.target.value }) + }} + id="newSecretKey" + label="New Secret Key" + name="newSecretKey" + type={this.state.newSecretKeyVisible ? "text" : "password"} + spellCheck="false" + required="required" + autoComplete="false" + align="ig-left" + onChange={e => { + this.setState({ newSecretKey: e.target.value }) + }} + /> +
- - + + `) @@ -210,12 +211,12 @@ func productionIndexHTML() (*asset, error) { return nil, err } - info := bindataFileInfo{name: "production/index.html", size: 2242, mode: os.FileMode(420), modTime: time.Unix(1558295918, 0)} + info := bindataFileInfo{name: "production/index.html", size: 2242, mode: os.FileMode(420), modTime: time.Unix(1559193981, 0)} a := &asset{bytes: bytes, info: info} return a, nil } -var _productionIndex_bundle20190519t195828zJs = []byte(`!function(A){var t={};function M(e){if(t[e])return t[e].exports;var I=t[e]={i:e,l:!1,exports:{}};return A[e].call(I.exports,I,I.exports,M),I.l=!0,I.exports}M.m=A,M.c=t,M.d=function(A,t,e){M.o(A,t)||Object.defineProperty(A,t,{enumerable:!0,get:e})},M.r=function(A){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})},M.t=function(A,t){if(1&t&&(A=M(A)),8&t)return A;if(4&t&&"object"==typeof A&&A&&A.__esModule)return A;var e=Object.create(null);if(M.r(e),Object.defineProperty(e,"default",{enumerable:!0,value:A}),2&t&&"string"!=typeof A)for(var I in A)M.d(e,I,function(t){return A[t]}.bind(null,I));return e},M.n=function(A){var t=A&&A.__esModule?function(){return A.default}:function(){return A};return M.d(t,"a",t),t},M.o=function(A,t){return Object.prototype.hasOwnProperty.call(A,t)},M.p="",M(M.s=272)}([function(A,t,M){A.exports=M(497)()},function(A,t,M){"use strict";A.exports=M(478)},function(A,t,M){"use strict";t.__esModule=!0;var e,I=M(191),g=(e=I)&&e.__esModule?e:{default:e};t.default=g.default||function(A){for(var t=1;t=0||Object.prototype.hasOwnProperty.call(A,e)&&(M[e]=A[e]);return M}},function(A,t,M){var e=M(15),I=M(54),g=M(31),i=M(32),n=M(55),o=function(A,t,M){var E,T,N,c,a=A&o.F,r=A&o.G,C=A&o.S,D=A&o.P,B=A&o.B,Q=r?e:C?e[t]||(e[t]={}):(e[t]||{}).prototype,s=r?I:I[t]||(I[t]={}),l=s.prototype||(s.prototype={});for(E in r&&(M=t),M)N=((T=!a&&Q&&void 0!==Q[E])?Q:M)[E],c=B&&T?n(N,e):D&&"function"==typeof N?n(Function.call,N):N,Q&&i(Q,E,N,A&o.U),s[E]!=N&&g(s,E,c),D&&l[E]!=N&&(l[E]=N)};e.core=I,o.F=1,o.G=2,o.S=4,o.P=8,o.B=16,o.W=32,o.U=64,o.R=128,A.exports=o},function(A,t,M){A.exports=M(492)()},function(A,t,M){"use strict";A.exports=function(){}},function(A,t,M){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(A){return typeof A}:function(A){return A&&"function"==typeof Symbol&&A.constructor===Symbol&&A!==Symbol.prototype?"symbol":typeof A},I=i(M(1)),g=i(M(77));function i(A){return A&&A.__esModule?A:{default:A}}t.default=(0,g.default)(function(A,t,M,g,i){var n=A[t],o=void 0===n?"undefined":e(n);return I.default.isValidElement(n)?new Error("Invalid "+g+" ` + "`" + `"+i+"` + "`" + ` of type ReactElement supplied to ` + "`" + `"+M+"` + "`" + `, expected an element type (a string or a ReactClass)."):"function"!==o&&"string"!==o?new Error("Invalid "+g+" ` + "`" + `"+i+"` + "`" + ` of value ` + "`" + `"+n+"` + "`" + ` supplied to ` + "`" + `"+M+"` + "`" + `, expected an element type (a string or a ReactClass)."):null}),A.exports=t.default},function(A,t,M){A.exports=M(488)()},function(A,t,M){var e=M(19);A.exports=function(A){if(!e(A))throw TypeError(A+" is not an object!");return A}},function(A,t,M){A.exports=M(690)()},function(A,t){var M=A.exports="undefined"!=typeof window&&window.Math==Math?window:"undefined"!=typeof self&&self.Math==Math?self:Function("return this")();"number"==typeof __g&&(__g=M)},function(A,t,M){"use strict";A.exports=function(A,t,M,e,I,g,i,n){if(!A){var o;if(void 0===t)o=new Error("Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings.");else{var E=[M,e,I,g,i,n],T=0;(o=new Error(t.replace(/%s/g,function(){return E[T++]}))).name="Invariant Violation"}throw o.framesToPop=1,o}}},function(A,t){A.exports=function(A){try{return!!A()}catch(A){return!0}}},function(A,t,M){"use strict";M.r(t);var e=M(1),I=M(0),g=M.n(I),i=g.a.shape({trySubscribe:g.a.func.isRequired,tryUnsubscribe:g.a.func.isRequired,notifyNestedSubs:g.a.func.isRequired,isSubscribed:g.a.func.isRequired}),n=g.a.shape({subscribe:g.a.func.isRequired,dispatch:g.a.func.isRequired,getState:g.a.func.isRequired});function o(){var A,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"store",M=arguments[1]||t+"Subscription",I=function(A){function I(M,e){!function(A,t){if(!(A instanceof t))throw new TypeError("Cannot call a class as a function")}(this,I);var g=function(A,t){if(!A)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?A:t}(this,A.call(this,M,e));return g[t]=M.store,g}return function(A,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);A.prototype=Object.create(t&&t.prototype,{constructor:{value:A,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(A,t):A.__proto__=t)}(I,A),I.prototype.getChildContext=function(){var A;return(A={})[t]=this[t],A[M]=null,A},I.prototype.render=function(){return e.Children.only(this.props.children)},I}(e.Component);return I.propTypes={store:n.isRequired,children:g.a.element.isRequired},I.childContextTypes=((A={})[t]=n.isRequired,A[M]=i,A),I}var E=o(),T=M(132),N=M.n(T),c=M(16),a=M.n(c);var r=null,C={notify:function(){}};var D=function(){function A(t,M,e){!function(A,t){if(!(A instanceof t))throw new TypeError("Cannot call a class as a function")}(this,A),this.store=t,this.parentSub=M,this.onStateChange=e,this.unsubscribe=null,this.listeners=C}return A.prototype.addNestedSub=function(A){return this.trySubscribe(),this.listeners.subscribe(A)},A.prototype.notifyNestedSubs=function(){this.listeners.notify()},A.prototype.isSubscribed=function(){return Boolean(this.unsubscribe)},A.prototype.trySubscribe=function(){var A,t;this.unsubscribe||(this.unsubscribe=this.parentSub?this.parentSub.addNestedSub(this.onStateChange):this.store.subscribe(this.onStateChange),this.listeners=(A=[],t=[],{clear:function(){t=r,A=r},notify:function(){for(var M=A=t,e=0;e1&&void 0!==arguments[1]?arguments[1]:{},g=I.getDisplayName,o=void 0===g?function(A){return"ConnectAdvanced("+A+")"}:g,E=I.methodName,T=void 0===E?"connectAdvanced":E,c=I.renderCountProp,r=void 0===c?void 0:c,C=I.shouldHandleStateChanges,u=void 0===C||C,y=I.storeKey,x=void 0===y?"store":y,w=I.withRef,j=void 0!==w&&w,Y=function(A,t){var M={};for(var e in A)t.indexOf(e)>=0||Object.prototype.hasOwnProperty.call(A,e)&&(M[e]=A[e]);return M}(I,["getDisplayName","methodName","renderCountProp","shouldHandleStateChanges","storeKey","withRef"]),d=x+"Subscription",h=Q++,L=((t={})[x]=n,t[d]=i,t),S=((M={})[d]=i,M);return function(t){a()("function"==typeof t,"You must pass a component to the function returned by connect. Instead received "+JSON.stringify(t));var M=t.displayName||t.name||"Component",I=o(M),g=B({},Y,{getDisplayName:o,methodName:T,renderCountProp:r,shouldHandleStateChanges:u,storeKey:x,withRef:j,displayName:I,wrappedComponentName:M,WrappedComponent:t}),i=function(M){function i(A,t){!function(A,t){if(!(A instanceof t))throw new TypeError("Cannot call a class as a function")}(this,i);var e=function(A,t){if(!A)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?A:t}(this,M.call(this,A,t));return e.version=h,e.state={},e.renderCount=0,e.store=A[x]||t[x],e.propsMode=Boolean(A[x]),e.setWrappedInstance=e.setWrappedInstance.bind(e),a()(e.store,'Could not find "'+x+'" in either the context or props of "'+I+'". Either wrap the root component in a , or explicitly pass "'+x+'" as a prop to "'+I+'".'),e.initSelector(),e.initSubscription(),e}return function(A,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);A.prototype=Object.create(t&&t.prototype,{constructor:{value:A,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(A,t):A.__proto__=t)}(i,M),i.prototype.getChildContext=function(){var A,t=this.propsMode?null:this.subscription;return(A={})[d]=t||this.context[d],A},i.prototype.componentDidMount=function(){u&&(this.subscription.trySubscribe(),this.selector.run(this.props),this.selector.shouldComponentUpdate&&this.forceUpdate())},i.prototype.componentWillReceiveProps=function(A){this.selector.run(A)},i.prototype.shouldComponentUpdate=function(){return this.selector.shouldComponentUpdate},i.prototype.componentWillUnmount=function(){this.subscription&&this.subscription.tryUnsubscribe(),this.subscription=null,this.notifyNestedSubs=l,this.store=null,this.selector.run=l,this.selector.shouldComponentUpdate=!1},i.prototype.getWrappedInstance=function(){return a()(j,"To access the wrapped instance, you need to specify { withRef: true } in the options argument of the "+T+"() call."),this.wrappedInstance},i.prototype.setWrappedInstance=function(A){this.wrappedInstance=A},i.prototype.initSelector=function(){var t=A(this.store.dispatch,g);this.selector=function(A,t){var M={run:function(e){try{var I=A(t.getState(),e);(I!==M.props||M.error)&&(M.shouldComponentUpdate=!0,M.props=I,M.error=null)}catch(A){M.shouldComponentUpdate=!0,M.error=A}}};return M}(t,this.store),this.selector.run(this.props)},i.prototype.initSubscription=function(){if(u){var A=(this.propsMode?this.props:this.context)[d];this.subscription=new D(this.store,A,this.onStateChange.bind(this)),this.notifyNestedSubs=this.subscription.notifyNestedSubs.bind(this.subscription)}},i.prototype.onStateChange=function(){this.selector.run(this.props),this.selector.shouldComponentUpdate?(this.componentDidUpdate=this.notifyNestedSubsOnComponentDidUpdate,this.setState(s)):this.notifyNestedSubs()},i.prototype.notifyNestedSubsOnComponentDidUpdate=function(){this.componentDidUpdate=void 0,this.notifyNestedSubs()},i.prototype.isSubscribed=function(){return Boolean(this.subscription)&&this.subscription.isSubscribed()},i.prototype.addExtraProps=function(A){if(!(j||r||this.propsMode&&this.subscription))return A;var t=B({},A);return j&&(t.ref=this.setWrappedInstance),r&&(t[r]=this.renderCount++),this.propsMode&&this.subscription&&(t[d]=this.subscription),t},i.prototype.render=function(){var A=this.selector;if(A.shouldComponentUpdate=!1,A.error)throw A.error;return Object(e.createElement)(t,this.addExtraProps(A.props))},i}(e.Component);return i.WrappedComponent=t,i.displayName=I,i.childContextTypes=S,i.contextTypes=L,i.propTypes=L,N()(i,t)}}var y=Object.prototype.hasOwnProperty;function x(A,t){return A===t?0!==A||0!==t||1/A==1/t:A!=A&&t!=t}function w(A,t){if(x(A,t))return!0;if("object"!=typeof A||null===A||"object"!=typeof t||null===t)return!1;var M=Object.keys(A),e=Object.keys(t);if(M.length!==e.length)return!1;for(var I=0;I=0||Object.prototype.hasOwnProperty.call(A,e)&&(M[e]=A[e]);return M}(t,["initMapStateToProps","initMapDispatchToProps","initMergeProps"]),i=M(A,g),n=e(A,g),o=I(A,g);return(g.pure?F:f)(i,n,o,A,g)}var O=Object.assign||function(A){for(var t=1;t=0;e--){var I=t[e](A);if(I)return I}return function(t,e){throw new Error("Invalid value of type "+typeof A+" for "+M+" argument when connecting component "+e.wrappedComponentName+".")}}function k(A,t){return A===t}var G=function(){var A=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=A.connectHOC,M=void 0===t?u:t,e=A.mapStateToPropsFactories,I=void 0===e?S:e,g=A.mapDispatchToPropsFactories,i=void 0===g?L:g,n=A.mergePropsFactories,o=void 0===n?p:n,E=A.selectorFactory,T=void 0===E?m:E;return function(A,t,e){var g=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},n=g.pure,E=void 0===n||n,N=g.areStatesEqual,c=void 0===N?k:N,a=g.areOwnPropsEqual,r=void 0===a?w:a,C=g.areStatePropsEqual,D=void 0===C?w:C,B=g.areMergedPropsEqual,Q=void 0===B?w:B,s=function(A,t){var M={};for(var e in A)t.indexOf(e)>=0||Object.prototype.hasOwnProperty.call(A,e)&&(M[e]=A[e]);return M}(g,["pure","areStatesEqual","areOwnPropsEqual","areStatePropsEqual","areMergedPropsEqual"]),l=R(A,I,"mapStateToProps"),u=R(t,i,"mapDispatchToProps"),y=R(e,o,"mergeProps");return M(T,O({methodName:"connect",getDisplayName:function(A){return"Connect("+A+")"},shouldHandleStateChanges:Boolean(A),initMapStateToProps:l,initMapDispatchToProps:u,initMergeProps:y,pure:E,areStatesEqual:c,areOwnPropsEqual:r,areStatePropsEqual:D,areMergedPropsEqual:Q},s))}}();M.d(t,"Provider",function(){return E}),M.d(t,"createProvider",function(){return o}),M.d(t,"connectAdvanced",function(){return u}),M.d(t,"connect",function(){return G})},function(A,t){A.exports=function(A){return"object"==typeof A?null!==A:"function"==typeof A}},function(A,t,M){"use strict";!function A(){if("undefined"!=typeof __REACT_DEVTOOLS_GLOBAL_HOOK__&&"function"==typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE)try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(A)}catch(A){console.error(A)}}(),A.exports=M(479)},function(A,t,M){var e=M(111)("wks"),I=M(66),g=M(15).Symbol,i="function"==typeof g;(A.exports=function(A){return e[A]||(e[A]=i&&g[A]||(i?g:I)("Symbol."+A))}).store=e},function(A,t,M){A.exports=!M(17)(function(){return 7!=Object.defineProperty({},"a",{get:function(){return 7}}).a})},function(A,t,M){var e=M(13),I=M(200),g=M(43),i=Object.defineProperty;t.f=M(22)?Object.defineProperty:function(A,t,M){if(e(A),t=g(t,!0),e(M),I)try{return i(A,t,M)}catch(A){}if("get"in M||"set"in M)throw TypeError("Accessors not supported!");return"value"in M&&(A[t]=M.value),A}},function(A,t,M){var e=M(61),I=Math.min;A.exports=function(A){return A>0?I(e(A),9007199254740991):0}},function(A,t,M){var e=M(40);A.exports=function(A){return Object(e(A))}},function(A,t){var M=(t=A.exports=function(A){if(A&&"object"==typeof A){var t=A.which||A.keyCode||A.charCode;t&&(A=t)}if("number"==typeof A)return g[A];var I,i=String(A);return(I=M[i.toLowerCase()])?I:(I=e[i.toLowerCase()])||(1===i.length?i.charCodeAt(0):void 0)}).code=t.codes={backspace:8,tab:9,enter:13,shift:16,ctrl:17,alt:18,"pause/break":19,"caps lock":20,esc:27,space:32,"page up":33,"page down":34,end:35,home:36,left:37,up:38,right:39,down:40,insert:45,delete:46,command:91,"left command":91,"right command":93,"numpad *":106,"numpad +":107,"numpad -":109,"numpad .":110,"numpad /":111,"num lock":144,"scroll lock":145,"my computer":182,"my calculator":183,";":186,"=":187,",":188,"-":189,".":190,"/":191,"` + "`" + `":192,"[":219,"\\":220,"]":221,"'":222},e=t.aliases={windows:91,"⇧":16,"⌥":18,"⌃":17,"⌘":91,ctl:17,control:17,option:18,pause:19,break:19,caps:20,return:13,escape:27,spc:32,pgup:33,pgdn:34,ins:45,del:46,cmd:91}; +!function(){"use strict";var M={}.hasOwnProperty;function I(){for(var A=[],t=0;t=0||Object.prototype.hasOwnProperty.call(A,e)&&(M[e]=A[e]);return M}},function(A,t,M){var e=M(15),I=M(54),g=M(31),i=M(32),n=M(55),o=function(A,t,M){var E,T,N,c,a=A&o.F,r=A&o.G,C=A&o.S,D=A&o.P,B=A&o.B,Q=r?e:C?e[t]||(e[t]={}):(e[t]||{}).prototype,s=r?I:I[t]||(I[t]={}),l=s.prototype||(s.prototype={});for(E in r&&(M=t),M)N=((T=!a&&Q&&void 0!==Q[E])?Q:M)[E],c=B&&T?n(N,e):D&&"function"==typeof N?n(Function.call,N):N,Q&&i(Q,E,N,A&o.U),s[E]!=N&&g(s,E,c),D&&l[E]!=N&&(l[E]=N)};e.core=I,o.F=1,o.G=2,o.S=4,o.P=8,o.B=16,o.W=32,o.U=64,o.R=128,A.exports=o},function(A,t,M){A.exports=M(492)()},function(A,t,M){"use strict";A.exports=function(){}},function(A,t,M){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(A){return typeof A}:function(A){return A&&"function"==typeof Symbol&&A.constructor===Symbol&&A!==Symbol.prototype?"symbol":typeof A},I=i(M(1)),g=i(M(77));function i(A){return A&&A.__esModule?A:{default:A}}t.default=(0,g.default)(function(A,t,M,g,i){var n=A[t],o=void 0===n?"undefined":e(n);return I.default.isValidElement(n)?new Error("Invalid "+g+" ` + "`" + `"+i+"` + "`" + ` of type ReactElement supplied to ` + "`" + `"+M+"` + "`" + `, expected an element type (a string or a ReactClass)."):"function"!==o&&"string"!==o?new Error("Invalid "+g+" ` + "`" + `"+i+"` + "`" + ` of value ` + "`" + `"+n+"` + "`" + ` supplied to ` + "`" + `"+M+"` + "`" + `, expected an element type (a string or a ReactClass)."):null}),A.exports=t.default},function(A,t,M){A.exports=M(488)()},function(A,t,M){var e=M(19);A.exports=function(A){if(!e(A))throw TypeError(A+" is not an object!");return A}},function(A,t,M){A.exports=M(693)()},function(A,t){var M=A.exports="undefined"!=typeof window&&window.Math==Math?window:"undefined"!=typeof self&&self.Math==Math?self:Function("return this")();"number"==typeof __g&&(__g=M)},function(A,t,M){"use strict";A.exports=function(A,t,M,e,I,g,i,n){if(!A){var o;if(void 0===t)o=new Error("Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings.");else{var E=[M,e,I,g,i,n],T=0;(o=new Error(t.replace(/%s/g,function(){return E[T++]}))).name="Invariant Violation"}throw o.framesToPop=1,o}}},function(A,t){A.exports=function(A){try{return!!A()}catch(A){return!0}}},function(A,t,M){"use strict";M.r(t);var e=M(1),I=M(0),g=M.n(I),i=g.a.shape({trySubscribe:g.a.func.isRequired,tryUnsubscribe:g.a.func.isRequired,notifyNestedSubs:g.a.func.isRequired,isSubscribed:g.a.func.isRequired}),n=g.a.shape({subscribe:g.a.func.isRequired,dispatch:g.a.func.isRequired,getState:g.a.func.isRequired});function o(){var A,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"store",M=arguments[1]||t+"Subscription",I=function(A){function I(M,e){!function(A,t){if(!(A instanceof t))throw new TypeError("Cannot call a class as a function")}(this,I);var g=function(A,t){if(!A)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?A:t}(this,A.call(this,M,e));return g[t]=M.store,g}return function(A,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);A.prototype=Object.create(t&&t.prototype,{constructor:{value:A,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(A,t):A.__proto__=t)}(I,A),I.prototype.getChildContext=function(){var A;return(A={})[t]=this[t],A[M]=null,A},I.prototype.render=function(){return e.Children.only(this.props.children)},I}(e.Component);return I.propTypes={store:n.isRequired,children:g.a.element.isRequired},I.childContextTypes=((A={})[t]=n.isRequired,A[M]=i,A),I}var E=o(),T=M(133),N=M.n(T),c=M(16),a=M.n(c);var r=null,C={notify:function(){}};var D=function(){function A(t,M,e){!function(A,t){if(!(A instanceof t))throw new TypeError("Cannot call a class as a function")}(this,A),this.store=t,this.parentSub=M,this.onStateChange=e,this.unsubscribe=null,this.listeners=C}return A.prototype.addNestedSub=function(A){return this.trySubscribe(),this.listeners.subscribe(A)},A.prototype.notifyNestedSubs=function(){this.listeners.notify()},A.prototype.isSubscribed=function(){return Boolean(this.unsubscribe)},A.prototype.trySubscribe=function(){var A,t;this.unsubscribe||(this.unsubscribe=this.parentSub?this.parentSub.addNestedSub(this.onStateChange):this.store.subscribe(this.onStateChange),this.listeners=(A=[],t=[],{clear:function(){t=r,A=r},notify:function(){for(var M=A=t,e=0;e1&&void 0!==arguments[1]?arguments[1]:{},g=I.getDisplayName,o=void 0===g?function(A){return"ConnectAdvanced("+A+")"}:g,E=I.methodName,T=void 0===E?"connectAdvanced":E,c=I.renderCountProp,r=void 0===c?void 0:c,C=I.shouldHandleStateChanges,u=void 0===C||C,y=I.storeKey,x=void 0===y?"store":y,w=I.withRef,j=void 0!==w&&w,d=function(A,t){var M={};for(var e in A)t.indexOf(e)>=0||Object.prototype.hasOwnProperty.call(A,e)&&(M[e]=A[e]);return M}(I,["getDisplayName","methodName","renderCountProp","shouldHandleStateChanges","storeKey","withRef"]),Y=x+"Subscription",h=Q++,L=((t={})[x]=n,t[Y]=i,t),S=((M={})[Y]=i,M);return function(t){a()("function"==typeof t,"You must pass a component to the function returned by connect. Instead received "+JSON.stringify(t));var M=t.displayName||t.name||"Component",I=o(M),g=B({},d,{getDisplayName:o,methodName:T,renderCountProp:r,shouldHandleStateChanges:u,storeKey:x,withRef:j,displayName:I,wrappedComponentName:M,WrappedComponent:t}),i=function(M){function i(A,t){!function(A,t){if(!(A instanceof t))throw new TypeError("Cannot call a class as a function")}(this,i);var e=function(A,t){if(!A)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?A:t}(this,M.call(this,A,t));return e.version=h,e.state={},e.renderCount=0,e.store=A[x]||t[x],e.propsMode=Boolean(A[x]),e.setWrappedInstance=e.setWrappedInstance.bind(e),a()(e.store,'Could not find "'+x+'" in either the context or props of "'+I+'". Either wrap the root component in a , or explicitly pass "'+x+'" as a prop to "'+I+'".'),e.initSelector(),e.initSubscription(),e}return function(A,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);A.prototype=Object.create(t&&t.prototype,{constructor:{value:A,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(A,t):A.__proto__=t)}(i,M),i.prototype.getChildContext=function(){var A,t=this.propsMode?null:this.subscription;return(A={})[Y]=t||this.context[Y],A},i.prototype.componentDidMount=function(){u&&(this.subscription.trySubscribe(),this.selector.run(this.props),this.selector.shouldComponentUpdate&&this.forceUpdate())},i.prototype.componentWillReceiveProps=function(A){this.selector.run(A)},i.prototype.shouldComponentUpdate=function(){return this.selector.shouldComponentUpdate},i.prototype.componentWillUnmount=function(){this.subscription&&this.subscription.tryUnsubscribe(),this.subscription=null,this.notifyNestedSubs=l,this.store=null,this.selector.run=l,this.selector.shouldComponentUpdate=!1},i.prototype.getWrappedInstance=function(){return a()(j,"To access the wrapped instance, you need to specify { withRef: true } in the options argument of the "+T+"() call."),this.wrappedInstance},i.prototype.setWrappedInstance=function(A){this.wrappedInstance=A},i.prototype.initSelector=function(){var t=A(this.store.dispatch,g);this.selector=function(A,t){var M={run:function(e){try{var I=A(t.getState(),e);(I!==M.props||M.error)&&(M.shouldComponentUpdate=!0,M.props=I,M.error=null)}catch(A){M.shouldComponentUpdate=!0,M.error=A}}};return M}(t,this.store),this.selector.run(this.props)},i.prototype.initSubscription=function(){if(u){var A=(this.propsMode?this.props:this.context)[Y];this.subscription=new D(this.store,A,this.onStateChange.bind(this)),this.notifyNestedSubs=this.subscription.notifyNestedSubs.bind(this.subscription)}},i.prototype.onStateChange=function(){this.selector.run(this.props),this.selector.shouldComponentUpdate?(this.componentDidUpdate=this.notifyNestedSubsOnComponentDidUpdate,this.setState(s)):this.notifyNestedSubs()},i.prototype.notifyNestedSubsOnComponentDidUpdate=function(){this.componentDidUpdate=void 0,this.notifyNestedSubs()},i.prototype.isSubscribed=function(){return Boolean(this.subscription)&&this.subscription.isSubscribed()},i.prototype.addExtraProps=function(A){if(!(j||r||this.propsMode&&this.subscription))return A;var t=B({},A);return j&&(t.ref=this.setWrappedInstance),r&&(t[r]=this.renderCount++),this.propsMode&&this.subscription&&(t[Y]=this.subscription),t},i.prototype.render=function(){var A=this.selector;if(A.shouldComponentUpdate=!1,A.error)throw A.error;return Object(e.createElement)(t,this.addExtraProps(A.props))},i}(e.Component);return i.WrappedComponent=t,i.displayName=I,i.childContextTypes=S,i.contextTypes=L,i.propTypes=L,N()(i,t)}}var y=Object.prototype.hasOwnProperty;function x(A,t){return A===t?0!==A||0!==t||1/A==1/t:A!=A&&t!=t}function w(A,t){if(x(A,t))return!0;if("object"!=typeof A||null===A||"object"!=typeof t||null===t)return!1;var M=Object.keys(A),e=Object.keys(t);if(M.length!==e.length)return!1;for(var I=0;I=0||Object.prototype.hasOwnProperty.call(A,e)&&(M[e]=A[e]);return M}(t,["initMapStateToProps","initMapDispatchToProps","initMergeProps"]),i=M(A,g),n=e(A,g),o=I(A,g);return(g.pure?F:f)(i,n,o,A,g)}var O=Object.assign||function(A){for(var t=1;t=0;e--){var I=t[e](A);if(I)return I}return function(t,e){throw new Error("Invalid value of type "+typeof A+" for "+M+" argument when connecting component "+e.wrappedComponentName+".")}}function k(A,t){return A===t}var G=function(){var A=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=A.connectHOC,M=void 0===t?u:t,e=A.mapStateToPropsFactories,I=void 0===e?S:e,g=A.mapDispatchToPropsFactories,i=void 0===g?L:g,n=A.mergePropsFactories,o=void 0===n?p:n,E=A.selectorFactory,T=void 0===E?m:E;return function(A,t,e){var g=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},n=g.pure,E=void 0===n||n,N=g.areStatesEqual,c=void 0===N?k:N,a=g.areOwnPropsEqual,r=void 0===a?w:a,C=g.areStatePropsEqual,D=void 0===C?w:C,B=g.areMergedPropsEqual,Q=void 0===B?w:B,s=function(A,t){var M={};for(var e in A)t.indexOf(e)>=0||Object.prototype.hasOwnProperty.call(A,e)&&(M[e]=A[e]);return M}(g,["pure","areStatesEqual","areOwnPropsEqual","areStatePropsEqual","areMergedPropsEqual"]),l=R(A,I,"mapStateToProps"),u=R(t,i,"mapDispatchToProps"),y=R(e,o,"mergeProps");return M(T,O({methodName:"connect",getDisplayName:function(A){return"Connect("+A+")"},shouldHandleStateChanges:Boolean(A),initMapStateToProps:l,initMapDispatchToProps:u,initMergeProps:y,pure:E,areStatesEqual:c,areOwnPropsEqual:r,areStatePropsEqual:D,areMergedPropsEqual:Q},s))}}();M.d(t,"Provider",function(){return E}),M.d(t,"createProvider",function(){return o}),M.d(t,"connectAdvanced",function(){return u}),M.d(t,"connect",function(){return G})},function(A,t){A.exports=function(A){return"object"==typeof A?null!==A:"function"==typeof A}},function(A,t,M){"use strict";!function A(){if("undefined"!=typeof __REACT_DEVTOOLS_GLOBAL_HOOK__&&"function"==typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE)try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(A)}catch(A){console.error(A)}}(),A.exports=M(479)},function(A,t,M){var e=M(111)("wks"),I=M(66),g=M(15).Symbol,i="function"==typeof g;(A.exports=function(A){return e[A]||(e[A]=i&&g[A]||(i?g:I)("Symbol."+A))}).store=e},function(A,t,M){A.exports=!M(17)(function(){return 7!=Object.defineProperty({},"a",{get:function(){return 7}}).a})},function(A,t,M){var e=M(13),I=M(200),g=M(44),i=Object.defineProperty;t.f=M(22)?Object.defineProperty:function(A,t,M){if(e(A),t=g(t,!0),e(M),I)try{return i(A,t,M)}catch(A){}if("get"in M||"set"in M)throw TypeError("Accessors not supported!");return"value"in M&&(A[t]=M.value),A}},function(A,t,M){var e=M(61),I=Math.min;A.exports=function(A){return A>0?I(e(A),9007199254740991):0}},function(A,t,M){var e=M(40);A.exports=function(A){return Object(e(A))}},function(A,t){var M=(t=A.exports=function(A){if(A&&"object"==typeof A){var t=A.which||A.keyCode||A.charCode;t&&(A=t)}if("number"==typeof A)return g[A];var I,i=String(A);return(I=M[i.toLowerCase()])?I:(I=e[i.toLowerCase()])||(1===i.length?i.charCodeAt(0):void 0)}).code=t.codes={backspace:8,tab:9,enter:13,shift:16,ctrl:17,alt:18,"pause/break":19,"caps lock":20,esc:27,space:32,"page up":33,"page down":34,end:35,home:36,left:37,up:38,right:39,down:40,insert:45,delete:46,command:91,"left command":91,"right command":93,"numpad *":106,"numpad +":107,"numpad -":109,"numpad .":110,"numpad /":111,"num lock":144,"scroll lock":145,"my computer":182,"my calculator":183,";":186,"=":187,",":188,"-":189,".":190,"/":191,"` + "`" + `":192,"[":219,"\\":220,"]":221,"'":222},e=t.aliases={windows:91,"⇧":16,"⌥":18,"⌃":17,"⌘":91,ctl:17,control:17,option:18,pause:19,break:19,caps:20,return:13,escape:27,spc:32,pgup:33,pgdn:34,ins:45,del:46,cmd:91}; /*! * Programatically add the following */ -for(I=97;I<123;I++)M[String.fromCharCode(I)]=I-32;for(var I=48;I<58;I++)M[I-48]=I;for(I=1;I<13;I++)M["f"+I]=I+111;for(I=0;I<10;I++)M["numpad "+I]=I+96;var g=t.names=t.title={};for(I in M)g[M[I]]=I;for(var i in e)M[i]=e[i]},function(A,t,M){"use strict";t.__esModule=!0;var e,I=M(568),g=(e=I)&&e.__esModule?e:{default:e};t.default=(0,g.default)({shouldComponentUpdate:function(){return!this._notifying}},function(A,t,M,e,I){M&&(A._notifying=!0,M.call.apply(M,[A,e].concat(I)),A._notifying=!1),A._values[t]=e,A.unmounted||A.forceUpdate()}),A.exports=t.default},function(A,t){var M={}.hasOwnProperty;A.exports=function(A,t){return M.call(A,t)}},function(A,t,M){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var e=function(){function A(A,t){for(var M=0;M"+I+""};A.exports=function(A,t){var M={};M[A]=t(n),e(e.P+e.F*I(function(){var t=""[A]('"');return t!==t.toLowerCase()||t.split('"').length>3}),"String",M)}},function(A,t,M){var e=M(99),I=M(59),g=M(34),i=M(43),n=M(28),o=M(200),E=Object.getOwnPropertyDescriptor;t.f=M(22)?E:function(A,t){if(A=g(A),t=i(t,!0),o)try{return E(A,t)}catch(A){}if(n(A,t))return I(!e.f.call(A,t),A[t])}},function(A,t,M){var e=M(28),I=M(25),g=M(136)("IE_PROTO"),i=Object.prototype;A.exports=Object.getPrototypeOf||function(A){return A=I(A),e(A,g)?A[g]:"function"==typeof A.constructor&&A instanceof A.constructor?A.constructor.prototype:A instanceof Object?i:null}},function(A,t,M){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.downloadCheckedObjects=t.resetCheckedList=t.uncheckObject=t.checkObject=t.downloadObject=t.hideShareObject=t.showShareObject=t.shareObject=t.deleteCheckedObjects=t.removeObject=t.deleteObject=t.setPrefixWritable=t.setCurrentPrefix=t.selectPrefix=t.setSortOrder=t.setSortBy=t.sortObjects=t.fetchObjects=t.appendList=t.resetList=t.setList=t.CHECKED_LIST_RESET=t.CHECKED_LIST_REMOVE=t.CHECKED_LIST_ADD=t.SET_SHARE_OBJECT=t.SET_PREFIX_WRITABLE=t.SET_CURRENT_PREFIX=t.SET_SORT_ORDER=t.SET_SORT_BY=t.REMOVE=t.APPEND_LIST=t.RESET_LIST=t.SET_LIST=void 0;var e=Object.assign||function(A){for(var t=1;t1?"-":"";e.href=g,e.download=t.bucketName+i+t.prefix.slice(0,-1)+".zip",e.click(),window.URL.revokeObjectURL(g),e.remove()}},I.send(JSON.stringify(t))})},function(A,t){var M={}.toString;A.exports=function(A){return M.call(A).slice(8,-1)}},function(A,t){A.exports=function(A){if(null==A)throw TypeError("Can't call method on "+A);return A}},function(A,t,M){var e=M(17);A.exports=function(A,t){return!!A&&e(function(){t?A.call(null,function(){},1):A.call(null)})}},function(A,t,M){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.hideBucketPolicy=t.showBucketPolicy=t.setPolicies=t.fetchPolicies=t.hideMakeBucketModal=t.showMakeBucketModal=t.removeBucket=t.addBucket=t.deleteBucket=t.makeBucket=t.setCurrentBucket=t.selectBucket=t.setFilter=t.setList=t.fetchBuckets=t.SET_POLICIES=t.SHOW_BUCKET_POLICY=t.SHOW_MAKE_BUCKET_MODAL=t.SET_CURRENT_BUCKET=t.SET_FILTER=t.REMOVE=t.ADD=t.SET_LIST=void 0;var e=E(M(29)),I=E(M(101)),g=o(M(47)),i=o(M(38)),n=M(165);function o(A){if(A&&A.__esModule)return A;var t={};if(null!=A)for(var M in A)Object.prototype.hasOwnProperty.call(A,M)&&(t[M]=A[M]);return t.default=A,t}function E(A){return A&&A.__esModule?A:{default:A}}var T=t.SET_LIST="buckets/SET_LIST",N=t.ADD="buckets/ADD",c=t.REMOVE="buckets/REMOVE",a=t.SET_FILTER="buckets/SET_FILTER",r=t.SET_CURRENT_BUCKET="buckets/SET_CURRENT_BUCKET",C=t.SHOW_MAKE_BUCKET_MODAL="buckets/SHOW_MAKE_BUCKET_MODAL",D=t.SHOW_BUCKET_POLICY="buckets/SHOW_BUCKET_POLICY",B=t.SET_POLICIES="buckets/SET_POLICIES",Q=t.fetchBuckets=function(){return function(A){return e.default.ListBuckets().then(function(t){var M=t.buckets?t.buckets.map(function(A){return A.name}):[];if(A(s(M)),M.length>0){var e=(0,n.pathSlice)(I.default.location.pathname),g=e.bucket,i=e.prefix;g&&M.indexOf(g)>-1?A(l(g,i)):A(l(M[0]))}else A(l("")),I.default.replace("/")})}},s=t.setList=function(A){return{type:T,buckets:A}},l=(t.setFilter=function(A){return{type:a,filter:A}},t.selectBucket=function(A,t){return function(M){M(u(A)),M(i.selectPrefix(t||""))}}),u=t.setCurrentBucket=function(A){return{type:r,bucket:A}},y=(t.makeBucket=function(A){return function(t){return e.default.MakeBucket({bucketName:A}).then(function(){t(y(A)),t(l(A))}).catch(function(A){return t(g.set({type:"danger",message:A.message}))})}},t.deleteBucket=function(A){return function(t){return e.default.DeleteBucket({bucketName:A}).then(function(){t(g.set({type:"info",message:"Bucket '"+A+"' has been deleted."})),t(x(A)),t(Q())}).catch(function(A){t(g.set({type:"danger",message:A.message}))})}},t.addBucket=function(A){return{type:N,bucket:A}}),x=t.removeBucket=function(A){return{type:c,bucket:A}},w=(t.showMakeBucketModal=function(){return{type:C,show:!0}},t.hideMakeBucketModal=function(){return{type:C,show:!1}},t.fetchPolicies=function(A){return function(t){return e.default.ListAllBucketPolicies({bucketName:A}).then(function(A){var M=A.policies;t(w(M||[]))}).catch(function(A){t(g.set({type:"danger",message:A.message}))})}},t.setPolicies=function(A){return{type:B,policies:A}});t.showBucketPolicy=function(){return{type:D,show:!0}},t.hideBucketPolicy=function(){return{type:D,show:!1}}},function(A,t,M){var e=M(19);A.exports=function(A,t){if(!e(A))return A;var M,I;if(t&&"function"==typeof(M=A.toString)&&!e(I=M.call(A)))return I;if("function"==typeof(M=A.valueOf)&&!e(I=M.call(A)))return I;if(!t&&"function"==typeof(M=A.toString)&&!e(I=M.call(A)))return I;throw TypeError("Can't convert object to primitive value")}},function(A,t,M){var e=M(8),I=M(54),g=M(17);A.exports=function(A,t){var M=(I.Object||{})[A]||Object[A],i={};i[A]=t(M),e(e.S+e.F*g(function(){M(1)}),"Object",i)}},function(A,t,M){var e=M(55),I=M(98),g=M(25),i=M(24),n=M(365);A.exports=function(A,t){var M=1==A,o=2==A,E=3==A,T=4==A,N=6==A,c=5==A||N,a=t||n;return function(t,n,r){for(var C,D,B=g(t),Q=I(B),s=e(n,r,3),l=i(Q.length),u=0,y=M?a(t,l):o?a(t,0):void 0;l>u;u++)if((c||u in Q)&&(D=s(C=Q[u],u,B),A))if(M)y[u]=D;else if(D)switch(A){case 3:return!0;case 5:return C;case 6:return u;case 2:y.push(C)}else if(T)return!1;return N?-1:E||T?T:y}}},function(A,t,M){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var e=window.location.pathname;t.minioBrowserPrefix=e.slice(0,e.indexOf("/",1)),t.READ_ONLY="readonly",t.WRITE_ONLY="writeonly",t.READ_WRITE="readwrite",t.NONE="none",t.SHARE_OBJECT_EXPIRY_DAYS=5,t.SHARE_OBJECT_EXPIRY_HOURS=0,t.SHARE_OBJECT_EXPIRY_MINUTES=0},function(A,t,M){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var e=t.SET="alert/SET",I=t.CLEAR="alert/CLEAR",g=t.alertId=0;t.set=function(A){var M=(t.alertId=g+=1,g-1);return function(t,g){("danger"!==A.type||A.autoClear)&&setTimeout(function(){t({type:I,alert:{id:M}})},5e3),t({type:e,alert:Object.assign({},A,{id:M})})}},t.clear=function(){return{type:I}}},function(A,t){var M=A.exports={version:"2.4.0"};"number"==typeof __e&&(__e=M)},function(A,t,M){var e=M(172)("wks"),I=M(124),g=M(63).Symbol,i="function"==typeof g;(A.exports=function(A){return e[A]||(e[A]=i&&g[A]||(i?g:I)("Symbol."+A))}).store=e},function(A,t,M){"use strict";M.r(t);var e={};M.r(e),M.d(e,"prefix",function(){return R}),M.d(e,"bsClass",function(){return k}),M.d(e,"bsStyles",function(){return G}),M.d(e,"bsSizes",function(){return J}),M.d(e,"getClassSet",function(){return b}),M.d(e,"splitBsProps",function(){return V}),M.d(e,"splitBsPropsAndOmit",function(){return X}),M.d(e,"addStyle",function(){return W}),M.d(e,"_curry",function(){return P});var I={};M.r(I),M.d(I,"bootstrapUtils",function(){return e}),M.d(I,"createChainedFunction",function(){return QA}),M.d(I,"ValidComponentChildren",function(){return K});var g=M(2),i=M.n(g),n=M(4),o=M.n(n),E=M(3),T=M.n(E),N=M(5),c=M.n(N),a=M(1),r=M.n(a),C=M(7),D=M.n(C),B=M(6),Q=M.n(B),s=M(0),l=M.n(s),u=M(27),y=M.n(u),x=M(94),w=M.n(x),j=M(16),Y=M.n(j),d="large",h="small",L="xsmall",S={large:"lg",medium:"md",small:"sm",xsmall:"xs",lg:"lg",md:"md",sm:"sm",xs:"xs"},z=["lg","md","sm","xs"],U={SUCCESS:"success",WARNING:"warning",DANGER:"danger",INFO:"info"},p="default",f="primary",F="link",m="inverse";function O(A){return function(){for(var t=arguments.length,M=Array(t),e=0;e1?t-1:0),e=1;e1?t-1:0),e=1;e=A.children.length&&this.setState({activeIndex:0,previousActiveIndex:null,direction:null})},t.prototype.componentWillUnmount=function(){clearTimeout(this.timeout),this.isUnmounted=!0},t.prototype.getActiveIndex=function(){var A=this.props.activeIndex;return null!=A?A:this.state.activeIndex},t.prototype.getDirection=function(A,t){return A===t?null:A>t?"prev":"next"},t.prototype.handleItemAnimateOutEnd=function(){var A=this;this.setState({previousActiveIndex:null,direction:null},function(){A.waitForNext(),A.props.onSlideEnd&&A.props.onSlideEnd()})},t.prototype.handleMouseOut=function(){this.isPaused&&this.play()},t.prototype.handleMouseOver=function(){this.props.pauseOnHover&&this.pause()},t.prototype.handleNext=function(A){var t=this.getActiveIndex()+1;if(t>K.count(this.props.children)-1){if(!this.props.wrap)return;t=0}this.select(t,A,"next")},t.prototype.handlePrev=function(A){var t=this.getActiveIndex()-1;if(t<0){if(!this.props.wrap)return;t=K.count(this.props.children)-1}this.select(t,A,"prev")},t.prototype.pause=function(){this.isPaused=!0,clearTimeout(this.timeout)},t.prototype.play=function(){this.isPaused=!1,this.waitForNext()},t.prototype.select=function(A,t,M){if(clearTimeout(this.timeout),!this.isUnmounted){var e=this.props.slide?this.getActiveIndex():null;M=M||this.getDirection(e,A);var I=this.props.onSelect;if(I&&(I.length>1?(t?(t.persist(),t.direction=M):t={direction:M},I(A,t)):I(A)),null==this.props.activeIndex&&A!==e){if(null!=this.state.previousActiveIndex)return;this.setState({activeIndex:A,previousActiveIndex:e,direction:M})}}},t.prototype.waitForNext=function(){var A=this.props,t=A.slide,M=A.interval,e=A.activeIndex;!this.isPaused&&t&&M&&null==e&&(this.timeout=setTimeout(this.handleNext,M))},t.prototype.renderControls=function(A){var t=A.wrap,M=A.children,e=A.activeIndex,I=A.prevIcon,g=A.nextIcon,i=A.bsProps,n=A.prevLabel,o=A.nextLabel,E=R(i,"control"),T=K.count(M);return[(t||0!==e)&&r.a.createElement(yA,{key:"prev",className:Q()(E,"left"),onClick:this.handlePrev},I,n&&r.a.createElement("span",{className:"sr-only"},n)),(t||e!==T-1)&&r.a.createElement(yA,{key:"next",className:Q()(E,"right"),onClick:this.handleNext},g,o&&r.a.createElement("span",{className:"sr-only"},o))]},t.prototype.renderIndicators=function(A,t,M){var e=this,I=[];return K.forEach(A,function(A,M){I.push(r.a.createElement("li",{key:M,className:M===t?"active":null,onClick:function(A){return e.select(M,A)}})," ")}),r.a.createElement("ol",{className:R(M,"indicators")},I)},t.prototype.render=function(){var A=this,t=this.props,M=t.slide,e=t.indicators,I=t.controls,g=t.wrap,n=t.prevIcon,o=t.prevLabel,E=t.nextIcon,T=t.nextLabel,N=t.className,c=t.children,C=D()(t,["slide","indicators","controls","wrap","prevIcon","prevLabel","nextIcon","nextLabel","className","children"]),B=this.state,s=B.previousActiveIndex,l=B.direction,u=X(C,["interval","pauseOnHover","onSelect","onSlideEnd","activeIndex","defaultActiveIndex","direction"]),y=u[0],x=u[1],w=this.getActiveIndex(),j=i()({},b(y),{slide:M});return r.a.createElement("div",i()({},x,{className:Q()(N,j),onMouseOver:this.handleMouseOver,onMouseOut:this.handleMouseOut}),e&&this.renderIndicators(c,w,y),r.a.createElement("div",{className:R(y,"inner")},K.map(c,function(t,e){var I=e===w,g=M&&e===s;return Object(a.cloneElement)(t,{active:I,index:e,animateOut:g,animateIn:I&&null!=s&&M,direction:l,onAnimateOutEnd:g?A.handleItemAnimateOutEnd:null})})),I&&this.renderControls({wrap:g,children:c,activeIndex:w,prevIcon:n,prevLabel:o,nextIcon:E,nextLabel:T,bsProps:y}))},t}(r.a.Component);$A.propTypes=qA,$A.defaultProps=_A,$A.Caption=GA,$A.Item=WA;var At=k("carousel",$A),tt=(M(10),{inline:l.a.bool,disabled:l.a.bool,title:l.a.string,validationState:l.a.oneOf(["success","warning","error",null]),inputRef:l.a.func}),Mt=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.inline,M=A.disabled,e=A.validationState,I=A.inputRef,g=A.className,n=A.style,o=A.title,E=A.children,T=V(D()(A,["inline","disabled","validationState","inputRef","className","style","title","children"])),N=T[0],c=T[1],a=r.a.createElement("input",i()({},c,{ref:I,type:"checkbox",disabled:M}));if(t){var C,B=((C={})[R(N,"inline")]=!0,C.disabled=M,C);return r.a.createElement("label",{className:Q()(g,B),style:n,title:o},a,E)}var s=i()({},b(N),{disabled:M});return e&&(s["has-"+e]=!0),r.a.createElement("div",{className:Q()(g,s),style:n},r.a.createElement("label",{title:o},a,E))},t}(r.a.Component);Mt.propTypes=tt,Mt.defaultProps={inline:!1,disabled:!1,title:""};var et=k("checkbox",Mt);function It(A){return""+A.charAt(0).toUpperCase()+A.slice(1)}var gt={componentClass:BA.a,visibleXsBlock:l.a.bool,visibleSmBlock:l.a.bool,visibleMdBlock:l.a.bool,visibleLgBlock:l.a.bool},it=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.className,e=V(D()(A,["componentClass","className"])),I=e[0],g=e[1],n=b(I);return z.forEach(function(A){var t="visible"+It(A)+"Block";g[t]&&(n["visible-"+A+"-block"]=!0),delete g[t]}),r.a.createElement(t,i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);it.propTypes=gt,it.defaultProps={componentClass:"div"};var nt=k("clearfix",it),ot={htmlFor:l.a.string,srOnly:l.a.bool},Et={$bs_formGroup:l.a.object},Tt=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.context.$bs_formGroup,t=A&&A.controlId,M=this.props,e=M.htmlFor,I=void 0===e?t:e,g=M.srOnly,n=M.className,o=V(D()(M,["htmlFor","srOnly","className"])),E=o[0],T=o[1],N=i()({},b(E),{"sr-only":g});return r.a.createElement("label",i()({},T,{htmlFor:I,className:Q()(n,N)}))},t}(r.a.Component);Tt.propTypes=ot,Tt.defaultProps={srOnly:!1},Tt.contextTypes=Et;var Nt=k("control-label",Tt),ct={componentClass:BA.a,xs:l.a.number,sm:l.a.number,md:l.a.number,lg:l.a.number,xsHidden:l.a.bool,smHidden:l.a.bool,mdHidden:l.a.bool,lgHidden:l.a.bool,xsOffset:l.a.number,smOffset:l.a.number,mdOffset:l.a.number,lgOffset:l.a.number,xsPush:l.a.number,smPush:l.a.number,mdPush:l.a.number,lgPush:l.a.number,xsPull:l.a.number,smPull:l.a.number,mdPull:l.a.number,lgPull:l.a.number},at=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.className,e=V(D()(A,["componentClass","className"])),I=e[0],g=e[1],n=[];return z.forEach(function(A){function t(t,M){var e=""+A+t,i=g[e];null!=i&&n.push(R(I,""+A+M+"-"+i)),delete g[e]}t("",""),t("Offset","-offset"),t("Push","-push"),t("Pull","-pull");var M=A+"Hidden";g[M]&&n.push("hidden-"+A),delete g[M]}),r.a.createElement(t,i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);at.propTypes=ct,at.defaultProps={componentClass:"div"};var rt,Ct=k("col",at),Dt=M(133),Bt=M.n(Dt),Qt=M(53),st=M.n(Qt),lt={height:["marginTop","marginBottom"],width:["marginLeft","marginRight"]};var ut=((rt={})[Qt.EXITED]="collapse",rt[Qt.EXITING]="collapsing",rt[Qt.ENTERING]="collapsing",rt[Qt.ENTERED]="collapse in",rt),yt={in:l.a.bool,mountOnEnter:l.a.bool,unmountOnExit:l.a.bool,appear:l.a.bool,timeout:l.a.number,onEnter:l.a.func,onEntering:l.a.func,onEntered:l.a.func,onExit:l.a.func,onExiting:l.a.func,onExited:l.a.func,dimension:l.a.oneOfType([l.a.oneOf(["height","width"]),l.a.func]),getDimensionValue:l.a.func,role:l.a.string},xt={in:!1,timeout:300,mountOnEnter:!1,unmountOnExit:!1,appear:!1,dimension:"height",getDimensionValue:function(A,t){var M=t["offset"+It(A)],e=lt[A];return M+parseInt(Bt()(t,e[0]),10)+parseInt(Bt()(t,e[1]),10)}},wt=function(A){function t(){var M,e,I;o()(this,t);for(var g=arguments.length,i=Array(g),n=0;n1&&(I=t,1))}),I?new Error("(children) "+e+" - Duplicate children detected of bsRole: "+I+". Only one child each allowed with the following bsRoles: "+t.join(", ")):null})}(Vt)),disabled:l.a.bool,pullRight:l.a.bool,open:l.a.bool,defaultOpen:l.a.bool,onToggle:l.a.func,onSelect:l.a.func,role:l.a.string,rootCloseEvent:l.a.oneOf(["click","mousedown"]),onMouseEnter:l.a.func,onMouseLeave:l.a.func},Wt={componentClass:FA},Pt=function(A){function t(M,e){o()(this,t);var I=T()(this,A.call(this,M,e));return I.handleClick=I.handleClick.bind(I),I.handleKeyDown=I.handleKeyDown.bind(I),I.handleClose=I.handleClose.bind(I),I._focusInDropdown=!1,I.lastOpenEventType=null,I}return c()(t,A),t.prototype.componentDidMount=function(){this.focusNextOnOpen()},t.prototype.componentWillUpdate=function(A){!A.open&&this.props.open&&(this._focusInDropdown=Lt()(bA.a.findDOMNode(this.menu),dt()(document)))},t.prototype.componentDidUpdate=function(A){var t=this.props.open,M=A.open;t&&!M&&this.focusNextOnOpen(),!t&&M&&this._focusInDropdown&&(this._focusInDropdown=!1,this.focus())},t.prototype.focus=function(){var A=bA.a.findDOMNode(this.toggle);A&&A.focus&&A.focus()},t.prototype.focusNextOnOpen=function(){var A=this.menu;A.focusNext&&("keydown"!==this.lastOpenEventType&&"menuitem"!==this.props.role||A.focusNext())},t.prototype.handleClick=function(A){this.props.disabled||this.toggleOpen(A,{source:"click"})},t.prototype.handleClose=function(A,t){this.props.open&&this.toggleOpen(A,t)},t.prototype.handleKeyDown=function(A){if(!this.props.disabled)switch(A.keyCode){case zt.a.codes.down:this.props.open?this.menu.focusNext&&this.menu.focusNext():this.toggleOpen(A,{source:"keydown"}),A.preventDefault();break;case zt.a.codes.esc:case zt.a.codes.tab:this.handleClose(A,{source:"keydown"})}},t.prototype.toggleOpen=function(A,t){var M=!this.props.open;M&&(this.lastOpenEventType=t.source),this.props.onToggle&&this.props.onToggle(M,A,t)},t.prototype.renderMenu=function(A,t){var M=this,e=t.id,I=t.onSelect,g=t.rootCloseEvent,n=D()(t,["id","onSelect","rootCloseEvent"]),o=function(A){M.menu=A};return"string"==typeof A.ref||(o=QA(A.ref,o)),Object(a.cloneElement)(A,i()({},n,{ref:o,labelledBy:e,bsClass:R(n,"menu"),onClose:QA(A.props.onClose,this.handleClose),onSelect:QA(A.props.onSelect,I,function(A,t){return M.handleClose(t,{source:"select"})}),rootCloseEvent:g}))},t.prototype.renderToggle=function(A,t){var M=this,e=function(A){M.toggle=A};return"string"==typeof A.ref||(e=QA(A.ref,e)),Object(a.cloneElement)(A,i()({},t,{ref:e,bsClass:R(t,"toggle"),onClick:QA(A.props.onClick,this.handleClick),onKeyDown:QA(A.props.onKeyDown,this.handleKeyDown)}))},t.prototype.render=function(){var A,t=this,M=this.props,e=M.componentClass,I=M.id,g=M.dropup,n=M.disabled,o=M.pullRight,E=M.open,T=M.onSelect,N=M.role,c=M.bsClass,a=M.className,C=M.rootCloseEvent,B=M.children,s=D()(M,["componentClass","id","dropup","disabled","pullRight","open","onSelect","role","bsClass","className","rootCloseEvent","children"]);delete s.onToggle;var l=((A={})[c]=!0,A.open=E,A.disabled=n,A);return g&&(l[c]=!1,l.dropup=!0),r.a.createElement(e,i()({},s,{className:Q()(a,l)}),K.map(B,function(A){switch(A.props.bsRole){case vt:return t.renderToggle(A,{id:I,disabled:n,open:E,role:N,bsClass:c});case Vt:return t.renderMenu(A,{id:I,open:E,pullRight:o,bsClass:c,onSelect:T,rootCloseEvent:C});default:return A}}))},t}(r.a.Component);Pt.propTypes=Xt,Pt.defaultProps=Wt,k("dropdown",Pt);var Kt=y()(Pt,{open:"onToggle"});Kt.Toggle=Ht,Kt.Menu=Gt;var Zt=Kt;function qt(A,t){var M=t.propTypes,e={},I={};return w()(A).forEach(function(A){var t=A[0],g=A[1];M[t]?e[t]=g:I[t]=g}),[e,I]}var _t=i()({},Zt.propTypes,{bsStyle:l.a.string,bsSize:l.a.string,title:l.a.node.isRequired,noCaret:l.a.bool,children:l.a.node}),$t=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.bsSize,M=A.bsStyle,e=A.title,I=A.children,g=qt(D()(A,["bsSize","bsStyle","title","children"]),Zt.ControlledComponent),n=g[0],o=g[1];return r.a.createElement(Zt,i()({},n,{bsSize:t,bsStyle:M}),r.a.createElement(Zt.Toggle,i()({},o,{bsSize:t,bsStyle:M}),e),r.a.createElement(Zt.Menu,null,I))},t}(r.a.Component);$t.propTypes=_t;var AM,tM=$t,MM={in:l.a.bool,mountOnEnter:l.a.bool,unmountOnExit:l.a.bool,appear:l.a.bool,timeout:l.a.number,onEnter:l.a.func,onEntering:l.a.func,onEntered:l.a.func,onExit:l.a.func,onExiting:l.a.func,onExited:l.a.func},eM=((AM={})[Qt.ENTERING]="in",AM[Qt.ENTERED]="in",AM),IM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=A.children,e=D()(A,["className","children"]);return r.a.createElement(st.a,e,function(A,e){return r.a.cloneElement(M,i()({},e,{className:Q()("fade",t,M.props.className,eM[A])}))})},t}(r.a.Component);IM.propTypes=MM,IM.defaultProps={in:!1,timeout:300,mountOnEnter:!1,unmountOnExit:!1,appear:!1};var gM=IM,iM={horizontal:l.a.bool,inline:l.a.bool,componentClass:BA.a},nM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.horizontal,M=A.inline,e=A.componentClass,I=A.className,g=V(D()(A,["horizontal","inline","componentClass","className"])),n=g[0],o=g[1],E=[];return t&&E.push(R(n,"horizontal")),M&&E.push(R(n,"inline")),r.a.createElement(e,i()({},o,{className:Q()(I,E)}))},t}(r.a.Component);nM.propTypes=iM,nM.defaultProps={horizontal:!1,inline:!1,componentClass:"form"};var oM=k("form",nM),EM={$bs_formGroup:l.a.object},TM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.getGlyph=function(A){switch(A){case"success":return"ok";case"warning":return"warning-sign";case"error":return"remove";default:return null}},t.prototype.renderDefaultFeedback=function(A,t,M,e){var I=this.getGlyph(A&&A.validationState);return I?r.a.createElement(ZA,i()({},e,{glyph:I,className:Q()(t,M)})):null},t.prototype.render=function(){var A=this.props,t=A.className,M=A.children,e=V(D()(A,["className","children"])),I=e[0],g=e[1],n=b(I);if(!M)return this.renderDefaultFeedback(this.context.$bs_formGroup,t,n,g);var o=r.a.Children.only(M);return r.a.cloneElement(o,i()({},g,{className:Q()(o.props.className,t,n)}))},t}(r.a.Component);TM.defaultProps={bsRole:"feedback"},TM.contextTypes=EM;var NM=k("form-control-feedback",TM),cM={componentClass:BA.a},aM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.className,e=V(D()(A,["componentClass","className"])),I=e[0],g=e[1],n=b(I);return r.a.createElement(t,i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);aM.propTypes=cM,aM.defaultProps={componentClass:"p"};var rM=k("form-control-static",aM),CM={componentClass:BA.a,type:l.a.string,id:l.a.string,inputRef:l.a.func},DM={$bs_formGroup:l.a.object},BM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.context.$bs_formGroup,t=A&&A.controlId,M=this.props,e=M.componentClass,I=M.type,g=M.id,n=void 0===g?t:g,o=M.inputRef,E=M.className,T=M.bsSize,N=V(D()(M,["componentClass","type","id","inputRef","className","bsSize"])),c=N[0],a=N[1],C=void 0;("file"!==I&&(C=b(c)),T)&&(C[R({bsClass:"input"},S[T]||T)]=!0);return r.a.createElement(e,i()({},a,{type:I,id:n,ref:o,className:Q()(E,C)}))},t}(r.a.Component);BM.propTypes=CM,BM.defaultProps={componentClass:"input"},BM.contextTypes=DM,BM.Feedback=NM,BM.Static=rM;var QM=k("form-control",J([h,d],BM)),sM={controlId:l.a.string,validationState:l.a.oneOf(["success","warning","error",null])},lM={$bs_formGroup:l.a.object.isRequired},uM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.getChildContext=function(){var A=this.props;return{$bs_formGroup:{controlId:A.controlId,validationState:A.validationState}}},t.prototype.hasFeedback=function(A){var t=this;return K.some(A,function(A){return"feedback"===A.props.bsRole||A.props.children&&t.hasFeedback(A.props.children)})},t.prototype.render=function(){var A=this.props,t=A.validationState,M=A.className,e=A.children,I=X(D()(A,["validationState","className","children"]),["controlId"]),g=I[0],n=I[1],o=i()({},b(g),{"has-feedback":this.hasFeedback(e)});return t&&(o["has-"+t]=!0),r.a.createElement("div",i()({},n,{className:Q()(M,o)}),e)},t}(r.a.Component);uM.propTypes=sM,uM.childContextTypes=lM;var yM=k("form-group",J([d,h],uM)),xM={fluid:l.a.bool,componentClass:BA.a},wM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.fluid,M=A.componentClass,e=A.className,I=V(D()(A,["fluid","componentClass","className"])),g=I[0],n=I[1],o=R(g,t&&"fluid");return r.a.createElement(M,i()({},n,{className:Q()(e,o)}))},t}(r.a.Component);wM.propTypes=xM,wM.defaultProps={componentClass:"div",fluid:!1};var jM=k("container",wM),YM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=V(D()(A,["className"])),e=M[0],I=M[1],g=b(e);return r.a.createElement("span",i()({},I,{className:Q()(t,g)}))},t}(r.a.Component),dM=k("help-block",YM),hM={responsive:l.a.bool,rounded:l.a.bool,circle:l.a.bool,thumbnail:l.a.bool},LM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A,t=this.props,M=t.responsive,e=t.rounded,I=t.circle,g=t.thumbnail,n=t.className,o=V(D()(t,["responsive","rounded","circle","thumbnail","className"])),E=o[0],T=o[1],N=((A={})[R(E,"responsive")]=M,A[R(E,"rounded")]=e,A[R(E,"circle")]=I,A[R(E,"thumbnail")]=g,A);return r.a.createElement("img",i()({},T,{className:Q()(n,N)}))},t}(r.a.Component);LM.propTypes=hM,LM.defaultProps={responsive:!1,rounded:!1,circle:!1,thumbnail:!1};var SM=k("img",LM),zM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=V(D()(A,["className"])),e=M[0],I=M[1],g=b(e);return r.a.createElement("span",i()({},I,{className:Q()(t,g)}))},t}(r.a.Component),UM=k("input-group-addon",zM),pM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=V(D()(A,["className"])),e=M[0],I=M[1],g=b(e);return r.a.createElement("span",i()({},I,{className:Q()(t,g)}))},t}(r.a.Component),fM=k("input-group-btn",pM),FM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=V(D()(A,["className"])),e=M[0],I=M[1],g=b(e);return r.a.createElement("span",i()({},I,{className:Q()(t,g)}))},t}(r.a.Component);FM.Addon=UM,FM.Button=fM;var mM=k("input-group",J([d,h],FM)),OM={componentClass:BA.a},RM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.className,e=V(D()(A,["componentClass","className"])),I=e[0],g=e[1],n=b(I);return r.a.createElement(t,i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);RM.propTypes=OM,RM.defaultProps={componentClass:"div"};var kM=k("jumbotron",RM),GM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.hasContent=function(A){var t=!1;return r.a.Children.forEach(A,function(A){t||(A||0===A)&&(t=!0)}),t},t.prototype.render=function(){var A=this.props,t=A.className,M=A.children,e=V(D()(A,["className","children"])),I=e[0],g=e[1],n=i()({},b(I),{hidden:!this.hasContent(M)});return r.a.createElement("span",i()({},g,{className:Q()(t,n)}),M)},t}(r.a.Component),JM=k("label",G([].concat(iA()(U),[p,f]),p,GM)),bM={active:l.a.any,disabled:l.a.any,header:l.a.node,listItem:l.a.bool,onClick:l.a.func,href:l.a.string,type:l.a.string},HM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.renderHeader=function(A,t){return r.a.isValidElement(A)?Object(a.cloneElement)(A,{className:Q()(A.props.className,t)}):r.a.createElement("h4",{className:t},A)},t.prototype.render=function(){var A=this.props,t=A.active,M=A.disabled,e=A.className,I=A.header,g=A.listItem,n=A.children,o=V(D()(A,["active","disabled","className","header","listItem","children"])),E=o[0],T=o[1],N=i()({},b(E),{active:t,disabled:M}),c=void 0;return T.href?c="a":T.onClick?(c="button",T.type=T.type||"button"):c=g?"li":"span",T.className=Q()(e,N),I?r.a.createElement(c,T,this.renderHeader(I,R(E,"heading")),r.a.createElement("p",{className:R(E,"text")},n)):r.a.createElement(c,T,n)},t}(r.a.Component);HM.propTypes=bM,HM.defaultProps={listItem:!1};var vM=k("list-group-item",G(iA()(U),HM)),VM={componentClass:BA.a};var XM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.children,M=A.componentClass,e=void 0===M?function(A){return A?K.some(A,function(A){return A.type!==vM||A.props.href||A.props.onClick})?"div":"ul":"div"}(t):M,I=A.className,g=V(D()(A,["children","componentClass","className"])),n=g[0],o=g[1],E=b(n),T="ul"===e&&K.every(t,function(A){return A.type===vM});return r.a.createElement(e,i()({},o,{className:Q()(I,E)}),T?K.map(t,function(A){return Object(a.cloneElement)(A,{listItem:!0})}):t)},t}(r.a.Component);XM.propTypes=VM;var WM=k("list-group",XM),PM={align:l.a.oneOf(["top","middle","bottom"]),componentClass:BA.a},KM=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.align,e=A.className,I=V(D()(A,["componentClass","align","className"])),g=I[0],n=I[1],o=b(g);return M&&(o[R(ce.defaultProps,M)]=!0),r.a.createElement(t,i()({},n,{className:Q()(e,o)}))},t}(r.a.Component);KM.propTypes=PM,KM.defaultProps={componentClass:"div"};var ZM=k("media-body",KM),qM={componentClass:BA.a},_M=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.className,e=V(D()(A,["componentClass","className"])),I=e[0],g=e[1],n=b(I);return r.a.createElement(t,i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);_M.propTypes=qM,_M.defaultProps={componentClass:"h4"};var $M=k("media-heading",_M),Ae={align:l.a.oneOf(["top","middle","bottom"])},te=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.align,M=A.className,e=V(D()(A,["align","className"])),I=e[0],g=e[1],n=b(I);return t&&(n[R(ce.defaultProps,t)]=!0),r.a.createElement("div",i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);te.propTypes=Ae;var Me=k("media-left",te),ee=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=V(D()(A,["className"])),e=M[0],I=M[1],g=b(e);return r.a.createElement("ul",i()({},I,{className:Q()(t,g)}))},t}(r.a.Component),Ie=k("media-list",ee),ge=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=V(D()(A,["className"])),e=M[0],I=M[1],g=b(e);return r.a.createElement("li",i()({},I,{className:Q()(t,g)}))},t}(r.a.Component),ie=k("media",ge),ne={align:l.a.oneOf(["top","middle","bottom"])},oe=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.align,M=A.className,e=V(D()(A,["align","className"])),I=e[0],g=e[1],n=b(I);return t&&(n[R(ce.defaultProps,t)]=!0),r.a.createElement("div",i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);oe.propTypes=ne;var Ee=k("media-right",oe),Te={componentClass:BA.a},Ne=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.className,e=V(D()(A,["componentClass","className"])),I=e[0],g=e[1],n=b(I);return r.a.createElement(t,i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);Ne.propTypes=Te,Ne.defaultProps={componentClass:"div"},Ne.Heading=$M,Ne.Body=ZM,Ne.Left=Me,Ne.Right=Ee,Ne.List=Ie,Ne.ListItem=ie;var ce=k("media",Ne),ae={active:l.a.bool,disabled:l.a.bool,divider:UA()(l.a.bool,function(A){var t=A.divider,M=A.children;return t&&M?new Error("Children will not be rendered for dividers"):null}),eventKey:l.a.any,header:l.a.bool,href:l.a.string,onClick:l.a.func,onSelect:l.a.func},re=function(A){function t(M,e){o()(this,t);var I=T()(this,A.call(this,M,e));return I.handleClick=I.handleClick.bind(I),I}return c()(t,A),t.prototype.handleClick=function(A){var t=this.props,M=t.href,e=t.disabled,I=t.onSelect,g=t.eventKey;M&&!e||A.preventDefault(),e||I&&I(g,A)},t.prototype.render=function(){var A=this.props,t=A.active,M=A.disabled,e=A.divider,I=A.header,g=A.onClick,n=A.className,o=A.style,E=X(D()(A,["active","disabled","divider","header","onClick","className","style"]),["eventKey","onSelect"]),T=E[0],N=E[1];return e?(N.children=void 0,r.a.createElement("li",i()({},N,{role:"separator",className:Q()(n,"divider"),style:o}))):I?r.a.createElement("li",i()({},N,{role:"heading",className:Q()(n,R(T,"header")),style:o})):r.a.createElement("li",{role:"presentation",className:Q()(n,{active:t,disabled:M}),style:o},r.a.createElement(yA,i()({},N,{role:"menuitem",tabIndex:"-1",onClick:QA(g,this.handleClick)})))},t}(r.a.Component);re.propTypes=ae,re.defaultProps={divider:!1,disabled:!1,header:!1};var Ce=k("dropdown",re),De=M(197),Be=M.n(De),Qe=M(193),se=M.n(Qe),le=M(65),ue=M.n(le),ye=M(198),xe=M.n(ye),we=M(97),je=M.n(we),Ye=M(195),de=M.n(Ye),he={componentClass:BA.a},Le=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.className,e=V(D()(A,["componentClass","className"])),I=e[0],g=e[1],n=b(I);return r.a.createElement(t,i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);Le.propTypes=he,Le.defaultProps={componentClass:"div"};var Se=k("modal-body",Le),ze={dialogClassName:l.a.string},Ue=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A,t=this.props,M=t.dialogClassName,e=t.className,I=t.style,g=t.children,n=V(D()(t,["dialogClassName","className","style","children"])),o=n[0],E=n[1],T=R(o),N=i()({display:"block"},I),c=i()({},b(o),((A={})[T]=!1,A[R(o,"dialog")]=!0,A));return r.a.createElement("div",i()({},E,{tabIndex:"-1",role:"dialog",style:N,className:Q()(e,T)}),r.a.createElement("div",{className:Q()(M,c)},r.a.createElement("div",{className:R(o,"content"),role:"document"},g)))},t}(r.a.Component);Ue.propTypes=ze;var pe=k("modal",J([d,h],Ue)),fe={componentClass:BA.a},Fe=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.className,e=V(D()(A,["componentClass","className"])),I=e[0],g=e[1],n=b(I);return r.a.createElement(t,i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);Fe.propTypes=fe,Fe.defaultProps={componentClass:"div"};var me=k("modal-footer",Fe),Oe={closeLabel:l.a.string,closeButton:l.a.bool,onHide:l.a.func},Re={$bs_modal:l.a.shape({onHide:l.a.func})},ke=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.closeLabel,M=A.closeButton,e=A.onHide,I=A.className,g=A.children,n=D()(A,["closeLabel","closeButton","onHide","className","children"]),o=this.context.$bs_modal,E=V(n),T=E[0],N=E[1],c=b(T);return r.a.createElement("div",i()({},N,{className:Q()(I,c)}),M&&r.a.createElement(EA,{label:t,onClick:QA(o&&o.onHide,e)}),g)},t}(r.a.Component);ke.propTypes=Oe,ke.defaultProps={closeLabel:"Close",closeButton:!1},ke.contextTypes=Re;var Ge=k("modal-header",ke),Je={componentClass:BA.a},be=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.componentClass,M=A.className,e=V(D()(A,["componentClass","className"])),I=e[0],g=e[1],n=b(I);return r.a.createElement(t,i()({},g,{className:Q()(M,n)}))},t}(r.a.Component);be.propTypes=Je,be.defaultProps={componentClass:"h4"};var He=k("modal-title",be),ve=i()({},je.a.propTypes,pe.propTypes,{backdrop:l.a.oneOf(["static",!0,!1]),backdropClassName:l.a.string,keyboard:l.a.bool,animation:l.a.bool,dialogComponentClass:BA.a,autoFocus:l.a.bool,enforceFocus:l.a.bool,restoreFocus:l.a.bool,show:l.a.bool,onHide:l.a.func,onEnter:l.a.func,onEntering:l.a.func,onEntered:l.a.func,onExit:l.a.func,onExiting:l.a.func,onExited:l.a.func,container:je.a.propTypes.container}),Ve=i()({},je.a.defaultProps,{animation:!0,dialogComponentClass:pe}),Xe={$bs_modal:l.a.shape({onHide:l.a.func})};function We(A){return r.a.createElement(gM,i()({},A,{timeout:Ke.TRANSITION_DURATION}))}function Pe(A){return r.a.createElement(gM,i()({},A,{timeout:Ke.BACKDROP_TRANSITION_DURATION}))}var Ke=function(A){function t(M,e){o()(this,t);var I=T()(this,A.call(this,M,e));return I.handleEntering=I.handleEntering.bind(I),I.handleExited=I.handleExited.bind(I),I.handleWindowResize=I.handleWindowResize.bind(I),I.handleDialogClick=I.handleDialogClick.bind(I),I.setModalRef=I.setModalRef.bind(I),I.state={style:{}},I}return c()(t,A),t.prototype.getChildContext=function(){return{$bs_modal:{onHide:this.props.onHide}}},t.prototype.componentWillUnmount=function(){this.handleExited()},t.prototype.setModalRef=function(A){this._modal=A},t.prototype.handleDialogClick=function(A){A.target===A.currentTarget&&this.props.onHide()},t.prototype.handleEntering=function(){Be.a.on(window,"resize",this.handleWindowResize),this.updateStyle()},t.prototype.handleExited=function(){Be.a.off(window,"resize",this.handleWindowResize)},t.prototype.handleWindowResize=function(){this.updateStyle()},t.prototype.updateStyle=function(){if(ue.a){var A=this._modal.getDialogElement(),t=A.scrollHeight,M=se()(A),e=de()(bA.a.findDOMNode(this.props.container||M.body)),I=t>M.documentElement.clientHeight;this.setState({style:{paddingRight:e&&!I?xe()():void 0,paddingLeft:!e&&I?xe()():void 0}})}},t.prototype.render=function(){var A=this.props,t=A.backdrop,M=A.backdropClassName,e=A.animation,I=A.show,g=A.dialogComponentClass,n=A.className,o=A.style,E=A.children,T=A.onEntering,N=A.onExited,c=D()(A,["backdrop","backdropClassName","animation","show","dialogComponentClass","className","style","children","onEntering","onExited"]),a=qt(c,je.a),C=a[0],B=a[1],s=I&&!e&&"in";return r.a.createElement(je.a,i()({},C,{ref:this.setModalRef,show:I,containerClassName:R(c,"open"),transition:e?We:void 0,backdrop:t,backdropTransition:e?Pe:void 0,backdropClassName:Q()(R(c,"backdrop"),M,s),onEntering:QA(T,this.handleEntering),onExited:QA(N,this.handleExited)}),r.a.createElement(g,i()({},B,{style:i()({},this.state.style,o),className:Q()(n,s),onClick:!0===t?this.handleDialogClick:null}),E))},t}(r.a.Component);Ke.propTypes=ve,Ke.defaultProps=Ve,Ke.childContextTypes=Xe,Ke.Body=Se,Ke.Header=Ge,Ke.Title=He,Ke.Footer=me,Ke.Dialog=pe,Ke.TRANSITION_DURATION=300,Ke.BACKDROP_TRANSITION_DURATION=150;var Ze=k("modal",J([d,h],Ke)),qe={activeKey:l.a.any,activeHref:l.a.string,stacked:l.a.bool,justified:UA()(l.a.bool,function(A){var t=A.justified,M=A.navbar;return t&&M?Error("justified navbar ` + "`" + `Nav` + "`" + `s are not supported"):null}),onSelect:l.a.func,role:l.a.string,navbar:l.a.bool,pullRight:l.a.bool,pullLeft:l.a.bool},_e={$bs_navbar:l.a.shape({bsClass:l.a.string,onSelect:l.a.func}),$bs_tabContainer:l.a.shape({activeKey:l.a.any,onSelect:l.a.func.isRequired,getTabId:l.a.func.isRequired,getPaneId:l.a.func.isRequired})},$e=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.componentDidUpdate=function(){var A=this;if(this._needsRefocus){this._needsRefocus=!1;var t=this.props.children,M=this.getActiveProps(),e=M.activeKey,I=M.activeHref,g=K.find(t,function(t){return A.isActive(t,e,I)}),i=K.toArray(t).indexOf(g),n=bA.a.findDOMNode(this).children,o=n&&n[i];o&&o.firstChild&&o.firstChild.focus()}},t.prototype.getActiveProps=function(){var A=this.context.$bs_tabContainer;return A||this.props},t.prototype.getNextActiveChild=function(A){var t=this,M=this.props.children,e=M.filter(function(A){return null!=A.props.eventKey&&!A.props.disabled}),I=this.getActiveProps(),g=I.activeKey,i=I.activeHref,n=K.find(M,function(A){return t.isActive(A,g,i)}),o=e.indexOf(n);if(-1===o)return e[0];var E=o+A,T=e.length;return E>=T?E=0:E<0&&(E=T-1),e[E]},t.prototype.getTabProps=function(A,t,M,e,I){var g=this;if(!t&&"tablist"!==M)return null;var i=A.props,n=i.id,o=i["aria-controls"],E=i.eventKey,T=i.role,N=i.onKeyDown,c=i.tabIndex;return t&&(n=t.getTabId(E),o=t.getPaneId(E)),"tablist"===M&&(T=T||"tab",N=QA(function(A){return g.handleTabKeyDown(I,A)},N),c=e?c:-1),{id:n,role:T,onKeyDown:N,"aria-controls":o,tabIndex:c}},t.prototype.handleTabKeyDown=function(A,t){var M=void 0;switch(t.keyCode){case zt.a.codes.left:case zt.a.codes.up:M=this.getNextActiveChild(-1);break;case zt.a.codes.right:case zt.a.codes.down:M=this.getNextActiveChild(1);break;default:return}t.preventDefault(),A&&M&&null!=M.props.eventKey&&A(M.props.eventKey),this._needsRefocus=!0},t.prototype.isActive=function(A,t,M){var e=A.props;return!!(e.active||null!=t&&e.eventKey===t||M&&e.href===M)||e.active},t.prototype.render=function(){var A,t=this,M=this.props,e=M.stacked,I=M.justified,g=M.onSelect,n=M.role,o=M.navbar,E=M.pullRight,T=M.pullLeft,N=M.className,c=M.children,C=D()(M,["stacked","justified","onSelect","role","navbar","pullRight","pullLeft","className","children"]),B=this.context.$bs_tabContainer,s=n||(B?"tablist":null),l=this.getActiveProps(),u=l.activeKey,y=l.activeHref;delete C.activeKey,delete C.activeHref;var x=V(C),w=x[0],j=x[1],Y=i()({},b(w),((A={})[R(w,"stacked")]=e,A[R(w,"justified")]=I,A)),d=null!=o?o:this.context.$bs_navbar,h=void 0,L=void 0;if(d){var S=this.context.$bs_navbar||{bsClass:"navbar"};Y[R(S,"nav")]=!0,L=R(S,"right"),h=R(S,"left")}else L="pull-right",h="pull-left";return Y[L]=E,Y[h]=T,r.a.createElement("ul",i()({},j,{role:s,className:Q()(N,Y)}),K.map(c,function(A){var M=t.isActive(A,u,y),e=QA(A.props.onSelect,g,d&&d.onSelect,B&&B.onSelect);return Object(a.cloneElement)(A,i()({},t.getTabProps(A,B,s,M,e),{active:M,activeKey:u,activeHref:y,onSelect:e}))}))},t}(r.a.Component);$e.propTypes=qe,$e.defaultProps={justified:!1,pullRight:!1,pullLeft:!1,stacked:!1},$e.contextTypes=_e;var AI=k("nav",G(["tabs","pills"],$e)),tI={$bs_navbar:l.a.shape({bsClass:l.a.string})},MI=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=A.children,e=D()(A,["className","children"]),I=R(this.context.$bs_navbar||{bsClass:"navbar"},"brand");return r.a.isValidElement(M)?r.a.cloneElement(M,{className:Q()(M.props.className,t,I)}):r.a.createElement("span",i()({},e,{className:Q()(t,I)}),M)},t}(r.a.Component);MI.contextTypes=tI;var eI=MI,II={$bs_navbar:l.a.shape({bsClass:l.a.string,expanded:l.a.bool})},gI=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.children,M=D()(A,["children"]),e=this.context.$bs_navbar||{bsClass:"navbar"},I=R(e,"collapse");return r.a.createElement(jt,i()({in:e.expanded},M),r.a.createElement("div",{className:I},t))},t}(r.a.Component);gI.contextTypes=II;var iI=gI,nI={$bs_navbar:l.a.shape({bsClass:l.a.string})},oI=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=D()(A,["className"]),e=R(this.context.$bs_navbar||{bsClass:"navbar"},"header");return r.a.createElement("div",i()({},M,{className:Q()(t,e)}))},t}(r.a.Component);oI.contextTypes=nI;var EI=oI,TI={onClick:l.a.func,children:l.a.node},NI={$bs_navbar:l.a.shape({bsClass:l.a.string,expanded:l.a.bool,onToggle:l.a.func.isRequired})},cI=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.onClick,M=A.className,e=A.children,I=D()(A,["onClick","className","children"]),g=this.context.$bs_navbar||{bsClass:"navbar"},n=i()({type:"button"},I,{onClick:QA(t,g.onToggle),className:Q()(M,R(g,"toggle"),!g.expanded&&"collapsed")});return e?r.a.createElement("button",n,e):r.a.createElement("button",n,r.a.createElement("span",{className:"sr-only"},"Toggle navigation"),r.a.createElement("span",{className:"icon-bar"}),r.a.createElement("span",{className:"icon-bar"}),r.a.createElement("span",{className:"icon-bar"}))},t}(r.a.Component);cI.propTypes=TI,cI.contextTypes=NI;var aI=cI,rI={fixedTop:l.a.bool,fixedBottom:l.a.bool,staticTop:l.a.bool,inverse:l.a.bool,fluid:l.a.bool,componentClass:BA.a,onToggle:l.a.func,onSelect:l.a.func,collapseOnSelect:l.a.bool,expanded:l.a.bool,role:l.a.string},CI={$bs_navbar:l.a.shape({bsClass:l.a.string,expanded:l.a.bool,onToggle:l.a.func.isRequired,onSelect:l.a.func})},DI=function(A){function t(M,e){o()(this,t);var I=T()(this,A.call(this,M,e));return I.handleToggle=I.handleToggle.bind(I),I.handleCollapse=I.handleCollapse.bind(I),I}return c()(t,A),t.prototype.getChildContext=function(){var A=this.props,t=A.bsClass,M=A.expanded,e=A.onSelect,I=A.collapseOnSelect;return{$bs_navbar:{bsClass:t,expanded:M,onToggle:this.handleToggle,onSelect:QA(e,I?this.handleCollapse:null)}}},t.prototype.handleCollapse=function(){var A=this.props,t=A.onToggle;A.expanded&&t(!1)},t.prototype.handleToggle=function(){var A=this.props;(0,A.onToggle)(!A.expanded)},t.prototype.render=function(){var A,t=this.props,M=t.componentClass,e=t.fixedTop,I=t.fixedBottom,g=t.staticTop,n=t.inverse,o=t.fluid,E=t.className,T=t.children,N=X(D()(t,["componentClass","fixedTop","fixedBottom","staticTop","inverse","fluid","className","children"]),["expanded","onToggle","onSelect","collapseOnSelect"]),c=N[0],a=N[1];void 0===a.role&&"nav"!==M&&(a.role="navigation"),n&&(c.bsStyle=m);var C=i()({},b(c),((A={})[R(c,"fixed-top")]=e,A[R(c,"fixed-bottom")]=I,A[R(c,"static-top")]=g,A));return r.a.createElement(M,i()({},a,{className:Q()(E,C)}),r.a.createElement(jM,{fluid:o},T))},t}(r.a.Component);DI.propTypes=rI,DI.defaultProps={componentClass:"nav",fixedTop:!1,fixedBottom:!1,staticTop:!1,inverse:!1,fluid:!1,collapseOnSelect:!1},DI.childContextTypes=CI,k("navbar",DI);var BI=y()(DI,{expanded:"onToggle"});function QI(A,t,M){var e=function(A,M){var e=M.$bs_navbar,I=void 0===e?{bsClass:"navbar"}:e,g=A.componentClass,n=A.className,o=A.pullRight,E=A.pullLeft,T=D()(A,["componentClass","className","pullRight","pullLeft"]);return r.a.createElement(g,i()({},T,{className:Q()(n,R(I,t),o&&R(I,"right"),E&&R(I,"left"))}))};return e.displayName=M,e.propTypes={componentClass:BA.a,pullRight:l.a.bool,pullLeft:l.a.bool},e.defaultProps={componentClass:A,pullRight:!1,pullLeft:!1},e.contextTypes={$bs_navbar:l.a.shape({bsClass:l.a.string})},e}BI.Brand=eI,BI.Header=EI,BI.Toggle=aI,BI.Collapse=iI,BI.Form=QI("div","form","NavbarForm"),BI.Text=QI("p","text","NavbarText"),BI.Link=QI("a","link","NavbarLink");var sI=G([p,m],p,BI),lI=i()({},Zt.propTypes,{title:l.a.node.isRequired,noCaret:l.a.bool,active:l.a.bool,activeKey:l.a.any,activeHref:l.a.string,children:l.a.node}),uI=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.isActive=function(A,t,M){var e=A.props,I=this;return!!(e.active||null!=t&&e.eventKey===t||M&&e.href===M)||(!!K.some(e.children,function(A){return I.isActive(A,t,M)})||e.active)},t.prototype.render=function(){var A=this,t=this.props,M=t.title,e=t.activeKey,I=t.activeHref,g=t.className,n=t.style,o=t.children,E=D()(t,["title","activeKey","activeHref","className","style","children"]),T=this.isActive(this,e,I);delete E.active,delete E.eventKey;var N=qt(E,Zt.ControlledComponent),c=N[0],a=N[1];return r.a.createElement(Zt,i()({},c,{componentClass:"li",className:Q()(g,{active:T}),style:n}),r.a.createElement(Zt.Toggle,i()({},a,{useAnchor:!0}),M),r.a.createElement(Zt.Menu,null,K.map(o,function(t){return r.a.cloneElement(t,{active:A.isActive(t,e,I)})})))},t}(r.a.Component);uI.propTypes=lI;var yI=uI,xI={active:l.a.bool,disabled:l.a.bool,role:l.a.string,href:l.a.string,onClick:l.a.func,onSelect:l.a.func,eventKey:l.a.any},wI=function(A){function t(M,e){o()(this,t);var I=T()(this,A.call(this,M,e));return I.handleClick=I.handleClick.bind(I),I}return c()(t,A),t.prototype.handleClick=function(A){this.props.disabled?A.preventDefault():this.props.onSelect&&this.props.onSelect(this.props.eventKey,A)},t.prototype.render=function(){var A=this.props,t=A.active,M=A.disabled,e=A.onClick,I=A.className,g=A.style,n=D()(A,["active","disabled","onClick","className","style"]);return delete n.onSelect,delete n.eventKey,delete n.activeKey,delete n.activeHref,n.role?"tab"===n.role&&(n["aria-selected"]=t):"#"===n.href&&(n.role="button"),r.a.createElement("li",{role:"presentation",className:Q()(I,{active:t,disabled:M}),style:g},r.a.createElement(yA,i()({},n,{disabled:M,onClick:QA(e,this.handleClick)})))},t}(r.a.Component);wI.propTypes=xI,wI.defaultProps={active:!1,disabled:!1};var jI=wI,YI=M(199),dI=M.n(YI),hI=i()({},dI.a.propTypes,{show:l.a.bool,rootClose:l.a.bool,onHide:l.a.func,animation:l.a.oneOfType([l.a.bool,BA.a]),onEnter:l.a.func,onEntering:l.a.func,onEntered:l.a.func,onExit:l.a.func,onExiting:l.a.func,onExited:l.a.func,placement:l.a.oneOf(["top","right","bottom","left"])}),LI={animation:gM,rootClose:!1,show:!1,placement:"right"},SI=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.animation,M=A.children,e=D()(A,["animation","children"]),I=!0===t?gM:t||null,g=void 0;return g=I?M:Object(a.cloneElement)(M,{className:Q()(M.props.className,"in")}),r.a.createElement(dI.a,i()({},e,{transition:I}),g)},t}(r.a.Component);SI.propTypes=hI,SI.defaultProps=LI;var zI=SI;function UI(A,t){return Array.isArray(t)?t.indexOf(A)>=0:A===t}var pI=l.a.oneOf(["click","hover","focus"]),fI=i()({},zI.propTypes,{trigger:l.a.oneOfType([pI,l.a.arrayOf(pI)]),delay:l.a.number,delayShow:l.a.number,delayHide:l.a.number,defaultOverlayShown:l.a.bool,overlay:l.a.node.isRequired,onBlur:l.a.func,onClick:l.a.func,onFocus:l.a.func,onMouseOut:l.a.func,onMouseOver:l.a.func,target:l.a.oneOf([null]),onHide:l.a.oneOf([null]),show:l.a.oneOf([null])}),FI=function(A){function t(M,e){o()(this,t);var I=T()(this,A.call(this,M,e));return I.handleToggle=I.handleToggle.bind(I),I.handleDelayedShow=I.handleDelayedShow.bind(I),I.handleDelayedHide=I.handleDelayedHide.bind(I),I.handleHide=I.handleHide.bind(I),I.handleMouseOver=function(A){return I.handleMouseOverOut(I.handleDelayedShow,A,"fromElement")},I.handleMouseOut=function(A){return I.handleMouseOverOut(I.handleDelayedHide,A,"toElement")},I._mountNode=null,I.state={show:M.defaultOverlayShown},I}return c()(t,A),t.prototype.componentDidMount=function(){this._mountNode=document.createElement("div"),this.renderOverlay()},t.prototype.componentDidUpdate=function(){this.renderOverlay()},t.prototype.componentWillUnmount=function(){bA.a.unmountComponentAtNode(this._mountNode),this._mountNode=null,clearTimeout(this._hoverShowDelay),clearTimeout(this._hoverHideDelay)},t.prototype.handleDelayedHide=function(){var A=this;if(null!=this._hoverShowDelay)return clearTimeout(this._hoverShowDelay),void(this._hoverShowDelay=null);if(this.state.show&&null==this._hoverHideDelay){var t=null!=this.props.delayHide?this.props.delayHide:this.props.delay;t?this._hoverHideDelay=setTimeout(function(){A._hoverHideDelay=null,A.hide()},t):this.hide()}},t.prototype.handleDelayedShow=function(){var A=this;if(null!=this._hoverHideDelay)return clearTimeout(this._hoverHideDelay),void(this._hoverHideDelay=null);if(!this.state.show&&null==this._hoverShowDelay){var t=null!=this.props.delayShow?this.props.delayShow:this.props.delay;t?this._hoverShowDelay=setTimeout(function(){A._hoverShowDelay=null,A.show()},t):this.show()}},t.prototype.handleHide=function(){this.hide()},t.prototype.handleMouseOverOut=function(A,t,M){var e=t.currentTarget,I=t.relatedTarget||t.nativeEvent[M];I&&I===e||Lt()(e,I)||A(t)},t.prototype.handleToggle=function(){this.state.show?this.hide():this.show()},t.prototype.hide=function(){this.setState({show:!1})},t.prototype.makeOverlay=function(A,t){return r.a.createElement(zI,i()({},t,{show:this.state.show,onHide:this.handleHide,target:this}),A)},t.prototype.show=function(){this.setState({show:!0})},t.prototype.renderOverlay=function(){bA.a.unstable_renderSubtreeIntoContainer(this,this._overlay,this._mountNode)},t.prototype.render=function(){var A=this.props,t=A.trigger,M=A.overlay,e=A.children,I=A.onBlur,g=A.onClick,i=A.onFocus,n=A.onMouseOut,o=A.onMouseOver,E=D()(A,["trigger","overlay","children","onBlur","onClick","onFocus","onMouseOut","onMouseOver"]);delete E.delay,delete E.delayShow,delete E.delayHide,delete E.defaultOverlayShown;var T=r.a.Children.only(e),N=T.props,c={};return this.state.show&&(c["aria-describedby"]=M.props.id),c.onClick=QA(N.onClick,g),UI("click",t)&&(c.onClick=QA(c.onClick,this.handleToggle)),UI("hover",t)&&(c.onMouseOver=QA(N.onMouseOver,o,this.handleMouseOver),c.onMouseOut=QA(N.onMouseOut,n,this.handleMouseOut)),UI("focus",t)&&(c.onFocus=QA(N.onFocus,i,this.handleDelayedShow),c.onBlur=QA(N.onBlur,I,this.handleDelayedHide)),this._overlay=this.makeOverlay(M,E),Object(a.cloneElement)(T,c)},t}(r.a.Component);FI.propTypes=fI,FI.defaultProps={defaultOverlayShown:!1,trigger:["hover","focus"]};var mI=FI,OI=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=A.children,e=V(D()(A,["className","children"])),I=e[0],g=e[1],n=b(I);return r.a.createElement("div",i()({},g,{className:Q()(t,n)}),r.a.createElement("h1",null,M))},t}(r.a.Component),RI=k("page-header",OI),kI={disabled:l.a.bool,previous:l.a.bool,next:l.a.bool,onClick:l.a.func,onSelect:l.a.func,eventKey:l.a.any},GI=function(A){function t(M,e){o()(this,t);var I=T()(this,A.call(this,M,e));return I.handleSelect=I.handleSelect.bind(I),I}return c()(t,A),t.prototype.handleSelect=function(A){var t=this.props,M=t.disabled,e=t.onSelect,I=t.eventKey;M?A.preventDefault():e&&e(I,A)},t.prototype.render=function(){var A=this.props,t=A.disabled,M=A.previous,e=A.next,I=A.onClick,g=A.className,n=A.style,o=D()(A,["disabled","previous","next","onClick","className","style"]);return delete o.onSelect,delete o.eventKey,r.a.createElement("li",{className:Q()(g,{disabled:t,previous:M,next:e}),style:n},r.a.createElement(yA,i()({},o,{disabled:t,onClick:QA(I,this.handleSelect)})))},t}(r.a.Component);GI.propTypes=kI,GI.defaultProps={disabled:!1,previous:!1,next:!1};var JI=GI,bI=M(129),HI=M.n(bI),vI={};function VI(A,t,M){var e=void 0;"object"===(void 0===A?"undefined":HI()(A))?e=A.message:(e=A+" is deprecated. Use "+t+" instead.",M&&(e+="\nYou can read more about it at "+M)),vI[e]||(vI[e]=!0)}VI.wrapper=function(A){for(var t=arguments.length,M=Array(t>1?t-1:0),e=1;e` + "`" + `","` + "`" + `` + "`" + `"),WI={onSelect:l.a.func},PI=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.onSelect,M=A.className,e=A.children,I=V(D()(A,["onSelect","className","children"])),g=I[0],n=I[1],o=b(g);return r.a.createElement("ul",i()({},n,{className:Q()(M,o)}),K.map(e,function(A){return Object(a.cloneElement)(A,{onSelect:QA(A.props.onSelect,t)})}))},t}(r.a.Component);PI.propTypes=WI,PI.Item=JI;var KI=k("pager",PI),ZI={eventKey:l.a.any,className:l.a.string,onSelect:l.a.func,disabled:l.a.bool,active:l.a.bool,activeLabel:l.a.string.isRequired};function qI(A){var t=A.active,M=A.disabled,e=A.className,I=A.style,g=A.activeLabel,n=A.children,o=D()(A,["active","disabled","className","style","activeLabel","children"]),E=t||M?"span":yA;return r.a.createElement("li",{style:I,className:Q()(e,{active:t,disabled:M})},r.a.createElement(E,i()({disabled:M},o),n,t&&r.a.createElement("span",{className:"sr-only"},g)))}function _I(A,t){var M,e,I=arguments.length>2&&void 0!==arguments[2]?arguments[2]:A;return e=M=function(A){function M(){return o()(this,M),T()(this,A.apply(this,arguments))}return c()(M,A),M.prototype.render=function(){var A=this.props,M=A.disabled,e=A.children,g=A.className,n=D()(A,["disabled","children","className"]),o=M?"span":yA;return r.a.createElement("li",i()({"aria-label":I,className:Q()(g,{disabled:M})},n),r.a.createElement(o,null,e||t))},M}(r.a.Component),M.displayName=A,M.propTypes={disabled:l.a.bool},e}qI.propTypes=ZI,qI.defaultProps={active:!1,disabled:!1,activeLabel:"(current)"};var $I=_I("First","«"),Ag=_I("Prev","‹"),tg=_I("Ellipsis","…","More"),Mg=_I("Next","›"),eg=_I("Last","»"),Ig=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.className,M=A.children,e=V(D()(A,["className","children"])),I=e[0],g=e[1],n=b(I);return r.a.createElement("ul",i()({},g,{className:Q()(t,n)}),M)},t}(r.a.Component);k("pagination",Ig),Ig.First=$I,Ig.Prev=Ag,Ig.Ellipsis=tg,Ig.Item=qI,Ig.Next=Mg,Ig.Last=eg;var gg=Ig,ig=M(191),ng=M.n(ig),og={onEnter:l.a.func,onEntering:l.a.func,onEntered:l.a.func,onExit:l.a.func,onExiting:l.a.func,onExited:l.a.func},Eg={$bs_panel:l.a.shape({headingId:l.a.string,bodyId:l.a.string,bsClass:l.a.string,expanded:l.a.bool})},Tg=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props.children,t=this.context.$bs_panel||{},M=t.headingId,e=t.bodyId,I=t.bsClass,g=t.expanded,n=V(this.props),o=n[0],E=n[1];return o.bsClass=I||o.bsClass,M&&e&&(E.id=e,E.role=E.role||"tabpanel",E["aria-labelledby"]=M),r.a.createElement(jt,i()({in:g},E),r.a.createElement("div",{className:R(o,"collapse")},A))},t}(r.a.Component);Tg.propTypes=og,Tg.contextTypes=Eg;var Ng=k("panel",Tg),cg={collapsible:l.a.bool.isRequired},ag={$bs_panel:l.a.shape({bsClass:l.a.string})},rg=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.children,M=A.className,e=A.collapsible,I=(this.context.$bs_panel||{}).bsClass,g=X(this.props,["collapsible"]),n=g[0],o=g[1];n.bsClass=I||n.bsClass;var E=r.a.createElement("div",i()({},o,{className:Q()(M,R(n,"body"))}),t);return e&&(E=r.a.createElement(Ng,null,E)),E},t}(r.a.Component);rg.propTypes=cg,rg.defaultProps={collapsible:!1},rg.contextTypes=ag;var Cg=k("panel",rg),Dg=M(95),Bg=M.n(Dg),Qg={componentClass:Bg.a},sg={$bs_panel:l.a.shape({headingId:l.a.string,bsClass:l.a.string})},lg=function(A){function t(){return o()(this,t),T()(this,A.apply(this,arguments))}return c()(t,A),t.prototype.render=function(){var A=this.props,t=A.children,M=A.className,e=A.componentClass,I=D()(A,["children","className","componentClass"]),g=this.context.$bs_panel||{},n=g.headingId,o=g.bsClass,E=V(I),T=E[0],N=E[1];return T.bsClass=o||T.bsClass,n&&(N.role=N.role||"tab",N.id=n),r.a.createElement(e,i()({},N,{className:Q()(M,R(T,"heading"))}),t)},t}(r.a.Component);lg.propTypes=Qg,lg.defaultProps={componentClass:"div"},lg.contextTypes=sg;var ug=k("panel",lg),yg={onClick:l.a.func,componentClass:Bg.a},xg={componentClass:yA},wg={$bs_panel:l.a.shape({bodyId:l.a.string,onToggle:l.a.func,expanded:l.a.bool})},jg=function(A){function t(){o()(this,t);for(var M=arguments.length,e=Array(M),I=0;I1?M-1:0),I=1;I0&&void 0!==arguments[0]&&arguments[0],t=this.nextStatus;if(null!==t){this.nextStatus=null,this.cancelNextCallback();var M=g.default.findDOMNode(this);t===E?this.performEnter(M,A):this.performExit(M)}else this.props.unmountOnExit&&this.state.status===o&&this.setState({status:n})},t.prototype.performEnter=function(A,t){var M=this,e=this.props.enter,I=this.context.transitionGroup?this.context.transitionGroup.isMounting:t,g=this.getTimeouts();t||e?(this.props.onEnter(A,I),this.safeSetState({status:E},function(){M.props.onEntering(A,I),M.onTransitionEnd(A,g.enter,function(){M.safeSetState({status:T},function(){M.props.onEntered(A,I)})})})):this.safeSetState({status:T},function(){M.props.onEntered(A)})},t.prototype.performExit=function(A){var t=this,M=this.props.exit,e=this.getTimeouts();M?(this.props.onExit(A),this.safeSetState({status:N},function(){t.props.onExiting(A),t.onTransitionEnd(A,e.exit,function(){t.safeSetState({status:o},function(){t.props.onExited(A)})})})):this.safeSetState({status:o},function(){t.props.onExited(A)})},t.prototype.cancelNextCallback=function(){null!==this.nextCallback&&(this.nextCallback.cancel(),this.nextCallback=null)},t.prototype.safeSetState=function(A,t){var M=this;this.pendingState=A,t=this.setNextCallback(t),this.setState(A,function(){M.pendingState=null,t()})},t.prototype.setNextCallback=function(A){var t=this,M=!0;return this.nextCallback=function(e){M&&(M=!1,t.nextCallback=null,A(e))},this.nextCallback.cancel=function(){M=!1},this.nextCallback},t.prototype.onTransitionEnd=function(A,t,M){this.setNextCallback(M),A?(this.props.addEndListener&&this.props.addEndListener(A,this.nextCallback),null!=t&&setTimeout(this.nextCallback,t)):setTimeout(this.nextCallback,0)},t.prototype.render=function(){var A=this.state.status;if(A===n)return null;var t=this.props,M=t.children,e=function(A,t){var M={};for(var e in A)t.indexOf(e)>=0||Object.prototype.hasOwnProperty.call(A,e)&&(M[e]=A[e]);return M}(t,["children"]);if(delete e.in,delete e.mountOnEnter,delete e.unmountOnExit,delete e.appear,delete e.enter,delete e.exit,delete e.timeout,delete e.addEndListener,delete e.onEnter,delete e.onEntering,delete e.onEntered,delete e.onExit,delete e.onExiting,delete e.onExited,"function"==typeof M)return M(A,e);var g=I.default.Children.only(M);return I.default.cloneElement(g,e)},t}(I.default.Component);function a(){}c.contextTypes={transitionGroup:e.object},c.childContextTypes={transitionGroup:function(){}},c.propTypes={},c.defaultProps={in:!1,mountOnEnter:!1,unmountOnExit:!1,appear:!1,enter:!0,exit:!0,onEnter:a,onEntering:a,onEntered:a,onExit:a,onExiting:a,onExited:a},c.UNMOUNTED=0,c.EXITED=1,c.ENTERING=2,c.ENTERED=3,c.EXITING=4,t.default=c},function(A,t){var M=A.exports={version:"2.4.0"};"number"==typeof __e&&(__e=M)},function(A,t,M){var e=M(33);A.exports=function(A,t,M){if(e(A),void 0===t)return A;switch(M){case 1:return function(M){return A.call(t,M)};case 2:return function(M,e){return A.call(t,M,e)};case 3:return function(M,e,I){return A.call(t,M,e,I)}}return function(){return A.apply(t,arguments)}}},function(A,t,M){"use strict";if(M(22)){var e=M(67),I=M(15),g=M(17),i=M(8),n=M(120),o=M(159),E=M(55),T=M(73),N=M(59),c=M(31),a=M(74),r=M(61),C=M(24),D=M(69),B=M(43),Q=M(28),s=M(206),l=M(100),u=M(19),y=M(25),x=M(151),w=M(70),j=M(37),Y=M(71).f,d=M(153),h=M(66),L=M(21),S=M(45),z=M(112),U=M(156),p=M(155),f=M(81),F=M(116),m=M(72),O=M(154),R=M(215),k=M(23),G=M(36),J=k.f,b=G.f,H=I.RangeError,v=I.TypeError,V=I.Uint8Array,X=Array.prototype,W=o.ArrayBuffer,P=o.DataView,K=S(0),Z=S(2),q=S(3),_=S(4),$=S(5),AA=S(6),tA=z(!0),MA=z(!1),eA=p.values,IA=p.keys,gA=p.entries,iA=X.lastIndexOf,nA=X.reduce,oA=X.reduceRight,EA=X.join,TA=X.sort,NA=X.slice,cA=X.toString,aA=X.toLocaleString,rA=L("iterator"),CA=L("toStringTag"),DA=h("typed_constructor"),BA=h("def_constructor"),QA=n.CONSTR,sA=n.TYPED,lA=n.VIEW,uA=S(1,function(A,t){return dA(U(A,A[BA]),t)}),yA=g(function(){return 1===new V(new Uint16Array([1]).buffer)[0]}),xA=!!V&&!!V.prototype.set&&g(function(){new V(1).set({})}),wA=function(A,t){if(void 0===A)throw v("Wrong length!");var M=+A,e=C(A);if(t&&!s(M,e))throw H("Wrong length!");return e},jA=function(A,t){var M=r(A);if(M<0||M%t)throw H("Wrong offset!");return M},YA=function(A){if(u(A)&&sA in A)return A;throw v(A+" is not a typed array!")},dA=function(A,t){if(!(u(A)&&DA in A))throw v("It is not a typed array constructor!");return new A(t)},hA=function(A,t){return LA(U(A,A[BA]),t)},LA=function(A,t){for(var M=0,e=t.length,I=dA(A,e);e>M;)I[M]=t[M++];return I},SA=function(A,t,M){J(A,t,{get:function(){return this._d[M]}})},zA=function(A){var t,M,e,I,g,i,n=y(A),o=arguments.length,T=o>1?arguments[1]:void 0,N=void 0!==T,c=d(n);if(null!=c&&!x(c)){for(i=c.call(n),e=[],t=0;!(g=i.next()).done;t++)e.push(g.value);n=e}for(N&&o>2&&(T=E(T,arguments[2],2)),t=0,M=C(n.length),I=dA(this,M);M>t;t++)I[t]=N?T(n[t],t):n[t];return I},UA=function(){for(var A=0,t=arguments.length,M=dA(this,t);t>A;)M[A]=arguments[A++];return M},pA=!!V&&g(function(){aA.call(new V(1))}),fA=function(){return aA.apply(pA?NA.call(YA(this)):YA(this),arguments)},FA={copyWithin:function(A,t){return R.call(YA(this),A,t,arguments.length>2?arguments[2]:void 0)},every:function(A){return _(YA(this),A,arguments.length>1?arguments[1]:void 0)},fill:function(A){return O.apply(YA(this),arguments)},filter:function(A){return hA(this,Z(YA(this),A,arguments.length>1?arguments[1]:void 0))},find:function(A){return $(YA(this),A,arguments.length>1?arguments[1]:void 0)},findIndex:function(A){return AA(YA(this),A,arguments.length>1?arguments[1]:void 0)},forEach:function(A){K(YA(this),A,arguments.length>1?arguments[1]:void 0)},indexOf:function(A){return MA(YA(this),A,arguments.length>1?arguments[1]:void 0)},includes:function(A){return tA(YA(this),A,arguments.length>1?arguments[1]:void 0)},join:function(A){return EA.apply(YA(this),arguments)},lastIndexOf:function(A){return iA.apply(YA(this),arguments)},map:function(A){return uA(YA(this),A,arguments.length>1?arguments[1]:void 0)},reduce:function(A){return nA.apply(YA(this),arguments)},reduceRight:function(A){return oA.apply(YA(this),arguments)},reverse:function(){for(var A,t=YA(this).length,M=Math.floor(t/2),e=0;e1?arguments[1]:void 0)},sort:function(A){return TA.call(YA(this),A)},subarray:function(A,t){var M=YA(this),e=M.length,I=D(A,e);return new(U(M,M[BA]))(M.buffer,M.byteOffset+I*M.BYTES_PER_ELEMENT,C((void 0===t?e:D(t,e))-I))}},mA=function(A,t){return hA(this,NA.call(YA(this),A,t))},OA=function(A){YA(this);var t=jA(arguments[1],1),M=this.length,e=y(A),I=C(e.length),g=0;if(I+t>M)throw H("Wrong length!");for(;g255?255:255&e),I.v[r](M*t+I.o,e,yA)}(this,M,A)},enumerable:!0})};s?(D=M(function(A,M,e,I){T(A,D,E,"_d");var g,i,n,o,N=0,a=0;if(u(M)){if(!(M instanceof W||"ArrayBuffer"==(o=l(M))||"SharedArrayBuffer"==o))return sA in M?LA(D,M):zA.call(D,M);g=M,a=jA(e,t);var r=M.byteLength;if(void 0===I){if(r%t)throw H("Wrong length!");if((i=r-a)<0)throw H("Wrong length!")}else if((i=C(I)*t)+a>r)throw H("Wrong length!");n=i/t}else n=wA(M,!0),g=new W(i=n*t);for(c(A,"_d",{b:g,o:a,l:i,e:n,v:new P(g)});N>",n=g||M;if(null==t[M])return new Error("The "+I+" ` + "`" + `"+n+"` + "`" + ` is required to make ` + "`" + `"+i+"` + "`" + ` accessible for users of assistive technologies such as screen readers.");for(var o=arguments.length,E=Array(o>5?o-5:0),T=5;T0?e:M)(A)}},function(A,t,M){var e=M(63),I=M(48),g=M(166),i=M(86),n=function(A,t,M){var o,E,T,N=A&n.F,c=A&n.G,a=A&n.S,r=A&n.P,C=A&n.B,D=A&n.W,B=c?I:I[t]||(I[t]={}),Q=B.prototype,s=c?e:a?e[t]:(e[t]||{}).prototype;for(o in c&&(M=t),M)(E=!N&&s&&void 0!==s[o])&&o in B||(T=E?s[o]:M[o],B[o]=c&&"function"!=typeof s[o]?M[o]:C&&E?g(T,e):D&&s[o]==T?function(A){var t=function(t,M,e){if(this instanceof A){switch(arguments.length){case 0:return new A;case 1:return new A(t);case 2:return new A(t,M)}return new A(t,M,e)}return A.apply(this,arguments)};return t.prototype=A.prototype,t}(T):r&&"function"==typeof T?g(Function.call,T):T,r&&((B.virtual||(B.virtual={}))[o]=T,A&n.R&&Q&&!Q[o]&&i(Q,o,T)))};n.F=1,n.G=2,n.S=4,n.P=8,n.B=16,n.W=32,n.U=64,n.R=128,A.exports=n},function(A,t){var M=A.exports="undefined"!=typeof window&&window.Math==Math?window:"undefined"!=typeof self&&self.Math==Math?self:Function("return this")();"number"==typeof __g&&(__g=M)},function(A,t,M){var e=M(239),I=M(169);A.exports=function(A){return e(I(A))}},function(A,t,M){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=!("undefined"==typeof window||!window.document||!window.document.createElement),A.exports=t.default},function(A,t){var M=0,e=Math.random();A.exports=function(A){return"Symbol(".concat(void 0===A?"":A,")_",(++M+e).toString(36))}},function(A,t){A.exports=!1},function(A,t,M){var e=M(202),I=M(137);A.exports=Object.keys||function(A){return e(A,I)}},function(A,t,M){var e=M(61),I=Math.max,g=Math.min;A.exports=function(A,t){return(A=e(A))<0?I(A+t,0):g(A,t)}},function(A,t,M){var e=M(13),I=M(203),g=M(137),i=M(136)("IE_PROTO"),n=function(){},o=function(){var A,t=M(134)("iframe"),e=g.length;for(t.style.display="none",M(139).appendChild(t),t.src="javascript:",(A=t.contentWindow.document).open(),A.write(" + +` diff --git a/vendor/golang.org/x/tools/cmd/cover/testdata/main.go b/vendor/golang.org/x/tools/cmd/cover/testdata/main.go new file mode 100644 index 0000000000..6ed39c4f23 --- /dev/null +++ b/vendor/golang.org/x/tools/cmd/cover/testdata/main.go @@ -0,0 +1,112 @@ +// Copyright 2013 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// Test runner for coverage test. This file is not coverage-annotated; test.go is. +// It knows the coverage counter is called "coverTest". + +package main + +import ( + "fmt" + "os" +) + +func main() { + testAll() + verify() +} + +type block struct { + count uint32 + line uint32 +} + +var counters = make(map[block]bool) + +// check records the location and expected value for a counter. +func check(line, count uint32) { + b := block{ + count, + line, + } + counters[b] = true +} + +// checkVal is a version of check that returns its extra argument, +// so it can be used in conditionals. +func checkVal(line, count uint32, val int) int { + b := block{ + count, + line, + } + counters[b] = true + return val +} + +var PASS = true + +// verify checks the expected counts against the actual. It runs after the test has completed. +func verify() { + for b := range counters { + got, index := count(b.line) + if b.count == anything && got != 0 { + got = anything + } + if got != b.count { + fmt.Fprintf(os.Stderr, "test_go:%d expected count %d got %d [counter %d]\n", b.line, b.count, got, index) + PASS = false + } + } + verifyPanic() + if !PASS { + fmt.Fprintf(os.Stderr, "FAIL\n") + os.Exit(2) + } +} + +// verifyPanic is a special check for the known counter that should be +// after the panic call in testPanic. +func verifyPanic() { + if coverTest.Count[panicIndex-1] != 1 { + // Sanity check for test before panic. + fmt.Fprintf(os.Stderr, "bad before panic") + PASS = false + } + if coverTest.Count[panicIndex] != 0 { + fmt.Fprintf(os.Stderr, "bad at panic: %d should be 0\n", coverTest.Count[panicIndex]) + PASS = false + } + if coverTest.Count[panicIndex+1] != 1 { + fmt.Fprintf(os.Stderr, "bad after panic") + PASS = false + } +} + +// count returns the count and index for the counter at the specified line. +func count(line uint32) (uint32, int) { + // Linear search is fine. Choose perfect fit over approximate. + // We can have a closing brace for a range on the same line as a condition for an "else if" + // and we don't want that brace to steal the count for the condition on the "if". + // Therefore we test for a perfect (lo==line && hi==line) match, but if we can't + // find that we take the first imperfect match. + index := -1 + indexLo := uint32(1e9) + for i := range coverTest.Count { + lo, hi := coverTest.Pos[3*i], coverTest.Pos[3*i+1] + if lo == line && line == hi { + return coverTest.Count[i], i + } + // Choose the earliest match (the counters are in unpredictable order). + if lo <= line && line <= hi && indexLo > lo { + index = i + indexLo = lo + } + } + if index == -1 { + fmt.Fprintln(os.Stderr, "cover_test: no counter for line", line) + PASS = false + return 0, 0 + } + return coverTest.Count[index], index +} diff --git a/vendor/golang.org/x/tools/cmd/cover/testdata/test.go b/vendor/golang.org/x/tools/cmd/cover/testdata/test.go new file mode 100644 index 0000000000..9013950a2b --- /dev/null +++ b/vendor/golang.org/x/tools/cmd/cover/testdata/test.go @@ -0,0 +1,218 @@ +// Copyright 2013 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// This program is processed by the cover command, and then testAll is called. +// The test driver in main.go can then compare the coverage statistics with expectation. + +// The word LINE is replaced by the line number in this file. When the file is executed, +// the coverage processing has changed the line numbers, so we can't use runtime.Caller. + +package main + +const anything = 1e9 // Just some unlikely value that means "we got here, don't care how often" + +func testAll() { + testSimple() + testBlockRun() + testIf() + testFor() + testRange() + testSwitch() + testTypeSwitch() + testSelect1() + testSelect2() + testPanic() + testEmptySwitches() +} + +// The indexes of the counters in testPanic are known to main.go +const panicIndex = 3 + +// This test appears first because the index of its counters is known to main.go +func testPanic() { + defer func() { + recover() + }() + check(LINE, 1) + panic("should not get next line") + check(LINE, 0) // this is GoCover.Count[panicIndex] + // The next counter is in testSimple and it will be non-zero. + // If the panic above does not trigger a counter, the test will fail + // because GoCover.Count[panicIndex] will be the one in testSimple. +} + +func testSimple() { + check(LINE, 1) +} + +func testIf() { + if true { + check(LINE, 1) + } else { + check(LINE, 0) + } + if false { + check(LINE, 0) + } else { + check(LINE, 1) + } + for i := 0; i < 3; i++ { + if checkVal(LINE, 3, i) <= 2 { + check(LINE, 3) + } + if checkVal(LINE, 3, i) <= 1 { + check(LINE, 2) + } + if checkVal(LINE, 3, i) <= 0 { + check(LINE, 1) + } + } + for i := 0; i < 3; i++ { + if checkVal(LINE, 3, i) <= 1 { + check(LINE, 2) + } else { + check(LINE, 1) + } + } + for i := 0; i < 3; i++ { + if checkVal(LINE, 3, i) <= 0 { + check(LINE, 1) + } else if checkVal(LINE, 2, i) <= 1 { + check(LINE, 1) + } else if checkVal(LINE, 1, i) <= 2 { + check(LINE, 1) + } else if checkVal(LINE, 0, i) <= 3 { + check(LINE, 0) + } + } + if func(a, b int) bool { return a < b }(3, 4) { + check(LINE, 1) + } +} + +func testFor() { + for i := 0; i < 10; func() { i++; check(LINE, 10) }() { + check(LINE, 10) + } +} + +func testRange() { + for _, f := range []func(){ + func() { check(LINE, 1) }, + } { + f() + check(LINE, 1) + } +} + +func testBlockRun() { + check(LINE, 1) + { + check(LINE, 1) + } + { + check(LINE, 1) + } + check(LINE, 1) + { + check(LINE, 1) + } + { + check(LINE, 1) + } + check(LINE, 1) +} + +func testSwitch() { + for i := 0; i < 5; func() { i++; check(LINE, 5) }() { + switch i { + case 0: + check(LINE, 1) + case 1: + check(LINE, 1) + case 2: + check(LINE, 1) + default: + check(LINE, 2) + } + } +} + +func testTypeSwitch() { + var x = []interface{}{1, 2.0, "hi"} + for _, v := range x { + switch func() { check(LINE, 3) }(); v.(type) { + case int: + check(LINE, 1) + case float64: + check(LINE, 1) + case string: + check(LINE, 1) + case complex128: + check(LINE, 0) + default: + check(LINE, 0) + } + } +} + +func testSelect1() { + c := make(chan int) + go func() { + for i := 0; i < 1000; i++ { + c <- i + } + }() + for { + select { + case <-c: + check(LINE, anything) + case <-c: + check(LINE, anything) + default: + check(LINE, 1) + return + } + } +} + +func testSelect2() { + c1 := make(chan int, 1000) + c2 := make(chan int, 1000) + for i := 0; i < 1000; i++ { + c1 <- i + c2 <- i + } + for { + select { + case <-c1: + check(LINE, 1000) + case <-c2: + check(LINE, 1000) + default: + check(LINE, 1) + return + } + } +} + +// Empty control statements created syntax errors. This function +// is here just to be sure that those are handled correctly now. +func testEmptySwitches() { + check(LINE, 1) + switch 3 { + } + check(LINE, 1) + switch i := (interface{})(3).(int); i { + } + check(LINE, 1) + c := make(chan int) + go func() { + check(LINE, 1) + c <- 1 + select {} + }() + <-c + check(LINE, 1) +} diff --git a/vendor/golang.org/x/tools/cmd/digraph/digraph.go b/vendor/golang.org/x/tools/cmd/digraph/digraph.go new file mode 100644 index 0000000000..8ef2e45ef1 --- /dev/null +++ b/vendor/golang.org/x/tools/cmd/digraph/digraph.go @@ -0,0 +1,541 @@ +// The digraph command performs queries over unlabelled directed graphs +// represented in text form. It is intended to integrate nicely with +// typical UNIX command pipelines. +// +// Since directed graphs (import graphs, reference graphs, call graphs, +// etc) often arise during software tool development and debugging, this +// command is included in the go.tools repository. +// +// TODO(adonovan): +// - support input files other than stdin +// - support alternative formats (AT&T GraphViz, CSV, etc), +// a comment syntax, etc. +// - allow queries to nest, like Blaze query language. +// +package main // import "golang.org/x/tools/cmd/digraph" + +import ( + "bufio" + "bytes" + "errors" + "flag" + "fmt" + "io" + "os" + "sort" + "strconv" + "unicode" + "unicode/utf8" +) + +const Usage = `digraph: queries over directed graphs in text form. + +Graph format: + + Each line contains zero or more words. Words are separated by + unquoted whitespace; words may contain Go-style double-quoted portions, + allowing spaces and other characters to be expressed. + + Each field declares a node, and if there are more than one, + an edge from the first to each subsequent one. + The graph is provided on the standard input. + + For instance, the following (acyclic) graph specifies a partial order + among the subtasks of getting dressed: + + % cat clothes.txt + socks shoes + "boxer shorts" pants + pants belt shoes + shirt tie sweater + sweater jacket + hat + + The line "shirt tie sweater" indicates the two edges shirt -> tie and + shirt -> sweater, not shirt -> tie -> sweater. + +Supported queries: + + nodes + the set of all nodes + degree + the in-degree and out-degree of each node. + preds