Update traefik dependencies (docker/docker and related) (#1823)
Update traefik dependencies (docker/docker and related) - Update dependencies - Fix compilation problems - Remove vdemeester/docker-events (in docker api now) - Remove `integration/vendor` - Use `testImport` - update some deps. - regenerate the lock from scratch (after a `glide cc`)
This commit is contained in:
parent
7d178f49b4
commit
b7daa2f3a4
1301 changed files with 21476 additions and 150099 deletions
|
@ -17,7 +17,6 @@ RUN go get github.com/jteeuwen/go-bindata/... \
|
||||||
# Which docker version to test on
|
# Which docker version to test on
|
||||||
ARG DOCKER_VERSION=17.03.2
|
ARG DOCKER_VERSION=17.03.2
|
||||||
|
|
||||||
|
|
||||||
# Which glide version to test on
|
# Which glide version to test on
|
||||||
ARG GLIDE_VERSION=v0.12.3
|
ARG GLIDE_VERSION=v0.12.3
|
||||||
|
|
||||||
|
|
196
glide.lock
generated
196
glide.lock
generated
|
@ -1,5 +1,5 @@
|
||||||
hash: de681761bddc92dceb0bb7a5ab72be2a898ff2eea4b09a526401f72fe8f20365
|
hash: 00a95d73c58e56b7f3c295f8c58efa786b234c96ea245bf213118f95de2c3ec0
|
||||||
updated: 2017-06-30T11:03:09.025639582+02:00
|
updated: 2017-07-05T21:00:31.241672481+02:00
|
||||||
imports:
|
imports:
|
||||||
- name: cloud.google.com/go
|
- name: cloud.google.com/go
|
||||||
version: 2e6a95edb1071d750f6d7db777bf66cd2997af6c
|
version: 2e6a95edb1071d750f6d7db777bf66cd2997af6c
|
||||||
|
@ -7,7 +7,7 @@ imports:
|
||||||
- compute/metadata
|
- compute/metadata
|
||||||
- internal
|
- internal
|
||||||
- name: github.com/abbot/go-http-auth
|
- name: github.com/abbot/go-http-auth
|
||||||
version: d45c47bedec736d172957bd394786b76626fa8ac
|
version: 0ddd408d5d60ea76e320503cc7dd091992dee608
|
||||||
- name: github.com/ArthurHlt/go-eureka-client
|
- name: github.com/ArthurHlt/go-eureka-client
|
||||||
version: 9d0a49cbd39aa3634ae1977e9f519a262b10adaf
|
version: 9d0a49cbd39aa3634ae1977e9f519a262b10adaf
|
||||||
subpackages:
|
subpackages:
|
||||||
|
@ -83,7 +83,7 @@ imports:
|
||||||
- name: github.com/codegangsta/cli
|
- name: github.com/codegangsta/cli
|
||||||
version: bf4a526f48af7badd25d2cb02d587e1b01be3b50
|
version: bf4a526f48af7badd25d2cb02d587e1b01be3b50
|
||||||
- name: github.com/codegangsta/negroni
|
- name: github.com/codegangsta/negroni
|
||||||
version: c0db5feaa33826cd5117930c8f4ee5c0f565eec6
|
version: 490e6a555d47ca891a89a150d0c1ef3922dfffe9
|
||||||
- name: github.com/containous/flaeg
|
- name: github.com/containous/flaeg
|
||||||
version: b5d2dc5878df07c2d74413348186982e7b865871
|
version: b5d2dc5878df07c2d74413348186982e7b865871
|
||||||
- name: github.com/containous/mux
|
- name: github.com/containous/mux
|
||||||
|
@ -93,6 +93,8 @@ imports:
|
||||||
- name: github.com/coreos/etcd
|
- name: github.com/coreos/etcd
|
||||||
version: c400d05d0aa73e21e431c16145e558d624098018
|
version: c400d05d0aa73e21e431c16145e558d624098018
|
||||||
subpackages:
|
subpackages:
|
||||||
|
- Godeps/_workspace/src/github.com/ugorji/go/codec
|
||||||
|
- Godeps/_workspace/src/golang.org/x/net/context
|
||||||
- client
|
- client
|
||||||
- pkg/pathutil
|
- pkg/pathutil
|
||||||
- pkg/types
|
- pkg/types
|
||||||
|
@ -127,46 +129,89 @@ imports:
|
||||||
subpackages:
|
subpackages:
|
||||||
- dnsimple
|
- dnsimple
|
||||||
- name: github.com/docker/distribution
|
- name: github.com/docker/distribution
|
||||||
version: 325b0804fef3a66309d962357aac3c2ce3f4d329
|
version: b38e5838b7b2f2ad48e06ec4b500011976080621
|
||||||
subpackages:
|
subpackages:
|
||||||
- digest
|
- context
|
||||||
|
- digestset
|
||||||
- reference
|
- reference
|
||||||
- name: github.com/docker/engine-api
|
- registry/api/errcode
|
||||||
version: 3d1601b9d2436a70b0dfc045a23f6503d19195df
|
- registry/api/v2
|
||||||
|
- registry/client
|
||||||
|
- registry/client/auth
|
||||||
|
- registry/client/auth/challenge
|
||||||
|
- registry/client/transport
|
||||||
|
- registry/storage/cache
|
||||||
|
- registry/storage/cache/memory
|
||||||
|
- uuid
|
||||||
|
- name: github.com/docker/docker
|
||||||
|
version: 75c7536d2e2e328b644bf69153de879d1d197988
|
||||||
subpackages:
|
subpackages:
|
||||||
|
- api
|
||||||
|
- api/types
|
||||||
|
- api/types/blkiodev
|
||||||
|
- api/types/container
|
||||||
|
- api/types/events
|
||||||
|
- api/types/filters
|
||||||
|
- api/types/image
|
||||||
|
- api/types/mount
|
||||||
|
- api/types/network
|
||||||
|
- api/types/registry
|
||||||
|
- api/types/strslice
|
||||||
|
- api/types/swarm
|
||||||
|
- api/types/time
|
||||||
|
- api/types/versions
|
||||||
|
- api/types/volume
|
||||||
|
- builder/dockerignore
|
||||||
- client
|
- client
|
||||||
- client/transport
|
- opts
|
||||||
- client/transport/cancellable
|
- pkg/archive
|
||||||
- types
|
- pkg/fileutils
|
||||||
- types/blkiodev
|
- pkg/gitutils
|
||||||
- types/container
|
- pkg/homedir
|
||||||
- types/events
|
- pkg/httputils
|
||||||
- types/filters
|
- pkg/idtools
|
||||||
- types/network
|
- pkg/ioutils
|
||||||
- types/reference
|
- pkg/jsonlog
|
||||||
- types/registry
|
- pkg/jsonmessage
|
||||||
- types/strslice
|
- pkg/longpath
|
||||||
- types/swarm
|
- pkg/mount
|
||||||
- types/time
|
- pkg/namesgenerator
|
||||||
- types/versions
|
- pkg/pools
|
||||||
|
- pkg/progress
|
||||||
|
- pkg/promise
|
||||||
|
- pkg/random
|
||||||
|
- pkg/stdcopy
|
||||||
|
- pkg/streamformatter
|
||||||
|
- pkg/stringid
|
||||||
|
- pkg/symlink
|
||||||
|
- pkg/system
|
||||||
|
- pkg/tarsum
|
||||||
|
- pkg/term
|
||||||
|
- pkg/term/windows
|
||||||
|
- pkg/tlsconfig
|
||||||
|
- pkg/urlutil
|
||||||
|
- registry
|
||||||
|
- runconfig/opts
|
||||||
- name: github.com/docker/go-connections
|
- name: github.com/docker/go-connections
|
||||||
version: 990a1a1a70b0da4c4cb70e117971a4f0babfbf1a
|
version: e15c02316c12de00874640cd76311849de2aeed5
|
||||||
subpackages:
|
subpackages:
|
||||||
- nat
|
- nat
|
||||||
- sockets
|
- sockets
|
||||||
- tlsconfig
|
- tlsconfig
|
||||||
- name: github.com/docker/go-units
|
- name: github.com/docker/go-units
|
||||||
version: 0dadbb0345b35ec7ef35e228dabb8de89a65bf52
|
version: 9e638d38cf6977a37a8ea0078f3ee75a7cdb2dd1
|
||||||
- name: github.com/docker/leadership
|
- name: github.com/docker/leadership
|
||||||
version: 0a913e2d71a12fd14a028452435cb71ac8d82cb6
|
version: 0a913e2d71a12fd14a028452435cb71ac8d82cb6
|
||||||
- name: github.com/docker/libkv
|
- name: github.com/docker/libkv
|
||||||
version: 1d8431073ae03cdaedb198a89722f3aab6d418ef
|
version: 93ab0e6c056d325dfbb11e1d58a3b4f5f62e7f3c
|
||||||
subpackages:
|
subpackages:
|
||||||
- store
|
- store
|
||||||
- store/boltdb
|
- store/boltdb
|
||||||
- store/consul
|
- store/consul
|
||||||
- store/etcd
|
- store/etcd
|
||||||
- store/zookeeper
|
- store/zookeeper
|
||||||
|
- name: github.com/docker/libtrust
|
||||||
|
version: 9cbd2a1374f46905c68a4eb3694a130610adc62a
|
||||||
- name: github.com/donovanhide/eventsource
|
- name: github.com/donovanhide/eventsource
|
||||||
version: b8f31a59085e69dd2678cf51840db2ac625cb741
|
version: b8f31a59085e69dd2678cf51840db2ac625cb741
|
||||||
- name: github.com/eapache/channels
|
- name: github.com/eapache/channels
|
||||||
|
@ -189,7 +234,7 @@ imports:
|
||||||
- log
|
- log
|
||||||
- swagger
|
- swagger
|
||||||
- name: github.com/fatih/color
|
- name: github.com/fatih/color
|
||||||
version: 9131ab34cf20d2f6d83fdc67168a5430d1c7dc23
|
version: 62e9147c64a1ed519147b62a56a14e83e2be02c1
|
||||||
- name: github.com/gambol99/go-marathon
|
- name: github.com/gambol99/go-marathon
|
||||||
version: dd6cbd4c2d71294a19fb89158f2a00d427f174ab
|
version: dd6cbd4c2d71294a19fb89158f2a00d427f174ab
|
||||||
- name: github.com/ghodss/yaml
|
- name: github.com/ghodss/yaml
|
||||||
|
@ -222,7 +267,7 @@ imports:
|
||||||
subpackages:
|
subpackages:
|
||||||
- proto
|
- proto
|
||||||
- name: github.com/google/go-github
|
- name: github.com/google/go-github
|
||||||
version: 6896997c7c9fe603fb9d2e8e92303bb18481e60a
|
version: fe7d11f8add400587b6718d9f39a62e42cb04c28
|
||||||
subpackages:
|
subpackages:
|
||||||
- github
|
- github
|
||||||
- name: github.com/google/go-querystring
|
- name: github.com/google/go-querystring
|
||||||
|
@ -234,9 +279,9 @@ imports:
|
||||||
- name: github.com/googleapis/gax-go
|
- name: github.com/googleapis/gax-go
|
||||||
version: 9af46dd5a1713e8b5cd71106287eba3cefdde50b
|
version: 9af46dd5a1713e8b5cd71106287eba3cefdde50b
|
||||||
- name: github.com/gorilla/context
|
- name: github.com/gorilla/context
|
||||||
version: 08b5f424b9271eedf6f9f0ce86cb9396ed337a42
|
version: 215affda49addc4c8ef7e2534915df2c8c35c6cd
|
||||||
- name: github.com/gorilla/websocket
|
- name: github.com/gorilla/websocket
|
||||||
version: a91eba7f97777409bc2c443f5534d41dd20c5720
|
version: ea4d1f681babbce9545c9c5f3d5194a789c89f5b
|
||||||
- name: github.com/hashicorp/consul
|
- name: github.com/hashicorp/consul
|
||||||
version: 3f92cc70e8163df866873c16c6d89889b5c95fc4
|
version: 3f92cc70e8163df866873c16c6d89889b5c95fc4
|
||||||
subpackages:
|
subpackages:
|
||||||
|
@ -302,21 +347,28 @@ imports:
|
||||||
- records/state
|
- records/state
|
||||||
- util
|
- util
|
||||||
- name: github.com/Microsoft/go-winio
|
- name: github.com/Microsoft/go-winio
|
||||||
version: fff283ad5116362ca252298cfc9b95828956d85d
|
version: f533f7a102197536779ea3a8cb881d639e21ec5a
|
||||||
- name: github.com/miekg/dns
|
- name: github.com/miekg/dns
|
||||||
version: 8060d9f51305bbe024b99679454e62f552cd0b0b
|
version: 8060d9f51305bbe024b99679454e62f552cd0b0b
|
||||||
- name: github.com/mitchellh/mapstructure
|
- name: github.com/mitchellh/mapstructure
|
||||||
version: 53818660ed4955e899c0bcafa97299a388bd7c8e
|
version: d0303fe809921458f417bcf828397a65db30a7e4
|
||||||
- name: github.com/mvdan/xurls
|
- name: github.com/mvdan/xurls
|
||||||
version: db96455566f05ffe42bd6ac671f05eeb1152b45d
|
version: db96455566f05ffe42bd6ac671f05eeb1152b45d
|
||||||
|
- name: github.com/Nvveen/Gotty
|
||||||
|
version: 6018b68f96b839edfbe3fb48668853f5dbad88a3
|
||||||
|
repo: https://github.com/ijc25/Gotty
|
||||||
|
vcs: git
|
||||||
- name: github.com/NYTimes/gziphandler
|
- name: github.com/NYTimes/gziphandler
|
||||||
version: 22d4470af89e09998fc16b35029df973932df4ae
|
version: 56545f4a5d46df9a6648819d1664c3a03a13ffdb
|
||||||
- name: github.com/ogier/pflag
|
- name: github.com/ogier/pflag
|
||||||
version: 45c278ab3607870051a2ea9040bb85fcb8557481
|
version: 45c278ab3607870051a2ea9040bb85fcb8557481
|
||||||
- name: github.com/opencontainers/runc
|
- name: github.com/opencontainers/go-digest
|
||||||
version: 50401b5b4c2e01e4f1372b73a021742deeaf4e2d
|
version: a6d0ee40d4207ea02364bd3b9e8e77b9159ba1eb
|
||||||
|
- name: github.com/opencontainers/image-spec
|
||||||
|
version: f03dbe35d449c54915d235f1a3cf8f585a24babe
|
||||||
subpackages:
|
subpackages:
|
||||||
- libcontainer/user
|
- specs-go
|
||||||
|
- specs-go/v1
|
||||||
- name: github.com/ovh/go-ovh
|
- name: github.com/ovh/go-ovh
|
||||||
version: d2207178e10e4527e8f222fd8707982df8c3af17
|
version: d2207178e10e4527e8f222fd8707982df8c3af17
|
||||||
subpackages:
|
subpackages:
|
||||||
|
@ -324,7 +376,7 @@ imports:
|
||||||
- name: github.com/pborman/uuid
|
- name: github.com/pborman/uuid
|
||||||
version: ca53cad383cad2479bbba7f7a1a05797ec1386e4
|
version: ca53cad383cad2479bbba7f7a1a05797ec1386e4
|
||||||
- name: github.com/pkg/errors
|
- name: github.com/pkg/errors
|
||||||
version: ff09b135c25aae272398c51a07235b90a75aa4f0
|
version: c605e284fe17294bda444b34710735b29d1a9d90
|
||||||
- name: github.com/pmezard/go-difflib
|
- name: github.com/pmezard/go-difflib
|
||||||
version: d8ed2627bdf02c080bf22230dbb337003b7aba2d
|
version: d8ed2627bdf02c080bf22230dbb337003b7aba2d
|
||||||
subpackages:
|
subpackages:
|
||||||
|
@ -375,7 +427,7 @@ imports:
|
||||||
- name: github.com/Sirupsen/logrus
|
- name: github.com/Sirupsen/logrus
|
||||||
version: 10f801ebc38b33738c9d17d50860f484a0988ff5
|
version: 10f801ebc38b33738c9d17d50860f484a0988ff5
|
||||||
- name: github.com/spf13/pflag
|
- name: github.com/spf13/pflag
|
||||||
version: 5ccb023bc27df288a957c5e994cd44fd19619465
|
version: cb88ea77998c3f024757528e3305022ab50b43be
|
||||||
- name: github.com/streamrail/concurrent-map
|
- name: github.com/streamrail/concurrent-map
|
||||||
version: 8bf1e9bacbf65b10c81d0f4314cf2b1ebef728b5
|
version: 8bf1e9bacbf65b10c81d0f4314cf2b1ebef728b5
|
||||||
- name: github.com/stretchr/objx
|
- name: github.com/stretchr/objx
|
||||||
|
@ -402,8 +454,6 @@ imports:
|
||||||
version: 50716a0a853771bb36bfce61a45cdefdb98c2e6e
|
version: 50716a0a853771bb36bfce61a45cdefdb98c2e6e
|
||||||
- name: github.com/unrolled/secure
|
- name: github.com/unrolled/secure
|
||||||
version: 824e85271811af89640ea25620c67f6c2eed987e
|
version: 824e85271811af89640ea25620c67f6c2eed987e
|
||||||
- name: github.com/vdemeester/docker-events
|
|
||||||
version: be74d4929ec1ad118df54349fda4b0cba60f849b
|
|
||||||
- name: github.com/vulcand/oxy
|
- name: github.com/vulcand/oxy
|
||||||
version: 7da864c1d53bd58165435bb78bbf8c01f01c8f4a
|
version: 7da864c1d53bd58165435bb78bbf8c01f01c8f4a
|
||||||
repo: https://github.com/containous/oxy.git
|
repo: https://github.com/containous/oxy.git
|
||||||
|
@ -479,7 +529,7 @@ imports:
|
||||||
- jws
|
- jws
|
||||||
- jwt
|
- jwt
|
||||||
- name: golang.org/x/sys
|
- name: golang.org/x/sys
|
||||||
version: 8d1157a435470616f975ff9bb013bea8d0962067
|
version: 8f0908ab3b2457e2e15403d3697c9ef5cb4b57a9
|
||||||
subpackages:
|
subpackages:
|
||||||
- unix
|
- unix
|
||||||
- windows
|
- windows
|
||||||
|
@ -496,6 +546,10 @@ imports:
|
||||||
- unicode/bidi
|
- unicode/bidi
|
||||||
- unicode/norm
|
- unicode/norm
|
||||||
- width
|
- width
|
||||||
|
- name: golang.org/x/time
|
||||||
|
version: 8be79e1e0910c292df4e79c241bb7e8f7e725959
|
||||||
|
subpackages:
|
||||||
|
- rate
|
||||||
- name: google.golang.org/api
|
- name: google.golang.org/api
|
||||||
version: 9bf6e6e569ff057f75d9604a46c52928f17d2b54
|
version: 9bf6e6e569ff057f75d9604a46c52928f17d2b54
|
||||||
subpackages:
|
subpackages:
|
||||||
|
@ -661,4 +715,64 @@ imports:
|
||||||
- tools/clientcmd/api
|
- tools/clientcmd/api
|
||||||
- tools/metrics
|
- tools/metrics
|
||||||
- transport
|
- transport
|
||||||
testImports: []
|
testImports:
|
||||||
|
- name: github.com/Azure/go-ansiterm
|
||||||
|
version: 19f72df4d05d31cbe1c56bfc8045c96babff6c7e
|
||||||
|
subpackages:
|
||||||
|
- winterm
|
||||||
|
- name: github.com/docker/cli
|
||||||
|
version: d95fd2f38cfc23e077530c6181330727d561b6a0
|
||||||
|
subpackages:
|
||||||
|
- cli/command/image/build
|
||||||
|
- cli/config
|
||||||
|
- cli/config/configfile
|
||||||
|
- name: github.com/docker/libcompose
|
||||||
|
version: 0ad950cbeb3d72107613dd220b5e9d7e001b890b
|
||||||
|
subpackages:
|
||||||
|
- config
|
||||||
|
- docker
|
||||||
|
- docker/auth
|
||||||
|
- docker/builder
|
||||||
|
- docker/client
|
||||||
|
- docker/container
|
||||||
|
- docker/ctx
|
||||||
|
- docker/image
|
||||||
|
- docker/network
|
||||||
|
- docker/service
|
||||||
|
- docker/volume
|
||||||
|
- labels
|
||||||
|
- logger
|
||||||
|
- lookup
|
||||||
|
- project
|
||||||
|
- project/events
|
||||||
|
- project/options
|
||||||
|
- utils
|
||||||
|
- version
|
||||||
|
- yaml
|
||||||
|
- name: github.com/flynn/go-shlex
|
||||||
|
version: 3f9db97f856818214da2e1057f8ad84803971cff
|
||||||
|
- name: github.com/go-check/check
|
||||||
|
version: 11d3bc7aa68e238947792f30573146a3231fc0f1
|
||||||
|
- name: github.com/gorilla/mux
|
||||||
|
version: e444e69cbd2e2e3e0749a2f3c717cec491552bbf
|
||||||
|
- name: github.com/libkermit/compose
|
||||||
|
version: 2048f803f56422a65b455f918d4a61704dc94603
|
||||||
|
subpackages:
|
||||||
|
- check
|
||||||
|
- name: github.com/libkermit/docker
|
||||||
|
version: ddede409294e8c5ae66d68ac09edb6b27e8f3e4a
|
||||||
|
- name: github.com/libkermit/docker-check
|
||||||
|
version: e0695005d6819191cf8969b479c94c40c8d22aa4
|
||||||
|
- name: github.com/opencontainers/runc
|
||||||
|
version: b6b70e53451794e8333e9b602cc096b47a20bd0f
|
||||||
|
subpackages:
|
||||||
|
- libcontainer/system
|
||||||
|
- libcontainer/user
|
||||||
|
- name: github.com/vdemeester/shakers
|
||||||
|
version: 24d7f1d6a71aa5d9cbe7390e4afb66b7eef9e1b3
|
||||||
|
- name: github.com/xeipuuv/gojsonpointer
|
||||||
|
version: 6fe8760cad3569743d51ddbb243b26f8456742dc
|
||||||
|
- name: github.com/xeipuuv/gojsonreference
|
||||||
|
version: e02fc20de94c78484cd5ffb007f8af96be030a45
|
||||||
|
- name: github.com/xeipuuv/gojsonschema
|
||||||
|
version: 0c8571ac0ce161a5feb57375a9cdf148c98c0f70
|
||||||
|
|
73
glide.yaml
73
glide.yaml
|
@ -1,6 +1,9 @@
|
||||||
package: github.com/containous/traefik
|
package: github.com/containous/traefik
|
||||||
|
ignore:
|
||||||
|
- github.com/sirupsen/logrus
|
||||||
import:
|
import:
|
||||||
- package: github.com/BurntSushi/toml
|
- package: github.com/BurntSushi/toml
|
||||||
|
version: v0.3.0
|
||||||
- package: github.com/BurntSushi/ty
|
- package: github.com/BurntSushi/ty
|
||||||
subpackages:
|
subpackages:
|
||||||
- fun
|
- fun
|
||||||
|
@ -19,22 +22,19 @@ import:
|
||||||
- roundrobin
|
- roundrobin
|
||||||
- stream
|
- stream
|
||||||
- utils
|
- utils
|
||||||
|
- name: github.com/codegangsta/negroni
|
||||||
|
version: 490e6a555d47ca891a89a150d0c1ef3922dfffe9
|
||||||
- package: github.com/containous/staert
|
- package: github.com/containous/staert
|
||||||
version: 1e26a71803e428fd933f5f9c8e50a26878f53147
|
version: 1e26a71803e428fd933f5f9c8e50a26878f53147
|
||||||
- package: github.com/docker/engine-api
|
- package: github.com/docker/docker
|
||||||
version: v0.4.0
|
version: 75c7536d2e2e328b644bf69153de879d1d197988
|
||||||
subpackages:
|
|
||||||
- client
|
|
||||||
- types
|
|
||||||
- types/events
|
|
||||||
- types/filters
|
|
||||||
- package: github.com/docker/go-connections
|
- package: github.com/docker/go-connections
|
||||||
version: v0.2.1
|
version: e15c02316c12de00874640cd76311849de2aeed5
|
||||||
subpackages:
|
subpackages:
|
||||||
- sockets
|
- sockets
|
||||||
- tlsconfig
|
- tlsconfig
|
||||||
- package: github.com/docker/go-units
|
- package: github.com/docker/go-units
|
||||||
version: 0dadbb0345b35ec7ef35e228dabb8de89a65bf52
|
version: 9e638d38cf6977a37a8ea0078f3ee75a7cdb2dd1
|
||||||
- package: github.com/docker/libkv
|
- package: github.com/docker/libkv
|
||||||
subpackages:
|
subpackages:
|
||||||
- store
|
- store
|
||||||
|
@ -48,16 +48,9 @@ import:
|
||||||
subpackages:
|
subpackages:
|
||||||
- api
|
- api
|
||||||
- package: github.com/streamrail/concurrent-map
|
- package: github.com/streamrail/concurrent-map
|
||||||
- package: github.com/stretchr/testify
|
|
||||||
subpackages:
|
|
||||||
- assert
|
|
||||||
- mock
|
|
||||||
- require
|
|
||||||
- package: github.com/thoas/stats
|
- package: github.com/thoas/stats
|
||||||
version: 152b5d051953fdb6e45f14b6826962aadc032324
|
version: 152b5d051953fdb6e45f14b6826962aadc032324
|
||||||
- package: github.com/unrolled/render
|
- package: github.com/unrolled/render
|
||||||
- package: github.com/vdemeester/docker-events
|
|
||||||
version: be74d4929ec1ad118df54349fda4b0cba60f849b
|
|
||||||
- package: github.com/vulcand/vulcand
|
- package: github.com/vulcand/vulcand
|
||||||
version: 42492a3a85e294bdbdd1bcabb8c12769a81ea284
|
version: 42492a3a85e294bdbdd1bcabb8c12769a81ea284
|
||||||
subpackages:
|
subpackages:
|
||||||
|
@ -122,14 +115,23 @@ import:
|
||||||
- package: github.com/eapache/channels
|
- package: github.com/eapache/channels
|
||||||
version: v1.1.0
|
version: v1.1.0
|
||||||
- package: golang.org/x/sys
|
- package: golang.org/x/sys
|
||||||
version: 8d1157a435470616f975ff9bb013bea8d0962067
|
version: 8f0908ab3b2457e2e15403d3697c9ef5cb4b57a9
|
||||||
- package: golang.org/x/net
|
- package: golang.org/x/net
|
||||||
version: 242b6b35177ec3909636b6cf6a47e8c2c6324b5d
|
version: 242b6b35177ec3909636b6cf6a47e8c2c6324b5d
|
||||||
subpackages:
|
subpackages:
|
||||||
- http2
|
- http2
|
||||||
- context
|
- context
|
||||||
- package: github.com/docker/distribution
|
- package: github.com/docker/distribution
|
||||||
version: v2.6.0
|
version: b38e5838b7b2f2ad48e06ec4b500011976080621
|
||||||
|
- package: github.com/opencontainers/go-digest
|
||||||
|
version: a6d0ee40d4207ea02364bd3b9e8e77b9159ba1eb
|
||||||
|
- package: github.com/opencontainers/image-spec
|
||||||
|
version: f03dbe35d449c54915d235f1a3cf8f585a24babe
|
||||||
|
subpackages:
|
||||||
|
- specs-go
|
||||||
|
- specs-go/v1
|
||||||
|
- package: github.com/docker/libtrust
|
||||||
|
version: 9cbd2a1374f46905c68a4eb3694a130610adc62a
|
||||||
- package: github.com/aws/aws-sdk-go
|
- package: github.com/aws/aws-sdk-go
|
||||||
version: v1.6.18
|
version: v1.6.18
|
||||||
subpackages:
|
subpackages:
|
||||||
|
@ -161,6 +163,8 @@ import:
|
||||||
version: 7fdf09982454086d5570c7db3e11f360194830ca
|
version: 7fdf09982454086d5570c7db3e11f360194830ca
|
||||||
subpackages:
|
subpackages:
|
||||||
- google
|
- google
|
||||||
|
- package: golang.org/x/time
|
||||||
|
version: 8be79e1e0910c292df4e79c241bb7e8f7e725959
|
||||||
- package: github.com/rancher/go-rancher-metadata
|
- package: github.com/rancher/go-rancher-metadata
|
||||||
version: 95d4962a8f0420be24fb49c2cb4f5491284c62f1
|
version: 95d4962a8f0420be24fb49c2cb4f5491284c62f1
|
||||||
- package: github.com/googleapis/gax-go
|
- package: github.com/googleapis/gax-go
|
||||||
|
@ -169,3 +173,36 @@ import:
|
||||||
version: v1.2.0
|
version: v1.2.0
|
||||||
- package: github.com/unrolled/secure
|
- package: github.com/unrolled/secure
|
||||||
version: 824e85271811af89640ea25620c67f6c2eed987e
|
version: 824e85271811af89640ea25620c67f6c2eed987e
|
||||||
|
- package: github.com/Nvveen/Gotty
|
||||||
|
version: 6018b68f96b839edfbe3fb48668853f5dbad88a3
|
||||||
|
repo: https://github.com/ijc25/Gotty
|
||||||
|
vcs: git
|
||||||
|
- package: github.com/spf13/pflag
|
||||||
|
version: cb88ea77998c3f024757528e3305022ab50b43be
|
||||||
|
- package: github.com/stretchr/testify
|
||||||
|
version: 4d4bfba8f1d1027c4fdbe371823030df51419987
|
||||||
|
subpackages:
|
||||||
|
- assert
|
||||||
|
- mock
|
||||||
|
- require
|
||||||
|
- package: github.com/davecgh/go-spew
|
||||||
|
version: 04cdfd42973bb9c8589fd6a731800cf222fde1a9
|
||||||
|
subpackages:
|
||||||
|
- spew
|
||||||
|
testImport:
|
||||||
|
- package: github.com/docker/libcompose
|
||||||
|
version: 0ad950cbeb3d72107613dd220b5e9d7e001b890b
|
||||||
|
- package: github.com/go-check/check
|
||||||
|
version: 11d3bc7aa68e238947792f30573146a3231fc0f1
|
||||||
|
- package: github.com/libkermit/compose
|
||||||
|
version: 2048f803f56422a65b455f918d4a61704dc94603
|
||||||
|
subpackages:
|
||||||
|
- check
|
||||||
|
- package: github.com/libkermit/docker
|
||||||
|
version: ddede409294e8c5ae66d68ac09edb6b27e8f3e4a
|
||||||
|
- package: github.com/libkermit/docker-check
|
||||||
|
version: e0695005d6819191cf8969b479c94c40c8d22aa4
|
||||||
|
- package: github.com/mattn/go-shellwords
|
||||||
|
- package: github.com/vdemeester/shakers
|
||||||
|
- package: github.com/docker/cli
|
||||||
|
version: d95fd2f38cfc23e077530c6181330727d561b6a0
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"crypto/tls"
|
"crypto/tls"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"crypto/tls"
|
"crypto/tls"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
169
integration/glide.lock
generated
169
integration/glide.lock
generated
|
@ -1,169 +0,0 @@
|
||||||
hash: 5e5e8d7a5c5fd9f258549ed2d66557ba28be66ea9ffc3eb88c1e98e3f28c8537
|
|
||||||
updated: 2017-07-02T17:06:45.618248907+02:00
|
|
||||||
imports: []
|
|
||||||
testImports:
|
|
||||||
- name: github.com/Azure/go-ansiterm
|
|
||||||
version: 19f72df4d05d31cbe1c56bfc8045c96babff6c7e
|
|
||||||
subpackages:
|
|
||||||
- winterm
|
|
||||||
- name: github.com/cloudfoundry-incubator/candiedyaml
|
|
||||||
version: cff29b469e0f490ab8c169b6a2c237543f46a1de
|
|
||||||
- name: github.com/docker/distribution
|
|
||||||
version: 99cb7c0946d2f5a38015443e515dc916295064d7
|
|
||||||
subpackages:
|
|
||||||
- context
|
|
||||||
- digest
|
|
||||||
- reference
|
|
||||||
- registry/api/errcode
|
|
||||||
- registry/api/v2
|
|
||||||
- registry/client
|
|
||||||
- registry/client/auth
|
|
||||||
- registry/client/transport
|
|
||||||
- registry/storage/cache
|
|
||||||
- registry/storage/cache/memory
|
|
||||||
- uuid
|
|
||||||
- name: github.com/docker/docker
|
|
||||||
version: 534753663161334baba06f13b8efa4cad22b5bc5
|
|
||||||
subpackages:
|
|
||||||
- api/types/backend
|
|
||||||
- builder
|
|
||||||
- builder/dockerignore
|
|
||||||
- cliconfig
|
|
||||||
- cliconfig/configfile
|
|
||||||
- daemon/graphdriver
|
|
||||||
- image
|
|
||||||
- image/v1
|
|
||||||
- layer
|
|
||||||
- opts
|
|
||||||
- pkg/archive
|
|
||||||
- pkg/chrootarchive
|
|
||||||
- pkg/fileutils
|
|
||||||
- pkg/gitutils
|
|
||||||
- pkg/homedir
|
|
||||||
- pkg/httputils
|
|
||||||
- pkg/idtools
|
|
||||||
- pkg/ioutils
|
|
||||||
- pkg/jsonlog
|
|
||||||
- pkg/jsonmessage
|
|
||||||
- pkg/longpath
|
|
||||||
- pkg/mflag
|
|
||||||
- pkg/mount
|
|
||||||
- pkg/namesgenerator
|
|
||||||
- pkg/plugins
|
|
||||||
- pkg/plugins/transport
|
|
||||||
- pkg/pools
|
|
||||||
- pkg/progress
|
|
||||||
- pkg/promise
|
|
||||||
- pkg/random
|
|
||||||
- pkg/reexec
|
|
||||||
- pkg/signal
|
|
||||||
- pkg/stdcopy
|
|
||||||
- pkg/streamformatter
|
|
||||||
- pkg/stringid
|
|
||||||
- pkg/symlink
|
|
||||||
- pkg/system
|
|
||||||
- pkg/tarsum
|
|
||||||
- pkg/term
|
|
||||||
- pkg/term/windows
|
|
||||||
- pkg/urlutil
|
|
||||||
- reference
|
|
||||||
- registry
|
|
||||||
- runconfig/opts
|
|
||||||
- name: github.com/docker/engine-api
|
|
||||||
version: 62043eb79d581a32ea849645277023c550732e52
|
|
||||||
subpackages:
|
|
||||||
- client
|
|
||||||
- client/transport
|
|
||||||
- client/transport/cancellable
|
|
||||||
- types
|
|
||||||
- types/blkiodev
|
|
||||||
- types/container
|
|
||||||
- types/events
|
|
||||||
- types/filters
|
|
||||||
- types/network
|
|
||||||
- types/reference
|
|
||||||
- types/registry
|
|
||||||
- types/strslice
|
|
||||||
- types/swarm
|
|
||||||
- types/time
|
|
||||||
- types/versions
|
|
||||||
- name: github.com/docker/go-connections
|
|
||||||
version: 35dcbbc189523094211e7f0af23d862349ada334
|
|
||||||
subpackages:
|
|
||||||
- nat
|
|
||||||
- sockets
|
|
||||||
- tlsconfig
|
|
||||||
- name: github.com/docker/go-units
|
|
||||||
version: f2145db703495b2e525c59662db69a7344b00bb8
|
|
||||||
- name: github.com/docker/libcompose
|
|
||||||
version: d1876c1d68527a49c0aac22a0b161acc7296b740
|
|
||||||
subpackages:
|
|
||||||
- config
|
|
||||||
- docker
|
|
||||||
- docker/builder
|
|
||||||
- docker/client
|
|
||||||
- docker/network
|
|
||||||
- labels
|
|
||||||
- logger
|
|
||||||
- lookup
|
|
||||||
- project
|
|
||||||
- project/events
|
|
||||||
- project/options
|
|
||||||
- utils
|
|
||||||
- version
|
|
||||||
- yaml
|
|
||||||
- name: github.com/flynn/go-shlex
|
|
||||||
version: 3f9db97f856818214da2e1057f8ad84803971cff
|
|
||||||
- name: github.com/go-check/check
|
|
||||||
version: 11d3bc7aa68e238947792f30573146a3231fc0f1
|
|
||||||
- name: github.com/gorilla/context
|
|
||||||
version: 14f550f51af52180c2eefed15e5fd18d63c0a64a
|
|
||||||
- name: github.com/gorilla/mux
|
|
||||||
version: e444e69cbd2e2e3e0749a2f3c717cec491552bbf
|
|
||||||
- name: github.com/libkermit/compose
|
|
||||||
version: cadc5a3b83a15790174bd7fbc75ea2529785e772
|
|
||||||
subpackages:
|
|
||||||
- check
|
|
||||||
- name: github.com/libkermit/docker
|
|
||||||
version: 55e3595409924fcfbb850811e5a7cdbe8960a0b7
|
|
||||||
- name: github.com/libkermit/docker-check
|
|
||||||
version: cbe0ef03b3d23070eac4d00ba8828f2cc7f7e5a3
|
|
||||||
- name: github.com/mattn/go-shellwords
|
|
||||||
version: 02e3cf038dcea8290e44424da473dd12be796a8a
|
|
||||||
- name: github.com/Microsoft/go-winio
|
|
||||||
version: f778f05015353be65d242f3fedc18695756153bb
|
|
||||||
- name: github.com/opencontainers/runc
|
|
||||||
version: b6b70e53451794e8333e9b602cc096b47a20bd0f
|
|
||||||
subpackages:
|
|
||||||
- libcontainer/user
|
|
||||||
- name: github.com/sirupsen/logrus
|
|
||||||
version: 7dd06bf38e1e13df288d471a57d5adbac106be9e
|
|
||||||
- name: github.com/Sirupsen/logrus
|
|
||||||
version: 55eb11d21d2a31a3cc93838241d04800f52e823d
|
|
||||||
- name: github.com/spf13/pflag
|
|
||||||
version: cb88ea77998c3f024757528e3305022ab50b43be
|
|
||||||
- name: github.com/vbatts/tar-split
|
|
||||||
version: b9127a139315e57ebc26030e7decf72d0a20acb4
|
|
||||||
subpackages:
|
|
||||||
- archive/tar
|
|
||||||
- tar/asm
|
|
||||||
- tar/storage
|
|
||||||
- name: github.com/vdemeester/docker-events
|
|
||||||
version: 4a83cc6dc9d599f999b62fe16bddd882ea731008
|
|
||||||
- name: github.com/vdemeester/shakers
|
|
||||||
version: 24d7f1d6a71aa5d9cbe7390e4afb66b7eef9e1b3
|
|
||||||
- name: github.com/xeipuuv/gojsonpointer
|
|
||||||
version: 6fe8760cad3569743d51ddbb243b26f8456742dc
|
|
||||||
- name: github.com/xeipuuv/gojsonreference
|
|
||||||
version: e02fc20de94c78484cd5ffb007f8af96be030a45
|
|
||||||
- name: github.com/xeipuuv/gojsonschema
|
|
||||||
version: 0c8571ac0ce161a5feb57375a9cdf148c98c0f70
|
|
||||||
- name: golang.org/x/net
|
|
||||||
version: 4876518f9e71663000c348837735820161a42df7
|
|
||||||
subpackages:
|
|
||||||
- context
|
|
||||||
- proxy
|
|
||||||
- name: golang.org/x/sys
|
|
||||||
version: 5eaf0df67e70d6997a9fe0ed24383fa1b01638d3
|
|
||||||
subpackages:
|
|
||||||
- unix
|
|
|
@ -1,36 +0,0 @@
|
||||||
package: github.com/containous/traefik/integration
|
|
||||||
ignore:
|
|
||||||
- github.com/containous/traefik
|
|
||||||
- github.com/containous/staert
|
|
||||||
- github.com/containous/flaeg
|
|
||||||
- github.com/docker/libkv
|
|
||||||
- github.com/aws/aws-sdk-go
|
|
||||||
- github.com/hashicorp/consul
|
|
||||||
testImport:
|
|
||||||
- package: github.com/docker/docker
|
|
||||||
version: 534753663161334baba06f13b8efa4cad22b5bc5
|
|
||||||
subpackages:
|
|
||||||
- pkg/namesgenerator
|
|
||||||
- package: github.com/docker/distribution
|
|
||||||
version: 99cb7c0946d2f5a38015443e515dc916295064d7
|
|
||||||
- package: github.com/docker/engine-api
|
|
||||||
version: 62043eb79d581a32ea849645277023c550732e52
|
|
||||||
- package: github.com/docker/libcompose
|
|
||||||
version: d1876c1d68527a49c0aac22a0b161acc7296b740
|
|
||||||
- package: github.com/docker/go-units
|
|
||||||
version: f2145db703495b2e525c59662db69a7344b00bb8
|
|
||||||
- package: github.com/docker/go-connections
|
|
||||||
version: 35dcbbc189523094211e7f0af23d862349ada334
|
|
||||||
- package: github.com/go-check/check
|
|
||||||
- package: github.com/libkermit/compose
|
|
||||||
version: cadc5a3b83a15790174bd7fbc75ea2529785e772
|
|
||||||
subpackages:
|
|
||||||
- check
|
|
||||||
- package: github.com/libkermit/docker
|
|
||||||
version: 55e3595409924fcfbb850811e5a7cdbe8960a0b7
|
|
||||||
- package: github.com/libkermit/docker-check
|
|
||||||
version: cbe0ef03b3d23070eac4d00ba8828f2cc7f7e5a3
|
|
||||||
- package: github.com/mattn/go-shellwords
|
|
||||||
- package: github.com/vdemeester/shakers
|
|
||||||
- package: github.com/spf13/pflag
|
|
||||||
version: cb88ea77998c3f024757528e3305022ab50b43be
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"crypto/tls"
|
"crypto/tls"
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
// This is the main file that sets up integration tests using go-check.
|
// This is the main file that sets up integration tests using go-check.
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package main
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
22
integration/vendor/github.com/Microsoft/go-winio/LICENSE
generated
vendored
22
integration/vendor/github.com/Microsoft/go-winio/LICENSE
generated
vendored
|
@ -1,22 +0,0 @@
|
||||||
The MIT License (MIT)
|
|
||||||
|
|
||||||
Copyright (c) 2015 Microsoft
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
|
||||||
copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
SOFTWARE.
|
|
||||||
|
|
241
integration/vendor/github.com/Microsoft/go-winio/backup.go
generated
vendored
241
integration/vendor/github.com/Microsoft/go-winio/backup.go
generated
vendored
|
@ -1,241 +0,0 @@
|
||||||
package winio
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/binary"
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
|
||||||
"runtime"
|
|
||||||
"syscall"
|
|
||||||
"unicode/utf16"
|
|
||||||
)
|
|
||||||
|
|
||||||
//sys backupRead(h syscall.Handle, b []byte, bytesRead *uint32, abort bool, processSecurity bool, context *uintptr) (err error) = BackupRead
|
|
||||||
//sys backupWrite(h syscall.Handle, b []byte, bytesWritten *uint32, abort bool, processSecurity bool, context *uintptr) (err error) = BackupWrite
|
|
||||||
|
|
||||||
const (
|
|
||||||
BackupData = uint32(iota + 1)
|
|
||||||
BackupEaData
|
|
||||||
BackupSecurity
|
|
||||||
BackupAlternateData
|
|
||||||
BackupLink
|
|
||||||
BackupPropertyData
|
|
||||||
BackupObjectId
|
|
||||||
BackupReparseData
|
|
||||||
BackupSparseBlock
|
|
||||||
BackupTxfsData
|
|
||||||
|
|
||||||
StreamSparseAttributes = uint32(8)
|
|
||||||
)
|
|
||||||
|
|
||||||
// BackupHeader represents a backup stream of a file.
|
|
||||||
type BackupHeader struct {
|
|
||||||
Id uint32 // The backup stream ID
|
|
||||||
Attributes uint32 // Stream attributes
|
|
||||||
Size int64 // The size of the stream in bytes
|
|
||||||
Name string // The name of the stream (for BackupAlternateData only).
|
|
||||||
Offset int64 // The offset of the stream in the file (for BackupSparseBlock only).
|
|
||||||
}
|
|
||||||
|
|
||||||
type win32StreamId struct {
|
|
||||||
StreamId uint32
|
|
||||||
Attributes uint32
|
|
||||||
Size uint64
|
|
||||||
NameSize uint32
|
|
||||||
}
|
|
||||||
|
|
||||||
// BackupStreamReader reads from a stream produced by the BackupRead Win32 API and produces a series
|
|
||||||
// of BackupHeader values.
|
|
||||||
type BackupStreamReader struct {
|
|
||||||
r io.Reader
|
|
||||||
bytesLeft int64
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewBackupStreamReader produces a BackupStreamReader from any io.Reader.
|
|
||||||
func NewBackupStreamReader(r io.Reader) *BackupStreamReader {
|
|
||||||
return &BackupStreamReader{r, 0}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Next returns the next backup stream and prepares for calls to Write(). It skips the remainder of the current stream if
|
|
||||||
// it was not completely read.
|
|
||||||
func (r *BackupStreamReader) Next() (*BackupHeader, error) {
|
|
||||||
if r.bytesLeft > 0 {
|
|
||||||
if _, err := io.Copy(ioutil.Discard, r); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var wsi win32StreamId
|
|
||||||
if err := binary.Read(r.r, binary.LittleEndian, &wsi); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
hdr := &BackupHeader{
|
|
||||||
Id: wsi.StreamId,
|
|
||||||
Attributes: wsi.Attributes,
|
|
||||||
Size: int64(wsi.Size),
|
|
||||||
}
|
|
||||||
if wsi.NameSize != 0 {
|
|
||||||
name := make([]uint16, int(wsi.NameSize/2))
|
|
||||||
if err := binary.Read(r.r, binary.LittleEndian, name); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
hdr.Name = syscall.UTF16ToString(name)
|
|
||||||
}
|
|
||||||
if wsi.StreamId == BackupSparseBlock {
|
|
||||||
if err := binary.Read(r.r, binary.LittleEndian, &hdr.Offset); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
hdr.Size -= 8
|
|
||||||
}
|
|
||||||
r.bytesLeft = hdr.Size
|
|
||||||
return hdr, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Read reads from the current backup stream.
|
|
||||||
func (r *BackupStreamReader) Read(b []byte) (int, error) {
|
|
||||||
if r.bytesLeft == 0 {
|
|
||||||
return 0, io.EOF
|
|
||||||
}
|
|
||||||
if int64(len(b)) > r.bytesLeft {
|
|
||||||
b = b[:r.bytesLeft]
|
|
||||||
}
|
|
||||||
n, err := r.r.Read(b)
|
|
||||||
r.bytesLeft -= int64(n)
|
|
||||||
if err == io.EOF {
|
|
||||||
err = io.ErrUnexpectedEOF
|
|
||||||
} else if r.bytesLeft == 0 && err == nil {
|
|
||||||
err = io.EOF
|
|
||||||
}
|
|
||||||
return n, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// BackupStreamWriter writes a stream compatible with the BackupWrite Win32 API.
|
|
||||||
type BackupStreamWriter struct {
|
|
||||||
w io.Writer
|
|
||||||
bytesLeft int64
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewBackupStreamWriter produces a BackupStreamWriter on top of an io.Writer.
|
|
||||||
func NewBackupStreamWriter(w io.Writer) *BackupStreamWriter {
|
|
||||||
return &BackupStreamWriter{w, 0}
|
|
||||||
}
|
|
||||||
|
|
||||||
// WriteHeader writes the next backup stream header and prepares for calls to Write().
|
|
||||||
func (w *BackupStreamWriter) WriteHeader(hdr *BackupHeader) error {
|
|
||||||
if w.bytesLeft != 0 {
|
|
||||||
return fmt.Errorf("missing %d bytes", w.bytesLeft)
|
|
||||||
}
|
|
||||||
name := utf16.Encode([]rune(hdr.Name))
|
|
||||||
wsi := win32StreamId{
|
|
||||||
StreamId: hdr.Id,
|
|
||||||
Attributes: hdr.Attributes,
|
|
||||||
Size: uint64(hdr.Size),
|
|
||||||
NameSize: uint32(len(name) * 2),
|
|
||||||
}
|
|
||||||
if hdr.Id == BackupSparseBlock {
|
|
||||||
// Include space for the int64 block offset
|
|
||||||
wsi.Size += 8
|
|
||||||
}
|
|
||||||
if err := binary.Write(w.w, binary.LittleEndian, &wsi); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if len(name) != 0 {
|
|
||||||
if err := binary.Write(w.w, binary.LittleEndian, name); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if hdr.Id == BackupSparseBlock {
|
|
||||||
if err := binary.Write(w.w, binary.LittleEndian, hdr.Offset); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
w.bytesLeft = hdr.Size
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Write writes to the current backup stream.
|
|
||||||
func (w *BackupStreamWriter) Write(b []byte) (int, error) {
|
|
||||||
if w.bytesLeft < int64(len(b)) {
|
|
||||||
return 0, fmt.Errorf("too many bytes by %d", int64(len(b))-w.bytesLeft)
|
|
||||||
}
|
|
||||||
n, err := w.w.Write(b)
|
|
||||||
w.bytesLeft -= int64(n)
|
|
||||||
return n, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// BackupFileReader provides an io.ReadCloser interface on top of the BackupRead Win32 API.
|
|
||||||
type BackupFileReader struct {
|
|
||||||
f *os.File
|
|
||||||
includeSecurity bool
|
|
||||||
ctx uintptr
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewBackupFileReader returns a new BackupFileReader from a file handle. If includeSecurity is true,
|
|
||||||
// Read will attempt to read the security descriptor of the file.
|
|
||||||
func NewBackupFileReader(f *os.File, includeSecurity bool) *BackupFileReader {
|
|
||||||
r := &BackupFileReader{f, includeSecurity, 0}
|
|
||||||
runtime.SetFinalizer(r, func(r *BackupFileReader) { r.Close() })
|
|
||||||
return r
|
|
||||||
}
|
|
||||||
|
|
||||||
// Read reads a backup stream from the file by calling the Win32 API BackupRead().
|
|
||||||
func (r *BackupFileReader) Read(b []byte) (int, error) {
|
|
||||||
var bytesRead uint32
|
|
||||||
err := backupRead(syscall.Handle(r.f.Fd()), b, &bytesRead, false, r.includeSecurity, &r.ctx)
|
|
||||||
if err != nil {
|
|
||||||
return 0, &os.PathError{"BackupRead", r.f.Name(), err}
|
|
||||||
}
|
|
||||||
if bytesRead == 0 {
|
|
||||||
return 0, io.EOF
|
|
||||||
}
|
|
||||||
return int(bytesRead), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Close frees Win32 resources associated with the BackupFileReader. It does not close
|
|
||||||
// the underlying file.
|
|
||||||
func (r *BackupFileReader) Close() error {
|
|
||||||
if r.ctx != 0 {
|
|
||||||
backupRead(syscall.Handle(r.f.Fd()), nil, nil, true, false, &r.ctx)
|
|
||||||
r.ctx = 0
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// BackupFileWriter provides an io.WriteCloser interface on top of the BackupWrite Win32 API.
|
|
||||||
type BackupFileWriter struct {
|
|
||||||
f *os.File
|
|
||||||
includeSecurity bool
|
|
||||||
ctx uintptr
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewBackupFileWrtier returns a new BackupFileWriter from a file handle. If includeSecurity is true,
|
|
||||||
// Write() will attempt to restore the security descriptor from the stream.
|
|
||||||
func NewBackupFileWriter(f *os.File, includeSecurity bool) *BackupFileWriter {
|
|
||||||
w := &BackupFileWriter{f, includeSecurity, 0}
|
|
||||||
runtime.SetFinalizer(w, func(w *BackupFileWriter) { w.Close() })
|
|
||||||
return w
|
|
||||||
}
|
|
||||||
|
|
||||||
// Write restores a portion of the file using the provided backup stream.
|
|
||||||
func (w *BackupFileWriter) Write(b []byte) (int, error) {
|
|
||||||
var bytesWritten uint32
|
|
||||||
err := backupWrite(syscall.Handle(w.f.Fd()), b, &bytesWritten, false, w.includeSecurity, &w.ctx)
|
|
||||||
if err != nil {
|
|
||||||
return 0, &os.PathError{"BackupWrite", w.f.Name(), err}
|
|
||||||
}
|
|
||||||
if int(bytesWritten) != len(b) {
|
|
||||||
return int(bytesWritten), errors.New("not all bytes could be written")
|
|
||||||
}
|
|
||||||
return len(b), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Close frees Win32 resources associated with the BackupFileWriter. It does not
|
|
||||||
// close the underlying file.
|
|
||||||
func (w *BackupFileWriter) Close() error {
|
|
||||||
if w.ctx != 0 {
|
|
||||||
backupWrite(syscall.Handle(w.f.Fd()), nil, nil, true, false, &w.ctx)
|
|
||||||
w.ctx = 0
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
216
integration/vendor/github.com/Microsoft/go-winio/file.go
generated
vendored
216
integration/vendor/github.com/Microsoft/go-winio/file.go
generated
vendored
|
@ -1,216 +0,0 @@
|
||||||
package winio
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"io"
|
|
||||||
"runtime"
|
|
||||||
"sync"
|
|
||||||
"syscall"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
//sys cancelIoEx(file syscall.Handle, o *syscall.Overlapped) (err error) = CancelIoEx
|
|
||||||
//sys createIoCompletionPort(file syscall.Handle, port syscall.Handle, key uintptr, threadCount uint32) (newport syscall.Handle, err error) = CreateIoCompletionPort
|
|
||||||
//sys getQueuedCompletionStatus(port syscall.Handle, bytes *uint32, key *uintptr, o **ioOperation, timeout uint32) (err error) = GetQueuedCompletionStatus
|
|
||||||
//sys setFileCompletionNotificationModes(h syscall.Handle, flags uint8) (err error) = SetFileCompletionNotificationModes
|
|
||||||
|
|
||||||
const (
|
|
||||||
cFILE_SKIP_COMPLETION_PORT_ON_SUCCESS = 1
|
|
||||||
cFILE_SKIP_SET_EVENT_ON_HANDLE = 2
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
ErrFileClosed = errors.New("file has already been closed")
|
|
||||||
ErrTimeout = &timeoutError{}
|
|
||||||
)
|
|
||||||
|
|
||||||
type timeoutError struct{}
|
|
||||||
|
|
||||||
func (e *timeoutError) Error() string { return "i/o timeout" }
|
|
||||||
func (e *timeoutError) Timeout() bool { return true }
|
|
||||||
func (e *timeoutError) Temporary() bool { return true }
|
|
||||||
|
|
||||||
var ioInitOnce sync.Once
|
|
||||||
var ioCompletionPort syscall.Handle
|
|
||||||
|
|
||||||
// ioResult contains the result of an asynchronous IO operation
|
|
||||||
type ioResult struct {
|
|
||||||
bytes uint32
|
|
||||||
err error
|
|
||||||
}
|
|
||||||
|
|
||||||
// ioOperation represents an outstanding asynchronous Win32 IO
|
|
||||||
type ioOperation struct {
|
|
||||||
o syscall.Overlapped
|
|
||||||
ch chan ioResult
|
|
||||||
}
|
|
||||||
|
|
||||||
func initIo() {
|
|
||||||
h, err := createIoCompletionPort(syscall.InvalidHandle, 0, 0, 0xffffffff)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
ioCompletionPort = h
|
|
||||||
go ioCompletionProcessor(h)
|
|
||||||
}
|
|
||||||
|
|
||||||
// win32File implements Reader, Writer, and Closer on a Win32 handle without blocking in a syscall.
|
|
||||||
// It takes ownership of this handle and will close it if it is garbage collected.
|
|
||||||
type win32File struct {
|
|
||||||
handle syscall.Handle
|
|
||||||
wg sync.WaitGroup
|
|
||||||
closing bool
|
|
||||||
readDeadline time.Time
|
|
||||||
writeDeadline time.Time
|
|
||||||
}
|
|
||||||
|
|
||||||
// makeWin32File makes a new win32File from an existing file handle
|
|
||||||
func makeWin32File(h syscall.Handle) (*win32File, error) {
|
|
||||||
f := &win32File{handle: h}
|
|
||||||
ioInitOnce.Do(initIo)
|
|
||||||
_, err := createIoCompletionPort(h, ioCompletionPort, 0, 0xffffffff)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
err = setFileCompletionNotificationModes(h, cFILE_SKIP_COMPLETION_PORT_ON_SUCCESS|cFILE_SKIP_SET_EVENT_ON_HANDLE)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
runtime.SetFinalizer(f, (*win32File).closeHandle)
|
|
||||||
return f, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func MakeOpenFile(h syscall.Handle) (io.ReadWriteCloser, error) {
|
|
||||||
return makeWin32File(h)
|
|
||||||
}
|
|
||||||
|
|
||||||
// closeHandle closes the resources associated with a Win32 handle
|
|
||||||
func (f *win32File) closeHandle() {
|
|
||||||
if !f.closing {
|
|
||||||
// cancel all IO and wait for it to complete
|
|
||||||
f.closing = true
|
|
||||||
cancelIoEx(f.handle, nil)
|
|
||||||
f.wg.Wait()
|
|
||||||
// at this point, no new IO can start
|
|
||||||
syscall.Close(f.handle)
|
|
||||||
f.handle = 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Close closes a win32File.
|
|
||||||
func (f *win32File) Close() error {
|
|
||||||
f.closeHandle()
|
|
||||||
runtime.SetFinalizer(f, nil)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// prepareIo prepares for a new IO operation
|
|
||||||
func (f *win32File) prepareIo() (*ioOperation, error) {
|
|
||||||
f.wg.Add(1)
|
|
||||||
if f.closing {
|
|
||||||
return nil, ErrFileClosed
|
|
||||||
}
|
|
||||||
c := &ioOperation{}
|
|
||||||
c.ch = make(chan ioResult)
|
|
||||||
return c, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// ioCompletionProcessor processes completed async IOs forever
|
|
||||||
func ioCompletionProcessor(h syscall.Handle) {
|
|
||||||
for {
|
|
||||||
var bytes uint32
|
|
||||||
var key uintptr
|
|
||||||
var op *ioOperation
|
|
||||||
err := getQueuedCompletionStatus(h, &bytes, &key, &op, syscall.INFINITE)
|
|
||||||
if op == nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
op.ch <- ioResult{bytes, err}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// asyncIo processes the return value from ReadFile or WriteFile, blocking until
|
|
||||||
// the operation has actually completed.
|
|
||||||
func (f *win32File) asyncIo(c *ioOperation, deadline time.Time, bytes uint32, err error) (int, error) {
|
|
||||||
if err != syscall.ERROR_IO_PENDING {
|
|
||||||
f.wg.Done()
|
|
||||||
return int(bytes), err
|
|
||||||
} else {
|
|
||||||
var r ioResult
|
|
||||||
wait := true
|
|
||||||
timedout := false
|
|
||||||
if f.closing {
|
|
||||||
cancelIoEx(f.handle, &c.o)
|
|
||||||
} else if !deadline.IsZero() {
|
|
||||||
now := time.Now()
|
|
||||||
if !deadline.After(now) {
|
|
||||||
timedout = true
|
|
||||||
} else {
|
|
||||||
timeout := time.After(deadline.Sub(now))
|
|
||||||
select {
|
|
||||||
case r = <-c.ch:
|
|
||||||
wait = false
|
|
||||||
case <-timeout:
|
|
||||||
timedout = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if timedout {
|
|
||||||
cancelIoEx(f.handle, &c.o)
|
|
||||||
}
|
|
||||||
if wait {
|
|
||||||
r = <-c.ch
|
|
||||||
}
|
|
||||||
err = r.err
|
|
||||||
if err == syscall.ERROR_OPERATION_ABORTED {
|
|
||||||
if f.closing {
|
|
||||||
err = ErrFileClosed
|
|
||||||
} else if timedout {
|
|
||||||
err = ErrTimeout
|
|
||||||
}
|
|
||||||
}
|
|
||||||
f.wg.Done()
|
|
||||||
return int(r.bytes), err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Read reads from a file handle.
|
|
||||||
func (f *win32File) Read(b []byte) (int, error) {
|
|
||||||
c, err := f.prepareIo()
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
var bytes uint32
|
|
||||||
err = syscall.ReadFile(f.handle, b, &bytes, &c.o)
|
|
||||||
n, err := f.asyncIo(c, f.readDeadline, bytes, err)
|
|
||||||
|
|
||||||
// Handle EOF conditions.
|
|
||||||
if err == nil && n == 0 && len(b) != 0 {
|
|
||||||
return 0, io.EOF
|
|
||||||
} else if err == syscall.ERROR_BROKEN_PIPE {
|
|
||||||
return 0, io.EOF
|
|
||||||
} else {
|
|
||||||
return n, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Write writes to a file handle.
|
|
||||||
func (f *win32File) Write(b []byte) (int, error) {
|
|
||||||
c, err := f.prepareIo()
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
var bytes uint32
|
|
||||||
err = syscall.WriteFile(f.handle, b, &bytes, &c.o)
|
|
||||||
return f.asyncIo(c, f.writeDeadline, bytes, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *win32File) SetReadDeadline(t time.Time) error {
|
|
||||||
f.readDeadline = t
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *win32File) SetWriteDeadline(t time.Time) error {
|
|
||||||
f.writeDeadline = t
|
|
||||||
return nil
|
|
||||||
}
|
|
30
integration/vendor/github.com/Microsoft/go-winio/fileinfo.go
generated
vendored
30
integration/vendor/github.com/Microsoft/go-winio/fileinfo.go
generated
vendored
|
@ -1,30 +0,0 @@
|
||||||
package winio
|
|
||||||
|
|
||||||
import (
|
|
||||||
"os"
|
|
||||||
"syscall"
|
|
||||||
"unsafe"
|
|
||||||
)
|
|
||||||
|
|
||||||
//sys getFileInformationByHandleEx(h syscall.Handle, class uint32, buffer *byte, size uint32) (err error) = GetFileInformationByHandleEx
|
|
||||||
//sys setFileInformationByHandle(h syscall.Handle, class uint32, buffer *byte, size uint32) (err error) = SetFileInformationByHandle
|
|
||||||
|
|
||||||
type FileBasicInfo struct {
|
|
||||||
CreationTime, LastAccessTime, LastWriteTime, ChangeTime syscall.Filetime
|
|
||||||
FileAttributes uintptr // includes padding
|
|
||||||
}
|
|
||||||
|
|
||||||
func GetFileBasicInfo(f *os.File) (*FileBasicInfo, error) {
|
|
||||||
bi := &FileBasicInfo{}
|
|
||||||
if err := getFileInformationByHandleEx(syscall.Handle(f.Fd()), 0, (*byte)(unsafe.Pointer(bi)), uint32(unsafe.Sizeof(*bi))); err != nil {
|
|
||||||
return nil, &os.PathError{"GetFileInformationByHandleEx", f.Name(), err}
|
|
||||||
}
|
|
||||||
return bi, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func SetFileBasicInfo(f *os.File, bi *FileBasicInfo) error {
|
|
||||||
if err := setFileInformationByHandle(syscall.Handle(f.Fd()), 0, (*byte)(unsafe.Pointer(bi)), uint32(unsafe.Sizeof(*bi))); err != nil {
|
|
||||||
return &os.PathError{"SetFileInformationByHandle", f.Name(), err}
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
280
integration/vendor/github.com/Microsoft/go-winio/pipe.go
generated
vendored
280
integration/vendor/github.com/Microsoft/go-winio/pipe.go
generated
vendored
|
@ -1,280 +0,0 @@
|
||||||
package winio
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"net"
|
|
||||||
"os"
|
|
||||||
"syscall"
|
|
||||||
"time"
|
|
||||||
"unsafe"
|
|
||||||
)
|
|
||||||
|
|
||||||
//sys connectNamedPipe(pipe syscall.Handle, o *syscall.Overlapped) (err error) = ConnectNamedPipe
|
|
||||||
//sys createNamedPipe(name string, flags uint32, pipeMode uint32, maxInstances uint32, outSize uint32, inSize uint32, defaultTimeout uint32, sa *securityAttributes) (handle syscall.Handle, err error) [failretval==syscall.InvalidHandle] = CreateNamedPipeW
|
|
||||||
//sys createFile(name string, access uint32, mode uint32, sa *securityAttributes, createmode uint32, attrs uint32, templatefile syscall.Handle) (handle syscall.Handle, err error) [failretval==syscall.InvalidHandle] = CreateFileW
|
|
||||||
//sys waitNamedPipe(name string, timeout uint32) (err error) = WaitNamedPipeW
|
|
||||||
|
|
||||||
type securityAttributes struct {
|
|
||||||
Length uint32
|
|
||||||
SecurityDescriptor *byte
|
|
||||||
InheritHandle uint32
|
|
||||||
}
|
|
||||||
|
|
||||||
const (
|
|
||||||
cERROR_PIPE_BUSY = syscall.Errno(231)
|
|
||||||
cERROR_PIPE_CONNECTED = syscall.Errno(535)
|
|
||||||
cERROR_SEM_TIMEOUT = syscall.Errno(121)
|
|
||||||
|
|
||||||
cPIPE_ACCESS_DUPLEX = 0x3
|
|
||||||
cFILE_FLAG_FIRST_PIPE_INSTANCE = 0x80000
|
|
||||||
cSECURITY_SQOS_PRESENT = 0x100000
|
|
||||||
cSECURITY_ANONYMOUS = 0
|
|
||||||
|
|
||||||
cPIPE_REJECT_REMOTE_CLIENTS = 0x8
|
|
||||||
|
|
||||||
cPIPE_UNLIMITED_INSTANCES = 255
|
|
||||||
|
|
||||||
cNMPWAIT_USE_DEFAULT_WAIT = 0
|
|
||||||
cNMPWAIT_NOWAIT = 1
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// This error should match net.errClosing since docker takes a dependency on its text
|
|
||||||
ErrPipeListenerClosed = errors.New("use of closed network connection")
|
|
||||||
)
|
|
||||||
|
|
||||||
type win32Pipe struct {
|
|
||||||
*win32File
|
|
||||||
path string
|
|
||||||
}
|
|
||||||
|
|
||||||
type pipeAddress string
|
|
||||||
|
|
||||||
func (f *win32Pipe) LocalAddr() net.Addr {
|
|
||||||
return pipeAddress(f.path)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *win32Pipe) RemoteAddr() net.Addr {
|
|
||||||
return pipeAddress(f.path)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *win32Pipe) SetDeadline(t time.Time) error {
|
|
||||||
f.SetReadDeadline(t)
|
|
||||||
f.SetWriteDeadline(t)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s pipeAddress) Network() string {
|
|
||||||
return "pipe"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s pipeAddress) String() string {
|
|
||||||
return string(s)
|
|
||||||
}
|
|
||||||
|
|
||||||
func makeWin32Pipe(h syscall.Handle, path string) (*win32Pipe, error) {
|
|
||||||
f, err := makeWin32File(h)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return &win32Pipe{f, path}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// DialPipe connects to a named pipe by path, timing out if the connection
|
|
||||||
// takes longer than the specified duration. If timeout is nil, then the timeout
|
|
||||||
// is the default timeout established by the pipe server.
|
|
||||||
func DialPipe(path string, timeout *time.Duration) (net.Conn, error) {
|
|
||||||
var absTimeout time.Time
|
|
||||||
if timeout != nil {
|
|
||||||
absTimeout = time.Now().Add(*timeout)
|
|
||||||
}
|
|
||||||
var err error
|
|
||||||
var h syscall.Handle
|
|
||||||
for {
|
|
||||||
h, err = createFile(path, syscall.GENERIC_READ|syscall.GENERIC_WRITE, 0, nil, syscall.OPEN_EXISTING, syscall.FILE_FLAG_OVERLAPPED|cSECURITY_SQOS_PRESENT|cSECURITY_ANONYMOUS, 0)
|
|
||||||
if err != cERROR_PIPE_BUSY {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
now := time.Now()
|
|
||||||
var ms uint32
|
|
||||||
if absTimeout.IsZero() {
|
|
||||||
ms = cNMPWAIT_USE_DEFAULT_WAIT
|
|
||||||
} else if now.After(absTimeout) {
|
|
||||||
ms = cNMPWAIT_NOWAIT
|
|
||||||
} else {
|
|
||||||
ms = uint32(absTimeout.Sub(now).Nanoseconds() / 1000 / 1000)
|
|
||||||
}
|
|
||||||
err = waitNamedPipe(path, ms)
|
|
||||||
if err != nil {
|
|
||||||
if err == cERROR_SEM_TIMEOUT {
|
|
||||||
return nil, ErrTimeout
|
|
||||||
}
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if err != nil {
|
|
||||||
return nil, &os.PathError{"open", path, err}
|
|
||||||
}
|
|
||||||
p, err := makeWin32Pipe(h, path)
|
|
||||||
if err != nil {
|
|
||||||
syscall.Close(h)
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return p, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
type acceptResponse struct {
|
|
||||||
p *win32Pipe
|
|
||||||
err error
|
|
||||||
}
|
|
||||||
|
|
||||||
type win32PipeListener struct {
|
|
||||||
firstHandle syscall.Handle
|
|
||||||
path string
|
|
||||||
securityDescriptor []byte
|
|
||||||
acceptCh chan (chan acceptResponse)
|
|
||||||
closeCh chan int
|
|
||||||
doneCh chan int
|
|
||||||
}
|
|
||||||
|
|
||||||
func makeServerPipeHandle(path string, securityDescriptor []byte, first bool) (syscall.Handle, error) {
|
|
||||||
var flags uint32 = cPIPE_ACCESS_DUPLEX | syscall.FILE_FLAG_OVERLAPPED
|
|
||||||
if first {
|
|
||||||
flags |= cFILE_FLAG_FIRST_PIPE_INSTANCE
|
|
||||||
}
|
|
||||||
var sa securityAttributes
|
|
||||||
sa.Length = uint32(unsafe.Sizeof(sa))
|
|
||||||
if securityDescriptor != nil {
|
|
||||||
sa.SecurityDescriptor = &securityDescriptor[0]
|
|
||||||
}
|
|
||||||
h, err := createNamedPipe(path, flags, cPIPE_REJECT_REMOTE_CLIENTS, cPIPE_UNLIMITED_INSTANCES, 4096, 4096, 0, &sa)
|
|
||||||
if err != nil {
|
|
||||||
return 0, &os.PathError{"open", path, err}
|
|
||||||
}
|
|
||||||
return h, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l *win32PipeListener) makeServerPipe() (*win32Pipe, error) {
|
|
||||||
h, err := makeServerPipeHandle(l.path, l.securityDescriptor, false)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
p, err := makeWin32Pipe(h, l.path)
|
|
||||||
if err != nil {
|
|
||||||
syscall.Close(h)
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return p, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l *win32PipeListener) listenerRoutine() {
|
|
||||||
closed := false
|
|
||||||
for !closed {
|
|
||||||
select {
|
|
||||||
case <-l.closeCh:
|
|
||||||
closed = true
|
|
||||||
case responseCh := <-l.acceptCh:
|
|
||||||
p, err := l.makeServerPipe()
|
|
||||||
if err == nil {
|
|
||||||
// Wait for the client to connect.
|
|
||||||
ch := make(chan error)
|
|
||||||
go func() {
|
|
||||||
ch <- connectPipe(p)
|
|
||||||
}()
|
|
||||||
select {
|
|
||||||
case err = <-ch:
|
|
||||||
if err != nil {
|
|
||||||
p.Close()
|
|
||||||
p = nil
|
|
||||||
}
|
|
||||||
case <-l.closeCh:
|
|
||||||
// Abort the connect request by closing the handle.
|
|
||||||
p.Close()
|
|
||||||
p = nil
|
|
||||||
err = <-ch
|
|
||||||
if err == nil || err == ErrFileClosed {
|
|
||||||
err = ErrPipeListenerClosed
|
|
||||||
}
|
|
||||||
closed = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
responseCh <- acceptResponse{p, err}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
syscall.Close(l.firstHandle)
|
|
||||||
l.firstHandle = 0
|
|
||||||
// Notify Close() and Accept() callers that the handle has been closed.
|
|
||||||
close(l.doneCh)
|
|
||||||
}
|
|
||||||
|
|
||||||
func ListenPipe(path, sddl string) (net.Listener, error) {
|
|
||||||
var (
|
|
||||||
sd []byte
|
|
||||||
err error
|
|
||||||
)
|
|
||||||
if sddl != "" {
|
|
||||||
sd, err = SddlToSecurityDescriptor(sddl)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
h, err := makeServerPipeHandle(path, sd, true)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
// Immediately open and then close a client handle so that the named pipe is
|
|
||||||
// created but not currently accepting connections.
|
|
||||||
h2, err := createFile(path, 0, 0, nil, syscall.OPEN_EXISTING, cSECURITY_SQOS_PRESENT|cSECURITY_ANONYMOUS, 0)
|
|
||||||
if err != nil {
|
|
||||||
syscall.Close(h)
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
syscall.Close(h2)
|
|
||||||
l := &win32PipeListener{
|
|
||||||
firstHandle: h,
|
|
||||||
path: path,
|
|
||||||
securityDescriptor: sd,
|
|
||||||
acceptCh: make(chan (chan acceptResponse)),
|
|
||||||
closeCh: make(chan int),
|
|
||||||
doneCh: make(chan int),
|
|
||||||
}
|
|
||||||
go l.listenerRoutine()
|
|
||||||
return l, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func connectPipe(p *win32Pipe) error {
|
|
||||||
c, err := p.prepareIo()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
err = connectNamedPipe(p.handle, &c.o)
|
|
||||||
_, err = p.asyncIo(c, time.Time{}, 0, err)
|
|
||||||
if err != nil && err != cERROR_PIPE_CONNECTED {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l *win32PipeListener) Accept() (net.Conn, error) {
|
|
||||||
ch := make(chan acceptResponse)
|
|
||||||
select {
|
|
||||||
case l.acceptCh <- ch:
|
|
||||||
response := <-ch
|
|
||||||
return response.p, response.err
|
|
||||||
case <-l.doneCh:
|
|
||||||
return nil, ErrPipeListenerClosed
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l *win32PipeListener) Close() error {
|
|
||||||
select {
|
|
||||||
case l.closeCh <- 1:
|
|
||||||
<-l.doneCh
|
|
||||||
case <-l.doneCh:
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l *win32PipeListener) Addr() net.Addr {
|
|
||||||
return pipeAddress(l.path)
|
|
||||||
}
|
|
150
integration/vendor/github.com/Microsoft/go-winio/privilege.go
generated
vendored
150
integration/vendor/github.com/Microsoft/go-winio/privilege.go
generated
vendored
|
@ -1,150 +0,0 @@
|
||||||
package winio
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"encoding/binary"
|
|
||||||
"fmt"
|
|
||||||
"runtime"
|
|
||||||
"syscall"
|
|
||||||
"unicode/utf16"
|
|
||||||
)
|
|
||||||
|
|
||||||
//sys adjustTokenPrivileges(token syscall.Handle, releaseAll bool, input *byte, outputSize uint32, output *byte, requiredSize *uint32) (success bool, err error) [true] = advapi32.AdjustTokenPrivileges
|
|
||||||
//sys impersonateSelf(level uint32) (err error) = advapi32.ImpersonateSelf
|
|
||||||
//sys revertToSelf() (err error) = advapi32.RevertToSelf
|
|
||||||
//sys openThreadToken(thread syscall.Handle, accessMask uint32, openAsSelf bool, token *syscall.Handle) (err error) = advapi32.OpenThreadToken
|
|
||||||
//sys getCurrentThread() (h syscall.Handle) = GetCurrentThread
|
|
||||||
//sys lookupPrivilegeValue(systemName string, name string, luid *uint64) (err error) = advapi32.LookupPrivilegeValueW
|
|
||||||
//sys lookupPrivilegeName(systemName string, luid *uint64, buffer *uint16, size *uint32) (err error) = advapi32.LookupPrivilegeNameW
|
|
||||||
//sys lookupPrivilegeDisplayName(systemName string, name *uint16, buffer *uint16, size *uint32, languageId *uint32) (err error) = advapi32.LookupPrivilegeDisplayNameW
|
|
||||||
|
|
||||||
const (
|
|
||||||
SE_PRIVILEGE_ENABLED = 2
|
|
||||||
|
|
||||||
ERROR_NOT_ALL_ASSIGNED syscall.Errno = 1300
|
|
||||||
|
|
||||||
SeBackupPrivilege = "SeBackupPrivilege"
|
|
||||||
SeRestorePrivilege = "SeRestorePrivilege"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
securityAnonymous = iota
|
|
||||||
securityIdentification
|
|
||||||
securityImpersonation
|
|
||||||
securityDelegation
|
|
||||||
)
|
|
||||||
|
|
||||||
type PrivilegeError struct {
|
|
||||||
privileges []uint64
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *PrivilegeError) Error() string {
|
|
||||||
s := ""
|
|
||||||
if len(e.privileges) > 1 {
|
|
||||||
s = "Could not enable privileges "
|
|
||||||
} else {
|
|
||||||
s = "Could not enable privilege "
|
|
||||||
}
|
|
||||||
for i, p := range e.privileges {
|
|
||||||
if i != 0 {
|
|
||||||
s += ", "
|
|
||||||
}
|
|
||||||
s += `"`
|
|
||||||
s += getPrivilegeName(p)
|
|
||||||
s += `"`
|
|
||||||
}
|
|
||||||
return s
|
|
||||||
}
|
|
||||||
|
|
||||||
func RunWithPrivilege(name string, fn func() error) error {
|
|
||||||
return RunWithPrivileges([]string{name}, fn)
|
|
||||||
}
|
|
||||||
|
|
||||||
func RunWithPrivileges(names []string, fn func() error) error {
|
|
||||||
var privileges []uint64
|
|
||||||
for _, name := range names {
|
|
||||||
p := uint64(0)
|
|
||||||
err := lookupPrivilegeValue("", name, &p)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
privileges = append(privileges, p)
|
|
||||||
}
|
|
||||||
runtime.LockOSThread()
|
|
||||||
defer runtime.UnlockOSThread()
|
|
||||||
token, err := newThreadToken()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
defer releaseThreadToken(token)
|
|
||||||
err = adjustPrivileges(token, privileges)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return fn()
|
|
||||||
}
|
|
||||||
|
|
||||||
func adjustPrivileges(token syscall.Handle, privileges []uint64) error {
|
|
||||||
var b bytes.Buffer
|
|
||||||
binary.Write(&b, binary.LittleEndian, uint32(len(privileges)))
|
|
||||||
for _, p := range privileges {
|
|
||||||
binary.Write(&b, binary.LittleEndian, p)
|
|
||||||
binary.Write(&b, binary.LittleEndian, uint32(SE_PRIVILEGE_ENABLED))
|
|
||||||
}
|
|
||||||
prevState := make([]byte, b.Len())
|
|
||||||
reqSize := uint32(0)
|
|
||||||
success, err := adjustTokenPrivileges(token, false, &b.Bytes()[0], uint32(len(prevState)), &prevState[0], &reqSize)
|
|
||||||
if !success {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if err == ERROR_NOT_ALL_ASSIGNED {
|
|
||||||
return &PrivilegeError{privileges}
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func getPrivilegeName(luid uint64) string {
|
|
||||||
var nameBuffer [256]uint16
|
|
||||||
bufSize := uint32(len(nameBuffer))
|
|
||||||
err := lookupPrivilegeName("", &luid, &nameBuffer[0], &bufSize)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Sprintf("<unknown privilege %d>", luid)
|
|
||||||
}
|
|
||||||
|
|
||||||
var displayNameBuffer [256]uint16
|
|
||||||
displayBufSize := uint32(len(displayNameBuffer))
|
|
||||||
var langId uint32
|
|
||||||
err = lookupPrivilegeDisplayName("", &nameBuffer[0], &displayNameBuffer[0], &displayBufSize, &langId)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Sprintf("<unknown privilege %s>", utf16.Decode(nameBuffer[:bufSize]))
|
|
||||||
}
|
|
||||||
|
|
||||||
return string(utf16.Decode(displayNameBuffer[:displayBufSize]))
|
|
||||||
}
|
|
||||||
|
|
||||||
func newThreadToken() (syscall.Handle, error) {
|
|
||||||
err := impersonateSelf(securityImpersonation)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
|
|
||||||
var token syscall.Handle
|
|
||||||
err = openThreadToken(getCurrentThread(), syscall.TOKEN_ADJUST_PRIVILEGES|syscall.TOKEN_QUERY, false, &token)
|
|
||||||
if err != nil {
|
|
||||||
rerr := revertToSelf()
|
|
||||||
if rerr != nil {
|
|
||||||
panic(rerr)
|
|
||||||
}
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return token, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func releaseThreadToken(h syscall.Handle) {
|
|
||||||
err := revertToSelf()
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
syscall.Close(h)
|
|
||||||
}
|
|
124
integration/vendor/github.com/Microsoft/go-winio/reparse.go
generated
vendored
124
integration/vendor/github.com/Microsoft/go-winio/reparse.go
generated
vendored
|
@ -1,124 +0,0 @@
|
||||||
package winio
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"encoding/binary"
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
"unicode/utf16"
|
|
||||||
"unsafe"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
reparseTagMountPoint = 0xA0000003
|
|
||||||
reparseTagSymlink = 0xA000000C
|
|
||||||
)
|
|
||||||
|
|
||||||
type reparseDataBuffer struct {
|
|
||||||
ReparseTag uint32
|
|
||||||
ReparseDataLength uint16
|
|
||||||
Reserved uint16
|
|
||||||
SubstituteNameOffset uint16
|
|
||||||
SubstituteNameLength uint16
|
|
||||||
PrintNameOffset uint16
|
|
||||||
PrintNameLength uint16
|
|
||||||
}
|
|
||||||
|
|
||||||
// ReparsePoint describes a Win32 symlink or mount point.
|
|
||||||
type ReparsePoint struct {
|
|
||||||
Target string
|
|
||||||
IsMountPoint bool
|
|
||||||
}
|
|
||||||
|
|
||||||
// UnsupportedReparsePointError is returned when trying to decode a non-symlink or
|
|
||||||
// mount point reparse point.
|
|
||||||
type UnsupportedReparsePointError struct {
|
|
||||||
Tag uint32
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *UnsupportedReparsePointError) Error() string {
|
|
||||||
return fmt.Sprintf("unsupported reparse point %x", e.Tag)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DecodeReparsePoint decodes a Win32 REPARSE_DATA_BUFFER structure containing either a symlink
|
|
||||||
// or a mount point.
|
|
||||||
func DecodeReparsePoint(b []byte) (*ReparsePoint, error) {
|
|
||||||
isMountPoint := false
|
|
||||||
tag := binary.LittleEndian.Uint32(b[0:4])
|
|
||||||
switch tag {
|
|
||||||
case reparseTagMountPoint:
|
|
||||||
isMountPoint = true
|
|
||||||
case reparseTagSymlink:
|
|
||||||
default:
|
|
||||||
return nil, &UnsupportedReparsePointError{tag}
|
|
||||||
}
|
|
||||||
nameOffset := 16 + binary.LittleEndian.Uint16(b[12:14])
|
|
||||||
if !isMountPoint {
|
|
||||||
nameOffset += 4
|
|
||||||
}
|
|
||||||
nameLength := binary.LittleEndian.Uint16(b[14:16])
|
|
||||||
name := make([]uint16, nameLength/2)
|
|
||||||
err := binary.Read(bytes.NewReader(b[nameOffset:nameOffset+nameLength]), binary.LittleEndian, &name)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return &ReparsePoint{string(utf16.Decode(name)), isMountPoint}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func isDriveLetter(c byte) bool {
|
|
||||||
return (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')
|
|
||||||
}
|
|
||||||
|
|
||||||
// EncodeReparsePoint encodes a Win32 REPARSE_DATA_BUFFER structure describing a symlink or
|
|
||||||
// mount point.
|
|
||||||
func EncodeReparsePoint(rp *ReparsePoint) []byte {
|
|
||||||
// Generate an NT path and determine if this is a relative path.
|
|
||||||
var ntTarget string
|
|
||||||
relative := false
|
|
||||||
if strings.HasPrefix(rp.Target, `\\?\`) {
|
|
||||||
ntTarget = rp.Target
|
|
||||||
} else if strings.HasPrefix(rp.Target, `\\`) {
|
|
||||||
ntTarget = `\??\UNC\` + rp.Target[2:]
|
|
||||||
} else if len(rp.Target) >= 2 && isDriveLetter(rp.Target[0]) && rp.Target[1] == ':' {
|
|
||||||
ntTarget = `\??\` + rp.Target
|
|
||||||
} else {
|
|
||||||
ntTarget = rp.Target
|
|
||||||
relative = true
|
|
||||||
}
|
|
||||||
|
|
||||||
// The paths must be NUL-terminated even though they are counted strings.
|
|
||||||
target16 := utf16.Encode([]rune(rp.Target + "\x00"))
|
|
||||||
ntTarget16 := utf16.Encode([]rune(ntTarget + "\x00"))
|
|
||||||
|
|
||||||
size := int(unsafe.Sizeof(reparseDataBuffer{})) - 8
|
|
||||||
size += len(ntTarget16)*2 + len(target16)*2
|
|
||||||
|
|
||||||
tag := uint32(reparseTagMountPoint)
|
|
||||||
if !rp.IsMountPoint {
|
|
||||||
tag = reparseTagSymlink
|
|
||||||
size += 4 // Add room for symlink flags
|
|
||||||
}
|
|
||||||
|
|
||||||
data := reparseDataBuffer{
|
|
||||||
ReparseTag: tag,
|
|
||||||
ReparseDataLength: uint16(size),
|
|
||||||
SubstituteNameOffset: 0,
|
|
||||||
SubstituteNameLength: uint16((len(ntTarget16) - 1) * 2),
|
|
||||||
PrintNameOffset: uint16(len(ntTarget16) * 2),
|
|
||||||
PrintNameLength: uint16((len(target16) - 1) * 2),
|
|
||||||
}
|
|
||||||
|
|
||||||
var b bytes.Buffer
|
|
||||||
binary.Write(&b, binary.LittleEndian, &data)
|
|
||||||
if !rp.IsMountPoint {
|
|
||||||
flags := uint32(0)
|
|
||||||
if relative {
|
|
||||||
flags |= 1
|
|
||||||
}
|
|
||||||
binary.Write(&b, binary.LittleEndian, flags)
|
|
||||||
}
|
|
||||||
|
|
||||||
binary.Write(&b, binary.LittleEndian, ntTarget16)
|
|
||||||
binary.Write(&b, binary.LittleEndian, target16)
|
|
||||||
return b.Bytes()
|
|
||||||
}
|
|
96
integration/vendor/github.com/Microsoft/go-winio/sd.go
generated
vendored
96
integration/vendor/github.com/Microsoft/go-winio/sd.go
generated
vendored
|
@ -1,96 +0,0 @@
|
||||||
package winio
|
|
||||||
|
|
||||||
import (
|
|
||||||
"syscall"
|
|
||||||
"unsafe"
|
|
||||||
)
|
|
||||||
|
|
||||||
//sys lookupAccountName(systemName *uint16, accountName string, sid *byte, sidSize *uint32, refDomain *uint16, refDomainSize *uint32, sidNameUse *uint32) (err error) = advapi32.LookupAccountNameW
|
|
||||||
//sys convertSidToStringSid(sid *byte, str **uint16) (err error) = advapi32.ConvertSidToStringSidW
|
|
||||||
//sys convertStringSecurityDescriptorToSecurityDescriptor(str string, revision uint32, sd *uintptr, size *uint32) (err error) = advapi32.ConvertStringSecurityDescriptorToSecurityDescriptorW
|
|
||||||
//sys convertSecurityDescriptorToStringSecurityDescriptor(sd *byte, revision uint32, secInfo uint32, sddl **uint16, sddlSize *uint32) (err error) = advapi32.ConvertSecurityDescriptorToStringSecurityDescriptorW
|
|
||||||
//sys localFree(mem uintptr) = LocalFree
|
|
||||||
//sys getSecurityDescriptorLength(sd uintptr) (len uint32) = advapi32.GetSecurityDescriptorLength
|
|
||||||
|
|
||||||
const (
|
|
||||||
cERROR_NONE_MAPPED = syscall.Errno(1332)
|
|
||||||
)
|
|
||||||
|
|
||||||
type AccountLookupError struct {
|
|
||||||
Name string
|
|
||||||
Err error
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *AccountLookupError) Error() string {
|
|
||||||
if e.Name == "" {
|
|
||||||
return "lookup account: empty account name specified"
|
|
||||||
}
|
|
||||||
var s string
|
|
||||||
switch e.Err {
|
|
||||||
case cERROR_NONE_MAPPED:
|
|
||||||
s = "not found"
|
|
||||||
default:
|
|
||||||
s = e.Err.Error()
|
|
||||||
}
|
|
||||||
return "lookup account " + e.Name + ": " + s
|
|
||||||
}
|
|
||||||
|
|
||||||
type SddlConversionError struct {
|
|
||||||
Sddl string
|
|
||||||
Err error
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *SddlConversionError) Error() string {
|
|
||||||
return "convert " + e.Sddl + ": " + e.Err.Error()
|
|
||||||
}
|
|
||||||
|
|
||||||
// LookupSidByName looks up the SID of an account by name
|
|
||||||
func LookupSidByName(name string) (sid string, err error) {
|
|
||||||
if name == "" {
|
|
||||||
return "", &AccountLookupError{name, cERROR_NONE_MAPPED}
|
|
||||||
}
|
|
||||||
|
|
||||||
var sidSize, sidNameUse, refDomainSize uint32
|
|
||||||
err = lookupAccountName(nil, name, nil, &sidSize, nil, &refDomainSize, &sidNameUse)
|
|
||||||
if err != nil && err != syscall.ERROR_INSUFFICIENT_BUFFER {
|
|
||||||
return "", &AccountLookupError{name, err}
|
|
||||||
}
|
|
||||||
sidBuffer := make([]byte, sidSize)
|
|
||||||
refDomainBuffer := make([]uint16, refDomainSize)
|
|
||||||
err = lookupAccountName(nil, name, &sidBuffer[0], &sidSize, &refDomainBuffer[0], &refDomainSize, &sidNameUse)
|
|
||||||
if err != nil {
|
|
||||||
return "", &AccountLookupError{name, err}
|
|
||||||
}
|
|
||||||
var strBuffer *uint16
|
|
||||||
err = convertSidToStringSid(&sidBuffer[0], &strBuffer)
|
|
||||||
if err != nil {
|
|
||||||
return "", &AccountLookupError{name, err}
|
|
||||||
}
|
|
||||||
sid = syscall.UTF16ToString((*[0xffff]uint16)(unsafe.Pointer(strBuffer))[:])
|
|
||||||
localFree(uintptr(unsafe.Pointer(strBuffer)))
|
|
||||||
return sid, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func SddlToSecurityDescriptor(sddl string) ([]byte, error) {
|
|
||||||
var sdBuffer uintptr
|
|
||||||
err := convertStringSecurityDescriptorToSecurityDescriptor(sddl, 1, &sdBuffer, nil)
|
|
||||||
if err != nil {
|
|
||||||
return nil, &SddlConversionError{sddl, err}
|
|
||||||
}
|
|
||||||
defer localFree(sdBuffer)
|
|
||||||
sd := make([]byte, getSecurityDescriptorLength(sdBuffer))
|
|
||||||
copy(sd, (*[0xffff]byte)(unsafe.Pointer(sdBuffer))[:len(sd)])
|
|
||||||
return sd, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func SecurityDescriptorToSddl(sd []byte) (string, error) {
|
|
||||||
var sddl *uint16
|
|
||||||
// The returned string length seems to including an aribtrary number of terminating NULs.
|
|
||||||
// Don't use it.
|
|
||||||
err := convertSecurityDescriptorToStringSecurityDescriptor(&sd[0], 1, 0xff, &sddl, nil)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
defer localFree(uintptr(unsafe.Pointer(sddl)))
|
|
||||||
return syscall.UTF16ToString((*[0xffff]uint16)(unsafe.Pointer(sddl))[:]), nil
|
|
||||||
}
|
|
3
integration/vendor/github.com/Microsoft/go-winio/syscall.go
generated
vendored
3
integration/vendor/github.com/Microsoft/go-winio/syscall.go
generated
vendored
|
@ -1,3 +0,0 @@
|
||||||
package winio
|
|
||||||
|
|
||||||
//go:generate go run $GOROOT/src/syscall/mksyscall_windows.go -output zsyscall.go file.go pipe.go sd.go fileinfo.go privilege.go backup.go
|
|
458
integration/vendor/github.com/Microsoft/go-winio/zsyscall.go
generated
vendored
458
integration/vendor/github.com/Microsoft/go-winio/zsyscall.go
generated
vendored
|
@ -1,458 +0,0 @@
|
||||||
// MACHINE GENERATED BY 'go generate' COMMAND; DO NOT EDIT
|
|
||||||
|
|
||||||
package winio
|
|
||||||
|
|
||||||
import "unsafe"
|
|
||||||
import "syscall"
|
|
||||||
|
|
||||||
var _ unsafe.Pointer
|
|
||||||
|
|
||||||
var (
|
|
||||||
modkernel32 = syscall.NewLazyDLL("kernel32.dll")
|
|
||||||
modadvapi32 = syscall.NewLazyDLL("advapi32.dll")
|
|
||||||
|
|
||||||
procCancelIoEx = modkernel32.NewProc("CancelIoEx")
|
|
||||||
procCreateIoCompletionPort = modkernel32.NewProc("CreateIoCompletionPort")
|
|
||||||
procGetQueuedCompletionStatus = modkernel32.NewProc("GetQueuedCompletionStatus")
|
|
||||||
procSetFileCompletionNotificationModes = modkernel32.NewProc("SetFileCompletionNotificationModes")
|
|
||||||
procConnectNamedPipe = modkernel32.NewProc("ConnectNamedPipe")
|
|
||||||
procCreateNamedPipeW = modkernel32.NewProc("CreateNamedPipeW")
|
|
||||||
procCreateFileW = modkernel32.NewProc("CreateFileW")
|
|
||||||
procWaitNamedPipeW = modkernel32.NewProc("WaitNamedPipeW")
|
|
||||||
procLookupAccountNameW = modadvapi32.NewProc("LookupAccountNameW")
|
|
||||||
procConvertSidToStringSidW = modadvapi32.NewProc("ConvertSidToStringSidW")
|
|
||||||
procConvertStringSecurityDescriptorToSecurityDescriptorW = modadvapi32.NewProc("ConvertStringSecurityDescriptorToSecurityDescriptorW")
|
|
||||||
procConvertSecurityDescriptorToStringSecurityDescriptorW = modadvapi32.NewProc("ConvertSecurityDescriptorToStringSecurityDescriptorW")
|
|
||||||
procLocalFree = modkernel32.NewProc("LocalFree")
|
|
||||||
procGetSecurityDescriptorLength = modadvapi32.NewProc("GetSecurityDescriptorLength")
|
|
||||||
procGetFileInformationByHandleEx = modkernel32.NewProc("GetFileInformationByHandleEx")
|
|
||||||
procSetFileInformationByHandle = modkernel32.NewProc("SetFileInformationByHandle")
|
|
||||||
procAdjustTokenPrivileges = modadvapi32.NewProc("AdjustTokenPrivileges")
|
|
||||||
procImpersonateSelf = modadvapi32.NewProc("ImpersonateSelf")
|
|
||||||
procRevertToSelf = modadvapi32.NewProc("RevertToSelf")
|
|
||||||
procOpenThreadToken = modadvapi32.NewProc("OpenThreadToken")
|
|
||||||
procGetCurrentThread = modkernel32.NewProc("GetCurrentThread")
|
|
||||||
procLookupPrivilegeValueW = modadvapi32.NewProc("LookupPrivilegeValueW")
|
|
||||||
procLookupPrivilegeNameW = modadvapi32.NewProc("LookupPrivilegeNameW")
|
|
||||||
procLookupPrivilegeDisplayNameW = modadvapi32.NewProc("LookupPrivilegeDisplayNameW")
|
|
||||||
procBackupRead = modkernel32.NewProc("BackupRead")
|
|
||||||
procBackupWrite = modkernel32.NewProc("BackupWrite")
|
|
||||||
)
|
|
||||||
|
|
||||||
func cancelIoEx(file syscall.Handle, o *syscall.Overlapped) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall(procCancelIoEx.Addr(), 2, uintptr(file), uintptr(unsafe.Pointer(o)), 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func createIoCompletionPort(file syscall.Handle, port syscall.Handle, key uintptr, threadCount uint32) (newport syscall.Handle, err error) {
|
|
||||||
r0, _, e1 := syscall.Syscall6(procCreateIoCompletionPort.Addr(), 4, uintptr(file), uintptr(port), uintptr(key), uintptr(threadCount), 0, 0)
|
|
||||||
newport = syscall.Handle(r0)
|
|
||||||
if newport == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func getQueuedCompletionStatus(port syscall.Handle, bytes *uint32, key *uintptr, o **ioOperation, timeout uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall6(procGetQueuedCompletionStatus.Addr(), 5, uintptr(port), uintptr(unsafe.Pointer(bytes)), uintptr(unsafe.Pointer(key)), uintptr(unsafe.Pointer(o)), uintptr(timeout), 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func setFileCompletionNotificationModes(h syscall.Handle, flags uint8) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall(procSetFileCompletionNotificationModes.Addr(), 2, uintptr(h), uintptr(flags), 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func connectNamedPipe(pipe syscall.Handle, o *syscall.Overlapped) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall(procConnectNamedPipe.Addr(), 2, uintptr(pipe), uintptr(unsafe.Pointer(o)), 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func createNamedPipe(name string, flags uint32, pipeMode uint32, maxInstances uint32, outSize uint32, inSize uint32, defaultTimeout uint32, sa *securityAttributes) (handle syscall.Handle, err error) {
|
|
||||||
var _p0 *uint16
|
|
||||||
_p0, err = syscall.UTF16PtrFromString(name)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return _createNamedPipe(_p0, flags, pipeMode, maxInstances, outSize, inSize, defaultTimeout, sa)
|
|
||||||
}
|
|
||||||
|
|
||||||
func _createNamedPipe(name *uint16, flags uint32, pipeMode uint32, maxInstances uint32, outSize uint32, inSize uint32, defaultTimeout uint32, sa *securityAttributes) (handle syscall.Handle, err error) {
|
|
||||||
r0, _, e1 := syscall.Syscall9(procCreateNamedPipeW.Addr(), 8, uintptr(unsafe.Pointer(name)), uintptr(flags), uintptr(pipeMode), uintptr(maxInstances), uintptr(outSize), uintptr(inSize), uintptr(defaultTimeout), uintptr(unsafe.Pointer(sa)), 0)
|
|
||||||
handle = syscall.Handle(r0)
|
|
||||||
if handle == syscall.InvalidHandle {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func createFile(name string, access uint32, mode uint32, sa *securityAttributes, createmode uint32, attrs uint32, templatefile syscall.Handle) (handle syscall.Handle, err error) {
|
|
||||||
var _p0 *uint16
|
|
||||||
_p0, err = syscall.UTF16PtrFromString(name)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return _createFile(_p0, access, mode, sa, createmode, attrs, templatefile)
|
|
||||||
}
|
|
||||||
|
|
||||||
func _createFile(name *uint16, access uint32, mode uint32, sa *securityAttributes, createmode uint32, attrs uint32, templatefile syscall.Handle) (handle syscall.Handle, err error) {
|
|
||||||
r0, _, e1 := syscall.Syscall9(procCreateFileW.Addr(), 7, uintptr(unsafe.Pointer(name)), uintptr(access), uintptr(mode), uintptr(unsafe.Pointer(sa)), uintptr(createmode), uintptr(attrs), uintptr(templatefile), 0, 0)
|
|
||||||
handle = syscall.Handle(r0)
|
|
||||||
if handle == syscall.InvalidHandle {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func waitNamedPipe(name string, timeout uint32) (err error) {
|
|
||||||
var _p0 *uint16
|
|
||||||
_p0, err = syscall.UTF16PtrFromString(name)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return _waitNamedPipe(_p0, timeout)
|
|
||||||
}
|
|
||||||
|
|
||||||
func _waitNamedPipe(name *uint16, timeout uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall(procWaitNamedPipeW.Addr(), 2, uintptr(unsafe.Pointer(name)), uintptr(timeout), 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func lookupAccountName(systemName *uint16, accountName string, sid *byte, sidSize *uint32, refDomain *uint16, refDomainSize *uint32, sidNameUse *uint32) (err error) {
|
|
||||||
var _p0 *uint16
|
|
||||||
_p0, err = syscall.UTF16PtrFromString(accountName)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return _lookupAccountName(systemName, _p0, sid, sidSize, refDomain, refDomainSize, sidNameUse)
|
|
||||||
}
|
|
||||||
|
|
||||||
func _lookupAccountName(systemName *uint16, accountName *uint16, sid *byte, sidSize *uint32, refDomain *uint16, refDomainSize *uint32, sidNameUse *uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall9(procLookupAccountNameW.Addr(), 7, uintptr(unsafe.Pointer(systemName)), uintptr(unsafe.Pointer(accountName)), uintptr(unsafe.Pointer(sid)), uintptr(unsafe.Pointer(sidSize)), uintptr(unsafe.Pointer(refDomain)), uintptr(unsafe.Pointer(refDomainSize)), uintptr(unsafe.Pointer(sidNameUse)), 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func convertSidToStringSid(sid *byte, str **uint16) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall(procConvertSidToStringSidW.Addr(), 2, uintptr(unsafe.Pointer(sid)), uintptr(unsafe.Pointer(str)), 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func convertStringSecurityDescriptorToSecurityDescriptor(str string, revision uint32, sd *uintptr, size *uint32) (err error) {
|
|
||||||
var _p0 *uint16
|
|
||||||
_p0, err = syscall.UTF16PtrFromString(str)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return _convertStringSecurityDescriptorToSecurityDescriptor(_p0, revision, sd, size)
|
|
||||||
}
|
|
||||||
|
|
||||||
func _convertStringSecurityDescriptorToSecurityDescriptor(str *uint16, revision uint32, sd *uintptr, size *uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall6(procConvertStringSecurityDescriptorToSecurityDescriptorW.Addr(), 4, uintptr(unsafe.Pointer(str)), uintptr(revision), uintptr(unsafe.Pointer(sd)), uintptr(unsafe.Pointer(size)), 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func convertSecurityDescriptorToStringSecurityDescriptor(sd *byte, revision uint32, secInfo uint32, sddl **uint16, sddlSize *uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall6(procConvertSecurityDescriptorToStringSecurityDescriptorW.Addr(), 5, uintptr(unsafe.Pointer(sd)), uintptr(revision), uintptr(secInfo), uintptr(unsafe.Pointer(sddl)), uintptr(unsafe.Pointer(sddlSize)), 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func localFree(mem uintptr) {
|
|
||||||
syscall.Syscall(procLocalFree.Addr(), 1, uintptr(mem), 0, 0)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func getSecurityDescriptorLength(sd uintptr) (len uint32) {
|
|
||||||
r0, _, _ := syscall.Syscall(procGetSecurityDescriptorLength.Addr(), 1, uintptr(sd), 0, 0)
|
|
||||||
len = uint32(r0)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func getFileInformationByHandleEx(h syscall.Handle, class uint32, buffer *byte, size uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall6(procGetFileInformationByHandleEx.Addr(), 4, uintptr(h), uintptr(class), uintptr(unsafe.Pointer(buffer)), uintptr(size), 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func setFileInformationByHandle(h syscall.Handle, class uint32, buffer *byte, size uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall6(procSetFileInformationByHandle.Addr(), 4, uintptr(h), uintptr(class), uintptr(unsafe.Pointer(buffer)), uintptr(size), 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func adjustTokenPrivileges(token syscall.Handle, releaseAll bool, input *byte, outputSize uint32, output *byte, requiredSize *uint32) (success bool, err error) {
|
|
||||||
var _p0 uint32
|
|
||||||
if releaseAll {
|
|
||||||
_p0 = 1
|
|
||||||
} else {
|
|
||||||
_p0 = 0
|
|
||||||
}
|
|
||||||
r0, _, e1 := syscall.Syscall6(procAdjustTokenPrivileges.Addr(), 6, uintptr(token), uintptr(_p0), uintptr(unsafe.Pointer(input)), uintptr(outputSize), uintptr(unsafe.Pointer(output)), uintptr(unsafe.Pointer(requiredSize)))
|
|
||||||
success = r0 != 0
|
|
||||||
if true {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func impersonateSelf(level uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall(procImpersonateSelf.Addr(), 1, uintptr(level), 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func revertToSelf() (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall(procRevertToSelf.Addr(), 0, 0, 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func openThreadToken(thread syscall.Handle, accessMask uint32, openAsSelf bool, token *syscall.Handle) (err error) {
|
|
||||||
var _p0 uint32
|
|
||||||
if openAsSelf {
|
|
||||||
_p0 = 1
|
|
||||||
} else {
|
|
||||||
_p0 = 0
|
|
||||||
}
|
|
||||||
r1, _, e1 := syscall.Syscall6(procOpenThreadToken.Addr(), 4, uintptr(thread), uintptr(accessMask), uintptr(_p0), uintptr(unsafe.Pointer(token)), 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func getCurrentThread() (h syscall.Handle) {
|
|
||||||
r0, _, _ := syscall.Syscall(procGetCurrentThread.Addr(), 0, 0, 0, 0)
|
|
||||||
h = syscall.Handle(r0)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func lookupPrivilegeValue(systemName string, name string, luid *uint64) (err error) {
|
|
||||||
var _p0 *uint16
|
|
||||||
_p0, err = syscall.UTF16PtrFromString(systemName)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
var _p1 *uint16
|
|
||||||
_p1, err = syscall.UTF16PtrFromString(name)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return _lookupPrivilegeValue(_p0, _p1, luid)
|
|
||||||
}
|
|
||||||
|
|
||||||
func _lookupPrivilegeValue(systemName *uint16, name *uint16, luid *uint64) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall(procLookupPrivilegeValueW.Addr(), 3, uintptr(unsafe.Pointer(systemName)), uintptr(unsafe.Pointer(name)), uintptr(unsafe.Pointer(luid)))
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func lookupPrivilegeName(systemName string, luid *uint64, buffer *uint16, size *uint32) (err error) {
|
|
||||||
var _p0 *uint16
|
|
||||||
_p0, err = syscall.UTF16PtrFromString(systemName)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return _lookupPrivilegeName(_p0, luid, buffer, size)
|
|
||||||
}
|
|
||||||
|
|
||||||
func _lookupPrivilegeName(systemName *uint16, luid *uint64, buffer *uint16, size *uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall6(procLookupPrivilegeNameW.Addr(), 4, uintptr(unsafe.Pointer(systemName)), uintptr(unsafe.Pointer(luid)), uintptr(unsafe.Pointer(buffer)), uintptr(unsafe.Pointer(size)), 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func lookupPrivilegeDisplayName(systemName string, name *uint16, buffer *uint16, size *uint32, languageId *uint32) (err error) {
|
|
||||||
var _p0 *uint16
|
|
||||||
_p0, err = syscall.UTF16PtrFromString(systemName)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return _lookupPrivilegeDisplayName(_p0, name, buffer, size, languageId)
|
|
||||||
}
|
|
||||||
|
|
||||||
func _lookupPrivilegeDisplayName(systemName *uint16, name *uint16, buffer *uint16, size *uint32, languageId *uint32) (err error) {
|
|
||||||
r1, _, e1 := syscall.Syscall6(procLookupPrivilegeDisplayNameW.Addr(), 5, uintptr(unsafe.Pointer(systemName)), uintptr(unsafe.Pointer(name)), uintptr(unsafe.Pointer(buffer)), uintptr(unsafe.Pointer(size)), uintptr(unsafe.Pointer(languageId)), 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func backupRead(h syscall.Handle, b []byte, bytesRead *uint32, abort bool, processSecurity bool, context *uintptr) (err error) {
|
|
||||||
var _p0 *byte
|
|
||||||
if len(b) > 0 {
|
|
||||||
_p0 = &b[0]
|
|
||||||
}
|
|
||||||
var _p1 uint32
|
|
||||||
if abort {
|
|
||||||
_p1 = 1
|
|
||||||
} else {
|
|
||||||
_p1 = 0
|
|
||||||
}
|
|
||||||
var _p2 uint32
|
|
||||||
if processSecurity {
|
|
||||||
_p2 = 1
|
|
||||||
} else {
|
|
||||||
_p2 = 0
|
|
||||||
}
|
|
||||||
r1, _, e1 := syscall.Syscall9(procBackupRead.Addr(), 7, uintptr(h), uintptr(unsafe.Pointer(_p0)), uintptr(len(b)), uintptr(unsafe.Pointer(bytesRead)), uintptr(_p1), uintptr(_p2), uintptr(unsafe.Pointer(context)), 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func backupWrite(h syscall.Handle, b []byte, bytesWritten *uint32, abort bool, processSecurity bool, context *uintptr) (err error) {
|
|
||||||
var _p0 *byte
|
|
||||||
if len(b) > 0 {
|
|
||||||
_p0 = &b[0]
|
|
||||||
}
|
|
||||||
var _p1 uint32
|
|
||||||
if abort {
|
|
||||||
_p1 = 1
|
|
||||||
} else {
|
|
||||||
_p1 = 0
|
|
||||||
}
|
|
||||||
var _p2 uint32
|
|
||||||
if processSecurity {
|
|
||||||
_p2 = 1
|
|
||||||
} else {
|
|
||||||
_p2 = 0
|
|
||||||
}
|
|
||||||
r1, _, e1 := syscall.Syscall9(procBackupWrite.Addr(), 7, uintptr(h), uintptr(unsafe.Pointer(_p0)), uintptr(len(b)), uintptr(unsafe.Pointer(bytesWritten)), uintptr(_p1), uintptr(_p2), uintptr(unsafe.Pointer(context)), 0, 0)
|
|
||||||
if r1 == 0 {
|
|
||||||
if e1 != 0 {
|
|
||||||
err = error(e1)
|
|
||||||
} else {
|
|
||||||
err = syscall.EINVAL
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
21
integration/vendor/github.com/Sirupsen/logrus/LICENSE
generated
vendored
21
integration/vendor/github.com/Sirupsen/logrus/LICENSE
generated
vendored
|
@ -1,21 +0,0 @@
|
||||||
The MIT License (MIT)
|
|
||||||
|
|
||||||
Copyright (c) 2014 Simon Eskildsen
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in
|
|
||||||
all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
252
integration/vendor/github.com/Sirupsen/logrus/entry.go
generated
vendored
252
integration/vendor/github.com/Sirupsen/logrus/entry.go
generated
vendored
|
@ -1,252 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"os"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
// An entry is the final or intermediate Logrus logging entry. It contains all
|
|
||||||
// the fields passed with WithField{,s}. It's finally logged when Debug, Info,
|
|
||||||
// Warn, Error, Fatal or Panic is called on it. These objects can be reused and
|
|
||||||
// passed around as much as you wish to avoid field duplication.
|
|
||||||
type Entry struct {
|
|
||||||
Logger *Logger
|
|
||||||
|
|
||||||
// Contains all the fields set by the user.
|
|
||||||
Data Fields
|
|
||||||
|
|
||||||
// Time at which the log entry was created
|
|
||||||
Time time.Time
|
|
||||||
|
|
||||||
// Level the log entry was logged at: Debug, Info, Warn, Error, Fatal or Panic
|
|
||||||
Level Level
|
|
||||||
|
|
||||||
// Message passed to Debug, Info, Warn, Error, Fatal or Panic
|
|
||||||
Message string
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewEntry(logger *Logger) *Entry {
|
|
||||||
return &Entry{
|
|
||||||
Logger: logger,
|
|
||||||
// Default is three fields, give a little extra room
|
|
||||||
Data: make(Fields, 5),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns a reader for the entry, which is a proxy to the formatter.
|
|
||||||
func (entry *Entry) Reader() (*bytes.Buffer, error) {
|
|
||||||
serialized, err := entry.Logger.Formatter.Format(entry)
|
|
||||||
return bytes.NewBuffer(serialized), err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns the string representation from the reader and ultimately the
|
|
||||||
// formatter.
|
|
||||||
func (entry *Entry) String() (string, error) {
|
|
||||||
reader, err := entry.Reader()
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
return reader.String(), err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add a single field to the Entry.
|
|
||||||
func (entry *Entry) WithField(key string, value interface{}) *Entry {
|
|
||||||
return entry.WithFields(Fields{key: value})
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add a map of fields to the Entry.
|
|
||||||
func (entry *Entry) WithFields(fields Fields) *Entry {
|
|
||||||
data := Fields{}
|
|
||||||
for k, v := range entry.Data {
|
|
||||||
data[k] = v
|
|
||||||
}
|
|
||||||
for k, v := range fields {
|
|
||||||
data[k] = v
|
|
||||||
}
|
|
||||||
return &Entry{Logger: entry.Logger, Data: data}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) log(level Level, msg string) {
|
|
||||||
entry.Time = time.Now()
|
|
||||||
entry.Level = level
|
|
||||||
entry.Message = msg
|
|
||||||
|
|
||||||
if err := entry.Logger.Hooks.Fire(level, entry); err != nil {
|
|
||||||
entry.Logger.mu.Lock()
|
|
||||||
fmt.Fprintf(os.Stderr, "Failed to fire hook: %v\n", err)
|
|
||||||
entry.Logger.mu.Unlock()
|
|
||||||
}
|
|
||||||
|
|
||||||
reader, err := entry.Reader()
|
|
||||||
if err != nil {
|
|
||||||
entry.Logger.mu.Lock()
|
|
||||||
fmt.Fprintf(os.Stderr, "Failed to obtain reader, %v\n", err)
|
|
||||||
entry.Logger.mu.Unlock()
|
|
||||||
}
|
|
||||||
|
|
||||||
entry.Logger.mu.Lock()
|
|
||||||
defer entry.Logger.mu.Unlock()
|
|
||||||
|
|
||||||
_, err = io.Copy(entry.Logger.Out, reader)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Fprintf(os.Stderr, "Failed to write to log, %v\n", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// To avoid Entry#log() returning a value that only would make sense for
|
|
||||||
// panic() to use in Entry#Panic(), we avoid the allocation by checking
|
|
||||||
// directly here.
|
|
||||||
if level <= PanicLevel {
|
|
||||||
panic(entry)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Debug(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= DebugLevel {
|
|
||||||
entry.log(DebugLevel, fmt.Sprint(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Print(args ...interface{}) {
|
|
||||||
entry.Info(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Info(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= InfoLevel {
|
|
||||||
entry.log(InfoLevel, fmt.Sprint(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Warn(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= WarnLevel {
|
|
||||||
entry.log(WarnLevel, fmt.Sprint(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Warning(args ...interface{}) {
|
|
||||||
entry.Warn(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Error(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= ErrorLevel {
|
|
||||||
entry.log(ErrorLevel, fmt.Sprint(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Fatal(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= FatalLevel {
|
|
||||||
entry.log(FatalLevel, fmt.Sprint(args...))
|
|
||||||
}
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Panic(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= PanicLevel {
|
|
||||||
entry.log(PanicLevel, fmt.Sprint(args...))
|
|
||||||
}
|
|
||||||
panic(fmt.Sprint(args...))
|
|
||||||
}
|
|
||||||
|
|
||||||
// Entry Printf family functions
|
|
||||||
|
|
||||||
func (entry *Entry) Debugf(format string, args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= DebugLevel {
|
|
||||||
entry.Debug(fmt.Sprintf(format, args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Infof(format string, args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= InfoLevel {
|
|
||||||
entry.Info(fmt.Sprintf(format, args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Printf(format string, args ...interface{}) {
|
|
||||||
entry.Infof(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Warnf(format string, args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= WarnLevel {
|
|
||||||
entry.Warn(fmt.Sprintf(format, args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Warningf(format string, args ...interface{}) {
|
|
||||||
entry.Warnf(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Errorf(format string, args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= ErrorLevel {
|
|
||||||
entry.Error(fmt.Sprintf(format, args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Fatalf(format string, args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= FatalLevel {
|
|
||||||
entry.Fatal(fmt.Sprintf(format, args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Panicf(format string, args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= PanicLevel {
|
|
||||||
entry.Panic(fmt.Sprintf(format, args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Entry Println family functions
|
|
||||||
|
|
||||||
func (entry *Entry) Debugln(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= DebugLevel {
|
|
||||||
entry.Debug(entry.sprintlnn(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Infoln(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= InfoLevel {
|
|
||||||
entry.Info(entry.sprintlnn(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Println(args ...interface{}) {
|
|
||||||
entry.Infoln(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Warnln(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= WarnLevel {
|
|
||||||
entry.Warn(entry.sprintlnn(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Warningln(args ...interface{}) {
|
|
||||||
entry.Warnln(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Errorln(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= ErrorLevel {
|
|
||||||
entry.Error(entry.sprintlnn(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Fatalln(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= FatalLevel {
|
|
||||||
entry.Fatal(entry.sprintlnn(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (entry *Entry) Panicln(args ...interface{}) {
|
|
||||||
if entry.Logger.Level >= PanicLevel {
|
|
||||||
entry.Panic(entry.sprintlnn(args...))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Sprintlnn => Sprint no newline. This is to get the behavior of how
|
|
||||||
// fmt.Sprintln where spaces are always added between operands, regardless of
|
|
||||||
// their type. Instead of vendoring the Sprintln implementation to spare a
|
|
||||||
// string allocation, we do the simplest thing.
|
|
||||||
func (entry *Entry) sprintlnn(args ...interface{}) string {
|
|
||||||
msg := fmt.Sprintln(args...)
|
|
||||||
return msg[:len(msg)-1]
|
|
||||||
}
|
|
188
integration/vendor/github.com/Sirupsen/logrus/exported.go
generated
vendored
188
integration/vendor/github.com/Sirupsen/logrus/exported.go
generated
vendored
|
@ -1,188 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// std is the name of the standard logger in stdlib `log`
|
|
||||||
std = New()
|
|
||||||
)
|
|
||||||
|
|
||||||
func StandardLogger() *Logger {
|
|
||||||
return std
|
|
||||||
}
|
|
||||||
|
|
||||||
// SetOutput sets the standard logger output.
|
|
||||||
func SetOutput(out io.Writer) {
|
|
||||||
std.mu.Lock()
|
|
||||||
defer std.mu.Unlock()
|
|
||||||
std.Out = out
|
|
||||||
}
|
|
||||||
|
|
||||||
// SetFormatter sets the standard logger formatter.
|
|
||||||
func SetFormatter(formatter Formatter) {
|
|
||||||
std.mu.Lock()
|
|
||||||
defer std.mu.Unlock()
|
|
||||||
std.Formatter = formatter
|
|
||||||
}
|
|
||||||
|
|
||||||
// SetLevel sets the standard logger level.
|
|
||||||
func SetLevel(level Level) {
|
|
||||||
std.mu.Lock()
|
|
||||||
defer std.mu.Unlock()
|
|
||||||
std.Level = level
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetLevel returns the standard logger level.
|
|
||||||
func GetLevel() Level {
|
|
||||||
std.mu.Lock()
|
|
||||||
defer std.mu.Unlock()
|
|
||||||
return std.Level
|
|
||||||
}
|
|
||||||
|
|
||||||
// AddHook adds a hook to the standard logger hooks.
|
|
||||||
func AddHook(hook Hook) {
|
|
||||||
std.mu.Lock()
|
|
||||||
defer std.mu.Unlock()
|
|
||||||
std.Hooks.Add(hook)
|
|
||||||
}
|
|
||||||
|
|
||||||
// WithField creates an entry from the standard logger and adds a field to
|
|
||||||
// it. If you want multiple fields, use `WithFields`.
|
|
||||||
//
|
|
||||||
// Note that it doesn't log until you call Debug, Print, Info, Warn, Fatal
|
|
||||||
// or Panic on the Entry it returns.
|
|
||||||
func WithField(key string, value interface{}) *Entry {
|
|
||||||
return std.WithField(key, value)
|
|
||||||
}
|
|
||||||
|
|
||||||
// WithFields creates an entry from the standard logger and adds multiple
|
|
||||||
// fields to it. This is simply a helper for `WithField`, invoking it
|
|
||||||
// once for each field.
|
|
||||||
//
|
|
||||||
// Note that it doesn't log until you call Debug, Print, Info, Warn, Fatal
|
|
||||||
// or Panic on the Entry it returns.
|
|
||||||
func WithFields(fields Fields) *Entry {
|
|
||||||
return std.WithFields(fields)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Debug logs a message at level Debug on the standard logger.
|
|
||||||
func Debug(args ...interface{}) {
|
|
||||||
std.Debug(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Print logs a message at level Info on the standard logger.
|
|
||||||
func Print(args ...interface{}) {
|
|
||||||
std.Print(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Info logs a message at level Info on the standard logger.
|
|
||||||
func Info(args ...interface{}) {
|
|
||||||
std.Info(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Warn logs a message at level Warn on the standard logger.
|
|
||||||
func Warn(args ...interface{}) {
|
|
||||||
std.Warn(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Warning logs a message at level Warn on the standard logger.
|
|
||||||
func Warning(args ...interface{}) {
|
|
||||||
std.Warning(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Error logs a message at level Error on the standard logger.
|
|
||||||
func Error(args ...interface{}) {
|
|
||||||
std.Error(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Panic logs a message at level Panic on the standard logger.
|
|
||||||
func Panic(args ...interface{}) {
|
|
||||||
std.Panic(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fatal logs a message at level Fatal on the standard logger.
|
|
||||||
func Fatal(args ...interface{}) {
|
|
||||||
std.Fatal(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Debugf logs a message at level Debug on the standard logger.
|
|
||||||
func Debugf(format string, args ...interface{}) {
|
|
||||||
std.Debugf(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Printf logs a message at level Info on the standard logger.
|
|
||||||
func Printf(format string, args ...interface{}) {
|
|
||||||
std.Printf(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Infof logs a message at level Info on the standard logger.
|
|
||||||
func Infof(format string, args ...interface{}) {
|
|
||||||
std.Infof(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Warnf logs a message at level Warn on the standard logger.
|
|
||||||
func Warnf(format string, args ...interface{}) {
|
|
||||||
std.Warnf(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Warningf logs a message at level Warn on the standard logger.
|
|
||||||
func Warningf(format string, args ...interface{}) {
|
|
||||||
std.Warningf(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Errorf logs a message at level Error on the standard logger.
|
|
||||||
func Errorf(format string, args ...interface{}) {
|
|
||||||
std.Errorf(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Panicf logs a message at level Panic on the standard logger.
|
|
||||||
func Panicf(format string, args ...interface{}) {
|
|
||||||
std.Panicf(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fatalf logs a message at level Fatal on the standard logger.
|
|
||||||
func Fatalf(format string, args ...interface{}) {
|
|
||||||
std.Fatalf(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Debugln logs a message at level Debug on the standard logger.
|
|
||||||
func Debugln(args ...interface{}) {
|
|
||||||
std.Debugln(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Println logs a message at level Info on the standard logger.
|
|
||||||
func Println(args ...interface{}) {
|
|
||||||
std.Println(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Infoln logs a message at level Info on the standard logger.
|
|
||||||
func Infoln(args ...interface{}) {
|
|
||||||
std.Infoln(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Warnln logs a message at level Warn on the standard logger.
|
|
||||||
func Warnln(args ...interface{}) {
|
|
||||||
std.Warnln(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Warningln logs a message at level Warn on the standard logger.
|
|
||||||
func Warningln(args ...interface{}) {
|
|
||||||
std.Warningln(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Errorln logs a message at level Error on the standard logger.
|
|
||||||
func Errorln(args ...interface{}) {
|
|
||||||
std.Errorln(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Panicln logs a message at level Panic on the standard logger.
|
|
||||||
func Panicln(args ...interface{}) {
|
|
||||||
std.Panicln(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fatalln logs a message at level Fatal on the standard logger.
|
|
||||||
func Fatalln(args ...interface{}) {
|
|
||||||
std.Fatalln(args...)
|
|
||||||
}
|
|
48
integration/vendor/github.com/Sirupsen/logrus/formatter.go
generated
vendored
48
integration/vendor/github.com/Sirupsen/logrus/formatter.go
generated
vendored
|
@ -1,48 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
import "time"
|
|
||||||
|
|
||||||
const DefaultTimestampFormat = time.RFC3339
|
|
||||||
|
|
||||||
// The Formatter interface is used to implement a custom Formatter. It takes an
|
|
||||||
// `Entry`. It exposes all the fields, including the default ones:
|
|
||||||
//
|
|
||||||
// * `entry.Data["msg"]`. The message passed from Info, Warn, Error ..
|
|
||||||
// * `entry.Data["time"]`. The timestamp.
|
|
||||||
// * `entry.Data["level"]. The level the entry was logged at.
|
|
||||||
//
|
|
||||||
// Any additional fields added with `WithField` or `WithFields` are also in
|
|
||||||
// `entry.Data`. Format is expected to return an array of bytes which are then
|
|
||||||
// logged to `logger.Out`.
|
|
||||||
type Formatter interface {
|
|
||||||
Format(*Entry) ([]byte, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
// This is to not silently overwrite `time`, `msg` and `level` fields when
|
|
||||||
// dumping it. If this code wasn't there doing:
|
|
||||||
//
|
|
||||||
// logrus.WithField("level", 1).Info("hello")
|
|
||||||
//
|
|
||||||
// Would just silently drop the user provided level. Instead with this code
|
|
||||||
// it'll logged as:
|
|
||||||
//
|
|
||||||
// {"level": "info", "fields.level": 1, "msg": "hello", "time": "..."}
|
|
||||||
//
|
|
||||||
// It's not exported because it's still using Data in an opinionated way. It's to
|
|
||||||
// avoid code duplication between the two default formatters.
|
|
||||||
func prefixFieldClashes(data Fields) {
|
|
||||||
_, ok := data["time"]
|
|
||||||
if ok {
|
|
||||||
data["fields.time"] = data["time"]
|
|
||||||
}
|
|
||||||
|
|
||||||
_, ok = data["msg"]
|
|
||||||
if ok {
|
|
||||||
data["fields.msg"] = data["msg"]
|
|
||||||
}
|
|
||||||
|
|
||||||
_, ok = data["level"]
|
|
||||||
if ok {
|
|
||||||
data["fields.level"] = data["level"]
|
|
||||||
}
|
|
||||||
}
|
|
34
integration/vendor/github.com/Sirupsen/logrus/hooks.go
generated
vendored
34
integration/vendor/github.com/Sirupsen/logrus/hooks.go
generated
vendored
|
@ -1,34 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
// A hook to be fired when logging on the logging levels returned from
|
|
||||||
// `Levels()` on your implementation of the interface. Note that this is not
|
|
||||||
// fired in a goroutine or a channel with workers, you should handle such
|
|
||||||
// functionality yourself if your call is non-blocking and you don't wish for
|
|
||||||
// the logging calls for levels returned from `Levels()` to block.
|
|
||||||
type Hook interface {
|
|
||||||
Levels() []Level
|
|
||||||
Fire(*Entry) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// Internal type for storing the hooks on a logger instance.
|
|
||||||
type levelHooks map[Level][]Hook
|
|
||||||
|
|
||||||
// Add a hook to an instance of logger. This is called with
|
|
||||||
// `log.Hooks.Add(new(MyHook))` where `MyHook` implements the `Hook` interface.
|
|
||||||
func (hooks levelHooks) Add(hook Hook) {
|
|
||||||
for _, level := range hook.Levels() {
|
|
||||||
hooks[level] = append(hooks[level], hook)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fire all the hooks for the passed level. Used by `entry.log` to fire
|
|
||||||
// appropriate hooks for a log entry.
|
|
||||||
func (hooks levelHooks) Fire(level Level, entry *Entry) error {
|
|
||||||
for _, hook := range hooks[level] {
|
|
||||||
if err := hook.Fire(entry); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
40
integration/vendor/github.com/Sirupsen/logrus/json_formatter.go
generated
vendored
40
integration/vendor/github.com/Sirupsen/logrus/json_formatter.go
generated
vendored
|
@ -1,40 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/json"
|
|
||||||
"fmt"
|
|
||||||
)
|
|
||||||
|
|
||||||
type JSONFormatter struct {
|
|
||||||
// TimestampFormat sets the format used for marshaling timestamps.
|
|
||||||
TimestampFormat string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *JSONFormatter) Format(entry *Entry) ([]byte, error) {
|
|
||||||
data := make(Fields, len(entry.Data)+3)
|
|
||||||
for k, v := range entry.Data {
|
|
||||||
switch v := v.(type) {
|
|
||||||
case error:
|
|
||||||
// Otherwise errors are ignored by `encoding/json`
|
|
||||||
// https://github.com/Sirupsen/logrus/issues/137
|
|
||||||
data[k] = v.Error()
|
|
||||||
default:
|
|
||||||
data[k] = v
|
|
||||||
}
|
|
||||||
}
|
|
||||||
prefixFieldClashes(data)
|
|
||||||
|
|
||||||
if f.TimestampFormat == "" {
|
|
||||||
f.TimestampFormat = DefaultTimestampFormat
|
|
||||||
}
|
|
||||||
|
|
||||||
data["time"] = entry.Time.Format(f.TimestampFormat)
|
|
||||||
data["msg"] = entry.Message
|
|
||||||
data["level"] = entry.Level.String()
|
|
||||||
|
|
||||||
serialized, err := json.Marshal(data)
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("Failed to marshal fields to JSON, %v", err)
|
|
||||||
}
|
|
||||||
return append(serialized, '\n'), nil
|
|
||||||
}
|
|
203
integration/vendor/github.com/Sirupsen/logrus/logger.go
generated
vendored
203
integration/vendor/github.com/Sirupsen/logrus/logger.go
generated
vendored
|
@ -1,203 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
"os"
|
|
||||||
"sync"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Logger struct {
|
|
||||||
// The logs are `io.Copy`'d to this in a mutex. It's common to set this to a
|
|
||||||
// file, or leave it default which is `os.Stdout`. You can also set this to
|
|
||||||
// something more adventorous, such as logging to Kafka.
|
|
||||||
Out io.Writer
|
|
||||||
// Hooks for the logger instance. These allow firing events based on logging
|
|
||||||
// levels and log entries. For example, to send errors to an error tracking
|
|
||||||
// service, log to StatsD or dump the core on fatal errors.
|
|
||||||
Hooks levelHooks
|
|
||||||
// All log entries pass through the formatter before logged to Out. The
|
|
||||||
// included formatters are `TextFormatter` and `JSONFormatter` for which
|
|
||||||
// TextFormatter is the default. In development (when a TTY is attached) it
|
|
||||||
// logs with colors, but to a file it wouldn't. You can easily implement your
|
|
||||||
// own that implements the `Formatter` interface, see the `README` or included
|
|
||||||
// formatters for examples.
|
|
||||||
Formatter Formatter
|
|
||||||
// The logging level the logger should log at. This is typically (and defaults
|
|
||||||
// to) `logrus.Info`, which allows Info(), Warn(), Error() and Fatal() to be
|
|
||||||
// logged. `logrus.Debug` is useful in
|
|
||||||
Level Level
|
|
||||||
// Used to sync writing to the log.
|
|
||||||
mu sync.Mutex
|
|
||||||
}
|
|
||||||
|
|
||||||
// Creates a new logger. Configuration should be set by changing `Formatter`,
|
|
||||||
// `Out` and `Hooks` directly on the default logger instance. You can also just
|
|
||||||
// instantiate your own:
|
|
||||||
//
|
|
||||||
// var log = &Logger{
|
|
||||||
// Out: os.Stderr,
|
|
||||||
// Formatter: new(JSONFormatter),
|
|
||||||
// Hooks: make(levelHooks),
|
|
||||||
// Level: logrus.DebugLevel,
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// It's recommended to make this a global instance called `log`.
|
|
||||||
func New() *Logger {
|
|
||||||
return &Logger{
|
|
||||||
Out: os.Stdout,
|
|
||||||
Formatter: new(TextFormatter),
|
|
||||||
Hooks: make(levelHooks),
|
|
||||||
Level: InfoLevel,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Adds a field to the log entry, note that you it doesn't log until you call
|
|
||||||
// Debug, Print, Info, Warn, Fatal or Panic. It only creates a log entry.
|
|
||||||
// Ff you want multiple fields, use `WithFields`.
|
|
||||||
func (logger *Logger) WithField(key string, value interface{}) *Entry {
|
|
||||||
return NewEntry(logger).WithField(key, value)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Adds a struct of fields to the log entry. All it does is call `WithField` for
|
|
||||||
// each `Field`.
|
|
||||||
func (logger *Logger) WithFields(fields Fields) *Entry {
|
|
||||||
return NewEntry(logger).WithFields(fields)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Debugf(format string, args ...interface{}) {
|
|
||||||
if logger.Level >= DebugLevel {
|
|
||||||
NewEntry(logger).Debugf(format, args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Infof(format string, args ...interface{}) {
|
|
||||||
if logger.Level >= InfoLevel {
|
|
||||||
NewEntry(logger).Infof(format, args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Printf(format string, args ...interface{}) {
|
|
||||||
NewEntry(logger).Printf(format, args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Warnf(format string, args ...interface{}) {
|
|
||||||
if logger.Level >= WarnLevel {
|
|
||||||
NewEntry(logger).Warnf(format, args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Warningf(format string, args ...interface{}) {
|
|
||||||
if logger.Level >= WarnLevel {
|
|
||||||
NewEntry(logger).Warnf(format, args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Errorf(format string, args ...interface{}) {
|
|
||||||
if logger.Level >= ErrorLevel {
|
|
||||||
NewEntry(logger).Errorf(format, args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Fatalf(format string, args ...interface{}) {
|
|
||||||
if logger.Level >= FatalLevel {
|
|
||||||
NewEntry(logger).Fatalf(format, args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Panicf(format string, args ...interface{}) {
|
|
||||||
if logger.Level >= PanicLevel {
|
|
||||||
NewEntry(logger).Panicf(format, args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Debug(args ...interface{}) {
|
|
||||||
if logger.Level >= DebugLevel {
|
|
||||||
NewEntry(logger).Debug(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Info(args ...interface{}) {
|
|
||||||
if logger.Level >= InfoLevel {
|
|
||||||
NewEntry(logger).Info(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Print(args ...interface{}) {
|
|
||||||
NewEntry(logger).Info(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Warn(args ...interface{}) {
|
|
||||||
if logger.Level >= WarnLevel {
|
|
||||||
NewEntry(logger).Warn(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Warning(args ...interface{}) {
|
|
||||||
if logger.Level >= WarnLevel {
|
|
||||||
NewEntry(logger).Warn(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Error(args ...interface{}) {
|
|
||||||
if logger.Level >= ErrorLevel {
|
|
||||||
NewEntry(logger).Error(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Fatal(args ...interface{}) {
|
|
||||||
if logger.Level >= FatalLevel {
|
|
||||||
NewEntry(logger).Fatal(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Panic(args ...interface{}) {
|
|
||||||
if logger.Level >= PanicLevel {
|
|
||||||
NewEntry(logger).Panic(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Debugln(args ...interface{}) {
|
|
||||||
if logger.Level >= DebugLevel {
|
|
||||||
NewEntry(logger).Debugln(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Infoln(args ...interface{}) {
|
|
||||||
if logger.Level >= InfoLevel {
|
|
||||||
NewEntry(logger).Infoln(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Println(args ...interface{}) {
|
|
||||||
NewEntry(logger).Println(args...)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Warnln(args ...interface{}) {
|
|
||||||
if logger.Level >= WarnLevel {
|
|
||||||
NewEntry(logger).Warnln(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Warningln(args ...interface{}) {
|
|
||||||
if logger.Level >= WarnLevel {
|
|
||||||
NewEntry(logger).Warnln(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Errorln(args ...interface{}) {
|
|
||||||
if logger.Level >= ErrorLevel {
|
|
||||||
NewEntry(logger).Errorln(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Fatalln(args ...interface{}) {
|
|
||||||
if logger.Level >= FatalLevel {
|
|
||||||
NewEntry(logger).Fatalln(args...)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) Panicln(args ...interface{}) {
|
|
||||||
if logger.Level >= PanicLevel {
|
|
||||||
NewEntry(logger).Panicln(args...)
|
|
||||||
}
|
|
||||||
}
|
|
94
integration/vendor/github.com/Sirupsen/logrus/logrus.go
generated
vendored
94
integration/vendor/github.com/Sirupsen/logrus/logrus.go
generated
vendored
|
@ -1,94 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"log"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Fields type, used to pass to `WithFields`.
|
|
||||||
type Fields map[string]interface{}
|
|
||||||
|
|
||||||
// Level type
|
|
||||||
type Level uint8
|
|
||||||
|
|
||||||
// Convert the Level to a string. E.g. PanicLevel becomes "panic".
|
|
||||||
func (level Level) String() string {
|
|
||||||
switch level {
|
|
||||||
case DebugLevel:
|
|
||||||
return "debug"
|
|
||||||
case InfoLevel:
|
|
||||||
return "info"
|
|
||||||
case WarnLevel:
|
|
||||||
return "warning"
|
|
||||||
case ErrorLevel:
|
|
||||||
return "error"
|
|
||||||
case FatalLevel:
|
|
||||||
return "fatal"
|
|
||||||
case PanicLevel:
|
|
||||||
return "panic"
|
|
||||||
}
|
|
||||||
|
|
||||||
return "unknown"
|
|
||||||
}
|
|
||||||
|
|
||||||
// ParseLevel takes a string level and returns the Logrus log level constant.
|
|
||||||
func ParseLevel(lvl string) (Level, error) {
|
|
||||||
switch lvl {
|
|
||||||
case "panic":
|
|
||||||
return PanicLevel, nil
|
|
||||||
case "fatal":
|
|
||||||
return FatalLevel, nil
|
|
||||||
case "error":
|
|
||||||
return ErrorLevel, nil
|
|
||||||
case "warn", "warning":
|
|
||||||
return WarnLevel, nil
|
|
||||||
case "info":
|
|
||||||
return InfoLevel, nil
|
|
||||||
case "debug":
|
|
||||||
return DebugLevel, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
var l Level
|
|
||||||
return l, fmt.Errorf("not a valid logrus Level: %q", lvl)
|
|
||||||
}
|
|
||||||
|
|
||||||
// These are the different logging levels. You can set the logging level to log
|
|
||||||
// on your instance of logger, obtained with `logrus.New()`.
|
|
||||||
const (
|
|
||||||
// PanicLevel level, highest level of severity. Logs and then calls panic with the
|
|
||||||
// message passed to Debug, Info, ...
|
|
||||||
PanicLevel Level = iota
|
|
||||||
// FatalLevel level. Logs and then calls `os.Exit(1)`. It will exit even if the
|
|
||||||
// logging level is set to Panic.
|
|
||||||
FatalLevel
|
|
||||||
// ErrorLevel level. Logs. Used for errors that should definitely be noted.
|
|
||||||
// Commonly used for hooks to send errors to an error tracking service.
|
|
||||||
ErrorLevel
|
|
||||||
// WarnLevel level. Non-critical entries that deserve eyes.
|
|
||||||
WarnLevel
|
|
||||||
// InfoLevel level. General operational entries about what's going on inside the
|
|
||||||
// application.
|
|
||||||
InfoLevel
|
|
||||||
// DebugLevel level. Usually only enabled when debugging. Very verbose logging.
|
|
||||||
DebugLevel
|
|
||||||
)
|
|
||||||
|
|
||||||
// Won't compile if StdLogger can't be realized by a log.Logger
|
|
||||||
var _ StdLogger = &log.Logger{}
|
|
||||||
|
|
||||||
// StdLogger is what your logrus-enabled library should take, that way
|
|
||||||
// it'll accept a stdlib logger and a logrus logger. There's no standard
|
|
||||||
// interface, this is the closest we get, unfortunately.
|
|
||||||
type StdLogger interface {
|
|
||||||
Print(...interface{})
|
|
||||||
Printf(string, ...interface{})
|
|
||||||
Println(...interface{})
|
|
||||||
|
|
||||||
Fatal(...interface{})
|
|
||||||
Fatalf(string, ...interface{})
|
|
||||||
Fatalln(...interface{})
|
|
||||||
|
|
||||||
Panic(...interface{})
|
|
||||||
Panicf(string, ...interface{})
|
|
||||||
Panicln(...interface{})
|
|
||||||
}
|
|
12
integration/vendor/github.com/Sirupsen/logrus/terminal_darwin.go
generated
vendored
12
integration/vendor/github.com/Sirupsen/logrus/terminal_darwin.go
generated
vendored
|
@ -1,12 +0,0 @@
|
||||||
// Based on ssh/terminal:
|
|
||||||
// Copyright 2013 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package logrus
|
|
||||||
|
|
||||||
import "syscall"
|
|
||||||
|
|
||||||
const ioctlReadTermios = syscall.TIOCGETA
|
|
||||||
|
|
||||||
type Termios syscall.Termios
|
|
20
integration/vendor/github.com/Sirupsen/logrus/terminal_freebsd.go
generated
vendored
20
integration/vendor/github.com/Sirupsen/logrus/terminal_freebsd.go
generated
vendored
|
@ -1,20 +0,0 @@
|
||||||
/*
|
|
||||||
Go 1.2 doesn't include Termios for FreeBSD. This should be added in 1.3 and this could be merged with terminal_darwin.
|
|
||||||
*/
|
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"syscall"
|
|
||||||
)
|
|
||||||
|
|
||||||
const ioctlReadTermios = syscall.TIOCGETA
|
|
||||||
|
|
||||||
type Termios struct {
|
|
||||||
Iflag uint32
|
|
||||||
Oflag uint32
|
|
||||||
Cflag uint32
|
|
||||||
Lflag uint32
|
|
||||||
Cc [20]uint8
|
|
||||||
Ispeed uint32
|
|
||||||
Ospeed uint32
|
|
||||||
}
|
|
12
integration/vendor/github.com/Sirupsen/logrus/terminal_linux.go
generated
vendored
12
integration/vendor/github.com/Sirupsen/logrus/terminal_linux.go
generated
vendored
|
@ -1,12 +0,0 @@
|
||||||
// Based on ssh/terminal:
|
|
||||||
// Copyright 2013 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package logrus
|
|
||||||
|
|
||||||
import "syscall"
|
|
||||||
|
|
||||||
const ioctlReadTermios = syscall.TCGETS
|
|
||||||
|
|
||||||
type Termios syscall.Termios
|
|
21
integration/vendor/github.com/Sirupsen/logrus/terminal_notwindows.go
generated
vendored
21
integration/vendor/github.com/Sirupsen/logrus/terminal_notwindows.go
generated
vendored
|
@ -1,21 +0,0 @@
|
||||||
// Based on ssh/terminal:
|
|
||||||
// Copyright 2011 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
// +build linux darwin freebsd openbsd
|
|
||||||
|
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"syscall"
|
|
||||||
"unsafe"
|
|
||||||
)
|
|
||||||
|
|
||||||
// IsTerminal returns true if the given file descriptor is a terminal.
|
|
||||||
func IsTerminal() bool {
|
|
||||||
fd := syscall.Stdout
|
|
||||||
var termios Termios
|
|
||||||
_, _, err := syscall.Syscall6(syscall.SYS_IOCTL, uintptr(fd), ioctlReadTermios, uintptr(unsafe.Pointer(&termios)), 0, 0, 0)
|
|
||||||
return err == 0
|
|
||||||
}
|
|
7
integration/vendor/github.com/Sirupsen/logrus/terminal_openbsd.go
generated
vendored
7
integration/vendor/github.com/Sirupsen/logrus/terminal_openbsd.go
generated
vendored
|
@ -1,7 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
import "syscall"
|
|
||||||
|
|
||||||
const ioctlReadTermios = syscall.TIOCGETA
|
|
||||||
|
|
||||||
type Termios syscall.Termios
|
|
27
integration/vendor/github.com/Sirupsen/logrus/terminal_windows.go
generated
vendored
27
integration/vendor/github.com/Sirupsen/logrus/terminal_windows.go
generated
vendored
|
@ -1,27 +0,0 @@
|
||||||
// Based on ssh/terminal:
|
|
||||||
// Copyright 2011 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
// +build windows
|
|
||||||
|
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"syscall"
|
|
||||||
"unsafe"
|
|
||||||
)
|
|
||||||
|
|
||||||
var kernel32 = syscall.NewLazyDLL("kernel32.dll")
|
|
||||||
|
|
||||||
var (
|
|
||||||
procGetConsoleMode = kernel32.NewProc("GetConsoleMode")
|
|
||||||
)
|
|
||||||
|
|
||||||
// IsTerminal returns true if the given file descriptor is a terminal.
|
|
||||||
func IsTerminal() bool {
|
|
||||||
fd := syscall.Stdout
|
|
||||||
var st uint32
|
|
||||||
r, _, e := syscall.Syscall(procGetConsoleMode.Addr(), 2, uintptr(fd), uintptr(unsafe.Pointer(&st)), 0)
|
|
||||||
return r != 0 && e == 0
|
|
||||||
}
|
|
149
integration/vendor/github.com/Sirupsen/logrus/text_formatter.go
generated
vendored
149
integration/vendor/github.com/Sirupsen/logrus/text_formatter.go
generated
vendored
|
@ -1,149 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"fmt"
|
|
||||||
"sort"
|
|
||||||
"strings"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
nocolor = 0
|
|
||||||
red = 31
|
|
||||||
green = 32
|
|
||||||
yellow = 33
|
|
||||||
blue = 34
|
|
||||||
gray = 37
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
baseTimestamp time.Time
|
|
||||||
isTerminal bool
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
baseTimestamp = time.Now()
|
|
||||||
isTerminal = IsTerminal()
|
|
||||||
}
|
|
||||||
|
|
||||||
func miniTS() int {
|
|
||||||
return int(time.Since(baseTimestamp) / time.Second)
|
|
||||||
}
|
|
||||||
|
|
||||||
type TextFormatter struct {
|
|
||||||
// Set to true to bypass checking for a TTY before outputting colors.
|
|
||||||
ForceColors bool
|
|
||||||
|
|
||||||
// Force disabling colors.
|
|
||||||
DisableColors bool
|
|
||||||
|
|
||||||
// Disable timestamp logging. useful when output is redirected to logging
|
|
||||||
// system that already adds timestamps.
|
|
||||||
DisableTimestamp bool
|
|
||||||
|
|
||||||
// Enable logging the full timestamp when a TTY is attached instead of just
|
|
||||||
// the time passed since beginning of execution.
|
|
||||||
FullTimestamp bool
|
|
||||||
|
|
||||||
// TimestampFormat to use for display when a full timestamp is printed
|
|
||||||
TimestampFormat string
|
|
||||||
|
|
||||||
// The fields are sorted by default for a consistent output. For applications
|
|
||||||
// that log extremely frequently and don't use the JSON formatter this may not
|
|
||||||
// be desired.
|
|
||||||
DisableSorting bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *TextFormatter) Format(entry *Entry) ([]byte, error) {
|
|
||||||
var keys []string = make([]string, 0, len(entry.Data))
|
|
||||||
for k := range entry.Data {
|
|
||||||
keys = append(keys, k)
|
|
||||||
}
|
|
||||||
|
|
||||||
if !f.DisableSorting {
|
|
||||||
sort.Strings(keys)
|
|
||||||
}
|
|
||||||
|
|
||||||
b := &bytes.Buffer{}
|
|
||||||
|
|
||||||
prefixFieldClashes(entry.Data)
|
|
||||||
|
|
||||||
isColored := (f.ForceColors || isTerminal) && !f.DisableColors
|
|
||||||
|
|
||||||
if f.TimestampFormat == "" {
|
|
||||||
f.TimestampFormat = DefaultTimestampFormat
|
|
||||||
}
|
|
||||||
if isColored {
|
|
||||||
f.printColored(b, entry, keys)
|
|
||||||
} else {
|
|
||||||
if !f.DisableTimestamp {
|
|
||||||
f.appendKeyValue(b, "time", entry.Time.Format(f.TimestampFormat))
|
|
||||||
}
|
|
||||||
f.appendKeyValue(b, "level", entry.Level.String())
|
|
||||||
f.appendKeyValue(b, "msg", entry.Message)
|
|
||||||
for _, key := range keys {
|
|
||||||
f.appendKeyValue(b, key, entry.Data[key])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
b.WriteByte('\n')
|
|
||||||
return b.Bytes(), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *TextFormatter) printColored(b *bytes.Buffer, entry *Entry, keys []string) {
|
|
||||||
var levelColor int
|
|
||||||
switch entry.Level {
|
|
||||||
case DebugLevel:
|
|
||||||
levelColor = gray
|
|
||||||
case WarnLevel:
|
|
||||||
levelColor = yellow
|
|
||||||
case ErrorLevel, FatalLevel, PanicLevel:
|
|
||||||
levelColor = red
|
|
||||||
default:
|
|
||||||
levelColor = blue
|
|
||||||
}
|
|
||||||
|
|
||||||
levelText := strings.ToUpper(entry.Level.String())[0:4]
|
|
||||||
|
|
||||||
if !f.FullTimestamp {
|
|
||||||
fmt.Fprintf(b, "\x1b[%dm%s\x1b[0m[%04d] %-44s ", levelColor, levelText, miniTS(), entry.Message)
|
|
||||||
} else {
|
|
||||||
fmt.Fprintf(b, "\x1b[%dm%s\x1b[0m[%s] %-44s ", levelColor, levelText, entry.Time.Format(f.TimestampFormat), entry.Message)
|
|
||||||
}
|
|
||||||
for _, k := range keys {
|
|
||||||
v := entry.Data[k]
|
|
||||||
fmt.Fprintf(b, " \x1b[%dm%s\x1b[0m=%v", levelColor, k, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func needsQuoting(text string) bool {
|
|
||||||
for _, ch := range text {
|
|
||||||
if !((ch >= 'a' && ch <= 'z') ||
|
|
||||||
(ch >= 'A' && ch <= 'Z') ||
|
|
||||||
(ch >= '0' && ch <= '9') ||
|
|
||||||
ch == '-' || ch == '.') {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *TextFormatter) appendKeyValue(b *bytes.Buffer, key, value interface{}) {
|
|
||||||
switch value.(type) {
|
|
||||||
case string:
|
|
||||||
if needsQuoting(value.(string)) {
|
|
||||||
fmt.Fprintf(b, "%v=%s ", key, value)
|
|
||||||
} else {
|
|
||||||
fmt.Fprintf(b, "%v=%q ", key, value)
|
|
||||||
}
|
|
||||||
case error:
|
|
||||||
if needsQuoting(value.(error).Error()) {
|
|
||||||
fmt.Fprintf(b, "%v=%s ", key, value)
|
|
||||||
} else {
|
|
||||||
fmt.Fprintf(b, "%v=%q ", key, value)
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
fmt.Fprintf(b, "%v=%v ", key, value)
|
|
||||||
}
|
|
||||||
}
|
|
31
integration/vendor/github.com/Sirupsen/logrus/writer.go
generated
vendored
31
integration/vendor/github.com/Sirupsen/logrus/writer.go
generated
vendored
|
@ -1,31 +0,0 @@
|
||||||
package logrus
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bufio"
|
|
||||||
"io"
|
|
||||||
"runtime"
|
|
||||||
)
|
|
||||||
|
|
||||||
func (logger *Logger) Writer() *io.PipeWriter {
|
|
||||||
reader, writer := io.Pipe()
|
|
||||||
|
|
||||||
go logger.writerScanner(reader)
|
|
||||||
runtime.SetFinalizer(writer, writerFinalizer)
|
|
||||||
|
|
||||||
return writer
|
|
||||||
}
|
|
||||||
|
|
||||||
func (logger *Logger) writerScanner(reader *io.PipeReader) {
|
|
||||||
scanner := bufio.NewScanner(reader)
|
|
||||||
for scanner.Scan() {
|
|
||||||
logger.Print(scanner.Text())
|
|
||||||
}
|
|
||||||
if err := scanner.Err(); err != nil {
|
|
||||||
logger.Errorf("Error while reading from Writer: %s", err)
|
|
||||||
}
|
|
||||||
reader.Close()
|
|
||||||
}
|
|
||||||
|
|
||||||
func writerFinalizer(writer *io.PipeWriter) {
|
|
||||||
writer.Close()
|
|
||||||
}
|
|
201
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/LICENSE
generated
vendored
201
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/LICENSE
generated
vendored
|
@ -1,201 +0,0 @@
|
||||||
Apache License
|
|
||||||
Version 2.0, January 2004
|
|
||||||
http://www.apache.org/licenses/
|
|
||||||
|
|
||||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
|
||||||
|
|
||||||
1. Definitions.
|
|
||||||
|
|
||||||
"License" shall mean the terms and conditions for use, reproduction,
|
|
||||||
and distribution as defined by Sections 1 through 9 of this document.
|
|
||||||
|
|
||||||
"Licensor" shall mean the copyright owner or entity authorized by
|
|
||||||
the copyright owner that is granting the License.
|
|
||||||
|
|
||||||
"Legal Entity" shall mean the union of the acting entity and all
|
|
||||||
other entities that control, are controlled by, or are under common
|
|
||||||
control with that entity. For the purposes of this definition,
|
|
||||||
"control" means (i) the power, direct or indirect, to cause the
|
|
||||||
direction or management of such entity, whether by contract or
|
|
||||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
|
||||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
|
||||||
|
|
||||||
"You" (or "Your") shall mean an individual or Legal Entity
|
|
||||||
exercising permissions granted by this License.
|
|
||||||
|
|
||||||
"Source" form shall mean the preferred form for making modifications,
|
|
||||||
including but not limited to software source code, documentation
|
|
||||||
source, and configuration files.
|
|
||||||
|
|
||||||
"Object" form shall mean any form resulting from mechanical
|
|
||||||
transformation or translation of a Source form, including but
|
|
||||||
not limited to compiled object code, generated documentation,
|
|
||||||
and conversions to other media types.
|
|
||||||
|
|
||||||
"Work" shall mean the work of authorship, whether in Source or
|
|
||||||
Object form, made available under the License, as indicated by a
|
|
||||||
copyright notice that is included in or attached to the work
|
|
||||||
(an example is provided in the Appendix below).
|
|
||||||
|
|
||||||
"Derivative Works" shall mean any work, whether in Source or Object
|
|
||||||
form, that is based on (or derived from) the Work and for which the
|
|
||||||
editorial revisions, annotations, elaborations, or other modifications
|
|
||||||
represent, as a whole, an original work of authorship. For the purposes
|
|
||||||
of this License, Derivative Works shall not include works that remain
|
|
||||||
separable from, or merely link (or bind by name) to the interfaces of,
|
|
||||||
the Work and Derivative Works thereof.
|
|
||||||
|
|
||||||
"Contribution" shall mean any work of authorship, including
|
|
||||||
the original version of the Work and any modifications or additions
|
|
||||||
to that Work or Derivative Works thereof, that is intentionally
|
|
||||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
|
||||||
or by an individual or Legal Entity authorized to submit on behalf of
|
|
||||||
the copyright owner. For the purposes of this definition, "submitted"
|
|
||||||
means any form of electronic, verbal, or written communication sent
|
|
||||||
to the Licensor or its representatives, including but not limited to
|
|
||||||
communication on electronic mailing lists, source code control systems,
|
|
||||||
and issue tracking systems that are managed by, or on behalf of, the
|
|
||||||
Licensor for the purpose of discussing and improving the Work, but
|
|
||||||
excluding communication that is conspicuously marked or otherwise
|
|
||||||
designated in writing by the copyright owner as "Not a Contribution."
|
|
||||||
|
|
||||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
|
||||||
on behalf of whom a Contribution has been received by Licensor and
|
|
||||||
subsequently incorporated within the Work.
|
|
||||||
|
|
||||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
|
||||||
this License, each Contributor hereby grants to You a perpetual,
|
|
||||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
|
||||||
copyright license to reproduce, prepare Derivative Works of,
|
|
||||||
publicly display, publicly perform, sublicense, and distribute the
|
|
||||||
Work and such Derivative Works in Source or Object form.
|
|
||||||
|
|
||||||
3. Grant of Patent License. Subject to the terms and conditions of
|
|
||||||
this License, each Contributor hereby grants to You a perpetual,
|
|
||||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
|
||||||
(except as stated in this section) patent license to make, have made,
|
|
||||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
|
||||||
where such license applies only to those patent claims licensable
|
|
||||||
by such Contributor that are necessarily infringed by their
|
|
||||||
Contribution(s) alone or by combination of their Contribution(s)
|
|
||||||
with the Work to which such Contribution(s) was submitted. If You
|
|
||||||
institute patent litigation against any entity (including a
|
|
||||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
|
||||||
or a Contribution incorporated within the Work constitutes direct
|
|
||||||
or contributory patent infringement, then any patent licenses
|
|
||||||
granted to You under this License for that Work shall terminate
|
|
||||||
as of the date such litigation is filed.
|
|
||||||
|
|
||||||
4. Redistribution. You may reproduce and distribute copies of the
|
|
||||||
Work or Derivative Works thereof in any medium, with or without
|
|
||||||
modifications, and in Source or Object form, provided that You
|
|
||||||
meet the following conditions:
|
|
||||||
|
|
||||||
(a) You must give any other recipients of the Work or
|
|
||||||
Derivative Works a copy of this License; and
|
|
||||||
|
|
||||||
(b) You must cause any modified files to carry prominent notices
|
|
||||||
stating that You changed the files; and
|
|
||||||
|
|
||||||
(c) You must retain, in the Source form of any Derivative Works
|
|
||||||
that You distribute, all copyright, patent, trademark, and
|
|
||||||
attribution notices from the Source form of the Work,
|
|
||||||
excluding those notices that do not pertain to any part of
|
|
||||||
the Derivative Works; and
|
|
||||||
|
|
||||||
(d) If the Work includes a "NOTICE" text file as part of its
|
|
||||||
distribution, then any Derivative Works that You distribute must
|
|
||||||
include a readable copy of the attribution notices contained
|
|
||||||
within such NOTICE file, excluding those notices that do not
|
|
||||||
pertain to any part of the Derivative Works, in at least one
|
|
||||||
of the following places: within a NOTICE text file distributed
|
|
||||||
as part of the Derivative Works; within the Source form or
|
|
||||||
documentation, if provided along with the Derivative Works; or,
|
|
||||||
within a display generated by the Derivative Works, if and
|
|
||||||
wherever such third-party notices normally appear. The contents
|
|
||||||
of the NOTICE file are for informational purposes only and
|
|
||||||
do not modify the License. You may add Your own attribution
|
|
||||||
notices within Derivative Works that You distribute, alongside
|
|
||||||
or as an addendum to the NOTICE text from the Work, provided
|
|
||||||
that such additional attribution notices cannot be construed
|
|
||||||
as modifying the License.
|
|
||||||
|
|
||||||
You may add Your own copyright statement to Your modifications and
|
|
||||||
may provide additional or different license terms and conditions
|
|
||||||
for use, reproduction, or distribution of Your modifications, or
|
|
||||||
for any such Derivative Works as a whole, provided Your use,
|
|
||||||
reproduction, and distribution of the Work otherwise complies with
|
|
||||||
the conditions stated in this License.
|
|
||||||
|
|
||||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
|
||||||
any Contribution intentionally submitted for inclusion in the Work
|
|
||||||
by You to the Licensor shall be under the terms and conditions of
|
|
||||||
this License, without any additional terms or conditions.
|
|
||||||
Notwithstanding the above, nothing herein shall supersede or modify
|
|
||||||
the terms of any separate license agreement you may have executed
|
|
||||||
with Licensor regarding such Contributions.
|
|
||||||
|
|
||||||
6. Trademarks. This License does not grant permission to use the trade
|
|
||||||
names, trademarks, service marks, or product names of the Licensor,
|
|
||||||
except as required for reasonable and customary use in describing the
|
|
||||||
origin of the Work and reproducing the content of the NOTICE file.
|
|
||||||
|
|
||||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
|
||||||
agreed to in writing, Licensor provides the Work (and each
|
|
||||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
||||||
implied, including, without limitation, any warranties or conditions
|
|
||||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
|
||||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
|
||||||
appropriateness of using or redistributing the Work and assume any
|
|
||||||
risks associated with Your exercise of permissions under this License.
|
|
||||||
|
|
||||||
8. Limitation of Liability. In no event and under no legal theory,
|
|
||||||
whether in tort (including negligence), contract, or otherwise,
|
|
||||||
unless required by applicable law (such as deliberate and grossly
|
|
||||||
negligent acts) or agreed to in writing, shall any Contributor be
|
|
||||||
liable to You for damages, including any direct, indirect, special,
|
|
||||||
incidental, or consequential damages of any character arising as a
|
|
||||||
result of this License or out of the use or inability to use the
|
|
||||||
Work (including but not limited to damages for loss of goodwill,
|
|
||||||
work stoppage, computer failure or malfunction, or any and all
|
|
||||||
other commercial damages or losses), even if such Contributor
|
|
||||||
has been advised of the possibility of such damages.
|
|
||||||
|
|
||||||
9. Accepting Warranty or Additional Liability. While redistributing
|
|
||||||
the Work or Derivative Works thereof, You may choose to offer,
|
|
||||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
|
||||||
or other liability obligations and/or rights consistent with this
|
|
||||||
License. However, in accepting such obligations, You may act only
|
|
||||||
on Your own behalf and on Your sole responsibility, not on behalf
|
|
||||||
of any other Contributor, and only if You agree to indemnify,
|
|
||||||
defend, and hold each Contributor harmless for any liability
|
|
||||||
incurred by, or claims asserted against, such Contributor by reason
|
|
||||||
of your accepting any such warranty or additional liability.
|
|
||||||
|
|
||||||
END OF TERMS AND CONDITIONS
|
|
||||||
|
|
||||||
APPENDIX: How to apply the Apache License to your work.
|
|
||||||
|
|
||||||
To apply the Apache License to your work, attach the following
|
|
||||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
|
||||||
replaced with your own identifying information. (Don't include
|
|
||||||
the brackets!) The text should be enclosed in the appropriate
|
|
||||||
comment syntax for the file format. We also recommend that a
|
|
||||||
file or class name and description of purpose be included on the
|
|
||||||
same "printed page" as the copyright notice for easier
|
|
||||||
identification within third-party archives.
|
|
||||||
|
|
||||||
Copyright [yyyy] [name of copyright owner]
|
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
18
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/NOTICE
generated
vendored
18
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/NOTICE
generated
vendored
|
@ -1,18 +0,0 @@
|
||||||
Copyright (c) 2015-Present CloudFoundry.org Foundation, 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.
|
|
||||||
|
|
||||||
This project may include a number of subcomponents with separate
|
|
||||||
copyright notices and license terms. Your use of these subcomponents
|
|
||||||
is subject to the terms and conditions of each subcomponent's license,
|
|
||||||
as noted in the LICENSE file.
|
|
834
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/api.go
generated
vendored
834
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/api.go
generated
vendored
|
@ -1,834 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create a new parser object.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_parser_initialize(parser *yaml_parser_t) bool {
|
|
||||||
*parser = yaml_parser_t{
|
|
||||||
raw_buffer: make([]byte, 0, INPUT_RAW_BUFFER_SIZE),
|
|
||||||
buffer: make([]byte, 0, INPUT_BUFFER_SIZE),
|
|
||||||
}
|
|
||||||
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Destroy a parser object.
|
|
||||||
*/
|
|
||||||
func yaml_parser_delete(parser *yaml_parser_t) {
|
|
||||||
*parser = yaml_parser_t{}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* String read handler.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_string_read_handler(parser *yaml_parser_t, buffer []byte) (int, error) {
|
|
||||||
if parser.input_pos == len(parser.input) {
|
|
||||||
return 0, io.EOF
|
|
||||||
}
|
|
||||||
|
|
||||||
n := copy(buffer, parser.input[parser.input_pos:])
|
|
||||||
parser.input_pos += n
|
|
||||||
return n, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* File read handler.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_file_read_handler(parser *yaml_parser_t, buffer []byte) (int, error) {
|
|
||||||
return parser.input_reader.Read(buffer)
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set a string input.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_parser_set_input_string(parser *yaml_parser_t, input []byte) {
|
|
||||||
if parser.read_handler != nil {
|
|
||||||
panic("input already set")
|
|
||||||
}
|
|
||||||
|
|
||||||
parser.read_handler = yaml_string_read_handler
|
|
||||||
|
|
||||||
parser.input = input
|
|
||||||
parser.input_pos = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set a reader input
|
|
||||||
*/
|
|
||||||
func yaml_parser_set_input_reader(parser *yaml_parser_t, reader io.Reader) {
|
|
||||||
if parser.read_handler != nil {
|
|
||||||
panic("input already set")
|
|
||||||
}
|
|
||||||
|
|
||||||
parser.read_handler = yaml_file_read_handler
|
|
||||||
parser.input_reader = reader
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set a generic input.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_parser_set_input(parser *yaml_parser_t, handler yaml_read_handler_t) {
|
|
||||||
if parser.read_handler != nil {
|
|
||||||
panic("input already set")
|
|
||||||
}
|
|
||||||
|
|
||||||
parser.read_handler = handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set the source encoding.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_parser_set_encoding(parser *yaml_parser_t, encoding yaml_encoding_t) {
|
|
||||||
if parser.encoding != yaml_ANY_ENCODING {
|
|
||||||
panic("encoding already set")
|
|
||||||
}
|
|
||||||
|
|
||||||
parser.encoding = encoding
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create a new emitter object.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_initialize(emitter *yaml_emitter_t) {
|
|
||||||
*emitter = yaml_emitter_t{
|
|
||||||
buffer: make([]byte, OUTPUT_BUFFER_SIZE),
|
|
||||||
raw_buffer: make([]byte, 0, OUTPUT_RAW_BUFFER_SIZE),
|
|
||||||
states: make([]yaml_emitter_state_t, 0, INITIAL_STACK_SIZE),
|
|
||||||
events: make([]yaml_event_t, 0, INITIAL_QUEUE_SIZE),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func yaml_emitter_delete(emitter *yaml_emitter_t) {
|
|
||||||
*emitter = yaml_emitter_t{}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* String write handler.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_string_write_handler(emitter *yaml_emitter_t, buffer []byte) error {
|
|
||||||
*emitter.output_buffer = append(*emitter.output_buffer, buffer...)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* File write handler.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_writer_write_handler(emitter *yaml_emitter_t, buffer []byte) error {
|
|
||||||
_, err := emitter.output_writer.Write(buffer)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set a string output.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_output_string(emitter *yaml_emitter_t, buffer *[]byte) {
|
|
||||||
if emitter.write_handler != nil {
|
|
||||||
panic("output already set")
|
|
||||||
}
|
|
||||||
|
|
||||||
emitter.write_handler = yaml_string_write_handler
|
|
||||||
emitter.output_buffer = buffer
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set a file output.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_output_writer(emitter *yaml_emitter_t, w io.Writer) {
|
|
||||||
if emitter.write_handler != nil {
|
|
||||||
panic("output already set")
|
|
||||||
}
|
|
||||||
|
|
||||||
emitter.write_handler = yaml_writer_write_handler
|
|
||||||
emitter.output_writer = w
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set a generic output handler.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_output(emitter *yaml_emitter_t, handler yaml_write_handler_t) {
|
|
||||||
if emitter.write_handler != nil {
|
|
||||||
panic("output already set")
|
|
||||||
}
|
|
||||||
|
|
||||||
emitter.write_handler = handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set the output encoding.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_encoding(emitter *yaml_emitter_t, encoding yaml_encoding_t) {
|
|
||||||
if emitter.encoding != yaml_ANY_ENCODING {
|
|
||||||
panic("encoding already set")
|
|
||||||
}
|
|
||||||
|
|
||||||
emitter.encoding = encoding
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set the canonical output style.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_canonical(emitter *yaml_emitter_t, canonical bool) {
|
|
||||||
emitter.canonical = canonical
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set the indentation increment.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_indent(emitter *yaml_emitter_t, indent int) {
|
|
||||||
if indent < 2 || indent > 9 {
|
|
||||||
indent = 2
|
|
||||||
}
|
|
||||||
emitter.best_indent = indent
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set the preferred line width.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_width(emitter *yaml_emitter_t, width int) {
|
|
||||||
if width < 0 {
|
|
||||||
width = -1
|
|
||||||
}
|
|
||||||
emitter.best_width = width
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set if unescaped non-ASCII characters are allowed.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_unicode(emitter *yaml_emitter_t, unicode bool) {
|
|
||||||
emitter.unicode = unicode
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set the preferred line break character.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_break(emitter *yaml_emitter_t, line_break yaml_break_t) {
|
|
||||||
emitter.line_break = line_break
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Destroy a token object.
|
|
||||||
*/
|
|
||||||
|
|
||||||
// yaml_DECLARE(void)
|
|
||||||
// yaml_token_delete(yaml_token_t *token)
|
|
||||||
// {
|
|
||||||
// assert(token); /* Non-NULL token object expected. */
|
|
||||||
//
|
|
||||||
// switch (token.type)
|
|
||||||
// {
|
|
||||||
// case yaml_TAG_DIRECTIVE_TOKEN:
|
|
||||||
// yaml_free(token.data.tag_directive.handle);
|
|
||||||
// yaml_free(token.data.tag_directive.prefix);
|
|
||||||
// break;
|
|
||||||
//
|
|
||||||
// case yaml_ALIAS_TOKEN:
|
|
||||||
// yaml_free(token.data.alias.value);
|
|
||||||
// break;
|
|
||||||
//
|
|
||||||
// case yaml_ANCHOR_TOKEN:
|
|
||||||
// yaml_free(token.data.anchor.value);
|
|
||||||
// break;
|
|
||||||
//
|
|
||||||
// case yaml_TAG_TOKEN:
|
|
||||||
// yaml_free(token.data.tag.handle);
|
|
||||||
// yaml_free(token.data.tag.suffix);
|
|
||||||
// break;
|
|
||||||
//
|
|
||||||
// case yaml_SCALAR_TOKEN:
|
|
||||||
// yaml_free(token.data.scalar.value);
|
|
||||||
// break;
|
|
||||||
//
|
|
||||||
// default:
|
|
||||||
// break;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// memset(token, 0, sizeof(yaml_token_t));
|
|
||||||
// }
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Check if a string is a valid UTF-8 sequence.
|
|
||||||
*
|
|
||||||
* Check 'reader.c' for more details on UTF-8 encoding.
|
|
||||||
*/
|
|
||||||
|
|
||||||
// static int
|
|
||||||
// yaml_check_utf8(yaml_char_t *start, size_t length)
|
|
||||||
// {
|
|
||||||
// yaml_char_t *end = start+length;
|
|
||||||
// yaml_char_t *pointer = start;
|
|
||||||
//
|
|
||||||
// while (pointer < end) {
|
|
||||||
// unsigned char octet;
|
|
||||||
// unsigned int width;
|
|
||||||
// unsigned int value;
|
|
||||||
// size_t k;
|
|
||||||
//
|
|
||||||
// octet = pointer[0];
|
|
||||||
// width = (octet & 0x80) == 0x00 ? 1 :
|
|
||||||
// (octet & 0xE0) == 0xC0 ? 2 :
|
|
||||||
// (octet & 0xF0) == 0xE0 ? 3 :
|
|
||||||
// (octet & 0xF8) == 0xF0 ? 4 : 0;
|
|
||||||
// value = (octet & 0x80) == 0x00 ? octet & 0x7F :
|
|
||||||
// (octet & 0xE0) == 0xC0 ? octet & 0x1F :
|
|
||||||
// (octet & 0xF0) == 0xE0 ? octet & 0x0F :
|
|
||||||
// (octet & 0xF8) == 0xF0 ? octet & 0x07 : 0;
|
|
||||||
// if (!width) return 0;
|
|
||||||
// if (pointer+width > end) return 0;
|
|
||||||
// for (k = 1; k < width; k ++) {
|
|
||||||
// octet = pointer[k];
|
|
||||||
// if ((octet & 0xC0) != 0x80) return 0;
|
|
||||||
// value = (value << 6) + (octet & 0x3F);
|
|
||||||
// }
|
|
||||||
// if (!((width == 1) ||
|
|
||||||
// (width == 2 && value >= 0x80) ||
|
|
||||||
// (width == 3 && value >= 0x800) ||
|
|
||||||
// (width == 4 && value >= 0x10000))) return 0;
|
|
||||||
//
|
|
||||||
// pointer += width;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// return 1;
|
|
||||||
// }
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create STREAM-START.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_stream_start_event_initialize(event *yaml_event_t, encoding yaml_encoding_t) {
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_STREAM_START_EVENT,
|
|
||||||
encoding: encoding,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create STREAM-END.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_stream_end_event_initialize(event *yaml_event_t) {
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_STREAM_END_EVENT,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create DOCUMENT-START.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_document_start_event_initialize(event *yaml_event_t,
|
|
||||||
version_directive *yaml_version_directive_t,
|
|
||||||
tag_directives []yaml_tag_directive_t,
|
|
||||||
implicit bool) {
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_DOCUMENT_START_EVENT,
|
|
||||||
version_directive: version_directive,
|
|
||||||
tag_directives: tag_directives,
|
|
||||||
implicit: implicit,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create DOCUMENT-END.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_document_end_event_initialize(event *yaml_event_t, implicit bool) {
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_DOCUMENT_END_EVENT,
|
|
||||||
implicit: implicit,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create ALIAS.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_alias_event_initialize(event *yaml_event_t, anchor []byte) {
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_ALIAS_EVENT,
|
|
||||||
anchor: anchor,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create SCALAR.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_scalar_event_initialize(event *yaml_event_t,
|
|
||||||
anchor []byte, tag []byte,
|
|
||||||
value []byte,
|
|
||||||
plain_implicit bool, quoted_implicit bool,
|
|
||||||
style yaml_scalar_style_t) {
|
|
||||||
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_SCALAR_EVENT,
|
|
||||||
anchor: anchor,
|
|
||||||
tag: tag,
|
|
||||||
value: value,
|
|
||||||
implicit: plain_implicit,
|
|
||||||
quoted_implicit: quoted_implicit,
|
|
||||||
style: yaml_style_t(style),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create SEQUENCE-START.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_sequence_start_event_initialize(event *yaml_event_t,
|
|
||||||
anchor []byte, tag []byte, implicit bool, style yaml_sequence_style_t) {
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_SEQUENCE_START_EVENT,
|
|
||||||
anchor: anchor,
|
|
||||||
tag: tag,
|
|
||||||
implicit: implicit,
|
|
||||||
style: yaml_style_t(style),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create SEQUENCE-END.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_sequence_end_event_initialize(event *yaml_event_t) {
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_SEQUENCE_END_EVENT,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create MAPPING-START.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_mapping_start_event_initialize(event *yaml_event_t,
|
|
||||||
anchor []byte, tag []byte, implicit bool, style yaml_mapping_style_t) {
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_MAPPING_START_EVENT,
|
|
||||||
anchor: anchor,
|
|
||||||
tag: tag,
|
|
||||||
implicit: implicit,
|
|
||||||
style: yaml_style_t(style),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create MAPPING-END.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_mapping_end_event_initialize(event *yaml_event_t) {
|
|
||||||
*event = yaml_event_t{
|
|
||||||
event_type: yaml_MAPPING_END_EVENT,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Destroy an event object.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_event_delete(event *yaml_event_t) {
|
|
||||||
*event = yaml_event_t{}
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Create a document object.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// func yaml_document_initialize(document *yaml_document_t,
|
|
||||||
// version_directive *yaml_version_directive_t,
|
|
||||||
// tag_directives []yaml_tag_directive_t,
|
|
||||||
// start_implicit, end_implicit bool) bool {
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// {
|
|
||||||
// struct {
|
|
||||||
// YAML_error_type_t error;
|
|
||||||
// } context;
|
|
||||||
// struct {
|
|
||||||
// yaml_node_t *start;
|
|
||||||
// yaml_node_t *end;
|
|
||||||
// yaml_node_t *top;
|
|
||||||
// } nodes = { NULL, NULL, NULL };
|
|
||||||
// yaml_version_directive_t *version_directive_copy = NULL;
|
|
||||||
// struct {
|
|
||||||
// yaml_tag_directive_t *start;
|
|
||||||
// yaml_tag_directive_t *end;
|
|
||||||
// yaml_tag_directive_t *top;
|
|
||||||
// } tag_directives_copy = { NULL, NULL, NULL };
|
|
||||||
// yaml_tag_directive_t value = { NULL, NULL };
|
|
||||||
// YAML_mark_t mark = { 0, 0, 0 };
|
|
||||||
//
|
|
||||||
// assert(document); /* Non-NULL document object is expected. */
|
|
||||||
// assert((tag_directives_start && tag_directives_end) ||
|
|
||||||
// (tag_directives_start == tag_directives_end));
|
|
||||||
// /* Valid tag directives are expected. */
|
|
||||||
//
|
|
||||||
// if (!STACK_INIT(&context, nodes, INITIAL_STACK_SIZE)) goto error;
|
|
||||||
//
|
|
||||||
// if (version_directive) {
|
|
||||||
// version_directive_copy = yaml_malloc(sizeof(yaml_version_directive_t));
|
|
||||||
// if (!version_directive_copy) goto error;
|
|
||||||
// version_directive_copy.major = version_directive.major;
|
|
||||||
// version_directive_copy.minor = version_directive.minor;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (tag_directives_start != tag_directives_end) {
|
|
||||||
// yaml_tag_directive_t *tag_directive;
|
|
||||||
// if (!STACK_INIT(&context, tag_directives_copy, INITIAL_STACK_SIZE))
|
|
||||||
// goto error;
|
|
||||||
// for (tag_directive = tag_directives_start;
|
|
||||||
// tag_directive != tag_directives_end; tag_directive ++) {
|
|
||||||
// assert(tag_directive.handle);
|
|
||||||
// assert(tag_directive.prefix);
|
|
||||||
// if (!yaml_check_utf8(tag_directive.handle,
|
|
||||||
// strlen((char *)tag_directive.handle)))
|
|
||||||
// goto error;
|
|
||||||
// if (!yaml_check_utf8(tag_directive.prefix,
|
|
||||||
// strlen((char *)tag_directive.prefix)))
|
|
||||||
// goto error;
|
|
||||||
// value.handle = yaml_strdup(tag_directive.handle);
|
|
||||||
// value.prefix = yaml_strdup(tag_directive.prefix);
|
|
||||||
// if (!value.handle || !value.prefix) goto error;
|
|
||||||
// if (!PUSH(&context, tag_directives_copy, value))
|
|
||||||
// goto error;
|
|
||||||
// value.handle = NULL;
|
|
||||||
// value.prefix = NULL;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// DOCUMENT_INIT(*document, nodes.start, nodes.end, version_directive_copy,
|
|
||||||
// tag_directives_copy.start, tag_directives_copy.top,
|
|
||||||
// start_implicit, end_implicit, mark, mark);
|
|
||||||
//
|
|
||||||
// return 1;
|
|
||||||
//
|
|
||||||
// error:
|
|
||||||
// STACK_DEL(&context, nodes);
|
|
||||||
// yaml_free(version_directive_copy);
|
|
||||||
// while (!STACK_EMPTY(&context, tag_directives_copy)) {
|
|
||||||
// yaml_tag_directive_t value = POP(&context, tag_directives_copy);
|
|
||||||
// yaml_free(value.handle);
|
|
||||||
// yaml_free(value.prefix);
|
|
||||||
// }
|
|
||||||
// STACK_DEL(&context, tag_directives_copy);
|
|
||||||
// yaml_free(value.handle);
|
|
||||||
// yaml_free(value.prefix);
|
|
||||||
//
|
|
||||||
// return 0;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Destroy a document object.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(void)
|
|
||||||
// yaml_document_delete(document *yaml_document_t)
|
|
||||||
// {
|
|
||||||
// struct {
|
|
||||||
// YAML_error_type_t error;
|
|
||||||
// } context;
|
|
||||||
// yaml_tag_directive_t *tag_directive;
|
|
||||||
//
|
|
||||||
// context.error = yaml_NO_ERROR; /* Eliminate a compliler warning. */
|
|
||||||
//
|
|
||||||
// assert(document); /* Non-NULL document object is expected. */
|
|
||||||
//
|
|
||||||
// while (!STACK_EMPTY(&context, document.nodes)) {
|
|
||||||
// yaml_node_t node = POP(&context, document.nodes);
|
|
||||||
// yaml_free(node.tag);
|
|
||||||
// switch (node.type) {
|
|
||||||
// case yaml_SCALAR_NODE:
|
|
||||||
// yaml_free(node.data.scalar.value);
|
|
||||||
// break;
|
|
||||||
// case yaml_SEQUENCE_NODE:
|
|
||||||
// STACK_DEL(&context, node.data.sequence.items);
|
|
||||||
// break;
|
|
||||||
// case yaml_MAPPING_NODE:
|
|
||||||
// STACK_DEL(&context, node.data.mapping.pairs);
|
|
||||||
// break;
|
|
||||||
// default:
|
|
||||||
// assert(0); /* Should not happen. */
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// STACK_DEL(&context, document.nodes);
|
|
||||||
//
|
|
||||||
// yaml_free(document.version_directive);
|
|
||||||
// for (tag_directive = document.tag_directives.start;
|
|
||||||
// tag_directive != document.tag_directives.end;
|
|
||||||
// tag_directive++) {
|
|
||||||
// yaml_free(tag_directive.handle);
|
|
||||||
// yaml_free(tag_directive.prefix);
|
|
||||||
// }
|
|
||||||
// yaml_free(document.tag_directives.start);
|
|
||||||
//
|
|
||||||
// memset(document, 0, sizeof(yaml_document_t));
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * Get a document node.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(yaml_node_t *)
|
|
||||||
// yaml_document_get_node(document *yaml_document_t, int index)
|
|
||||||
// {
|
|
||||||
// assert(document); /* Non-NULL document object is expected. */
|
|
||||||
//
|
|
||||||
// if (index > 0 && document.nodes.start + index <= document.nodes.top) {
|
|
||||||
// return document.nodes.start + index - 1;
|
|
||||||
// }
|
|
||||||
// return NULL;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * Get the root object.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(yaml_node_t *)
|
|
||||||
// yaml_document_get_root_node(document *yaml_document_t)
|
|
||||||
// {
|
|
||||||
// assert(document); /* Non-NULL document object is expected. */
|
|
||||||
//
|
|
||||||
// if (document.nodes.top != document.nodes.start) {
|
|
||||||
// return document.nodes.start;
|
|
||||||
// }
|
|
||||||
// return NULL;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Add a scalar node to a document.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_document_add_scalar(document *yaml_document_t,
|
|
||||||
// yaml_char_t *tag, yaml_char_t *value, int length,
|
|
||||||
// yaml_scalar_style_t style)
|
|
||||||
// {
|
|
||||||
// struct {
|
|
||||||
// YAML_error_type_t error;
|
|
||||||
// } context;
|
|
||||||
// YAML_mark_t mark = { 0, 0, 0 };
|
|
||||||
// yaml_char_t *tag_copy = NULL;
|
|
||||||
// yaml_char_t *value_copy = NULL;
|
|
||||||
// yaml_node_t node;
|
|
||||||
//
|
|
||||||
// assert(document); /* Non-NULL document object is expected. */
|
|
||||||
// assert(value); /* Non-NULL value is expected. */
|
|
||||||
//
|
|
||||||
// if (!tag) {
|
|
||||||
// tag = (yaml_char_t *)yaml_DEFAULT_SCALAR_TAG;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (!yaml_check_utf8(tag, strlen((char *)tag))) goto error;
|
|
||||||
// tag_copy = yaml_strdup(tag);
|
|
||||||
// if (!tag_copy) goto error;
|
|
||||||
//
|
|
||||||
// if (length < 0) {
|
|
||||||
// length = strlen((char *)value);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (!yaml_check_utf8(value, length)) goto error;
|
|
||||||
// value_copy = yaml_malloc(length+1);
|
|
||||||
// if (!value_copy) goto error;
|
|
||||||
// memcpy(value_copy, value, length);
|
|
||||||
// value_copy[length] = '\0';
|
|
||||||
//
|
|
||||||
// SCALAR_NODE_INIT(node, tag_copy, value_copy, length, style, mark, mark);
|
|
||||||
// if (!PUSH(&context, document.nodes, node)) goto error;
|
|
||||||
//
|
|
||||||
// return document.nodes.top - document.nodes.start;
|
|
||||||
//
|
|
||||||
// error:
|
|
||||||
// yaml_free(tag_copy);
|
|
||||||
// yaml_free(value_copy);
|
|
||||||
//
|
|
||||||
// return 0;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Add a sequence node to a document.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_document_add_sequence(document *yaml_document_t,
|
|
||||||
// yaml_char_t *tag, yaml_sequence_style_t style)
|
|
||||||
// {
|
|
||||||
// struct {
|
|
||||||
// YAML_error_type_t error;
|
|
||||||
// } context;
|
|
||||||
// YAML_mark_t mark = { 0, 0, 0 };
|
|
||||||
// yaml_char_t *tag_copy = NULL;
|
|
||||||
// struct {
|
|
||||||
// yaml_node_item_t *start;
|
|
||||||
// yaml_node_item_t *end;
|
|
||||||
// yaml_node_item_t *top;
|
|
||||||
// } items = { NULL, NULL, NULL };
|
|
||||||
// yaml_node_t node;
|
|
||||||
//
|
|
||||||
// assert(document); /* Non-NULL document object is expected. */
|
|
||||||
//
|
|
||||||
// if (!tag) {
|
|
||||||
// tag = (yaml_char_t *)yaml_DEFAULT_SEQUENCE_TAG;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (!yaml_check_utf8(tag, strlen((char *)tag))) goto error;
|
|
||||||
// tag_copy = yaml_strdup(tag);
|
|
||||||
// if (!tag_copy) goto error;
|
|
||||||
//
|
|
||||||
// if (!STACK_INIT(&context, items, INITIAL_STACK_SIZE)) goto error;
|
|
||||||
//
|
|
||||||
// SEQUENCE_NODE_INIT(node, tag_copy, items.start, items.end,
|
|
||||||
// style, mark, mark);
|
|
||||||
// if (!PUSH(&context, document.nodes, node)) goto error;
|
|
||||||
//
|
|
||||||
// return document.nodes.top - document.nodes.start;
|
|
||||||
//
|
|
||||||
// error:
|
|
||||||
// STACK_DEL(&context, items);
|
|
||||||
// yaml_free(tag_copy);
|
|
||||||
//
|
|
||||||
// return 0;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Add a mapping node to a document.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_document_add_mapping(document *yaml_document_t,
|
|
||||||
// yaml_char_t *tag, yaml_mapping_style_t style)
|
|
||||||
// {
|
|
||||||
// struct {
|
|
||||||
// YAML_error_type_t error;
|
|
||||||
// } context;
|
|
||||||
// YAML_mark_t mark = { 0, 0, 0 };
|
|
||||||
// yaml_char_t *tag_copy = NULL;
|
|
||||||
// struct {
|
|
||||||
// yaml_node_pair_t *start;
|
|
||||||
// yaml_node_pair_t *end;
|
|
||||||
// yaml_node_pair_t *top;
|
|
||||||
// } pairs = { NULL, NULL, NULL };
|
|
||||||
// yaml_node_t node;
|
|
||||||
//
|
|
||||||
// assert(document); /* Non-NULL document object is expected. */
|
|
||||||
//
|
|
||||||
// if (!tag) {
|
|
||||||
// tag = (yaml_char_t *)yaml_DEFAULT_MAPPING_TAG;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (!yaml_check_utf8(tag, strlen((char *)tag))) goto error;
|
|
||||||
// tag_copy = yaml_strdup(tag);
|
|
||||||
// if (!tag_copy) goto error;
|
|
||||||
//
|
|
||||||
// if (!STACK_INIT(&context, pairs, INITIAL_STACK_SIZE)) goto error;
|
|
||||||
//
|
|
||||||
// MAPPING_NODE_INIT(node, tag_copy, pairs.start, pairs.end,
|
|
||||||
// style, mark, mark);
|
|
||||||
// if (!PUSH(&context, document.nodes, node)) goto error;
|
|
||||||
//
|
|
||||||
// return document.nodes.top - document.nodes.start;
|
|
||||||
//
|
|
||||||
// error:
|
|
||||||
// STACK_DEL(&context, pairs);
|
|
||||||
// yaml_free(tag_copy);
|
|
||||||
//
|
|
||||||
// return 0;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Append an item to a sequence node.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_document_append_sequence_item(document *yaml_document_t,
|
|
||||||
// int sequence, int item)
|
|
||||||
// {
|
|
||||||
// struct {
|
|
||||||
// YAML_error_type_t error;
|
|
||||||
// } context;
|
|
||||||
//
|
|
||||||
// assert(document); /* Non-NULL document is required. */
|
|
||||||
// assert(sequence > 0
|
|
||||||
// && document.nodes.start + sequence <= document.nodes.top);
|
|
||||||
// /* Valid sequence id is required. */
|
|
||||||
// assert(document.nodes.start[sequence-1].type == yaml_SEQUENCE_NODE);
|
|
||||||
// /* A sequence node is required. */
|
|
||||||
// assert(item > 0 && document.nodes.start + item <= document.nodes.top);
|
|
||||||
// /* Valid item id is required. */
|
|
||||||
//
|
|
||||||
// if (!PUSH(&context,
|
|
||||||
// document.nodes.start[sequence-1].data.sequence.items, item))
|
|
||||||
// return 0;
|
|
||||||
//
|
|
||||||
// return 1;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Append a pair of a key and a value to a mapping node.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_document_append_mapping_pair(document *yaml_document_t,
|
|
||||||
// int mapping, int key, int value)
|
|
||||||
// {
|
|
||||||
// struct {
|
|
||||||
// YAML_error_type_t error;
|
|
||||||
// } context;
|
|
||||||
//
|
|
||||||
// yaml_node_pair_t pair;
|
|
||||||
//
|
|
||||||
// assert(document); /* Non-NULL document is required. */
|
|
||||||
// assert(mapping > 0
|
|
||||||
// && document.nodes.start + mapping <= document.nodes.top);
|
|
||||||
// /* Valid mapping id is required. */
|
|
||||||
// assert(document.nodes.start[mapping-1].type == yaml_MAPPING_NODE);
|
|
||||||
// /* A mapping node is required. */
|
|
||||||
// assert(key > 0 && document.nodes.start + key <= document.nodes.top);
|
|
||||||
// /* Valid key id is required. */
|
|
||||||
// assert(value > 0 && document.nodes.start + value <= document.nodes.top);
|
|
||||||
// /* Valid value id is required. */
|
|
||||||
//
|
|
||||||
// pair.key = key;
|
|
||||||
// pair.value = value;
|
|
||||||
//
|
|
||||||
// if (!PUSH(&context,
|
|
||||||
// document.nodes.start[mapping-1].data.mapping.pairs, pair))
|
|
||||||
// return 0;
|
|
||||||
//
|
|
||||||
// return 1;
|
|
||||||
// }
|
|
||||||
//
|
|
622
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/decode.go
generated
vendored
622
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/decode.go
generated
vendored
|
@ -1,622 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"reflect"
|
|
||||||
"runtime"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Unmarshaler interface {
|
|
||||||
UnmarshalYAML(tag string, value interface{}) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// A Number represents a JSON number literal.
|
|
||||||
type Number string
|
|
||||||
|
|
||||||
// String returns the literal text of the number.
|
|
||||||
func (n Number) String() string { return string(n) }
|
|
||||||
|
|
||||||
// Float64 returns the number as a float64.
|
|
||||||
func (n Number) Float64() (float64, error) {
|
|
||||||
return strconv.ParseFloat(string(n), 64)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int64 returns the number as an int64.
|
|
||||||
func (n Number) Int64() (int64, error) {
|
|
||||||
return strconv.ParseInt(string(n), 10, 64)
|
|
||||||
}
|
|
||||||
|
|
||||||
type Decoder struct {
|
|
||||||
parser yaml_parser_t
|
|
||||||
event yaml_event_t
|
|
||||||
replay_events []yaml_event_t
|
|
||||||
useNumber bool
|
|
||||||
|
|
||||||
anchors map[string][]yaml_event_t
|
|
||||||
tracking_anchors [][]yaml_event_t
|
|
||||||
}
|
|
||||||
|
|
||||||
type ParserError struct {
|
|
||||||
ErrorType YAML_error_type_t
|
|
||||||
Context string
|
|
||||||
ContextMark YAML_mark_t
|
|
||||||
Problem string
|
|
||||||
ProblemMark YAML_mark_t
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *ParserError) Error() string {
|
|
||||||
return fmt.Sprintf("yaml: [%s] %s at line %d, column %d", e.Context, e.Problem, e.ProblemMark.line+1, e.ProblemMark.column+1)
|
|
||||||
}
|
|
||||||
|
|
||||||
type UnexpectedEventError struct {
|
|
||||||
Value string
|
|
||||||
EventType yaml_event_type_t
|
|
||||||
At YAML_mark_t
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *UnexpectedEventError) Error() string {
|
|
||||||
return fmt.Sprintf("yaml: Unexpect event [%d]: '%s' at line %d, column %d", e.EventType, e.Value, e.At.line+1, e.At.column+1)
|
|
||||||
}
|
|
||||||
|
|
||||||
func recovery(err *error) {
|
|
||||||
if r := recover(); r != nil {
|
|
||||||
if _, ok := r.(runtime.Error); ok {
|
|
||||||
panic(r)
|
|
||||||
}
|
|
||||||
|
|
||||||
var tmpError error
|
|
||||||
switch r := r.(type) {
|
|
||||||
case error:
|
|
||||||
tmpError = r
|
|
||||||
case string:
|
|
||||||
tmpError = errors.New(r)
|
|
||||||
default:
|
|
||||||
tmpError = errors.New("Unknown panic: " + reflect.ValueOf(r).String())
|
|
||||||
}
|
|
||||||
|
|
||||||
*err = tmpError
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func Unmarshal(data []byte, v interface{}) error {
|
|
||||||
d := NewDecoder(bytes.NewBuffer(data))
|
|
||||||
return d.Decode(v)
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewDecoder(r io.Reader) *Decoder {
|
|
||||||
d := &Decoder{
|
|
||||||
anchors: make(map[string][]yaml_event_t),
|
|
||||||
tracking_anchors: make([][]yaml_event_t, 1),
|
|
||||||
}
|
|
||||||
yaml_parser_initialize(&d.parser)
|
|
||||||
yaml_parser_set_input_reader(&d.parser, r)
|
|
||||||
return d
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) Decode(v interface{}) (err error) {
|
|
||||||
defer recovery(&err)
|
|
||||||
|
|
||||||
rv := reflect.ValueOf(v)
|
|
||||||
if rv.Kind() != reflect.Ptr || rv.IsNil() {
|
|
||||||
return fmt.Errorf("Expected a pointer or nil but was a %s at %s", rv.String(), d.event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
if d.event.event_type == yaml_NO_EVENT {
|
|
||||||
d.nextEvent()
|
|
||||||
|
|
||||||
if d.event.event_type != yaml_STREAM_START_EVENT {
|
|
||||||
return errors.New("Invalid stream")
|
|
||||||
}
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
}
|
|
||||||
|
|
||||||
d.document(rv)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) UseNumber() { d.useNumber = true }
|
|
||||||
|
|
||||||
func (d *Decoder) error(err error) {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) nextEvent() {
|
|
||||||
if d.event.event_type == yaml_STREAM_END_EVENT {
|
|
||||||
d.error(errors.New("The stream is closed"))
|
|
||||||
}
|
|
||||||
|
|
||||||
if d.replay_events != nil {
|
|
||||||
d.event = d.replay_events[0]
|
|
||||||
if len(d.replay_events) == 1 {
|
|
||||||
d.replay_events = nil
|
|
||||||
} else {
|
|
||||||
d.replay_events = d.replay_events[1:]
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if !yaml_parser_parse(&d.parser, &d.event) {
|
|
||||||
yaml_event_delete(&d.event)
|
|
||||||
|
|
||||||
d.error(&ParserError{
|
|
||||||
ErrorType: d.parser.error,
|
|
||||||
Context: d.parser.context,
|
|
||||||
ContextMark: d.parser.context_mark,
|
|
||||||
Problem: d.parser.problem,
|
|
||||||
ProblemMark: d.parser.problem_mark,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
last := len(d.tracking_anchors)
|
|
||||||
// skip aliases when tracking an anchor
|
|
||||||
if last > 0 && d.event.event_type != yaml_ALIAS_EVENT {
|
|
||||||
d.tracking_anchors[last-1] = append(d.tracking_anchors[last-1], d.event)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) document(rv reflect.Value) {
|
|
||||||
if d.event.event_type != yaml_DOCUMENT_START_EVENT {
|
|
||||||
d.error(fmt.Errorf("Expected document start at %s", d.event.start_mark))
|
|
||||||
}
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
d.parse(rv)
|
|
||||||
|
|
||||||
if d.event.event_type != yaml_DOCUMENT_END_EVENT {
|
|
||||||
d.error(fmt.Errorf("Expected document end at %s", d.event.start_mark))
|
|
||||||
}
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) parse(rv reflect.Value) {
|
|
||||||
if !rv.IsValid() {
|
|
||||||
// skip ahead since we cannot store
|
|
||||||
d.valueInterface()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
anchor := string(d.event.anchor)
|
|
||||||
switch d.event.event_type {
|
|
||||||
case yaml_SEQUENCE_START_EVENT:
|
|
||||||
d.begin_anchor(anchor)
|
|
||||||
d.sequence(rv)
|
|
||||||
d.end_anchor(anchor)
|
|
||||||
case yaml_MAPPING_START_EVENT:
|
|
||||||
d.begin_anchor(anchor)
|
|
||||||
d.mapping(rv)
|
|
||||||
d.end_anchor(anchor)
|
|
||||||
case yaml_SCALAR_EVENT:
|
|
||||||
d.begin_anchor(anchor)
|
|
||||||
d.scalar(rv)
|
|
||||||
d.end_anchor(anchor)
|
|
||||||
case yaml_ALIAS_EVENT:
|
|
||||||
d.alias(rv)
|
|
||||||
case yaml_DOCUMENT_END_EVENT:
|
|
||||||
default:
|
|
||||||
d.error(&UnexpectedEventError{
|
|
||||||
Value: string(d.event.value),
|
|
||||||
EventType: d.event.event_type,
|
|
||||||
At: d.event.start_mark,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) begin_anchor(anchor string) {
|
|
||||||
if anchor != "" {
|
|
||||||
events := []yaml_event_t{d.event}
|
|
||||||
d.tracking_anchors = append(d.tracking_anchors, events)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) end_anchor(anchor string) {
|
|
||||||
if anchor != "" {
|
|
||||||
events := d.tracking_anchors[len(d.tracking_anchors)-1]
|
|
||||||
d.tracking_anchors = d.tracking_anchors[0 : len(d.tracking_anchors)-1]
|
|
||||||
// remove the anchor, replaying events shouldn't have anchors
|
|
||||||
events[0].anchor = nil
|
|
||||||
// we went one too many, remove the extra event
|
|
||||||
events = events[:len(events)-1]
|
|
||||||
// if nested, append to all the other anchors
|
|
||||||
for i, e := range d.tracking_anchors {
|
|
||||||
d.tracking_anchors[i] = append(e, events...)
|
|
||||||
}
|
|
||||||
d.anchors[anchor] = events
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) indirect(v reflect.Value, decodingNull bool) (Unmarshaler, reflect.Value) {
|
|
||||||
// If v is a named type and is addressable,
|
|
||||||
// start with its address, so that if the type has pointer methods,
|
|
||||||
// we find them.
|
|
||||||
if v.Kind() != reflect.Ptr && v.Type().Name() != "" && v.CanAddr() {
|
|
||||||
v = v.Addr()
|
|
||||||
}
|
|
||||||
for {
|
|
||||||
// Load value from interface, but only if the result will be
|
|
||||||
// usefully addressable.
|
|
||||||
if v.Kind() == reflect.Interface && !v.IsNil() {
|
|
||||||
e := v.Elem()
|
|
||||||
if e.Kind() == reflect.Ptr && !e.IsNil() && (!decodingNull || e.Elem().Kind() == reflect.Ptr) {
|
|
||||||
v = e
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if v.Kind() != reflect.Ptr {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
if v.Elem().Kind() != reflect.Ptr && decodingNull && v.CanSet() {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
if v.IsNil() {
|
|
||||||
v.Set(reflect.New(v.Type().Elem()))
|
|
||||||
}
|
|
||||||
|
|
||||||
if v.Type().NumMethod() > 0 {
|
|
||||||
if u, ok := v.Interface().(Unmarshaler); ok {
|
|
||||||
var temp interface{}
|
|
||||||
return u, reflect.ValueOf(&temp)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
v = v.Elem()
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil, v
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) sequence(v reflect.Value) {
|
|
||||||
if d.event.event_type != yaml_SEQUENCE_START_EVENT {
|
|
||||||
d.error(fmt.Errorf("Expected sequence start at %s", d.event.start_mark))
|
|
||||||
}
|
|
||||||
|
|
||||||
u, pv := d.indirect(v, false)
|
|
||||||
if u != nil {
|
|
||||||
defer func() {
|
|
||||||
if err := u.UnmarshalYAML(yaml_SEQ_TAG, pv.Interface()); err != nil {
|
|
||||||
d.error(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
_, pv = d.indirect(pv, false)
|
|
||||||
}
|
|
||||||
|
|
||||||
v = pv
|
|
||||||
|
|
||||||
// Check type of target.
|
|
||||||
switch v.Kind() {
|
|
||||||
case reflect.Interface:
|
|
||||||
if v.NumMethod() == 0 {
|
|
||||||
// Decoding into nil interface? Switch to non-reflect code.
|
|
||||||
v.Set(reflect.ValueOf(d.sequenceInterface()))
|
|
||||||
return
|
|
||||||
}
|
|
||||||
// Otherwise it's invalid.
|
|
||||||
fallthrough
|
|
||||||
default:
|
|
||||||
d.error(fmt.Errorf("Expected an array, slice or interface{} but was a %s at %s", v, d.event.start_mark))
|
|
||||||
case reflect.Array:
|
|
||||||
case reflect.Slice:
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
|
|
||||||
i := 0
|
|
||||||
done:
|
|
||||||
for {
|
|
||||||
switch d.event.event_type {
|
|
||||||
case yaml_SEQUENCE_END_EVENT, yaml_DOCUMENT_END_EVENT:
|
|
||||||
break done
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get element of array, growing if necessary.
|
|
||||||
if v.Kind() == reflect.Slice {
|
|
||||||
// Grow slice if necessary
|
|
||||||
if i >= v.Cap() {
|
|
||||||
newcap := v.Cap() + v.Cap()/2
|
|
||||||
if newcap < 4 {
|
|
||||||
newcap = 4
|
|
||||||
}
|
|
||||||
newv := reflect.MakeSlice(v.Type(), v.Len(), newcap)
|
|
||||||
reflect.Copy(newv, v)
|
|
||||||
v.Set(newv)
|
|
||||||
}
|
|
||||||
if i >= v.Len() {
|
|
||||||
v.SetLen(i + 1)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if i < v.Len() {
|
|
||||||
// Decode into element.
|
|
||||||
d.parse(v.Index(i))
|
|
||||||
} else {
|
|
||||||
// Ran out of fixed array: skip.
|
|
||||||
d.parse(reflect.Value{})
|
|
||||||
}
|
|
||||||
i++
|
|
||||||
}
|
|
||||||
|
|
||||||
if i < v.Len() {
|
|
||||||
if v.Kind() == reflect.Array {
|
|
||||||
// Array. Zero the rest.
|
|
||||||
z := reflect.Zero(v.Type().Elem())
|
|
||||||
for ; i < v.Len(); i++ {
|
|
||||||
v.Index(i).Set(z)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
v.SetLen(i)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if i == 0 && v.Kind() == reflect.Slice {
|
|
||||||
v.Set(reflect.MakeSlice(v.Type(), 0, 0))
|
|
||||||
}
|
|
||||||
|
|
||||||
if d.event.event_type != yaml_DOCUMENT_END_EVENT {
|
|
||||||
d.nextEvent()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) mapping(v reflect.Value) {
|
|
||||||
u, pv := d.indirect(v, false)
|
|
||||||
if u != nil {
|
|
||||||
defer func() {
|
|
||||||
if err := u.UnmarshalYAML(yaml_MAP_TAG, pv.Interface()); err != nil {
|
|
||||||
d.error(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
_, pv = d.indirect(pv, false)
|
|
||||||
}
|
|
||||||
v = pv
|
|
||||||
|
|
||||||
// Decoding into nil interface? Switch to non-reflect code.
|
|
||||||
if v.Kind() == reflect.Interface && v.NumMethod() == 0 {
|
|
||||||
v.Set(reflect.ValueOf(d.mappingInterface()))
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check type of target: struct or map[X]Y
|
|
||||||
switch v.Kind() {
|
|
||||||
case reflect.Struct:
|
|
||||||
d.mappingStruct(v)
|
|
||||||
return
|
|
||||||
case reflect.Map:
|
|
||||||
default:
|
|
||||||
d.error(fmt.Errorf("Expected a struct or map but was a %s at %s ", v, d.event.start_mark))
|
|
||||||
}
|
|
||||||
|
|
||||||
mapt := v.Type()
|
|
||||||
if v.IsNil() {
|
|
||||||
v.Set(reflect.MakeMap(mapt))
|
|
||||||
}
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
|
|
||||||
keyt := mapt.Key()
|
|
||||||
mapElemt := mapt.Elem()
|
|
||||||
|
|
||||||
var mapElem reflect.Value
|
|
||||||
done:
|
|
||||||
for {
|
|
||||||
switch d.event.event_type {
|
|
||||||
case yaml_MAPPING_END_EVENT:
|
|
||||||
break done
|
|
||||||
case yaml_DOCUMENT_END_EVENT:
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
key := reflect.New(keyt)
|
|
||||||
d.parse(key.Elem())
|
|
||||||
|
|
||||||
if !mapElem.IsValid() {
|
|
||||||
mapElem = reflect.New(mapElemt).Elem()
|
|
||||||
} else {
|
|
||||||
mapElem.Set(reflect.Zero(mapElemt))
|
|
||||||
}
|
|
||||||
|
|
||||||
d.parse(mapElem)
|
|
||||||
|
|
||||||
v.SetMapIndex(key.Elem(), mapElem)
|
|
||||||
}
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) mappingStruct(v reflect.Value) {
|
|
||||||
|
|
||||||
structt := v.Type()
|
|
||||||
fields := cachedTypeFields(structt)
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
|
|
||||||
done:
|
|
||||||
for {
|
|
||||||
switch d.event.event_type {
|
|
||||||
case yaml_MAPPING_END_EVENT:
|
|
||||||
break done
|
|
||||||
case yaml_DOCUMENT_END_EVENT:
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
key := ""
|
|
||||||
d.parse(reflect.ValueOf(&key))
|
|
||||||
|
|
||||||
// Figure out field corresponding to key.
|
|
||||||
var subv reflect.Value
|
|
||||||
|
|
||||||
var f *field
|
|
||||||
for i := range fields {
|
|
||||||
ff := &fields[i]
|
|
||||||
if ff.name == key {
|
|
||||||
f = ff
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
if f == nil && strings.EqualFold(ff.name, key) {
|
|
||||||
f = ff
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if f != nil {
|
|
||||||
subv = v
|
|
||||||
for _, i := range f.index {
|
|
||||||
if subv.Kind() == reflect.Ptr {
|
|
||||||
if subv.IsNil() {
|
|
||||||
subv.Set(reflect.New(subv.Type().Elem()))
|
|
||||||
}
|
|
||||||
subv = subv.Elem()
|
|
||||||
}
|
|
||||||
subv = subv.Field(i)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
d.parse(subv)
|
|
||||||
}
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) scalar(v reflect.Value) {
|
|
||||||
val := string(d.event.value)
|
|
||||||
wantptr := null_values[val]
|
|
||||||
|
|
||||||
u, pv := d.indirect(v, wantptr)
|
|
||||||
|
|
||||||
var tag string
|
|
||||||
if u != nil {
|
|
||||||
defer func() {
|
|
||||||
if err := u.UnmarshalYAML(tag, pv.Interface()); err != nil {
|
|
||||||
d.error(err)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
_, pv = d.indirect(pv, wantptr)
|
|
||||||
}
|
|
||||||
v = pv
|
|
||||||
|
|
||||||
var err error
|
|
||||||
tag, err = resolve(d.event, v, d.useNumber)
|
|
||||||
if err != nil {
|
|
||||||
d.error(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) alias(rv reflect.Value) {
|
|
||||||
val, ok := d.anchors[string(d.event.anchor)]
|
|
||||||
if !ok {
|
|
||||||
d.error(fmt.Errorf("missing anchor: '%s' at %s", d.event.anchor, d.event.start_mark))
|
|
||||||
}
|
|
||||||
|
|
||||||
d.replay_events = val
|
|
||||||
d.nextEvent()
|
|
||||||
d.parse(rv)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) valueInterface() interface{} {
|
|
||||||
var v interface{}
|
|
||||||
|
|
||||||
anchor := string(d.event.anchor)
|
|
||||||
switch d.event.event_type {
|
|
||||||
case yaml_SEQUENCE_START_EVENT:
|
|
||||||
d.begin_anchor(anchor)
|
|
||||||
v = d.sequenceInterface()
|
|
||||||
case yaml_MAPPING_START_EVENT:
|
|
||||||
d.begin_anchor(anchor)
|
|
||||||
v = d.mappingInterface()
|
|
||||||
case yaml_SCALAR_EVENT:
|
|
||||||
d.begin_anchor(anchor)
|
|
||||||
v = d.scalarInterface()
|
|
||||||
case yaml_ALIAS_EVENT:
|
|
||||||
rv := reflect.ValueOf(&v)
|
|
||||||
d.alias(rv)
|
|
||||||
return v
|
|
||||||
case yaml_DOCUMENT_END_EVENT:
|
|
||||||
d.error(&UnexpectedEventError{
|
|
||||||
Value: string(d.event.value),
|
|
||||||
EventType: d.event.event_type,
|
|
||||||
At: d.event.start_mark,
|
|
||||||
})
|
|
||||||
|
|
||||||
}
|
|
||||||
d.end_anchor(anchor)
|
|
||||||
|
|
||||||
return v
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *Decoder) scalarInterface() interface{} {
|
|
||||||
_, v := resolveInterface(d.event, d.useNumber)
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
return v
|
|
||||||
}
|
|
||||||
|
|
||||||
// sequenceInterface is like sequence but returns []interface{}.
|
|
||||||
func (d *Decoder) sequenceInterface() []interface{} {
|
|
||||||
var v = make([]interface{}, 0)
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
|
|
||||||
done:
|
|
||||||
for {
|
|
||||||
switch d.event.event_type {
|
|
||||||
case yaml_SEQUENCE_END_EVENT, yaml_DOCUMENT_END_EVENT:
|
|
||||||
break done
|
|
||||||
}
|
|
||||||
|
|
||||||
v = append(v, d.valueInterface())
|
|
||||||
}
|
|
||||||
|
|
||||||
if d.event.event_type != yaml_DOCUMENT_END_EVENT {
|
|
||||||
d.nextEvent()
|
|
||||||
}
|
|
||||||
|
|
||||||
return v
|
|
||||||
}
|
|
||||||
|
|
||||||
// mappingInterface is like mapping but returns map[interface{}]interface{}.
|
|
||||||
func (d *Decoder) mappingInterface() map[interface{}]interface{} {
|
|
||||||
m := make(map[interface{}]interface{})
|
|
||||||
|
|
||||||
d.nextEvent()
|
|
||||||
|
|
||||||
done:
|
|
||||||
for {
|
|
||||||
switch d.event.event_type {
|
|
||||||
case yaml_MAPPING_END_EVENT, yaml_DOCUMENT_END_EVENT:
|
|
||||||
break done
|
|
||||||
}
|
|
||||||
|
|
||||||
key := d.valueInterface()
|
|
||||||
|
|
||||||
// Read value.
|
|
||||||
m[key] = d.valueInterface()
|
|
||||||
}
|
|
||||||
|
|
||||||
if d.event.event_type != yaml_DOCUMENT_END_EVENT {
|
|
||||||
d.nextEvent()
|
|
||||||
}
|
|
||||||
|
|
||||||
return m
|
|
||||||
}
|
|
2072
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/emitter.go
generated
vendored
2072
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/emitter.go
generated
vendored
File diff suppressed because it is too large
Load diff
395
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/encode.go
generated
vendored
395
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/encode.go
generated
vendored
|
@ -1,395 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"encoding/base64"
|
|
||||||
"io"
|
|
||||||
"math"
|
|
||||||
"reflect"
|
|
||||||
"regexp"
|
|
||||||
"sort"
|
|
||||||
"strconv"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
timeTimeType = reflect.TypeOf(time.Time{})
|
|
||||||
marshalerType = reflect.TypeOf(new(Marshaler)).Elem()
|
|
||||||
numberType = reflect.TypeOf(Number(""))
|
|
||||||
nonPrintable = regexp.MustCompile("[^\t\n\r\u0020-\u007E\u0085\u00A0-\uD7FF\uE000-\uFFFD]")
|
|
||||||
multiline = regexp.MustCompile("\n|\u0085|\u2028|\u2029")
|
|
||||||
|
|
||||||
shortTags = map[string]string{
|
|
||||||
yaml_NULL_TAG: "!!null",
|
|
||||||
yaml_BOOL_TAG: "!!bool",
|
|
||||||
yaml_STR_TAG: "!!str",
|
|
||||||
yaml_INT_TAG: "!!int",
|
|
||||||
yaml_FLOAT_TAG: "!!float",
|
|
||||||
yaml_TIMESTAMP_TAG: "!!timestamp",
|
|
||||||
yaml_SEQ_TAG: "!!seq",
|
|
||||||
yaml_MAP_TAG: "!!map",
|
|
||||||
yaml_BINARY_TAG: "!!binary",
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
type Marshaler interface {
|
|
||||||
MarshalYAML() (tag string, value interface{}, err error)
|
|
||||||
}
|
|
||||||
|
|
||||||
// An Encoder writes JSON objects to an output stream.
|
|
||||||
type Encoder struct {
|
|
||||||
w io.Writer
|
|
||||||
emitter yaml_emitter_t
|
|
||||||
event yaml_event_t
|
|
||||||
flow bool
|
|
||||||
err error
|
|
||||||
}
|
|
||||||
|
|
||||||
func Marshal(v interface{}) ([]byte, error) {
|
|
||||||
b := bytes.Buffer{}
|
|
||||||
e := NewEncoder(&b)
|
|
||||||
err := e.Encode(v)
|
|
||||||
return b.Bytes(), err
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewEncoder returns a new encoder that writes to w.
|
|
||||||
func NewEncoder(w io.Writer) *Encoder {
|
|
||||||
e := &Encoder{w: w}
|
|
||||||
yaml_emitter_initialize(&e.emitter)
|
|
||||||
yaml_emitter_set_output_writer(&e.emitter, e.w)
|
|
||||||
yaml_stream_start_event_initialize(&e.event, yaml_UTF8_ENCODING)
|
|
||||||
e.emit()
|
|
||||||
yaml_document_start_event_initialize(&e.event, nil, nil, true)
|
|
||||||
e.emit()
|
|
||||||
|
|
||||||
return e
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) Encode(v interface{}) (err error) {
|
|
||||||
defer recovery(&err)
|
|
||||||
|
|
||||||
if e.err != nil {
|
|
||||||
return e.err
|
|
||||||
}
|
|
||||||
|
|
||||||
e.marshal("", reflect.ValueOf(v), true)
|
|
||||||
|
|
||||||
yaml_document_end_event_initialize(&e.event, true)
|
|
||||||
e.emit()
|
|
||||||
e.emitter.open_ended = false
|
|
||||||
yaml_stream_end_event_initialize(&e.event)
|
|
||||||
e.emit()
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emit() {
|
|
||||||
if !yaml_emitter_emit(&e.emitter, &e.event) {
|
|
||||||
panic("bad emit")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) marshal(tag string, v reflect.Value, allowAddr bool) {
|
|
||||||
vt := v.Type()
|
|
||||||
|
|
||||||
if vt.Implements(marshalerType) {
|
|
||||||
e.emitMarshaler(tag, v)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if vt.Kind() != reflect.Ptr && allowAddr {
|
|
||||||
if reflect.PtrTo(vt).Implements(marshalerType) {
|
|
||||||
e.emitAddrMarshaler(tag, v)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
switch v.Kind() {
|
|
||||||
case reflect.Interface:
|
|
||||||
if v.IsNil() {
|
|
||||||
e.emitNil()
|
|
||||||
} else {
|
|
||||||
e.marshal(tag, v.Elem(), allowAddr)
|
|
||||||
}
|
|
||||||
case reflect.Map:
|
|
||||||
e.emitMap(tag, v)
|
|
||||||
case reflect.Ptr:
|
|
||||||
if v.IsNil() {
|
|
||||||
e.emitNil()
|
|
||||||
} else {
|
|
||||||
e.marshal(tag, v.Elem(), true)
|
|
||||||
}
|
|
||||||
case reflect.Struct:
|
|
||||||
e.emitStruct(tag, v)
|
|
||||||
case reflect.Slice:
|
|
||||||
e.emitSlice(tag, v)
|
|
||||||
case reflect.String:
|
|
||||||
e.emitString(tag, v)
|
|
||||||
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
|
|
||||||
e.emitInt(tag, v)
|
|
||||||
case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr:
|
|
||||||
e.emitUint(tag, v)
|
|
||||||
case reflect.Float32, reflect.Float64:
|
|
||||||
e.emitFloat(tag, v)
|
|
||||||
case reflect.Bool:
|
|
||||||
e.emitBool(tag, v)
|
|
||||||
default:
|
|
||||||
panic("Can't marshal type yet: " + v.Type().String())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitMap(tag string, v reflect.Value) {
|
|
||||||
e.mapping(tag, func() {
|
|
||||||
var keys stringValues = v.MapKeys()
|
|
||||||
sort.Sort(keys)
|
|
||||||
for _, k := range keys {
|
|
||||||
e.marshal("", k, true)
|
|
||||||
e.marshal("", v.MapIndex(k), true)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitStruct(tag string, v reflect.Value) {
|
|
||||||
if v.Type() == timeTimeType {
|
|
||||||
e.emitTime(tag, v)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
fields := cachedTypeFields(v.Type())
|
|
||||||
|
|
||||||
e.mapping(tag, func() {
|
|
||||||
for _, f := range fields {
|
|
||||||
fv := fieldByIndex(v, f.index)
|
|
||||||
if !fv.IsValid() || f.omitEmpty && isEmptyValue(fv) {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
e.marshal("", reflect.ValueOf(f.name), true)
|
|
||||||
e.flow = f.flow
|
|
||||||
e.marshal("", fv, true)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitTime(tag string, v reflect.Value) {
|
|
||||||
t := v.Interface().(time.Time)
|
|
||||||
bytes, _ := t.MarshalText()
|
|
||||||
e.emitScalar(string(bytes), "", tag, yaml_PLAIN_SCALAR_STYLE)
|
|
||||||
}
|
|
||||||
|
|
||||||
func isEmptyValue(v reflect.Value) bool {
|
|
||||||
switch v.Kind() {
|
|
||||||
case reflect.Array, reflect.Map, reflect.Slice, reflect.String:
|
|
||||||
return v.Len() == 0
|
|
||||||
case reflect.Bool:
|
|
||||||
return !v.Bool()
|
|
||||||
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
|
|
||||||
return v.Int() == 0
|
|
||||||
case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr:
|
|
||||||
return v.Uint() == 0
|
|
||||||
case reflect.Float32, reflect.Float64:
|
|
||||||
return v.Float() == 0
|
|
||||||
case reflect.Interface, reflect.Ptr:
|
|
||||||
return v.IsNil()
|
|
||||||
}
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) mapping(tag string, f func()) {
|
|
||||||
implicit := tag == ""
|
|
||||||
style := yaml_BLOCK_MAPPING_STYLE
|
|
||||||
if e.flow {
|
|
||||||
e.flow = false
|
|
||||||
style = yaml_FLOW_MAPPING_STYLE
|
|
||||||
}
|
|
||||||
yaml_mapping_start_event_initialize(&e.event, nil, []byte(tag), implicit, style)
|
|
||||||
e.emit()
|
|
||||||
|
|
||||||
f()
|
|
||||||
|
|
||||||
yaml_mapping_end_event_initialize(&e.event)
|
|
||||||
e.emit()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitSlice(tag string, v reflect.Value) {
|
|
||||||
if v.Type() == byteSliceType {
|
|
||||||
e.emitBase64(tag, v)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
implicit := tag == ""
|
|
||||||
style := yaml_BLOCK_SEQUENCE_STYLE
|
|
||||||
if e.flow {
|
|
||||||
e.flow = false
|
|
||||||
style = yaml_FLOW_SEQUENCE_STYLE
|
|
||||||
}
|
|
||||||
yaml_sequence_start_event_initialize(&e.event, nil, []byte(tag), implicit, style)
|
|
||||||
e.emit()
|
|
||||||
|
|
||||||
n := v.Len()
|
|
||||||
for i := 0; i < n; i++ {
|
|
||||||
e.marshal("", v.Index(i), true)
|
|
||||||
}
|
|
||||||
|
|
||||||
yaml_sequence_end_event_initialize(&e.event)
|
|
||||||
e.emit()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitBase64(tag string, v reflect.Value) {
|
|
||||||
if v.IsNil() {
|
|
||||||
e.emitNil()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
s := v.Bytes()
|
|
||||||
|
|
||||||
dst := make([]byte, base64.StdEncoding.EncodedLen(len(s)))
|
|
||||||
|
|
||||||
base64.StdEncoding.Encode(dst, s)
|
|
||||||
e.emitScalar(string(dst), "", yaml_BINARY_TAG, yaml_DOUBLE_QUOTED_SCALAR_STYLE)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitString(tag string, v reflect.Value) {
|
|
||||||
var style yaml_scalar_style_t
|
|
||||||
s := v.String()
|
|
||||||
|
|
||||||
if nonPrintable.MatchString(s) {
|
|
||||||
e.emitBase64(tag, v)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if v.Type() == numberType {
|
|
||||||
style = yaml_PLAIN_SCALAR_STYLE
|
|
||||||
} else {
|
|
||||||
event := yaml_event_t{
|
|
||||||
implicit: true,
|
|
||||||
value: []byte(s),
|
|
||||||
}
|
|
||||||
|
|
||||||
rtag, _ := resolveInterface(event, false)
|
|
||||||
if tag == "" && rtag != yaml_STR_TAG {
|
|
||||||
style = yaml_DOUBLE_QUOTED_SCALAR_STYLE
|
|
||||||
} else if multiline.MatchString(s) {
|
|
||||||
style = yaml_LITERAL_SCALAR_STYLE
|
|
||||||
} else {
|
|
||||||
style = yaml_PLAIN_SCALAR_STYLE
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
e.emitScalar(s, "", tag, style)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitBool(tag string, v reflect.Value) {
|
|
||||||
s := strconv.FormatBool(v.Bool())
|
|
||||||
e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitInt(tag string, v reflect.Value) {
|
|
||||||
s := strconv.FormatInt(v.Int(), 10)
|
|
||||||
e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitUint(tag string, v reflect.Value) {
|
|
||||||
s := strconv.FormatUint(v.Uint(), 10)
|
|
||||||
e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitFloat(tag string, v reflect.Value) {
|
|
||||||
f := v.Float()
|
|
||||||
|
|
||||||
var s string
|
|
||||||
switch {
|
|
||||||
case math.IsNaN(f):
|
|
||||||
s = ".nan"
|
|
||||||
case math.IsInf(f, 1):
|
|
||||||
s = "+.inf"
|
|
||||||
case math.IsInf(f, -1):
|
|
||||||
s = "-.inf"
|
|
||||||
default:
|
|
||||||
s = strconv.FormatFloat(f, 'g', -1, v.Type().Bits())
|
|
||||||
}
|
|
||||||
|
|
||||||
e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitNil() {
|
|
||||||
e.emitScalar("null", "", "", yaml_PLAIN_SCALAR_STYLE)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitScalar(value, anchor, tag string, style yaml_scalar_style_t) {
|
|
||||||
implicit := tag == ""
|
|
||||||
if !implicit {
|
|
||||||
style = yaml_PLAIN_SCALAR_STYLE
|
|
||||||
}
|
|
||||||
|
|
||||||
stag := shortTags[tag]
|
|
||||||
if stag == "" {
|
|
||||||
stag = tag
|
|
||||||
}
|
|
||||||
|
|
||||||
yaml_scalar_event_initialize(&e.event, []byte(anchor), []byte(stag), []byte(value), implicit, implicit, style)
|
|
||||||
e.emit()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitMarshaler(tag string, v reflect.Value) {
|
|
||||||
if v.Kind() == reflect.Ptr && v.IsNil() {
|
|
||||||
e.emitNil()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
m := v.Interface().(Marshaler)
|
|
||||||
if m == nil {
|
|
||||||
e.emitNil()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
t, val, err := m.MarshalYAML()
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
if val == nil {
|
|
||||||
e.emitNil()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
e.marshal(t, reflect.ValueOf(val), false)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (e *Encoder) emitAddrMarshaler(tag string, v reflect.Value) {
|
|
||||||
if !v.CanAddr() {
|
|
||||||
e.marshal(tag, v, false)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
va := v.Addr()
|
|
||||||
if va.IsNil() {
|
|
||||||
e.emitNil()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
m := v.Interface().(Marshaler)
|
|
||||||
t, val, err := m.MarshalYAML()
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if val == nil {
|
|
||||||
e.emitNil()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
e.marshal(t, reflect.ValueOf(val), false)
|
|
||||||
}
|
|
1230
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/parser.go
generated
vendored
1230
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/parser.go
generated
vendored
File diff suppressed because it is too large
Load diff
465
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/reader.go
generated
vendored
465
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/reader.go
generated
vendored
|
@ -1,465 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set the reader error and return 0.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_parser_set_reader_error(parser *yaml_parser_t, problem string,
|
|
||||||
offset int, value int) bool {
|
|
||||||
parser.error = yaml_READER_ERROR
|
|
||||||
parser.problem = problem
|
|
||||||
parser.problem_offset = offset
|
|
||||||
parser.problem_value = value
|
|
||||||
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Byte order marks.
|
|
||||||
*/
|
|
||||||
const (
|
|
||||||
BOM_UTF8 = "\xef\xbb\xbf"
|
|
||||||
BOM_UTF16LE = "\xff\xfe"
|
|
||||||
BOM_UTF16BE = "\xfe\xff"
|
|
||||||
)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Determine the input stream encoding by checking the BOM symbol. If no BOM is
|
|
||||||
* found, the UTF-8 encoding is assumed. Return 1 on success, 0 on failure.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_parser_determine_encoding(parser *yaml_parser_t) bool {
|
|
||||||
/* Ensure that we had enough bytes in the raw buffer. */
|
|
||||||
for !parser.eof &&
|
|
||||||
len(parser.raw_buffer)-parser.raw_buffer_pos < 3 {
|
|
||||||
if !yaml_parser_update_raw_buffer(parser) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Determine the encoding. */
|
|
||||||
raw := parser.raw_buffer
|
|
||||||
pos := parser.raw_buffer_pos
|
|
||||||
remaining := len(raw) - pos
|
|
||||||
if remaining >= 2 &&
|
|
||||||
raw[pos] == BOM_UTF16LE[0] && raw[pos+1] == BOM_UTF16LE[1] {
|
|
||||||
parser.encoding = yaml_UTF16LE_ENCODING
|
|
||||||
parser.raw_buffer_pos += 2
|
|
||||||
parser.offset += 2
|
|
||||||
} else if remaining >= 2 &&
|
|
||||||
raw[pos] == BOM_UTF16BE[0] && raw[pos+1] == BOM_UTF16BE[1] {
|
|
||||||
parser.encoding = yaml_UTF16BE_ENCODING
|
|
||||||
parser.raw_buffer_pos += 2
|
|
||||||
parser.offset += 2
|
|
||||||
} else if remaining >= 3 &&
|
|
||||||
raw[pos] == BOM_UTF8[0] && raw[pos+1] == BOM_UTF8[1] && raw[pos+2] == BOM_UTF8[2] {
|
|
||||||
parser.encoding = yaml_UTF8_ENCODING
|
|
||||||
parser.raw_buffer_pos += 3
|
|
||||||
parser.offset += 3
|
|
||||||
} else {
|
|
||||||
parser.encoding = yaml_UTF8_ENCODING
|
|
||||||
}
|
|
||||||
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Update the raw buffer.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_parser_update_raw_buffer(parser *yaml_parser_t) bool {
|
|
||||||
size_read := 0
|
|
||||||
|
|
||||||
/* Return if the raw buffer is full. */
|
|
||||||
if parser.raw_buffer_pos == 0 && len(parser.raw_buffer) == cap(parser.raw_buffer) {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Return on EOF. */
|
|
||||||
|
|
||||||
if parser.eof {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Move the remaining bytes in the raw buffer to the beginning. */
|
|
||||||
if parser.raw_buffer_pos > 0 && parser.raw_buffer_pos < len(parser.raw_buffer) {
|
|
||||||
copy(parser.raw_buffer, parser.raw_buffer[parser.raw_buffer_pos:])
|
|
||||||
}
|
|
||||||
parser.raw_buffer = parser.raw_buffer[:len(parser.raw_buffer)-parser.raw_buffer_pos]
|
|
||||||
parser.raw_buffer_pos = 0
|
|
||||||
|
|
||||||
/* Call the read handler to fill the buffer. */
|
|
||||||
size_read, err := parser.read_handler(parser,
|
|
||||||
parser.raw_buffer[len(parser.raw_buffer):cap(parser.raw_buffer)])
|
|
||||||
parser.raw_buffer = parser.raw_buffer[:len(parser.raw_buffer)+size_read]
|
|
||||||
|
|
||||||
if err == io.EOF {
|
|
||||||
parser.eof = true
|
|
||||||
} else if err != nil {
|
|
||||||
return yaml_parser_set_reader_error(parser, "input error: "+err.Error(),
|
|
||||||
parser.offset, -1)
|
|
||||||
}
|
|
||||||
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Ensure that the buffer contains at least `length` characters.
|
|
||||||
* Return 1 on success, 0 on failure.
|
|
||||||
*
|
|
||||||
* The length is supposed to be significantly less that the buffer size.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_parser_update_buffer(parser *yaml_parser_t, length int) bool {
|
|
||||||
/* Read handler must be set. */
|
|
||||||
if parser.read_handler == nil {
|
|
||||||
panic("read handler must be set")
|
|
||||||
}
|
|
||||||
|
|
||||||
/* If the EOF flag is set and the raw buffer is empty, do nothing. */
|
|
||||||
|
|
||||||
if parser.eof && parser.raw_buffer_pos == len(parser.raw_buffer) {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Return if the buffer contains enough characters. */
|
|
||||||
|
|
||||||
if parser.unread >= length {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Determine the input encoding if it is not known yet. */
|
|
||||||
|
|
||||||
if parser.encoding == yaml_ANY_ENCODING {
|
|
||||||
if !yaml_parser_determine_encoding(parser) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Move the unread characters to the beginning of the buffer. */
|
|
||||||
buffer_end := len(parser.buffer)
|
|
||||||
if 0 < parser.buffer_pos &&
|
|
||||||
parser.buffer_pos < buffer_end {
|
|
||||||
copy(parser.buffer, parser.buffer[parser.buffer_pos:])
|
|
||||||
buffer_end -= parser.buffer_pos
|
|
||||||
parser.buffer_pos = 0
|
|
||||||
} else if parser.buffer_pos == buffer_end {
|
|
||||||
buffer_end = 0
|
|
||||||
parser.buffer_pos = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
parser.buffer = parser.buffer[:cap(parser.buffer)]
|
|
||||||
|
|
||||||
/* Fill the buffer until it has enough characters. */
|
|
||||||
first := true
|
|
||||||
for parser.unread < length {
|
|
||||||
/* Fill the raw buffer if necessary. */
|
|
||||||
|
|
||||||
if !first || parser.raw_buffer_pos == len(parser.raw_buffer) {
|
|
||||||
if !yaml_parser_update_raw_buffer(parser) {
|
|
||||||
parser.buffer = parser.buffer[:buffer_end]
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
first = false
|
|
||||||
|
|
||||||
/* Decode the raw buffer. */
|
|
||||||
for parser.raw_buffer_pos != len(parser.raw_buffer) {
|
|
||||||
var value rune
|
|
||||||
var w int
|
|
||||||
|
|
||||||
raw_unread := len(parser.raw_buffer) - parser.raw_buffer_pos
|
|
||||||
incomplete := false
|
|
||||||
|
|
||||||
/* Decode the next character. */
|
|
||||||
|
|
||||||
switch parser.encoding {
|
|
||||||
case yaml_UTF8_ENCODING:
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Decode a UTF-8 character. Check RFC 3629
|
|
||||||
* (http://www.ietf.org/rfc/rfc3629.txt) for more details.
|
|
||||||
*
|
|
||||||
* The following table (taken from the RFC) is used for
|
|
||||||
* decoding.
|
|
||||||
*
|
|
||||||
* Char. number range | UTF-8 octet sequence
|
|
||||||
* (hexadecimal) | (binary)
|
|
||||||
* --------------------+------------------------------------
|
|
||||||
* 0000 0000-0000 007F | 0xxxxxxx
|
|
||||||
* 0000 0080-0000 07FF | 110xxxxx 10xxxxxx
|
|
||||||
* 0000 0800-0000 FFFF | 1110xxxx 10xxxxxx 10xxxxxx
|
|
||||||
* 0001 0000-0010 FFFF | 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
|
|
||||||
*
|
|
||||||
* Additionally, the characters in the range 0xD800-0xDFFF
|
|
||||||
* are prohibited as they are reserved for use with UTF-16
|
|
||||||
* surrogate pairs.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Determine the length of the UTF-8 sequence. */
|
|
||||||
|
|
||||||
octet := parser.raw_buffer[parser.raw_buffer_pos]
|
|
||||||
w = width(octet)
|
|
||||||
|
|
||||||
/* Check if the leading octet is valid. */
|
|
||||||
|
|
||||||
if w == 0 {
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"invalid leading UTF-8 octet",
|
|
||||||
parser.offset, int(octet))
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check if the raw buffer contains an incomplete character. */
|
|
||||||
|
|
||||||
if w > raw_unread {
|
|
||||||
if parser.eof {
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"incomplete UTF-8 octet sequence",
|
|
||||||
parser.offset, -1)
|
|
||||||
}
|
|
||||||
incomplete = true
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Decode the leading octet. */
|
|
||||||
switch {
|
|
||||||
case octet&0x80 == 0x00:
|
|
||||||
value = rune(octet & 0x7F)
|
|
||||||
case octet&0xE0 == 0xC0:
|
|
||||||
value = rune(octet & 0x1F)
|
|
||||||
case octet&0xF0 == 0xE0:
|
|
||||||
value = rune(octet & 0x0F)
|
|
||||||
case octet&0xF8 == 0xF0:
|
|
||||||
value = rune(octet & 0x07)
|
|
||||||
default:
|
|
||||||
value = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check and decode the trailing octets. */
|
|
||||||
|
|
||||||
for k := 1; k < w; k++ {
|
|
||||||
octet = parser.raw_buffer[parser.raw_buffer_pos+k]
|
|
||||||
|
|
||||||
/* Check if the octet is valid. */
|
|
||||||
|
|
||||||
if (octet & 0xC0) != 0x80 {
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"invalid trailing UTF-8 octet",
|
|
||||||
parser.offset+k, int(octet))
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Decode the octet. */
|
|
||||||
|
|
||||||
value = (value << 6) + rune(octet&0x3F)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check the length of the sequence against the value. */
|
|
||||||
switch {
|
|
||||||
case w == 1:
|
|
||||||
case w == 2 && value >= 0x80:
|
|
||||||
case w == 3 && value >= 0x800:
|
|
||||||
case w == 4 && value >= 0x10000:
|
|
||||||
default:
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"invalid length of a UTF-8 sequence",
|
|
||||||
parser.offset, -1)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check the range of the value. */
|
|
||||||
|
|
||||||
if (value >= 0xD800 && value <= 0xDFFF) || value > 0x10FFFF {
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"invalid Unicode character",
|
|
||||||
parser.offset, int(value))
|
|
||||||
}
|
|
||||||
case yaml_UTF16LE_ENCODING,
|
|
||||||
yaml_UTF16BE_ENCODING:
|
|
||||||
|
|
||||||
var low, high int
|
|
||||||
if parser.encoding == yaml_UTF16LE_ENCODING {
|
|
||||||
low, high = 0, 1
|
|
||||||
} else {
|
|
||||||
high, low = 1, 0
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The UTF-16 encoding is not as simple as one might
|
|
||||||
* naively think. Check RFC 2781
|
|
||||||
* (http://www.ietf.org/rfc/rfc2781.txt).
|
|
||||||
*
|
|
||||||
* Normally, two subsequent bytes describe a Unicode
|
|
||||||
* character. However a special technique (called a
|
|
||||||
* surrogate pair) is used for specifying character
|
|
||||||
* values larger than 0xFFFF.
|
|
||||||
*
|
|
||||||
* A surrogate pair consists of two pseudo-characters:
|
|
||||||
* high surrogate area (0xD800-0xDBFF)
|
|
||||||
* low surrogate area (0xDC00-0xDFFF)
|
|
||||||
*
|
|
||||||
* The following formulas are used for decoding
|
|
||||||
* and encoding characters using surrogate pairs:
|
|
||||||
*
|
|
||||||
* U = U' + 0x10000 (0x01 00 00 <= U <= 0x10 FF FF)
|
|
||||||
* U' = yyyyyyyyyyxxxxxxxxxx (0 <= U' <= 0x0F FF FF)
|
|
||||||
* W1 = 110110yyyyyyyyyy
|
|
||||||
* W2 = 110111xxxxxxxxxx
|
|
||||||
*
|
|
||||||
* where U is the character value, W1 is the high surrogate
|
|
||||||
* area, W2 is the low surrogate area.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Check for incomplete UTF-16 character. */
|
|
||||||
|
|
||||||
if raw_unread < 2 {
|
|
||||||
if parser.eof {
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"incomplete UTF-16 character",
|
|
||||||
parser.offset, -1)
|
|
||||||
}
|
|
||||||
incomplete = true
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Get the character. */
|
|
||||||
value = rune(parser.raw_buffer[parser.raw_buffer_pos+low]) +
|
|
||||||
(rune(parser.raw_buffer[parser.raw_buffer_pos+high]) << 8)
|
|
||||||
|
|
||||||
/* Check for unexpected low surrogate area. */
|
|
||||||
|
|
||||||
if (value & 0xFC00) == 0xDC00 {
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"unexpected low surrogate area",
|
|
||||||
parser.offset, int(value))
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check for a high surrogate area. */
|
|
||||||
|
|
||||||
if (value & 0xFC00) == 0xD800 {
|
|
||||||
|
|
||||||
w = 4
|
|
||||||
|
|
||||||
/* Check for incomplete surrogate pair. */
|
|
||||||
|
|
||||||
if raw_unread < 4 {
|
|
||||||
if parser.eof {
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"incomplete UTF-16 surrogate pair",
|
|
||||||
parser.offset, -1)
|
|
||||||
}
|
|
||||||
incomplete = true
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Get the next character. */
|
|
||||||
|
|
||||||
value2 := rune(parser.raw_buffer[parser.raw_buffer_pos+low+2]) +
|
|
||||||
(rune(parser.raw_buffer[parser.raw_buffer_pos+high+2]) << 8)
|
|
||||||
|
|
||||||
/* Check for a low surrogate area. */
|
|
||||||
|
|
||||||
if (value2 & 0xFC00) != 0xDC00 {
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"expected low surrogate area",
|
|
||||||
parser.offset+2, int(value2))
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Generate the value of the surrogate pair. */
|
|
||||||
|
|
||||||
value = 0x10000 + ((value & 0x3FF) << 10) + (value2 & 0x3FF)
|
|
||||||
} else {
|
|
||||||
w = 2
|
|
||||||
}
|
|
||||||
|
|
||||||
break
|
|
||||||
|
|
||||||
default:
|
|
||||||
panic("Impossible") /* Impossible. */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check if the raw buffer contains enough bytes to form a character. */
|
|
||||||
|
|
||||||
if incomplete {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Check if the character is in the allowed range:
|
|
||||||
* #x9 | #xA | #xD | [#x20-#x7E] (8 bit)
|
|
||||||
* | #x85 | [#xA0-#xD7FF] | [#xE000-#xFFFD] (16 bit)
|
|
||||||
* | [#x10000-#x10FFFF] (32 bit)
|
|
||||||
*/
|
|
||||||
|
|
||||||
if !(value == 0x09 || value == 0x0A || value == 0x0D ||
|
|
||||||
(value >= 0x20 && value <= 0x7E) ||
|
|
||||||
(value == 0x85) || (value >= 0xA0 && value <= 0xD7FF) ||
|
|
||||||
(value >= 0xE000 && value <= 0xFFFD) ||
|
|
||||||
(value >= 0x10000 && value <= 0x10FFFF)) {
|
|
||||||
return yaml_parser_set_reader_error(parser,
|
|
||||||
"control characters are not allowed",
|
|
||||||
parser.offset, int(value))
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Move the raw pointers. */
|
|
||||||
|
|
||||||
parser.raw_buffer_pos += w
|
|
||||||
parser.offset += w
|
|
||||||
|
|
||||||
/* Finally put the character into the buffer. */
|
|
||||||
|
|
||||||
/* 0000 0000-0000 007F . 0xxxxxxx */
|
|
||||||
if value <= 0x7F {
|
|
||||||
parser.buffer[buffer_end] = byte(value)
|
|
||||||
} else if value <= 0x7FF {
|
|
||||||
/* 0000 0080-0000 07FF . 110xxxxx 10xxxxxx */
|
|
||||||
parser.buffer[buffer_end] = byte(0xC0 + (value >> 6))
|
|
||||||
parser.buffer[buffer_end+1] = byte(0x80 + (value & 0x3F))
|
|
||||||
} else if value <= 0xFFFF {
|
|
||||||
/* 0000 0800-0000 FFFF . 1110xxxx 10xxxxxx 10xxxxxx */
|
|
||||||
parser.buffer[buffer_end] = byte(0xE0 + (value >> 12))
|
|
||||||
parser.buffer[buffer_end+1] = byte(0x80 + ((value >> 6) & 0x3F))
|
|
||||||
parser.buffer[buffer_end+2] = byte(0x80 + (value & 0x3F))
|
|
||||||
} else {
|
|
||||||
/* 0001 0000-0010 FFFF . 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx */
|
|
||||||
parser.buffer[buffer_end] = byte(0xF0 + (value >> 18))
|
|
||||||
parser.buffer[buffer_end+1] = byte(0x80 + ((value >> 12) & 0x3F))
|
|
||||||
parser.buffer[buffer_end+2] = byte(0x80 + ((value >> 6) & 0x3F))
|
|
||||||
parser.buffer[buffer_end+3] = byte(0x80 + (value & 0x3F))
|
|
||||||
}
|
|
||||||
|
|
||||||
buffer_end += w
|
|
||||||
parser.unread++
|
|
||||||
}
|
|
||||||
|
|
||||||
/* On EOF, put NUL into the buffer and return. */
|
|
||||||
|
|
||||||
if parser.eof {
|
|
||||||
parser.buffer[buffer_end] = 0
|
|
||||||
buffer_end++
|
|
||||||
parser.buffer = parser.buffer[:buffer_end]
|
|
||||||
parser.unread++
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
parser.buffer = parser.buffer[:buffer_end]
|
|
||||||
return true
|
|
||||||
}
|
|
449
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/resolver.go
generated
vendored
449
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/resolver.go
generated
vendored
|
@ -1,449 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"encoding/base64"
|
|
||||||
"fmt"
|
|
||||||
"math"
|
|
||||||
"reflect"
|
|
||||||
"regexp"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
var byteSliceType = reflect.TypeOf([]byte(nil))
|
|
||||||
|
|
||||||
var binary_tags = [][]byte{[]byte("!binary"), []byte(yaml_BINARY_TAG)}
|
|
||||||
var bool_values map[string]bool
|
|
||||||
var null_values map[string]bool
|
|
||||||
|
|
||||||
var signs = []byte{'-', '+'}
|
|
||||||
var nulls = []byte{'~', 'n', 'N'}
|
|
||||||
var bools = []byte{'t', 'T', 'f', 'F', 'y', 'Y', 'n', 'N', 'o', 'O'}
|
|
||||||
|
|
||||||
var timestamp_regexp *regexp.Regexp
|
|
||||||
var ymd_regexp *regexp.Regexp
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
bool_values = make(map[string]bool)
|
|
||||||
bool_values["y"] = true
|
|
||||||
bool_values["yes"] = true
|
|
||||||
bool_values["n"] = false
|
|
||||||
bool_values["no"] = false
|
|
||||||
bool_values["true"] = true
|
|
||||||
bool_values["false"] = false
|
|
||||||
bool_values["on"] = true
|
|
||||||
bool_values["off"] = false
|
|
||||||
|
|
||||||
null_values = make(map[string]bool)
|
|
||||||
null_values["~"] = true
|
|
||||||
null_values["null"] = true
|
|
||||||
null_values["Null"] = true
|
|
||||||
null_values["NULL"] = true
|
|
||||||
|
|
||||||
timestamp_regexp = regexp.MustCompile("^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)(?:(?:[Tt]|[ \t]+)([0-9][0-9]?):([0-9][0-9]):([0-9][0-9])(?:\\.([0-9]*))?(?:[ \t]*(?:Z|([-+][0-9][0-9]?)(?::([0-9][0-9])?)?))?)?$")
|
|
||||||
ymd_regexp = regexp.MustCompile("^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)$")
|
|
||||||
}
|
|
||||||
|
|
||||||
func resolve(event yaml_event_t, v reflect.Value, useNumber bool) (string, error) {
|
|
||||||
val := string(event.value)
|
|
||||||
|
|
||||||
if null_values[val] {
|
|
||||||
v.Set(reflect.Zero(v.Type()))
|
|
||||||
return yaml_NULL_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
switch v.Kind() {
|
|
||||||
case reflect.String:
|
|
||||||
if useNumber && v.Type() == numberType {
|
|
||||||
tag, i := resolveInterface(event, useNumber)
|
|
||||||
if n, ok := i.(Number); ok {
|
|
||||||
v.Set(reflect.ValueOf(n))
|
|
||||||
return tag, nil
|
|
||||||
}
|
|
||||||
return "", fmt.Errorf("Not a number: '%s' at %s", event.value, event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
return resolve_string(val, v, event)
|
|
||||||
case reflect.Bool:
|
|
||||||
return resolve_bool(val, v, event)
|
|
||||||
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
|
|
||||||
return resolve_int(val, v, useNumber, event)
|
|
||||||
case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64:
|
|
||||||
return resolve_uint(val, v, useNumber, event)
|
|
||||||
case reflect.Float32, reflect.Float64:
|
|
||||||
return resolve_float(val, v, useNumber, event)
|
|
||||||
case reflect.Interface:
|
|
||||||
_, i := resolveInterface(event, useNumber)
|
|
||||||
if i != nil {
|
|
||||||
v.Set(reflect.ValueOf(i))
|
|
||||||
} else {
|
|
||||||
v.Set(reflect.Zero(v.Type()))
|
|
||||||
}
|
|
||||||
|
|
||||||
case reflect.Struct:
|
|
||||||
return resolve_time(val, v, event)
|
|
||||||
case reflect.Slice:
|
|
||||||
if v.Type() != byteSliceType {
|
|
||||||
return "", fmt.Errorf("Cannot resolve %s into %s at %s", val, v.String(), event.start_mark)
|
|
||||||
}
|
|
||||||
b, err := decode_binary(event.value, event)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
v.Set(reflect.ValueOf(b))
|
|
||||||
default:
|
|
||||||
return "", fmt.Errorf("Unknown resolution for '%s' using %s at %s", val, v.String(), event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
return yaml_STR_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func hasBinaryTag(event yaml_event_t) bool {
|
|
||||||
for _, tag := range binary_tags {
|
|
||||||
if bytes.Equal(event.tag, tag) {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
func decode_binary(value []byte, event yaml_event_t) ([]byte, error) {
|
|
||||||
b := make([]byte, base64.StdEncoding.DecodedLen(len(value)))
|
|
||||||
n, err := base64.StdEncoding.Decode(b, value)
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("Invalid base64 text: '%s' at %s", string(b), event.start_mark)
|
|
||||||
}
|
|
||||||
return b[:n], nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func resolve_string(val string, v reflect.Value, event yaml_event_t) (string, error) {
|
|
||||||
if len(event.tag) > 0 {
|
|
||||||
if hasBinaryTag(event) {
|
|
||||||
b, err := decode_binary(event.value, event)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
val = string(b)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
v.SetString(val)
|
|
||||||
return yaml_STR_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func resolve_bool(val string, v reflect.Value, event yaml_event_t) (string, error) {
|
|
||||||
b, found := bool_values[strings.ToLower(val)]
|
|
||||||
if !found {
|
|
||||||
return "", fmt.Errorf("Invalid boolean: '%s' at %s", val, event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
v.SetBool(b)
|
|
||||||
return yaml_BOOL_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func resolve_int(val string, v reflect.Value, useNumber bool, event yaml_event_t) (string, error) {
|
|
||||||
original := val
|
|
||||||
val = strings.Replace(val, "_", "", -1)
|
|
||||||
var value uint64
|
|
||||||
|
|
||||||
isNumberValue := v.Type() == numberType
|
|
||||||
|
|
||||||
sign := int64(1)
|
|
||||||
if val[0] == '-' {
|
|
||||||
sign = -1
|
|
||||||
val = val[1:]
|
|
||||||
} else if val[0] == '+' {
|
|
||||||
val = val[1:]
|
|
||||||
}
|
|
||||||
|
|
||||||
base := 0
|
|
||||||
if val == "0" {
|
|
||||||
if isNumberValue {
|
|
||||||
v.SetString("0")
|
|
||||||
} else {
|
|
||||||
v.Set(reflect.Zero(v.Type()))
|
|
||||||
}
|
|
||||||
|
|
||||||
return yaml_INT_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
if strings.HasPrefix(val, "0o") {
|
|
||||||
base = 8
|
|
||||||
val = val[2:]
|
|
||||||
}
|
|
||||||
|
|
||||||
value, err := strconv.ParseUint(val, base, 64)
|
|
||||||
if err != nil {
|
|
||||||
return "", fmt.Errorf("Invalid integer: '%s' at %s", original, event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
var val64 int64
|
|
||||||
if value <= math.MaxInt64 {
|
|
||||||
val64 = int64(value)
|
|
||||||
if sign == -1 {
|
|
||||||
val64 = -val64
|
|
||||||
}
|
|
||||||
} else if sign == -1 && value == uint64(math.MaxInt64)+1 {
|
|
||||||
val64 = math.MinInt64
|
|
||||||
} else {
|
|
||||||
return "", fmt.Errorf("Invalid integer: '%s' at %s", original, event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
if isNumberValue {
|
|
||||||
v.SetString(strconv.FormatInt(val64, 10))
|
|
||||||
} else {
|
|
||||||
if v.OverflowInt(val64) {
|
|
||||||
return "", fmt.Errorf("Invalid integer: '%s' at %s", original, event.start_mark)
|
|
||||||
}
|
|
||||||
v.SetInt(val64)
|
|
||||||
}
|
|
||||||
|
|
||||||
return yaml_INT_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func resolve_uint(val string, v reflect.Value, useNumber bool, event yaml_event_t) (string, error) {
|
|
||||||
original := val
|
|
||||||
val = strings.Replace(val, "_", "", -1)
|
|
||||||
var value uint64
|
|
||||||
|
|
||||||
isNumberValue := v.Type() == numberType
|
|
||||||
|
|
||||||
if val[0] == '-' {
|
|
||||||
return "", fmt.Errorf("Unsigned int with negative value: '%s' at %s", original, event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
if val[0] == '+' {
|
|
||||||
val = val[1:]
|
|
||||||
}
|
|
||||||
|
|
||||||
base := 0
|
|
||||||
if val == "0" {
|
|
||||||
if isNumberValue {
|
|
||||||
v.SetString("0")
|
|
||||||
} else {
|
|
||||||
v.Set(reflect.Zero(v.Type()))
|
|
||||||
}
|
|
||||||
|
|
||||||
return yaml_INT_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
if strings.HasPrefix(val, "0o") {
|
|
||||||
base = 8
|
|
||||||
val = val[2:]
|
|
||||||
}
|
|
||||||
|
|
||||||
value, err := strconv.ParseUint(val, base, 64)
|
|
||||||
if err != nil {
|
|
||||||
return "", fmt.Errorf("Invalid unsigned integer: '%s' at %s", val, event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
if isNumberValue {
|
|
||||||
v.SetString(strconv.FormatUint(value, 10))
|
|
||||||
} else {
|
|
||||||
if v.OverflowUint(value) {
|
|
||||||
return "", fmt.Errorf("Invalid unsigned integer: '%s' at %s", val, event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
v.SetUint(value)
|
|
||||||
}
|
|
||||||
|
|
||||||
return yaml_INT_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func resolve_float(val string, v reflect.Value, useNumber bool, event yaml_event_t) (string, error) {
|
|
||||||
val = strings.Replace(val, "_", "", -1)
|
|
||||||
var value float64
|
|
||||||
|
|
||||||
isNumberValue := v.Type() == numberType
|
|
||||||
typeBits := 64
|
|
||||||
if !isNumberValue {
|
|
||||||
typeBits = v.Type().Bits()
|
|
||||||
}
|
|
||||||
|
|
||||||
sign := 1
|
|
||||||
if val[0] == '-' {
|
|
||||||
sign = -1
|
|
||||||
val = val[1:]
|
|
||||||
} else if val[0] == '+' {
|
|
||||||
val = val[1:]
|
|
||||||
}
|
|
||||||
|
|
||||||
valLower := strings.ToLower(val)
|
|
||||||
if valLower == ".inf" {
|
|
||||||
value = math.Inf(sign)
|
|
||||||
} else if valLower == ".nan" {
|
|
||||||
value = math.NaN()
|
|
||||||
} else {
|
|
||||||
var err error
|
|
||||||
value, err = strconv.ParseFloat(val, typeBits)
|
|
||||||
value *= float64(sign)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
return "", fmt.Errorf("Invalid float: '%s' at %s", val, event.start_mark)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if isNumberValue {
|
|
||||||
v.SetString(strconv.FormatFloat(value, 'g', -1, typeBits))
|
|
||||||
} else {
|
|
||||||
if v.OverflowFloat(value) {
|
|
||||||
return "", fmt.Errorf("Invalid float: '%s' at %s", val, event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
v.SetFloat(value)
|
|
||||||
}
|
|
||||||
|
|
||||||
return yaml_FLOAT_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func resolve_time(val string, v reflect.Value, event yaml_event_t) (string, error) {
|
|
||||||
var parsedTime time.Time
|
|
||||||
matches := ymd_regexp.FindStringSubmatch(val)
|
|
||||||
if len(matches) > 0 {
|
|
||||||
year, _ := strconv.Atoi(matches[1])
|
|
||||||
month, _ := strconv.Atoi(matches[2])
|
|
||||||
day, _ := strconv.Atoi(matches[3])
|
|
||||||
parsedTime = time.Date(year, time.Month(month), day, 0, 0, 0, 0, time.UTC)
|
|
||||||
} else {
|
|
||||||
matches = timestamp_regexp.FindStringSubmatch(val)
|
|
||||||
if len(matches) == 0 {
|
|
||||||
return "", fmt.Errorf("Invalid timestamp: '%s' at %s", val, event.start_mark)
|
|
||||||
}
|
|
||||||
|
|
||||||
year, _ := strconv.Atoi(matches[1])
|
|
||||||
month, _ := strconv.Atoi(matches[2])
|
|
||||||
day, _ := strconv.Atoi(matches[3])
|
|
||||||
hour, _ := strconv.Atoi(matches[4])
|
|
||||||
min, _ := strconv.Atoi(matches[5])
|
|
||||||
sec, _ := strconv.Atoi(matches[6])
|
|
||||||
|
|
||||||
nsec := 0
|
|
||||||
if matches[7] != "" {
|
|
||||||
millis, _ := strconv.Atoi(matches[7])
|
|
||||||
nsec = int(time.Duration(millis) * time.Millisecond)
|
|
||||||
}
|
|
||||||
|
|
||||||
loc := time.UTC
|
|
||||||
if matches[8] != "" {
|
|
||||||
sign := matches[8][0]
|
|
||||||
hr, _ := strconv.Atoi(matches[8][1:])
|
|
||||||
min := 0
|
|
||||||
if matches[9] != "" {
|
|
||||||
min, _ = strconv.Atoi(matches[9])
|
|
||||||
}
|
|
||||||
|
|
||||||
zoneOffset := (hr*60 + min) * 60
|
|
||||||
if sign == '-' {
|
|
||||||
zoneOffset = -zoneOffset
|
|
||||||
}
|
|
||||||
|
|
||||||
loc = time.FixedZone("", zoneOffset)
|
|
||||||
}
|
|
||||||
parsedTime = time.Date(year, time.Month(month), day, hour, min, sec, nsec, loc)
|
|
||||||
}
|
|
||||||
|
|
||||||
v.Set(reflect.ValueOf(parsedTime))
|
|
||||||
return "", nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func resolveInterface(event yaml_event_t, useNumber bool) (string, interface{}) {
|
|
||||||
val := string(event.value)
|
|
||||||
if len(event.tag) == 0 && !event.implicit {
|
|
||||||
return "", val
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(val) == 0 {
|
|
||||||
return yaml_NULL_TAG, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
var result interface{}
|
|
||||||
|
|
||||||
sign := false
|
|
||||||
c := val[0]
|
|
||||||
switch {
|
|
||||||
case bytes.IndexByte(signs, c) != -1:
|
|
||||||
sign = true
|
|
||||||
fallthrough
|
|
||||||
case c >= '0' && c <= '9':
|
|
||||||
i := int64(0)
|
|
||||||
result = &i
|
|
||||||
if useNumber {
|
|
||||||
var n Number
|
|
||||||
result = &n
|
|
||||||
}
|
|
||||||
|
|
||||||
v := reflect.ValueOf(result).Elem()
|
|
||||||
if _, err := resolve_int(val, v, useNumber, event); err == nil {
|
|
||||||
return yaml_INT_TAG, v.Interface()
|
|
||||||
}
|
|
||||||
|
|
||||||
f := float64(0)
|
|
||||||
result = &f
|
|
||||||
if useNumber {
|
|
||||||
var n Number
|
|
||||||
result = &n
|
|
||||||
}
|
|
||||||
|
|
||||||
v = reflect.ValueOf(result).Elem()
|
|
||||||
if _, err := resolve_float(val, v, useNumber, event); err == nil {
|
|
||||||
return yaml_FLOAT_TAG, v.Interface()
|
|
||||||
}
|
|
||||||
|
|
||||||
if !sign {
|
|
||||||
t := time.Time{}
|
|
||||||
if _, err := resolve_time(val, reflect.ValueOf(&t).Elem(), event); err == nil {
|
|
||||||
return "", t
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case bytes.IndexByte(nulls, c) != -1:
|
|
||||||
if null_values[val] {
|
|
||||||
return yaml_NULL_TAG, nil
|
|
||||||
}
|
|
||||||
b := false
|
|
||||||
if _, err := resolve_bool(val, reflect.ValueOf(&b).Elem(), event); err == nil {
|
|
||||||
return yaml_BOOL_TAG, b
|
|
||||||
}
|
|
||||||
case c == '.':
|
|
||||||
f := float64(0)
|
|
||||||
result = &f
|
|
||||||
if useNumber {
|
|
||||||
var n Number
|
|
||||||
result = &n
|
|
||||||
}
|
|
||||||
|
|
||||||
v := reflect.ValueOf(result).Elem()
|
|
||||||
if _, err := resolve_float(val, v, useNumber, event); err == nil {
|
|
||||||
return yaml_FLOAT_TAG, v.Interface()
|
|
||||||
}
|
|
||||||
case bytes.IndexByte(bools, c) != -1:
|
|
||||||
b := false
|
|
||||||
if _, err := resolve_bool(val, reflect.ValueOf(&b).Elem(), event); err == nil {
|
|
||||||
return yaml_BOOL_TAG, b
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if hasBinaryTag(event) {
|
|
||||||
bytes, err := decode_binary(event.value, event)
|
|
||||||
if err == nil {
|
|
||||||
return yaml_BINARY_TAG, bytes
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return yaml_STR_TAG, val
|
|
||||||
}
|
|
62
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/run_parser.go
generated
vendored
62
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/run_parser.go
generated
vendored
|
@ -1,62 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
)
|
|
||||||
|
|
||||||
func Run_parser(cmd string, args []string) {
|
|
||||||
for i := 0; i < len(args); i++ {
|
|
||||||
fmt.Printf("[%d] Scanning '%s'", i, args[i])
|
|
||||||
file, err := os.Open(args[i])
|
|
||||||
if err != nil {
|
|
||||||
panic(fmt.Sprintf("Invalid file '%s': %s", args[i], err.Error()))
|
|
||||||
}
|
|
||||||
|
|
||||||
parser := yaml_parser_t{}
|
|
||||||
yaml_parser_initialize(&parser)
|
|
||||||
yaml_parser_set_input_reader(&parser, file)
|
|
||||||
|
|
||||||
failed := false
|
|
||||||
token := yaml_token_t{}
|
|
||||||
count := 0
|
|
||||||
for {
|
|
||||||
if !yaml_parser_scan(&parser, &token) {
|
|
||||||
failed = true
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
if token.token_type == yaml_STREAM_END_TOKEN {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
count++
|
|
||||||
}
|
|
||||||
|
|
||||||
file.Close()
|
|
||||||
|
|
||||||
msg := "SUCCESS"
|
|
||||||
if failed {
|
|
||||||
msg = "FAILED"
|
|
||||||
if parser.error != yaml_NO_ERROR {
|
|
||||||
m := parser.problem_mark
|
|
||||||
fmt.Printf("ERROR: (%s) %s @ line: %d col: %d\n",
|
|
||||||
parser.context, parser.problem, m.line, m.column)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fmt.Printf("%s (%d tokens)\n", msg, count)
|
|
||||||
}
|
|
||||||
}
|
|
3318
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/scanner.go
generated
vendored
3318
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/scanner.go
generated
vendored
File diff suppressed because it is too large
Load diff
360
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/tags.go
generated
vendored
360
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/tags.go
generated
vendored
|
@ -1,360 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
import (
|
|
||||||
"reflect"
|
|
||||||
"sort"
|
|
||||||
"strings"
|
|
||||||
"sync"
|
|
||||||
"unicode"
|
|
||||||
)
|
|
||||||
|
|
||||||
// A field represents a single field found in a struct.
|
|
||||||
type field struct {
|
|
||||||
name string
|
|
||||||
tag bool
|
|
||||||
index []int
|
|
||||||
typ reflect.Type
|
|
||||||
omitEmpty bool
|
|
||||||
flow bool
|
|
||||||
}
|
|
||||||
|
|
||||||
// byName sorts field by name, breaking ties with depth,
|
|
||||||
// then breaking ties with "name came from json tag", then
|
|
||||||
// breaking ties with index sequence.
|
|
||||||
type byName []field
|
|
||||||
|
|
||||||
func (x byName) Len() int { return len(x) }
|
|
||||||
|
|
||||||
func (x byName) Swap(i, j int) { x[i], x[j] = x[j], x[i] }
|
|
||||||
|
|
||||||
func (x byName) Less(i, j int) bool {
|
|
||||||
if x[i].name != x[j].name {
|
|
||||||
return x[i].name < x[j].name
|
|
||||||
}
|
|
||||||
if len(x[i].index) != len(x[j].index) {
|
|
||||||
return len(x[i].index) < len(x[j].index)
|
|
||||||
}
|
|
||||||
if x[i].tag != x[j].tag {
|
|
||||||
return x[i].tag
|
|
||||||
}
|
|
||||||
return byIndex(x).Less(i, j)
|
|
||||||
}
|
|
||||||
|
|
||||||
// byIndex sorts field by index sequence.
|
|
||||||
type byIndex []field
|
|
||||||
|
|
||||||
func (x byIndex) Len() int { return len(x) }
|
|
||||||
|
|
||||||
func (x byIndex) Swap(i, j int) { x[i], x[j] = x[j], x[i] }
|
|
||||||
|
|
||||||
func (x byIndex) Less(i, j int) bool {
|
|
||||||
for k, xik := range x[i].index {
|
|
||||||
if k >= len(x[j].index) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if xik != x[j].index[k] {
|
|
||||||
return xik < x[j].index[k]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return len(x[i].index) < len(x[j].index)
|
|
||||||
}
|
|
||||||
|
|
||||||
// typeFields returns a list of fields that JSON should recognize for the given type.
|
|
||||||
// The algorithm is breadth-first search over the set of structs to include - the top struct
|
|
||||||
// and then any reachable anonymous structs.
|
|
||||||
func typeFields(t reflect.Type) []field {
|
|
||||||
// Anonymous fields to explore at the current level and the next.
|
|
||||||
current := []field{}
|
|
||||||
next := []field{{typ: t}}
|
|
||||||
|
|
||||||
// Count of queued names for current level and the next.
|
|
||||||
count := map[reflect.Type]int{}
|
|
||||||
nextCount := map[reflect.Type]int{}
|
|
||||||
|
|
||||||
// Types already visited at an earlier level.
|
|
||||||
visited := map[reflect.Type]bool{}
|
|
||||||
|
|
||||||
// Fields found.
|
|
||||||
var fields []field
|
|
||||||
|
|
||||||
for len(next) > 0 {
|
|
||||||
current, next = next, current[:0]
|
|
||||||
count, nextCount = nextCount, map[reflect.Type]int{}
|
|
||||||
|
|
||||||
for _, f := range current {
|
|
||||||
if visited[f.typ] {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
visited[f.typ] = true
|
|
||||||
|
|
||||||
// Scan f.typ for fields to include.
|
|
||||||
for i := 0; i < f.typ.NumField(); i++ {
|
|
||||||
sf := f.typ.Field(i)
|
|
||||||
if sf.PkgPath != "" { // unexported
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
tag := sf.Tag.Get("yaml")
|
|
||||||
if tag == "-" {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
name, opts := parseTag(tag)
|
|
||||||
if !isValidTag(name) {
|
|
||||||
name = ""
|
|
||||||
}
|
|
||||||
index := make([]int, len(f.index)+1)
|
|
||||||
copy(index, f.index)
|
|
||||||
index[len(f.index)] = i
|
|
||||||
|
|
||||||
ft := sf.Type
|
|
||||||
if ft.Name() == "" && ft.Kind() == reflect.Ptr {
|
|
||||||
// Follow pointer.
|
|
||||||
ft = ft.Elem()
|
|
||||||
}
|
|
||||||
|
|
||||||
// Record found field and index sequence.
|
|
||||||
if name != "" || !sf.Anonymous || ft.Kind() != reflect.Struct {
|
|
||||||
tagged := name != ""
|
|
||||||
if name == "" {
|
|
||||||
name = sf.Name
|
|
||||||
}
|
|
||||||
fields = append(fields, field{name, tagged, index, ft,
|
|
||||||
opts.Contains("omitempty"), opts.Contains("flow")})
|
|
||||||
if count[f.typ] > 1 {
|
|
||||||
// If there were multiple instances, add a second,
|
|
||||||
// so that the annihilation code will see a duplicate.
|
|
||||||
// It only cares about the distinction between 1 or 2,
|
|
||||||
// so don't bother generating any more copies.
|
|
||||||
fields = append(fields, fields[len(fields)-1])
|
|
||||||
}
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
// Record new anonymous struct to explore in next round.
|
|
||||||
nextCount[ft]++
|
|
||||||
if nextCount[ft] == 1 {
|
|
||||||
next = append(next, field{name: ft.Name(), index: index, typ: ft})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sort.Sort(byName(fields))
|
|
||||||
|
|
||||||
// Delete all fields that are hidden by the Go rules for embedded fields,
|
|
||||||
// except that fields with JSON tags are promoted.
|
|
||||||
|
|
||||||
// The fields are sorted in primary order of name, secondary order
|
|
||||||
// of field index length. Loop over names; for each name, delete
|
|
||||||
// hidden fields by choosing the one dominant field that survives.
|
|
||||||
out := fields[:0]
|
|
||||||
for advance, i := 0, 0; i < len(fields); i += advance {
|
|
||||||
// One iteration per name.
|
|
||||||
// Find the sequence of fields with the name of this first field.
|
|
||||||
fi := fields[i]
|
|
||||||
name := fi.name
|
|
||||||
for advance = 1; i+advance < len(fields); advance++ {
|
|
||||||
fj := fields[i+advance]
|
|
||||||
if fj.name != name {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if advance == 1 { // Only one field with this name
|
|
||||||
out = append(out, fi)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
dominant, ok := dominantField(fields[i : i+advance])
|
|
||||||
if ok {
|
|
||||||
out = append(out, dominant)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fields = out
|
|
||||||
sort.Sort(byIndex(fields))
|
|
||||||
|
|
||||||
return fields
|
|
||||||
}
|
|
||||||
|
|
||||||
// dominantField looks through the fields, all of which are known to
|
|
||||||
// have the same name, to find the single field that dominates the
|
|
||||||
// others using Go's embedding rules, modified by the presence of
|
|
||||||
// JSON tags. If there are multiple top-level fields, the boolean
|
|
||||||
// will be false: This condition is an error in Go and we skip all
|
|
||||||
// the fields.
|
|
||||||
func dominantField(fields []field) (field, bool) {
|
|
||||||
// The fields are sorted in increasing index-length order. The winner
|
|
||||||
// must therefore be one with the shortest index length. Drop all
|
|
||||||
// longer entries, which is easy: just truncate the slice.
|
|
||||||
length := len(fields[0].index)
|
|
||||||
tagged := -1 // Index of first tagged field.
|
|
||||||
for i, f := range fields {
|
|
||||||
if len(f.index) > length {
|
|
||||||
fields = fields[:i]
|
|
||||||
break
|
|
||||||
}
|
|
||||||
if f.tag {
|
|
||||||
if tagged >= 0 {
|
|
||||||
// Multiple tagged fields at the same level: conflict.
|
|
||||||
// Return no field.
|
|
||||||
return field{}, false
|
|
||||||
}
|
|
||||||
tagged = i
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if tagged >= 0 {
|
|
||||||
return fields[tagged], true
|
|
||||||
}
|
|
||||||
// All remaining fields have the same length. If there's more than one,
|
|
||||||
// we have a conflict (two fields named "X" at the same level) and we
|
|
||||||
// return no field.
|
|
||||||
if len(fields) > 1 {
|
|
||||||
return field{}, false
|
|
||||||
}
|
|
||||||
return fields[0], true
|
|
||||||
}
|
|
||||||
|
|
||||||
var fieldCache struct {
|
|
||||||
sync.RWMutex
|
|
||||||
m map[reflect.Type][]field
|
|
||||||
}
|
|
||||||
|
|
||||||
// cachedTypeFields is like typeFields but uses a cache to avoid repeated work.
|
|
||||||
func cachedTypeFields(t reflect.Type) []field {
|
|
||||||
fieldCache.RLock()
|
|
||||||
f := fieldCache.m[t]
|
|
||||||
fieldCache.RUnlock()
|
|
||||||
if f != nil {
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
// Compute fields without lock.
|
|
||||||
// Might duplicate effort but won't hold other computations back.
|
|
||||||
f = typeFields(t)
|
|
||||||
if f == nil {
|
|
||||||
f = []field{}
|
|
||||||
}
|
|
||||||
|
|
||||||
fieldCache.Lock()
|
|
||||||
if fieldCache.m == nil {
|
|
||||||
fieldCache.m = map[reflect.Type][]field{}
|
|
||||||
}
|
|
||||||
fieldCache.m[t] = f
|
|
||||||
fieldCache.Unlock()
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
// tagOptions is the string following a comma in a struct field's "json"
|
|
||||||
// tag, or the empty string. It does not include the leading comma.
|
|
||||||
type tagOptions string
|
|
||||||
|
|
||||||
func isValidTag(s string) bool {
|
|
||||||
if s == "" {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
for _, c := range s {
|
|
||||||
switch {
|
|
||||||
case strings.ContainsRune("!#$%&()*+-./:<=>?@[]^_{|}~ ", c):
|
|
||||||
// Backslash and quote chars are reserved, but
|
|
||||||
// otherwise any punctuation chars are allowed
|
|
||||||
// in a tag name.
|
|
||||||
default:
|
|
||||||
if !unicode.IsLetter(c) && !unicode.IsDigit(c) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
func fieldByIndex(v reflect.Value, index []int) reflect.Value {
|
|
||||||
for _, i := range index {
|
|
||||||
if v.Kind() == reflect.Ptr {
|
|
||||||
if v.IsNil() {
|
|
||||||
return reflect.Value{}
|
|
||||||
}
|
|
||||||
v = v.Elem()
|
|
||||||
}
|
|
||||||
v = v.Field(i)
|
|
||||||
}
|
|
||||||
return v
|
|
||||||
}
|
|
||||||
|
|
||||||
func typeByIndex(t reflect.Type, index []int) reflect.Type {
|
|
||||||
for _, i := range index {
|
|
||||||
if t.Kind() == reflect.Ptr {
|
|
||||||
t = t.Elem()
|
|
||||||
}
|
|
||||||
t = t.Field(i).Type
|
|
||||||
}
|
|
||||||
return t
|
|
||||||
}
|
|
||||||
|
|
||||||
// stringValues is a slice of reflect.Value holding *reflect.StringValue.
|
|
||||||
// It implements the methods to sort by string.
|
|
||||||
type stringValues []reflect.Value
|
|
||||||
|
|
||||||
func (sv stringValues) Len() int { return len(sv) }
|
|
||||||
func (sv stringValues) Swap(i, j int) { sv[i], sv[j] = sv[j], sv[i] }
|
|
||||||
func (sv stringValues) Less(i, j int) bool {
|
|
||||||
av, ak := getElem(sv[i])
|
|
||||||
bv, bk := getElem(sv[j])
|
|
||||||
if ak == reflect.String && bk == reflect.String {
|
|
||||||
return av.String() < bv.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
return ak < bk
|
|
||||||
}
|
|
||||||
|
|
||||||
func getElem(v reflect.Value) (reflect.Value, reflect.Kind) {
|
|
||||||
k := v.Kind()
|
|
||||||
for k == reflect.Interface || k == reflect.Ptr && !v.IsNil() {
|
|
||||||
v = v.Elem()
|
|
||||||
k = v.Kind()
|
|
||||||
}
|
|
||||||
|
|
||||||
return v, k
|
|
||||||
}
|
|
||||||
|
|
||||||
// parseTag splits a struct field's json tag into its name and
|
|
||||||
// comma-separated options.
|
|
||||||
func parseTag(tag string) (string, tagOptions) {
|
|
||||||
if idx := strings.Index(tag, ","); idx != -1 {
|
|
||||||
return tag[:idx], tagOptions(tag[idx+1:])
|
|
||||||
}
|
|
||||||
return tag, tagOptions("")
|
|
||||||
}
|
|
||||||
|
|
||||||
// Contains reports whether a comma-separated list of options
|
|
||||||
// contains a particular substr flag. substr must be surrounded by a
|
|
||||||
// string boundary or commas.
|
|
||||||
func (o tagOptions) Contains(optionName string) bool {
|
|
||||||
if len(o) == 0 {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
s := string(o)
|
|
||||||
for s != "" {
|
|
||||||
var next string
|
|
||||||
i := strings.Index(s, ",")
|
|
||||||
if i >= 0 {
|
|
||||||
s, next = s[:i], s[i+1:]
|
|
||||||
}
|
|
||||||
if s == optionName {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
s = next
|
|
||||||
}
|
|
||||||
return false
|
|
||||||
}
|
|
128
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/writer.go
generated
vendored
128
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/writer.go
generated
vendored
|
@ -1,128 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set the writer error and return 0.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_set_writer_error(emitter *yaml_emitter_t, problem string) bool {
|
|
||||||
emitter.error = yaml_WRITER_ERROR
|
|
||||||
emitter.problem = problem
|
|
||||||
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Flush the output buffer.
|
|
||||||
*/
|
|
||||||
|
|
||||||
func yaml_emitter_flush(emitter *yaml_emitter_t) bool {
|
|
||||||
if emitter.write_handler == nil {
|
|
||||||
panic("Write handler must be set") /* Write handler must be set. */
|
|
||||||
}
|
|
||||||
if emitter.encoding == yaml_ANY_ENCODING {
|
|
||||||
panic("Encoding must be set") /* Output encoding must be set. */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check if the buffer is empty. */
|
|
||||||
|
|
||||||
if emitter.buffer_pos == 0 {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
/* If the output encoding is UTF-8, we don't need to recode the buffer. */
|
|
||||||
|
|
||||||
if emitter.encoding == yaml_UTF8_ENCODING {
|
|
||||||
if err := emitter.write_handler(emitter,
|
|
||||||
emitter.buffer[:emitter.buffer_pos]); err != nil {
|
|
||||||
return yaml_emitter_set_writer_error(emitter, "write error: "+err.Error())
|
|
||||||
}
|
|
||||||
emitter.buffer_pos = 0
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Recode the buffer into the raw buffer. */
|
|
||||||
|
|
||||||
var low, high int
|
|
||||||
if emitter.encoding == yaml_UTF16LE_ENCODING {
|
|
||||||
low, high = 0, 1
|
|
||||||
} else {
|
|
||||||
high, low = 1, 0
|
|
||||||
}
|
|
||||||
|
|
||||||
pos := 0
|
|
||||||
for pos < emitter.buffer_pos {
|
|
||||||
|
|
||||||
/*
|
|
||||||
* See the "reader.c" code for more details on UTF-8 encoding. Note
|
|
||||||
* that we assume that the buffer contains a valid UTF-8 sequence.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Read the next UTF-8 character. */
|
|
||||||
|
|
||||||
octet := emitter.buffer[pos]
|
|
||||||
|
|
||||||
var w int
|
|
||||||
var value rune
|
|
||||||
switch {
|
|
||||||
case octet&0x80 == 0x00:
|
|
||||||
w, value = 1, rune(octet&0x7F)
|
|
||||||
case octet&0xE0 == 0xC0:
|
|
||||||
w, value = 2, rune(octet&0x1F)
|
|
||||||
case octet&0xF0 == 0xE0:
|
|
||||||
w, value = 3, rune(octet&0x0F)
|
|
||||||
case octet&0xF8 == 0xF0:
|
|
||||||
w, value = 4, rune(octet&0x07)
|
|
||||||
}
|
|
||||||
|
|
||||||
for k := 1; k < w; k++ {
|
|
||||||
octet = emitter.buffer[pos+k]
|
|
||||||
value = (value << 6) + (rune(octet) & 0x3F)
|
|
||||||
}
|
|
||||||
|
|
||||||
pos += w
|
|
||||||
|
|
||||||
/* Write the character. */
|
|
||||||
|
|
||||||
if value < 0x10000 {
|
|
||||||
var b [2]byte
|
|
||||||
b[high] = byte(value >> 8)
|
|
||||||
b[low] = byte(value & 0xFF)
|
|
||||||
emitter.raw_buffer = append(emitter.raw_buffer, b[0], b[1])
|
|
||||||
} else {
|
|
||||||
/* Write the character using a surrogate pair (check "reader.c"). */
|
|
||||||
|
|
||||||
var b [4]byte
|
|
||||||
value -= 0x10000
|
|
||||||
b[high] = byte(0xD8 + (value >> 18))
|
|
||||||
b[low] = byte((value >> 10) & 0xFF)
|
|
||||||
b[high+2] = byte(0xDC + ((value >> 8) & 0xFF))
|
|
||||||
b[low+2] = byte(value & 0xFF)
|
|
||||||
emitter.raw_buffer = append(emitter.raw_buffer, b[0], b[1], b[2], b[3])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Write the raw buffer. */
|
|
||||||
|
|
||||||
// Write the raw buffer.
|
|
||||||
if err := emitter.write_handler(emitter, emitter.raw_buffer); err != nil {
|
|
||||||
return yaml_emitter_set_writer_error(emitter, "write error: "+err.Error())
|
|
||||||
}
|
|
||||||
|
|
||||||
emitter.buffer_pos = 0
|
|
||||||
emitter.raw_buffer = emitter.raw_buffer[:0]
|
|
||||||
return true
|
|
||||||
}
|
|
22
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_definesh.go
generated
vendored
22
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_definesh.go
generated
vendored
|
@ -1,22 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
const (
|
|
||||||
yaml_VERSION_MAJOR = 0
|
|
||||||
yaml_VERSION_MINOR = 1
|
|
||||||
yaml_VERSION_PATCH = 6
|
|
||||||
yaml_VERSION_STRING = "0.1.6"
|
|
||||||
)
|
|
891
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_privateh.go
generated
vendored
891
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_privateh.go
generated
vendored
|
@ -1,891 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
const (
|
|
||||||
INPUT_RAW_BUFFER_SIZE = 1024
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The size of the input buffer.
|
|
||||||
*
|
|
||||||
* It should be possible to decode the whole raw buffer.
|
|
||||||
*/
|
|
||||||
INPUT_BUFFER_SIZE = (INPUT_RAW_BUFFER_SIZE * 3)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The size of the output buffer.
|
|
||||||
*/
|
|
||||||
|
|
||||||
OUTPUT_BUFFER_SIZE = 512
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The size of the output raw buffer.
|
|
||||||
*
|
|
||||||
* It should be possible to encode the whole output buffer.
|
|
||||||
*/
|
|
||||||
|
|
||||||
OUTPUT_RAW_BUFFER_SIZE = (OUTPUT_BUFFER_SIZE*2 + 2)
|
|
||||||
|
|
||||||
INITIAL_STACK_SIZE = 16
|
|
||||||
INITIAL_QUEUE_SIZE = 16
|
|
||||||
)
|
|
||||||
|
|
||||||
func width(b byte) int {
|
|
||||||
if b&0x80 == 0 {
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
|
|
||||||
if b&0xE0 == 0xC0 {
|
|
||||||
return 2
|
|
||||||
}
|
|
||||||
|
|
||||||
if b&0xF0 == 0xE0 {
|
|
||||||
return 3
|
|
||||||
}
|
|
||||||
|
|
||||||
if b&0xF8 == 0xF0 {
|
|
||||||
return 4
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
func copy_bytes(dest []byte, dest_pos *int, src []byte, src_pos *int) {
|
|
||||||
w := width(src[*src_pos])
|
|
||||||
switch w {
|
|
||||||
case 4:
|
|
||||||
dest[*dest_pos+3] = src[*src_pos+3]
|
|
||||||
fallthrough
|
|
||||||
case 3:
|
|
||||||
dest[*dest_pos+2] = src[*src_pos+2]
|
|
||||||
fallthrough
|
|
||||||
case 2:
|
|
||||||
dest[*dest_pos+1] = src[*src_pos+1]
|
|
||||||
fallthrough
|
|
||||||
case 1:
|
|
||||||
dest[*dest_pos] = src[*src_pos]
|
|
||||||
default:
|
|
||||||
panic("invalid width")
|
|
||||||
}
|
|
||||||
*dest_pos += w
|
|
||||||
*src_pos += w
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is an alphabetical
|
|
||||||
// * character, a digit, '_', or '-'.
|
|
||||||
// */
|
|
||||||
|
|
||||||
func is_alpha(b byte) bool {
|
|
||||||
return (b >= '0' && b <= '9') ||
|
|
||||||
(b >= 'A' && b <= 'Z') ||
|
|
||||||
(b >= 'a' && b <= 'z') ||
|
|
||||||
b == '_' || b == '-'
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is a digit.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
func is_digit(b byte) bool {
|
|
||||||
return b >= '0' && b <= '9'
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Get the value of a digit.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
func as_digit(b byte) int {
|
|
||||||
return int(b) - '0'
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is a hex-digit.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
func is_hex(b byte) bool {
|
|
||||||
return (b >= '0' && b <= '9') ||
|
|
||||||
(b >= 'A' && b <= 'F') ||
|
|
||||||
(b >= 'a' && b <= 'f')
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Get the value of a hex-digit.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
func as_hex(b byte) int {
|
|
||||||
if b >= 'A' && b <= 'F' {
|
|
||||||
return int(b) - 'A' + 10
|
|
||||||
} else if b >= 'a' && b <= 'f' {
|
|
||||||
return int(b) - 'a' + 10
|
|
||||||
}
|
|
||||||
return int(b) - '0'
|
|
||||||
}
|
|
||||||
|
|
||||||
// #define AS_HEX_AT(string,offset) \
|
|
||||||
// (((string).pointer[offset] >= (yaml_char_t) 'A' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) 'F') ? \
|
|
||||||
// ((string).pointer[offset] - (yaml_char_t) 'A' + 10) : \
|
|
||||||
// ((string).pointer[offset] >= (yaml_char_t) 'a' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) 'f') ? \
|
|
||||||
// ((string).pointer[offset] - (yaml_char_t) 'a' + 10) : \
|
|
||||||
// ((string).pointer[offset] - (yaml_char_t) '0'))
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character is a line break, space, tab, or NUL.
|
|
||||||
// */
|
|
||||||
func is_blankz_at(b []byte, i int) bool {
|
|
||||||
return is_blank(b[i]) || is_breakz_at(b, i)
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is a line break.
|
|
||||||
// */
|
|
||||||
func is_break_at(b []byte, i int) bool {
|
|
||||||
return b[i] == '\r' || /* CR (#xD)*/
|
|
||||||
b[i] == '\n' || /* LF (#xA) */
|
|
||||||
(b[i] == 0xC2 && b[i+1] == 0x85) || /* NEL (#x85) */
|
|
||||||
(b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA8) || /* LS (#x2028) */
|
|
||||||
(b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA9) /* PS (#x2029) */
|
|
||||||
}
|
|
||||||
|
|
||||||
func is_breakz_at(b []byte, i int) bool {
|
|
||||||
return is_break_at(b, i) || is_z(b[i])
|
|
||||||
}
|
|
||||||
|
|
||||||
func is_crlf_at(b []byte, i int) bool {
|
|
||||||
return b[i] == '\r' && b[i+1] == '\n'
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is NUL.
|
|
||||||
// */
|
|
||||||
func is_z(b byte) bool {
|
|
||||||
return b == 0x0
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is space.
|
|
||||||
// */
|
|
||||||
func is_space(b byte) bool {
|
|
||||||
return b == ' '
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is tab.
|
|
||||||
// */
|
|
||||||
func is_tab(b byte) bool {
|
|
||||||
return b == '\t'
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is blank (space or tab).
|
|
||||||
// */
|
|
||||||
func is_blank(b byte) bool {
|
|
||||||
return is_space(b) || is_tab(b)
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character is ASCII.
|
|
||||||
// */
|
|
||||||
func is_ascii(b byte) bool {
|
|
||||||
return b <= '\x7f'
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character can be printed unescaped.
|
|
||||||
// */
|
|
||||||
func is_printable_at(b []byte, i int) bool {
|
|
||||||
return ((b[i] == 0x0A) || /* . == #x0A */
|
|
||||||
(b[i] >= 0x20 && b[i] <= 0x7E) || /* #x20 <= . <= #x7E */
|
|
||||||
(b[i] == 0xC2 && b[i+1] >= 0xA0) || /* #0xA0 <= . <= #xD7FF */
|
|
||||||
(b[i] > 0xC2 && b[i] < 0xED) ||
|
|
||||||
(b[i] == 0xED && b[i+1] < 0xA0) ||
|
|
||||||
(b[i] == 0xEE) ||
|
|
||||||
(b[i] == 0xEF && /* && . != #xFEFF */
|
|
||||||
!(b[i+1] == 0xBB && b[i+2] == 0xBF) &&
|
|
||||||
!(b[i+1] == 0xBF && (b[i+2] == 0xBE || b[i+2] == 0xBF))))
|
|
||||||
}
|
|
||||||
|
|
||||||
func insert_token(parser *yaml_parser_t, pos int, token *yaml_token_t) {
|
|
||||||
// collapse the slice
|
|
||||||
if parser.tokens_head > 0 && len(parser.tokens) == cap(parser.tokens) {
|
|
||||||
if parser.tokens_head != len(parser.tokens) {
|
|
||||||
// move the tokens down
|
|
||||||
copy(parser.tokens, parser.tokens[parser.tokens_head:])
|
|
||||||
}
|
|
||||||
// readjust the length
|
|
||||||
parser.tokens = parser.tokens[:len(parser.tokens)-parser.tokens_head]
|
|
||||||
parser.tokens_head = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
parser.tokens = append(parser.tokens, *token)
|
|
||||||
if pos < 0 {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
copy(parser.tokens[parser.tokens_head+pos+1:], parser.tokens[parser.tokens_head+pos:])
|
|
||||||
parser.tokens[parser.tokens_head+pos] = *token
|
|
||||||
}
|
|
||||||
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is BOM.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
func is_bom_at(b []byte, i int) bool {
|
|
||||||
return b[i] == 0xEF && b[i+1] == 0xBB && b[i+2] == 0xBF
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// #ifdef HAVE_CONFIG_H
|
|
||||||
// #include <config.h>
|
|
||||||
// #endif
|
|
||||||
//
|
|
||||||
// #include "./yaml.h"
|
|
||||||
//
|
|
||||||
// #include <assert.h>
|
|
||||||
// #include <limits.h>
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Memory management.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(void *)
|
|
||||||
// yaml_malloc(size_t size);
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(void *)
|
|
||||||
// yaml_realloc(void *ptr, size_t size);
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(void)
|
|
||||||
// yaml_free(void *ptr);
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(yaml_char_t *)
|
|
||||||
// yaml_strdup(const yaml_char_t *);
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Reader: Ensure that the buffer contains at least `length` characters.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_parser_update_buffer(yaml_parser_t *parser, size_t length);
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Scanner: Ensure that the token stack contains at least one token ready.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_parser_fetch_more_tokens(yaml_parser_t *parser);
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * The size of the input raw buffer.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define INPUT_RAW_BUFFER_SIZE 16384
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * The size of the input buffer.
|
|
||||||
// *
|
|
||||||
// * It should be possible to decode the whole raw buffer.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define INPUT_BUFFER_SIZE (INPUT_RAW_BUFFER_SIZE*3)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * The size of the output buffer.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define OUTPUT_BUFFER_SIZE 16384
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * The size of the output raw buffer.
|
|
||||||
// *
|
|
||||||
// * It should be possible to encode the whole output buffer.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define OUTPUT_RAW_BUFFER_SIZE (OUTPUT_BUFFER_SIZE*2+2)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * The size of other stacks and queues.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define INITIAL_STACK_SIZE 16
|
|
||||||
// #define INITIAL_QUEUE_SIZE 16
|
|
||||||
// #define INITIAL_STRING_SIZE 16
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Buffer management.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define BUFFER_INIT(context,buffer,size) \
|
|
||||||
// (((buffer).start = yaml_malloc(size)) ? \
|
|
||||||
// ((buffer).last = (buffer).pointer = (buffer).start, \
|
|
||||||
// (buffer).end = (buffer).start+(size), \
|
|
||||||
// 1) : \
|
|
||||||
// ((context)->error = yaml_MEMORY_ERROR, \
|
|
||||||
// 0))
|
|
||||||
//
|
|
||||||
// #define BUFFER_DEL(context,buffer) \
|
|
||||||
// (yaml_free((buffer).start), \
|
|
||||||
// (buffer).start = (buffer).pointer = (buffer).end = 0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * String management.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// typedef struct {
|
|
||||||
// yaml_char_t *start;
|
|
||||||
// yaml_char_t *end;
|
|
||||||
// yaml_char_t *pointer;
|
|
||||||
// } yaml_string_t;
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_string_extend(yaml_char_t **start,
|
|
||||||
// yaml_char_t **pointer, yaml_char_t **end);
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_string_join(
|
|
||||||
// yaml_char_t **a_start, yaml_char_t **a_pointer, yaml_char_t **a_end,
|
|
||||||
// yaml_char_t **b_start, yaml_char_t **b_pointer, yaml_char_t **b_end);
|
|
||||||
//
|
|
||||||
// #define NULL_STRING { NULL, NULL, NULL }
|
|
||||||
//
|
|
||||||
// #define STRING(string,length) { (string), (string)+(length), (string) }
|
|
||||||
//
|
|
||||||
// #define STRING_ASSIGN(value,string,length) \
|
|
||||||
// ((value).start = (string), \
|
|
||||||
// (value).end = (string)+(length), \
|
|
||||||
// (value).pointer = (string))
|
|
||||||
//
|
|
||||||
// #define STRING_INIT(context,string,size) \
|
|
||||||
// (((string).start = yaml_malloc(size)) ? \
|
|
||||||
// ((string).pointer = (string).start, \
|
|
||||||
// (string).end = (string).start+(size), \
|
|
||||||
// memset((string).start, 0, (size)), \
|
|
||||||
// 1) : \
|
|
||||||
// ((context)->error = yaml_MEMORY_ERROR, \
|
|
||||||
// 0))
|
|
||||||
//
|
|
||||||
// #define STRING_DEL(context,string) \
|
|
||||||
// (yaml_free((string).start), \
|
|
||||||
// (string).start = (string).pointer = (string).end = 0)
|
|
||||||
//
|
|
||||||
// #define STRING_EXTEND(context,string) \
|
|
||||||
// (((string).pointer+5 < (string).end) \
|
|
||||||
// || yaml_string_extend(&(string).start, \
|
|
||||||
// &(string).pointer, &(string).end))
|
|
||||||
//
|
|
||||||
// #define CLEAR(context,string) \
|
|
||||||
// ((string).pointer = (string).start, \
|
|
||||||
// memset((string).start, 0, (string).end-(string).start))
|
|
||||||
//
|
|
||||||
// #define JOIN(context,string_a,string_b) \
|
|
||||||
// ((yaml_string_join(&(string_a).start, &(string_a).pointer, \
|
|
||||||
// &(string_a).end, &(string_b).start, \
|
|
||||||
// &(string_b).pointer, &(string_b).end)) ? \
|
|
||||||
// ((string_b).pointer = (string_b).start, \
|
|
||||||
// 1) : \
|
|
||||||
// ((context)->error = yaml_MEMORY_ERROR, \
|
|
||||||
// 0))
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * String check operations.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check the octet at the specified position.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define CHECK_AT(string,octet,offset) \
|
|
||||||
// ((string).pointer[offset] == (yaml_char_t)(octet))
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check the current octet in the buffer.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define CHECK(string,octet) CHECK_AT((string),(octet),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is an alphabetical
|
|
||||||
// * character, a digit, '_', or '-'.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_ALPHA_AT(string,offset) \
|
|
||||||
// (((string).pointer[offset] >= (yaml_char_t) '0' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) '9') || \
|
|
||||||
// ((string).pointer[offset] >= (yaml_char_t) 'A' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) 'Z') || \
|
|
||||||
// ((string).pointer[offset] >= (yaml_char_t) 'a' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) 'z') || \
|
|
||||||
// (string).pointer[offset] == '_' || \
|
|
||||||
// (string).pointer[offset] == '-')
|
|
||||||
//
|
|
||||||
// #define IS_ALPHA(string) IS_ALPHA_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is a digit.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_DIGIT_AT(string,offset) \
|
|
||||||
// (((string).pointer[offset] >= (yaml_char_t) '0' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) '9'))
|
|
||||||
//
|
|
||||||
// #define IS_DIGIT(string) IS_DIGIT_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Get the value of a digit.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define AS_DIGIT_AT(string,offset) \
|
|
||||||
// ((string).pointer[offset] - (yaml_char_t) '0')
|
|
||||||
//
|
|
||||||
// #define AS_DIGIT(string) AS_DIGIT_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is a hex-digit.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_HEX_AT(string,offset) \
|
|
||||||
// (((string).pointer[offset] >= (yaml_char_t) '0' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) '9') || \
|
|
||||||
// ((string).pointer[offset] >= (yaml_char_t) 'A' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) 'F') || \
|
|
||||||
// ((string).pointer[offset] >= (yaml_char_t) 'a' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) 'f'))
|
|
||||||
//
|
|
||||||
// #define IS_HEX(string) IS_HEX_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Get the value of a hex-digit.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define AS_HEX_AT(string,offset) \
|
|
||||||
// (((string).pointer[offset] >= (yaml_char_t) 'A' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) 'F') ? \
|
|
||||||
// ((string).pointer[offset] - (yaml_char_t) 'A' + 10) : \
|
|
||||||
// ((string).pointer[offset] >= (yaml_char_t) 'a' && \
|
|
||||||
// (string).pointer[offset] <= (yaml_char_t) 'f') ? \
|
|
||||||
// ((string).pointer[offset] - (yaml_char_t) 'a' + 10) : \
|
|
||||||
// ((string).pointer[offset] - (yaml_char_t) '0'))
|
|
||||||
//
|
|
||||||
// #define AS_HEX(string) AS_HEX_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character is ASCII.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_ASCII_AT(string,offset) \
|
|
||||||
// ((string).pointer[offset] <= (yaml_char_t) '\x7F')
|
|
||||||
//
|
|
||||||
// #define IS_ASCII(string) IS_ASCII_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character can be printed unescaped.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_PRINTABLE_AT(string,offset) \
|
|
||||||
// (((string).pointer[offset] == 0x0A) /* . == #x0A */ \
|
|
||||||
// || ((string).pointer[offset] >= 0x20 /* #x20 <= . <= #x7E */ \
|
|
||||||
// && (string).pointer[offset] <= 0x7E) \
|
|
||||||
// || ((string).pointer[offset] == 0xC2 /* #0xA0 <= . <= #xD7FF */ \
|
|
||||||
// && (string).pointer[offset+1] >= 0xA0) \
|
|
||||||
// || ((string).pointer[offset] > 0xC2 \
|
|
||||||
// && (string).pointer[offset] < 0xED) \
|
|
||||||
// || ((string).pointer[offset] == 0xED \
|
|
||||||
// && (string).pointer[offset+1] < 0xA0) \
|
|
||||||
// || ((string).pointer[offset] == 0xEE) \
|
|
||||||
// || ((string).pointer[offset] == 0xEF /* #xE000 <= . <= #xFFFD */ \
|
|
||||||
// && !((string).pointer[offset+1] == 0xBB /* && . != #xFEFF */ \
|
|
||||||
// && (string).pointer[offset+2] == 0xBF) \
|
|
||||||
// && !((string).pointer[offset+1] == 0xBF \
|
|
||||||
// && ((string).pointer[offset+2] == 0xBE \
|
|
||||||
// || (string).pointer[offset+2] == 0xBF))))
|
|
||||||
//
|
|
||||||
// #define IS_PRINTABLE(string) IS_PRINTABLE_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is NUL.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_Z_AT(string,offset) CHECK_AT((string),'\0',(offset))
|
|
||||||
//
|
|
||||||
// #define IS_Z(string) IS_Z_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is BOM.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_BOM_AT(string,offset) \
|
|
||||||
// (CHECK_AT((string),'\xEF',(offset)) \
|
|
||||||
// && CHECK_AT((string),'\xBB',(offset)+1) \
|
|
||||||
// && CHECK_AT((string),'\xBF',(offset)+2)) /* BOM (#xFEFF) */
|
|
||||||
//
|
|
||||||
// #define IS_BOM(string) IS_BOM_AT(string,0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is space.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_SPACE_AT(string,offset) CHECK_AT((string),' ',(offset))
|
|
||||||
//
|
|
||||||
// #define IS_SPACE(string) IS_SPACE_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is tab.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_TAB_AT(string,offset) CHECK_AT((string),'\t',(offset))
|
|
||||||
//
|
|
||||||
// #define IS_TAB(string) IS_TAB_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is blank (space or tab).
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_BLANK_AT(string,offset) \
|
|
||||||
// (IS_SPACE_AT((string),(offset)) || IS_TAB_AT((string),(offset)))
|
|
||||||
//
|
|
||||||
// #define IS_BLANK(string) IS_BLANK_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character at the specified position is a line break.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_BREAK_AT(string,offset) \
|
|
||||||
// (CHECK_AT((string),'\r',(offset)) /* CR (#xD)*/ \
|
|
||||||
// || CHECK_AT((string),'\n',(offset)) /* LF (#xA) */ \
|
|
||||||
// || (CHECK_AT((string),'\xC2',(offset)) \
|
|
||||||
// && CHECK_AT((string),'\x85',(offset)+1)) /* NEL (#x85) */ \
|
|
||||||
// || (CHECK_AT((string),'\xE2',(offset)) \
|
|
||||||
// && CHECK_AT((string),'\x80',(offset)+1) \
|
|
||||||
// && CHECK_AT((string),'\xA8',(offset)+2)) /* LS (#x2028) */ \
|
|
||||||
// || (CHECK_AT((string),'\xE2',(offset)) \
|
|
||||||
// && CHECK_AT((string),'\x80',(offset)+1) \
|
|
||||||
// && CHECK_AT((string),'\xA9',(offset)+2))) /* PS (#x2029) */
|
|
||||||
//
|
|
||||||
// #define IS_BREAK(string) IS_BREAK_AT((string),0)
|
|
||||||
//
|
|
||||||
// #define IS_CRLF_AT(string,offset) \
|
|
||||||
// (CHECK_AT((string),'\r',(offset)) && CHECK_AT((string),'\n',(offset)+1))
|
|
||||||
//
|
|
||||||
// #define IS_CRLF(string) IS_CRLF_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character is a line break or NUL.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_BREAKZ_AT(string,offset) \
|
|
||||||
// (IS_BREAK_AT((string),(offset)) || IS_Z_AT((string),(offset)))
|
|
||||||
//
|
|
||||||
// #define IS_BREAKZ(string) IS_BREAKZ_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character is a line break, space, or NUL.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_SPACEZ_AT(string,offset) \
|
|
||||||
// (IS_SPACE_AT((string),(offset)) || IS_BREAKZ_AT((string),(offset)))
|
|
||||||
//
|
|
||||||
// #define IS_SPACEZ(string) IS_SPACEZ_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Check if the character is a line break, space, tab, or NUL.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define IS_BLANKZ_AT(string,offset) \
|
|
||||||
// (IS_BLANK_AT((string),(offset)) || IS_BREAKZ_AT((string),(offset)))
|
|
||||||
//
|
|
||||||
// #define IS_BLANKZ(string) IS_BLANKZ_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Determine the width of the character.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define WIDTH_AT(string,offset) \
|
|
||||||
// (((string).pointer[offset] & 0x80) == 0x00 ? 1 : \
|
|
||||||
// ((string).pointer[offset] & 0xE0) == 0xC0 ? 2 : \
|
|
||||||
// ((string).pointer[offset] & 0xF0) == 0xE0 ? 3 : \
|
|
||||||
// ((string).pointer[offset] & 0xF8) == 0xF0 ? 4 : 0)
|
|
||||||
//
|
|
||||||
// #define WIDTH(string) WIDTH_AT((string),0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Move the string pointer to the next character.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define MOVE(string) ((string).pointer += WIDTH((string)))
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Copy a character and move the pointers of both strings.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define COPY(string_a,string_b) \
|
|
||||||
// ((*(string_b).pointer & 0x80) == 0x00 ? \
|
|
||||||
// (*((string_a).pointer++) = *((string_b).pointer++)) : \
|
|
||||||
// (*(string_b).pointer & 0xE0) == 0xC0 ? \
|
|
||||||
// (*((string_a).pointer++) = *((string_b).pointer++), \
|
|
||||||
// *((string_a).pointer++) = *((string_b).pointer++)) : \
|
|
||||||
// (*(string_b).pointer & 0xF0) == 0xE0 ? \
|
|
||||||
// (*((string_a).pointer++) = *((string_b).pointer++), \
|
|
||||||
// *((string_a).pointer++) = *((string_b).pointer++), \
|
|
||||||
// *((string_a).pointer++) = *((string_b).pointer++)) : \
|
|
||||||
// (*(string_b).pointer & 0xF8) == 0xF0 ? \
|
|
||||||
// (*((string_a).pointer++) = *((string_b).pointer++), \
|
|
||||||
// *((string_a).pointer++) = *((string_b).pointer++), \
|
|
||||||
// *((string_a).pointer++) = *((string_b).pointer++), \
|
|
||||||
// *((string_a).pointer++) = *((string_b).pointer++)) : 0)
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Stack and queue management.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_stack_extend(void **start, void **top, void **end);
|
|
||||||
//
|
|
||||||
// yaml_DECLARE(int)
|
|
||||||
// yaml_queue_extend(void **start, void **head, void **tail, void **end);
|
|
||||||
//
|
|
||||||
// #define STACK_INIT(context,stack,size) \
|
|
||||||
// (((stack).start = yaml_malloc((size)*sizeof(*(stack).start))) ? \
|
|
||||||
// ((stack).top = (stack).start, \
|
|
||||||
// (stack).end = (stack).start+(size), \
|
|
||||||
// 1) : \
|
|
||||||
// ((context)->error = yaml_MEMORY_ERROR, \
|
|
||||||
// 0))
|
|
||||||
//
|
|
||||||
// #define STACK_DEL(context,stack) \
|
|
||||||
// (yaml_free((stack).start), \
|
|
||||||
// (stack).start = (stack).top = (stack).end = 0)
|
|
||||||
//
|
|
||||||
// #define STACK_EMPTY(context,stack) \
|
|
||||||
// ((stack).start == (stack).top)
|
|
||||||
//
|
|
||||||
// #define PUSH(context,stack,value) \
|
|
||||||
// (((stack).top != (stack).end \
|
|
||||||
// || yaml_stack_extend((void **)&(stack).start, \
|
|
||||||
// (void **)&(stack).top, (void **)&(stack).end)) ? \
|
|
||||||
// (*((stack).top++) = value, \
|
|
||||||
// 1) : \
|
|
||||||
// ((context)->error = yaml_MEMORY_ERROR, \
|
|
||||||
// 0))
|
|
||||||
//
|
|
||||||
// #define POP(context,stack) \
|
|
||||||
// (*(--(stack).top))
|
|
||||||
//
|
|
||||||
// #define QUEUE_INIT(context,queue,size) \
|
|
||||||
// (((queue).start = yaml_malloc((size)*sizeof(*(queue).start))) ? \
|
|
||||||
// ((queue).head = (queue).tail = (queue).start, \
|
|
||||||
// (queue).end = (queue).start+(size), \
|
|
||||||
// 1) : \
|
|
||||||
// ((context)->error = yaml_MEMORY_ERROR, \
|
|
||||||
// 0))
|
|
||||||
//
|
|
||||||
// #define QUEUE_DEL(context,queue) \
|
|
||||||
// (yaml_free((queue).start), \
|
|
||||||
// (queue).start = (queue).head = (queue).tail = (queue).end = 0)
|
|
||||||
//
|
|
||||||
// #define QUEUE_EMPTY(context,queue) \
|
|
||||||
// ((queue).head == (queue).tail)
|
|
||||||
//
|
|
||||||
// #define ENQUEUE(context,queue,value) \
|
|
||||||
// (((queue).tail != (queue).end \
|
|
||||||
// || yaml_queue_extend((void **)&(queue).start, (void **)&(queue).head, \
|
|
||||||
// (void **)&(queue).tail, (void **)&(queue).end)) ? \
|
|
||||||
// (*((queue).tail++) = value, \
|
|
||||||
// 1) : \
|
|
||||||
// ((context)->error = yaml_MEMORY_ERROR, \
|
|
||||||
// 0))
|
|
||||||
//
|
|
||||||
// #define DEQUEUE(context,queue) \
|
|
||||||
// (*((queue).head++))
|
|
||||||
//
|
|
||||||
// #define QUEUE_INSERT(context,queue,index,value) \
|
|
||||||
// (((queue).tail != (queue).end \
|
|
||||||
// || yaml_queue_extend((void **)&(queue).start, (void **)&(queue).head, \
|
|
||||||
// (void **)&(queue).tail, (void **)&(queue).end)) ? \
|
|
||||||
// (memmove((queue).head+(index)+1,(queue).head+(index), \
|
|
||||||
// ((queue).tail-(queue).head-(index))*sizeof(*(queue).start)), \
|
|
||||||
// *((queue).head+(index)) = value, \
|
|
||||||
// (queue).tail++, \
|
|
||||||
// 1) : \
|
|
||||||
// ((context)->error = yaml_MEMORY_ERROR, \
|
|
||||||
// 0))
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Token initializers.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define TOKEN_INIT(token,token_type,token_start_mark,token_end_mark) \
|
|
||||||
// (memset(&(token), 0, sizeof(yaml_token_t)), \
|
|
||||||
// (token).type = (token_type), \
|
|
||||||
// (token).start_mark = (token_start_mark), \
|
|
||||||
// (token).end_mark = (token_end_mark))
|
|
||||||
//
|
|
||||||
// #define STREAM_START_TOKEN_INIT(token,token_encoding,start_mark,end_mark) \
|
|
||||||
// (TOKEN_INIT((token),yaml_STREAM_START_TOKEN,(start_mark),(end_mark)), \
|
|
||||||
// (token).data.stream_start.encoding = (token_encoding))
|
|
||||||
//
|
|
||||||
// #define STREAM_END_TOKEN_INIT(token,start_mark,end_mark) \
|
|
||||||
// (TOKEN_INIT((token),yaml_STREAM_END_TOKEN,(start_mark),(end_mark)))
|
|
||||||
//
|
|
||||||
// #define ALIAS_TOKEN_INIT(token,token_value,start_mark,end_mark) \
|
|
||||||
// (TOKEN_INIT((token),yaml_ALIAS_TOKEN,(start_mark),(end_mark)), \
|
|
||||||
// (token).data.alias.value = (token_value))
|
|
||||||
//
|
|
||||||
// #define ANCHOR_TOKEN_INIT(token,token_value,start_mark,end_mark) \
|
|
||||||
// (TOKEN_INIT((token),yaml_ANCHOR_TOKEN,(start_mark),(end_mark)), \
|
|
||||||
// (token).data.anchor.value = (token_value))
|
|
||||||
//
|
|
||||||
// #define TAG_TOKEN_INIT(token,token_handle,token_suffix,start_mark,end_mark) \
|
|
||||||
// (TOKEN_INIT((token),yaml_TAG_TOKEN,(start_mark),(end_mark)), \
|
|
||||||
// (token).data.tag.handle = (token_handle), \
|
|
||||||
// (token).data.tag.suffix = (token_suffix))
|
|
||||||
//
|
|
||||||
// #define SCALAR_TOKEN_INIT(token,token_value,token_length,token_style,start_mark,end_mark) \
|
|
||||||
// (TOKEN_INIT((token),yaml_SCALAR_TOKEN,(start_mark),(end_mark)), \
|
|
||||||
// (token).data.scalar.value = (token_value), \
|
|
||||||
// (token).data.scalar.length = (token_length), \
|
|
||||||
// (token).data.scalar.style = (token_style))
|
|
||||||
//
|
|
||||||
// #define VERSION_DIRECTIVE_TOKEN_INIT(token,token_major,token_minor,start_mark,end_mark) \
|
|
||||||
// (TOKEN_INIT((token),yaml_VERSION_DIRECTIVE_TOKEN,(start_mark),(end_mark)), \
|
|
||||||
// (token).data.version_directive.major = (token_major), \
|
|
||||||
// (token).data.version_directive.minor = (token_minor))
|
|
||||||
//
|
|
||||||
// #define TAG_DIRECTIVE_TOKEN_INIT(token,token_handle,token_prefix,start_mark,end_mark) \
|
|
||||||
// (TOKEN_INIT((token),yaml_TAG_DIRECTIVE_TOKEN,(start_mark),(end_mark)), \
|
|
||||||
// (token).data.tag_directive.handle = (token_handle), \
|
|
||||||
// (token).data.tag_directive.prefix = (token_prefix))
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Event initializers.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define EVENT_INIT(event,event_type,event_start_mark,event_end_mark) \
|
|
||||||
// (memset(&(event), 0, sizeof(yaml_event_t)), \
|
|
||||||
// (event).type = (event_type), \
|
|
||||||
// (event).start_mark = (event_start_mark), \
|
|
||||||
// (event).end_mark = (event_end_mark))
|
|
||||||
//
|
|
||||||
// #define STREAM_START_EVENT_INIT(event,event_encoding,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_STREAM_START_EVENT,(start_mark),(end_mark)), \
|
|
||||||
// (event).data.stream_start.encoding = (event_encoding))
|
|
||||||
//
|
|
||||||
// #define STREAM_END_EVENT_INIT(event,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_STREAM_END_EVENT,(start_mark),(end_mark)))
|
|
||||||
//
|
|
||||||
// #define DOCUMENT_START_EVENT_INIT(event,event_version_directive, \
|
|
||||||
// event_tag_directives_start,event_tag_directives_end,event_implicit,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_DOCUMENT_START_EVENT,(start_mark),(end_mark)), \
|
|
||||||
// (event).data.document_start.version_directive = (event_version_directive), \
|
|
||||||
// (event).data.document_start.tag_directives.start = (event_tag_directives_start), \
|
|
||||||
// (event).data.document_start.tag_directives.end = (event_tag_directives_end), \
|
|
||||||
// (event).data.document_start.implicit = (event_implicit))
|
|
||||||
//
|
|
||||||
// #define DOCUMENT_END_EVENT_INIT(event,event_implicit,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_DOCUMENT_END_EVENT,(start_mark),(end_mark)), \
|
|
||||||
// (event).data.document_end.implicit = (event_implicit))
|
|
||||||
//
|
|
||||||
// #define ALIAS_EVENT_INIT(event,event_anchor,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_ALIAS_EVENT,(start_mark),(end_mark)), \
|
|
||||||
// (event).data.alias.anchor = (event_anchor))
|
|
||||||
//
|
|
||||||
// #define SCALAR_EVENT_INIT(event,event_anchor,event_tag,event_value,event_length, \
|
|
||||||
// event_plain_implicit, event_quoted_implicit,event_style,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_SCALAR_EVENT,(start_mark),(end_mark)), \
|
|
||||||
// (event).data.scalar.anchor = (event_anchor), \
|
|
||||||
// (event).data.scalar.tag = (event_tag), \
|
|
||||||
// (event).data.scalar.value = (event_value), \
|
|
||||||
// (event).data.scalar.length = (event_length), \
|
|
||||||
// (event).data.scalar.plain_implicit = (event_plain_implicit), \
|
|
||||||
// (event).data.scalar.quoted_implicit = (event_quoted_implicit), \
|
|
||||||
// (event).data.scalar.style = (event_style))
|
|
||||||
//
|
|
||||||
// #define SEQUENCE_START_EVENT_INIT(event,event_anchor,event_tag, \
|
|
||||||
// event_implicit,event_style,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_SEQUENCE_START_EVENT,(start_mark),(end_mark)), \
|
|
||||||
// (event).data.sequence_start.anchor = (event_anchor), \
|
|
||||||
// (event).data.sequence_start.tag = (event_tag), \
|
|
||||||
// (event).data.sequence_start.implicit = (event_implicit), \
|
|
||||||
// (event).data.sequence_start.style = (event_style))
|
|
||||||
//
|
|
||||||
// #define SEQUENCE_END_EVENT_INIT(event,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_SEQUENCE_END_EVENT,(start_mark),(end_mark)))
|
|
||||||
//
|
|
||||||
// #define MAPPING_START_EVENT_INIT(event,event_anchor,event_tag, \
|
|
||||||
// event_implicit,event_style,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_MAPPING_START_EVENT,(start_mark),(end_mark)), \
|
|
||||||
// (event).data.mapping_start.anchor = (event_anchor), \
|
|
||||||
// (event).data.mapping_start.tag = (event_tag), \
|
|
||||||
// (event).data.mapping_start.implicit = (event_implicit), \
|
|
||||||
// (event).data.mapping_start.style = (event_style))
|
|
||||||
//
|
|
||||||
// #define MAPPING_END_EVENT_INIT(event,start_mark,end_mark) \
|
|
||||||
// (EVENT_INIT((event),yaml_MAPPING_END_EVENT,(start_mark),(end_mark)))
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Document initializer.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define DOCUMENT_INIT(document,document_nodes_start,document_nodes_end, \
|
|
||||||
// document_version_directive,document_tag_directives_start, \
|
|
||||||
// document_tag_directives_end,document_start_implicit, \
|
|
||||||
// document_end_implicit,document_start_mark,document_end_mark) \
|
|
||||||
// (memset(&(document), 0, sizeof(yaml_document_t)), \
|
|
||||||
// (document).nodes.start = (document_nodes_start), \
|
|
||||||
// (document).nodes.end = (document_nodes_end), \
|
|
||||||
// (document).nodes.top = (document_nodes_start), \
|
|
||||||
// (document).version_directive = (document_version_directive), \
|
|
||||||
// (document).tag_directives.start = (document_tag_directives_start), \
|
|
||||||
// (document).tag_directives.end = (document_tag_directives_end), \
|
|
||||||
// (document).start_implicit = (document_start_implicit), \
|
|
||||||
// (document).end_implicit = (document_end_implicit), \
|
|
||||||
// (document).start_mark = (document_start_mark), \
|
|
||||||
// (document).end_mark = (document_end_mark))
|
|
||||||
//
|
|
||||||
// /*
|
|
||||||
// * Node initializers.
|
|
||||||
// */
|
|
||||||
//
|
|
||||||
// #define NODE_INIT(node,node_type,node_tag,node_start_mark,node_end_mark) \
|
|
||||||
// (memset(&(node), 0, sizeof(yaml_node_t)), \
|
|
||||||
// (node).type = (node_type), \
|
|
||||||
// (node).tag = (node_tag), \
|
|
||||||
// (node).start_mark = (node_start_mark), \
|
|
||||||
// (node).end_mark = (node_end_mark))
|
|
||||||
//
|
|
||||||
// #define SCALAR_NODE_INIT(node,node_tag,node_value,node_length, \
|
|
||||||
// node_style,start_mark,end_mark) \
|
|
||||||
// (NODE_INIT((node),yaml_SCALAR_NODE,(node_tag),(start_mark),(end_mark)), \
|
|
||||||
// (node).data.scalar.value = (node_value), \
|
|
||||||
// (node).data.scalar.length = (node_length), \
|
|
||||||
// (node).data.scalar.style = (node_style))
|
|
||||||
//
|
|
||||||
// #define SEQUENCE_NODE_INIT(node,node_tag,node_items_start,node_items_end, \
|
|
||||||
// node_style,start_mark,end_mark) \
|
|
||||||
// (NODE_INIT((node),yaml_SEQUENCE_NODE,(node_tag),(start_mark),(end_mark)), \
|
|
||||||
// (node).data.sequence.items.start = (node_items_start), \
|
|
||||||
// (node).data.sequence.items.end = (node_items_end), \
|
|
||||||
// (node).data.sequence.items.top = (node_items_start), \
|
|
||||||
// (node).data.sequence.style = (node_style))
|
|
||||||
//
|
|
||||||
// #define MAPPING_NODE_INIT(node,node_tag,node_pairs_start,node_pairs_end, \
|
|
||||||
// node_style,start_mark,end_mark) \
|
|
||||||
// (NODE_INIT((node),yaml_MAPPING_NODE,(node_tag),(start_mark),(end_mark)), \
|
|
||||||
// (node).data.mapping.pairs.start = (node_pairs_start), \
|
|
||||||
// (node).data.mapping.pairs.end = (node_pairs_end), \
|
|
||||||
// (node).data.mapping.pairs.top = (node_pairs_start), \
|
|
||||||
// (node).data.mapping.style = (node_style))
|
|
||||||
//
|
|
953
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/yamlh.go
generated
vendored
953
integration/vendor/github.com/cloudfoundry-incubator/candiedyaml/yamlh.go
generated
vendored
|
@ -1,953 +0,0 @@
|
||||||
/*
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package candiedyaml
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
)
|
|
||||||
|
|
||||||
/** The version directive data. */
|
|
||||||
type yaml_version_directive_t struct {
|
|
||||||
major int // The major version number
|
|
||||||
minor int // The minor version number
|
|
||||||
}
|
|
||||||
|
|
||||||
/** The tag directive data. */
|
|
||||||
type yaml_tag_directive_t struct {
|
|
||||||
handle []byte // The tag handle
|
|
||||||
prefix []byte // The tag prefix
|
|
||||||
}
|
|
||||||
|
|
||||||
/** The stream encoding. */
|
|
||||||
type yaml_encoding_t int
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** Let the parser choose the encoding. */
|
|
||||||
yaml_ANY_ENCODING yaml_encoding_t = iota
|
|
||||||
/** The defau lt UTF-8 encoding. */
|
|
||||||
yaml_UTF8_ENCODING
|
|
||||||
/** The UTF-16-LE encoding with BOM. */
|
|
||||||
yaml_UTF16LE_ENCODING
|
|
||||||
/** The UTF-16-BE encoding with BOM. */
|
|
||||||
yaml_UTF16BE_ENCODING
|
|
||||||
)
|
|
||||||
|
|
||||||
/** Line break types. */
|
|
||||||
type yaml_break_t int
|
|
||||||
|
|
||||||
const (
|
|
||||||
yaml_ANY_BREAK yaml_break_t = iota /** Let the parser choose the break type. */
|
|
||||||
yaml_CR_BREAK /** Use CR for line breaks (Mac style). */
|
|
||||||
yaml_LN_BREAK /** Use LN for line breaks (Unix style). */
|
|
||||||
yaml_CRLN_BREAK /** Use CR LN for line breaks (DOS style). */
|
|
||||||
)
|
|
||||||
|
|
||||||
/** Many bad things could happen with the parser and emitter. */
|
|
||||||
type YAML_error_type_t int
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** No error is produced. */
|
|
||||||
yaml_NO_ERROR YAML_error_type_t = iota
|
|
||||||
|
|
||||||
/** Cannot allocate or reallocate a block of memory. */
|
|
||||||
yaml_MEMORY_ERROR
|
|
||||||
|
|
||||||
/** Cannot read or decode the input stream. */
|
|
||||||
yaml_READER_ERROR
|
|
||||||
/** Cannot scan the input stream. */
|
|
||||||
yaml_SCANNER_ERROR
|
|
||||||
/** Cannot parse the input stream. */
|
|
||||||
yaml_PARSER_ERROR
|
|
||||||
/** Cannot compose a YAML document. */
|
|
||||||
yaml_COMPOSER_ERROR
|
|
||||||
|
|
||||||
/** Cannot write to the output stream. */
|
|
||||||
yaml_WRITER_ERROR
|
|
||||||
/** Cannot emit a YAML stream. */
|
|
||||||
yaml_EMITTER_ERROR
|
|
||||||
)
|
|
||||||
|
|
||||||
/** The pointer position. */
|
|
||||||
type YAML_mark_t struct {
|
|
||||||
/** The position index. */
|
|
||||||
index int
|
|
||||||
|
|
||||||
/** The position line. */
|
|
||||||
line int
|
|
||||||
|
|
||||||
/** The position column. */
|
|
||||||
column int
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m YAML_mark_t) String() string {
|
|
||||||
return fmt.Sprintf("line %d, column %d", m.line, m.column)
|
|
||||||
}
|
|
||||||
|
|
||||||
/** @} */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @defgroup styles Node Styles
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
type yaml_style_t int
|
|
||||||
|
|
||||||
/** Scalar styles. */
|
|
||||||
type yaml_scalar_style_t yaml_style_t
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** Let the emitter choose the style. */
|
|
||||||
yaml_ANY_SCALAR_STYLE yaml_scalar_style_t = iota
|
|
||||||
|
|
||||||
/** The plain scalar style. */
|
|
||||||
yaml_PLAIN_SCALAR_STYLE
|
|
||||||
|
|
||||||
/** The single-quoted scalar style. */
|
|
||||||
yaml_SINGLE_QUOTED_SCALAR_STYLE
|
|
||||||
/** The double-quoted scalar style. */
|
|
||||||
yaml_DOUBLE_QUOTED_SCALAR_STYLE
|
|
||||||
|
|
||||||
/** The literal scalar style. */
|
|
||||||
yaml_LITERAL_SCALAR_STYLE
|
|
||||||
/** The folded scalar style. */
|
|
||||||
yaml_FOLDED_SCALAR_STYLE
|
|
||||||
)
|
|
||||||
|
|
||||||
/** Sequence styles. */
|
|
||||||
type yaml_sequence_style_t yaml_style_t
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** Let the emitter choose the style. */
|
|
||||||
yaml_ANY_SEQUENCE_STYLE yaml_sequence_style_t = iota
|
|
||||||
|
|
||||||
/** The block sequence style. */
|
|
||||||
yaml_BLOCK_SEQUENCE_STYLE
|
|
||||||
/** The flow sequence style. */
|
|
||||||
yaml_FLOW_SEQUENCE_STYLE
|
|
||||||
)
|
|
||||||
|
|
||||||
/** Mapping styles. */
|
|
||||||
type yaml_mapping_style_t yaml_style_t
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** Let the emitter choose the style. */
|
|
||||||
yaml_ANY_MAPPING_STYLE yaml_mapping_style_t = iota
|
|
||||||
|
|
||||||
/** The block mapping style. */
|
|
||||||
yaml_BLOCK_MAPPING_STYLE
|
|
||||||
/** The flow mapping style. */
|
|
||||||
yaml_FLOW_MAPPING_STYLE
|
|
||||||
|
|
||||||
/* yaml_FLOW_SET_MAPPING_STYLE */
|
|
||||||
)
|
|
||||||
|
|
||||||
/** @} */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @defgroup tokens Tokens
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Token types. */
|
|
||||||
type yaml_token_type_t int
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** An empty token. */
|
|
||||||
yaml_NO_TOKEN yaml_token_type_t = iota
|
|
||||||
|
|
||||||
/** A STREAM-START token. */
|
|
||||||
yaml_STREAM_START_TOKEN
|
|
||||||
/** A STREAM-END token. */
|
|
||||||
yaml_STREAM_END_TOKEN
|
|
||||||
|
|
||||||
/** A VERSION-DIRECTIVE token. */
|
|
||||||
yaml_VERSION_DIRECTIVE_TOKEN
|
|
||||||
/** A TAG-DIRECTIVE token. */
|
|
||||||
yaml_TAG_DIRECTIVE_TOKEN
|
|
||||||
/** A DOCUMENT-START token. */
|
|
||||||
yaml_DOCUMENT_START_TOKEN
|
|
||||||
/** A DOCUMENT-END token. */
|
|
||||||
yaml_DOCUMENT_END_TOKEN
|
|
||||||
|
|
||||||
/** A BLOCK-SEQUENCE-START token. */
|
|
||||||
yaml_BLOCK_SEQUENCE_START_TOKEN
|
|
||||||
/** A BLOCK-SEQUENCE-END token. */
|
|
||||||
yaml_BLOCK_MAPPING_START_TOKEN
|
|
||||||
/** A BLOCK-END token. */
|
|
||||||
yaml_BLOCK_END_TOKEN
|
|
||||||
|
|
||||||
/** A FLOW-SEQUENCE-START token. */
|
|
||||||
yaml_FLOW_SEQUENCE_START_TOKEN
|
|
||||||
/** A FLOW-SEQUENCE-END token. */
|
|
||||||
yaml_FLOW_SEQUENCE_END_TOKEN
|
|
||||||
/** A FLOW-MAPPING-START token. */
|
|
||||||
yaml_FLOW_MAPPING_START_TOKEN
|
|
||||||
/** A FLOW-MAPPING-END token. */
|
|
||||||
yaml_FLOW_MAPPING_END_TOKEN
|
|
||||||
|
|
||||||
/** A BLOCK-ENTRY token. */
|
|
||||||
yaml_BLOCK_ENTRY_TOKEN
|
|
||||||
/** A FLOW-ENTRY token. */
|
|
||||||
yaml_FLOW_ENTRY_TOKEN
|
|
||||||
/** A KEY token. */
|
|
||||||
yaml_KEY_TOKEN
|
|
||||||
/** A VALUE token. */
|
|
||||||
yaml_VALUE_TOKEN
|
|
||||||
|
|
||||||
/** An ALIAS token. */
|
|
||||||
yaml_ALIAS_TOKEN
|
|
||||||
/** An ANCHOR token. */
|
|
||||||
yaml_ANCHOR_TOKEN
|
|
||||||
/** A TAG token. */
|
|
||||||
yaml_TAG_TOKEN
|
|
||||||
/** A SCALAR token. */
|
|
||||||
yaml_SCALAR_TOKEN
|
|
||||||
)
|
|
||||||
|
|
||||||
/** The token structure. */
|
|
||||||
type yaml_token_t struct {
|
|
||||||
|
|
||||||
/** The token type. */
|
|
||||||
token_type yaml_token_type_t
|
|
||||||
|
|
||||||
/** The token data. */
|
|
||||||
/** The stream start (for @c yaml_STREAM_START_TOKEN). */
|
|
||||||
encoding yaml_encoding_t
|
|
||||||
|
|
||||||
/** The alias (for @c yaml_ALIAS_TOKEN, yaml_ANCHOR_TOKEN, yaml_SCALAR_TOKEN,yaml_TAG_TOKEN ). */
|
|
||||||
/** The anchor (for @c ). */
|
|
||||||
/** The scalar value (for @c ). */
|
|
||||||
value []byte
|
|
||||||
|
|
||||||
/** The tag suffix. */
|
|
||||||
suffix []byte
|
|
||||||
|
|
||||||
/** The scalar value (for @c yaml_SCALAR_TOKEN). */
|
|
||||||
/** The scalar style. */
|
|
||||||
style yaml_scalar_style_t
|
|
||||||
|
|
||||||
/** The version directive (for @c yaml_VERSION_DIRECTIVE_TOKEN). */
|
|
||||||
version_directive yaml_version_directive_t
|
|
||||||
|
|
||||||
/** The tag directive (for @c yaml_TAG_DIRECTIVE_TOKEN). */
|
|
||||||
prefix []byte
|
|
||||||
|
|
||||||
/** The beginning of the token. */
|
|
||||||
start_mark YAML_mark_t
|
|
||||||
/** The end of the token. */
|
|
||||||
end_mark YAML_mark_t
|
|
||||||
|
|
||||||
major, minor int
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @defgroup events Events
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Event types. */
|
|
||||||
type yaml_event_type_t int
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** An empty event. */
|
|
||||||
yaml_NO_EVENT yaml_event_type_t = iota
|
|
||||||
|
|
||||||
/** A STREAM-START event. */
|
|
||||||
yaml_STREAM_START_EVENT
|
|
||||||
/** A STREAM-END event. */
|
|
||||||
yaml_STREAM_END_EVENT
|
|
||||||
|
|
||||||
/** A DOCUMENT-START event. */
|
|
||||||
yaml_DOCUMENT_START_EVENT
|
|
||||||
/** A DOCUMENT-END event. */
|
|
||||||
yaml_DOCUMENT_END_EVENT
|
|
||||||
|
|
||||||
/** An ALIAS event. */
|
|
||||||
yaml_ALIAS_EVENT
|
|
||||||
/** A SCALAR event. */
|
|
||||||
yaml_SCALAR_EVENT
|
|
||||||
|
|
||||||
/** A SEQUENCE-START event. */
|
|
||||||
yaml_SEQUENCE_START_EVENT
|
|
||||||
/** A SEQUENCE-END event. */
|
|
||||||
yaml_SEQUENCE_END_EVENT
|
|
||||||
|
|
||||||
/** A MAPPING-START event. */
|
|
||||||
yaml_MAPPING_START_EVENT
|
|
||||||
/** A MAPPING-END event. */
|
|
||||||
yaml_MAPPING_END_EVENT
|
|
||||||
)
|
|
||||||
|
|
||||||
/** The event structure. */
|
|
||||||
type yaml_event_t struct {
|
|
||||||
|
|
||||||
/** The event type. */
|
|
||||||
event_type yaml_event_type_t
|
|
||||||
|
|
||||||
/** The stream parameters (for @c yaml_STREAM_START_EVENT). */
|
|
||||||
encoding yaml_encoding_t
|
|
||||||
|
|
||||||
/** The document parameters (for @c yaml_DOCUMENT_START_EVENT). */
|
|
||||||
version_directive *yaml_version_directive_t
|
|
||||||
|
|
||||||
/** The beginning and end of the tag directives list. */
|
|
||||||
tag_directives []yaml_tag_directive_t
|
|
||||||
|
|
||||||
/** The document parameters (for @c yaml_DOCUMENT_START_EVENT, yaml_DOCUMENT_END_EVENT, yaml_SEQUENCE_START_EVENT,yaml_MAPPING_START_EVENT). */
|
|
||||||
/** Is the document indicator implicit? */
|
|
||||||
implicit bool
|
|
||||||
|
|
||||||
/** The alias parameters (for @c yaml_ALIAS_EVENT,yaml_SCALAR_EVENT, yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT). */
|
|
||||||
/** The anchor. */
|
|
||||||
anchor []byte
|
|
||||||
|
|
||||||
/** The scalar parameters (for @c yaml_SCALAR_EVENT,yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT). */
|
|
||||||
/** The tag. */
|
|
||||||
tag []byte
|
|
||||||
/** The scalar value. */
|
|
||||||
value []byte
|
|
||||||
|
|
||||||
/** Is the tag optional for the plain style? */
|
|
||||||
plain_implicit bool
|
|
||||||
/** Is the tag optional for any non-plain style? */
|
|
||||||
quoted_implicit bool
|
|
||||||
|
|
||||||
/** The sequence parameters (for @c yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT). */
|
|
||||||
/** The sequence style. */
|
|
||||||
/** The scalar style. */
|
|
||||||
style yaml_style_t
|
|
||||||
|
|
||||||
/** The beginning of the event. */
|
|
||||||
start_mark, end_mark YAML_mark_t
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @defgroup nodes Nodes
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** The tag @c !!null with the only possible value: @c null. */
|
|
||||||
yaml_NULL_TAG = "tag:yaml.org,2002:null"
|
|
||||||
/** The tag @c !!bool with the values: @c true and @c falce. */
|
|
||||||
yaml_BOOL_TAG = "tag:yaml.org,2002:bool"
|
|
||||||
/** The tag @c !!str for string values. */
|
|
||||||
yaml_STR_TAG = "tag:yaml.org,2002:str"
|
|
||||||
/** The tag @c !!int for integer values. */
|
|
||||||
yaml_INT_TAG = "tag:yaml.org,2002:int"
|
|
||||||
/** The tag @c !!float for float values. */
|
|
||||||
yaml_FLOAT_TAG = "tag:yaml.org,2002:float"
|
|
||||||
/** The tag @c !!timestamp for date and time values. */
|
|
||||||
yaml_TIMESTAMP_TAG = "tag:yaml.org,2002:timestamp"
|
|
||||||
|
|
||||||
/** The tag @c !!seq is used to denote sequences. */
|
|
||||||
yaml_SEQ_TAG = "tag:yaml.org,2002:seq"
|
|
||||||
/** The tag @c !!map is used to denote mapping. */
|
|
||||||
yaml_MAP_TAG = "tag:yaml.org,2002:map"
|
|
||||||
|
|
||||||
/** The default scalar tag is @c !!str. */
|
|
||||||
yaml_DEFAULT_SCALAR_TAG = yaml_STR_TAG
|
|
||||||
/** The default sequence tag is @c !!seq. */
|
|
||||||
yaml_DEFAULT_SEQUENCE_TAG = yaml_SEQ_TAG
|
|
||||||
/** The default mapping tag is @c !!map. */
|
|
||||||
yaml_DEFAULT_MAPPING_TAG = yaml_MAP_TAG
|
|
||||||
|
|
||||||
yaml_BINARY_TAG = "tag:yaml.org,2002:binary"
|
|
||||||
)
|
|
||||||
|
|
||||||
/** Node types. */
|
|
||||||
type yaml_node_type_t int
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** An empty node. */
|
|
||||||
yaml_NO_NODE yaml_node_type_t = iota
|
|
||||||
|
|
||||||
/** A scalar node. */
|
|
||||||
yaml_SCALAR_NODE
|
|
||||||
/** A sequence node. */
|
|
||||||
yaml_SEQUENCE_NODE
|
|
||||||
/** A mapping node. */
|
|
||||||
yaml_MAPPING_NODE
|
|
||||||
)
|
|
||||||
|
|
||||||
/** An element of a sequence node. */
|
|
||||||
type yaml_node_item_t int
|
|
||||||
|
|
||||||
/** An element of a mapping node. */
|
|
||||||
type yaml_node_pair_t struct {
|
|
||||||
/** The key of the element. */
|
|
||||||
key int
|
|
||||||
/** The value of the element. */
|
|
||||||
value int
|
|
||||||
}
|
|
||||||
|
|
||||||
/** The node structure. */
|
|
||||||
type yaml_node_t struct {
|
|
||||||
|
|
||||||
/** The node type. */
|
|
||||||
node_type yaml_node_type_t
|
|
||||||
|
|
||||||
/** The node tag. */
|
|
||||||
tag []byte
|
|
||||||
|
|
||||||
/** The scalar parameters (for @c yaml_SCALAR_NODE). */
|
|
||||||
scalar struct {
|
|
||||||
/** The scalar value. */
|
|
||||||
value []byte
|
|
||||||
/** The scalar style. */
|
|
||||||
style yaml_scalar_style_t
|
|
||||||
}
|
|
||||||
|
|
||||||
/** The sequence parameters (for @c yaml_SEQUENCE_NODE). */
|
|
||||||
sequence struct {
|
|
||||||
/** The stack of sequence items. */
|
|
||||||
items []yaml_node_item_t
|
|
||||||
/** The sequence style. */
|
|
||||||
style yaml_sequence_style_t
|
|
||||||
}
|
|
||||||
|
|
||||||
/** The mapping parameters (for @c yaml_MAPPING_NODE). */
|
|
||||||
mapping struct {
|
|
||||||
/** The stack of mapping pairs (key, value). */
|
|
||||||
pairs []yaml_node_pair_t
|
|
||||||
/** The mapping style. */
|
|
||||||
style yaml_mapping_style_t
|
|
||||||
}
|
|
||||||
|
|
||||||
/** The beginning of the node. */
|
|
||||||
start_mark YAML_mark_t
|
|
||||||
/** The end of the node. */
|
|
||||||
end_mark YAML_mark_t
|
|
||||||
}
|
|
||||||
|
|
||||||
/** The document structure. */
|
|
||||||
type yaml_document_t struct {
|
|
||||||
|
|
||||||
/** The document nodes. */
|
|
||||||
nodes []yaml_node_t
|
|
||||||
|
|
||||||
/** The version directive. */
|
|
||||||
version_directive *yaml_version_directive_t
|
|
||||||
|
|
||||||
/** The list of tag directives. */
|
|
||||||
tags []yaml_tag_directive_t
|
|
||||||
|
|
||||||
/** Is the document start indicator implicit? */
|
|
||||||
start_implicit bool
|
|
||||||
/** Is the document end indicator implicit? */
|
|
||||||
end_implicit bool
|
|
||||||
|
|
||||||
/** The beginning of the document. */
|
|
||||||
start_mark YAML_mark_t
|
|
||||||
/** The end of the document. */
|
|
||||||
end_mark YAML_mark_t
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The prototype of a read handler.
|
|
||||||
*
|
|
||||||
* The read handler is called when the parser needs to read more bytes from the
|
|
||||||
* source. The handler should write not more than @a size bytes to the @a
|
|
||||||
* buffer. The number of written bytes should be set to the @a length variable.
|
|
||||||
*
|
|
||||||
* @param[in,out] data A pointer to an application data specified by
|
|
||||||
* yaml_parser_set_input().
|
|
||||||
* @param[out] buffer The buffer to write the data from the source.
|
|
||||||
* @param[in] size The size of the buffer.
|
|
||||||
* @param[out] size_read The actual number of bytes read from the source.
|
|
||||||
*
|
|
||||||
* @returns On success, the handler should return @c 1. If the handler failed,
|
|
||||||
* the returned value should be @c 0. On EOF, the handler should set the
|
|
||||||
* @a size_read to @c 0 and return @c 1.
|
|
||||||
*/
|
|
||||||
|
|
||||||
type yaml_read_handler_t func(parser *yaml_parser_t, buffer []byte) (n int, err error)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This structure holds information about a potential simple key.
|
|
||||||
*/
|
|
||||||
|
|
||||||
type yaml_simple_key_t struct {
|
|
||||||
/** Is a simple key possible? */
|
|
||||||
possible bool
|
|
||||||
|
|
||||||
/** Is a simple key required? */
|
|
||||||
required bool
|
|
||||||
|
|
||||||
/** The number of the token. */
|
|
||||||
token_number int
|
|
||||||
|
|
||||||
/** The position mark. */
|
|
||||||
mark YAML_mark_t
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The states of the parser.
|
|
||||||
*/
|
|
||||||
type yaml_parser_state_t int
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** Expect STREAM-START. */
|
|
||||||
yaml_PARSE_STREAM_START_STATE yaml_parser_state_t = iota
|
|
||||||
/** Expect the beginning of an implicit document. */
|
|
||||||
yaml_PARSE_IMPLICIT_DOCUMENT_START_STATE
|
|
||||||
/** Expect DOCUMENT-START. */
|
|
||||||
yaml_PARSE_DOCUMENT_START_STATE
|
|
||||||
/** Expect the content of a document. */
|
|
||||||
yaml_PARSE_DOCUMENT_CONTENT_STATE
|
|
||||||
/** Expect DOCUMENT-END. */
|
|
||||||
yaml_PARSE_DOCUMENT_END_STATE
|
|
||||||
/** Expect a block node. */
|
|
||||||
yaml_PARSE_BLOCK_NODE_STATE
|
|
||||||
/** Expect a block node or indentless sequence. */
|
|
||||||
yaml_PARSE_BLOCK_NODE_OR_INDENTLESS_SEQUENCE_STATE
|
|
||||||
/** Expect a flow node. */
|
|
||||||
yaml_PARSE_FLOW_NODE_STATE
|
|
||||||
/** Expect the first entry of a block sequence. */
|
|
||||||
yaml_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE
|
|
||||||
/** Expect an entry of a block sequence. */
|
|
||||||
yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE
|
|
||||||
/** Expect an entry of an indentless sequence. */
|
|
||||||
yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE
|
|
||||||
/** Expect the first key of a block mapping. */
|
|
||||||
yaml_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE
|
|
||||||
/** Expect a block mapping key. */
|
|
||||||
yaml_PARSE_BLOCK_MAPPING_KEY_STATE
|
|
||||||
/** Expect a block mapping value. */
|
|
||||||
yaml_PARSE_BLOCK_MAPPING_VALUE_STATE
|
|
||||||
/** Expect the first entry of a flow sequence. */
|
|
||||||
yaml_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE
|
|
||||||
/** Expect an entry of a flow sequence. */
|
|
||||||
yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE
|
|
||||||
/** Expect a key of an ordered mapping. */
|
|
||||||
yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE
|
|
||||||
/** Expect a value of an ordered mapping. */
|
|
||||||
yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE
|
|
||||||
/** Expect the and of an ordered mapping entry. */
|
|
||||||
yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE
|
|
||||||
/** Expect the first key of a flow mapping. */
|
|
||||||
yaml_PARSE_FLOW_MAPPING_FIRST_KEY_STATE
|
|
||||||
/** Expect a key of a flow mapping. */
|
|
||||||
yaml_PARSE_FLOW_MAPPING_KEY_STATE
|
|
||||||
/** Expect a value of a flow mapping. */
|
|
||||||
yaml_PARSE_FLOW_MAPPING_VALUE_STATE
|
|
||||||
/** Expect an empty value of a flow mapping. */
|
|
||||||
yaml_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE
|
|
||||||
/** Expect nothing. */
|
|
||||||
yaml_PARSE_END_STATE
|
|
||||||
)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This structure holds aliases data.
|
|
||||||
*/
|
|
||||||
|
|
||||||
type yaml_alias_data_t struct {
|
|
||||||
/** The anchor. */
|
|
||||||
anchor []byte
|
|
||||||
/** The node id. */
|
|
||||||
index int
|
|
||||||
/** The anchor mark. */
|
|
||||||
mark YAML_mark_t
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The parser structure.
|
|
||||||
*
|
|
||||||
* All members are internal. Manage the structure using the @c yaml_parser_
|
|
||||||
* family of functions.
|
|
||||||
*/
|
|
||||||
|
|
||||||
type yaml_parser_t struct {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @name Error handling
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Error type. */
|
|
||||||
error YAML_error_type_t
|
|
||||||
/** Error description. */
|
|
||||||
problem string
|
|
||||||
/** The byte about which the problem occured. */
|
|
||||||
problem_offset int
|
|
||||||
/** The problematic value (@c -1 is none). */
|
|
||||||
problem_value int
|
|
||||||
/** The problem position. */
|
|
||||||
problem_mark YAML_mark_t
|
|
||||||
/** The error context. */
|
|
||||||
context string
|
|
||||||
/** The context position. */
|
|
||||||
context_mark YAML_mark_t
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @name Reader stuff
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Read handler. */
|
|
||||||
read_handler yaml_read_handler_t
|
|
||||||
|
|
||||||
/** Reader input data. */
|
|
||||||
input_reader io.Reader
|
|
||||||
input []byte
|
|
||||||
input_pos int
|
|
||||||
|
|
||||||
/** EOF flag */
|
|
||||||
eof bool
|
|
||||||
|
|
||||||
/** The working buffer. */
|
|
||||||
buffer []byte
|
|
||||||
buffer_pos int
|
|
||||||
|
|
||||||
/* The number of unread characters in the buffer. */
|
|
||||||
unread int
|
|
||||||
|
|
||||||
/** The raw buffer. */
|
|
||||||
raw_buffer []byte
|
|
||||||
raw_buffer_pos int
|
|
||||||
|
|
||||||
/** The input encoding. */
|
|
||||||
encoding yaml_encoding_t
|
|
||||||
|
|
||||||
/** The offset of the current position (in bytes). */
|
|
||||||
offset int
|
|
||||||
|
|
||||||
/** The mark of the current position. */
|
|
||||||
mark YAML_mark_t
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @name Scanner stuff
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Have we started to scan the input stream? */
|
|
||||||
stream_start_produced bool
|
|
||||||
|
|
||||||
/** Have we reached the end of the input stream? */
|
|
||||||
stream_end_produced bool
|
|
||||||
|
|
||||||
/** The number of unclosed '[' and '{' indicators. */
|
|
||||||
flow_level int
|
|
||||||
|
|
||||||
/** The tokens queue. */
|
|
||||||
tokens []yaml_token_t
|
|
||||||
tokens_head int
|
|
||||||
|
|
||||||
/** The number of tokens fetched from the queue. */
|
|
||||||
tokens_parsed int
|
|
||||||
|
|
||||||
/* Does the tokens queue contain a token ready for dequeueing. */
|
|
||||||
token_available bool
|
|
||||||
|
|
||||||
/** The indentation levels stack. */
|
|
||||||
indents []int
|
|
||||||
|
|
||||||
/** The current indentation level. */
|
|
||||||
indent int
|
|
||||||
|
|
||||||
/** May a simple key occur at the current position? */
|
|
||||||
simple_key_allowed bool
|
|
||||||
|
|
||||||
/** The stack of simple keys. */
|
|
||||||
simple_keys []yaml_simple_key_t
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @name Parser stuff
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** The parser states stack. */
|
|
||||||
states []yaml_parser_state_t
|
|
||||||
|
|
||||||
/** The current parser state. */
|
|
||||||
state yaml_parser_state_t
|
|
||||||
|
|
||||||
/** The stack of marks. */
|
|
||||||
marks []YAML_mark_t
|
|
||||||
|
|
||||||
/** The list of TAG directives. */
|
|
||||||
tag_directives []yaml_tag_directive_t
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @name Dumper stuff
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** The alias data. */
|
|
||||||
aliases []yaml_alias_data_t
|
|
||||||
|
|
||||||
/** The currently parsed document. */
|
|
||||||
document *yaml_document_t
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The prototype of a write handler.
|
|
||||||
*
|
|
||||||
* The write handler is called when the emitter needs to flush the accumulated
|
|
||||||
* characters to the output. The handler should write @a size bytes of the
|
|
||||||
* @a buffer to the output.
|
|
||||||
*
|
|
||||||
* @param[in,out] data A pointer to an application data specified by
|
|
||||||
* yaml_emitter_set_output().
|
|
||||||
* @param[in] buffer The buffer with bytes to be written.
|
|
||||||
* @param[in] size The size of the buffer.
|
|
||||||
*
|
|
||||||
* @returns On success, the handler should return @c 1. If the handler failed,
|
|
||||||
* the returned value should be @c 0.
|
|
||||||
*/
|
|
||||||
|
|
||||||
type yaml_write_handler_t func(emitter *yaml_emitter_t, buffer []byte) error
|
|
||||||
|
|
||||||
/** The emitter states. */
|
|
||||||
type yaml_emitter_state_t int
|
|
||||||
|
|
||||||
const (
|
|
||||||
/** Expect STREAM-START. */
|
|
||||||
yaml_EMIT_STREAM_START_STATE yaml_emitter_state_t = iota
|
|
||||||
/** Expect the first DOCUMENT-START or STREAM-END. */
|
|
||||||
yaml_EMIT_FIRST_DOCUMENT_START_STATE
|
|
||||||
/** Expect DOCUMENT-START or STREAM-END. */
|
|
||||||
yaml_EMIT_DOCUMENT_START_STATE
|
|
||||||
/** Expect the content of a document. */
|
|
||||||
yaml_EMIT_DOCUMENT_CONTENT_STATE
|
|
||||||
/** Expect DOCUMENT-END. */
|
|
||||||
yaml_EMIT_DOCUMENT_END_STATE
|
|
||||||
/** Expect the first item of a flow sequence. */
|
|
||||||
yaml_EMIT_FLOW_SEQUENCE_FIRST_ITEM_STATE
|
|
||||||
/** Expect an item of a flow sequence. */
|
|
||||||
yaml_EMIT_FLOW_SEQUENCE_ITEM_STATE
|
|
||||||
/** Expect the first key of a flow mapping. */
|
|
||||||
yaml_EMIT_FLOW_MAPPING_FIRST_KEY_STATE
|
|
||||||
/** Expect a key of a flow mapping. */
|
|
||||||
yaml_EMIT_FLOW_MAPPING_KEY_STATE
|
|
||||||
/** Expect a value for a simple key of a flow mapping. */
|
|
||||||
yaml_EMIT_FLOW_MAPPING_SIMPLE_VALUE_STATE
|
|
||||||
/** Expect a value of a flow mapping. */
|
|
||||||
yaml_EMIT_FLOW_MAPPING_VALUE_STATE
|
|
||||||
/** Expect the first item of a block sequence. */
|
|
||||||
yaml_EMIT_BLOCK_SEQUENCE_FIRST_ITEM_STATE
|
|
||||||
/** Expect an item of a block sequence. */
|
|
||||||
yaml_EMIT_BLOCK_SEQUENCE_ITEM_STATE
|
|
||||||
/** Expect the first key of a block mapping. */
|
|
||||||
yaml_EMIT_BLOCK_MAPPING_FIRST_KEY_STATE
|
|
||||||
/** Expect the key of a block mapping. */
|
|
||||||
yaml_EMIT_BLOCK_MAPPING_KEY_STATE
|
|
||||||
/** Expect a value for a simple key of a block mapping. */
|
|
||||||
yaml_EMIT_BLOCK_MAPPING_SIMPLE_VALUE_STATE
|
|
||||||
/** Expect a value of a block mapping. */
|
|
||||||
yaml_EMIT_BLOCK_MAPPING_VALUE_STATE
|
|
||||||
/** Expect nothing. */
|
|
||||||
yaml_EMIT_END_STATE
|
|
||||||
)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The emitter structure.
|
|
||||||
*
|
|
||||||
* All members are internal. Manage the structure using the @c yaml_emitter_
|
|
||||||
* family of functions.
|
|
||||||
*/
|
|
||||||
|
|
||||||
type yaml_emitter_t struct {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @name Error handling
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Error type. */
|
|
||||||
error YAML_error_type_t
|
|
||||||
/** Error description. */
|
|
||||||
problem string
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @name Writer stuff
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Write handler. */
|
|
||||||
write_handler yaml_write_handler_t
|
|
||||||
|
|
||||||
/** Standard (string or file) output data. */
|
|
||||||
output_buffer *[]byte
|
|
||||||
output_writer io.Writer
|
|
||||||
|
|
||||||
/** The working buffer. */
|
|
||||||
buffer []byte
|
|
||||||
buffer_pos int
|
|
||||||
|
|
||||||
/** The raw buffer. */
|
|
||||||
raw_buffer []byte
|
|
||||||
raw_buffer_pos int
|
|
||||||
|
|
||||||
/** The stream encoding. */
|
|
||||||
encoding yaml_encoding_t
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @name Emitter stuff
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** If the output is in the canonical style? */
|
|
||||||
canonical bool
|
|
||||||
/** The number of indentation spaces. */
|
|
||||||
best_indent int
|
|
||||||
/** The preferred width of the output lines. */
|
|
||||||
best_width int
|
|
||||||
/** Allow unescaped non-ASCII characters? */
|
|
||||||
unicode bool
|
|
||||||
/** The preferred line break. */
|
|
||||||
line_break yaml_break_t
|
|
||||||
|
|
||||||
/** The stack of states. */
|
|
||||||
states []yaml_emitter_state_t
|
|
||||||
|
|
||||||
/** The current emitter state. */
|
|
||||||
state yaml_emitter_state_t
|
|
||||||
|
|
||||||
/** The event queue. */
|
|
||||||
events []yaml_event_t
|
|
||||||
events_head int
|
|
||||||
|
|
||||||
/** The stack of indentation levels. */
|
|
||||||
indents []int
|
|
||||||
|
|
||||||
/** The list of tag directives. */
|
|
||||||
tag_directives []yaml_tag_directive_t
|
|
||||||
|
|
||||||
/** The current indentation level. */
|
|
||||||
indent int
|
|
||||||
|
|
||||||
/** The current flow level. */
|
|
||||||
flow_level int
|
|
||||||
|
|
||||||
/** Is it the document root context? */
|
|
||||||
root_context bool
|
|
||||||
/** Is it a sequence context? */
|
|
||||||
sequence_context bool
|
|
||||||
/** Is it a mapping context? */
|
|
||||||
mapping_context bool
|
|
||||||
/** Is it a simple mapping key context? */
|
|
||||||
simple_key_context bool
|
|
||||||
|
|
||||||
/** The current line. */
|
|
||||||
line int
|
|
||||||
/** The current column. */
|
|
||||||
column int
|
|
||||||
/** If the last character was a whitespace? */
|
|
||||||
whitespace bool
|
|
||||||
/** If the last character was an indentation character (' ', '-', '?', ':')? */
|
|
||||||
indention bool
|
|
||||||
/** If an explicit document end is required? */
|
|
||||||
open_ended bool
|
|
||||||
|
|
||||||
/** Anchor analysis. */
|
|
||||||
anchor_data struct {
|
|
||||||
/** The anchor value. */
|
|
||||||
anchor []byte
|
|
||||||
/** Is it an alias? */
|
|
||||||
alias bool
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Tag analysis. */
|
|
||||||
tag_data struct {
|
|
||||||
/** The tag handle. */
|
|
||||||
handle []byte
|
|
||||||
/** The tag suffix. */
|
|
||||||
suffix []byte
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Scalar analysis. */
|
|
||||||
scalar_data struct {
|
|
||||||
/** The scalar value. */
|
|
||||||
value []byte
|
|
||||||
/** Does the scalar contain line breaks? */
|
|
||||||
multiline bool
|
|
||||||
/** Can the scalar be expessed in the flow plain style? */
|
|
||||||
flow_plain_allowed bool
|
|
||||||
/** Can the scalar be expressed in the block plain style? */
|
|
||||||
block_plain_allowed bool
|
|
||||||
/** Can the scalar be expressed in the single quoted style? */
|
|
||||||
single_quoted_allowed bool
|
|
||||||
/** Can the scalar be expressed in the literal or folded styles? */
|
|
||||||
block_allowed bool
|
|
||||||
/** The output style. */
|
|
||||||
style yaml_scalar_style_t
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @name Dumper stuff
|
|
||||||
* @{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** If the stream was already opened? */
|
|
||||||
opened bool
|
|
||||||
/** If the stream was already closed? */
|
|
||||||
closed bool
|
|
||||||
|
|
||||||
/** The information associated with the document nodes. */
|
|
||||||
anchors *struct {
|
|
||||||
/** The number of references. */
|
|
||||||
references int
|
|
||||||
/** The anchor id. */
|
|
||||||
anchor int
|
|
||||||
/** If the node has been emitted? */
|
|
||||||
serialized bool
|
|
||||||
}
|
|
||||||
|
|
||||||
/** The last assigned anchor id. */
|
|
||||||
last_anchor_id int
|
|
||||||
|
|
||||||
/** The currently emitted document. */
|
|
||||||
document *yaml_document_t
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
*/
|
|
||||||
|
|
||||||
}
|
|
202
integration/vendor/github.com/docker/distribution/LICENSE
generated
vendored
202
integration/vendor/github.com/docker/distribution/LICENSE
generated
vendored
|
@ -1,202 +0,0 @@
|
||||||
Apache License
|
|
||||||
Version 2.0, January 2004
|
|
||||||
http://www.apache.org/licenses/
|
|
||||||
|
|
||||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
|
||||||
|
|
||||||
1. Definitions.
|
|
||||||
|
|
||||||
"License" shall mean the terms and conditions for use, reproduction,
|
|
||||||
and distribution as defined by Sections 1 through 9 of this document.
|
|
||||||
|
|
||||||
"Licensor" shall mean the copyright owner or entity authorized by
|
|
||||||
the copyright owner that is granting the License.
|
|
||||||
|
|
||||||
"Legal Entity" shall mean the union of the acting entity and all
|
|
||||||
other entities that control, are controlled by, or are under common
|
|
||||||
control with that entity. For the purposes of this definition,
|
|
||||||
"control" means (i) the power, direct or indirect, to cause the
|
|
||||||
direction or management of such entity, whether by contract or
|
|
||||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
|
||||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
|
||||||
|
|
||||||
"You" (or "Your") shall mean an individual or Legal Entity
|
|
||||||
exercising permissions granted by this License.
|
|
||||||
|
|
||||||
"Source" form shall mean the preferred form for making modifications,
|
|
||||||
including but not limited to software source code, documentation
|
|
||||||
source, and configuration files.
|
|
||||||
|
|
||||||
"Object" form shall mean any form resulting from mechanical
|
|
||||||
transformation or translation of a Source form, including but
|
|
||||||
not limited to compiled object code, generated documentation,
|
|
||||||
and conversions to other media types.
|
|
||||||
|
|
||||||
"Work" shall mean the work of authorship, whether in Source or
|
|
||||||
Object form, made available under the License, as indicated by a
|
|
||||||
copyright notice that is included in or attached to the work
|
|
||||||
(an example is provided in the Appendix below).
|
|
||||||
|
|
||||||
"Derivative Works" shall mean any work, whether in Source or Object
|
|
||||||
form, that is based on (or derived from) the Work and for which the
|
|
||||||
editorial revisions, annotations, elaborations, or other modifications
|
|
||||||
represent, as a whole, an original work of authorship. For the purposes
|
|
||||||
of this License, Derivative Works shall not include works that remain
|
|
||||||
separable from, or merely link (or bind by name) to the interfaces of,
|
|
||||||
the Work and Derivative Works thereof.
|
|
||||||
|
|
||||||
"Contribution" shall mean any work of authorship, including
|
|
||||||
the original version of the Work and any modifications or additions
|
|
||||||
to that Work or Derivative Works thereof, that is intentionally
|
|
||||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
|
||||||
or by an individual or Legal Entity authorized to submit on behalf of
|
|
||||||
the copyright owner. For the purposes of this definition, "submitted"
|
|
||||||
means any form of electronic, verbal, or written communication sent
|
|
||||||
to the Licensor or its representatives, including but not limited to
|
|
||||||
communication on electronic mailing lists, source code control systems,
|
|
||||||
and issue tracking systems that are managed by, or on behalf of, the
|
|
||||||
Licensor for the purpose of discussing and improving the Work, but
|
|
||||||
excluding communication that is conspicuously marked or otherwise
|
|
||||||
designated in writing by the copyright owner as "Not a Contribution."
|
|
||||||
|
|
||||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
|
||||||
on behalf of whom a Contribution has been received by Licensor and
|
|
||||||
subsequently incorporated within the Work.
|
|
||||||
|
|
||||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
|
||||||
this License, each Contributor hereby grants to You a perpetual,
|
|
||||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
|
||||||
copyright license to reproduce, prepare Derivative Works of,
|
|
||||||
publicly display, publicly perform, sublicense, and distribute the
|
|
||||||
Work and such Derivative Works in Source or Object form.
|
|
||||||
|
|
||||||
3. Grant of Patent License. Subject to the terms and conditions of
|
|
||||||
this License, each Contributor hereby grants to You a perpetual,
|
|
||||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
|
||||||
(except as stated in this section) patent license to make, have made,
|
|
||||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
|
||||||
where such license applies only to those patent claims licensable
|
|
||||||
by such Contributor that are necessarily infringed by their
|
|
||||||
Contribution(s) alone or by combination of their Contribution(s)
|
|
||||||
with the Work to which such Contribution(s) was submitted. If You
|
|
||||||
institute patent litigation against any entity (including a
|
|
||||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
|
||||||
or a Contribution incorporated within the Work constitutes direct
|
|
||||||
or contributory patent infringement, then any patent licenses
|
|
||||||
granted to You under this License for that Work shall terminate
|
|
||||||
as of the date such litigation is filed.
|
|
||||||
|
|
||||||
4. Redistribution. You may reproduce and distribute copies of the
|
|
||||||
Work or Derivative Works thereof in any medium, with or without
|
|
||||||
modifications, and in Source or Object form, provided that You
|
|
||||||
meet the following conditions:
|
|
||||||
|
|
||||||
(a) You must give any other recipients of the Work or
|
|
||||||
Derivative Works a copy of this License; and
|
|
||||||
|
|
||||||
(b) You must cause any modified files to carry prominent notices
|
|
||||||
stating that You changed the files; and
|
|
||||||
|
|
||||||
(c) You must retain, in the Source form of any Derivative Works
|
|
||||||
that You distribute, all copyright, patent, trademark, and
|
|
||||||
attribution notices from the Source form of the Work,
|
|
||||||
excluding those notices that do not pertain to any part of
|
|
||||||
the Derivative Works; and
|
|
||||||
|
|
||||||
(d) If the Work includes a "NOTICE" text file as part of its
|
|
||||||
distribution, then any Derivative Works that You distribute must
|
|
||||||
include a readable copy of the attribution notices contained
|
|
||||||
within such NOTICE file, excluding those notices that do not
|
|
||||||
pertain to any part of the Derivative Works, in at least one
|
|
||||||
of the following places: within a NOTICE text file distributed
|
|
||||||
as part of the Derivative Works; within the Source form or
|
|
||||||
documentation, if provided along with the Derivative Works; or,
|
|
||||||
within a display generated by the Derivative Works, if and
|
|
||||||
wherever such third-party notices normally appear. The contents
|
|
||||||
of the NOTICE file are for informational purposes only and
|
|
||||||
do not modify the License. You may add Your own attribution
|
|
||||||
notices within Derivative Works that You distribute, alongside
|
|
||||||
or as an addendum to the NOTICE text from the Work, provided
|
|
||||||
that such additional attribution notices cannot be construed
|
|
||||||
as modifying the License.
|
|
||||||
|
|
||||||
You may add Your own copyright statement to Your modifications and
|
|
||||||
may provide additional or different license terms and conditions
|
|
||||||
for use, reproduction, or distribution of Your modifications, or
|
|
||||||
for any such Derivative Works as a whole, provided Your use,
|
|
||||||
reproduction, and distribution of the Work otherwise complies with
|
|
||||||
the conditions stated in this License.
|
|
||||||
|
|
||||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
|
||||||
any Contribution intentionally submitted for inclusion in the Work
|
|
||||||
by You to the Licensor shall be under the terms and conditions of
|
|
||||||
this License, without any additional terms or conditions.
|
|
||||||
Notwithstanding the above, nothing herein shall supersede or modify
|
|
||||||
the terms of any separate license agreement you may have executed
|
|
||||||
with Licensor regarding such Contributions.
|
|
||||||
|
|
||||||
6. Trademarks. This License does not grant permission to use the trade
|
|
||||||
names, trademarks, service marks, or product names of the Licensor,
|
|
||||||
except as required for reasonable and customary use in describing the
|
|
||||||
origin of the Work and reproducing the content of the NOTICE file.
|
|
||||||
|
|
||||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
|
||||||
agreed to in writing, Licensor provides the Work (and each
|
|
||||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
||||||
implied, including, without limitation, any warranties or conditions
|
|
||||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
|
||||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
|
||||||
appropriateness of using or redistributing the Work and assume any
|
|
||||||
risks associated with Your exercise of permissions under this License.
|
|
||||||
|
|
||||||
8. Limitation of Liability. In no event and under no legal theory,
|
|
||||||
whether in tort (including negligence), contract, or otherwise,
|
|
||||||
unless required by applicable law (such as deliberate and grossly
|
|
||||||
negligent acts) or agreed to in writing, shall any Contributor be
|
|
||||||
liable to You for damages, including any direct, indirect, special,
|
|
||||||
incidental, or consequential damages of any character arising as a
|
|
||||||
result of this License or out of the use or inability to use the
|
|
||||||
Work (including but not limited to damages for loss of goodwill,
|
|
||||||
work stoppage, computer failure or malfunction, or any and all
|
|
||||||
other commercial damages or losses), even if such Contributor
|
|
||||||
has been advised of the possibility of such damages.
|
|
||||||
|
|
||||||
9. Accepting Warranty or Additional Liability. While redistributing
|
|
||||||
the Work or Derivative Works thereof, You may choose to offer,
|
|
||||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
|
||||||
or other liability obligations and/or rights consistent with this
|
|
||||||
License. However, in accepting such obligations, You may act only
|
|
||||||
on Your own behalf and on Your sole responsibility, not on behalf
|
|
||||||
of any other Contributor, and only if You agree to indemnify,
|
|
||||||
defend, and hold each Contributor harmless for any liability
|
|
||||||
incurred by, or claims asserted against, such Contributor by reason
|
|
||||||
of your accepting any such warranty or additional liability.
|
|
||||||
|
|
||||||
END OF TERMS AND CONDITIONS
|
|
||||||
|
|
||||||
APPENDIX: How to apply the Apache License to your work.
|
|
||||||
|
|
||||||
To apply the Apache License to your work, attach the following
|
|
||||||
boilerplate notice, with the fields enclosed by brackets "{}"
|
|
||||||
replaced with your own identifying information. (Don't include
|
|
||||||
the brackets!) The text should be enclosed in the appropriate
|
|
||||||
comment syntax for the file format. We also recommend that a
|
|
||||||
file or class name and description of purpose be included on the
|
|
||||||
same "printed page" as the copyright notice for easier
|
|
||||||
identification within third-party archives.
|
|
||||||
|
|
||||||
Copyright {yyyy} {name of copyright owner}
|
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
|
|
257
integration/vendor/github.com/docker/distribution/blobs.go
generated
vendored
257
integration/vendor/github.com/docker/distribution/blobs.go
generated
vendored
|
@ -1,257 +0,0 @@
|
||||||
package distribution
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"net/http"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/docker/distribution/context"
|
|
||||||
"github.com/docker/distribution/digest"
|
|
||||||
"github.com/docker/distribution/reference"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// ErrBlobExists returned when blob already exists
|
|
||||||
ErrBlobExists = errors.New("blob exists")
|
|
||||||
|
|
||||||
// ErrBlobDigestUnsupported when blob digest is an unsupported version.
|
|
||||||
ErrBlobDigestUnsupported = errors.New("unsupported blob digest")
|
|
||||||
|
|
||||||
// ErrBlobUnknown when blob is not found.
|
|
||||||
ErrBlobUnknown = errors.New("unknown blob")
|
|
||||||
|
|
||||||
// ErrBlobUploadUnknown returned when upload is not found.
|
|
||||||
ErrBlobUploadUnknown = errors.New("blob upload unknown")
|
|
||||||
|
|
||||||
// ErrBlobInvalidLength returned when the blob has an expected length on
|
|
||||||
// commit, meaning mismatched with the descriptor or an invalid value.
|
|
||||||
ErrBlobInvalidLength = errors.New("blob invalid length")
|
|
||||||
)
|
|
||||||
|
|
||||||
// ErrBlobInvalidDigest returned when digest check fails.
|
|
||||||
type ErrBlobInvalidDigest struct {
|
|
||||||
Digest digest.Digest
|
|
||||||
Reason error
|
|
||||||
}
|
|
||||||
|
|
||||||
func (err ErrBlobInvalidDigest) Error() string {
|
|
||||||
return fmt.Sprintf("invalid digest for referenced layer: %v, %v",
|
|
||||||
err.Digest, err.Reason)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ErrBlobMounted returned when a blob is mounted from another repository
|
|
||||||
// instead of initiating an upload session.
|
|
||||||
type ErrBlobMounted struct {
|
|
||||||
From reference.Canonical
|
|
||||||
Descriptor Descriptor
|
|
||||||
}
|
|
||||||
|
|
||||||
func (err ErrBlobMounted) Error() string {
|
|
||||||
return fmt.Sprintf("blob mounted from: %v to: %v",
|
|
||||||
err.From, err.Descriptor)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Descriptor describes targeted content. Used in conjunction with a blob
|
|
||||||
// store, a descriptor can be used to fetch, store and target any kind of
|
|
||||||
// blob. The struct also describes the wire protocol format. Fields should
|
|
||||||
// only be added but never changed.
|
|
||||||
type Descriptor struct {
|
|
||||||
// MediaType describe the type of the content. All text based formats are
|
|
||||||
// encoded as utf-8.
|
|
||||||
MediaType string `json:"mediaType,omitempty"`
|
|
||||||
|
|
||||||
// Size in bytes of content.
|
|
||||||
Size int64 `json:"size,omitempty"`
|
|
||||||
|
|
||||||
// Digest uniquely identifies the content. A byte stream can be verified
|
|
||||||
// against against this digest.
|
|
||||||
Digest digest.Digest `json:"digest,omitempty"`
|
|
||||||
|
|
||||||
// URLs contains the source URLs of this content.
|
|
||||||
URLs []string `json:"urls,omitempty"`
|
|
||||||
|
|
||||||
// NOTE: Before adding a field here, please ensure that all
|
|
||||||
// other options have been exhausted. Much of the type relationships
|
|
||||||
// depend on the simplicity of this type.
|
|
||||||
}
|
|
||||||
|
|
||||||
// Descriptor returns the descriptor, to make it satisfy the Describable
|
|
||||||
// interface. Note that implementations of Describable are generally objects
|
|
||||||
// which can be described, not simply descriptors; this exception is in place
|
|
||||||
// to make it more convenient to pass actual descriptors to functions that
|
|
||||||
// expect Describable objects.
|
|
||||||
func (d Descriptor) Descriptor() Descriptor {
|
|
||||||
return d
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobStatter makes blob descriptors available by digest. The service may
|
|
||||||
// provide a descriptor of a different digest if the provided digest is not
|
|
||||||
// canonical.
|
|
||||||
type BlobStatter interface {
|
|
||||||
// Stat provides metadata about a blob identified by the digest. If the
|
|
||||||
// blob is unknown to the describer, ErrBlobUnknown will be returned.
|
|
||||||
Stat(ctx context.Context, dgst digest.Digest) (Descriptor, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobDeleter enables deleting blobs from storage.
|
|
||||||
type BlobDeleter interface {
|
|
||||||
Delete(ctx context.Context, dgst digest.Digest) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobEnumerator enables iterating over blobs from storage
|
|
||||||
type BlobEnumerator interface {
|
|
||||||
Enumerate(ctx context.Context, ingester func(dgst digest.Digest) error) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobDescriptorService manages metadata about a blob by digest. Most
|
|
||||||
// implementations will not expose such an interface explicitly. Such mappings
|
|
||||||
// should be maintained by interacting with the BlobIngester. Hence, this is
|
|
||||||
// left off of BlobService and BlobStore.
|
|
||||||
type BlobDescriptorService interface {
|
|
||||||
BlobStatter
|
|
||||||
|
|
||||||
// SetDescriptor assigns the descriptor to the digest. The provided digest and
|
|
||||||
// the digest in the descriptor must map to identical content but they may
|
|
||||||
// differ on their algorithm. The descriptor must have the canonical
|
|
||||||
// digest of the content and the digest algorithm must match the
|
|
||||||
// annotators canonical algorithm.
|
|
||||||
//
|
|
||||||
// Such a facility can be used to map blobs between digest domains, with
|
|
||||||
// the restriction that the algorithm of the descriptor must match the
|
|
||||||
// canonical algorithm (ie sha256) of the annotator.
|
|
||||||
SetDescriptor(ctx context.Context, dgst digest.Digest, desc Descriptor) error
|
|
||||||
|
|
||||||
// Clear enables descriptors to be unlinked
|
|
||||||
Clear(ctx context.Context, dgst digest.Digest) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobDescriptorServiceFactory creates middleware for BlobDescriptorService.
|
|
||||||
type BlobDescriptorServiceFactory interface {
|
|
||||||
BlobAccessController(svc BlobDescriptorService) BlobDescriptorService
|
|
||||||
}
|
|
||||||
|
|
||||||
// ReadSeekCloser is the primary reader type for blob data, combining
|
|
||||||
// io.ReadSeeker with io.Closer.
|
|
||||||
type ReadSeekCloser interface {
|
|
||||||
io.ReadSeeker
|
|
||||||
io.Closer
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobProvider describes operations for getting blob data.
|
|
||||||
type BlobProvider interface {
|
|
||||||
// Get returns the entire blob identified by digest along with the descriptor.
|
|
||||||
Get(ctx context.Context, dgst digest.Digest) ([]byte, error)
|
|
||||||
|
|
||||||
// Open provides a ReadSeekCloser to the blob identified by the provided
|
|
||||||
// descriptor. If the blob is not known to the service, an error will be
|
|
||||||
// returned.
|
|
||||||
Open(ctx context.Context, dgst digest.Digest) (ReadSeekCloser, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobServer can serve blobs via http.
|
|
||||||
type BlobServer interface {
|
|
||||||
// ServeBlob attempts to serve the blob, identifed by dgst, via http. The
|
|
||||||
// service may decide to redirect the client elsewhere or serve the data
|
|
||||||
// directly.
|
|
||||||
//
|
|
||||||
// This handler only issues successful responses, such as 2xx or 3xx,
|
|
||||||
// meaning it serves data or issues a redirect. If the blob is not
|
|
||||||
// available, an error will be returned and the caller may still issue a
|
|
||||||
// response.
|
|
||||||
//
|
|
||||||
// The implementation may serve the same blob from a different digest
|
|
||||||
// domain. The appropriate headers will be set for the blob, unless they
|
|
||||||
// have already been set by the caller.
|
|
||||||
ServeBlob(ctx context.Context, w http.ResponseWriter, r *http.Request, dgst digest.Digest) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobIngester ingests blob data.
|
|
||||||
type BlobIngester interface {
|
|
||||||
// Put inserts the content p into the blob service, returning a descriptor
|
|
||||||
// or an error.
|
|
||||||
Put(ctx context.Context, mediaType string, p []byte) (Descriptor, error)
|
|
||||||
|
|
||||||
// Create allocates a new blob writer to add a blob to this service. The
|
|
||||||
// returned handle can be written to and later resumed using an opaque
|
|
||||||
// identifier. With this approach, one can Close and Resume a BlobWriter
|
|
||||||
// multiple times until the BlobWriter is committed or cancelled.
|
|
||||||
Create(ctx context.Context, options ...BlobCreateOption) (BlobWriter, error)
|
|
||||||
|
|
||||||
// Resume attempts to resume a write to a blob, identified by an id.
|
|
||||||
Resume(ctx context.Context, id string) (BlobWriter, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobCreateOption is a general extensible function argument for blob creation
|
|
||||||
// methods. A BlobIngester may choose to honor any or none of the given
|
|
||||||
// BlobCreateOptions, which can be specific to the implementation of the
|
|
||||||
// BlobIngester receiving them.
|
|
||||||
// TODO (brianbland): unify this with ManifestServiceOption in the future
|
|
||||||
type BlobCreateOption interface {
|
|
||||||
Apply(interface{}) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// CreateOptions is a collection of blob creation modifiers relevant to general
|
|
||||||
// blob storage intended to be configured by the BlobCreateOption.Apply method.
|
|
||||||
type CreateOptions struct {
|
|
||||||
Mount struct {
|
|
||||||
ShouldMount bool
|
|
||||||
From reference.Canonical
|
|
||||||
// Stat allows to pass precalculated descriptor to link and return.
|
|
||||||
// Blob access check will be skipped if set.
|
|
||||||
Stat *Descriptor
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobWriter provides a handle for inserting data into a blob store.
|
|
||||||
// Instances should be obtained from BlobWriteService.Writer and
|
|
||||||
// BlobWriteService.Resume. If supported by the store, a writer can be
|
|
||||||
// recovered with the id.
|
|
||||||
type BlobWriter interface {
|
|
||||||
io.WriteCloser
|
|
||||||
io.ReaderFrom
|
|
||||||
|
|
||||||
// Size returns the number of bytes written to this blob.
|
|
||||||
Size() int64
|
|
||||||
|
|
||||||
// ID returns the identifier for this writer. The ID can be used with the
|
|
||||||
// Blob service to later resume the write.
|
|
||||||
ID() string
|
|
||||||
|
|
||||||
// StartedAt returns the time this blob write was started.
|
|
||||||
StartedAt() time.Time
|
|
||||||
|
|
||||||
// Commit completes the blob writer process. The content is verified
|
|
||||||
// against the provided provisional descriptor, which may result in an
|
|
||||||
// error. Depending on the implementation, written data may be validated
|
|
||||||
// against the provisional descriptor fields. If MediaType is not present,
|
|
||||||
// the implementation may reject the commit or assign "application/octet-
|
|
||||||
// stream" to the blob. The returned descriptor may have a different
|
|
||||||
// digest depending on the blob store, referred to as the canonical
|
|
||||||
// descriptor.
|
|
||||||
Commit(ctx context.Context, provisional Descriptor) (canonical Descriptor, err error)
|
|
||||||
|
|
||||||
// Cancel ends the blob write without storing any data and frees any
|
|
||||||
// associated resources. Any data written thus far will be lost. Cancel
|
|
||||||
// implementations should allow multiple calls even after a commit that
|
|
||||||
// result in a no-op. This allows use of Cancel in a defer statement,
|
|
||||||
// increasing the assurance that it is correctly called.
|
|
||||||
Cancel(ctx context.Context) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobService combines the operations to access, read and write blobs. This
|
|
||||||
// can be used to describe remote blob services.
|
|
||||||
type BlobService interface {
|
|
||||||
BlobStatter
|
|
||||||
BlobProvider
|
|
||||||
BlobIngester
|
|
||||||
}
|
|
||||||
|
|
||||||
// BlobStore represent the entire suite of blob related operations. Such an
|
|
||||||
// implementation can access, read, write, delete and serve blobs.
|
|
||||||
type BlobStore interface {
|
|
||||||
BlobService
|
|
||||||
BlobServer
|
|
||||||
BlobDeleter
|
|
||||||
}
|
|
245
integration/vendor/github.com/docker/distribution/digest/set.go
generated
vendored
245
integration/vendor/github.com/docker/distribution/digest/set.go
generated
vendored
|
@ -1,245 +0,0 @@
|
||||||
package digest
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"sort"
|
|
||||||
"strings"
|
|
||||||
"sync"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// ErrDigestNotFound is used when a matching digest
|
|
||||||
// could not be found in a set.
|
|
||||||
ErrDigestNotFound = errors.New("digest not found")
|
|
||||||
|
|
||||||
// ErrDigestAmbiguous is used when multiple digests
|
|
||||||
// are found in a set. None of the matching digests
|
|
||||||
// should be considered valid matches.
|
|
||||||
ErrDigestAmbiguous = errors.New("ambiguous digest string")
|
|
||||||
)
|
|
||||||
|
|
||||||
// Set is used to hold a unique set of digests which
|
|
||||||
// may be easily referenced by easily referenced by a string
|
|
||||||
// representation of the digest as well as short representation.
|
|
||||||
// The uniqueness of the short representation is based on other
|
|
||||||
// digests in the set. If digests are omitted from this set,
|
|
||||||
// collisions in a larger set may not be detected, therefore it
|
|
||||||
// is important to always do short representation lookups on
|
|
||||||
// the complete set of digests. To mitigate collisions, an
|
|
||||||
// appropriately long short code should be used.
|
|
||||||
type Set struct {
|
|
||||||
mutex sync.RWMutex
|
|
||||||
entries digestEntries
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewSet creates an empty set of digests
|
|
||||||
// which may have digests added.
|
|
||||||
func NewSet() *Set {
|
|
||||||
return &Set{
|
|
||||||
entries: digestEntries{},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// checkShortMatch checks whether two digests match as either whole
|
|
||||||
// values or short values. This function does not test equality,
|
|
||||||
// rather whether the second value could match against the first
|
|
||||||
// value.
|
|
||||||
func checkShortMatch(alg Algorithm, hex, shortAlg, shortHex string) bool {
|
|
||||||
if len(hex) == len(shortHex) {
|
|
||||||
if hex != shortHex {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
if len(shortAlg) > 0 && string(alg) != shortAlg {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
} else if !strings.HasPrefix(hex, shortHex) {
|
|
||||||
return false
|
|
||||||
} else if len(shortAlg) > 0 && string(alg) != shortAlg {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
// Lookup looks for a digest matching the given string representation.
|
|
||||||
// If no digests could be found ErrDigestNotFound will be returned
|
|
||||||
// with an empty digest value. If multiple matches are found
|
|
||||||
// ErrDigestAmbiguous will be returned with an empty digest value.
|
|
||||||
func (dst *Set) Lookup(d string) (Digest, error) {
|
|
||||||
dst.mutex.RLock()
|
|
||||||
defer dst.mutex.RUnlock()
|
|
||||||
if len(dst.entries) == 0 {
|
|
||||||
return "", ErrDigestNotFound
|
|
||||||
}
|
|
||||||
var (
|
|
||||||
searchFunc func(int) bool
|
|
||||||
alg Algorithm
|
|
||||||
hex string
|
|
||||||
)
|
|
||||||
dgst, err := ParseDigest(d)
|
|
||||||
if err == ErrDigestInvalidFormat {
|
|
||||||
hex = d
|
|
||||||
searchFunc = func(i int) bool {
|
|
||||||
return dst.entries[i].val >= d
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
hex = dgst.Hex()
|
|
||||||
alg = dgst.Algorithm()
|
|
||||||
searchFunc = func(i int) bool {
|
|
||||||
if dst.entries[i].val == hex {
|
|
||||||
return dst.entries[i].alg >= alg
|
|
||||||
}
|
|
||||||
return dst.entries[i].val >= hex
|
|
||||||
}
|
|
||||||
}
|
|
||||||
idx := sort.Search(len(dst.entries), searchFunc)
|
|
||||||
if idx == len(dst.entries) || !checkShortMatch(dst.entries[idx].alg, dst.entries[idx].val, string(alg), hex) {
|
|
||||||
return "", ErrDigestNotFound
|
|
||||||
}
|
|
||||||
if dst.entries[idx].alg == alg && dst.entries[idx].val == hex {
|
|
||||||
return dst.entries[idx].digest, nil
|
|
||||||
}
|
|
||||||
if idx+1 < len(dst.entries) && checkShortMatch(dst.entries[idx+1].alg, dst.entries[idx+1].val, string(alg), hex) {
|
|
||||||
return "", ErrDigestAmbiguous
|
|
||||||
}
|
|
||||||
|
|
||||||
return dst.entries[idx].digest, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add adds the given digest to the set. An error will be returned
|
|
||||||
// if the given digest is invalid. If the digest already exists in the
|
|
||||||
// set, this operation will be a no-op.
|
|
||||||
func (dst *Set) Add(d Digest) error {
|
|
||||||
if err := d.Validate(); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
dst.mutex.Lock()
|
|
||||||
defer dst.mutex.Unlock()
|
|
||||||
entry := &digestEntry{alg: d.Algorithm(), val: d.Hex(), digest: d}
|
|
||||||
searchFunc := func(i int) bool {
|
|
||||||
if dst.entries[i].val == entry.val {
|
|
||||||
return dst.entries[i].alg >= entry.alg
|
|
||||||
}
|
|
||||||
return dst.entries[i].val >= entry.val
|
|
||||||
}
|
|
||||||
idx := sort.Search(len(dst.entries), searchFunc)
|
|
||||||
if idx == len(dst.entries) {
|
|
||||||
dst.entries = append(dst.entries, entry)
|
|
||||||
return nil
|
|
||||||
} else if dst.entries[idx].digest == d {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
entries := append(dst.entries, nil)
|
|
||||||
copy(entries[idx+1:], entries[idx:len(entries)-1])
|
|
||||||
entries[idx] = entry
|
|
||||||
dst.entries = entries
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Remove removes the given digest from the set. An err will be
|
|
||||||
// returned if the given digest is invalid. If the digest does
|
|
||||||
// not exist in the set, this operation will be a no-op.
|
|
||||||
func (dst *Set) Remove(d Digest) error {
|
|
||||||
if err := d.Validate(); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
dst.mutex.Lock()
|
|
||||||
defer dst.mutex.Unlock()
|
|
||||||
entry := &digestEntry{alg: d.Algorithm(), val: d.Hex(), digest: d}
|
|
||||||
searchFunc := func(i int) bool {
|
|
||||||
if dst.entries[i].val == entry.val {
|
|
||||||
return dst.entries[i].alg >= entry.alg
|
|
||||||
}
|
|
||||||
return dst.entries[i].val >= entry.val
|
|
||||||
}
|
|
||||||
idx := sort.Search(len(dst.entries), searchFunc)
|
|
||||||
// Not found if idx is after or value at idx is not digest
|
|
||||||
if idx == len(dst.entries) || dst.entries[idx].digest != d {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
entries := dst.entries
|
|
||||||
copy(entries[idx:], entries[idx+1:])
|
|
||||||
entries = entries[:len(entries)-1]
|
|
||||||
dst.entries = entries
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// All returns all the digests in the set
|
|
||||||
func (dst *Set) All() []Digest {
|
|
||||||
dst.mutex.RLock()
|
|
||||||
defer dst.mutex.RUnlock()
|
|
||||||
retValues := make([]Digest, len(dst.entries))
|
|
||||||
for i := range dst.entries {
|
|
||||||
retValues[i] = dst.entries[i].digest
|
|
||||||
}
|
|
||||||
|
|
||||||
return retValues
|
|
||||||
}
|
|
||||||
|
|
||||||
// ShortCodeTable returns a map of Digest to unique short codes. The
|
|
||||||
// length represents the minimum value, the maximum length may be the
|
|
||||||
// entire value of digest if uniqueness cannot be achieved without the
|
|
||||||
// full value. This function will attempt to make short codes as short
|
|
||||||
// as possible to be unique.
|
|
||||||
func ShortCodeTable(dst *Set, length int) map[Digest]string {
|
|
||||||
dst.mutex.RLock()
|
|
||||||
defer dst.mutex.RUnlock()
|
|
||||||
m := make(map[Digest]string, len(dst.entries))
|
|
||||||
l := length
|
|
||||||
resetIdx := 0
|
|
||||||
for i := 0; i < len(dst.entries); i++ {
|
|
||||||
var short string
|
|
||||||
extended := true
|
|
||||||
for extended {
|
|
||||||
extended = false
|
|
||||||
if len(dst.entries[i].val) <= l {
|
|
||||||
short = dst.entries[i].digest.String()
|
|
||||||
} else {
|
|
||||||
short = dst.entries[i].val[:l]
|
|
||||||
for j := i + 1; j < len(dst.entries); j++ {
|
|
||||||
if checkShortMatch(dst.entries[j].alg, dst.entries[j].val, "", short) {
|
|
||||||
if j > resetIdx {
|
|
||||||
resetIdx = j
|
|
||||||
}
|
|
||||||
extended = true
|
|
||||||
} else {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if extended {
|
|
||||||
l++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
m[dst.entries[i].digest] = short
|
|
||||||
if i >= resetIdx {
|
|
||||||
l = length
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return m
|
|
||||||
}
|
|
||||||
|
|
||||||
type digestEntry struct {
|
|
||||||
alg Algorithm
|
|
||||||
val string
|
|
||||||
digest Digest
|
|
||||||
}
|
|
||||||
|
|
||||||
type digestEntries []*digestEntry
|
|
||||||
|
|
||||||
func (d digestEntries) Len() int {
|
|
||||||
return len(d)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d digestEntries) Less(i, j int) bool {
|
|
||||||
if d[i].val != d[j].val {
|
|
||||||
return d[i].val < d[j].val
|
|
||||||
}
|
|
||||||
return d[i].alg < d[j].alg
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d digestEntries) Swap(i, j int) {
|
|
||||||
d[i], d[j] = d[j], d[i]
|
|
||||||
}
|
|
44
integration/vendor/github.com/docker/distribution/digest/verifiers.go
generated
vendored
44
integration/vendor/github.com/docker/distribution/digest/verifiers.go
generated
vendored
|
@ -1,44 +0,0 @@
|
||||||
package digest
|
|
||||||
|
|
||||||
import (
|
|
||||||
"hash"
|
|
||||||
"io"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Verifier presents a general verification interface to be used with message
|
|
||||||
// digests and other byte stream verifications. Users instantiate a Verifier
|
|
||||||
// from one of the various methods, write the data under test to it then check
|
|
||||||
// the result with the Verified method.
|
|
||||||
type Verifier interface {
|
|
||||||
io.Writer
|
|
||||||
|
|
||||||
// Verified will return true if the content written to Verifier matches
|
|
||||||
// the digest.
|
|
||||||
Verified() bool
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewDigestVerifier returns a verifier that compares the written bytes
|
|
||||||
// against a passed in digest.
|
|
||||||
func NewDigestVerifier(d Digest) (Verifier, error) {
|
|
||||||
if err := d.Validate(); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return hashVerifier{
|
|
||||||
hash: d.Algorithm().Hash(),
|
|
||||||
digest: d,
|
|
||||||
}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
type hashVerifier struct {
|
|
||||||
digest Digest
|
|
||||||
hash hash.Hash
|
|
||||||
}
|
|
||||||
|
|
||||||
func (hv hashVerifier) Write(p []byte) (n int, err error) {
|
|
||||||
return hv.hash.Write(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (hv hashVerifier) Verified() bool {
|
|
||||||
return hv.digest == NewDigest(hv.digest.Algorithm(), hv.hash)
|
|
||||||
}
|
|
7
integration/vendor/github.com/docker/distribution/doc.go
generated
vendored
7
integration/vendor/github.com/docker/distribution/doc.go
generated
vendored
|
@ -1,7 +0,0 @@
|
||||||
// Package distribution will define the interfaces for the components of
|
|
||||||
// docker distribution. The goal is to allow users to reliably package, ship
|
|
||||||
// and store content related to docker images.
|
|
||||||
//
|
|
||||||
// This is currently a work in progress. More details are available in the
|
|
||||||
// README.md.
|
|
||||||
package distribution
|
|
115
integration/vendor/github.com/docker/distribution/errors.go
generated
vendored
115
integration/vendor/github.com/docker/distribution/errors.go
generated
vendored
|
@ -1,115 +0,0 @@
|
||||||
package distribution
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
"github.com/docker/distribution/digest"
|
|
||||||
)
|
|
||||||
|
|
||||||
// ErrAccessDenied is returned when an access to a requested resource is
|
|
||||||
// denied.
|
|
||||||
var ErrAccessDenied = errors.New("access denied")
|
|
||||||
|
|
||||||
// ErrManifestNotModified is returned when a conditional manifest GetByTag
|
|
||||||
// returns nil due to the client indicating it has the latest version
|
|
||||||
var ErrManifestNotModified = errors.New("manifest not modified")
|
|
||||||
|
|
||||||
// ErrUnsupported is returned when an unimplemented or unsupported action is
|
|
||||||
// performed
|
|
||||||
var ErrUnsupported = errors.New("operation unsupported")
|
|
||||||
|
|
||||||
// ErrTagUnknown is returned if the given tag is not known by the tag service
|
|
||||||
type ErrTagUnknown struct {
|
|
||||||
Tag string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (err ErrTagUnknown) Error() string {
|
|
||||||
return fmt.Sprintf("unknown tag=%s", err.Tag)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ErrRepositoryUnknown is returned if the named repository is not known by
|
|
||||||
// the registry.
|
|
||||||
type ErrRepositoryUnknown struct {
|
|
||||||
Name string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (err ErrRepositoryUnknown) Error() string {
|
|
||||||
return fmt.Sprintf("unknown repository name=%s", err.Name)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ErrRepositoryNameInvalid should be used to denote an invalid repository
|
|
||||||
// name. Reason may set, indicating the cause of invalidity.
|
|
||||||
type ErrRepositoryNameInvalid struct {
|
|
||||||
Name string
|
|
||||||
Reason error
|
|
||||||
}
|
|
||||||
|
|
||||||
func (err ErrRepositoryNameInvalid) Error() string {
|
|
||||||
return fmt.Sprintf("repository name %q invalid: %v", err.Name, err.Reason)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ErrManifestUnknown is returned if the manifest is not known by the
|
|
||||||
// registry.
|
|
||||||
type ErrManifestUnknown struct {
|
|
||||||
Name string
|
|
||||||
Tag string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (err ErrManifestUnknown) Error() string {
|
|
||||||
return fmt.Sprintf("unknown manifest name=%s tag=%s", err.Name, err.Tag)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ErrManifestUnknownRevision is returned when a manifest cannot be found by
|
|
||||||
// revision within a repository.
|
|
||||||
type ErrManifestUnknownRevision struct {
|
|
||||||
Name string
|
|
||||||
Revision digest.Digest
|
|
||||||
}
|
|
||||||
|
|
||||||
func (err ErrManifestUnknownRevision) Error() string {
|
|
||||||
return fmt.Sprintf("unknown manifest name=%s revision=%s", err.Name, err.Revision)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ErrManifestUnverified is returned when the registry is unable to verify
|
|
||||||
// the manifest.
|
|
||||||
type ErrManifestUnverified struct{}
|
|
||||||
|
|
||||||
func (ErrManifestUnverified) Error() string {
|
|
||||||
return fmt.Sprintf("unverified manifest")
|
|
||||||
}
|
|
||||||
|
|
||||||
// ErrManifestVerification provides a type to collect errors encountered
|
|
||||||
// during manifest verification. Currently, it accepts errors of all types,
|
|
||||||
// but it may be narrowed to those involving manifest verification.
|
|
||||||
type ErrManifestVerification []error
|
|
||||||
|
|
||||||
func (errs ErrManifestVerification) Error() string {
|
|
||||||
var parts []string
|
|
||||||
for _, err := range errs {
|
|
||||||
parts = append(parts, err.Error())
|
|
||||||
}
|
|
||||||
|
|
||||||
return fmt.Sprintf("errors verifying manifest: %v", strings.Join(parts, ","))
|
|
||||||
}
|
|
||||||
|
|
||||||
// ErrManifestBlobUnknown returned when a referenced blob cannot be found.
|
|
||||||
type ErrManifestBlobUnknown struct {
|
|
||||||
Digest digest.Digest
|
|
||||||
}
|
|
||||||
|
|
||||||
func (err ErrManifestBlobUnknown) Error() string {
|
|
||||||
return fmt.Sprintf("unknown blob %v on manifest", err.Digest)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ErrManifestNameInvalid should be used to denote an invalid manifest
|
|
||||||
// name. Reason may set, indicating the cause of invalidity.
|
|
||||||
type ErrManifestNameInvalid struct {
|
|
||||||
Name string
|
|
||||||
Reason error
|
|
||||||
}
|
|
||||||
|
|
||||||
func (err ErrManifestNameInvalid) Error() string {
|
|
||||||
return fmt.Sprintf("manifest name %q invalid: %v", err.Name, err.Reason)
|
|
||||||
}
|
|
117
integration/vendor/github.com/docker/distribution/manifests.go
generated
vendored
117
integration/vendor/github.com/docker/distribution/manifests.go
generated
vendored
|
@ -1,117 +0,0 @@
|
||||||
package distribution
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"mime"
|
|
||||||
|
|
||||||
"github.com/docker/distribution/context"
|
|
||||||
"github.com/docker/distribution/digest"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Manifest represents a registry object specifying a set of
|
|
||||||
// references and an optional target
|
|
||||||
type Manifest interface {
|
|
||||||
// References returns a list of objects which make up this manifest.
|
|
||||||
// The references are strictly ordered from base to head. A reference
|
|
||||||
// is anything which can be represented by a distribution.Descriptor
|
|
||||||
References() []Descriptor
|
|
||||||
|
|
||||||
// Payload provides the serialized format of the manifest, in addition to
|
|
||||||
// the mediatype.
|
|
||||||
Payload() (mediatype string, payload []byte, err error)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ManifestBuilder creates a manifest allowing one to include dependencies.
|
|
||||||
// Instances can be obtained from a version-specific manifest package. Manifest
|
|
||||||
// specific data is passed into the function which creates the builder.
|
|
||||||
type ManifestBuilder interface {
|
|
||||||
// Build creates the manifest from his builder.
|
|
||||||
Build(ctx context.Context) (Manifest, error)
|
|
||||||
|
|
||||||
// References returns a list of objects which have been added to this
|
|
||||||
// builder. The dependencies are returned in the order they were added,
|
|
||||||
// which should be from base to head.
|
|
||||||
References() []Descriptor
|
|
||||||
|
|
||||||
// AppendReference includes the given object in the manifest after any
|
|
||||||
// existing dependencies. If the add fails, such as when adding an
|
|
||||||
// unsupported dependency, an error may be returned.
|
|
||||||
AppendReference(dependency Describable) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// ManifestService describes operations on image manifests.
|
|
||||||
type ManifestService interface {
|
|
||||||
// Exists returns true if the manifest exists.
|
|
||||||
Exists(ctx context.Context, dgst digest.Digest) (bool, error)
|
|
||||||
|
|
||||||
// Get retrieves the manifest specified by the given digest
|
|
||||||
Get(ctx context.Context, dgst digest.Digest, options ...ManifestServiceOption) (Manifest, error)
|
|
||||||
|
|
||||||
// Put creates or updates the given manifest returning the manifest digest
|
|
||||||
Put(ctx context.Context, manifest Manifest, options ...ManifestServiceOption) (digest.Digest, error)
|
|
||||||
|
|
||||||
// Delete removes the manifest specified by the given digest. Deleting
|
|
||||||
// a manifest that doesn't exist will return ErrManifestNotFound
|
|
||||||
Delete(ctx context.Context, dgst digest.Digest) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// ManifestEnumerator enables iterating over manifests
|
|
||||||
type ManifestEnumerator interface {
|
|
||||||
// Enumerate calls ingester for each manifest.
|
|
||||||
Enumerate(ctx context.Context, ingester func(digest.Digest) error) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// Describable is an interface for descriptors
|
|
||||||
type Describable interface {
|
|
||||||
Descriptor() Descriptor
|
|
||||||
}
|
|
||||||
|
|
||||||
// ManifestMediaTypes returns the supported media types for manifests.
|
|
||||||
func ManifestMediaTypes() (mediaTypes []string) {
|
|
||||||
for t := range mappings {
|
|
||||||
if t != "" {
|
|
||||||
mediaTypes = append(mediaTypes, t)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// UnmarshalFunc implements manifest unmarshalling a given MediaType
|
|
||||||
type UnmarshalFunc func([]byte) (Manifest, Descriptor, error)
|
|
||||||
|
|
||||||
var mappings = make(map[string]UnmarshalFunc, 0)
|
|
||||||
|
|
||||||
// UnmarshalManifest looks up manifest unmarshal functions based on
|
|
||||||
// MediaType
|
|
||||||
func UnmarshalManifest(ctHeader string, p []byte) (Manifest, Descriptor, error) {
|
|
||||||
// Need to look up by the actual media type, not the raw contents of
|
|
||||||
// the header. Strip semicolons and anything following them.
|
|
||||||
var mediatype string
|
|
||||||
if ctHeader != "" {
|
|
||||||
var err error
|
|
||||||
mediatype, _, err = mime.ParseMediaType(ctHeader)
|
|
||||||
if err != nil {
|
|
||||||
return nil, Descriptor{}, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
unmarshalFunc, ok := mappings[mediatype]
|
|
||||||
if !ok {
|
|
||||||
unmarshalFunc, ok = mappings[""]
|
|
||||||
if !ok {
|
|
||||||
return nil, Descriptor{}, fmt.Errorf("unsupported manifest mediatype and no default available: %s", mediatype)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return unmarshalFunc(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
// RegisterManifestSchema registers an UnmarshalFunc for a given schema type. This
|
|
||||||
// should be called from specific
|
|
||||||
func RegisterManifestSchema(mediatype string, u UnmarshalFunc) error {
|
|
||||||
if _, ok := mappings[mediatype]; ok {
|
|
||||||
return fmt.Errorf("manifest mediatype registration would overwrite existing: %s", mediatype)
|
|
||||||
}
|
|
||||||
mappings[mediatype] = u
|
|
||||||
return nil
|
|
||||||
}
|
|
340
integration/vendor/github.com/docker/distribution/reference/reference.go
generated
vendored
340
integration/vendor/github.com/docker/distribution/reference/reference.go
generated
vendored
|
@ -1,340 +0,0 @@
|
||||||
// Package reference provides a general type to represent any way of referencing images within the registry.
|
|
||||||
// Its main purpose is to abstract tags and digests (content-addressable hash).
|
|
||||||
//
|
|
||||||
// Grammar
|
|
||||||
//
|
|
||||||
// reference := name [ ":" tag ] [ "@" digest ]
|
|
||||||
// name := [hostname '/'] component ['/' component]*
|
|
||||||
// hostname := hostcomponent ['.' hostcomponent]* [':' port-number]
|
|
||||||
// hostcomponent := /([a-zA-Z0-9]|[a-zA-Z0-9][a-zA-Z0-9-]*[a-zA-Z0-9])/
|
|
||||||
// port-number := /[0-9]+/
|
|
||||||
// component := alpha-numeric [separator alpha-numeric]*
|
|
||||||
// alpha-numeric := /[a-z0-9]+/
|
|
||||||
// separator := /[_.]|__|[-]*/
|
|
||||||
//
|
|
||||||
// tag := /[\w][\w.-]{0,127}/
|
|
||||||
//
|
|
||||||
// digest := digest-algorithm ":" digest-hex
|
|
||||||
// digest-algorithm := digest-algorithm-component [ digest-algorithm-separator digest-algorithm-component ]
|
|
||||||
// digest-algorithm-separator := /[+.-_]/
|
|
||||||
// digest-algorithm-component := /[A-Za-z][A-Za-z0-9]*/
|
|
||||||
// digest-hex := /[0-9a-fA-F]{32,}/ ; At least 128 bit digest value
|
|
||||||
package reference
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
"github.com/docker/distribution/digest"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
// NameTotalLengthMax is the maximum total number of characters in a repository name.
|
|
||||||
NameTotalLengthMax = 255
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// ErrReferenceInvalidFormat represents an error while trying to parse a string as a reference.
|
|
||||||
ErrReferenceInvalidFormat = errors.New("invalid reference format")
|
|
||||||
|
|
||||||
// ErrTagInvalidFormat represents an error while trying to parse a string as a tag.
|
|
||||||
ErrTagInvalidFormat = errors.New("invalid tag format")
|
|
||||||
|
|
||||||
// ErrDigestInvalidFormat represents an error while trying to parse a string as a tag.
|
|
||||||
ErrDigestInvalidFormat = errors.New("invalid digest format")
|
|
||||||
|
|
||||||
// ErrNameContainsUppercase is returned for invalid repository names that contain uppercase characters.
|
|
||||||
ErrNameContainsUppercase = errors.New("repository name must be lowercase")
|
|
||||||
|
|
||||||
// ErrNameEmpty is returned for empty, invalid repository names.
|
|
||||||
ErrNameEmpty = errors.New("repository name must have at least one component")
|
|
||||||
|
|
||||||
// ErrNameTooLong is returned when a repository name is longer than NameTotalLengthMax.
|
|
||||||
ErrNameTooLong = fmt.Errorf("repository name must not be more than %v characters", NameTotalLengthMax)
|
|
||||||
)
|
|
||||||
|
|
||||||
// Reference is an opaque object reference identifier that may include
|
|
||||||
// modifiers such as a hostname, name, tag, and digest.
|
|
||||||
type Reference interface {
|
|
||||||
// String returns the full reference
|
|
||||||
String() string
|
|
||||||
}
|
|
||||||
|
|
||||||
// Field provides a wrapper type for resolving correct reference types when
|
|
||||||
// working with encoding.
|
|
||||||
type Field struct {
|
|
||||||
reference Reference
|
|
||||||
}
|
|
||||||
|
|
||||||
// AsField wraps a reference in a Field for encoding.
|
|
||||||
func AsField(reference Reference) Field {
|
|
||||||
return Field{reference}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reference unwraps the reference type from the field to
|
|
||||||
// return the Reference object. This object should be
|
|
||||||
// of the appropriate type to further check for different
|
|
||||||
// reference types.
|
|
||||||
func (f Field) Reference() Reference {
|
|
||||||
return f.reference
|
|
||||||
}
|
|
||||||
|
|
||||||
// MarshalText serializes the field to byte text which
|
|
||||||
// is the string of the reference.
|
|
||||||
func (f Field) MarshalText() (p []byte, err error) {
|
|
||||||
return []byte(f.reference.String()), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// UnmarshalText parses text bytes by invoking the
|
|
||||||
// reference parser to ensure the appropriately
|
|
||||||
// typed reference object is wrapped by field.
|
|
||||||
func (f *Field) UnmarshalText(p []byte) error {
|
|
||||||
r, err := Parse(string(p))
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
f.reference = r
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Named is an object with a full name
|
|
||||||
type Named interface {
|
|
||||||
Reference
|
|
||||||
Name() string
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tagged is an object which has a tag
|
|
||||||
type Tagged interface {
|
|
||||||
Reference
|
|
||||||
Tag() string
|
|
||||||
}
|
|
||||||
|
|
||||||
// NamedTagged is an object including a name and tag.
|
|
||||||
type NamedTagged interface {
|
|
||||||
Named
|
|
||||||
Tag() string
|
|
||||||
}
|
|
||||||
|
|
||||||
// Digested is an object which has a digest
|
|
||||||
// in which it can be referenced by
|
|
||||||
type Digested interface {
|
|
||||||
Reference
|
|
||||||
Digest() digest.Digest
|
|
||||||
}
|
|
||||||
|
|
||||||
// Canonical reference is an object with a fully unique
|
|
||||||
// name including a name with hostname and digest
|
|
||||||
type Canonical interface {
|
|
||||||
Named
|
|
||||||
Digest() digest.Digest
|
|
||||||
}
|
|
||||||
|
|
||||||
// SplitHostname splits a named reference into a
|
|
||||||
// hostname and name string. If no valid hostname is
|
|
||||||
// found, the hostname is empty and the full value
|
|
||||||
// is returned as name
|
|
||||||
func SplitHostname(named Named) (string, string) {
|
|
||||||
name := named.Name()
|
|
||||||
match := anchoredNameRegexp.FindStringSubmatch(name)
|
|
||||||
if match == nil || len(match) != 3 {
|
|
||||||
return "", name
|
|
||||||
}
|
|
||||||
return match[1], match[2]
|
|
||||||
}
|
|
||||||
|
|
||||||
// Parse parses s and returns a syntactically valid Reference.
|
|
||||||
// If an error was encountered it is returned, along with a nil Reference.
|
|
||||||
// NOTE: Parse will not handle short digests.
|
|
||||||
func Parse(s string) (Reference, error) {
|
|
||||||
matches := ReferenceRegexp.FindStringSubmatch(s)
|
|
||||||
if matches == nil {
|
|
||||||
if s == "" {
|
|
||||||
return nil, ErrNameEmpty
|
|
||||||
}
|
|
||||||
if ReferenceRegexp.FindStringSubmatch(strings.ToLower(s)) != nil {
|
|
||||||
return nil, ErrNameContainsUppercase
|
|
||||||
}
|
|
||||||
return nil, ErrReferenceInvalidFormat
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(matches[1]) > NameTotalLengthMax {
|
|
||||||
return nil, ErrNameTooLong
|
|
||||||
}
|
|
||||||
|
|
||||||
ref := reference{
|
|
||||||
name: matches[1],
|
|
||||||
tag: matches[2],
|
|
||||||
}
|
|
||||||
if matches[3] != "" {
|
|
||||||
var err error
|
|
||||||
ref.digest, err = digest.ParseDigest(matches[3])
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
r := getBestReferenceType(ref)
|
|
||||||
if r == nil {
|
|
||||||
return nil, ErrNameEmpty
|
|
||||||
}
|
|
||||||
|
|
||||||
return r, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// ParseNamed parses s and returns a syntactically valid reference implementing
|
|
||||||
// the Named interface. The reference must have a name, otherwise an error is
|
|
||||||
// returned.
|
|
||||||
// If an error was encountered it is returned, along with a nil Reference.
|
|
||||||
// NOTE: ParseNamed will not handle short digests.
|
|
||||||
func ParseNamed(s string) (Named, error) {
|
|
||||||
ref, err := Parse(s)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
named, isNamed := ref.(Named)
|
|
||||||
if !isNamed {
|
|
||||||
return nil, fmt.Errorf("reference %s has no name", ref.String())
|
|
||||||
}
|
|
||||||
return named, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// WithName returns a named object representing the given string. If the input
|
|
||||||
// is invalid ErrReferenceInvalidFormat will be returned.
|
|
||||||
func WithName(name string) (Named, error) {
|
|
||||||
if len(name) > NameTotalLengthMax {
|
|
||||||
return nil, ErrNameTooLong
|
|
||||||
}
|
|
||||||
if !anchoredNameRegexp.MatchString(name) {
|
|
||||||
return nil, ErrReferenceInvalidFormat
|
|
||||||
}
|
|
||||||
return repository(name), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// WithTag combines the name from "name" and the tag from "tag" to form a
|
|
||||||
// reference incorporating both the name and the tag.
|
|
||||||
func WithTag(name Named, tag string) (NamedTagged, error) {
|
|
||||||
if !anchoredTagRegexp.MatchString(tag) {
|
|
||||||
return nil, ErrTagInvalidFormat
|
|
||||||
}
|
|
||||||
return taggedReference{
|
|
||||||
name: name.Name(),
|
|
||||||
tag: tag,
|
|
||||||
}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// WithDigest combines the name from "name" and the digest from "digest" to form
|
|
||||||
// a reference incorporating both the name and the digest.
|
|
||||||
func WithDigest(name Named, digest digest.Digest) (Canonical, error) {
|
|
||||||
if !anchoredDigestRegexp.MatchString(digest.String()) {
|
|
||||||
return nil, ErrDigestInvalidFormat
|
|
||||||
}
|
|
||||||
return canonicalReference{
|
|
||||||
name: name.Name(),
|
|
||||||
digest: digest,
|
|
||||||
}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func getBestReferenceType(ref reference) Reference {
|
|
||||||
if ref.name == "" {
|
|
||||||
// Allow digest only references
|
|
||||||
if ref.digest != "" {
|
|
||||||
return digestReference(ref.digest)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
if ref.tag == "" {
|
|
||||||
if ref.digest != "" {
|
|
||||||
return canonicalReference{
|
|
||||||
name: ref.name,
|
|
||||||
digest: ref.digest,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return repository(ref.name)
|
|
||||||
}
|
|
||||||
if ref.digest == "" {
|
|
||||||
return taggedReference{
|
|
||||||
name: ref.name,
|
|
||||||
tag: ref.tag,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return ref
|
|
||||||
}
|
|
||||||
|
|
||||||
type reference struct {
|
|
||||||
name string
|
|
||||||
tag string
|
|
||||||
digest digest.Digest
|
|
||||||
}
|
|
||||||
|
|
||||||
func (r reference) String() string {
|
|
||||||
return r.name + ":" + r.tag + "@" + r.digest.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (r reference) Name() string {
|
|
||||||
return r.name
|
|
||||||
}
|
|
||||||
|
|
||||||
func (r reference) Tag() string {
|
|
||||||
return r.tag
|
|
||||||
}
|
|
||||||
|
|
||||||
func (r reference) Digest() digest.Digest {
|
|
||||||
return r.digest
|
|
||||||
}
|
|
||||||
|
|
||||||
type repository string
|
|
||||||
|
|
||||||
func (r repository) String() string {
|
|
||||||
return string(r)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (r repository) Name() string {
|
|
||||||
return string(r)
|
|
||||||
}
|
|
||||||
|
|
||||||
type digestReference digest.Digest
|
|
||||||
|
|
||||||
func (d digestReference) String() string {
|
|
||||||
return d.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d digestReference) Digest() digest.Digest {
|
|
||||||
return digest.Digest(d)
|
|
||||||
}
|
|
||||||
|
|
||||||
type taggedReference struct {
|
|
||||||
name string
|
|
||||||
tag string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (t taggedReference) String() string {
|
|
||||||
return t.name + ":" + t.tag
|
|
||||||
}
|
|
||||||
|
|
||||||
func (t taggedReference) Name() string {
|
|
||||||
return t.name
|
|
||||||
}
|
|
||||||
|
|
||||||
func (t taggedReference) Tag() string {
|
|
||||||
return t.tag
|
|
||||||
}
|
|
||||||
|
|
||||||
type canonicalReference struct {
|
|
||||||
name string
|
|
||||||
digest digest.Digest
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c canonicalReference) String() string {
|
|
||||||
return c.name + "@" + c.digest.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c canonicalReference) Name() string {
|
|
||||||
return c.name
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c canonicalReference) Digest() digest.Digest {
|
|
||||||
return c.digest
|
|
||||||
}
|
|
124
integration/vendor/github.com/docker/distribution/reference/regexp.go
generated
vendored
124
integration/vendor/github.com/docker/distribution/reference/regexp.go
generated
vendored
|
@ -1,124 +0,0 @@
|
||||||
package reference
|
|
||||||
|
|
||||||
import "regexp"
|
|
||||||
|
|
||||||
var (
|
|
||||||
// alphaNumericRegexp defines the alpha numeric atom, typically a
|
|
||||||
// component of names. This only allows lower case characters and digits.
|
|
||||||
alphaNumericRegexp = match(`[a-z0-9]+`)
|
|
||||||
|
|
||||||
// separatorRegexp defines the separators allowed to be embedded in name
|
|
||||||
// components. This allow one period, one or two underscore and multiple
|
|
||||||
// dashes.
|
|
||||||
separatorRegexp = match(`(?:[._]|__|[-]*)`)
|
|
||||||
|
|
||||||
// nameComponentRegexp restricts registry path component names to start
|
|
||||||
// with at least one letter or number, with following parts able to be
|
|
||||||
// separated by one period, one or two underscore and multiple dashes.
|
|
||||||
nameComponentRegexp = expression(
|
|
||||||
alphaNumericRegexp,
|
|
||||||
optional(repeated(separatorRegexp, alphaNumericRegexp)))
|
|
||||||
|
|
||||||
// hostnameComponentRegexp restricts the registry hostname component of a
|
|
||||||
// repository name to start with a component as defined by hostnameRegexp
|
|
||||||
// and followed by an optional port.
|
|
||||||
hostnameComponentRegexp = match(`(?:[a-zA-Z0-9]|[a-zA-Z0-9][a-zA-Z0-9-]*[a-zA-Z0-9])`)
|
|
||||||
|
|
||||||
// hostnameRegexp defines the structure of potential hostname components
|
|
||||||
// that may be part of image names. This is purposely a subset of what is
|
|
||||||
// allowed by DNS to ensure backwards compatibility with Docker image
|
|
||||||
// names.
|
|
||||||
hostnameRegexp = expression(
|
|
||||||
hostnameComponentRegexp,
|
|
||||||
optional(repeated(literal(`.`), hostnameComponentRegexp)),
|
|
||||||
optional(literal(`:`), match(`[0-9]+`)))
|
|
||||||
|
|
||||||
// TagRegexp matches valid tag names. From docker/docker:graph/tags.go.
|
|
||||||
TagRegexp = match(`[\w][\w.-]{0,127}`)
|
|
||||||
|
|
||||||
// anchoredTagRegexp matches valid tag names, anchored at the start and
|
|
||||||
// end of the matched string.
|
|
||||||
anchoredTagRegexp = anchored(TagRegexp)
|
|
||||||
|
|
||||||
// DigestRegexp matches valid digests.
|
|
||||||
DigestRegexp = match(`[A-Za-z][A-Za-z0-9]*(?:[-_+.][A-Za-z][A-Za-z0-9]*)*[:][[:xdigit:]]{32,}`)
|
|
||||||
|
|
||||||
// anchoredDigestRegexp matches valid digests, anchored at the start and
|
|
||||||
// end of the matched string.
|
|
||||||
anchoredDigestRegexp = anchored(DigestRegexp)
|
|
||||||
|
|
||||||
// NameRegexp is the format for the name component of references. The
|
|
||||||
// regexp has capturing groups for the hostname and name part omitting
|
|
||||||
// the separating forward slash from either.
|
|
||||||
NameRegexp = expression(
|
|
||||||
optional(hostnameRegexp, literal(`/`)),
|
|
||||||
nameComponentRegexp,
|
|
||||||
optional(repeated(literal(`/`), nameComponentRegexp)))
|
|
||||||
|
|
||||||
// anchoredNameRegexp is used to parse a name value, capturing the
|
|
||||||
// hostname and trailing components.
|
|
||||||
anchoredNameRegexp = anchored(
|
|
||||||
optional(capture(hostnameRegexp), literal(`/`)),
|
|
||||||
capture(nameComponentRegexp,
|
|
||||||
optional(repeated(literal(`/`), nameComponentRegexp))))
|
|
||||||
|
|
||||||
// ReferenceRegexp is the full supported format of a reference. The regexp
|
|
||||||
// is anchored and has capturing groups for name, tag, and digest
|
|
||||||
// components.
|
|
||||||
ReferenceRegexp = anchored(capture(NameRegexp),
|
|
||||||
optional(literal(":"), capture(TagRegexp)),
|
|
||||||
optional(literal("@"), capture(DigestRegexp)))
|
|
||||||
)
|
|
||||||
|
|
||||||
// match compiles the string to a regular expression.
|
|
||||||
var match = regexp.MustCompile
|
|
||||||
|
|
||||||
// literal compiles s into a literal regular expression, escaping any regexp
|
|
||||||
// reserved characters.
|
|
||||||
func literal(s string) *regexp.Regexp {
|
|
||||||
re := match(regexp.QuoteMeta(s))
|
|
||||||
|
|
||||||
if _, complete := re.LiteralPrefix(); !complete {
|
|
||||||
panic("must be a literal")
|
|
||||||
}
|
|
||||||
|
|
||||||
return re
|
|
||||||
}
|
|
||||||
|
|
||||||
// expression defines a full expression, where each regular expression must
|
|
||||||
// follow the previous.
|
|
||||||
func expression(res ...*regexp.Regexp) *regexp.Regexp {
|
|
||||||
var s string
|
|
||||||
for _, re := range res {
|
|
||||||
s += re.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
return match(s)
|
|
||||||
}
|
|
||||||
|
|
||||||
// optional wraps the expression in a non-capturing group and makes the
|
|
||||||
// production optional.
|
|
||||||
func optional(res ...*regexp.Regexp) *regexp.Regexp {
|
|
||||||
return match(group(expression(res...)).String() + `?`)
|
|
||||||
}
|
|
||||||
|
|
||||||
// repeated wraps the regexp in a non-capturing group to get one or more
|
|
||||||
// matches.
|
|
||||||
func repeated(res ...*regexp.Regexp) *regexp.Regexp {
|
|
||||||
return match(group(expression(res...)).String() + `+`)
|
|
||||||
}
|
|
||||||
|
|
||||||
// group wraps the regexp in a non-capturing group.
|
|
||||||
func group(res ...*regexp.Regexp) *regexp.Regexp {
|
|
||||||
return match(`(?:` + expression(res...).String() + `)`)
|
|
||||||
}
|
|
||||||
|
|
||||||
// capture wraps the expression in a capturing group.
|
|
||||||
func capture(res ...*regexp.Regexp) *regexp.Regexp {
|
|
||||||
return match(`(` + expression(res...).String() + `)`)
|
|
||||||
}
|
|
||||||
|
|
||||||
// anchored anchors the regular expression by adding start and end delimiters.
|
|
||||||
func anchored(res ...*regexp.Regexp) *regexp.Regexp {
|
|
||||||
return match(`^` + expression(res...).String() + `$`)
|
|
||||||
}
|
|
97
integration/vendor/github.com/docker/distribution/registry.go
generated
vendored
97
integration/vendor/github.com/docker/distribution/registry.go
generated
vendored
|
@ -1,97 +0,0 @@
|
||||||
package distribution
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/docker/distribution/context"
|
|
||||||
"github.com/docker/distribution/reference"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Scope defines the set of items that match a namespace.
|
|
||||||
type Scope interface {
|
|
||||||
// Contains returns true if the name belongs to the namespace.
|
|
||||||
Contains(name string) bool
|
|
||||||
}
|
|
||||||
|
|
||||||
type fullScope struct{}
|
|
||||||
|
|
||||||
func (f fullScope) Contains(string) bool {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
// GlobalScope represents the full namespace scope which contains
|
|
||||||
// all other scopes.
|
|
||||||
var GlobalScope = Scope(fullScope{})
|
|
||||||
|
|
||||||
// Namespace represents a collection of repositories, addressable by name.
|
|
||||||
// Generally, a namespace is backed by a set of one or more services,
|
|
||||||
// providing facilities such as registry access, trust, and indexing.
|
|
||||||
type Namespace interface {
|
|
||||||
// Scope describes the names that can be used with this Namespace. The
|
|
||||||
// global namespace will have a scope that matches all names. The scope
|
|
||||||
// effectively provides an identity for the namespace.
|
|
||||||
Scope() Scope
|
|
||||||
|
|
||||||
// Repository should return a reference to the named repository. The
|
|
||||||
// registry may or may not have the repository but should always return a
|
|
||||||
// reference.
|
|
||||||
Repository(ctx context.Context, name reference.Named) (Repository, error)
|
|
||||||
|
|
||||||
// Repositories fills 'repos' with a lexigraphically sorted catalog of repositories
|
|
||||||
// up to the size of 'repos' and returns the value 'n' for the number of entries
|
|
||||||
// which were filled. 'last' contains an offset in the catalog, and 'err' will be
|
|
||||||
// set to io.EOF if there are no more entries to obtain.
|
|
||||||
Repositories(ctx context.Context, repos []string, last string) (n int, err error)
|
|
||||||
|
|
||||||
// Blobs returns a blob enumerator to access all blobs
|
|
||||||
Blobs() BlobEnumerator
|
|
||||||
|
|
||||||
// BlobStatter returns a BlobStatter to control
|
|
||||||
BlobStatter() BlobStatter
|
|
||||||
}
|
|
||||||
|
|
||||||
// RepositoryEnumerator describes an operation to enumerate repositories
|
|
||||||
type RepositoryEnumerator interface {
|
|
||||||
Enumerate(ctx context.Context, ingester func(string) error) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// ManifestServiceOption is a function argument for Manifest Service methods
|
|
||||||
type ManifestServiceOption interface {
|
|
||||||
Apply(ManifestService) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// WithTag allows a tag to be passed into Put
|
|
||||||
func WithTag(tag string) ManifestServiceOption {
|
|
||||||
return WithTagOption{tag}
|
|
||||||
}
|
|
||||||
|
|
||||||
// WithTagOption holds a tag
|
|
||||||
type WithTagOption struct{ Tag string }
|
|
||||||
|
|
||||||
// Apply conforms to the ManifestServiceOption interface
|
|
||||||
func (o WithTagOption) Apply(m ManifestService) error {
|
|
||||||
// no implementation
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Repository is a named collection of manifests and layers.
|
|
||||||
type Repository interface {
|
|
||||||
// Named returns the name of the repository.
|
|
||||||
Named() reference.Named
|
|
||||||
|
|
||||||
// Manifests returns a reference to this repository's manifest service.
|
|
||||||
// with the supplied options applied.
|
|
||||||
Manifests(ctx context.Context, options ...ManifestServiceOption) (ManifestService, error)
|
|
||||||
|
|
||||||
// Blobs returns a reference to this repository's blob service.
|
|
||||||
Blobs(ctx context.Context) BlobStore
|
|
||||||
|
|
||||||
// TODO(stevvooe): The above BlobStore return can probably be relaxed to
|
|
||||||
// be a BlobService for use with clients. This will allow such
|
|
||||||
// implementations to avoid implementing ServeBlob.
|
|
||||||
|
|
||||||
// Tags returns a reference to this repositories tag service
|
|
||||||
Tags(ctx context.Context) TagService
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO(stevvooe): Must add close methods to all these. May want to change the
|
|
||||||
// way instances are created to better reflect internal dependency
|
|
||||||
// relationships.
|
|
27
integration/vendor/github.com/docker/distribution/tags.go
generated
vendored
27
integration/vendor/github.com/docker/distribution/tags.go
generated
vendored
|
@ -1,27 +0,0 @@
|
||||||
package distribution
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/docker/distribution/context"
|
|
||||||
)
|
|
||||||
|
|
||||||
// TagService provides access to information about tagged objects.
|
|
||||||
type TagService interface {
|
|
||||||
// Get retrieves the descriptor identified by the tag. Some
|
|
||||||
// implementations may differentiate between "trusted" tags and
|
|
||||||
// "untrusted" tags. If a tag is "untrusted", the mapping will be returned
|
|
||||||
// as an ErrTagUntrusted error, with the target descriptor.
|
|
||||||
Get(ctx context.Context, tag string) (Descriptor, error)
|
|
||||||
|
|
||||||
// Tag associates the tag with the provided descriptor, updating the
|
|
||||||
// current association, if needed.
|
|
||||||
Tag(ctx context.Context, tag string, desc Descriptor) error
|
|
||||||
|
|
||||||
// Untag removes the given tag association
|
|
||||||
Untag(ctx context.Context, tag string) error
|
|
||||||
|
|
||||||
// All returns the set of tags managed by this tag service
|
|
||||||
All(ctx context.Context) ([]string, error)
|
|
||||||
|
|
||||||
// Lookup returns the set of tags referencing the given digest.
|
|
||||||
Lookup(ctx context.Context, digest Descriptor) ([]string, error)
|
|
||||||
}
|
|
85
integration/vendor/github.com/docker/docker/api/types/backend/backend.go
generated
vendored
85
integration/vendor/github.com/docker/docker/api/types/backend/backend.go
generated
vendored
|
@ -1,85 +0,0 @@
|
||||||
// Package backend includes types to send information to server backends.
|
|
||||||
// TODO(calavera): This package is pending of extraction to engine-api
|
|
||||||
// when the server package is clean of daemon dependencies.
|
|
||||||
package backend
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
|
|
||||||
"github.com/docker/docker/pkg/streamformatter"
|
|
||||||
"github.com/docker/engine-api/types"
|
|
||||||
)
|
|
||||||
|
|
||||||
// ContainerAttachConfig holds the streams to use when connecting to a container to view logs.
|
|
||||||
type ContainerAttachConfig struct {
|
|
||||||
GetStreams func() (io.ReadCloser, io.Writer, io.Writer, error)
|
|
||||||
UseStdin bool
|
|
||||||
UseStdout bool
|
|
||||||
UseStderr bool
|
|
||||||
Logs bool
|
|
||||||
Stream bool
|
|
||||||
DetachKeys string
|
|
||||||
|
|
||||||
// Used to signify that streams are multiplexed and therefore need a StdWriter to encode stdout/sderr messages accordingly.
|
|
||||||
// TODO @cpuguy83: This shouldn't be needed. It was only added so that http and websocket endpoints can use the same function, and the websocket function was not using a stdwriter prior to this change...
|
|
||||||
// HOWEVER, the websocket endpoint is using a single stream and SHOULD be encoded with stdout/stderr as is done for HTTP since it is still just a single stream.
|
|
||||||
// Since such a change is an API change unrelated to the current changeset we'll keep it as is here and change separately.
|
|
||||||
MuxStreams bool
|
|
||||||
}
|
|
||||||
|
|
||||||
// ContainerLogsConfig holds configs for logging operations. Exists
|
|
||||||
// for users of the backend to to pass it a logging configuration.
|
|
||||||
type ContainerLogsConfig struct {
|
|
||||||
types.ContainerLogsOptions
|
|
||||||
OutStream io.Writer
|
|
||||||
}
|
|
||||||
|
|
||||||
// ContainerStatsConfig holds information for configuring the runtime
|
|
||||||
// behavior of a backend.ContainerStats() call.
|
|
||||||
type ContainerStatsConfig struct {
|
|
||||||
Stream bool
|
|
||||||
OutStream io.Writer
|
|
||||||
Version string
|
|
||||||
}
|
|
||||||
|
|
||||||
// ExecInspect holds information about a running process started
|
|
||||||
// with docker exec.
|
|
||||||
type ExecInspect struct {
|
|
||||||
ID string
|
|
||||||
Running bool
|
|
||||||
ExitCode *int
|
|
||||||
ProcessConfig *ExecProcessConfig
|
|
||||||
OpenStdin bool
|
|
||||||
OpenStderr bool
|
|
||||||
OpenStdout bool
|
|
||||||
CanRemove bool
|
|
||||||
ContainerID string
|
|
||||||
DetachKeys []byte
|
|
||||||
}
|
|
||||||
|
|
||||||
// ExecProcessConfig holds information about the exec process
|
|
||||||
// running on the host.
|
|
||||||
type ExecProcessConfig struct {
|
|
||||||
Tty bool `json:"tty"`
|
|
||||||
Entrypoint string `json:"entrypoint"`
|
|
||||||
Arguments []string `json:"arguments"`
|
|
||||||
Privileged *bool `json:"privileged,omitempty"`
|
|
||||||
User string `json:"user,omitempty"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// ContainerCommitConfig is a wrapper around
|
|
||||||
// types.ContainerCommitConfig that also
|
|
||||||
// transports configuration changes for a container.
|
|
||||||
type ContainerCommitConfig struct {
|
|
||||||
types.ContainerCommitConfig
|
|
||||||
Changes []string
|
|
||||||
}
|
|
||||||
|
|
||||||
// ProgressWriter is an interface
|
|
||||||
// to transport progress streams.
|
|
||||||
type ProgressWriter struct {
|
|
||||||
Output io.Writer
|
|
||||||
StdoutFormatter *streamformatter.StdoutFormatter
|
|
||||||
StderrFormatter *streamformatter.StderrFormatter
|
|
||||||
ProgressReaderFunc func(io.ReadCloser) io.ReadCloser
|
|
||||||
}
|
|
155
integration/vendor/github.com/docker/docker/builder/builder.go
generated
vendored
155
integration/vendor/github.com/docker/docker/builder/builder.go
generated
vendored
|
@ -1,155 +0,0 @@
|
||||||
// Package builder defines interfaces for any Docker builder to implement.
|
|
||||||
//
|
|
||||||
// Historically, only server-side Dockerfile interpreters existed.
|
|
||||||
// This package allows for other implementations of Docker builders.
|
|
||||||
package builder
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
"os"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/docker/docker/api/types/backend"
|
|
||||||
"github.com/docker/docker/image"
|
|
||||||
"github.com/docker/docker/reference"
|
|
||||||
"github.com/docker/engine-api/types"
|
|
||||||
"github.com/docker/engine-api/types/container"
|
|
||||||
"golang.org/x/net/context"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
// DefaultDockerfileName is the Default filename with Docker commands, read by docker build
|
|
||||||
DefaultDockerfileName string = "Dockerfile"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Context represents a file system tree.
|
|
||||||
type Context interface {
|
|
||||||
// Close allows to signal that the filesystem tree won't be used anymore.
|
|
||||||
// For Context implementations using a temporary directory, it is recommended to
|
|
||||||
// delete the temporary directory in Close().
|
|
||||||
Close() error
|
|
||||||
// Stat returns an entry corresponding to path if any.
|
|
||||||
// It is recommended to return an error if path was not found.
|
|
||||||
// If path is a symlink it also returns the path to the target file.
|
|
||||||
Stat(path string) (string, FileInfo, error)
|
|
||||||
// Open opens path from the context and returns a readable stream of it.
|
|
||||||
Open(path string) (io.ReadCloser, error)
|
|
||||||
// Walk walks the tree of the context with the function passed to it.
|
|
||||||
Walk(root string, walkFn WalkFunc) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// WalkFunc is the type of the function called for each file or directory visited by Context.Walk().
|
|
||||||
type WalkFunc func(path string, fi FileInfo, err error) error
|
|
||||||
|
|
||||||
// ModifiableContext represents a modifiable Context.
|
|
||||||
// TODO: remove this interface once we can get rid of Remove()
|
|
||||||
type ModifiableContext interface {
|
|
||||||
Context
|
|
||||||
// Remove deletes the entry specified by `path`.
|
|
||||||
// It is usual for directory entries to delete all its subentries.
|
|
||||||
Remove(path string) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// FileInfo extends os.FileInfo to allow retrieving an absolute path to the file.
|
|
||||||
// TODO: remove this interface once pkg/archive exposes a walk function that Context can use.
|
|
||||||
type FileInfo interface {
|
|
||||||
os.FileInfo
|
|
||||||
Path() string
|
|
||||||
}
|
|
||||||
|
|
||||||
// PathFileInfo is a convenience struct that implements the FileInfo interface.
|
|
||||||
type PathFileInfo struct {
|
|
||||||
os.FileInfo
|
|
||||||
// FilePath holds the absolute path to the file.
|
|
||||||
FilePath string
|
|
||||||
// Name holds the basename for the file.
|
|
||||||
FileName string
|
|
||||||
}
|
|
||||||
|
|
||||||
// Path returns the absolute path to the file.
|
|
||||||
func (fi PathFileInfo) Path() string {
|
|
||||||
return fi.FilePath
|
|
||||||
}
|
|
||||||
|
|
||||||
// Name returns the basename of the file.
|
|
||||||
func (fi PathFileInfo) Name() string {
|
|
||||||
if fi.FileName != "" {
|
|
||||||
return fi.FileName
|
|
||||||
}
|
|
||||||
return fi.FileInfo.Name()
|
|
||||||
}
|
|
||||||
|
|
||||||
// Hashed defines an extra method intended for implementations of os.FileInfo.
|
|
||||||
type Hashed interface {
|
|
||||||
// Hash returns the hash of a file.
|
|
||||||
Hash() string
|
|
||||||
SetHash(string)
|
|
||||||
}
|
|
||||||
|
|
||||||
// HashedFileInfo is a convenient struct that augments FileInfo with a field.
|
|
||||||
type HashedFileInfo struct {
|
|
||||||
FileInfo
|
|
||||||
// FileHash represents the hash of a file.
|
|
||||||
FileHash string
|
|
||||||
}
|
|
||||||
|
|
||||||
// Hash returns the hash of a file.
|
|
||||||
func (fi HashedFileInfo) Hash() string {
|
|
||||||
return fi.FileHash
|
|
||||||
}
|
|
||||||
|
|
||||||
// SetHash sets the hash of a file.
|
|
||||||
func (fi *HashedFileInfo) SetHash(h string) {
|
|
||||||
fi.FileHash = h
|
|
||||||
}
|
|
||||||
|
|
||||||
// Backend abstracts calls to a Docker Daemon.
|
|
||||||
type Backend interface {
|
|
||||||
// TODO: use digest reference instead of name
|
|
||||||
|
|
||||||
// GetImageOnBuild looks up a Docker image referenced by `name`.
|
|
||||||
GetImageOnBuild(name string) (Image, error)
|
|
||||||
// TagImage tags an image with newTag
|
|
||||||
TagImageWithReference(image.ID, reference.Named) error
|
|
||||||
// PullOnBuild tells Docker to pull image referenced by `name`.
|
|
||||||
PullOnBuild(ctx context.Context, name string, authConfigs map[string]types.AuthConfig, output io.Writer) (Image, error)
|
|
||||||
// ContainerAttachRaw attaches to container.
|
|
||||||
ContainerAttachRaw(cID string, stdin io.ReadCloser, stdout, stderr io.Writer, stream bool) error
|
|
||||||
// ContainerCreate creates a new Docker container and returns potential warnings
|
|
||||||
ContainerCreate(types.ContainerCreateConfig) (types.ContainerCreateResponse, error)
|
|
||||||
// ContainerRm removes a container specified by `id`.
|
|
||||||
ContainerRm(name string, config *types.ContainerRmConfig) error
|
|
||||||
// Commit creates a new Docker image from an existing Docker container.
|
|
||||||
Commit(string, *backend.ContainerCommitConfig) (string, error)
|
|
||||||
// ContainerKill stops the container execution abruptly.
|
|
||||||
ContainerKill(containerID string, sig uint64) error
|
|
||||||
// ContainerStart starts a new container
|
|
||||||
ContainerStart(containerID string, hostConfig *container.HostConfig) error
|
|
||||||
// ContainerWait stops processing until the given container is stopped.
|
|
||||||
ContainerWait(containerID string, timeout time.Duration) (int, error)
|
|
||||||
// ContainerUpdateCmdOnBuild updates container.Path and container.Args
|
|
||||||
ContainerUpdateCmdOnBuild(containerID string, cmd []string) error
|
|
||||||
|
|
||||||
// ContainerCopy copies/extracts a source FileInfo to a destination path inside a container
|
|
||||||
// specified by a container object.
|
|
||||||
// TODO: make an Extract method instead of passing `decompress`
|
|
||||||
// TODO: do not pass a FileInfo, instead refactor the archive package to export a Walk function that can be used
|
|
||||||
// with Context.Walk
|
|
||||||
//ContainerCopy(name string, res string) (io.ReadCloser, error)
|
|
||||||
// TODO: use copyBackend api
|
|
||||||
CopyOnBuild(containerID string, destPath string, src FileInfo, decompress bool) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// Image represents a Docker image used by the builder.
|
|
||||||
type Image interface {
|
|
||||||
ImageID() string
|
|
||||||
RunConfig() *container.Config
|
|
||||||
}
|
|
||||||
|
|
||||||
// ImageCache abstracts an image cache store.
|
|
||||||
// (parent image, child runconfig) -> child image
|
|
||||||
type ImageCache interface {
|
|
||||||
// GetCachedImageOnBuild returns a reference to a cached image whose parent equals `parent`
|
|
||||||
// and runconfig equals `cfg`. A cache miss is expected to return an empty ID and a nil error.
|
|
||||||
GetCachedImageOnBuild(parentID string, cfg *container.Config) (imageID string, err error)
|
|
||||||
}
|
|
47
integration/vendor/github.com/docker/docker/builder/dockerignore.go
generated
vendored
47
integration/vendor/github.com/docker/docker/builder/dockerignore.go
generated
vendored
|
@ -1,47 +0,0 @@
|
||||||
package builder
|
|
||||||
|
|
||||||
import (
|
|
||||||
"os"
|
|
||||||
|
|
||||||
"github.com/docker/docker/builder/dockerignore"
|
|
||||||
"github.com/docker/docker/pkg/fileutils"
|
|
||||||
)
|
|
||||||
|
|
||||||
// DockerIgnoreContext wraps a ModifiableContext to add a method
|
|
||||||
// for handling the .dockerignore file at the root of the context.
|
|
||||||
type DockerIgnoreContext struct {
|
|
||||||
ModifiableContext
|
|
||||||
}
|
|
||||||
|
|
||||||
// Process reads the .dockerignore file at the root of the embedded context.
|
|
||||||
// If .dockerignore does not exist in the context, then nil is returned.
|
|
||||||
//
|
|
||||||
// It can take a list of files to be removed after .dockerignore is removed.
|
|
||||||
// This is used for server-side implementations of builders that need to send
|
|
||||||
// the .dockerignore file as well as the special files specified in filesToRemove,
|
|
||||||
// but expect them to be excluded from the context after they were processed.
|
|
||||||
//
|
|
||||||
// For example, server-side Dockerfile builders are expected to pass in the name
|
|
||||||
// of the Dockerfile to be removed after it was parsed.
|
|
||||||
//
|
|
||||||
// TODO: Don't require a ModifiableContext (use Context instead) and don't remove
|
|
||||||
// files, instead handle a list of files to be excluded from the context.
|
|
||||||
func (c DockerIgnoreContext) Process(filesToRemove []string) error {
|
|
||||||
f, err := c.Open(".dockerignore")
|
|
||||||
// Note that a missing .dockerignore file isn't treated as an error
|
|
||||||
if err != nil {
|
|
||||||
if os.IsNotExist(err) {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
excludes, _ := dockerignore.ReadAll(f)
|
|
||||||
filesToRemove = append([]string{".dockerignore"}, filesToRemove...)
|
|
||||||
for _, fileToRemove := range filesToRemove {
|
|
||||||
rm, _ := fileutils.Matches(fileToRemove, excludes)
|
|
||||||
if rm {
|
|
||||||
c.Remove(fileToRemove)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
28
integration/vendor/github.com/docker/docker/builder/git.go
generated
vendored
28
integration/vendor/github.com/docker/docker/builder/git.go
generated
vendored
|
@ -1,28 +0,0 @@
|
||||||
package builder
|
|
||||||
|
|
||||||
import (
|
|
||||||
"os"
|
|
||||||
|
|
||||||
"github.com/docker/docker/pkg/archive"
|
|
||||||
"github.com/docker/docker/pkg/gitutils"
|
|
||||||
)
|
|
||||||
|
|
||||||
// MakeGitContext returns a Context from gitURL that is cloned in a temporary directory.
|
|
||||||
func MakeGitContext(gitURL string) (ModifiableContext, error) {
|
|
||||||
root, err := gitutils.Clone(gitURL)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
c, err := archive.Tar(root, archive.Uncompressed)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
defer func() {
|
|
||||||
// TODO: print errors?
|
|
||||||
c.Close()
|
|
||||||
os.RemoveAll(root)
|
|
||||||
}()
|
|
||||||
return MakeTarSumContext(c)
|
|
||||||
}
|
|
152
integration/vendor/github.com/docker/docker/builder/remote.go
generated
vendored
152
integration/vendor/github.com/docker/docker/builder/remote.go
generated
vendored
|
@ -1,152 +0,0 @@
|
||||||
package builder
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"io/ioutil"
|
|
||||||
"regexp"
|
|
||||||
|
|
||||||
"github.com/docker/docker/pkg/archive"
|
|
||||||
"github.com/docker/docker/pkg/httputils"
|
|
||||||
"github.com/docker/docker/pkg/urlutil"
|
|
||||||
)
|
|
||||||
|
|
||||||
// When downloading remote contexts, limit the amount (in bytes)
|
|
||||||
// to be read from the response body in order to detect its Content-Type
|
|
||||||
const maxPreambleLength = 100
|
|
||||||
|
|
||||||
const acceptableRemoteMIME = `(?:application/(?:(?:x\-)?tar|octet\-stream|((?:x\-)?(?:gzip|bzip2?|xz)))|(?:text/plain))`
|
|
||||||
|
|
||||||
var mimeRe = regexp.MustCompile(acceptableRemoteMIME)
|
|
||||||
|
|
||||||
// MakeRemoteContext downloads a context from remoteURL and returns it.
|
|
||||||
//
|
|
||||||
// If contentTypeHandlers is non-nil, then the Content-Type header is read along with a maximum of
|
|
||||||
// maxPreambleLength bytes from the body to help detecting the MIME type.
|
|
||||||
// Look at acceptableRemoteMIME for more details.
|
|
||||||
//
|
|
||||||
// If a match is found, then the body is sent to the contentType handler and a (potentially compressed) tar stream is expected
|
|
||||||
// to be returned. If no match is found, it is assumed the body is a tar stream (compressed or not).
|
|
||||||
// In either case, an (assumed) tar stream is passed to MakeTarSumContext whose result is returned.
|
|
||||||
func MakeRemoteContext(remoteURL string, contentTypeHandlers map[string]func(io.ReadCloser) (io.ReadCloser, error)) (ModifiableContext, error) {
|
|
||||||
f, err := httputils.Download(remoteURL)
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("Error downloading remote context %s: %v", remoteURL, err)
|
|
||||||
}
|
|
||||||
defer f.Body.Close()
|
|
||||||
|
|
||||||
var contextReader io.ReadCloser
|
|
||||||
if contentTypeHandlers != nil {
|
|
||||||
contentType := f.Header.Get("Content-Type")
|
|
||||||
clen := f.ContentLength
|
|
||||||
|
|
||||||
contentType, contextReader, err = inspectResponse(contentType, f.Body, clen)
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("Error detecting content type for remote %s: %v", remoteURL, err)
|
|
||||||
}
|
|
||||||
defer contextReader.Close()
|
|
||||||
|
|
||||||
// This loop tries to find a content-type handler for the detected content-type.
|
|
||||||
// If it could not find one from the caller-supplied map, it tries the empty content-type `""`
|
|
||||||
// which is interpreted as a fallback handler (usually used for raw tar contexts).
|
|
||||||
for _, ct := range []string{contentType, ""} {
|
|
||||||
if fn, ok := contentTypeHandlers[ct]; ok {
|
|
||||||
defer contextReader.Close()
|
|
||||||
if contextReader, err = fn(contextReader); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Pass through - this is a pre-packaged context, presumably
|
|
||||||
// with a Dockerfile with the right name inside it.
|
|
||||||
return MakeTarSumContext(contextReader)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DetectContextFromRemoteURL returns a context and in certain cases the name of the dockerfile to be used
|
|
||||||
// irrespective of user input.
|
|
||||||
// progressReader is only used if remoteURL is actually a URL (not empty, and not a Git endpoint).
|
|
||||||
func DetectContextFromRemoteURL(r io.ReadCloser, remoteURL string, createProgressReader func(in io.ReadCloser) io.ReadCloser) (context ModifiableContext, dockerfileName string, err error) {
|
|
||||||
switch {
|
|
||||||
case remoteURL == "":
|
|
||||||
context, err = MakeTarSumContext(r)
|
|
||||||
case urlutil.IsGitURL(remoteURL):
|
|
||||||
context, err = MakeGitContext(remoteURL)
|
|
||||||
case urlutil.IsURL(remoteURL):
|
|
||||||
context, err = MakeRemoteContext(remoteURL, map[string]func(io.ReadCloser) (io.ReadCloser, error){
|
|
||||||
httputils.MimeTypes.TextPlain: func(rc io.ReadCloser) (io.ReadCloser, error) {
|
|
||||||
dockerfile, err := ioutil.ReadAll(rc)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// dockerfileName is set to signal that the remote was interpreted as a single Dockerfile, in which case the caller
|
|
||||||
// should use dockerfileName as the new name for the Dockerfile, irrespective of any other user input.
|
|
||||||
dockerfileName = DefaultDockerfileName
|
|
||||||
|
|
||||||
// TODO: return a context without tarsum
|
|
||||||
return archive.Generate(dockerfileName, string(dockerfile))
|
|
||||||
},
|
|
||||||
// fallback handler (tar context)
|
|
||||||
"": func(rc io.ReadCloser) (io.ReadCloser, error) {
|
|
||||||
return createProgressReader(rc), nil
|
|
||||||
},
|
|
||||||
})
|
|
||||||
default:
|
|
||||||
err = fmt.Errorf("remoteURL (%s) could not be recognized as URL", remoteURL)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// inspectResponse looks into the http response data at r to determine whether its
|
|
||||||
// content-type is on the list of acceptable content types for remote build contexts.
|
|
||||||
// This function returns:
|
|
||||||
// - a string representation of the detected content-type
|
|
||||||
// - an io.Reader for the response body
|
|
||||||
// - an error value which will be non-nil either when something goes wrong while
|
|
||||||
// reading bytes from r or when the detected content-type is not acceptable.
|
|
||||||
func inspectResponse(ct string, r io.ReadCloser, clen int64) (string, io.ReadCloser, error) {
|
|
||||||
plen := clen
|
|
||||||
if plen <= 0 || plen > maxPreambleLength {
|
|
||||||
plen = maxPreambleLength
|
|
||||||
}
|
|
||||||
|
|
||||||
preamble := make([]byte, plen, plen)
|
|
||||||
rlen, err := r.Read(preamble)
|
|
||||||
if rlen == 0 {
|
|
||||||
return ct, r, errors.New("Empty response")
|
|
||||||
}
|
|
||||||
if err != nil && err != io.EOF {
|
|
||||||
return ct, r, err
|
|
||||||
}
|
|
||||||
|
|
||||||
preambleR := bytes.NewReader(preamble)
|
|
||||||
bodyReader := ioutil.NopCloser(io.MultiReader(preambleR, r))
|
|
||||||
// Some web servers will use application/octet-stream as the default
|
|
||||||
// content type for files without an extension (e.g. 'Dockerfile')
|
|
||||||
// so if we receive this value we better check for text content
|
|
||||||
contentType := ct
|
|
||||||
if len(ct) == 0 || ct == httputils.MimeTypes.OctetStream {
|
|
||||||
contentType, _, err = httputils.DetectContentType(preamble)
|
|
||||||
if err != nil {
|
|
||||||
return contentType, bodyReader, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
contentType = selectAcceptableMIME(contentType)
|
|
||||||
var cterr error
|
|
||||||
if len(contentType) == 0 {
|
|
||||||
cterr = fmt.Errorf("unsupported Content-Type %q", ct)
|
|
||||||
contentType = ct
|
|
||||||
}
|
|
||||||
|
|
||||||
return contentType, bodyReader, cterr
|
|
||||||
}
|
|
||||||
|
|
||||||
func selectAcceptableMIME(ct string) string {
|
|
||||||
return mimeRe.FindString(ct)
|
|
||||||
}
|
|
158
integration/vendor/github.com/docker/docker/builder/tarsum.go
generated
vendored
158
integration/vendor/github.com/docker/docker/builder/tarsum.go
generated
vendored
|
@ -1,158 +0,0 @@
|
||||||
package builder
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"os"
|
|
||||||
"path/filepath"
|
|
||||||
|
|
||||||
"github.com/docker/docker/pkg/archive"
|
|
||||||
"github.com/docker/docker/pkg/chrootarchive"
|
|
||||||
"github.com/docker/docker/pkg/ioutils"
|
|
||||||
"github.com/docker/docker/pkg/symlink"
|
|
||||||
"github.com/docker/docker/pkg/tarsum"
|
|
||||||
)
|
|
||||||
|
|
||||||
type tarSumContext struct {
|
|
||||||
root string
|
|
||||||
sums tarsum.FileInfoSums
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *tarSumContext) Close() error {
|
|
||||||
return os.RemoveAll(c.root)
|
|
||||||
}
|
|
||||||
|
|
||||||
func convertPathError(err error, cleanpath string) error {
|
|
||||||
if err, ok := err.(*os.PathError); ok {
|
|
||||||
err.Path = cleanpath
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *tarSumContext) Open(path string) (io.ReadCloser, error) {
|
|
||||||
cleanpath, fullpath, err := c.normalize(path)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
r, err := os.Open(fullpath)
|
|
||||||
if err != nil {
|
|
||||||
return nil, convertPathError(err, cleanpath)
|
|
||||||
}
|
|
||||||
return r, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *tarSumContext) Stat(path string) (string, FileInfo, error) {
|
|
||||||
cleanpath, fullpath, err := c.normalize(path)
|
|
||||||
if err != nil {
|
|
||||||
return "", nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
st, err := os.Lstat(fullpath)
|
|
||||||
if err != nil {
|
|
||||||
return "", nil, convertPathError(err, cleanpath)
|
|
||||||
}
|
|
||||||
|
|
||||||
rel, err := filepath.Rel(c.root, fullpath)
|
|
||||||
if err != nil {
|
|
||||||
return "", nil, convertPathError(err, cleanpath)
|
|
||||||
}
|
|
||||||
|
|
||||||
// We set sum to path by default for the case where GetFile returns nil.
|
|
||||||
// The usual case is if relative path is empty.
|
|
||||||
sum := path
|
|
||||||
// Use the checksum of the followed path(not the possible symlink) because
|
|
||||||
// this is the file that is actually copied.
|
|
||||||
if tsInfo := c.sums.GetFile(rel); tsInfo != nil {
|
|
||||||
sum = tsInfo.Sum()
|
|
||||||
}
|
|
||||||
fi := &HashedFileInfo{PathFileInfo{st, fullpath, filepath.Base(cleanpath)}, sum}
|
|
||||||
return rel, fi, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// MakeTarSumContext returns a build Context from a tar stream.
|
|
||||||
//
|
|
||||||
// It extracts the tar stream to a temporary folder that is deleted as soon as
|
|
||||||
// the Context is closed.
|
|
||||||
// As the extraction happens, a tarsum is calculated for every file, and the set of
|
|
||||||
// all those sums then becomes the source of truth for all operations on this Context.
|
|
||||||
//
|
|
||||||
// Closing tarStream has to be done by the caller.
|
|
||||||
func MakeTarSumContext(tarStream io.Reader) (ModifiableContext, error) {
|
|
||||||
root, err := ioutils.TempDir("", "docker-builder")
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
tsc := &tarSumContext{root: root}
|
|
||||||
|
|
||||||
// Make sure we clean-up upon error. In the happy case the caller
|
|
||||||
// is expected to manage the clean-up
|
|
||||||
defer func() {
|
|
||||||
if err != nil {
|
|
||||||
tsc.Close()
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
decompressedStream, err := archive.DecompressStream(tarStream)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
sum, err := tarsum.NewTarSum(decompressedStream, true, tarsum.Version1)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := chrootarchive.Untar(sum, root, nil); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
tsc.sums = sum.GetSums()
|
|
||||||
|
|
||||||
return tsc, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *tarSumContext) normalize(path string) (cleanpath, fullpath string, err error) {
|
|
||||||
cleanpath = filepath.Clean(string(os.PathSeparator) + path)[1:]
|
|
||||||
fullpath, err = symlink.FollowSymlinkInScope(filepath.Join(c.root, path), c.root)
|
|
||||||
if err != nil {
|
|
||||||
return "", "", fmt.Errorf("Forbidden path outside the build context: %s (%s)", path, fullpath)
|
|
||||||
}
|
|
||||||
_, err = os.Lstat(fullpath)
|
|
||||||
if err != nil {
|
|
||||||
return "", "", convertPathError(err, path)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *tarSumContext) Walk(root string, walkFn WalkFunc) error {
|
|
||||||
root = filepath.Join(c.root, filepath.Join(string(filepath.Separator), root))
|
|
||||||
return filepath.Walk(root, func(fullpath string, info os.FileInfo, err error) error {
|
|
||||||
rel, err := filepath.Rel(c.root, fullpath)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if rel == "." {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
sum := rel
|
|
||||||
if tsInfo := c.sums.GetFile(filepath.ToSlash(rel)); tsInfo != nil {
|
|
||||||
sum = tsInfo.Sum()
|
|
||||||
}
|
|
||||||
fi := &HashedFileInfo{PathFileInfo{FileInfo: info, FilePath: fullpath}, sum}
|
|
||||||
if err := walkFn(rel, fi, nil); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *tarSumContext) Remove(path string) error {
|
|
||||||
_, fullpath, err := c.normalize(path)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return os.RemoveAll(fullpath)
|
|
||||||
}
|
|
67
integration/vendor/github.com/docker/docker/daemon/graphdriver/counter.go
generated
vendored
67
integration/vendor/github.com/docker/docker/daemon/graphdriver/counter.go
generated
vendored
|
@ -1,67 +0,0 @@
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
import "sync"
|
|
||||||
|
|
||||||
type minfo struct {
|
|
||||||
check bool
|
|
||||||
count int
|
|
||||||
}
|
|
||||||
|
|
||||||
// RefCounter is a generic counter for use by graphdriver Get/Put calls
|
|
||||||
type RefCounter struct {
|
|
||||||
counts map[string]*minfo
|
|
||||||
mu sync.Mutex
|
|
||||||
checker Checker
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewRefCounter returns a new RefCounter
|
|
||||||
func NewRefCounter(c Checker) *RefCounter {
|
|
||||||
return &RefCounter{
|
|
||||||
checker: c,
|
|
||||||
counts: make(map[string]*minfo),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Increment increaes the ref count for the given id and returns the current count
|
|
||||||
func (c *RefCounter) Increment(path string) int {
|
|
||||||
c.mu.Lock()
|
|
||||||
m := c.counts[path]
|
|
||||||
if m == nil {
|
|
||||||
m = &minfo{}
|
|
||||||
c.counts[path] = m
|
|
||||||
}
|
|
||||||
// if we are checking this path for the first time check to make sure
|
|
||||||
// if it was already mounted on the system and make sure we have a correct ref
|
|
||||||
// count if it is mounted as it is in use.
|
|
||||||
if !m.check {
|
|
||||||
m.check = true
|
|
||||||
if c.checker.IsMounted(path) {
|
|
||||||
m.count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
m.count++
|
|
||||||
c.mu.Unlock()
|
|
||||||
return m.count
|
|
||||||
}
|
|
||||||
|
|
||||||
// Decrement decreases the ref count for the given id and returns the current count
|
|
||||||
func (c *RefCounter) Decrement(path string) int {
|
|
||||||
c.mu.Lock()
|
|
||||||
m := c.counts[path]
|
|
||||||
if m == nil {
|
|
||||||
m = &minfo{}
|
|
||||||
c.counts[path] = m
|
|
||||||
}
|
|
||||||
// if we are checking this path for the first time check to make sure
|
|
||||||
// if it was already mounted on the system and make sure we have a correct ref
|
|
||||||
// count if it is mounted as it is in use.
|
|
||||||
if !m.check {
|
|
||||||
m.check = true
|
|
||||||
if c.checker.IsMounted(path) {
|
|
||||||
m.count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
m.count--
|
|
||||||
c.mu.Unlock()
|
|
||||||
return m.count
|
|
||||||
}
|
|
243
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver.go
generated
vendored
243
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver.go
generated
vendored
|
@ -1,243 +0,0 @@
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
"path/filepath"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
"github.com/Sirupsen/logrus"
|
|
||||||
"github.com/vbatts/tar-split/tar/storage"
|
|
||||||
|
|
||||||
"github.com/docker/docker/pkg/archive"
|
|
||||||
"github.com/docker/docker/pkg/idtools"
|
|
||||||
)
|
|
||||||
|
|
||||||
// FsMagic unsigned id of the filesystem in use.
|
|
||||||
type FsMagic uint32
|
|
||||||
|
|
||||||
const (
|
|
||||||
// FsMagicUnsupported is a predefined constant value other than a valid filesystem id.
|
|
||||||
FsMagicUnsupported = FsMagic(0x00000000)
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// All registered drivers
|
|
||||||
drivers map[string]InitFunc
|
|
||||||
|
|
||||||
// ErrNotSupported returned when driver is not supported.
|
|
||||||
ErrNotSupported = errors.New("driver not supported")
|
|
||||||
// ErrPrerequisites retuned when driver does not meet prerequisites.
|
|
||||||
ErrPrerequisites = errors.New("prerequisites for driver not satisfied (wrong filesystem?)")
|
|
||||||
// ErrIncompatibleFS returned when file system is not supported.
|
|
||||||
ErrIncompatibleFS = fmt.Errorf("backing file system is unsupported for this graph driver")
|
|
||||||
)
|
|
||||||
|
|
||||||
// InitFunc initializes the storage driver.
|
|
||||||
type InitFunc func(root string, options []string, uidMaps, gidMaps []idtools.IDMap) (Driver, error)
|
|
||||||
|
|
||||||
// ProtoDriver defines the basic capabilities of a driver.
|
|
||||||
// This interface exists solely to be a minimum set of methods
|
|
||||||
// for client code which choose not to implement the entire Driver
|
|
||||||
// interface and use the NaiveDiffDriver wrapper constructor.
|
|
||||||
//
|
|
||||||
// Use of ProtoDriver directly by client code is not recommended.
|
|
||||||
type ProtoDriver interface {
|
|
||||||
// String returns a string representation of this driver.
|
|
||||||
String() string
|
|
||||||
// CreateReadWrite creates a new, empty filesystem layer that is ready
|
|
||||||
// to be used as the storage for a container.
|
|
||||||
CreateReadWrite(id, parent, mountLabel string, storageOpt map[string]string) error
|
|
||||||
// Create creates a new, empty, filesystem layer with the
|
|
||||||
// specified id and parent and mountLabel. Parent and mountLabel may be "".
|
|
||||||
Create(id, parent, mountLabel string, storageOpt map[string]string) error
|
|
||||||
// Remove attempts to remove the filesystem layer with this id.
|
|
||||||
Remove(id string) error
|
|
||||||
// Get returns the mountpoint for the layered filesystem referred
|
|
||||||
// to by this id. You can optionally specify a mountLabel or "".
|
|
||||||
// Returns the absolute path to the mounted layered filesystem.
|
|
||||||
Get(id, mountLabel string) (dir string, err error)
|
|
||||||
// Put releases the system resources for the specified id,
|
|
||||||
// e.g, unmounting layered filesystem.
|
|
||||||
Put(id string) error
|
|
||||||
// Exists returns whether a filesystem layer with the specified
|
|
||||||
// ID exists on this driver.
|
|
||||||
Exists(id string) bool
|
|
||||||
// Status returns a set of key-value pairs which give low
|
|
||||||
// level diagnostic status about this driver.
|
|
||||||
Status() [][2]string
|
|
||||||
// Returns a set of key-value pairs which give low level information
|
|
||||||
// about the image/container driver is managing.
|
|
||||||
GetMetadata(id string) (map[string]string, error)
|
|
||||||
// Cleanup performs necessary tasks to release resources
|
|
||||||
// held by the driver, e.g., unmounting all layered filesystems
|
|
||||||
// known to this driver.
|
|
||||||
Cleanup() error
|
|
||||||
}
|
|
||||||
|
|
||||||
// Driver is the interface for layered/snapshot file system drivers.
|
|
||||||
type Driver interface {
|
|
||||||
ProtoDriver
|
|
||||||
// Diff produces an archive of the changes between the specified
|
|
||||||
// layer and its parent layer which may be "".
|
|
||||||
Diff(id, parent string) (archive.Archive, error)
|
|
||||||
// Changes produces a list of changes between the specified layer
|
|
||||||
// and its parent layer. If parent is "", then all changes will be ADD changes.
|
|
||||||
Changes(id, parent string) ([]archive.Change, error)
|
|
||||||
// ApplyDiff extracts the changeset from the given diff into the
|
|
||||||
// layer with the specified id and parent, returning the size of the
|
|
||||||
// new layer in bytes.
|
|
||||||
// The archive.Reader must be an uncompressed stream.
|
|
||||||
ApplyDiff(id, parent string, diff archive.Reader) (size int64, err error)
|
|
||||||
// DiffSize calculates the changes between the specified id
|
|
||||||
// and its parent and returns the size in bytes of the changes
|
|
||||||
// relative to its base filesystem directory.
|
|
||||||
DiffSize(id, parent string) (size int64, err error)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DiffGetterDriver is the interface for layered file system drivers that
|
|
||||||
// provide a specialized function for getting file contents for tar-split.
|
|
||||||
type DiffGetterDriver interface {
|
|
||||||
Driver
|
|
||||||
// DiffGetter returns an interface to efficiently retrieve the contents
|
|
||||||
// of files in a layer.
|
|
||||||
DiffGetter(id string) (FileGetCloser, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
// FileGetCloser extends the storage.FileGetter interface with a Close method
|
|
||||||
// for cleaning up.
|
|
||||||
type FileGetCloser interface {
|
|
||||||
storage.FileGetter
|
|
||||||
// Close cleans up any resources associated with the FileGetCloser.
|
|
||||||
Close() error
|
|
||||||
}
|
|
||||||
|
|
||||||
// Checker makes checks on specified filesystems.
|
|
||||||
type Checker interface {
|
|
||||||
// IsMounted returns true if the provided path is mounted for the specific checker
|
|
||||||
IsMounted(path string) bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
drivers = make(map[string]InitFunc)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Register registers an InitFunc for the driver.
|
|
||||||
func Register(name string, initFunc InitFunc) error {
|
|
||||||
if _, exists := drivers[name]; exists {
|
|
||||||
return fmt.Errorf("Name already registered %s", name)
|
|
||||||
}
|
|
||||||
drivers[name] = initFunc
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetDriver initializes and returns the registered driver
|
|
||||||
func GetDriver(name, home string, options []string, uidMaps, gidMaps []idtools.IDMap) (Driver, error) {
|
|
||||||
if initFunc, exists := drivers[name]; exists {
|
|
||||||
return initFunc(filepath.Join(home, name), options, uidMaps, gidMaps)
|
|
||||||
}
|
|
||||||
if pluginDriver, err := lookupPlugin(name, home, options); err == nil {
|
|
||||||
return pluginDriver, nil
|
|
||||||
}
|
|
||||||
logrus.Errorf("Failed to GetDriver graph %s %s", name, home)
|
|
||||||
return nil, ErrNotSupported
|
|
||||||
}
|
|
||||||
|
|
||||||
// getBuiltinDriver initializes and returns the registered driver, but does not try to load from plugins
|
|
||||||
func getBuiltinDriver(name, home string, options []string, uidMaps, gidMaps []idtools.IDMap) (Driver, error) {
|
|
||||||
if initFunc, exists := drivers[name]; exists {
|
|
||||||
return initFunc(filepath.Join(home, name), options, uidMaps, gidMaps)
|
|
||||||
}
|
|
||||||
logrus.Errorf("Failed to built-in GetDriver graph %s %s", name, home)
|
|
||||||
return nil, ErrNotSupported
|
|
||||||
}
|
|
||||||
|
|
||||||
// New creates the driver and initializes it at the specified root.
|
|
||||||
func New(root string, name string, options []string, uidMaps, gidMaps []idtools.IDMap) (Driver, error) {
|
|
||||||
if name != "" {
|
|
||||||
logrus.Debugf("[graphdriver] trying provided driver %q", name) // so the logs show specified driver
|
|
||||||
return GetDriver(name, root, options, uidMaps, gidMaps)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Guess for prior driver
|
|
||||||
driversMap := scanPriorDrivers(root)
|
|
||||||
for _, name := range priority {
|
|
||||||
if name == "vfs" {
|
|
||||||
// don't use vfs even if there is state present.
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if _, prior := driversMap[name]; prior {
|
|
||||||
// of the state found from prior drivers, check in order of our priority
|
|
||||||
// which we would prefer
|
|
||||||
driver, err := getBuiltinDriver(name, root, options, uidMaps, gidMaps)
|
|
||||||
if err != nil {
|
|
||||||
// unlike below, we will return error here, because there is prior
|
|
||||||
// state, and now it is no longer supported/prereq/compatible, so
|
|
||||||
// something changed and needs attention. Otherwise the daemon's
|
|
||||||
// images would just "disappear".
|
|
||||||
logrus.Errorf("[graphdriver] prior storage driver %q failed: %s", name, err)
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// abort starting when there are other prior configured drivers
|
|
||||||
// to ensure the user explicitly selects the driver to load
|
|
||||||
if len(driversMap)-1 > 0 {
|
|
||||||
var driversSlice []string
|
|
||||||
for name := range driversMap {
|
|
||||||
driversSlice = append(driversSlice, name)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil, fmt.Errorf("%q contains several valid graphdrivers: %s; Please cleanup or explicitly choose storage driver (-s <DRIVER>)", root, strings.Join(driversSlice, ", "))
|
|
||||||
}
|
|
||||||
|
|
||||||
logrus.Infof("[graphdriver] using prior storage driver %q", name)
|
|
||||||
return driver, nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check for priority drivers first
|
|
||||||
for _, name := range priority {
|
|
||||||
driver, err := getBuiltinDriver(name, root, options, uidMaps, gidMaps)
|
|
||||||
if err != nil {
|
|
||||||
if isDriverNotSupported(err) {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return driver, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check all registered drivers if no priority driver is found
|
|
||||||
for name, initFunc := range drivers {
|
|
||||||
driver, err := initFunc(filepath.Join(root, name), options, uidMaps, gidMaps)
|
|
||||||
if err != nil {
|
|
||||||
if isDriverNotSupported(err) {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return driver, nil
|
|
||||||
}
|
|
||||||
return nil, fmt.Errorf("No supported storage backend found")
|
|
||||||
}
|
|
||||||
|
|
||||||
// isDriverNotSupported returns true if the error initializing
|
|
||||||
// the graph driver is a non-supported error.
|
|
||||||
func isDriverNotSupported(err error) bool {
|
|
||||||
return err == ErrNotSupported || err == ErrPrerequisites || err == ErrIncompatibleFS
|
|
||||||
}
|
|
||||||
|
|
||||||
// scanPriorDrivers returns an un-ordered scan of directories of prior storage drivers
|
|
||||||
func scanPriorDrivers(root string) map[string]bool {
|
|
||||||
driversMap := make(map[string]bool)
|
|
||||||
|
|
||||||
for driver := range drivers {
|
|
||||||
p := filepath.Join(root, driver)
|
|
||||||
if _, err := os.Stat(p); err == nil && driver != "vfs" {
|
|
||||||
driversMap[driver] = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return driversMap
|
|
||||||
}
|
|
19
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_freebsd.go
generated
vendored
19
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_freebsd.go
generated
vendored
|
@ -1,19 +0,0 @@
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
import "syscall"
|
|
||||||
|
|
||||||
var (
|
|
||||||
// Slice of drivers that should be used in an order
|
|
||||||
priority = []string{
|
|
||||||
"zfs",
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
// Mounted checks if the given path is mounted as the fs type
|
|
||||||
func Mounted(fsType FsMagic, mountPath string) (bool, error) {
|
|
||||||
var buf syscall.Statfs_t
|
|
||||||
if err := syscall.Statfs(mountPath, &buf); err != nil {
|
|
||||||
return false, err
|
|
||||||
}
|
|
||||||
return FsMagic(buf.Type) == fsType, nil
|
|
||||||
}
|
|
133
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_linux.go
generated
vendored
133
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_linux.go
generated
vendored
|
@ -1,133 +0,0 @@
|
||||||
// +build linux
|
|
||||||
|
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
import (
|
|
||||||
"path/filepath"
|
|
||||||
"syscall"
|
|
||||||
|
|
||||||
"github.com/docker/docker/pkg/mount"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
// FsMagicAufs filesystem id for Aufs
|
|
||||||
FsMagicAufs = FsMagic(0x61756673)
|
|
||||||
// FsMagicBtrfs filesystem id for Btrfs
|
|
||||||
FsMagicBtrfs = FsMagic(0x9123683E)
|
|
||||||
// FsMagicCramfs filesystem id for Cramfs
|
|
||||||
FsMagicCramfs = FsMagic(0x28cd3d45)
|
|
||||||
// FsMagicEcryptfs filesystem id for eCryptfs
|
|
||||||
FsMagicEcryptfs = FsMagic(0xf15f)
|
|
||||||
// FsMagicExtfs filesystem id for Extfs
|
|
||||||
FsMagicExtfs = FsMagic(0x0000EF53)
|
|
||||||
// FsMagicF2fs filesystem id for F2fs
|
|
||||||
FsMagicF2fs = FsMagic(0xF2F52010)
|
|
||||||
// FsMagicGPFS filesystem id for GPFS
|
|
||||||
FsMagicGPFS = FsMagic(0x47504653)
|
|
||||||
// FsMagicJffs2Fs filesystem if for Jffs2Fs
|
|
||||||
FsMagicJffs2Fs = FsMagic(0x000072b6)
|
|
||||||
// FsMagicJfs filesystem id for Jfs
|
|
||||||
FsMagicJfs = FsMagic(0x3153464a)
|
|
||||||
// FsMagicNfsFs filesystem id for NfsFs
|
|
||||||
FsMagicNfsFs = FsMagic(0x00006969)
|
|
||||||
// FsMagicRAMFs filesystem id for RamFs
|
|
||||||
FsMagicRAMFs = FsMagic(0x858458f6)
|
|
||||||
// FsMagicReiserFs filesystem id for ReiserFs
|
|
||||||
FsMagicReiserFs = FsMagic(0x52654973)
|
|
||||||
// FsMagicSmbFs filesystem id for SmbFs
|
|
||||||
FsMagicSmbFs = FsMagic(0x0000517B)
|
|
||||||
// FsMagicSquashFs filesystem id for SquashFs
|
|
||||||
FsMagicSquashFs = FsMagic(0x73717368)
|
|
||||||
// FsMagicTmpFs filesystem id for TmpFs
|
|
||||||
FsMagicTmpFs = FsMagic(0x01021994)
|
|
||||||
// FsMagicVxFS filesystem id for VxFs
|
|
||||||
FsMagicVxFS = FsMagic(0xa501fcf5)
|
|
||||||
// FsMagicXfs filesystem id for Xfs
|
|
||||||
FsMagicXfs = FsMagic(0x58465342)
|
|
||||||
// FsMagicZfs filesystem id for Zfs
|
|
||||||
FsMagicZfs = FsMagic(0x2fc12fc1)
|
|
||||||
// FsMagicOverlay filesystem id for overlay
|
|
||||||
FsMagicOverlay = FsMagic(0x794C7630)
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// Slice of drivers that should be used in an order
|
|
||||||
priority = []string{
|
|
||||||
"aufs",
|
|
||||||
"btrfs",
|
|
||||||
"zfs",
|
|
||||||
"devicemapper",
|
|
||||||
"overlay",
|
|
||||||
"vfs",
|
|
||||||
}
|
|
||||||
|
|
||||||
// FsNames maps filesystem id to name of the filesystem.
|
|
||||||
FsNames = map[FsMagic]string{
|
|
||||||
FsMagicAufs: "aufs",
|
|
||||||
FsMagicBtrfs: "btrfs",
|
|
||||||
FsMagicCramfs: "cramfs",
|
|
||||||
FsMagicExtfs: "extfs",
|
|
||||||
FsMagicF2fs: "f2fs",
|
|
||||||
FsMagicGPFS: "gpfs",
|
|
||||||
FsMagicJffs2Fs: "jffs2",
|
|
||||||
FsMagicJfs: "jfs",
|
|
||||||
FsMagicNfsFs: "nfs",
|
|
||||||
FsMagicRAMFs: "ramfs",
|
|
||||||
FsMagicReiserFs: "reiserfs",
|
|
||||||
FsMagicSmbFs: "smb",
|
|
||||||
FsMagicSquashFs: "squashfs",
|
|
||||||
FsMagicTmpFs: "tmpfs",
|
|
||||||
FsMagicUnsupported: "unsupported",
|
|
||||||
FsMagicVxFS: "vxfs",
|
|
||||||
FsMagicXfs: "xfs",
|
|
||||||
FsMagicZfs: "zfs",
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
// GetFSMagic returns the filesystem id given the path.
|
|
||||||
func GetFSMagic(rootpath string) (FsMagic, error) {
|
|
||||||
var buf syscall.Statfs_t
|
|
||||||
if err := syscall.Statfs(filepath.Dir(rootpath), &buf); err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return FsMagic(buf.Type), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewFsChecker returns a checker configured for the provied FsMagic
|
|
||||||
func NewFsChecker(t FsMagic) Checker {
|
|
||||||
return &fsChecker{
|
|
||||||
t: t,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
type fsChecker struct {
|
|
||||||
t FsMagic
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *fsChecker) IsMounted(path string) bool {
|
|
||||||
m, _ := Mounted(c.t, path)
|
|
||||||
return m
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewDefaultChecker returns a check that parses /proc/mountinfo to check
|
|
||||||
// if the specified path is mounted.
|
|
||||||
func NewDefaultChecker() Checker {
|
|
||||||
return &defaultChecker{}
|
|
||||||
}
|
|
||||||
|
|
||||||
type defaultChecker struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *defaultChecker) IsMounted(path string) bool {
|
|
||||||
m, _ := mount.Mounted(path)
|
|
||||||
return m
|
|
||||||
}
|
|
||||||
|
|
||||||
// Mounted checks if the given path is mounted as the fs type
|
|
||||||
func Mounted(fsType FsMagic, mountPath string) (bool, error) {
|
|
||||||
var buf syscall.Statfs_t
|
|
||||||
if err := syscall.Statfs(mountPath, &buf); err != nil {
|
|
||||||
return false, err
|
|
||||||
}
|
|
||||||
return FsMagic(buf.Type) == fsType, nil
|
|
||||||
}
|
|
65
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_solaris.go
generated
vendored
65
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_solaris.go
generated
vendored
|
@ -1,65 +0,0 @@
|
||||||
// +build solaris,cgo
|
|
||||||
|
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
/*
|
|
||||||
#include <sys/statvfs.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
static inline struct statvfs *getstatfs(char *s) {
|
|
||||||
struct statvfs *buf;
|
|
||||||
int err;
|
|
||||||
buf = (struct statvfs *)malloc(sizeof(struct statvfs));
|
|
||||||
err = statvfs(s, buf);
|
|
||||||
return buf;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
import "C"
|
|
||||||
import (
|
|
||||||
"path/filepath"
|
|
||||||
"unsafe"
|
|
||||||
|
|
||||||
log "github.com/Sirupsen/logrus"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
// FsMagicZfs filesystem id for Zfs
|
|
||||||
FsMagicZfs = FsMagic(0x2fc12fc1)
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// Slice of drivers that should be used in an order
|
|
||||||
priority = []string{
|
|
||||||
"zfs",
|
|
||||||
}
|
|
||||||
|
|
||||||
// FsNames maps filesystem id to name of the filesystem.
|
|
||||||
FsNames = map[FsMagic]string{
|
|
||||||
FsMagicZfs: "zfs",
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
// GetFSMagic returns the filesystem id given the path.
|
|
||||||
func GetFSMagic(rootpath string) (FsMagic, error) {
|
|
||||||
return 0, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Mounted checks if the given path is mounted as the fs type
|
|
||||||
//Solaris supports only ZFS for now
|
|
||||||
func Mounted(fsType FsMagic, mountPath string) (bool, error) {
|
|
||||||
|
|
||||||
cs := C.CString(filepath.Dir(mountPath))
|
|
||||||
buf := C.getstatfs(cs)
|
|
||||||
|
|
||||||
// on Solaris buf.f_basetype contains ['z', 'f', 's', 0 ... ]
|
|
||||||
if (buf.f_basetype[0] != 122) || (buf.f_basetype[1] != 102) || (buf.f_basetype[2] != 115) ||
|
|
||||||
(buf.f_basetype[3] != 0) {
|
|
||||||
log.Debugf("[zfs] no zfs dataset found for rootdir '%s'", mountPath)
|
|
||||||
C.free(unsafe.Pointer(buf))
|
|
||||||
return false, ErrPrerequisites
|
|
||||||
}
|
|
||||||
|
|
||||||
C.free(unsafe.Pointer(buf))
|
|
||||||
C.free(unsafe.Pointer(cs))
|
|
||||||
return true, nil
|
|
||||||
}
|
|
15
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_unsupported.go
generated
vendored
15
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_unsupported.go
generated
vendored
|
@ -1,15 +0,0 @@
|
||||||
// +build !linux,!windows,!freebsd,!solaris
|
|
||||||
|
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
var (
|
|
||||||
// Slice of drivers that should be used in an order
|
|
||||||
priority = []string{
|
|
||||||
"unsupported",
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
// GetFSMagic returns the filesystem id given the path.
|
|
||||||
func GetFSMagic(rootpath string) (FsMagic, error) {
|
|
||||||
return FsMagicUnsupported, nil
|
|
||||||
}
|
|
14
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_windows.go
generated
vendored
14
integration/vendor/github.com/docker/docker/daemon/graphdriver/driver_windows.go
generated
vendored
|
@ -1,14 +0,0 @@
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
var (
|
|
||||||
// Slice of drivers that should be used in order
|
|
||||||
priority = []string{
|
|
||||||
"windowsfilter",
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
// GetFSMagic returns the filesystem id given the path.
|
|
||||||
func GetFSMagic(rootpath string) (FsMagic, error) {
|
|
||||||
// Note it is OK to return FsMagicUnsupported on Windows.
|
|
||||||
return FsMagicUnsupported, nil
|
|
||||||
}
|
|
162
integration/vendor/github.com/docker/docker/daemon/graphdriver/fsdiff.go
generated
vendored
162
integration/vendor/github.com/docker/docker/daemon/graphdriver/fsdiff.go
generated
vendored
|
@ -1,162 +0,0 @@
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
import (
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/Sirupsen/logrus"
|
|
||||||
|
|
||||||
"github.com/docker/docker/pkg/archive"
|
|
||||||
"github.com/docker/docker/pkg/chrootarchive"
|
|
||||||
"github.com/docker/docker/pkg/idtools"
|
|
||||||
"github.com/docker/docker/pkg/ioutils"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// ApplyUncompressedLayer defines the unpack method used by the graph
|
|
||||||
// driver.
|
|
||||||
ApplyUncompressedLayer = chrootarchive.ApplyUncompressedLayer
|
|
||||||
)
|
|
||||||
|
|
||||||
// NaiveDiffDriver takes a ProtoDriver and adds the
|
|
||||||
// capability of the Diffing methods which it may or may not
|
|
||||||
// support on its own. See the comment on the exported
|
|
||||||
// NewNaiveDiffDriver function below.
|
|
||||||
// Notably, the AUFS driver doesn't need to be wrapped like this.
|
|
||||||
type NaiveDiffDriver struct {
|
|
||||||
ProtoDriver
|
|
||||||
uidMaps []idtools.IDMap
|
|
||||||
gidMaps []idtools.IDMap
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewNaiveDiffDriver returns a fully functional driver that wraps the
|
|
||||||
// given ProtoDriver and adds the capability of the following methods which
|
|
||||||
// it may or may not support on its own:
|
|
||||||
// Diff(id, parent string) (archive.Archive, error)
|
|
||||||
// Changes(id, parent string) ([]archive.Change, error)
|
|
||||||
// ApplyDiff(id, parent string, diff archive.Reader) (size int64, err error)
|
|
||||||
// DiffSize(id, parent string) (size int64, err error)
|
|
||||||
func NewNaiveDiffDriver(driver ProtoDriver, uidMaps, gidMaps []idtools.IDMap) Driver {
|
|
||||||
return &NaiveDiffDriver{ProtoDriver: driver,
|
|
||||||
uidMaps: uidMaps,
|
|
||||||
gidMaps: gidMaps}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Diff produces an archive of the changes between the specified
|
|
||||||
// layer and its parent layer which may be "".
|
|
||||||
func (gdw *NaiveDiffDriver) Diff(id, parent string) (arch archive.Archive, err error) {
|
|
||||||
driver := gdw.ProtoDriver
|
|
||||||
|
|
||||||
layerFs, err := driver.Get(id, "")
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
defer func() {
|
|
||||||
if err != nil {
|
|
||||||
driver.Put(id)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
if parent == "" {
|
|
||||||
archive, err := archive.Tar(layerFs, archive.Uncompressed)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return ioutils.NewReadCloserWrapper(archive, func() error {
|
|
||||||
err := archive.Close()
|
|
||||||
driver.Put(id)
|
|
||||||
return err
|
|
||||||
}), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
parentFs, err := driver.Get(parent, "")
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
defer driver.Put(parent)
|
|
||||||
|
|
||||||
changes, err := archive.ChangesDirs(layerFs, parentFs)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
archive, err := archive.ExportChanges(layerFs, changes, gdw.uidMaps, gdw.gidMaps)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return ioutils.NewReadCloserWrapper(archive, func() error {
|
|
||||||
err := archive.Close()
|
|
||||||
driver.Put(id)
|
|
||||||
return err
|
|
||||||
}), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Changes produces a list of changes between the specified layer
|
|
||||||
// and its parent layer. If parent is "", then all changes will be ADD changes.
|
|
||||||
func (gdw *NaiveDiffDriver) Changes(id, parent string) ([]archive.Change, error) {
|
|
||||||
driver := gdw.ProtoDriver
|
|
||||||
|
|
||||||
layerFs, err := driver.Get(id, "")
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
defer driver.Put(id)
|
|
||||||
|
|
||||||
parentFs := ""
|
|
||||||
|
|
||||||
if parent != "" {
|
|
||||||
parentFs, err = driver.Get(parent, "")
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
defer driver.Put(parent)
|
|
||||||
}
|
|
||||||
|
|
||||||
return archive.ChangesDirs(layerFs, parentFs)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ApplyDiff extracts the changeset from the given diff into the
|
|
||||||
// layer with the specified id and parent, returning the size of the
|
|
||||||
// new layer in bytes.
|
|
||||||
func (gdw *NaiveDiffDriver) ApplyDiff(id, parent string, diff archive.Reader) (size int64, err error) {
|
|
||||||
driver := gdw.ProtoDriver
|
|
||||||
|
|
||||||
// Mount the root filesystem so we can apply the diff/layer.
|
|
||||||
layerFs, err := driver.Get(id, "")
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
defer driver.Put(id)
|
|
||||||
|
|
||||||
options := &archive.TarOptions{UIDMaps: gdw.uidMaps,
|
|
||||||
GIDMaps: gdw.gidMaps}
|
|
||||||
start := time.Now().UTC()
|
|
||||||
logrus.Debug("Start untar layer")
|
|
||||||
if size, err = ApplyUncompressedLayer(layerFs, diff, options); err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
logrus.Debugf("Untar time: %vs", time.Now().UTC().Sub(start).Seconds())
|
|
||||||
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// DiffSize calculates the changes between the specified layer
|
|
||||||
// and its parent and returns the size in bytes of the changes
|
|
||||||
// relative to its base filesystem directory.
|
|
||||||
func (gdw *NaiveDiffDriver) DiffSize(id, parent string) (size int64, err error) {
|
|
||||||
driver := gdw.ProtoDriver
|
|
||||||
|
|
||||||
changes, err := gdw.Changes(id, parent)
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
layerFs, err := driver.Get(id, "")
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
defer driver.Put(id)
|
|
||||||
|
|
||||||
return archive.ChangesSize(layerFs, changes), nil
|
|
||||||
}
|
|
32
integration/vendor/github.com/docker/docker/daemon/graphdriver/plugin.go
generated
vendored
32
integration/vendor/github.com/docker/docker/daemon/graphdriver/plugin.go
generated
vendored
|
@ -1,32 +0,0 @@
|
||||||
// +build experimental
|
|
||||||
|
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
|
|
||||||
"github.com/docker/docker/pkg/plugins"
|
|
||||||
)
|
|
||||||
|
|
||||||
type pluginClient interface {
|
|
||||||
// Call calls the specified method with the specified arguments for the plugin.
|
|
||||||
Call(string, interface{}, interface{}) error
|
|
||||||
// Stream calls the specified method with the specified arguments for the plugin and returns the response IO stream
|
|
||||||
Stream(string, interface{}) (io.ReadCloser, error)
|
|
||||||
// SendFile calls the specified method, and passes through the IO stream
|
|
||||||
SendFile(string, io.Reader, interface{}) error
|
|
||||||
}
|
|
||||||
|
|
||||||
func lookupPlugin(name, home string, opts []string) (Driver, error) {
|
|
||||||
pl, err := plugins.Get(name, "GraphDriver")
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("Error looking up graphdriver plugin %s: %v", name, err)
|
|
||||||
}
|
|
||||||
return newPluginDriver(name, home, opts, pl.Client())
|
|
||||||
}
|
|
||||||
|
|
||||||
func newPluginDriver(name, home string, opts []string, c pluginClient) (Driver, error) {
|
|
||||||
proxy := &graphDriverProxy{name, c}
|
|
||||||
return proxy, proxy.Init(home, opts)
|
|
||||||
}
|
|
7
integration/vendor/github.com/docker/docker/daemon/graphdriver/plugin_unsupported.go
generated
vendored
7
integration/vendor/github.com/docker/docker/daemon/graphdriver/plugin_unsupported.go
generated
vendored
|
@ -1,7 +0,0 @@
|
||||||
// +build !experimental
|
|
||||||
|
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
func lookupPlugin(name, home string, opts []string) (Driver, error) {
|
|
||||||
return nil, ErrNotSupported
|
|
||||||
}
|
|
225
integration/vendor/github.com/docker/docker/daemon/graphdriver/proxy.go
generated
vendored
225
integration/vendor/github.com/docker/docker/daemon/graphdriver/proxy.go
generated
vendored
|
@ -1,225 +0,0 @@
|
||||||
// +build experimental
|
|
||||||
|
|
||||||
package graphdriver
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
|
|
||||||
"github.com/docker/docker/pkg/archive"
|
|
||||||
)
|
|
||||||
|
|
||||||
type graphDriverProxy struct {
|
|
||||||
name string
|
|
||||||
client pluginClient
|
|
||||||
}
|
|
||||||
|
|
||||||
type graphDriverRequest struct {
|
|
||||||
ID string `json:",omitempty"`
|
|
||||||
Parent string `json:",omitempty"`
|
|
||||||
MountLabel string `json:",omitempty"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type graphDriverResponse struct {
|
|
||||||
Err string `json:",omitempty"`
|
|
||||||
Dir string `json:",omitempty"`
|
|
||||||
Exists bool `json:",omitempty"`
|
|
||||||
Status [][2]string `json:",omitempty"`
|
|
||||||
Changes []archive.Change `json:",omitempty"`
|
|
||||||
Size int64 `json:",omitempty"`
|
|
||||||
Metadata map[string]string `json:",omitempty"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type graphDriverInitRequest struct {
|
|
||||||
Home string
|
|
||||||
Opts []string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Init(home string, opts []string) error {
|
|
||||||
args := &graphDriverInitRequest{
|
|
||||||
Home: home,
|
|
||||||
Opts: opts,
|
|
||||||
}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.Init", args, &ret); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) String() string {
|
|
||||||
return d.name
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) CreateReadWrite(id, parent, mountLabel string, storageOpt map[string]string) error {
|
|
||||||
args := &graphDriverRequest{
|
|
||||||
ID: id,
|
|
||||||
Parent: parent,
|
|
||||||
MountLabel: mountLabel,
|
|
||||||
}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.CreateReadWrite", args, &ret); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Create(id, parent, mountLabel string, storageOpt map[string]string) error {
|
|
||||||
args := &graphDriverRequest{
|
|
||||||
ID: id,
|
|
||||||
Parent: parent,
|
|
||||||
MountLabel: mountLabel,
|
|
||||||
}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.Create", args, &ret); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Remove(id string) error {
|
|
||||||
args := &graphDriverRequest{ID: id}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.Remove", args, &ret); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Get(id, mountLabel string) (string, error) {
|
|
||||||
args := &graphDriverRequest{
|
|
||||||
ID: id,
|
|
||||||
MountLabel: mountLabel,
|
|
||||||
}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.Get", args, &ret); err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
var err error
|
|
||||||
if ret.Err != "" {
|
|
||||||
err = errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return ret.Dir, err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Put(id string) error {
|
|
||||||
args := &graphDriverRequest{ID: id}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.Put", args, &ret); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Exists(id string) bool {
|
|
||||||
args := &graphDriverRequest{ID: id}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.Exists", args, &ret); err != nil {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
return ret.Exists
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Status() [][2]string {
|
|
||||||
args := &graphDriverRequest{}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.Status", args, &ret); err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
return ret.Status
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) GetMetadata(id string) (map[string]string, error) {
|
|
||||||
args := &graphDriverRequest{
|
|
||||||
ID: id,
|
|
||||||
}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.GetMetadata", args, &ret); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return nil, errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return ret.Metadata, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Cleanup() error {
|
|
||||||
args := &graphDriverRequest{}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.Cleanup", args, &ret); err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Diff(id, parent string) (archive.Archive, error) {
|
|
||||||
args := &graphDriverRequest{
|
|
||||||
ID: id,
|
|
||||||
Parent: parent,
|
|
||||||
}
|
|
||||||
body, err := d.client.Stream("GraphDriver.Diff", args)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return archive.Archive(body), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) Changes(id, parent string) ([]archive.Change, error) {
|
|
||||||
args := &graphDriverRequest{
|
|
||||||
ID: id,
|
|
||||||
Parent: parent,
|
|
||||||
}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.Changes", args, &ret); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return nil, errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret.Changes, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) ApplyDiff(id, parent string, diff archive.Reader) (int64, error) {
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.SendFile(fmt.Sprintf("GraphDriver.ApplyDiff?id=%s&parent=%s", id, parent), diff, &ret); err != nil {
|
|
||||||
return -1, err
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return -1, errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return ret.Size, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *graphDriverProxy) DiffSize(id, parent string) (int64, error) {
|
|
||||||
args := &graphDriverRequest{
|
|
||||||
ID: id,
|
|
||||||
Parent: parent,
|
|
||||||
}
|
|
||||||
var ret graphDriverResponse
|
|
||||||
if err := d.client.Call("GraphDriver.DiffSize", args, &ret); err != nil {
|
|
||||||
return -1, err
|
|
||||||
}
|
|
||||||
if ret.Err != "" {
|
|
||||||
return -1, errors.New(ret.Err)
|
|
||||||
}
|
|
||||||
return ret.Size, nil
|
|
||||||
}
|
|
175
integration/vendor/github.com/docker/docker/image/fs.go
generated
vendored
175
integration/vendor/github.com/docker/docker/image/fs.go
generated
vendored
|
@ -1,175 +0,0 @@
|
||||||
package image
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
|
||||||
"path/filepath"
|
|
||||||
"sync"
|
|
||||||
|
|
||||||
"github.com/Sirupsen/logrus"
|
|
||||||
"github.com/docker/distribution/digest"
|
|
||||||
"github.com/docker/docker/pkg/ioutils"
|
|
||||||
)
|
|
||||||
|
|
||||||
// IDWalkFunc is function called by StoreBackend.Walk
|
|
||||||
type IDWalkFunc func(id ID) error
|
|
||||||
|
|
||||||
// StoreBackend provides interface for image.Store persistence
|
|
||||||
type StoreBackend interface {
|
|
||||||
Walk(f IDWalkFunc) error
|
|
||||||
Get(id ID) ([]byte, error)
|
|
||||||
Set(data []byte) (ID, error)
|
|
||||||
Delete(id ID) error
|
|
||||||
SetMetadata(id ID, key string, data []byte) error
|
|
||||||
GetMetadata(id ID, key string) ([]byte, error)
|
|
||||||
DeleteMetadata(id ID, key string) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// fs implements StoreBackend using the filesystem.
|
|
||||||
type fs struct {
|
|
||||||
sync.RWMutex
|
|
||||||
root string
|
|
||||||
}
|
|
||||||
|
|
||||||
const (
|
|
||||||
contentDirName = "content"
|
|
||||||
metadataDirName = "metadata"
|
|
||||||
)
|
|
||||||
|
|
||||||
// NewFSStoreBackend returns new filesystem based backend for image.Store
|
|
||||||
func NewFSStoreBackend(root string) (StoreBackend, error) {
|
|
||||||
return newFSStore(root)
|
|
||||||
}
|
|
||||||
|
|
||||||
func newFSStore(root string) (*fs, error) {
|
|
||||||
s := &fs{
|
|
||||||
root: root,
|
|
||||||
}
|
|
||||||
if err := os.MkdirAll(filepath.Join(root, contentDirName, string(digest.Canonical)), 0700); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if err := os.MkdirAll(filepath.Join(root, metadataDirName, string(digest.Canonical)), 0700); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return s, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *fs) contentFile(id ID) string {
|
|
||||||
dgst := digest.Digest(id)
|
|
||||||
return filepath.Join(s.root, contentDirName, string(dgst.Algorithm()), dgst.Hex())
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *fs) metadataDir(id ID) string {
|
|
||||||
dgst := digest.Digest(id)
|
|
||||||
return filepath.Join(s.root, metadataDirName, string(dgst.Algorithm()), dgst.Hex())
|
|
||||||
}
|
|
||||||
|
|
||||||
// Walk calls the supplied callback for each image ID in the storage backend.
|
|
||||||
func (s *fs) Walk(f IDWalkFunc) error {
|
|
||||||
// Only Canonical digest (sha256) is currently supported
|
|
||||||
s.RLock()
|
|
||||||
dir, err := ioutil.ReadDir(filepath.Join(s.root, contentDirName, string(digest.Canonical)))
|
|
||||||
s.RUnlock()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
for _, v := range dir {
|
|
||||||
dgst := digest.NewDigestFromHex(string(digest.Canonical), v.Name())
|
|
||||||
if err := dgst.Validate(); err != nil {
|
|
||||||
logrus.Debugf("Skipping invalid digest %s: %s", dgst, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if err := f(ID(dgst)); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get returns the content stored under a given ID.
|
|
||||||
func (s *fs) Get(id ID) ([]byte, error) {
|
|
||||||
s.RLock()
|
|
||||||
defer s.RUnlock()
|
|
||||||
|
|
||||||
return s.get(id)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *fs) get(id ID) ([]byte, error) {
|
|
||||||
content, err := ioutil.ReadFile(s.contentFile(id))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// todo: maybe optional
|
|
||||||
if ID(digest.FromBytes(content)) != id {
|
|
||||||
return nil, fmt.Errorf("failed to verify image: %v", id)
|
|
||||||
}
|
|
||||||
|
|
||||||
return content, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set stores content under a given ID.
|
|
||||||
func (s *fs) Set(data []byte) (ID, error) {
|
|
||||||
s.Lock()
|
|
||||||
defer s.Unlock()
|
|
||||||
|
|
||||||
if len(data) == 0 {
|
|
||||||
return "", fmt.Errorf("Invalid empty data")
|
|
||||||
}
|
|
||||||
|
|
||||||
id := ID(digest.FromBytes(data))
|
|
||||||
if err := ioutils.AtomicWriteFile(s.contentFile(id), data, 0600); err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
return id, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Delete removes content and metadata files associated with the ID.
|
|
||||||
func (s *fs) Delete(id ID) error {
|
|
||||||
s.Lock()
|
|
||||||
defer s.Unlock()
|
|
||||||
|
|
||||||
if err := os.RemoveAll(s.metadataDir(id)); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if err := os.Remove(s.contentFile(id)); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// SetMetadata sets metadata for a given ID. It fails if there's no base file.
|
|
||||||
func (s *fs) SetMetadata(id ID, key string, data []byte) error {
|
|
||||||
s.Lock()
|
|
||||||
defer s.Unlock()
|
|
||||||
if _, err := s.get(id); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
baseDir := filepath.Join(s.metadataDir(id))
|
|
||||||
if err := os.MkdirAll(baseDir, 0700); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return ioutils.AtomicWriteFile(filepath.Join(s.metadataDir(id), key), data, 0600)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetMetadata returns metadata for a given ID.
|
|
||||||
func (s *fs) GetMetadata(id ID, key string) ([]byte, error) {
|
|
||||||
s.RLock()
|
|
||||||
defer s.RUnlock()
|
|
||||||
|
|
||||||
if _, err := s.get(id); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return ioutil.ReadFile(filepath.Join(s.metadataDir(id), key))
|
|
||||||
}
|
|
||||||
|
|
||||||
// DeleteMetadata removes the metadata associated with an ID.
|
|
||||||
func (s *fs) DeleteMetadata(id ID, key string) error {
|
|
||||||
s.Lock()
|
|
||||||
defer s.Unlock()
|
|
||||||
|
|
||||||
return os.RemoveAll(filepath.Join(s.metadataDir(id), key))
|
|
||||||
}
|
|
140
integration/vendor/github.com/docker/docker/image/image.go
generated
vendored
140
integration/vendor/github.com/docker/docker/image/image.go
generated
vendored
|
@ -1,140 +0,0 @@
|
||||||
package image
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/json"
|
|
||||||
"errors"
|
|
||||||
"io"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/docker/distribution/digest"
|
|
||||||
"github.com/docker/engine-api/types/container"
|
|
||||||
)
|
|
||||||
|
|
||||||
// ID is the content-addressable ID of an image.
|
|
||||||
type ID digest.Digest
|
|
||||||
|
|
||||||
func (id ID) String() string {
|
|
||||||
return digest.Digest(id).String()
|
|
||||||
}
|
|
||||||
|
|
||||||
// V1Image stores the V1 image configuration.
|
|
||||||
type V1Image struct {
|
|
||||||
// ID a unique 64 character identifier of the image
|
|
||||||
ID string `json:"id,omitempty"`
|
|
||||||
// Parent id of the image
|
|
||||||
Parent string `json:"parent,omitempty"`
|
|
||||||
// Comment user added comment
|
|
||||||
Comment string `json:"comment,omitempty"`
|
|
||||||
// Created timestamp when image was created
|
|
||||||
Created time.Time `json:"created"`
|
|
||||||
// Container is the id of the container used to commit
|
|
||||||
Container string `json:"container,omitempty"`
|
|
||||||
// ContainerConfig is the configuration of the container that is committed into the image
|
|
||||||
ContainerConfig container.Config `json:"container_config,omitempty"`
|
|
||||||
// DockerVersion specifies version on which image is built
|
|
||||||
DockerVersion string `json:"docker_version,omitempty"`
|
|
||||||
// Author of the image
|
|
||||||
Author string `json:"author,omitempty"`
|
|
||||||
// Config is the configuration of the container received from the client
|
|
||||||
Config *container.Config `json:"config,omitempty"`
|
|
||||||
// Architecture is the hardware that the image is build and runs on
|
|
||||||
Architecture string `json:"architecture,omitempty"`
|
|
||||||
// OS is the operating system used to build and run the image
|
|
||||||
OS string `json:"os,omitempty"`
|
|
||||||
// Size is the total size of the image including all layers it is composed of
|
|
||||||
Size int64 `json:",omitempty"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// Image stores the image configuration
|
|
||||||
type Image struct {
|
|
||||||
V1Image
|
|
||||||
Parent ID `json:"parent,omitempty"`
|
|
||||||
RootFS *RootFS `json:"rootfs,omitempty"`
|
|
||||||
History []History `json:"history,omitempty"`
|
|
||||||
OSVersion string `json:"os.version,omitempty"`
|
|
||||||
OSFeatures []string `json:"os.features,omitempty"`
|
|
||||||
|
|
||||||
// rawJSON caches the immutable JSON associated with this image.
|
|
||||||
rawJSON []byte
|
|
||||||
|
|
||||||
// computedID is the ID computed from the hash of the image config.
|
|
||||||
// Not to be confused with the legacy V1 ID in V1Image.
|
|
||||||
computedID ID
|
|
||||||
}
|
|
||||||
|
|
||||||
// RawJSON returns the immutable JSON associated with the image.
|
|
||||||
func (img *Image) RawJSON() []byte {
|
|
||||||
return img.rawJSON
|
|
||||||
}
|
|
||||||
|
|
||||||
// ID returns the image's content-addressable ID.
|
|
||||||
func (img *Image) ID() ID {
|
|
||||||
return img.computedID
|
|
||||||
}
|
|
||||||
|
|
||||||
// ImageID stringizes ID.
|
|
||||||
func (img *Image) ImageID() string {
|
|
||||||
return string(img.ID())
|
|
||||||
}
|
|
||||||
|
|
||||||
// RunConfig returns the image's container config.
|
|
||||||
func (img *Image) RunConfig() *container.Config {
|
|
||||||
return img.Config
|
|
||||||
}
|
|
||||||
|
|
||||||
// MarshalJSON serializes the image to JSON. It sorts the top-level keys so
|
|
||||||
// that JSON that's been manipulated by a push/pull cycle with a legacy
|
|
||||||
// registry won't end up with a different key order.
|
|
||||||
func (img *Image) MarshalJSON() ([]byte, error) {
|
|
||||||
type MarshalImage Image
|
|
||||||
|
|
||||||
pass1, err := json.Marshal(MarshalImage(*img))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
var c map[string]*json.RawMessage
|
|
||||||
if err := json.Unmarshal(pass1, &c); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return json.Marshal(c)
|
|
||||||
}
|
|
||||||
|
|
||||||
// History stores build commands that were used to create an image
|
|
||||||
type History struct {
|
|
||||||
// Created timestamp for build point
|
|
||||||
Created time.Time `json:"created"`
|
|
||||||
// Author of the build point
|
|
||||||
Author string `json:"author,omitempty"`
|
|
||||||
// CreatedBy keeps the Dockerfile command used while building image.
|
|
||||||
CreatedBy string `json:"created_by,omitempty"`
|
|
||||||
// Comment is custom message set by the user when creating the image.
|
|
||||||
Comment string `json:"comment,omitempty"`
|
|
||||||
// EmptyLayer is set to true if this history item did not generate a
|
|
||||||
// layer. Otherwise, the history item is associated with the next
|
|
||||||
// layer in the RootFS section.
|
|
||||||
EmptyLayer bool `json:"empty_layer,omitempty"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// Exporter provides interface for exporting and importing images
|
|
||||||
type Exporter interface {
|
|
||||||
Load(io.ReadCloser, io.Writer, bool) error
|
|
||||||
// TODO: Load(net.Context, io.ReadCloser, <- chan StatusMessage) error
|
|
||||||
Save([]string, io.Writer) error
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewFromJSON creates an Image configuration from json.
|
|
||||||
func NewFromJSON(src []byte) (*Image, error) {
|
|
||||||
img := &Image{}
|
|
||||||
|
|
||||||
if err := json.Unmarshal(src, img); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if img.RootFS == nil {
|
|
||||||
return nil, errors.New("Invalid image JSON, no RootFS key.")
|
|
||||||
}
|
|
||||||
|
|
||||||
img.rawJSON = src
|
|
||||||
|
|
||||||
return img, nil
|
|
||||||
}
|
|
16
integration/vendor/github.com/docker/docker/image/rootfs.go
generated
vendored
16
integration/vendor/github.com/docker/docker/image/rootfs.go
generated
vendored
|
@ -1,16 +0,0 @@
|
||||||
package image
|
|
||||||
|
|
||||||
import "github.com/docker/docker/layer"
|
|
||||||
|
|
||||||
// TypeLayers is used for RootFS.Type for filesystems organized into layers.
|
|
||||||
const TypeLayers = "layers"
|
|
||||||
|
|
||||||
// NewRootFS returns empty RootFS struct
|
|
||||||
func NewRootFS() *RootFS {
|
|
||||||
return &RootFS{Type: TypeLayers}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Append appends a new diffID to rootfs
|
|
||||||
func (r *RootFS) Append(id layer.DiffID) {
|
|
||||||
r.DiffIDs = append(r.DiffIDs, id)
|
|
||||||
}
|
|
18
integration/vendor/github.com/docker/docker/image/rootfs_unix.go
generated
vendored
18
integration/vendor/github.com/docker/docker/image/rootfs_unix.go
generated
vendored
|
@ -1,18 +0,0 @@
|
||||||
// +build !windows
|
|
||||||
|
|
||||||
package image
|
|
||||||
|
|
||||||
import "github.com/docker/docker/layer"
|
|
||||||
|
|
||||||
// RootFS describes images root filesystem
|
|
||||||
// This is currently a placeholder that only supports layers. In the future
|
|
||||||
// this can be made into an interface that supports different implementations.
|
|
||||||
type RootFS struct {
|
|
||||||
Type string `json:"type"`
|
|
||||||
DiffIDs []layer.DiffID `json:"diff_ids,omitempty"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// ChainID returns the ChainID for the top layer in RootFS.
|
|
||||||
func (r *RootFS) ChainID() layer.ChainID {
|
|
||||||
return layer.CreateChainID(r.DiffIDs)
|
|
||||||
}
|
|
48
integration/vendor/github.com/docker/docker/image/rootfs_windows.go
generated
vendored
48
integration/vendor/github.com/docker/docker/image/rootfs_windows.go
generated
vendored
|
@ -1,48 +0,0 @@
|
||||||
// +build windows
|
|
||||||
|
|
||||||
package image
|
|
||||||
|
|
||||||
import (
|
|
||||||
"crypto/sha512"
|
|
||||||
"fmt"
|
|
||||||
|
|
||||||
"github.com/docker/distribution/digest"
|
|
||||||
"github.com/docker/docker/layer"
|
|
||||||
)
|
|
||||||
|
|
||||||
// TypeLayersWithBase is used for RootFS.Type for Windows filesystems that have layers and a centrally-stored base layer.
|
|
||||||
const TypeLayersWithBase = "layers+base"
|
|
||||||
|
|
||||||
// RootFS describes images root filesystem
|
|
||||||
// This is currently a placeholder that only supports layers. In the future
|
|
||||||
// this can be made into an interface that supports different implementations.
|
|
||||||
type RootFS struct {
|
|
||||||
Type string `json:"type"`
|
|
||||||
DiffIDs []layer.DiffID `json:"diff_ids,omitempty"`
|
|
||||||
BaseLayer string `json:"base_layer,omitempty"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// BaseLayerID returns the 64 byte hex ID for the baselayer name.
|
|
||||||
func (r *RootFS) BaseLayerID() string {
|
|
||||||
if r.Type != TypeLayersWithBase {
|
|
||||||
panic("tried to get base layer ID without a base layer")
|
|
||||||
}
|
|
||||||
baseID := sha512.Sum384([]byte(r.BaseLayer))
|
|
||||||
return fmt.Sprintf("%x", baseID[:32])
|
|
||||||
}
|
|
||||||
|
|
||||||
// ChainID returns the ChainID for the top layer in RootFS.
|
|
||||||
func (r *RootFS) ChainID() layer.ChainID {
|
|
||||||
ids := r.DiffIDs
|
|
||||||
if r.Type == TypeLayersWithBase {
|
|
||||||
// Add an extra ID for the base.
|
|
||||||
baseDiffID := layer.DiffID(digest.FromBytes([]byte(r.BaseLayerID())))
|
|
||||||
ids = append([]layer.DiffID{baseDiffID}, ids...)
|
|
||||||
}
|
|
||||||
return layer.CreateChainID(ids)
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewRootFSWithBaseLayer returns a RootFS struct with a base layer
|
|
||||||
func NewRootFSWithBaseLayer(baseLayer string) *RootFS {
|
|
||||||
return &RootFS{Type: TypeLayersWithBase, BaseLayer: baseLayer}
|
|
||||||
}
|
|
295
integration/vendor/github.com/docker/docker/image/store.go
generated
vendored
295
integration/vendor/github.com/docker/docker/image/store.go
generated
vendored
|
@ -1,295 +0,0 @@
|
||||||
package image
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/json"
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"sync"
|
|
||||||
|
|
||||||
"github.com/Sirupsen/logrus"
|
|
||||||
"github.com/docker/distribution/digest"
|
|
||||||
"github.com/docker/docker/layer"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Store is an interface for creating and accessing images
|
|
||||||
type Store interface {
|
|
||||||
Create(config []byte) (ID, error)
|
|
||||||
Get(id ID) (*Image, error)
|
|
||||||
Delete(id ID) ([]layer.Metadata, error)
|
|
||||||
Search(partialID string) (ID, error)
|
|
||||||
SetParent(id ID, parent ID) error
|
|
||||||
GetParent(id ID) (ID, error)
|
|
||||||
Children(id ID) []ID
|
|
||||||
Map() map[ID]*Image
|
|
||||||
Heads() map[ID]*Image
|
|
||||||
}
|
|
||||||
|
|
||||||
// LayerGetReleaser is a minimal interface for getting and releasing images.
|
|
||||||
type LayerGetReleaser interface {
|
|
||||||
Get(layer.ChainID) (layer.Layer, error)
|
|
||||||
Release(layer.Layer) ([]layer.Metadata, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
type imageMeta struct {
|
|
||||||
layer layer.Layer
|
|
||||||
children map[ID]struct{}
|
|
||||||
}
|
|
||||||
|
|
||||||
type store struct {
|
|
||||||
sync.Mutex
|
|
||||||
ls LayerGetReleaser
|
|
||||||
images map[ID]*imageMeta
|
|
||||||
fs StoreBackend
|
|
||||||
digestSet *digest.Set
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewImageStore returns new store object for given layer store
|
|
||||||
func NewImageStore(fs StoreBackend, ls LayerGetReleaser) (Store, error) {
|
|
||||||
is := &store{
|
|
||||||
ls: ls,
|
|
||||||
images: make(map[ID]*imageMeta),
|
|
||||||
fs: fs,
|
|
||||||
digestSet: digest.NewSet(),
|
|
||||||
}
|
|
||||||
|
|
||||||
// load all current images and retain layers
|
|
||||||
if err := is.restore(); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return is, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) restore() error {
|
|
||||||
err := is.fs.Walk(func(id ID) error {
|
|
||||||
img, err := is.Get(id)
|
|
||||||
if err != nil {
|
|
||||||
logrus.Errorf("invalid image %v, %v", id, err)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
var l layer.Layer
|
|
||||||
if chainID := img.RootFS.ChainID(); chainID != "" {
|
|
||||||
l, err = is.ls.Get(chainID)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if err := is.digestSet.Add(digest.Digest(id)); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
imageMeta := &imageMeta{
|
|
||||||
layer: l,
|
|
||||||
children: make(map[ID]struct{}),
|
|
||||||
}
|
|
||||||
|
|
||||||
is.images[ID(id)] = imageMeta
|
|
||||||
|
|
||||||
return nil
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Second pass to fill in children maps
|
|
||||||
for id := range is.images {
|
|
||||||
if parent, err := is.GetParent(id); err == nil {
|
|
||||||
if parentMeta := is.images[parent]; parentMeta != nil {
|
|
||||||
parentMeta.children[id] = struct{}{}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) Create(config []byte) (ID, error) {
|
|
||||||
var img Image
|
|
||||||
err := json.Unmarshal(config, &img)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Must reject any config that references diffIDs from the history
|
|
||||||
// which aren't among the rootfs layers.
|
|
||||||
rootFSLayers := make(map[layer.DiffID]struct{})
|
|
||||||
for _, diffID := range img.RootFS.DiffIDs {
|
|
||||||
rootFSLayers[diffID] = struct{}{}
|
|
||||||
}
|
|
||||||
|
|
||||||
layerCounter := 0
|
|
||||||
for _, h := range img.History {
|
|
||||||
if !h.EmptyLayer {
|
|
||||||
layerCounter++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if layerCounter > len(img.RootFS.DiffIDs) {
|
|
||||||
return "", errors.New("too many non-empty layers in History section")
|
|
||||||
}
|
|
||||||
|
|
||||||
dgst, err := is.fs.Set(config)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
imageID := ID(dgst)
|
|
||||||
|
|
||||||
is.Lock()
|
|
||||||
defer is.Unlock()
|
|
||||||
|
|
||||||
if _, exists := is.images[imageID]; exists {
|
|
||||||
return imageID, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
layerID := img.RootFS.ChainID()
|
|
||||||
|
|
||||||
var l layer.Layer
|
|
||||||
if layerID != "" {
|
|
||||||
l, err = is.ls.Get(layerID)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
imageMeta := &imageMeta{
|
|
||||||
layer: l,
|
|
||||||
children: make(map[ID]struct{}),
|
|
||||||
}
|
|
||||||
|
|
||||||
is.images[imageID] = imageMeta
|
|
||||||
if err := is.digestSet.Add(digest.Digest(imageID)); err != nil {
|
|
||||||
delete(is.images, imageID)
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
return imageID, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) Search(term string) (ID, error) {
|
|
||||||
is.Lock()
|
|
||||||
defer is.Unlock()
|
|
||||||
|
|
||||||
dgst, err := is.digestSet.Lookup(term)
|
|
||||||
if err != nil {
|
|
||||||
if err == digest.ErrDigestNotFound {
|
|
||||||
err = fmt.Errorf("No such image: %s", term)
|
|
||||||
}
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
return ID(dgst), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) Get(id ID) (*Image, error) {
|
|
||||||
// todo: Check if image is in images
|
|
||||||
// todo: Detect manual insertions and start using them
|
|
||||||
config, err := is.fs.Get(id)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
img, err := NewFromJSON(config)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
img.computedID = id
|
|
||||||
|
|
||||||
img.Parent, err = is.GetParent(id)
|
|
||||||
if err != nil {
|
|
||||||
img.Parent = ""
|
|
||||||
}
|
|
||||||
|
|
||||||
return img, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) Delete(id ID) ([]layer.Metadata, error) {
|
|
||||||
is.Lock()
|
|
||||||
defer is.Unlock()
|
|
||||||
|
|
||||||
imageMeta := is.images[id]
|
|
||||||
if imageMeta == nil {
|
|
||||||
return nil, fmt.Errorf("unrecognized image ID %s", id.String())
|
|
||||||
}
|
|
||||||
for id := range imageMeta.children {
|
|
||||||
is.fs.DeleteMetadata(id, "parent")
|
|
||||||
}
|
|
||||||
if parent, err := is.GetParent(id); err == nil && is.images[parent] != nil {
|
|
||||||
delete(is.images[parent].children, id)
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := is.digestSet.Remove(digest.Digest(id)); err != nil {
|
|
||||||
logrus.Errorf("error removing %s from digest set: %q", id, err)
|
|
||||||
}
|
|
||||||
delete(is.images, id)
|
|
||||||
is.fs.Delete(id)
|
|
||||||
|
|
||||||
if imageMeta.layer != nil {
|
|
||||||
return is.ls.Release(imageMeta.layer)
|
|
||||||
}
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) SetParent(id, parent ID) error {
|
|
||||||
is.Lock()
|
|
||||||
defer is.Unlock()
|
|
||||||
parentMeta := is.images[parent]
|
|
||||||
if parentMeta == nil {
|
|
||||||
return fmt.Errorf("unknown parent image ID %s", parent.String())
|
|
||||||
}
|
|
||||||
if parent, err := is.GetParent(id); err == nil && is.images[parent] != nil {
|
|
||||||
delete(is.images[parent].children, id)
|
|
||||||
}
|
|
||||||
parentMeta.children[id] = struct{}{}
|
|
||||||
return is.fs.SetMetadata(id, "parent", []byte(parent))
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) GetParent(id ID) (ID, error) {
|
|
||||||
d, err := is.fs.GetMetadata(id, "parent")
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
return ID(d), nil // todo: validate?
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) Children(id ID) []ID {
|
|
||||||
is.Lock()
|
|
||||||
defer is.Unlock()
|
|
||||||
|
|
||||||
return is.children(id)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) children(id ID) []ID {
|
|
||||||
var ids []ID
|
|
||||||
if is.images[id] != nil {
|
|
||||||
for id := range is.images[id].children {
|
|
||||||
ids = append(ids, id)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return ids
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) Heads() map[ID]*Image {
|
|
||||||
return is.imagesMap(false)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) Map() map[ID]*Image {
|
|
||||||
return is.imagesMap(true)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (is *store) imagesMap(all bool) map[ID]*Image {
|
|
||||||
is.Lock()
|
|
||||||
defer is.Unlock()
|
|
||||||
|
|
||||||
images := make(map[ID]*Image)
|
|
||||||
|
|
||||||
for id := range is.images {
|
|
||||||
if !all && len(is.children(id)) > 0 {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
img, err := is.Get(id)
|
|
||||||
if err != nil {
|
|
||||||
logrus.Errorf("invalid image access: %q, error: %q", id, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
images[id] = img
|
|
||||||
}
|
|
||||||
return images
|
|
||||||
}
|
|
156
integration/vendor/github.com/docker/docker/image/v1/imagev1.go
generated
vendored
156
integration/vendor/github.com/docker/docker/image/v1/imagev1.go
generated
vendored
|
@ -1,156 +0,0 @@
|
||||||
package v1
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/json"
|
|
||||||
"fmt"
|
|
||||||
"reflect"
|
|
||||||
"regexp"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
"github.com/Sirupsen/logrus"
|
|
||||||
"github.com/docker/distribution/digest"
|
|
||||||
"github.com/docker/docker/image"
|
|
||||||
"github.com/docker/docker/layer"
|
|
||||||
"github.com/docker/engine-api/types/versions"
|
|
||||||
)
|
|
||||||
|
|
||||||
var validHex = regexp.MustCompile(`^([a-f0-9]{64})$`)
|
|
||||||
|
|
||||||
// noFallbackMinVersion is the minimum version for which v1compatibility
|
|
||||||
// information will not be marshaled through the Image struct to remove
|
|
||||||
// blank fields.
|
|
||||||
var noFallbackMinVersion = "1.8.3"
|
|
||||||
|
|
||||||
// HistoryFromConfig creates a History struct from v1 configuration JSON
|
|
||||||
func HistoryFromConfig(imageJSON []byte, emptyLayer bool) (image.History, error) {
|
|
||||||
h := image.History{}
|
|
||||||
var v1Image image.V1Image
|
|
||||||
if err := json.Unmarshal(imageJSON, &v1Image); err != nil {
|
|
||||||
return h, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return image.History{
|
|
||||||
Author: v1Image.Author,
|
|
||||||
Created: v1Image.Created,
|
|
||||||
CreatedBy: strings.Join(v1Image.ContainerConfig.Cmd, " "),
|
|
||||||
Comment: v1Image.Comment,
|
|
||||||
EmptyLayer: emptyLayer,
|
|
||||||
}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// CreateID creates an ID from v1 image, layerID and parent ID.
|
|
||||||
// Used for backwards compatibility with old clients.
|
|
||||||
func CreateID(v1Image image.V1Image, layerID layer.ChainID, parent digest.Digest) (digest.Digest, error) {
|
|
||||||
v1Image.ID = ""
|
|
||||||
v1JSON, err := json.Marshal(v1Image)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
var config map[string]*json.RawMessage
|
|
||||||
if err := json.Unmarshal(v1JSON, &config); err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
// FIXME: note that this is slightly incompatible with RootFS logic
|
|
||||||
config["layer_id"] = rawJSON(layerID)
|
|
||||||
if parent != "" {
|
|
||||||
config["parent"] = rawJSON(parent)
|
|
||||||
}
|
|
||||||
|
|
||||||
configJSON, err := json.Marshal(config)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
logrus.Debugf("CreateV1ID %s", configJSON)
|
|
||||||
|
|
||||||
return digest.FromBytes(configJSON), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// MakeConfigFromV1Config creates an image config from the legacy V1 config format.
|
|
||||||
func MakeConfigFromV1Config(imageJSON []byte, rootfs *image.RootFS, history []image.History) ([]byte, error) {
|
|
||||||
var dver struct {
|
|
||||||
DockerVersion string `json:"docker_version"`
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := json.Unmarshal(imageJSON, &dver); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
useFallback := versions.LessThan(dver.DockerVersion, noFallbackMinVersion)
|
|
||||||
|
|
||||||
if useFallback {
|
|
||||||
var v1Image image.V1Image
|
|
||||||
err := json.Unmarshal(imageJSON, &v1Image)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
imageJSON, err = json.Marshal(v1Image)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var c map[string]*json.RawMessage
|
|
||||||
if err := json.Unmarshal(imageJSON, &c); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
delete(c, "id")
|
|
||||||
delete(c, "parent")
|
|
||||||
delete(c, "Size") // Size is calculated from data on disk and is inconsistent
|
|
||||||
delete(c, "parent_id")
|
|
||||||
delete(c, "layer_id")
|
|
||||||
delete(c, "throwaway")
|
|
||||||
|
|
||||||
c["rootfs"] = rawJSON(rootfs)
|
|
||||||
c["history"] = rawJSON(history)
|
|
||||||
|
|
||||||
return json.Marshal(c)
|
|
||||||
}
|
|
||||||
|
|
||||||
// MakeV1ConfigFromConfig creates an legacy V1 image config from an Image struct
|
|
||||||
func MakeV1ConfigFromConfig(img *image.Image, v1ID, parentV1ID string, throwaway bool) ([]byte, error) {
|
|
||||||
// Top-level v1compatibility string should be a modified version of the
|
|
||||||
// image config.
|
|
||||||
var configAsMap map[string]*json.RawMessage
|
|
||||||
if err := json.Unmarshal(img.RawJSON(), &configAsMap); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Delete fields that didn't exist in old manifest
|
|
||||||
imageType := reflect.TypeOf(img).Elem()
|
|
||||||
for i := 0; i < imageType.NumField(); i++ {
|
|
||||||
f := imageType.Field(i)
|
|
||||||
jsonName := strings.Split(f.Tag.Get("json"), ",")[0]
|
|
||||||
// Parent is handled specially below.
|
|
||||||
if jsonName != "" && jsonName != "parent" {
|
|
||||||
delete(configAsMap, jsonName)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
configAsMap["id"] = rawJSON(v1ID)
|
|
||||||
if parentV1ID != "" {
|
|
||||||
configAsMap["parent"] = rawJSON(parentV1ID)
|
|
||||||
}
|
|
||||||
if throwaway {
|
|
||||||
configAsMap["throwaway"] = rawJSON(true)
|
|
||||||
}
|
|
||||||
|
|
||||||
return json.Marshal(configAsMap)
|
|
||||||
}
|
|
||||||
|
|
||||||
func rawJSON(value interface{}) *json.RawMessage {
|
|
||||||
jsonval, err := json.Marshal(value)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
return (*json.RawMessage)(&jsonval)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ValidateID checks whether an ID string is a valid image ID.
|
|
||||||
func ValidateID(id string) error {
|
|
||||||
if ok := validHex.MatchString(id); !ok {
|
|
||||||
return fmt.Errorf("image ID %q is invalid", id)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
48
integration/vendor/github.com/docker/docker/layer/empty.go
generated
vendored
48
integration/vendor/github.com/docker/docker/layer/empty.go
generated
vendored
|
@ -1,48 +0,0 @@
|
||||||
package layer
|
|
||||||
|
|
||||||
import (
|
|
||||||
"archive/tar"
|
|
||||||
"bytes"
|
|
||||||
"io"
|
|
||||||
"io/ioutil"
|
|
||||||
)
|
|
||||||
|
|
||||||
// DigestSHA256EmptyTar is the canonical sha256 digest of empty tar file -
|
|
||||||
// (1024 NULL bytes)
|
|
||||||
const DigestSHA256EmptyTar = DiffID("sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef")
|
|
||||||
|
|
||||||
type emptyLayer struct{}
|
|
||||||
|
|
||||||
// EmptyLayer is a layer that corresponds to empty tar.
|
|
||||||
var EmptyLayer = &emptyLayer{}
|
|
||||||
|
|
||||||
func (el *emptyLayer) TarStream() (io.ReadCloser, error) {
|
|
||||||
buf := new(bytes.Buffer)
|
|
||||||
tarWriter := tar.NewWriter(buf)
|
|
||||||
tarWriter.Close()
|
|
||||||
return ioutil.NopCloser(buf), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (el *emptyLayer) ChainID() ChainID {
|
|
||||||
return ChainID(DigestSHA256EmptyTar)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (el *emptyLayer) DiffID() DiffID {
|
|
||||||
return DigestSHA256EmptyTar
|
|
||||||
}
|
|
||||||
|
|
||||||
func (el *emptyLayer) Parent() Layer {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (el *emptyLayer) Size() (size int64, err error) {
|
|
||||||
return 0, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (el *emptyLayer) DiffSize() (size int64, err error) {
|
|
||||||
return 0, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (el *emptyLayer) Metadata() (map[string]string, error) {
|
|
||||||
return make(map[string]string), nil
|
|
||||||
}
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue