mirror of
https://github.com/fatedier/frp.git
synced 2025-01-22 09:32:07 +00:00
vendor: udpate
This commit is contained in:
parent
39089cf262
commit
8a6d6c534a
@ -25,13 +25,13 @@ import (
|
|||||||
"github.com/fatedier/frp/g"
|
"github.com/fatedier/frp/g"
|
||||||
"github.com/fatedier/frp/models/config"
|
"github.com/fatedier/frp/models/config"
|
||||||
"github.com/fatedier/frp/models/msg"
|
"github.com/fatedier/frp/models/msg"
|
||||||
"github.com/fatedier/frp/utils/crypto"
|
|
||||||
"github.com/fatedier/frp/utils/log"
|
"github.com/fatedier/frp/utils/log"
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
"github.com/fatedier/frp/utils/shutdown"
|
"github.com/fatedier/frp/utils/shutdown"
|
||||||
"github.com/fatedier/frp/utils/util"
|
"github.com/fatedier/frp/utils/util"
|
||||||
"github.com/fatedier/frp/utils/version"
|
"github.com/fatedier/frp/utils/version"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/crypto"
|
||||||
fmux "github.com/hashicorp/yamux"
|
fmux "github.com/hashicorp/yamux"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -27,11 +27,12 @@ import (
|
|||||||
"github.com/fatedier/frp/models/msg"
|
"github.com/fatedier/frp/models/msg"
|
||||||
"github.com/fatedier/frp/models/plugin"
|
"github.com/fatedier/frp/models/plugin"
|
||||||
"github.com/fatedier/frp/models/proto/udp"
|
"github.com/fatedier/frp/models/proto/udp"
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
frpIo "github.com/fatedier/frp/utils/io"
|
frpIo "github.com/fatedier/frp/utils/io"
|
||||||
"github.com/fatedier/frp/utils/log"
|
"github.com/fatedier/frp/utils/log"
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
"github.com/fatedier/frp/utils/pool"
|
|
||||||
|
"github.com/fatedier/golib/errors"
|
||||||
|
"github.com/fatedier/golib/pool"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Proxy defines how to deal with work connections for different proxy type.
|
// Proxy defines how to deal with work connections for different proxy type.
|
||||||
|
@ -6,9 +6,10 @@ import (
|
|||||||
|
|
||||||
"github.com/fatedier/frp/models/config"
|
"github.com/fatedier/frp/models/config"
|
||||||
"github.com/fatedier/frp/models/msg"
|
"github.com/fatedier/frp/models/msg"
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
"github.com/fatedier/frp/utils/log"
|
"github.com/fatedier/frp/utils/log"
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -32,8 +32,9 @@ import (
|
|||||||
frpIo "github.com/fatedier/frp/utils/io"
|
frpIo "github.com/fatedier/frp/utils/io"
|
||||||
"github.com/fatedier/frp/utils/log"
|
"github.com/fatedier/frp/utils/log"
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
"github.com/fatedier/frp/utils/pool"
|
|
||||||
"github.com/fatedier/frp/utils/util"
|
"github.com/fatedier/frp/utils/util"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/pool"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Visitor is used for forward traffics from local port tot remote service.
|
// Visitor is used for forward traffics from local port tot remote service.
|
||||||
|
@ -16,8 +16,12 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/fatedier/frp/cmd/frpc/sub"
|
"github.com/fatedier/frp/cmd/frpc/sub"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/crypto"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
crypto.DefaultSalt = "frp"
|
||||||
|
|
||||||
sub.Execute()
|
sub.Execute()
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,12 @@
|
|||||||
|
|
||||||
package main
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/fatedier/golib/crypto"
|
||||||
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
crypto.DefaultSalt = "frp"
|
||||||
|
|
||||||
Execute()
|
Execute()
|
||||||
}
|
}
|
||||||
|
12
glide.lock
generated
12
glide.lock
generated
@ -1,5 +1,5 @@
|
|||||||
hash: 47d70fb6b7dee9b0e453269a7079b42488dae6c4902b4d5c93976a8b7e15f604
|
hash: 47773e5a3ffd26ed0abf65042f71e7fe83764d8ccf0b00503d00987b962305a1
|
||||||
updated: 2018-05-04T17:59:35.698911+08:00
|
updated: 2018-05-08T02:13:16.483443+08:00
|
||||||
imports:
|
imports:
|
||||||
- name: github.com/armon/go-socks5
|
- name: github.com/armon/go-socks5
|
||||||
version: e75332964ef517daa070d7c38a9466a0d687e0a5
|
version: e75332964ef517daa070d7c38a9466a0d687e0a5
|
||||||
@ -13,14 +13,10 @@ imports:
|
|||||||
- logs
|
- logs
|
||||||
- name: github.com/fatedier/kcp-go
|
- name: github.com/fatedier/kcp-go
|
||||||
version: cd167d2f15f451b0f33780ce862fca97adc0331e
|
version: cd167d2f15f451b0f33780ce862fca97adc0331e
|
||||||
- name: github.com/golang/snappy
|
|
||||||
version: 5979233c5d6225d4a8e438cdd0b411888449ddab
|
|
||||||
- name: github.com/gorilla/websocket
|
- name: github.com/gorilla/websocket
|
||||||
version: ea4d1f681babbce9545c9c5f3d5194a789c89f5b
|
version: ea4d1f681babbce9545c9c5f3d5194a789c89f5b
|
||||||
- name: github.com/hashicorp/yamux
|
- name: github.com/hashicorp/yamux
|
||||||
version: 2658be15c5f05e76244154714161f17e3e77de2e
|
version: 2658be15c5f05e76244154714161f17e3e77de2e
|
||||||
- name: github.com/inconshreveable/mousetrap
|
|
||||||
version: 76626ae9c91c4f2a10f34cad8ce83ea42c93bb75
|
|
||||||
- name: github.com/julienschmidt/httprouter
|
- name: github.com/julienschmidt/httprouter
|
||||||
version: 8a45e95fc75cb77048068a62daed98cc22fdac7c
|
version: 8a45e95fc75cb77048068a62daed98cc22fdac7c
|
||||||
- name: github.com/klauspost/cpuid
|
- name: github.com/klauspost/cpuid
|
||||||
@ -41,8 +37,6 @@ imports:
|
|||||||
version: 212a2ad1c462ed4d5b5511ea2b480a573281dbbd
|
version: 212a2ad1c462ed4d5b5511ea2b480a573281dbbd
|
||||||
- name: github.com/spf13/cobra
|
- name: github.com/spf13/cobra
|
||||||
version: a1f051bc3eba734da4772d60e2d677f47cf93ef4
|
version: a1f051bc3eba734da4772d60e2d677f47cf93ef4
|
||||||
- name: github.com/spf13/pflag
|
|
||||||
version: 583c0c0531f06d5278b7d917446061adc344b5cd
|
|
||||||
- name: github.com/stretchr/testify
|
- name: github.com/stretchr/testify
|
||||||
version: 2402e8e7a02fc811447d11f881aa9746cdc57983
|
version: 2402e8e7a02fc811447d11f881aa9746cdc57983
|
||||||
subpackages:
|
subpackages:
|
||||||
@ -77,7 +71,5 @@ imports:
|
|||||||
- context
|
- context
|
||||||
- internal/iana
|
- internal/iana
|
||||||
- internal/socket
|
- internal/socket
|
||||||
- internal/socks
|
|
||||||
- ipv4
|
- ipv4
|
||||||
- proxy
|
|
||||||
testImports: []
|
testImports: []
|
||||||
|
@ -12,8 +12,6 @@ import:
|
|||||||
- logs
|
- logs
|
||||||
- package: github.com/fatedier/kcp-go
|
- package: github.com/fatedier/kcp-go
|
||||||
version: cd167d2f15f451b0f33780ce862fca97adc0331e
|
version: cd167d2f15f451b0f33780ce862fca97adc0331e
|
||||||
- package: github.com/golang/snappy
|
|
||||||
version: 5979233c5d6225d4a8e438cdd0b411888449ddab
|
|
||||||
- package: github.com/julienschmidt/httprouter
|
- package: github.com/julienschmidt/httprouter
|
||||||
version: 8a45e95fc75cb77048068a62daed98cc22fdac7c
|
version: 8a45e95fc75cb77048068a62daed98cc22fdac7c
|
||||||
- package: github.com/klauspost/cpuid
|
- package: github.com/klauspost/cpuid
|
||||||
|
@ -14,8 +14,11 @@
|
|||||||
|
|
||||||
package errors
|
package errors
|
||||||
|
|
||||||
import "errors"
|
import (
|
||||||
|
"errors"
|
||||||
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
ErrMsgType = errors.New("message type error")
|
ErrMsgType = errors.New("message type error")
|
||||||
|
ErrCtlClosed = errors.New("control is closed")
|
||||||
)
|
)
|
||||||
|
@ -21,7 +21,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"reflect"
|
"reflect"
|
||||||
|
|
||||||
"github.com/fatedier/frp/utils/errors"
|
"github.com/fatedier/frp/models/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
func unpack(typeByte byte, buffer []byte, msgIn Message) (msg Message, err error) {
|
func unpack(typeByte byte, buffer []byte, msgIn Message) (msg Message, err error) {
|
||||||
|
@ -22,7 +22,7 @@ import (
|
|||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/fatedier/frp/utils/errors"
|
"github.com/fatedier/frp/models/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
type TestStruct struct{}
|
type TestStruct struct{}
|
||||||
|
@ -20,8 +20,9 @@ import (
|
|||||||
"net"
|
"net"
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Creators is used for create plugins to handle connections.
|
// Creators is used for create plugins to handle connections.
|
||||||
|
@ -21,8 +21,9 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/fatedier/frp/models/msg"
|
"github.com/fatedier/frp/models/msg"
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
"github.com/fatedier/frp/utils/pool"
|
"github.com/fatedier/golib/errors"
|
||||||
|
"github.com/fatedier/golib/pool"
|
||||||
)
|
)
|
||||||
|
|
||||||
func NewUdpPacket(buf []byte, laddr, raddr *net.UDPAddr) *msg.UdpPacket {
|
func NewUdpPacket(buf []byte, laddr, raddr *net.UDPAddr) *msg.UdpPacket {
|
||||||
|
@ -23,12 +23,14 @@ import (
|
|||||||
"github.com/fatedier/frp/g"
|
"github.com/fatedier/frp/g"
|
||||||
"github.com/fatedier/frp/models/config"
|
"github.com/fatedier/frp/models/config"
|
||||||
"github.com/fatedier/frp/models/consts"
|
"github.com/fatedier/frp/models/consts"
|
||||||
|
frpErr "github.com/fatedier/frp/models/errors"
|
||||||
"github.com/fatedier/frp/models/msg"
|
"github.com/fatedier/frp/models/msg"
|
||||||
"github.com/fatedier/frp/utils/crypto"
|
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
"github.com/fatedier/frp/utils/net"
|
"github.com/fatedier/frp/utils/net"
|
||||||
"github.com/fatedier/frp/utils/shutdown"
|
"github.com/fatedier/frp/utils/shutdown"
|
||||||
"github.com/fatedier/frp/utils/version"
|
"github.com/fatedier/frp/utils/version"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/crypto"
|
||||||
|
"github.com/fatedier/golib/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Control struct {
|
type Control struct {
|
||||||
@ -151,7 +153,7 @@ func (ctl *Control) GetWorkConn() (workConn net.Conn, err error) {
|
|||||||
select {
|
select {
|
||||||
case workConn, ok = <-ctl.workConnCh:
|
case workConn, ok = <-ctl.workConnCh:
|
||||||
if !ok {
|
if !ok {
|
||||||
err = errors.ErrCtlClosed
|
err = frpErr.ErrCtlClosed
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctl.conn.Debug("get work connection from pool")
|
ctl.conn.Debug("get work connection from pool")
|
||||||
@ -168,7 +170,7 @@ func (ctl *Control) GetWorkConn() (workConn net.Conn, err error) {
|
|||||||
select {
|
select {
|
||||||
case workConn, ok = <-ctl.workConnCh:
|
case workConn, ok = <-ctl.workConnCh:
|
||||||
if !ok {
|
if !ok {
|
||||||
err = errors.ErrCtlClosed
|
err = frpErr.ErrCtlClosed
|
||||||
ctl.conn.Warn("no work connections avaiable, %v", err)
|
ctl.conn.Warn("no work connections avaiable, %v", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -8,10 +8,11 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/fatedier/frp/models/msg"
|
"github.com/fatedier/frp/models/msg"
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
"github.com/fatedier/frp/utils/log"
|
"github.com/fatedier/frp/utils/log"
|
||||||
"github.com/fatedier/frp/utils/pool"
|
|
||||||
"github.com/fatedier/frp/utils/util"
|
"github.com/fatedier/frp/utils/util"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/errors"
|
||||||
|
"github.com/fatedier/golib/pool"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Timeout seconds.
|
// Timeout seconds.
|
||||||
|
@ -27,12 +27,13 @@ import (
|
|||||||
"github.com/fatedier/frp/models/config"
|
"github.com/fatedier/frp/models/config"
|
||||||
"github.com/fatedier/frp/models/msg"
|
"github.com/fatedier/frp/models/msg"
|
||||||
"github.com/fatedier/frp/models/proto/udp"
|
"github.com/fatedier/frp/models/proto/udp"
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
frpIo "github.com/fatedier/frp/utils/io"
|
frpIo "github.com/fatedier/frp/utils/io"
|
||||||
"github.com/fatedier/frp/utils/log"
|
"github.com/fatedier/frp/utils/log"
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
"github.com/fatedier/frp/utils/util"
|
"github.com/fatedier/frp/utils/util"
|
||||||
"github.com/fatedier/frp/utils/vhost"
|
"github.com/fatedier/frp/utils/vhost"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Proxy interface {
|
type Proxy interface {
|
||||||
|
@ -1,41 +0,0 @@
|
|||||||
// Copyright 2017 fatedier, fatedier@gmail.com
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package crypto
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"io"
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestCrypto(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
|
|
||||||
text := "1234567890abcdefghigklmnopqrstuvwxyzeeeeeeeeeeeeeeeeeeeeeewwwwwwwwwwwwwwwwwwwwwwwwwwzzzzzzzzzzzzzzzzzzzzzzzzdddddddddddddddddddddddddddddddddddddrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrllllllllllllllllllllllllllllllllllqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeewwwwwwwwwwwwwwwwwwwwww"
|
|
||||||
key := "123456"
|
|
||||||
|
|
||||||
buffer := bytes.NewBuffer(nil)
|
|
||||||
encWriter, err := NewWriter(buffer, []byte(key))
|
|
||||||
assert.NoError(err)
|
|
||||||
decReader := NewReader(buffer, []byte(key))
|
|
||||||
|
|
||||||
encWriter.Write([]byte(text))
|
|
||||||
|
|
||||||
c := bytes.NewBuffer(nil)
|
|
||||||
io.Copy(c, decReader)
|
|
||||||
assert.Equal(text, string(c.Bytes()))
|
|
||||||
}
|
|
@ -1,75 +0,0 @@
|
|||||||
// Copyright 2017 fatedier, fatedier@gmail.com
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package crypto
|
|
||||||
|
|
||||||
import (
|
|
||||||
"crypto/aes"
|
|
||||||
"crypto/cipher"
|
|
||||||
"crypto/sha1"
|
|
||||||
"io"
|
|
||||||
|
|
||||||
"golang.org/x/crypto/pbkdf2"
|
|
||||||
)
|
|
||||||
|
|
||||||
// NewReader returns a new Reader that decrypts bytes from r
|
|
||||||
func NewReader(r io.Reader, key []byte) *Reader {
|
|
||||||
key = pbkdf2.Key(key, []byte(salt), 64, aes.BlockSize, sha1.New)
|
|
||||||
|
|
||||||
return &Reader{
|
|
||||||
r: r,
|
|
||||||
key: key,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reader is an io.Reader that can read encrypted bytes.
|
|
||||||
// Now it only supports aes-128-cfb.
|
|
||||||
type Reader struct {
|
|
||||||
r io.Reader
|
|
||||||
dec *cipher.StreamReader
|
|
||||||
key []byte
|
|
||||||
iv []byte
|
|
||||||
err error
|
|
||||||
}
|
|
||||||
|
|
||||||
// Read satisfies the io.Reader interface.
|
|
||||||
func (r *Reader) Read(p []byte) (nRet int, errRet error) {
|
|
||||||
if r.err != nil {
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
|
|
||||||
if r.dec == nil {
|
|
||||||
iv := make([]byte, aes.BlockSize)
|
|
||||||
if _, errRet = io.ReadFull(r.r, iv); errRet != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
r.iv = iv
|
|
||||||
|
|
||||||
block, err := aes.NewCipher(r.key)
|
|
||||||
if err != nil {
|
|
||||||
errRet = err
|
|
||||||
return
|
|
||||||
}
|
|
||||||
r.dec = &cipher.StreamReader{
|
|
||||||
S: cipher.NewCFBDecrypter(block, iv),
|
|
||||||
R: r.r,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
nRet, errRet = r.dec.Read(p)
|
|
||||||
if errRet != nil {
|
|
||||||
r.err = errRet
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
@ -1,89 +0,0 @@
|
|||||||
// Copyright 2017 fatedier, fatedier@gmail.com
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package crypto
|
|
||||||
|
|
||||||
import (
|
|
||||||
"crypto/aes"
|
|
||||||
"crypto/cipher"
|
|
||||||
"crypto/rand"
|
|
||||||
"crypto/sha1"
|
|
||||||
"io"
|
|
||||||
|
|
||||||
"golang.org/x/crypto/pbkdf2"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
salt = "frp"
|
|
||||||
)
|
|
||||||
|
|
||||||
// NewWriter returns a new Writer that encrypts bytes to w.
|
|
||||||
func NewWriter(w io.Writer, key []byte) (*Writer, error) {
|
|
||||||
key = pbkdf2.Key(key, []byte(salt), 64, aes.BlockSize, sha1.New)
|
|
||||||
|
|
||||||
// random iv
|
|
||||||
iv := make([]byte, aes.BlockSize)
|
|
||||||
if _, err := io.ReadFull(rand.Reader, iv); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
block, err := aes.NewCipher(key)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return &Writer{
|
|
||||||
w: w,
|
|
||||||
enc: &cipher.StreamWriter{
|
|
||||||
S: cipher.NewCFBEncrypter(block, iv),
|
|
||||||
W: w,
|
|
||||||
},
|
|
||||||
key: key,
|
|
||||||
iv: iv,
|
|
||||||
}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Writer is an io.Writer that can write encrypted bytes.
|
|
||||||
// Now it only support aes-128-cfb.
|
|
||||||
type Writer struct {
|
|
||||||
w io.Writer
|
|
||||||
enc *cipher.StreamWriter
|
|
||||||
key []byte
|
|
||||||
iv []byte
|
|
||||||
ivSend bool
|
|
||||||
err error
|
|
||||||
}
|
|
||||||
|
|
||||||
// Write satisfies the io.Writer interface.
|
|
||||||
func (w *Writer) Write(p []byte) (nRet int, errRet error) {
|
|
||||||
if w.err != nil {
|
|
||||||
return 0, w.err
|
|
||||||
}
|
|
||||||
|
|
||||||
// When write is first called, iv will be written to w.w
|
|
||||||
if !w.ivSend {
|
|
||||||
w.ivSend = true
|
|
||||||
_, errRet = w.w.Write(w.iv)
|
|
||||||
if errRet != nil {
|
|
||||||
w.err = errRet
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
nRet, errRet = w.enc.Write(p)
|
|
||||||
if errRet != nil {
|
|
||||||
w.err = errRet
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
@ -1,36 +0,0 @@
|
|||||||
// Copyright 2016 fatedier, fatedier@gmail.com
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package errors
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
ErrMsgType = errors.New("message type error")
|
|
||||||
ErrCtlClosed = errors.New("control is closed")
|
|
||||||
)
|
|
||||||
|
|
||||||
func PanicToError(fn func()) (err error) {
|
|
||||||
defer func() {
|
|
||||||
if r := recover(); r != nil {
|
|
||||||
err = fmt.Errorf("Panic error: %v", r)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
fn()
|
|
||||||
return
|
|
||||||
}
|
|
@ -1,16 +0,0 @@
|
|||||||
package errors
|
|
||||||
|
|
||||||
import (
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestPanicToError(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
|
|
||||||
err := PanicToError(func() {
|
|
||||||
panic("test error")
|
|
||||||
})
|
|
||||||
assert.Contains(err.Error(), "test error")
|
|
||||||
}
|
|
@ -18,8 +18,8 @@ import (
|
|||||||
"io"
|
"io"
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/fatedier/frp/utils/crypto"
|
"github.com/fatedier/golib/crypto"
|
||||||
"github.com/fatedier/frp/utils/pool"
|
"github.com/fatedier/golib/pool"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Join two io.ReadWriteCloser and do some operations.
|
// Join two io.ReadWriteCloser and do some operations.
|
||||||
|
@ -19,8 +19,9 @@ import (
|
|||||||
"net"
|
"net"
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
"github.com/fatedier/frp/utils/log"
|
"github.com/fatedier/frp/utils/log"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Listener interface {
|
type Listener interface {
|
||||||
|
@ -8,8 +8,9 @@ import (
|
|||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -22,7 +22,8 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/fatedier/frp/utils/log"
|
"github.com/fatedier/frp/utils/log"
|
||||||
"github.com/fatedier/frp/utils/pool"
|
|
||||||
|
"github.com/fatedier/golib/pool"
|
||||||
)
|
)
|
||||||
|
|
||||||
type UdpPacket struct {
|
type UdpPacket struct {
|
||||||
|
@ -1,63 +0,0 @@
|
|||||||
// Copyright 2016 fatedier, fatedier@gmail.com
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package pool
|
|
||||||
|
|
||||||
import "sync"
|
|
||||||
|
|
||||||
var (
|
|
||||||
bufPool16k sync.Pool
|
|
||||||
bufPool5k sync.Pool
|
|
||||||
bufPool2k sync.Pool
|
|
||||||
bufPool1k sync.Pool
|
|
||||||
bufPool sync.Pool
|
|
||||||
)
|
|
||||||
|
|
||||||
func GetBuf(size int) []byte {
|
|
||||||
var x interface{}
|
|
||||||
if size >= 16*1024 {
|
|
||||||
x = bufPool16k.Get()
|
|
||||||
} else if size >= 5*1024 {
|
|
||||||
x = bufPool5k.Get()
|
|
||||||
} else if size >= 2*1024 {
|
|
||||||
x = bufPool2k.Get()
|
|
||||||
} else if size >= 1*1024 {
|
|
||||||
x = bufPool1k.Get()
|
|
||||||
} else {
|
|
||||||
x = bufPool.Get()
|
|
||||||
}
|
|
||||||
if x == nil {
|
|
||||||
return make([]byte, size)
|
|
||||||
}
|
|
||||||
buf := x.([]byte)
|
|
||||||
if cap(buf) < size {
|
|
||||||
return make([]byte, size)
|
|
||||||
}
|
|
||||||
return buf[:size]
|
|
||||||
}
|
|
||||||
|
|
||||||
func PutBuf(buf []byte) {
|
|
||||||
size := cap(buf)
|
|
||||||
if size >= 16*1024 {
|
|
||||||
bufPool16k.Put(buf)
|
|
||||||
} else if size >= 5*1024 {
|
|
||||||
bufPool5k.Put(buf)
|
|
||||||
} else if size >= 2*1024 {
|
|
||||||
bufPool2k.Put(buf)
|
|
||||||
} else if size >= 1*1024 {
|
|
||||||
bufPool1k.Put(buf)
|
|
||||||
} else {
|
|
||||||
bufPool.Put(buf)
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,51 +0,0 @@
|
|||||||
// Copyright 2016 fatedier, fatedier@gmail.com
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package pool
|
|
||||||
|
|
||||||
import (
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestPutBuf(t *testing.T) {
|
|
||||||
buf := make([]byte, 512)
|
|
||||||
PutBuf(buf)
|
|
||||||
|
|
||||||
buf = make([]byte, 1025)
|
|
||||||
PutBuf(buf)
|
|
||||||
|
|
||||||
buf = make([]byte, 2*1025)
|
|
||||||
PutBuf(buf)
|
|
||||||
|
|
||||||
buf = make([]byte, 5*1025)
|
|
||||||
PutBuf(buf)
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestGetBuf(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
|
|
||||||
buf := GetBuf(200)
|
|
||||||
assert.Len(buf, 200)
|
|
||||||
|
|
||||||
buf = GetBuf(1025)
|
|
||||||
assert.Len(buf, 1025)
|
|
||||||
|
|
||||||
buf = GetBuf(2 * 1024)
|
|
||||||
assert.Len(buf, 2*1024)
|
|
||||||
|
|
||||||
buf = GetBuf(5 * 2000)
|
|
||||||
assert.Len(buf, 5*2000)
|
|
||||||
}
|
|
@ -1,57 +0,0 @@
|
|||||||
// Copyright 2017 fatedier, fatedier@gmail.com
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package pool
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
"sync"
|
|
||||||
|
|
||||||
"github.com/golang/snappy"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
snappyReaderPool sync.Pool
|
|
||||||
snappyWriterPool sync.Pool
|
|
||||||
)
|
|
||||||
|
|
||||||
func GetSnappyReader(r io.Reader) *snappy.Reader {
|
|
||||||
var x interface{}
|
|
||||||
x = snappyReaderPool.Get()
|
|
||||||
if x == nil {
|
|
||||||
return snappy.NewReader(r)
|
|
||||||
}
|
|
||||||
sr := x.(*snappy.Reader)
|
|
||||||
sr.Reset(r)
|
|
||||||
return sr
|
|
||||||
}
|
|
||||||
|
|
||||||
func PutSnappyReader(sr *snappy.Reader) {
|
|
||||||
snappyReaderPool.Put(sr)
|
|
||||||
}
|
|
||||||
|
|
||||||
func GetSnappyWriter(w io.Writer) *snappy.Writer {
|
|
||||||
var x interface{}
|
|
||||||
x = snappyWriterPool.Get()
|
|
||||||
if x == nil {
|
|
||||||
return snappy.NewWriter(w)
|
|
||||||
}
|
|
||||||
sw := x.(*snappy.Writer)
|
|
||||||
sw.Reset(w)
|
|
||||||
return sw
|
|
||||||
}
|
|
||||||
|
|
||||||
func PutSnappyWriter(sw *snappy.Writer) {
|
|
||||||
snappyWriterPool.Put(sw)
|
|
||||||
}
|
|
@ -26,7 +26,8 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
"github.com/fatedier/frp/utils/pool"
|
|
||||||
|
"github.com/fatedier/golib/pool"
|
||||||
)
|
)
|
||||||
|
|
||||||
type HttpMuxer struct {
|
type HttpMuxer struct {
|
||||||
|
@ -21,7 +21,7 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
"github.com/fatedier/frp/utils/pool"
|
"github.com/fatedier/golib/pool"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -26,7 +26,8 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
frpLog "github.com/fatedier/frp/utils/log"
|
frpLog "github.com/fatedier/frp/utils/log"
|
||||||
"github.com/fatedier/frp/utils/pool"
|
|
||||||
|
"github.com/fatedier/golib/pool"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
@ -18,9 +18,10 @@ import (
|
|||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/fatedier/frp/utils/errors"
|
|
||||||
"github.com/fatedier/frp/utils/log"
|
"github.com/fatedier/frp/utils/log"
|
||||||
frpNet "github.com/fatedier/frp/utils/net"
|
frpNet "github.com/fatedier/frp/utils/net"
|
||||||
|
|
||||||
|
"github.com/fatedier/golib/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
type muxFunc func(frpNet.Conn) (frpNet.Conn, map[string]string, error)
|
type muxFunc func(frpNet.Conn) (frpNet.Conn, map[string]string, error)
|
||||||
|
11
vendor/github.com/golang/snappy/.gitignore
generated
vendored
11
vendor/github.com/golang/snappy/.gitignore
generated
vendored
@ -1,11 +0,0 @@
|
|||||||
testdata/alice29.txt
|
|
||||||
testdata/asyoulik.txt
|
|
||||||
testdata/fireworks.jpeg
|
|
||||||
testdata/geo.protodata
|
|
||||||
testdata/html
|
|
||||||
testdata/html_x_4
|
|
||||||
testdata/kppkn.gtb
|
|
||||||
testdata/lcet10.txt
|
|
||||||
testdata/paper-100k.pdf
|
|
||||||
testdata/plrabn12.txt
|
|
||||||
testdata/urls.10K
|
|
15
vendor/github.com/golang/snappy/AUTHORS
generated
vendored
15
vendor/github.com/golang/snappy/AUTHORS
generated
vendored
@ -1,15 +0,0 @@
|
|||||||
# This is the official list of Snappy-Go authors for copyright purposes.
|
|
||||||
# This file is distinct from the CONTRIBUTORS files.
|
|
||||||
# See the latter for an explanation.
|
|
||||||
|
|
||||||
# Names should be added to this file as
|
|
||||||
# Name or Organization <email address>
|
|
||||||
# The email address is not required for organizations.
|
|
||||||
|
|
||||||
# Please keep the list sorted.
|
|
||||||
|
|
||||||
Damian Gryski <dgryski@gmail.com>
|
|
||||||
Google Inc.
|
|
||||||
Jan Mercl <0xjnml@gmail.com>
|
|
||||||
Rodolfo Carvalho <rhcarvalho@gmail.com>
|
|
||||||
Sebastien Binet <seb.binet@gmail.com>
|
|
37
vendor/github.com/golang/snappy/CONTRIBUTORS
generated
vendored
37
vendor/github.com/golang/snappy/CONTRIBUTORS
generated
vendored
@ -1,37 +0,0 @@
|
|||||||
# This is the official list of people who can contribute
|
|
||||||
# (and typically have contributed) code to the Snappy-Go repository.
|
|
||||||
# The AUTHORS file lists the copyright holders; this file
|
|
||||||
# lists people. For example, Google employees are listed here
|
|
||||||
# but not in AUTHORS, because Google holds the copyright.
|
|
||||||
#
|
|
||||||
# The submission process automatically checks to make sure
|
|
||||||
# that people submitting code are listed in this file (by email address).
|
|
||||||
#
|
|
||||||
# Names should be added to this file only after verifying that
|
|
||||||
# the individual or the individual's organization has agreed to
|
|
||||||
# the appropriate Contributor License Agreement, found here:
|
|
||||||
#
|
|
||||||
# http://code.google.com/legal/individual-cla-v1.0.html
|
|
||||||
# http://code.google.com/legal/corporate-cla-v1.0.html
|
|
||||||
#
|
|
||||||
# The agreement for individuals can be filled out on the web.
|
|
||||||
#
|
|
||||||
# When adding J Random Contributor's name to this file,
|
|
||||||
# either J's name or J's organization's name should be
|
|
||||||
# added to the AUTHORS file, depending on whether the
|
|
||||||
# individual or corporate CLA was used.
|
|
||||||
|
|
||||||
# Names should be added to this file like so:
|
|
||||||
# Name <email address>
|
|
||||||
|
|
||||||
# Please keep the list sorted.
|
|
||||||
|
|
||||||
Damian Gryski <dgryski@gmail.com>
|
|
||||||
Jan Mercl <0xjnml@gmail.com>
|
|
||||||
Kai Backman <kaib@golang.org>
|
|
||||||
Marc-Antoine Ruel <maruel@chromium.org>
|
|
||||||
Nigel Tao <nigeltao@golang.org>
|
|
||||||
Rob Pike <r@golang.org>
|
|
||||||
Rodolfo Carvalho <rhcarvalho@gmail.com>
|
|
||||||
Russ Cox <rsc@golang.org>
|
|
||||||
Sebastien Binet <seb.binet@gmail.com>
|
|
27
vendor/github.com/golang/snappy/LICENSE
generated
vendored
27
vendor/github.com/golang/snappy/LICENSE
generated
vendored
@ -1,27 +0,0 @@
|
|||||||
Copyright (c) 2011 The Snappy-Go Authors. All rights reserved.
|
|
||||||
|
|
||||||
Redistribution and use in source and binary forms, with or without
|
|
||||||
modification, are permitted provided that the following conditions are
|
|
||||||
met:
|
|
||||||
|
|
||||||
* Redistributions of source code must retain the above copyright
|
|
||||||
notice, this list of conditions and the following disclaimer.
|
|
||||||
* Redistributions in binary form must reproduce the above
|
|
||||||
copyright notice, this list of conditions and the following disclaimer
|
|
||||||
in the documentation and/or other materials provided with the
|
|
||||||
distribution.
|
|
||||||
* Neither the name of Google Inc. nor the names of its
|
|
||||||
contributors may be used to endorse or promote products derived from
|
|
||||||
this software without specific prior written permission.
|
|
||||||
|
|
||||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
7
vendor/github.com/golang/snappy/README
generated
vendored
7
vendor/github.com/golang/snappy/README
generated
vendored
@ -1,7 +0,0 @@
|
|||||||
The Snappy compression format in the Go programming language.
|
|
||||||
|
|
||||||
To download and install from source:
|
|
||||||
$ go get github.com/golang/snappy
|
|
||||||
|
|
||||||
Unless otherwise noted, the Snappy-Go source files are distributed
|
|
||||||
under the BSD-style license found in the LICENSE file.
|
|
296
vendor/github.com/golang/snappy/decode.go
generated
vendored
296
vendor/github.com/golang/snappy/decode.go
generated
vendored
@ -1,296 +0,0 @@
|
|||||||
// Copyright 2011 The Snappy-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 snappy
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/binary"
|
|
||||||
"errors"
|
|
||||||
"io"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
// ErrCorrupt reports that the input is invalid.
|
|
||||||
ErrCorrupt = errors.New("snappy: corrupt input")
|
|
||||||
// ErrTooLarge reports that the uncompressed length is too large.
|
|
||||||
ErrTooLarge = errors.New("snappy: decoded block is too large")
|
|
||||||
// ErrUnsupported reports that the input isn't supported.
|
|
||||||
ErrUnsupported = errors.New("snappy: unsupported input")
|
|
||||||
|
|
||||||
errUnsupportedCopy4Tag = errors.New("snappy: unsupported COPY_4 tag")
|
|
||||||
errUnsupportedLiteralLength = errors.New("snappy: unsupported literal length")
|
|
||||||
)
|
|
||||||
|
|
||||||
// DecodedLen returns the length of the decoded block.
|
|
||||||
func DecodedLen(src []byte) (int, error) {
|
|
||||||
v, _, err := decodedLen(src)
|
|
||||||
return v, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// decodedLen returns the length of the decoded block and the number of bytes
|
|
||||||
// that the length header occupied.
|
|
||||||
func decodedLen(src []byte) (blockLen, headerLen int, err error) {
|
|
||||||
v, n := binary.Uvarint(src)
|
|
||||||
if n <= 0 || v > 0xffffffff {
|
|
||||||
return 0, 0, ErrCorrupt
|
|
||||||
}
|
|
||||||
|
|
||||||
const wordSize = 32 << (^uint(0) >> 32 & 1)
|
|
||||||
if wordSize == 32 && v > 0x7fffffff {
|
|
||||||
return 0, 0, ErrTooLarge
|
|
||||||
}
|
|
||||||
return int(v), n, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Decode returns the decoded form of src. The returned slice may be a sub-
|
|
||||||
// slice of dst if dst was large enough to hold the entire decoded block.
|
|
||||||
// Otherwise, a newly allocated slice will be returned.
|
|
||||||
// It is valid to pass a nil dst.
|
|
||||||
func Decode(dst, src []byte) ([]byte, error) {
|
|
||||||
dLen, s, err := decodedLen(src)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if len(dst) < dLen {
|
|
||||||
dst = make([]byte, dLen)
|
|
||||||
}
|
|
||||||
|
|
||||||
var d, offset, length int
|
|
||||||
for s < len(src) {
|
|
||||||
switch src[s] & 0x03 {
|
|
||||||
case tagLiteral:
|
|
||||||
x := uint(src[s] >> 2)
|
|
||||||
switch {
|
|
||||||
case x < 60:
|
|
||||||
s++
|
|
||||||
case x == 60:
|
|
||||||
s += 2
|
|
||||||
if uint(s) > uint(len(src)) { // The uint conversions catch overflow from the previous line.
|
|
||||||
return nil, ErrCorrupt
|
|
||||||
}
|
|
||||||
x = uint(src[s-1])
|
|
||||||
case x == 61:
|
|
||||||
s += 3
|
|
||||||
if uint(s) > uint(len(src)) { // The uint conversions catch overflow from the previous line.
|
|
||||||
return nil, ErrCorrupt
|
|
||||||
}
|
|
||||||
x = uint(src[s-2]) | uint(src[s-1])<<8
|
|
||||||
case x == 62:
|
|
||||||
s += 4
|
|
||||||
if uint(s) > uint(len(src)) { // The uint conversions catch overflow from the previous line.
|
|
||||||
return nil, ErrCorrupt
|
|
||||||
}
|
|
||||||
x = uint(src[s-3]) | uint(src[s-2])<<8 | uint(src[s-1])<<16
|
|
||||||
case x == 63:
|
|
||||||
s += 5
|
|
||||||
if uint(s) > uint(len(src)) { // The uint conversions catch overflow from the previous line.
|
|
||||||
return nil, ErrCorrupt
|
|
||||||
}
|
|
||||||
x = uint(src[s-4]) | uint(src[s-3])<<8 | uint(src[s-2])<<16 | uint(src[s-1])<<24
|
|
||||||
}
|
|
||||||
length = int(x + 1)
|
|
||||||
if length <= 0 {
|
|
||||||
return nil, errUnsupportedLiteralLength
|
|
||||||
}
|
|
||||||
if length > len(dst)-d || length > len(src)-s {
|
|
||||||
return nil, ErrCorrupt
|
|
||||||
}
|
|
||||||
copy(dst[d:], src[s:s+length])
|
|
||||||
d += length
|
|
||||||
s += length
|
|
||||||
continue
|
|
||||||
|
|
||||||
case tagCopy1:
|
|
||||||
s += 2
|
|
||||||
if s > len(src) {
|
|
||||||
return nil, ErrCorrupt
|
|
||||||
}
|
|
||||||
length = 4 + int(src[s-2])>>2&0x7
|
|
||||||
offset = int(src[s-2])&0xe0<<3 | int(src[s-1])
|
|
||||||
|
|
||||||
case tagCopy2:
|
|
||||||
s += 3
|
|
||||||
if s > len(src) {
|
|
||||||
return nil, ErrCorrupt
|
|
||||||
}
|
|
||||||
length = 1 + int(src[s-3])>>2
|
|
||||||
offset = int(src[s-2]) | int(src[s-1])<<8
|
|
||||||
|
|
||||||
case tagCopy4:
|
|
||||||
return nil, errUnsupportedCopy4Tag
|
|
||||||
}
|
|
||||||
|
|
||||||
if offset > d || length > len(dst)-d {
|
|
||||||
return nil, ErrCorrupt
|
|
||||||
}
|
|
||||||
for end := d + length; d != end; d++ {
|
|
||||||
dst[d] = dst[d-offset]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if d != dLen {
|
|
||||||
return nil, ErrCorrupt
|
|
||||||
}
|
|
||||||
return dst[:d], nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewReader returns a new Reader that decompresses from r, using the framing
|
|
||||||
// format described at
|
|
||||||
// https://github.com/google/snappy/blob/master/framing_format.txt
|
|
||||||
func NewReader(r io.Reader) *Reader {
|
|
||||||
return &Reader{
|
|
||||||
r: r,
|
|
||||||
decoded: make([]byte, maxUncompressedChunkLen),
|
|
||||||
buf: make([]byte, MaxEncodedLen(maxUncompressedChunkLen)+checksumSize),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reader is an io.Reader that can read Snappy-compressed bytes.
|
|
||||||
type Reader struct {
|
|
||||||
r io.Reader
|
|
||||||
err error
|
|
||||||
decoded []byte
|
|
||||||
buf []byte
|
|
||||||
// decoded[i:j] contains decoded bytes that have not yet been passed on.
|
|
||||||
i, j int
|
|
||||||
readHeader bool
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reset discards any buffered data, resets all state, and switches the Snappy
|
|
||||||
// reader to read from r. This permits reusing a Reader rather than allocating
|
|
||||||
// a new one.
|
|
||||||
func (r *Reader) Reset(reader io.Reader) {
|
|
||||||
r.r = reader
|
|
||||||
r.err = nil
|
|
||||||
r.i = 0
|
|
||||||
r.j = 0
|
|
||||||
r.readHeader = false
|
|
||||||
}
|
|
||||||
|
|
||||||
func (r *Reader) readFull(p []byte) (ok bool) {
|
|
||||||
if _, r.err = io.ReadFull(r.r, p); r.err != nil {
|
|
||||||
if r.err == io.ErrUnexpectedEOF {
|
|
||||||
r.err = ErrCorrupt
|
|
||||||
}
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
// Read satisfies the io.Reader interface.
|
|
||||||
func (r *Reader) Read(p []byte) (int, error) {
|
|
||||||
if r.err != nil {
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
for {
|
|
||||||
if r.i < r.j {
|
|
||||||
n := copy(p, r.decoded[r.i:r.j])
|
|
||||||
r.i += n
|
|
||||||
return n, nil
|
|
||||||
}
|
|
||||||
if !r.readFull(r.buf[:4]) {
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
chunkType := r.buf[0]
|
|
||||||
if !r.readHeader {
|
|
||||||
if chunkType != chunkTypeStreamIdentifier {
|
|
||||||
r.err = ErrCorrupt
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
r.readHeader = true
|
|
||||||
}
|
|
||||||
chunkLen := int(r.buf[1]) | int(r.buf[2])<<8 | int(r.buf[3])<<16
|
|
||||||
if chunkLen > len(r.buf) {
|
|
||||||
r.err = ErrUnsupported
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
|
|
||||||
// The chunk types are specified at
|
|
||||||
// https://github.com/google/snappy/blob/master/framing_format.txt
|
|
||||||
switch chunkType {
|
|
||||||
case chunkTypeCompressedData:
|
|
||||||
// Section 4.2. Compressed data (chunk type 0x00).
|
|
||||||
if chunkLen < checksumSize {
|
|
||||||
r.err = ErrCorrupt
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
buf := r.buf[:chunkLen]
|
|
||||||
if !r.readFull(buf) {
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
checksum := uint32(buf[0]) | uint32(buf[1])<<8 | uint32(buf[2])<<16 | uint32(buf[3])<<24
|
|
||||||
buf = buf[checksumSize:]
|
|
||||||
|
|
||||||
n, err := DecodedLen(buf)
|
|
||||||
if err != nil {
|
|
||||||
r.err = err
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
if n > len(r.decoded) {
|
|
||||||
r.err = ErrCorrupt
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
if _, err := Decode(r.decoded, buf); err != nil {
|
|
||||||
r.err = err
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
if crc(r.decoded[:n]) != checksum {
|
|
||||||
r.err = ErrCorrupt
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
r.i, r.j = 0, n
|
|
||||||
continue
|
|
||||||
|
|
||||||
case chunkTypeUncompressedData:
|
|
||||||
// Section 4.3. Uncompressed data (chunk type 0x01).
|
|
||||||
if chunkLen < checksumSize {
|
|
||||||
r.err = ErrCorrupt
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
buf := r.buf[:checksumSize]
|
|
||||||
if !r.readFull(buf) {
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
checksum := uint32(buf[0]) | uint32(buf[1])<<8 | uint32(buf[2])<<16 | uint32(buf[3])<<24
|
|
||||||
// Read directly into r.decoded instead of via r.buf.
|
|
||||||
n := chunkLen - checksumSize
|
|
||||||
if !r.readFull(r.decoded[:n]) {
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
if crc(r.decoded[:n]) != checksum {
|
|
||||||
r.err = ErrCorrupt
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
r.i, r.j = 0, n
|
|
||||||
continue
|
|
||||||
|
|
||||||
case chunkTypeStreamIdentifier:
|
|
||||||
// Section 4.1. Stream identifier (chunk type 0xff).
|
|
||||||
if chunkLen != len(magicBody) {
|
|
||||||
r.err = ErrCorrupt
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
if !r.readFull(r.buf[:len(magicBody)]) {
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
for i := 0; i < len(magicBody); i++ {
|
|
||||||
if r.buf[i] != magicBody[i] {
|
|
||||||
r.err = ErrCorrupt
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
if chunkType <= 0x7f {
|
|
||||||
// Section 4.5. Reserved unskippable chunks (chunk types 0x02-0x7f).
|
|
||||||
r.err = ErrUnsupported
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
// Section 4.4 Padding (chunk type 0xfe).
|
|
||||||
// Section 4.6. Reserved skippable chunks (chunk types 0x80-0xfd).
|
|
||||||
if !r.readFull(r.buf[:chunkLen]) {
|
|
||||||
return 0, r.err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
356
vendor/github.com/golang/snappy/encode.go
generated
vendored
356
vendor/github.com/golang/snappy/encode.go
generated
vendored
@ -1,356 +0,0 @@
|
|||||||
// Copyright 2011 The Snappy-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 snappy
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/binary"
|
|
||||||
"errors"
|
|
||||||
"io"
|
|
||||||
)
|
|
||||||
|
|
||||||
// We limit how far copy back-references can go, the same as the C++ code.
|
|
||||||
const maxOffset = 1 << 15
|
|
||||||
|
|
||||||
// emitLiteral writes a literal chunk and returns the number of bytes written.
|
|
||||||
func emitLiteral(dst, lit []byte) int {
|
|
||||||
i, n := 0, uint(len(lit)-1)
|
|
||||||
switch {
|
|
||||||
case n < 60:
|
|
||||||
dst[0] = uint8(n)<<2 | tagLiteral
|
|
||||||
i = 1
|
|
||||||
case n < 1<<8:
|
|
||||||
dst[0] = 60<<2 | tagLiteral
|
|
||||||
dst[1] = uint8(n)
|
|
||||||
i = 2
|
|
||||||
case n < 1<<16:
|
|
||||||
dst[0] = 61<<2 | tagLiteral
|
|
||||||
dst[1] = uint8(n)
|
|
||||||
dst[2] = uint8(n >> 8)
|
|
||||||
i = 3
|
|
||||||
case n < 1<<24:
|
|
||||||
dst[0] = 62<<2 | tagLiteral
|
|
||||||
dst[1] = uint8(n)
|
|
||||||
dst[2] = uint8(n >> 8)
|
|
||||||
dst[3] = uint8(n >> 16)
|
|
||||||
i = 4
|
|
||||||
case int64(n) < 1<<32:
|
|
||||||
dst[0] = 63<<2 | tagLiteral
|
|
||||||
dst[1] = uint8(n)
|
|
||||||
dst[2] = uint8(n >> 8)
|
|
||||||
dst[3] = uint8(n >> 16)
|
|
||||||
dst[4] = uint8(n >> 24)
|
|
||||||
i = 5
|
|
||||||
default:
|
|
||||||
panic("snappy: source buffer is too long")
|
|
||||||
}
|
|
||||||
if copy(dst[i:], lit) != len(lit) {
|
|
||||||
panic("snappy: destination buffer is too short")
|
|
||||||
}
|
|
||||||
return i + len(lit)
|
|
||||||
}
|
|
||||||
|
|
||||||
// emitCopy writes a copy chunk and returns the number of bytes written.
|
|
||||||
func emitCopy(dst []byte, offset, length int) int {
|
|
||||||
i := 0
|
|
||||||
for length > 0 {
|
|
||||||
x := length - 4
|
|
||||||
if 0 <= x && x < 1<<3 && offset < 1<<11 {
|
|
||||||
dst[i+0] = uint8(offset>>8)&0x07<<5 | uint8(x)<<2 | tagCopy1
|
|
||||||
dst[i+1] = uint8(offset)
|
|
||||||
i += 2
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
x = length
|
|
||||||
if x > 1<<6 {
|
|
||||||
x = 1 << 6
|
|
||||||
}
|
|
||||||
dst[i+0] = uint8(x-1)<<2 | tagCopy2
|
|
||||||
dst[i+1] = uint8(offset)
|
|
||||||
dst[i+2] = uint8(offset >> 8)
|
|
||||||
i += 3
|
|
||||||
length -= x
|
|
||||||
}
|
|
||||||
return i
|
|
||||||
}
|
|
||||||
|
|
||||||
// Encode returns the encoded form of src. The returned slice may be a sub-
|
|
||||||
// slice of dst if dst was large enough to hold the entire encoded block.
|
|
||||||
// Otherwise, a newly allocated slice will be returned.
|
|
||||||
// It is valid to pass a nil dst.
|
|
||||||
func Encode(dst, src []byte) []byte {
|
|
||||||
if n := MaxEncodedLen(len(src)); len(dst) < n {
|
|
||||||
dst = make([]byte, n)
|
|
||||||
}
|
|
||||||
|
|
||||||
// The block starts with the varint-encoded length of the decompressed bytes.
|
|
||||||
d := binary.PutUvarint(dst, uint64(len(src)))
|
|
||||||
|
|
||||||
// Return early if src is short.
|
|
||||||
if len(src) <= 4 {
|
|
||||||
if len(src) != 0 {
|
|
||||||
d += emitLiteral(dst[d:], src)
|
|
||||||
}
|
|
||||||
return dst[:d]
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize the hash table. Its size ranges from 1<<8 to 1<<14 inclusive.
|
|
||||||
const maxTableSize = 1 << 14
|
|
||||||
shift, tableSize := uint(32-8), 1<<8
|
|
||||||
for tableSize < maxTableSize && tableSize < len(src) {
|
|
||||||
shift--
|
|
||||||
tableSize *= 2
|
|
||||||
}
|
|
||||||
var table [maxTableSize]int
|
|
||||||
|
|
||||||
// Iterate over the source bytes.
|
|
||||||
var (
|
|
||||||
s int // The iterator position.
|
|
||||||
t int // The last position with the same hash as s.
|
|
||||||
lit int // The start position of any pending literal bytes.
|
|
||||||
)
|
|
||||||
for uint(s+3) < uint(len(src)) { // The uint conversions catch overflow from the +3.
|
|
||||||
// Update the hash table.
|
|
||||||
b0, b1, b2, b3 := src[s], src[s+1], src[s+2], src[s+3]
|
|
||||||
h := uint32(b0) | uint32(b1)<<8 | uint32(b2)<<16 | uint32(b3)<<24
|
|
||||||
p := &table[(h*0x1e35a7bd)>>shift]
|
|
||||||
// We need to to store values in [-1, inf) in table. To save
|
|
||||||
// some initialization time, (re)use the table's zero value
|
|
||||||
// and shift the values against this zero: add 1 on writes,
|
|
||||||
// subtract 1 on reads.
|
|
||||||
t, *p = *p-1, s+1
|
|
||||||
// If t is invalid or src[s:s+4] differs from src[t:t+4], accumulate a literal byte.
|
|
||||||
if t < 0 || s-t >= maxOffset || b0 != src[t] || b1 != src[t+1] || b2 != src[t+2] || b3 != src[t+3] {
|
|
||||||
// Skip multiple bytes if the last match was >= 32 bytes prior.
|
|
||||||
s += 1 + (s-lit)>>5
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
// Otherwise, we have a match. First, emit any pending literal bytes.
|
|
||||||
if lit != s {
|
|
||||||
d += emitLiteral(dst[d:], src[lit:s])
|
|
||||||
}
|
|
||||||
// Extend the match to be as long as possible.
|
|
||||||
s0 := s
|
|
||||||
s, t = s+4, t+4
|
|
||||||
for s < len(src) && src[s] == src[t] {
|
|
||||||
s++
|
|
||||||
t++
|
|
||||||
}
|
|
||||||
// Emit the copied bytes.
|
|
||||||
d += emitCopy(dst[d:], s-t, s-s0)
|
|
||||||
lit = s
|
|
||||||
}
|
|
||||||
|
|
||||||
// Emit any final pending literal bytes and return.
|
|
||||||
if lit != len(src) {
|
|
||||||
d += emitLiteral(dst[d:], src[lit:])
|
|
||||||
}
|
|
||||||
return dst[:d]
|
|
||||||
}
|
|
||||||
|
|
||||||
// MaxEncodedLen returns the maximum length of a snappy block, given its
|
|
||||||
// uncompressed length.
|
|
||||||
func MaxEncodedLen(srcLen int) int {
|
|
||||||
// Compressed data can be defined as:
|
|
||||||
// compressed := item* literal*
|
|
||||||
// item := literal* copy
|
|
||||||
//
|
|
||||||
// The trailing literal sequence has a space blowup of at most 62/60
|
|
||||||
// since a literal of length 60 needs one tag byte + one extra byte
|
|
||||||
// for length information.
|
|
||||||
//
|
|
||||||
// Item blowup is trickier to measure. Suppose the "copy" op copies
|
|
||||||
// 4 bytes of data. Because of a special check in the encoding code,
|
|
||||||
// we produce a 4-byte copy only if the offset is < 65536. Therefore
|
|
||||||
// the copy op takes 3 bytes to encode, and this type of item leads
|
|
||||||
// to at most the 62/60 blowup for representing literals.
|
|
||||||
//
|
|
||||||
// Suppose the "copy" op copies 5 bytes of data. If the offset is big
|
|
||||||
// enough, it will take 5 bytes to encode the copy op. Therefore the
|
|
||||||
// worst case here is a one-byte literal followed by a five-byte copy.
|
|
||||||
// That is, 6 bytes of input turn into 7 bytes of "compressed" data.
|
|
||||||
//
|
|
||||||
// This last factor dominates the blowup, so the final estimate is:
|
|
||||||
return 32 + srcLen + srcLen/6
|
|
||||||
}
|
|
||||||
|
|
||||||
var errClosed = errors.New("snappy: Writer is closed")
|
|
||||||
|
|
||||||
// NewWriter returns a new Writer that compresses to w.
|
|
||||||
//
|
|
||||||
// The Writer returned does not buffer writes. There is no need to Flush or
|
|
||||||
// Close such a Writer.
|
|
||||||
//
|
|
||||||
// Deprecated: the Writer returned is not suitable for many small writes, only
|
|
||||||
// for few large writes. Use NewBufferedWriter instead, which is efficient
|
|
||||||
// regardless of the frequency and shape of the writes, and remember to Close
|
|
||||||
// that Writer when done.
|
|
||||||
func NewWriter(w io.Writer) *Writer {
|
|
||||||
return &Writer{
|
|
||||||
w: w,
|
|
||||||
obuf: make([]byte, obufLen),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewBufferedWriter returns a new Writer that compresses to w, using the
|
|
||||||
// framing format described at
|
|
||||||
// https://github.com/google/snappy/blob/master/framing_format.txt
|
|
||||||
//
|
|
||||||
// The Writer returned buffers writes. Users must call Close to guarantee all
|
|
||||||
// data has been forwarded to the underlying io.Writer. They may also call
|
|
||||||
// Flush zero or more times before calling Close.
|
|
||||||
func NewBufferedWriter(w io.Writer) *Writer {
|
|
||||||
return &Writer{
|
|
||||||
w: w,
|
|
||||||
ibuf: make([]byte, 0, maxUncompressedChunkLen),
|
|
||||||
obuf: make([]byte, obufLen),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Writer is an io.Writer than can write Snappy-compressed bytes.
|
|
||||||
type Writer struct {
|
|
||||||
w io.Writer
|
|
||||||
err error
|
|
||||||
|
|
||||||
// ibuf is a buffer for the incoming (uncompressed) bytes.
|
|
||||||
//
|
|
||||||
// Its use is optional. For backwards compatibility, Writers created by the
|
|
||||||
// NewWriter function have ibuf == nil, do not buffer incoming bytes, and
|
|
||||||
// therefore do not need to be Flush'ed or Close'd.
|
|
||||||
ibuf []byte
|
|
||||||
|
|
||||||
// obuf is a buffer for the outgoing (compressed) bytes.
|
|
||||||
obuf []byte
|
|
||||||
|
|
||||||
// wroteStreamHeader is whether we have written the stream header.
|
|
||||||
wroteStreamHeader bool
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reset discards the writer's state and switches the Snappy writer to write to
|
|
||||||
// w. This permits reusing a Writer rather than allocating a new one.
|
|
||||||
func (w *Writer) Reset(writer io.Writer) {
|
|
||||||
w.w = writer
|
|
||||||
w.err = nil
|
|
||||||
if w.ibuf != nil {
|
|
||||||
w.ibuf = w.ibuf[:0]
|
|
||||||
}
|
|
||||||
w.wroteStreamHeader = false
|
|
||||||
}
|
|
||||||
|
|
||||||
// Write satisfies the io.Writer interface.
|
|
||||||
func (w *Writer) Write(p []byte) (nRet int, errRet error) {
|
|
||||||
if w.ibuf == nil {
|
|
||||||
// Do not buffer incoming bytes. This does not perform or compress well
|
|
||||||
// if the caller of Writer.Write writes many small slices. This
|
|
||||||
// behavior is therefore deprecated, but still supported for backwards
|
|
||||||
// compatibility with code that doesn't explicitly Flush or Close.
|
|
||||||
return w.write(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
// The remainder of this method is based on bufio.Writer.Write from the
|
|
||||||
// standard library.
|
|
||||||
|
|
||||||
for len(p) > (cap(w.ibuf)-len(w.ibuf)) && w.err == nil {
|
|
||||||
var n int
|
|
||||||
if len(w.ibuf) == 0 {
|
|
||||||
// Large write, empty buffer.
|
|
||||||
// Write directly from p to avoid copy.
|
|
||||||
n, _ = w.write(p)
|
|
||||||
} else {
|
|
||||||
n = copy(w.ibuf[len(w.ibuf):cap(w.ibuf)], p)
|
|
||||||
w.ibuf = w.ibuf[:len(w.ibuf)+n]
|
|
||||||
w.Flush()
|
|
||||||
}
|
|
||||||
nRet += n
|
|
||||||
p = p[n:]
|
|
||||||
}
|
|
||||||
if w.err != nil {
|
|
||||||
return nRet, w.err
|
|
||||||
}
|
|
||||||
n := copy(w.ibuf[len(w.ibuf):cap(w.ibuf)], p)
|
|
||||||
w.ibuf = w.ibuf[:len(w.ibuf)+n]
|
|
||||||
nRet += n
|
|
||||||
return nRet, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (w *Writer) write(p []byte) (nRet int, errRet error) {
|
|
||||||
if w.err != nil {
|
|
||||||
return 0, w.err
|
|
||||||
}
|
|
||||||
for len(p) > 0 {
|
|
||||||
obufStart := len(magicChunk)
|
|
||||||
if !w.wroteStreamHeader {
|
|
||||||
w.wroteStreamHeader = true
|
|
||||||
copy(w.obuf, magicChunk)
|
|
||||||
obufStart = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
var uncompressed []byte
|
|
||||||
if len(p) > maxUncompressedChunkLen {
|
|
||||||
uncompressed, p = p[:maxUncompressedChunkLen], p[maxUncompressedChunkLen:]
|
|
||||||
} else {
|
|
||||||
uncompressed, p = p, nil
|
|
||||||
}
|
|
||||||
checksum := crc(uncompressed)
|
|
||||||
|
|
||||||
// Compress the buffer, discarding the result if the improvement
|
|
||||||
// isn't at least 12.5%.
|
|
||||||
compressed := Encode(w.obuf[obufHeaderLen:], uncompressed)
|
|
||||||
chunkType := uint8(chunkTypeCompressedData)
|
|
||||||
chunkLen := 4 + len(compressed)
|
|
||||||
obufEnd := obufHeaderLen + len(compressed)
|
|
||||||
if len(compressed) >= len(uncompressed)-len(uncompressed)/8 {
|
|
||||||
chunkType = chunkTypeUncompressedData
|
|
||||||
chunkLen = 4 + len(uncompressed)
|
|
||||||
obufEnd = obufHeaderLen
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fill in the per-chunk header that comes before the body.
|
|
||||||
w.obuf[len(magicChunk)+0] = chunkType
|
|
||||||
w.obuf[len(magicChunk)+1] = uint8(chunkLen >> 0)
|
|
||||||
w.obuf[len(magicChunk)+2] = uint8(chunkLen >> 8)
|
|
||||||
w.obuf[len(magicChunk)+3] = uint8(chunkLen >> 16)
|
|
||||||
w.obuf[len(magicChunk)+4] = uint8(checksum >> 0)
|
|
||||||
w.obuf[len(magicChunk)+5] = uint8(checksum >> 8)
|
|
||||||
w.obuf[len(magicChunk)+6] = uint8(checksum >> 16)
|
|
||||||
w.obuf[len(magicChunk)+7] = uint8(checksum >> 24)
|
|
||||||
|
|
||||||
if _, err := w.w.Write(w.obuf[obufStart:obufEnd]); err != nil {
|
|
||||||
w.err = err
|
|
||||||
return nRet, err
|
|
||||||
}
|
|
||||||
if chunkType == chunkTypeUncompressedData {
|
|
||||||
if _, err := w.w.Write(uncompressed); err != nil {
|
|
||||||
w.err = err
|
|
||||||
return nRet, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
nRet += len(uncompressed)
|
|
||||||
}
|
|
||||||
return nRet, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Flush flushes the Writer to its underlying io.Writer.
|
|
||||||
func (w *Writer) Flush() error {
|
|
||||||
if w.err != nil {
|
|
||||||
return w.err
|
|
||||||
}
|
|
||||||
if len(w.ibuf) == 0 {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
w.write(w.ibuf)
|
|
||||||
w.ibuf = w.ibuf[:0]
|
|
||||||
return w.err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Close calls Flush and then closes the Writer.
|
|
||||||
func (w *Writer) Close() error {
|
|
||||||
w.Flush()
|
|
||||||
ret := w.err
|
|
||||||
if w.err == nil {
|
|
||||||
w.err = errClosed
|
|
||||||
}
|
|
||||||
return ret
|
|
||||||
}
|
|
77
vendor/github.com/golang/snappy/snappy.go
generated
vendored
77
vendor/github.com/golang/snappy/snappy.go
generated
vendored
@ -1,77 +0,0 @@
|
|||||||
// Copyright 2011 The Snappy-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 snappy implements the snappy block-based compression format.
|
|
||||||
// It aims for very high speeds and reasonable compression.
|
|
||||||
//
|
|
||||||
// The C++ snappy implementation is at https://github.com/google/snappy
|
|
||||||
package snappy // import "github.com/golang/snappy"
|
|
||||||
|
|
||||||
import (
|
|
||||||
"hash/crc32"
|
|
||||||
)
|
|
||||||
|
|
||||||
/*
|
|
||||||
Each encoded block begins with the varint-encoded length of the decoded data,
|
|
||||||
followed by a sequence of chunks. Chunks begin and end on byte boundaries. The
|
|
||||||
first byte of each chunk is broken into its 2 least and 6 most significant bits
|
|
||||||
called l and m: l ranges in [0, 4) and m ranges in [0, 64). l is the chunk tag.
|
|
||||||
Zero means a literal tag. All other values mean a copy tag.
|
|
||||||
|
|
||||||
For literal tags:
|
|
||||||
- If m < 60, the next 1 + m bytes are literal bytes.
|
|
||||||
- Otherwise, let n be the little-endian unsigned integer denoted by the next
|
|
||||||
m - 59 bytes. The next 1 + n bytes after that are literal bytes.
|
|
||||||
|
|
||||||
For copy tags, length bytes are copied from offset bytes ago, in the style of
|
|
||||||
Lempel-Ziv compression algorithms. In particular:
|
|
||||||
- For l == 1, the offset ranges in [0, 1<<11) and the length in [4, 12).
|
|
||||||
The length is 4 + the low 3 bits of m. The high 3 bits of m form bits 8-10
|
|
||||||
of the offset. The next byte is bits 0-7 of the offset.
|
|
||||||
- For l == 2, the offset ranges in [0, 1<<16) and the length in [1, 65).
|
|
||||||
The length is 1 + m. The offset is the little-endian unsigned integer
|
|
||||||
denoted by the next 2 bytes.
|
|
||||||
- For l == 3, this tag is a legacy format that is no longer supported.
|
|
||||||
*/
|
|
||||||
const (
|
|
||||||
tagLiteral = 0x00
|
|
||||||
tagCopy1 = 0x01
|
|
||||||
tagCopy2 = 0x02
|
|
||||||
tagCopy4 = 0x03
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
checksumSize = 4
|
|
||||||
chunkHeaderSize = 4
|
|
||||||
magicChunk = "\xff\x06\x00\x00" + magicBody
|
|
||||||
magicBody = "sNaPpY"
|
|
||||||
// https://github.com/google/snappy/blob/master/framing_format.txt says
|
|
||||||
// that "the uncompressed data in a chunk must be no longer than 65536 bytes".
|
|
||||||
maxUncompressedChunkLen = 65536
|
|
||||||
|
|
||||||
// maxEncodedLenOfMaxUncompressedChunkLen equals
|
|
||||||
// MaxEncodedLen(maxUncompressedChunkLen), but is hard coded to be a const
|
|
||||||
// instead of a variable, so that obufLen can also be a const. Their
|
|
||||||
// equivalence is confirmed by TestMaxEncodedLenOfMaxUncompressedChunkLen.
|
|
||||||
maxEncodedLenOfMaxUncompressedChunkLen = 76490
|
|
||||||
|
|
||||||
obufHeaderLen = len(magicChunk) + checksumSize + chunkHeaderSize
|
|
||||||
obufLen = obufHeaderLen + maxEncodedLenOfMaxUncompressedChunkLen
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
chunkTypeCompressedData = 0x00
|
|
||||||
chunkTypeUncompressedData = 0x01
|
|
||||||
chunkTypePadding = 0xfe
|
|
||||||
chunkTypeStreamIdentifier = 0xff
|
|
||||||
)
|
|
||||||
|
|
||||||
var crcTable = crc32.MakeTable(crc32.Castagnoli)
|
|
||||||
|
|
||||||
// crc implements the checksum specified in section 3 of
|
|
||||||
// https://github.com/google/snappy/blob/master/framing_format.txt
|
|
||||||
func crc(b []byte) uint32 {
|
|
||||||
c := crc32.Update(0, crcTable, b)
|
|
||||||
return uint32(c>>15|c<<17) + 0xa282ead8
|
|
||||||
}
|
|
689
vendor/github.com/golang/snappy/snappy_test.go
generated
vendored
689
vendor/github.com/golang/snappy/snappy_test.go
generated
vendored
@ -1,689 +0,0 @@
|
|||||||
// Copyright 2011 The Snappy-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 snappy
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"flag"
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"io/ioutil"
|
|
||||||
"math/rand"
|
|
||||||
"net/http"
|
|
||||||
"os"
|
|
||||||
"path/filepath"
|
|
||||||
"strings"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
download = flag.Bool("download", false, "If true, download any missing files before running benchmarks")
|
|
||||||
testdata = flag.String("testdata", "testdata", "Directory containing the test data")
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestMaxEncodedLenOfMaxUncompressedChunkLen(t *testing.T) {
|
|
||||||
got := maxEncodedLenOfMaxUncompressedChunkLen
|
|
||||||
want := MaxEncodedLen(maxUncompressedChunkLen)
|
|
||||||
if got != want {
|
|
||||||
t.Fatalf("got %d, want %d", got, want)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func roundtrip(b, ebuf, dbuf []byte) error {
|
|
||||||
d, err := Decode(dbuf, Encode(ebuf, b))
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("decoding error: %v", err)
|
|
||||||
}
|
|
||||||
if !bytes.Equal(b, d) {
|
|
||||||
return fmt.Errorf("roundtrip mismatch:\n\twant %v\n\tgot %v", b, d)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmpty(t *testing.T) {
|
|
||||||
if err := roundtrip(nil, nil, nil); err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSmallCopy(t *testing.T) {
|
|
||||||
for _, ebuf := range [][]byte{nil, make([]byte, 20), make([]byte, 64)} {
|
|
||||||
for _, dbuf := range [][]byte{nil, make([]byte, 20), make([]byte, 64)} {
|
|
||||||
for i := 0; i < 32; i++ {
|
|
||||||
s := "aaaa" + strings.Repeat("b", i) + "aaaabbbb"
|
|
||||||
if err := roundtrip([]byte(s), ebuf, dbuf); err != nil {
|
|
||||||
t.Errorf("len(ebuf)=%d, len(dbuf)=%d, i=%d: %v", len(ebuf), len(dbuf), i, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSmallRand(t *testing.T) {
|
|
||||||
rng := rand.New(rand.NewSource(1))
|
|
||||||
for n := 1; n < 20000; n += 23 {
|
|
||||||
b := make([]byte, n)
|
|
||||||
for i := range b {
|
|
||||||
b[i] = uint8(rng.Uint32())
|
|
||||||
}
|
|
||||||
if err := roundtrip(b, nil, nil); err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSmallRegular(t *testing.T) {
|
|
||||||
for n := 1; n < 20000; n += 23 {
|
|
||||||
b := make([]byte, n)
|
|
||||||
for i := range b {
|
|
||||||
b[i] = uint8(i%10 + 'a')
|
|
||||||
}
|
|
||||||
if err := roundtrip(b, nil, nil); err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestInvalidVarint(t *testing.T) {
|
|
||||||
data := []byte("\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\x00")
|
|
||||||
if _, err := DecodedLen(data); err != ErrCorrupt {
|
|
||||||
t.Errorf("DecodedLen: got %v, want ErrCorrupt", err)
|
|
||||||
}
|
|
||||||
if _, err := Decode(nil, data); err != ErrCorrupt {
|
|
||||||
t.Errorf("Decode: got %v, want ErrCorrupt", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// The encoded varint overflows 32 bits
|
|
||||||
data = []byte("\xff\xff\xff\xff\xff\x00")
|
|
||||||
|
|
||||||
if _, err := DecodedLen(data); err != ErrCorrupt {
|
|
||||||
t.Errorf("DecodedLen: got %v, want ErrCorrupt", err)
|
|
||||||
}
|
|
||||||
if _, err := Decode(nil, data); err != ErrCorrupt {
|
|
||||||
t.Errorf("Decode: got %v, want ErrCorrupt", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDecode(t *testing.T) {
|
|
||||||
testCases := []struct {
|
|
||||||
desc string
|
|
||||||
input string
|
|
||||||
want string
|
|
||||||
wantErr error
|
|
||||||
}{{
|
|
||||||
`decodedLen=0x100000000 is too long`,
|
|
||||||
"\x80\x80\x80\x80\x10" + "\x00\x41",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=3; tagLiteral, 0-byte length; length=3; valid input`,
|
|
||||||
"\x03" + "\x08\xff\xff\xff",
|
|
||||||
"\xff\xff\xff",
|
|
||||||
nil,
|
|
||||||
}, {
|
|
||||||
`decodedLen=1; tagLiteral, 1-byte length; not enough length bytes`,
|
|
||||||
"\x01" + "\xf0",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=3; tagLiteral, 1-byte length; length=3; valid input`,
|
|
||||||
"\x03" + "\xf0\x02\xff\xff\xff",
|
|
||||||
"\xff\xff\xff",
|
|
||||||
nil,
|
|
||||||
}, {
|
|
||||||
`decodedLen=1; tagLiteral, 2-byte length; not enough length bytes`,
|
|
||||||
"\x01" + "\xf4\x00",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=3; tagLiteral, 2-byte length; length=3; valid input`,
|
|
||||||
"\x03" + "\xf4\x02\x00\xff\xff\xff",
|
|
||||||
"\xff\xff\xff",
|
|
||||||
nil,
|
|
||||||
}, {
|
|
||||||
`decodedLen=1; tagLiteral, 3-byte length; not enough length bytes`,
|
|
||||||
"\x01" + "\xf8\x00\x00",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=3; tagLiteral, 3-byte length; length=3; valid input`,
|
|
||||||
"\x03" + "\xf8\x02\x00\x00\xff\xff\xff",
|
|
||||||
"\xff\xff\xff",
|
|
||||||
nil,
|
|
||||||
}, {
|
|
||||||
`decodedLen=1; tagLiteral, 4-byte length; not enough length bytes`,
|
|
||||||
"\x01" + "\xfc\x00\x00\x00",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=1; tagLiteral, 4-byte length; length=3; not enough dst bytes`,
|
|
||||||
"\x01" + "\xfc\x02\x00\x00\x00\xff\xff\xff",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=4; tagLiteral, 4-byte length; length=3; not enough src bytes`,
|
|
||||||
"\x04" + "\xfc\x02\x00\x00\x00\xff",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=3; tagLiteral, 4-byte length; length=3; valid input`,
|
|
||||||
"\x03" + "\xfc\x02\x00\x00\x00\xff\xff\xff",
|
|
||||||
"\xff\xff\xff",
|
|
||||||
nil,
|
|
||||||
}, {
|
|
||||||
`decodedLen=4; tagCopy1, 1 extra length|offset byte; not enough extra bytes`,
|
|
||||||
"\x04" + "\x01",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=4; tagCopy2, 2 extra length|offset bytes; not enough extra bytes`,
|
|
||||||
"\x04" + "\x02\x00",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=4; tagCopy4; unsupported COPY_4 tag`,
|
|
||||||
"\x04" + "\x03\x00\x00\x00\x00",
|
|
||||||
"",
|
|
||||||
errUnsupportedCopy4Tag,
|
|
||||||
}, {
|
|
||||||
`decodedLen=4; tagLiteral (4 bytes "abcd"); valid input`,
|
|
||||||
"\x04" + "\x0cabcd",
|
|
||||||
"abcd",
|
|
||||||
nil,
|
|
||||||
}, {
|
|
||||||
`decodedLen=8; tagLiteral (4 bytes "abcd"); tagCopy1; length=4 offset=4; valid input`,
|
|
||||||
"\x08" + "\x0cabcd" + "\x01\x04",
|
|
||||||
"abcdabcd",
|
|
||||||
nil,
|
|
||||||
}, {
|
|
||||||
`decodedLen=9; tagLiteral (4 bytes "abcd"); tagCopy1; length=4 offset=4; inconsistent dLen`,
|
|
||||||
"\x09" + "\x0cabcd" + "\x01\x04",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=8; tagLiteral (4 bytes "abcd"); tagCopy1; length=4 offset=5; offset too large`,
|
|
||||||
"\x08" + "\x0cabcd" + "\x01\x05",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}, {
|
|
||||||
`decodedLen=7; tagLiteral (4 bytes "abcd"); tagCopy1; length=4 offset=4; length too large`,
|
|
||||||
"\x07" + "\x0cabcd" + "\x01\x04",
|
|
||||||
"",
|
|
||||||
ErrCorrupt,
|
|
||||||
}}
|
|
||||||
|
|
||||||
for _, tc := range testCases {
|
|
||||||
g, gotErr := Decode(nil, []byte(tc.input))
|
|
||||||
if got := string(g); got != tc.want || gotErr != tc.wantErr {
|
|
||||||
t.Errorf("%s:\ngot %q, %v\nwant %q, %v", tc.desc, got, gotErr, tc.want, tc.wantErr)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func cmp(a, b []byte) error {
|
|
||||||
if len(a) != len(b) {
|
|
||||||
return fmt.Errorf("got %d bytes, want %d", len(a), len(b))
|
|
||||||
}
|
|
||||||
for i := range a {
|
|
||||||
if a[i] != b[i] {
|
|
||||||
return fmt.Errorf("byte #%d: got 0x%02x, want 0x%02x", i, a[i], b[i])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestFramingFormat(t *testing.T) {
|
|
||||||
// src is comprised of alternating 1e5-sized sequences of random
|
|
||||||
// (incompressible) bytes and repeated (compressible) bytes. 1e5 was chosen
|
|
||||||
// because it is larger than maxUncompressedChunkLen (64k).
|
|
||||||
src := make([]byte, 1e6)
|
|
||||||
rng := rand.New(rand.NewSource(1))
|
|
||||||
for i := 0; i < 10; i++ {
|
|
||||||
if i%2 == 0 {
|
|
||||||
for j := 0; j < 1e5; j++ {
|
|
||||||
src[1e5*i+j] = uint8(rng.Intn(256))
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for j := 0; j < 1e5; j++ {
|
|
||||||
src[1e5*i+j] = uint8(i)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
buf := new(bytes.Buffer)
|
|
||||||
if _, err := NewWriter(buf).Write(src); err != nil {
|
|
||||||
t.Fatalf("Write: encoding: %v", err)
|
|
||||||
}
|
|
||||||
dst, err := ioutil.ReadAll(NewReader(buf))
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("ReadAll: decoding: %v", err)
|
|
||||||
}
|
|
||||||
if err := cmp(dst, src); err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestWriterGoldenOutput(t *testing.T) {
|
|
||||||
buf := new(bytes.Buffer)
|
|
||||||
w := NewBufferedWriter(buf)
|
|
||||||
defer w.Close()
|
|
||||||
w.Write([]byte("abcd")) // Not compressible.
|
|
||||||
w.Flush()
|
|
||||||
w.Write(bytes.Repeat([]byte{'A'}, 100)) // Compressible.
|
|
||||||
w.Flush()
|
|
||||||
got := buf.String()
|
|
||||||
want := strings.Join([]string{
|
|
||||||
magicChunk,
|
|
||||||
"\x01\x08\x00\x00", // Uncompressed chunk, 8 bytes long (including 4 byte checksum).
|
|
||||||
"\x68\x10\xe6\xb6", // Checksum.
|
|
||||||
"\x61\x62\x63\x64", // Uncompressed payload: "abcd".
|
|
||||||
"\x00\x0d\x00\x00", // Compressed chunk, 13 bytes long (including 4 byte checksum).
|
|
||||||
"\x37\xcb\xbc\x9d", // Checksum.
|
|
||||||
"\x64", // Compressed payload: Uncompressed length (varint encoded): 100.
|
|
||||||
"\x00\x41", // Compressed payload: tagLiteral, length=1, "A".
|
|
||||||
"\xfe\x01\x00", // Compressed payload: tagCopy2, length=64, offset=1.
|
|
||||||
"\x8a\x01\x00", // Compressed payload: tagCopy2, length=35, offset=1.
|
|
||||||
}, "")
|
|
||||||
if got != want {
|
|
||||||
t.Fatalf("\ngot: % x\nwant: % x", got, want)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestNewBufferedWriter(t *testing.T) {
|
|
||||||
// Test all 32 possible sub-sequences of these 5 input slices.
|
|
||||||
//
|
|
||||||
// Their lengths sum to 400,000, which is over 6 times the Writer ibuf
|
|
||||||
// capacity: 6 * maxUncompressedChunkLen is 393,216.
|
|
||||||
inputs := [][]byte{
|
|
||||||
bytes.Repeat([]byte{'a'}, 40000),
|
|
||||||
bytes.Repeat([]byte{'b'}, 150000),
|
|
||||||
bytes.Repeat([]byte{'c'}, 60000),
|
|
||||||
bytes.Repeat([]byte{'d'}, 120000),
|
|
||||||
bytes.Repeat([]byte{'e'}, 30000),
|
|
||||||
}
|
|
||||||
loop:
|
|
||||||
for i := 0; i < 1<<uint(len(inputs)); i++ {
|
|
||||||
var want []byte
|
|
||||||
buf := new(bytes.Buffer)
|
|
||||||
w := NewBufferedWriter(buf)
|
|
||||||
for j, input := range inputs {
|
|
||||||
if i&(1<<uint(j)) == 0 {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if _, err := w.Write(input); err != nil {
|
|
||||||
t.Errorf("i=%#02x: j=%d: Write: %v", i, j, err)
|
|
||||||
continue loop
|
|
||||||
}
|
|
||||||
want = append(want, input...)
|
|
||||||
}
|
|
||||||
if err := w.Close(); err != nil {
|
|
||||||
t.Errorf("i=%#02x: Close: %v", i, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
got, err := ioutil.ReadAll(NewReader(buf))
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("i=%#02x: ReadAll: %v", i, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if err := cmp(got, want); err != nil {
|
|
||||||
t.Errorf("i=%#02x: %v", i, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestFlush(t *testing.T) {
|
|
||||||
buf := new(bytes.Buffer)
|
|
||||||
w := NewBufferedWriter(buf)
|
|
||||||
defer w.Close()
|
|
||||||
if _, err := w.Write(bytes.Repeat([]byte{'x'}, 20)); err != nil {
|
|
||||||
t.Fatalf("Write: %v", err)
|
|
||||||
}
|
|
||||||
if n := buf.Len(); n != 0 {
|
|
||||||
t.Fatalf("before Flush: %d bytes were written to the underlying io.Writer, want 0", n)
|
|
||||||
}
|
|
||||||
if err := w.Flush(); err != nil {
|
|
||||||
t.Fatalf("Flush: %v", err)
|
|
||||||
}
|
|
||||||
if n := buf.Len(); n == 0 {
|
|
||||||
t.Fatalf("after Flush: %d bytes were written to the underlying io.Writer, want non-0", n)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestReaderReset(t *testing.T) {
|
|
||||||
gold := bytes.Repeat([]byte("All that is gold does not glitter,\n"), 10000)
|
|
||||||
buf := new(bytes.Buffer)
|
|
||||||
if _, err := NewWriter(buf).Write(gold); err != nil {
|
|
||||||
t.Fatalf("Write: %v", err)
|
|
||||||
}
|
|
||||||
encoded, invalid, partial := buf.String(), "invalid", "partial"
|
|
||||||
r := NewReader(nil)
|
|
||||||
for i, s := range []string{encoded, invalid, partial, encoded, partial, invalid, encoded, encoded} {
|
|
||||||
if s == partial {
|
|
||||||
r.Reset(strings.NewReader(encoded))
|
|
||||||
if _, err := r.Read(make([]byte, 101)); err != nil {
|
|
||||||
t.Errorf("#%d: %v", i, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
r.Reset(strings.NewReader(s))
|
|
||||||
got, err := ioutil.ReadAll(r)
|
|
||||||
switch s {
|
|
||||||
case encoded:
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("#%d: %v", i, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if err := cmp(got, gold); err != nil {
|
|
||||||
t.Errorf("#%d: %v", i, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
case invalid:
|
|
||||||
if err == nil {
|
|
||||||
t.Errorf("#%d: got nil error, want non-nil", i)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestWriterReset(t *testing.T) {
|
|
||||||
gold := bytes.Repeat([]byte("Not all those who wander are lost;\n"), 10000)
|
|
||||||
const n = 20
|
|
||||||
for _, buffered := range []bool{false, true} {
|
|
||||||
var w *Writer
|
|
||||||
if buffered {
|
|
||||||
w = NewBufferedWriter(nil)
|
|
||||||
defer w.Close()
|
|
||||||
} else {
|
|
||||||
w = NewWriter(nil)
|
|
||||||
}
|
|
||||||
|
|
||||||
var gots, wants [][]byte
|
|
||||||
failed := false
|
|
||||||
for i := 0; i <= n; i++ {
|
|
||||||
buf := new(bytes.Buffer)
|
|
||||||
w.Reset(buf)
|
|
||||||
want := gold[:len(gold)*i/n]
|
|
||||||
if _, err := w.Write(want); err != nil {
|
|
||||||
t.Errorf("#%d: Write: %v", i, err)
|
|
||||||
failed = true
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if buffered {
|
|
||||||
if err := w.Flush(); err != nil {
|
|
||||||
t.Errorf("#%d: Flush: %v", i, err)
|
|
||||||
failed = true
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
}
|
|
||||||
got, err := ioutil.ReadAll(NewReader(buf))
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("#%d: ReadAll: %v", i, err)
|
|
||||||
failed = true
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
gots = append(gots, got)
|
|
||||||
wants = append(wants, want)
|
|
||||||
}
|
|
||||||
if failed {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
for i := range gots {
|
|
||||||
if err := cmp(gots[i], wants[i]); err != nil {
|
|
||||||
t.Errorf("#%d: %v", i, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestWriterResetWithoutFlush(t *testing.T) {
|
|
||||||
buf0 := new(bytes.Buffer)
|
|
||||||
buf1 := new(bytes.Buffer)
|
|
||||||
w := NewBufferedWriter(buf0)
|
|
||||||
if _, err := w.Write([]byte("xxx")); err != nil {
|
|
||||||
t.Fatalf("Write #0: %v", err)
|
|
||||||
}
|
|
||||||
// Note that we don't Flush the Writer before calling Reset.
|
|
||||||
w.Reset(buf1)
|
|
||||||
if _, err := w.Write([]byte("yyy")); err != nil {
|
|
||||||
t.Fatalf("Write #1: %v", err)
|
|
||||||
}
|
|
||||||
if err := w.Flush(); err != nil {
|
|
||||||
t.Fatalf("Flush: %v", err)
|
|
||||||
}
|
|
||||||
got, err := ioutil.ReadAll(NewReader(buf1))
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("ReadAll: %v", err)
|
|
||||||
}
|
|
||||||
if err := cmp(got, []byte("yyy")); err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
type writeCounter int
|
|
||||||
|
|
||||||
func (c *writeCounter) Write(p []byte) (int, error) {
|
|
||||||
*c++
|
|
||||||
return len(p), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// TestNumUnderlyingWrites tests that each Writer flush only makes one or two
|
|
||||||
// Write calls on its underlying io.Writer, depending on whether or not the
|
|
||||||
// flushed buffer was compressible.
|
|
||||||
func TestNumUnderlyingWrites(t *testing.T) {
|
|
||||||
testCases := []struct {
|
|
||||||
input []byte
|
|
||||||
want int
|
|
||||||
}{
|
|
||||||
{bytes.Repeat([]byte{'x'}, 100), 1},
|
|
||||||
{bytes.Repeat([]byte{'y'}, 100), 1},
|
|
||||||
{[]byte("ABCDEFGHIJKLMNOPQRST"), 2},
|
|
||||||
}
|
|
||||||
|
|
||||||
var c writeCounter
|
|
||||||
w := NewBufferedWriter(&c)
|
|
||||||
defer w.Close()
|
|
||||||
for i, tc := range testCases {
|
|
||||||
c = 0
|
|
||||||
if _, err := w.Write(tc.input); err != nil {
|
|
||||||
t.Errorf("#%d: Write: %v", i, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if err := w.Flush(); err != nil {
|
|
||||||
t.Errorf("#%d: Flush: %v", i, err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if int(c) != tc.want {
|
|
||||||
t.Errorf("#%d: got %d underlying writes, want %d", i, c, tc.want)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func benchDecode(b *testing.B, src []byte) {
|
|
||||||
encoded := Encode(nil, src)
|
|
||||||
// Bandwidth is in amount of uncompressed data.
|
|
||||||
b.SetBytes(int64(len(src)))
|
|
||||||
b.ResetTimer()
|
|
||||||
for i := 0; i < b.N; i++ {
|
|
||||||
Decode(src, encoded)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func benchEncode(b *testing.B, src []byte) {
|
|
||||||
// Bandwidth is in amount of uncompressed data.
|
|
||||||
b.SetBytes(int64(len(src)))
|
|
||||||
dst := make([]byte, MaxEncodedLen(len(src)))
|
|
||||||
b.ResetTimer()
|
|
||||||
for i := 0; i < b.N; i++ {
|
|
||||||
Encode(dst, src)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func readFile(b testing.TB, filename string) []byte {
|
|
||||||
src, err := ioutil.ReadFile(filename)
|
|
||||||
if err != nil {
|
|
||||||
b.Skipf("skipping benchmark: %v", err)
|
|
||||||
}
|
|
||||||
if len(src) == 0 {
|
|
||||||
b.Fatalf("%s has zero length", filename)
|
|
||||||
}
|
|
||||||
return src
|
|
||||||
}
|
|
||||||
|
|
||||||
// expand returns a slice of length n containing repeated copies of src.
|
|
||||||
func expand(src []byte, n int) []byte {
|
|
||||||
dst := make([]byte, n)
|
|
||||||
for x := dst; len(x) > 0; {
|
|
||||||
i := copy(x, src)
|
|
||||||
x = x[i:]
|
|
||||||
}
|
|
||||||
return dst
|
|
||||||
}
|
|
||||||
|
|
||||||
func benchWords(b *testing.B, n int, decode bool) {
|
|
||||||
// Note: the file is OS-language dependent so the resulting values are not
|
|
||||||
// directly comparable for non-US-English OS installations.
|
|
||||||
data := expand(readFile(b, "/usr/share/dict/words"), n)
|
|
||||||
if decode {
|
|
||||||
benchDecode(b, data)
|
|
||||||
} else {
|
|
||||||
benchEncode(b, data)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func BenchmarkWordsDecode1e1(b *testing.B) { benchWords(b, 1e1, true) }
|
|
||||||
func BenchmarkWordsDecode1e2(b *testing.B) { benchWords(b, 1e2, true) }
|
|
||||||
func BenchmarkWordsDecode1e3(b *testing.B) { benchWords(b, 1e3, true) }
|
|
||||||
func BenchmarkWordsDecode1e4(b *testing.B) { benchWords(b, 1e4, true) }
|
|
||||||
func BenchmarkWordsDecode1e5(b *testing.B) { benchWords(b, 1e5, true) }
|
|
||||||
func BenchmarkWordsDecode1e6(b *testing.B) { benchWords(b, 1e6, true) }
|
|
||||||
func BenchmarkWordsEncode1e1(b *testing.B) { benchWords(b, 1e1, false) }
|
|
||||||
func BenchmarkWordsEncode1e2(b *testing.B) { benchWords(b, 1e2, false) }
|
|
||||||
func BenchmarkWordsEncode1e3(b *testing.B) { benchWords(b, 1e3, false) }
|
|
||||||
func BenchmarkWordsEncode1e4(b *testing.B) { benchWords(b, 1e4, false) }
|
|
||||||
func BenchmarkWordsEncode1e5(b *testing.B) { benchWords(b, 1e5, false) }
|
|
||||||
func BenchmarkWordsEncode1e6(b *testing.B) { benchWords(b, 1e6, false) }
|
|
||||||
|
|
||||||
func BenchmarkRandomEncode(b *testing.B) {
|
|
||||||
rng := rand.New(rand.NewSource(1))
|
|
||||||
data := make([]byte, 1<<20)
|
|
||||||
for i := range data {
|
|
||||||
data[i] = uint8(rng.Intn(256))
|
|
||||||
}
|
|
||||||
benchEncode(b, data)
|
|
||||||
}
|
|
||||||
|
|
||||||
// testFiles' values are copied directly from
|
|
||||||
// https://raw.githubusercontent.com/google/snappy/master/snappy_unittest.cc
|
|
||||||
// The label field is unused in snappy-go.
|
|
||||||
//
|
|
||||||
// If this list changes (due to the upstream C++ list changing), remember to
|
|
||||||
// update the .gitignore file in this repository.
|
|
||||||
var testFiles = []struct {
|
|
||||||
label string
|
|
||||||
filename string
|
|
||||||
sizeLimit int
|
|
||||||
}{
|
|
||||||
{"html", "html", 0},
|
|
||||||
{"urls", "urls.10K", 0},
|
|
||||||
{"jpg", "fireworks.jpeg", 0},
|
|
||||||
{"jpg_200", "fireworks.jpeg", 200},
|
|
||||||
{"pdf", "paper-100k.pdf", 0},
|
|
||||||
{"html4", "html_x_4", 0},
|
|
||||||
{"txt1", "alice29.txt", 0},
|
|
||||||
{"txt2", "asyoulik.txt", 0},
|
|
||||||
{"txt3", "lcet10.txt", 0},
|
|
||||||
{"txt4", "plrabn12.txt", 0},
|
|
||||||
{"pb", "geo.protodata", 0},
|
|
||||||
{"gaviota", "kppkn.gtb", 0},
|
|
||||||
}
|
|
||||||
|
|
||||||
// The test data files are present at this canonical URL.
|
|
||||||
const baseURL = "https://raw.githubusercontent.com/google/snappy/master/testdata/"
|
|
||||||
|
|
||||||
func downloadTestdata(b *testing.B, basename string) (errRet error) {
|
|
||||||
filename := filepath.Join(*testdata, basename)
|
|
||||||
if stat, err := os.Stat(filename); err == nil && stat.Size() != 0 {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
if !*download {
|
|
||||||
b.Skipf("test data not found; skipping benchmark without the -download flag")
|
|
||||||
}
|
|
||||||
// Download the official snappy C++ implementation reference test data
|
|
||||||
// files for benchmarking.
|
|
||||||
if err := os.Mkdir(*testdata, 0777); err != nil && !os.IsExist(err) {
|
|
||||||
return fmt.Errorf("failed to create testdata: %s", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
f, err := os.Create(filename)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("failed to create %s: %s", filename, err)
|
|
||||||
}
|
|
||||||
defer f.Close()
|
|
||||||
defer func() {
|
|
||||||
if errRet != nil {
|
|
||||||
os.Remove(filename)
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
url := baseURL + basename
|
|
||||||
resp, err := http.Get(url)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("failed to download %s: %s", url, err)
|
|
||||||
}
|
|
||||||
defer resp.Body.Close()
|
|
||||||
if s := resp.StatusCode; s != http.StatusOK {
|
|
||||||
return fmt.Errorf("downloading %s: HTTP status code %d (%s)", url, s, http.StatusText(s))
|
|
||||||
}
|
|
||||||
_, err = io.Copy(f, resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("failed to download %s to %s: %s", url, filename, err)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func benchFile(b *testing.B, n int, decode bool) {
|
|
||||||
if err := downloadTestdata(b, testFiles[n].filename); err != nil {
|
|
||||||
b.Fatalf("failed to download testdata: %s", err)
|
|
||||||
}
|
|
||||||
data := readFile(b, filepath.Join(*testdata, testFiles[n].filename))
|
|
||||||
if n := testFiles[n].sizeLimit; 0 < n && n < len(data) {
|
|
||||||
data = data[:n]
|
|
||||||
}
|
|
||||||
if decode {
|
|
||||||
benchDecode(b, data)
|
|
||||||
} else {
|
|
||||||
benchEncode(b, data)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Naming convention is kept similar to what snappy's C++ implementation uses.
|
|
||||||
func Benchmark_UFlat0(b *testing.B) { benchFile(b, 0, true) }
|
|
||||||
func Benchmark_UFlat1(b *testing.B) { benchFile(b, 1, true) }
|
|
||||||
func Benchmark_UFlat2(b *testing.B) { benchFile(b, 2, true) }
|
|
||||||
func Benchmark_UFlat3(b *testing.B) { benchFile(b, 3, true) }
|
|
||||||
func Benchmark_UFlat4(b *testing.B) { benchFile(b, 4, true) }
|
|
||||||
func Benchmark_UFlat5(b *testing.B) { benchFile(b, 5, true) }
|
|
||||||
func Benchmark_UFlat6(b *testing.B) { benchFile(b, 6, true) }
|
|
||||||
func Benchmark_UFlat7(b *testing.B) { benchFile(b, 7, true) }
|
|
||||||
func Benchmark_UFlat8(b *testing.B) { benchFile(b, 8, true) }
|
|
||||||
func Benchmark_UFlat9(b *testing.B) { benchFile(b, 9, true) }
|
|
||||||
func Benchmark_UFlat10(b *testing.B) { benchFile(b, 10, true) }
|
|
||||||
func Benchmark_UFlat11(b *testing.B) { benchFile(b, 11, true) }
|
|
||||||
func Benchmark_ZFlat0(b *testing.B) { benchFile(b, 0, false) }
|
|
||||||
func Benchmark_ZFlat1(b *testing.B) { benchFile(b, 1, false) }
|
|
||||||
func Benchmark_ZFlat2(b *testing.B) { benchFile(b, 2, false) }
|
|
||||||
func Benchmark_ZFlat3(b *testing.B) { benchFile(b, 3, false) }
|
|
||||||
func Benchmark_ZFlat4(b *testing.B) { benchFile(b, 4, false) }
|
|
||||||
func Benchmark_ZFlat5(b *testing.B) { benchFile(b, 5, false) }
|
|
||||||
func Benchmark_ZFlat6(b *testing.B) { benchFile(b, 6, false) }
|
|
||||||
func Benchmark_ZFlat7(b *testing.B) { benchFile(b, 7, false) }
|
|
||||||
func Benchmark_ZFlat8(b *testing.B) { benchFile(b, 8, false) }
|
|
||||||
func Benchmark_ZFlat9(b *testing.B) { benchFile(b, 9, false) }
|
|
||||||
func Benchmark_ZFlat10(b *testing.B) { benchFile(b, 10, false) }
|
|
||||||
func Benchmark_ZFlat11(b *testing.B) { benchFile(b, 11, false) }
|
|
13
vendor/github.com/inconshreveable/mousetrap/LICENSE
generated
vendored
13
vendor/github.com/inconshreveable/mousetrap/LICENSE
generated
vendored
@ -1,13 +0,0 @@
|
|||||||
Copyright 2014 Alan Shreve
|
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
23
vendor/github.com/inconshreveable/mousetrap/README.md
generated
vendored
23
vendor/github.com/inconshreveable/mousetrap/README.md
generated
vendored
@ -1,23 +0,0 @@
|
|||||||
# mousetrap
|
|
||||||
|
|
||||||
mousetrap is a tiny library that answers a single question.
|
|
||||||
|
|
||||||
On a Windows machine, was the process invoked by someone double clicking on
|
|
||||||
the executable file while browsing in explorer?
|
|
||||||
|
|
||||||
### Motivation
|
|
||||||
|
|
||||||
Windows developers unfamiliar with command line tools will often "double-click"
|
|
||||||
the executable for a tool. Because most CLI tools print the help and then exit
|
|
||||||
when invoked without arguments, this is often very frustrating for those users.
|
|
||||||
|
|
||||||
mousetrap provides a way to detect these invocations so that you can provide
|
|
||||||
more helpful behavior and instructions on how to run the CLI tool. To see what
|
|
||||||
this looks like, both from an organizational and a technical perspective, see
|
|
||||||
https://inconshreveable.com/09-09-2014/sweat-the-small-stuff/
|
|
||||||
|
|
||||||
### The interface
|
|
||||||
|
|
||||||
The library exposes a single interface:
|
|
||||||
|
|
||||||
func StartedByExplorer() (bool)
|
|
15
vendor/github.com/inconshreveable/mousetrap/trap_others.go
generated
vendored
15
vendor/github.com/inconshreveable/mousetrap/trap_others.go
generated
vendored
@ -1,15 +0,0 @@
|
|||||||
// +build !windows
|
|
||||||
|
|
||||||
package mousetrap
|
|
||||||
|
|
||||||
// StartedByExplorer returns true if the program was invoked by the user
|
|
||||||
// double-clicking on the executable from explorer.exe
|
|
||||||
//
|
|
||||||
// It is conservative and returns false if any of the internal calls fail.
|
|
||||||
// It does not guarantee that the program was run from a terminal. It only can tell you
|
|
||||||
// whether it was launched from explorer.exe
|
|
||||||
//
|
|
||||||
// On non-Windows platforms, it always returns false.
|
|
||||||
func StartedByExplorer() bool {
|
|
||||||
return false
|
|
||||||
}
|
|
98
vendor/github.com/inconshreveable/mousetrap/trap_windows.go
generated
vendored
98
vendor/github.com/inconshreveable/mousetrap/trap_windows.go
generated
vendored
@ -1,98 +0,0 @@
|
|||||||
// +build windows
|
|
||||||
// +build !go1.4
|
|
||||||
|
|
||||||
package mousetrap
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
"syscall"
|
|
||||||
"unsafe"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
// defined by the Win32 API
|
|
||||||
th32cs_snapprocess uintptr = 0x2
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
kernel = syscall.MustLoadDLL("kernel32.dll")
|
|
||||||
CreateToolhelp32Snapshot = kernel.MustFindProc("CreateToolhelp32Snapshot")
|
|
||||||
Process32First = kernel.MustFindProc("Process32FirstW")
|
|
||||||
Process32Next = kernel.MustFindProc("Process32NextW")
|
|
||||||
)
|
|
||||||
|
|
||||||
// ProcessEntry32 structure defined by the Win32 API
|
|
||||||
type processEntry32 struct {
|
|
||||||
dwSize uint32
|
|
||||||
cntUsage uint32
|
|
||||||
th32ProcessID uint32
|
|
||||||
th32DefaultHeapID int
|
|
||||||
th32ModuleID uint32
|
|
||||||
cntThreads uint32
|
|
||||||
th32ParentProcessID uint32
|
|
||||||
pcPriClassBase int32
|
|
||||||
dwFlags uint32
|
|
||||||
szExeFile [syscall.MAX_PATH]uint16
|
|
||||||
}
|
|
||||||
|
|
||||||
func getProcessEntry(pid int) (pe *processEntry32, err error) {
|
|
||||||
snapshot, _, e1 := CreateToolhelp32Snapshot.Call(th32cs_snapprocess, uintptr(0))
|
|
||||||
if snapshot == uintptr(syscall.InvalidHandle) {
|
|
||||||
err = fmt.Errorf("CreateToolhelp32Snapshot: %v", e1)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
defer syscall.CloseHandle(syscall.Handle(snapshot))
|
|
||||||
|
|
||||||
var processEntry processEntry32
|
|
||||||
processEntry.dwSize = uint32(unsafe.Sizeof(processEntry))
|
|
||||||
ok, _, e1 := Process32First.Call(snapshot, uintptr(unsafe.Pointer(&processEntry)))
|
|
||||||
if ok == 0 {
|
|
||||||
err = fmt.Errorf("Process32First: %v", e1)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
for {
|
|
||||||
if processEntry.th32ProcessID == uint32(pid) {
|
|
||||||
pe = &processEntry
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
ok, _, e1 = Process32Next.Call(snapshot, uintptr(unsafe.Pointer(&processEntry)))
|
|
||||||
if ok == 0 {
|
|
||||||
err = fmt.Errorf("Process32Next: %v", e1)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func getppid() (pid int, err error) {
|
|
||||||
pe, err := getProcessEntry(os.Getpid())
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
pid = int(pe.th32ParentProcessID)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// StartedByExplorer returns true if the program was invoked by the user double-clicking
|
|
||||||
// on the executable from explorer.exe
|
|
||||||
//
|
|
||||||
// It is conservative and returns false if any of the internal calls fail.
|
|
||||||
// It does not guarantee that the program was run from a terminal. It only can tell you
|
|
||||||
// whether it was launched from explorer.exe
|
|
||||||
func StartedByExplorer() bool {
|
|
||||||
ppid, err := getppid()
|
|
||||||
if err != nil {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
pe, err := getProcessEntry(ppid)
|
|
||||||
if err != nil {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
name := syscall.UTF16ToString(pe.szExeFile[:])
|
|
||||||
return name == "explorer.exe"
|
|
||||||
}
|
|
46
vendor/github.com/inconshreveable/mousetrap/trap_windows_1.4.go
generated
vendored
46
vendor/github.com/inconshreveable/mousetrap/trap_windows_1.4.go
generated
vendored
@ -1,46 +0,0 @@
|
|||||||
// +build windows
|
|
||||||
// +build go1.4
|
|
||||||
|
|
||||||
package mousetrap
|
|
||||||
|
|
||||||
import (
|
|
||||||
"os"
|
|
||||||
"syscall"
|
|
||||||
"unsafe"
|
|
||||||
)
|
|
||||||
|
|
||||||
func getProcessEntry(pid int) (*syscall.ProcessEntry32, error) {
|
|
||||||
snapshot, err := syscall.CreateToolhelp32Snapshot(syscall.TH32CS_SNAPPROCESS, 0)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
defer syscall.CloseHandle(snapshot)
|
|
||||||
var procEntry syscall.ProcessEntry32
|
|
||||||
procEntry.Size = uint32(unsafe.Sizeof(procEntry))
|
|
||||||
if err = syscall.Process32First(snapshot, &procEntry); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
for {
|
|
||||||
if procEntry.ProcessID == uint32(pid) {
|
|
||||||
return &procEntry, nil
|
|
||||||
}
|
|
||||||
err = syscall.Process32Next(snapshot, &procEntry)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// StartedByExplorer returns true if the program was invoked by the user double-clicking
|
|
||||||
// on the executable from explorer.exe
|
|
||||||
//
|
|
||||||
// It is conservative and returns false if any of the internal calls fail.
|
|
||||||
// It does not guarantee that the program was run from a terminal. It only can tell you
|
|
||||||
// whether it was launched from explorer.exe
|
|
||||||
func StartedByExplorer() bool {
|
|
||||||
pe, err := getProcessEntry(os.Getppid())
|
|
||||||
if err != nil {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
return "explorer.exe" == syscall.UTF16ToString(pe.ExeFile[:])
|
|
||||||
}
|
|
2
vendor/github.com/spf13/pflag/.gitignore
generated
vendored
2
vendor/github.com/spf13/pflag/.gitignore
generated
vendored
@ -1,2 +0,0 @@
|
|||||||
.idea/*
|
|
||||||
|
|
21
vendor/github.com/spf13/pflag/.travis.yml
generated
vendored
21
vendor/github.com/spf13/pflag/.travis.yml
generated
vendored
@ -1,21 +0,0 @@
|
|||||||
sudo: false
|
|
||||||
|
|
||||||
language: go
|
|
||||||
|
|
||||||
go:
|
|
||||||
- 1.7.3
|
|
||||||
- 1.8.1
|
|
||||||
- tip
|
|
||||||
|
|
||||||
matrix:
|
|
||||||
allow_failures:
|
|
||||||
- go: tip
|
|
||||||
|
|
||||||
install:
|
|
||||||
- go get github.com/golang/lint/golint
|
|
||||||
- export PATH=$GOPATH/bin:$PATH
|
|
||||||
- go install ./...
|
|
||||||
|
|
||||||
script:
|
|
||||||
- verify/all.sh -v
|
|
||||||
- go test ./...
|
|
28
vendor/github.com/spf13/pflag/LICENSE
generated
vendored
28
vendor/github.com/spf13/pflag/LICENSE
generated
vendored
@ -1,28 +0,0 @@
|
|||||||
Copyright (c) 2012 Alex Ogier. All rights reserved.
|
|
||||||
Copyright (c) 2012 The Go Authors. All rights reserved.
|
|
||||||
|
|
||||||
Redistribution and use in source and binary forms, with or without
|
|
||||||
modification, are permitted provided that the following conditions are
|
|
||||||
met:
|
|
||||||
|
|
||||||
* Redistributions of source code must retain the above copyright
|
|
||||||
notice, this list of conditions and the following disclaimer.
|
|
||||||
* Redistributions in binary form must reproduce the above
|
|
||||||
copyright notice, this list of conditions and the following disclaimer
|
|
||||||
in the documentation and/or other materials provided with the
|
|
||||||
distribution.
|
|
||||||
* Neither the name of Google Inc. nor the names of its
|
|
||||||
contributors may be used to endorse or promote products derived from
|
|
||||||
this software without specific prior written permission.
|
|
||||||
|
|
||||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
296
vendor/github.com/spf13/pflag/README.md
generated
vendored
296
vendor/github.com/spf13/pflag/README.md
generated
vendored
@ -1,296 +0,0 @@
|
|||||||
[![Build Status](https://travis-ci.org/spf13/pflag.svg?branch=master)](https://travis-ci.org/spf13/pflag)
|
|
||||||
[![Go Report Card](https://goreportcard.com/badge/github.com/spf13/pflag)](https://goreportcard.com/report/github.com/spf13/pflag)
|
|
||||||
[![GoDoc](https://godoc.org/github.com/spf13/pflag?status.svg)](https://godoc.org/github.com/spf13/pflag)
|
|
||||||
|
|
||||||
## Description
|
|
||||||
|
|
||||||
pflag is a drop-in replacement for Go's flag package, implementing
|
|
||||||
POSIX/GNU-style --flags.
|
|
||||||
|
|
||||||
pflag is compatible with the [GNU extensions to the POSIX recommendations
|
|
||||||
for command-line options][1]. For a more precise description, see the
|
|
||||||
"Command-line flag syntax" section below.
|
|
||||||
|
|
||||||
[1]: http://www.gnu.org/software/libc/manual/html_node/Argument-Syntax.html
|
|
||||||
|
|
||||||
pflag is available under the same style of BSD license as the Go language,
|
|
||||||
which can be found in the LICENSE file.
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
pflag is available using the standard `go get` command.
|
|
||||||
|
|
||||||
Install by running:
|
|
||||||
|
|
||||||
go get github.com/spf13/pflag
|
|
||||||
|
|
||||||
Run tests by running:
|
|
||||||
|
|
||||||
go test github.com/spf13/pflag
|
|
||||||
|
|
||||||
## Usage
|
|
||||||
|
|
||||||
pflag is a drop-in replacement of Go's native flag package. If you import
|
|
||||||
pflag under the name "flag" then all code should continue to function
|
|
||||||
with no changes.
|
|
||||||
|
|
||||||
``` go
|
|
||||||
import flag "github.com/spf13/pflag"
|
|
||||||
```
|
|
||||||
|
|
||||||
There is one exception to this: if you directly instantiate the Flag struct
|
|
||||||
there is one more field "Shorthand" that you will need to set.
|
|
||||||
Most code never instantiates this struct directly, and instead uses
|
|
||||||
functions such as String(), BoolVar(), and Var(), and is therefore
|
|
||||||
unaffected.
|
|
||||||
|
|
||||||
Define flags using flag.String(), Bool(), Int(), etc.
|
|
||||||
|
|
||||||
This declares an integer flag, -flagname, stored in the pointer ip, with type *int.
|
|
||||||
|
|
||||||
``` go
|
|
||||||
var ip *int = flag.Int("flagname", 1234, "help message for flagname")
|
|
||||||
```
|
|
||||||
|
|
||||||
If you like, you can bind the flag to a variable using the Var() functions.
|
|
||||||
|
|
||||||
``` go
|
|
||||||
var flagvar int
|
|
||||||
func init() {
|
|
||||||
flag.IntVar(&flagvar, "flagname", 1234, "help message for flagname")
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
Or you can create custom flags that satisfy the Value interface (with
|
|
||||||
pointer receivers) and couple them to flag parsing by
|
|
||||||
|
|
||||||
``` go
|
|
||||||
flag.Var(&flagVal, "name", "help message for flagname")
|
|
||||||
```
|
|
||||||
|
|
||||||
For such flags, the default value is just the initial value of the variable.
|
|
||||||
|
|
||||||
After all flags are defined, call
|
|
||||||
|
|
||||||
``` go
|
|
||||||
flag.Parse()
|
|
||||||
```
|
|
||||||
|
|
||||||
to parse the command line into the defined flags.
|
|
||||||
|
|
||||||
Flags may then be used directly. If you're using the flags themselves,
|
|
||||||
they are all pointers; if you bind to variables, they're values.
|
|
||||||
|
|
||||||
``` go
|
|
||||||
fmt.Println("ip has value ", *ip)
|
|
||||||
fmt.Println("flagvar has value ", flagvar)
|
|
||||||
```
|
|
||||||
|
|
||||||
There are helpers function to get values later if you have the FlagSet but
|
|
||||||
it was difficult to keep up with all of the flag pointers in your code.
|
|
||||||
If you have a pflag.FlagSet with a flag called 'flagname' of type int you
|
|
||||||
can use GetInt() to get the int value. But notice that 'flagname' must exist
|
|
||||||
and it must be an int. GetString("flagname") will fail.
|
|
||||||
|
|
||||||
``` go
|
|
||||||
i, err := flagset.GetInt("flagname")
|
|
||||||
```
|
|
||||||
|
|
||||||
After parsing, the arguments after the flag are available as the
|
|
||||||
slice flag.Args() or individually as flag.Arg(i).
|
|
||||||
The arguments are indexed from 0 through flag.NArg()-1.
|
|
||||||
|
|
||||||
The pflag package also defines some new functions that are not in flag,
|
|
||||||
that give one-letter shorthands for flags. You can use these by appending
|
|
||||||
'P' to the name of any function that defines a flag.
|
|
||||||
|
|
||||||
``` go
|
|
||||||
var ip = flag.IntP("flagname", "f", 1234, "help message")
|
|
||||||
var flagvar bool
|
|
||||||
func init() {
|
|
||||||
flag.BoolVarP(&flagvar, "boolname", "b", true, "help message")
|
|
||||||
}
|
|
||||||
flag.VarP(&flagVal, "varname", "v", "help message")
|
|
||||||
```
|
|
||||||
|
|
||||||
Shorthand letters can be used with single dashes on the command line.
|
|
||||||
Boolean shorthand flags can be combined with other shorthand flags.
|
|
||||||
|
|
||||||
The default set of command-line flags is controlled by
|
|
||||||
top-level functions. The FlagSet type allows one to define
|
|
||||||
independent sets of flags, such as to implement subcommands
|
|
||||||
in a command-line interface. The methods of FlagSet are
|
|
||||||
analogous to the top-level functions for the command-line
|
|
||||||
flag set.
|
|
||||||
|
|
||||||
## Setting no option default values for flags
|
|
||||||
|
|
||||||
After you create a flag it is possible to set the pflag.NoOptDefVal for
|
|
||||||
the given flag. Doing this changes the meaning of the flag slightly. If
|
|
||||||
a flag has a NoOptDefVal and the flag is set on the command line without
|
|
||||||
an option the flag will be set to the NoOptDefVal. For example given:
|
|
||||||
|
|
||||||
``` go
|
|
||||||
var ip = flag.IntP("flagname", "f", 1234, "help message")
|
|
||||||
flag.Lookup("flagname").NoOptDefVal = "4321"
|
|
||||||
```
|
|
||||||
|
|
||||||
Would result in something like
|
|
||||||
|
|
||||||
| Parsed Arguments | Resulting Value |
|
|
||||||
| ------------- | ------------- |
|
|
||||||
| --flagname=1357 | ip=1357 |
|
|
||||||
| --flagname | ip=4321 |
|
|
||||||
| [nothing] | ip=1234 |
|
|
||||||
|
|
||||||
## Command line flag syntax
|
|
||||||
|
|
||||||
```
|
|
||||||
--flag // boolean flags, or flags with no option default values
|
|
||||||
--flag x // only on flags without a default value
|
|
||||||
--flag=x
|
|
||||||
```
|
|
||||||
|
|
||||||
Unlike the flag package, a single dash before an option means something
|
|
||||||
different than a double dash. Single dashes signify a series of shorthand
|
|
||||||
letters for flags. All but the last shorthand letter must be boolean flags
|
|
||||||
or a flag with a default value
|
|
||||||
|
|
||||||
```
|
|
||||||
// boolean or flags where the 'no option default value' is set
|
|
||||||
-f
|
|
||||||
-f=true
|
|
||||||
-abc
|
|
||||||
but
|
|
||||||
-b true is INVALID
|
|
||||||
|
|
||||||
// non-boolean and flags without a 'no option default value'
|
|
||||||
-n 1234
|
|
||||||
-n=1234
|
|
||||||
-n1234
|
|
||||||
|
|
||||||
// mixed
|
|
||||||
-abcs "hello"
|
|
||||||
-absd="hello"
|
|
||||||
-abcs1234
|
|
||||||
```
|
|
||||||
|
|
||||||
Flag parsing stops after the terminator "--". Unlike the flag package,
|
|
||||||
flags can be interspersed with arguments anywhere on the command line
|
|
||||||
before this terminator.
|
|
||||||
|
|
||||||
Integer flags accept 1234, 0664, 0x1234 and may be negative.
|
|
||||||
Boolean flags (in their long form) accept 1, 0, t, f, true, false,
|
|
||||||
TRUE, FALSE, True, False.
|
|
||||||
Duration flags accept any input valid for time.ParseDuration.
|
|
||||||
|
|
||||||
## Mutating or "Normalizing" Flag names
|
|
||||||
|
|
||||||
It is possible to set a custom flag name 'normalization function.' It allows flag names to be mutated both when created in the code and when used on the command line to some 'normalized' form. The 'normalized' form is used for comparison. Two examples of using the custom normalization func follow.
|
|
||||||
|
|
||||||
**Example #1**: You want -, _, and . in flags to compare the same. aka --my-flag == --my_flag == --my.flag
|
|
||||||
|
|
||||||
``` go
|
|
||||||
func wordSepNormalizeFunc(f *pflag.FlagSet, name string) pflag.NormalizedName {
|
|
||||||
from := []string{"-", "_"}
|
|
||||||
to := "."
|
|
||||||
for _, sep := range from {
|
|
||||||
name = strings.Replace(name, sep, to, -1)
|
|
||||||
}
|
|
||||||
return pflag.NormalizedName(name)
|
|
||||||
}
|
|
||||||
|
|
||||||
myFlagSet.SetNormalizeFunc(wordSepNormalizeFunc)
|
|
||||||
```
|
|
||||||
|
|
||||||
**Example #2**: You want to alias two flags. aka --old-flag-name == --new-flag-name
|
|
||||||
|
|
||||||
``` go
|
|
||||||
func aliasNormalizeFunc(f *pflag.FlagSet, name string) pflag.NormalizedName {
|
|
||||||
switch name {
|
|
||||||
case "old-flag-name":
|
|
||||||
name = "new-flag-name"
|
|
||||||
break
|
|
||||||
}
|
|
||||||
return pflag.NormalizedName(name)
|
|
||||||
}
|
|
||||||
|
|
||||||
myFlagSet.SetNormalizeFunc(aliasNormalizeFunc)
|
|
||||||
```
|
|
||||||
|
|
||||||
## Deprecating a flag or its shorthand
|
|
||||||
It is possible to deprecate a flag, or just its shorthand. Deprecating a flag/shorthand hides it from help text and prints a usage message when the deprecated flag/shorthand is used.
|
|
||||||
|
|
||||||
**Example #1**: You want to deprecate a flag named "badflag" as well as inform the users what flag they should use instead.
|
|
||||||
```go
|
|
||||||
// deprecate a flag by specifying its name and a usage message
|
|
||||||
flags.MarkDeprecated("badflag", "please use --good-flag instead")
|
|
||||||
```
|
|
||||||
This hides "badflag" from help text, and prints `Flag --badflag has been deprecated, please use --good-flag instead` when "badflag" is used.
|
|
||||||
|
|
||||||
**Example #2**: You want to keep a flag name "noshorthandflag" but deprecate its shortname "n".
|
|
||||||
```go
|
|
||||||
// deprecate a flag shorthand by specifying its flag name and a usage message
|
|
||||||
flags.MarkShorthandDeprecated("noshorthandflag", "please use --noshorthandflag only")
|
|
||||||
```
|
|
||||||
This hides the shortname "n" from help text, and prints `Flag shorthand -n has been deprecated, please use --noshorthandflag only` when the shorthand "n" is used.
|
|
||||||
|
|
||||||
Note that usage message is essential here, and it should not be empty.
|
|
||||||
|
|
||||||
## Hidden flags
|
|
||||||
It is possible to mark a flag as hidden, meaning it will still function as normal, however will not show up in usage/help text.
|
|
||||||
|
|
||||||
**Example**: You have a flag named "secretFlag" that you need for internal use only and don't want it showing up in help text, or for its usage text to be available.
|
|
||||||
```go
|
|
||||||
// hide a flag by specifying its name
|
|
||||||
flags.MarkHidden("secretFlag")
|
|
||||||
```
|
|
||||||
|
|
||||||
## Disable sorting of flags
|
|
||||||
`pflag` allows you to disable sorting of flags for help and usage message.
|
|
||||||
|
|
||||||
**Example**:
|
|
||||||
```go
|
|
||||||
flags.BoolP("verbose", "v", false, "verbose output")
|
|
||||||
flags.String("coolflag", "yeaah", "it's really cool flag")
|
|
||||||
flags.Int("usefulflag", 777, "sometimes it's very useful")
|
|
||||||
flags.SortFlags = false
|
|
||||||
flags.PrintDefaults()
|
|
||||||
```
|
|
||||||
**Output**:
|
|
||||||
```
|
|
||||||
-v, --verbose verbose output
|
|
||||||
--coolflag string it's really cool flag (default "yeaah")
|
|
||||||
--usefulflag int sometimes it's very useful (default 777)
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
## Supporting Go flags when using pflag
|
|
||||||
In order to support flags defined using Go's `flag` package, they must be added to the `pflag` flagset. This is usually necessary
|
|
||||||
to support flags defined by third-party dependencies (e.g. `golang/glog`).
|
|
||||||
|
|
||||||
**Example**: You want to add the Go flags to the `CommandLine` flagset
|
|
||||||
```go
|
|
||||||
import (
|
|
||||||
goflag "flag"
|
|
||||||
flag "github.com/spf13/pflag"
|
|
||||||
)
|
|
||||||
|
|
||||||
var ip *int = flag.Int("flagname", 1234, "help message for flagname")
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
flag.CommandLine.AddGoFlagSet(goflag.CommandLine)
|
|
||||||
flag.Parse()
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## More info
|
|
||||||
|
|
||||||
You can see the full reference documentation of the pflag package
|
|
||||||
[at godoc.org][3], or through go's standard documentation system by
|
|
||||||
running `godoc -http=:6060` and browsing to
|
|
||||||
[http://localhost:6060/pkg/github.com/spf13/pflag][2] after
|
|
||||||
installation.
|
|
||||||
|
|
||||||
[2]: http://localhost:6060/pkg/github.com/spf13/pflag
|
|
||||||
[3]: http://godoc.org/github.com/spf13/pflag
|
|
94
vendor/github.com/spf13/pflag/bool.go
generated
vendored
94
vendor/github.com/spf13/pflag/bool.go
generated
vendored
@ -1,94 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// optional interface to indicate boolean flags that can be
|
|
||||||
// supplied without "=value" text
|
|
||||||
type boolFlag interface {
|
|
||||||
Value
|
|
||||||
IsBoolFlag() bool
|
|
||||||
}
|
|
||||||
|
|
||||||
// -- bool Value
|
|
||||||
type boolValue bool
|
|
||||||
|
|
||||||
func newBoolValue(val bool, p *bool) *boolValue {
|
|
||||||
*p = val
|
|
||||||
return (*boolValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (b *boolValue) Set(s string) error {
|
|
||||||
v, err := strconv.ParseBool(s)
|
|
||||||
*b = boolValue(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (b *boolValue) Type() string {
|
|
||||||
return "bool"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (b *boolValue) String() string { return strconv.FormatBool(bool(*b)) }
|
|
||||||
|
|
||||||
func (b *boolValue) IsBoolFlag() bool { return true }
|
|
||||||
|
|
||||||
func boolConv(sval string) (interface{}, error) {
|
|
||||||
return strconv.ParseBool(sval)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetBool return the bool value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetBool(name string) (bool, error) {
|
|
||||||
val, err := f.getFlagType(name, "bool", boolConv)
|
|
||||||
if err != nil {
|
|
||||||
return false, err
|
|
||||||
}
|
|
||||||
return val.(bool), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolVar defines a bool flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a bool variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) BoolVar(p *bool, name string, value bool, usage string) {
|
|
||||||
f.BoolVarP(p, name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolVarP is like BoolVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) BoolVarP(p *bool, name, shorthand string, value bool, usage string) {
|
|
||||||
flag := f.VarPF(newBoolValue(value, p), name, shorthand, usage)
|
|
||||||
flag.NoOptDefVal = "true"
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolVar defines a bool flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a bool variable in which to store the value of the flag.
|
|
||||||
func BoolVar(p *bool, name string, value bool, usage string) {
|
|
||||||
BoolVarP(p, name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolVarP is like BoolVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func BoolVarP(p *bool, name, shorthand string, value bool, usage string) {
|
|
||||||
flag := CommandLine.VarPF(newBoolValue(value, p), name, shorthand, usage)
|
|
||||||
flag.NoOptDefVal = "true"
|
|
||||||
}
|
|
||||||
|
|
||||||
// Bool defines a bool flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a bool variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Bool(name string, value bool, usage string) *bool {
|
|
||||||
return f.BoolP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolP is like Bool, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) BoolP(name, shorthand string, value bool, usage string) *bool {
|
|
||||||
p := new(bool)
|
|
||||||
f.BoolVarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Bool defines a bool flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a bool variable that stores the value of the flag.
|
|
||||||
func Bool(name string, value bool, usage string) *bool {
|
|
||||||
return BoolP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolP is like Bool, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func BoolP(name, shorthand string, value bool, usage string) *bool {
|
|
||||||
b := CommandLine.BoolP(name, shorthand, value, usage)
|
|
||||||
return b
|
|
||||||
}
|
|
147
vendor/github.com/spf13/pflag/bool_slice.go
generated
vendored
147
vendor/github.com/spf13/pflag/bool_slice.go
generated
vendored
@ -1,147 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// -- boolSlice Value
|
|
||||||
type boolSliceValue struct {
|
|
||||||
value *[]bool
|
|
||||||
changed bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func newBoolSliceValue(val []bool, p *[]bool) *boolSliceValue {
|
|
||||||
bsv := new(boolSliceValue)
|
|
||||||
bsv.value = p
|
|
||||||
*bsv.value = val
|
|
||||||
return bsv
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set converts, and assigns, the comma-separated boolean argument string representation as the []bool value of this flag.
|
|
||||||
// If Set is called on a flag that already has a []bool assigned, the newly converted values will be appended.
|
|
||||||
func (s *boolSliceValue) Set(val string) error {
|
|
||||||
|
|
||||||
// remove all quote characters
|
|
||||||
rmQuote := strings.NewReplacer(`"`, "", `'`, "", "`", "")
|
|
||||||
|
|
||||||
// read flag arguments with CSV parser
|
|
||||||
boolStrSlice, err := readAsCSV(rmQuote.Replace(val))
|
|
||||||
if err != nil && err != io.EOF {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// parse boolean values into slice
|
|
||||||
out := make([]bool, 0, len(boolStrSlice))
|
|
||||||
for _, boolStr := range boolStrSlice {
|
|
||||||
b, err := strconv.ParseBool(strings.TrimSpace(boolStr))
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
out = append(out, b)
|
|
||||||
}
|
|
||||||
|
|
||||||
if !s.changed {
|
|
||||||
*s.value = out
|
|
||||||
} else {
|
|
||||||
*s.value = append(*s.value, out...)
|
|
||||||
}
|
|
||||||
|
|
||||||
s.changed = true
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Type returns a string that uniquely represents this flag's type.
|
|
||||||
func (s *boolSliceValue) Type() string {
|
|
||||||
return "boolSlice"
|
|
||||||
}
|
|
||||||
|
|
||||||
// String defines a "native" format for this boolean slice flag value.
|
|
||||||
func (s *boolSliceValue) String() string {
|
|
||||||
|
|
||||||
boolStrSlice := make([]string, len(*s.value))
|
|
||||||
for i, b := range *s.value {
|
|
||||||
boolStrSlice[i] = strconv.FormatBool(b)
|
|
||||||
}
|
|
||||||
|
|
||||||
out, _ := writeAsCSV(boolStrSlice)
|
|
||||||
|
|
||||||
return "[" + out + "]"
|
|
||||||
}
|
|
||||||
|
|
||||||
func boolSliceConv(val string) (interface{}, error) {
|
|
||||||
val = strings.Trim(val, "[]")
|
|
||||||
// Empty string would cause a slice with one (empty) entry
|
|
||||||
if len(val) == 0 {
|
|
||||||
return []bool{}, nil
|
|
||||||
}
|
|
||||||
ss := strings.Split(val, ",")
|
|
||||||
out := make([]bool, len(ss))
|
|
||||||
for i, t := range ss {
|
|
||||||
var err error
|
|
||||||
out[i], err = strconv.ParseBool(t)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return out, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetBoolSlice returns the []bool value of a flag with the given name.
|
|
||||||
func (f *FlagSet) GetBoolSlice(name string) ([]bool, error) {
|
|
||||||
val, err := f.getFlagType(name, "boolSlice", boolSliceConv)
|
|
||||||
if err != nil {
|
|
||||||
return []bool{}, err
|
|
||||||
}
|
|
||||||
return val.([]bool), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolSliceVar defines a boolSlice flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []bool variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) BoolSliceVar(p *[]bool, name string, value []bool, usage string) {
|
|
||||||
f.VarP(newBoolSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolSliceVarP is like BoolSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) BoolSliceVarP(p *[]bool, name, shorthand string, value []bool, usage string) {
|
|
||||||
f.VarP(newBoolSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolSliceVar defines a []bool flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []bool variable in which to store the value of the flag.
|
|
||||||
func BoolSliceVar(p *[]bool, name string, value []bool, usage string) {
|
|
||||||
CommandLine.VarP(newBoolSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolSliceVarP is like BoolSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func BoolSliceVarP(p *[]bool, name, shorthand string, value []bool, usage string) {
|
|
||||||
CommandLine.VarP(newBoolSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolSlice defines a []bool flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []bool variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) BoolSlice(name string, value []bool, usage string) *[]bool {
|
|
||||||
p := []bool{}
|
|
||||||
f.BoolSliceVarP(&p, name, "", value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolSliceP is like BoolSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) BoolSliceP(name, shorthand string, value []bool, usage string) *[]bool {
|
|
||||||
p := []bool{}
|
|
||||||
f.BoolSliceVarP(&p, name, shorthand, value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolSlice defines a []bool flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []bool variable that stores the value of the flag.
|
|
||||||
func BoolSlice(name string, value []bool, usage string) *[]bool {
|
|
||||||
return CommandLine.BoolSliceP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BoolSliceP is like BoolSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func BoolSliceP(name, shorthand string, value []bool, usage string) *[]bool {
|
|
||||||
return CommandLine.BoolSliceP(name, shorthand, value, usage)
|
|
||||||
}
|
|
215
vendor/github.com/spf13/pflag/bool_slice_test.go
generated
vendored
215
vendor/github.com/spf13/pflag/bool_slice_test.go
generated
vendored
@ -1,215 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpBSFlagSet(bsp *[]bool) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.BoolSliceVar(bsp, "bs", []bool{}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func setUpBSFlagSetWithDefault(bsp *[]bool) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.BoolSliceVar(bsp, "bs", []bool{false, true}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmptyBS(t *testing.T) {
|
|
||||||
var bs []bool
|
|
||||||
f := setUpBSFlagSet(&bs)
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getBS, err := f.GetBoolSlice("bs")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetBoolSlice():", err)
|
|
||||||
}
|
|
||||||
if len(getBS) != 0 {
|
|
||||||
t.Fatalf("got bs %v with len=%d but expected length=0", getBS, len(getBS))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBS(t *testing.T) {
|
|
||||||
var bs []bool
|
|
||||||
f := setUpBSFlagSet(&bs)
|
|
||||||
|
|
||||||
vals := []string{"1", "F", "TRUE", "0"}
|
|
||||||
arg := fmt.Sprintf("--bs=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range bs {
|
|
||||||
b, err := strconv.ParseBool(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if b != v {
|
|
||||||
t.Fatalf("expected is[%d] to be %s but got: %t", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
getBS, err := f.GetBoolSlice("bs")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
for i, v := range getBS {
|
|
||||||
b, err := strconv.ParseBool(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if b != v {
|
|
||||||
t.Fatalf("expected bs[%d] to be %s but got: %t from GetBoolSlice", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBSDefault(t *testing.T) {
|
|
||||||
var bs []bool
|
|
||||||
f := setUpBSFlagSetWithDefault(&bs)
|
|
||||||
|
|
||||||
vals := []string{"false", "T"}
|
|
||||||
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range bs {
|
|
||||||
b, err := strconv.ParseBool(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if b != v {
|
|
||||||
t.Fatalf("expected bs[%d] to be %t from GetBoolSlice but got: %t", i, b, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getBS, err := f.GetBoolSlice("bs")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetBoolSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getBS {
|
|
||||||
b, err := strconv.ParseBool(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetBoolSlice():", err)
|
|
||||||
}
|
|
||||||
if b != v {
|
|
||||||
t.Fatalf("expected bs[%d] to be %t from GetBoolSlice but got: %t", i, b, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBSWithDefault(t *testing.T) {
|
|
||||||
var bs []bool
|
|
||||||
f := setUpBSFlagSetWithDefault(&bs)
|
|
||||||
|
|
||||||
vals := []string{"FALSE", "1"}
|
|
||||||
arg := fmt.Sprintf("--bs=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range bs {
|
|
||||||
b, err := strconv.ParseBool(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if b != v {
|
|
||||||
t.Fatalf("expected bs[%d] to be %t but got: %t", i, b, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getBS, err := f.GetBoolSlice("bs")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetBoolSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getBS {
|
|
||||||
b, err := strconv.ParseBool(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if b != v {
|
|
||||||
t.Fatalf("expected bs[%d] to be %t from GetBoolSlice but got: %t", i, b, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBSCalledTwice(t *testing.T) {
|
|
||||||
var bs []bool
|
|
||||||
f := setUpBSFlagSet(&bs)
|
|
||||||
|
|
||||||
in := []string{"T,F", "T"}
|
|
||||||
expected := []bool{true, false, true}
|
|
||||||
argfmt := "--bs=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
err := f.Parse([]string{arg1, arg2})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range bs {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected bs[%d] to be %t but got %t", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBSBadQuoting(t *testing.T) {
|
|
||||||
|
|
||||||
tests := []struct {
|
|
||||||
Want []bool
|
|
||||||
FlagArg []string
|
|
||||||
}{
|
|
||||||
{
|
|
||||||
Want: []bool{true, false, true},
|
|
||||||
FlagArg: []string{"1", "0", "true"},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []bool{true, false},
|
|
||||||
FlagArg: []string{"True", "F"},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []bool{true, false},
|
|
||||||
FlagArg: []string{"T", "0"},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []bool{true, false},
|
|
||||||
FlagArg: []string{"1", "0"},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []bool{true, false, false},
|
|
||||||
FlagArg: []string{"true,false", "false"},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []bool{true, false, false, true, false, true, false},
|
|
||||||
FlagArg: []string{`"true,false,false,1,0, T"`, " false "},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []bool{false, false, true, false, true, false, true},
|
|
||||||
FlagArg: []string{`"0, False, T,false , true,F"`, "true"},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
for i, test := range tests {
|
|
||||||
|
|
||||||
var bs []bool
|
|
||||||
f := setUpBSFlagSet(&bs)
|
|
||||||
|
|
||||||
if err := f.Parse([]string{fmt.Sprintf("--bs=%s", strings.Join(test.FlagArg, ","))}); err != nil {
|
|
||||||
t.Fatalf("flag parsing failed with error: %s\nparsing:\t%#v\nwant:\t\t%#v",
|
|
||||||
err, test.FlagArg, test.Want[i])
|
|
||||||
}
|
|
||||||
|
|
||||||
for j, b := range bs {
|
|
||||||
if b != test.Want[j] {
|
|
||||||
t.Fatalf("bad value parsed for test %d on bool %d:\nwant:\t%t\ngot:\t%t", i, j, test.Want[j], b)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
179
vendor/github.com/spf13/pflag/bool_test.go
generated
vendored
179
vendor/github.com/spf13/pflag/bool_test.go
generated
vendored
@ -1,179 +0,0 @@
|
|||||||
// Copyright 2009 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"strconv"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
// This value can be a boolean ("true", "false") or "maybe"
|
|
||||||
type triStateValue int
|
|
||||||
|
|
||||||
const (
|
|
||||||
triStateFalse triStateValue = 0
|
|
||||||
triStateTrue triStateValue = 1
|
|
||||||
triStateMaybe triStateValue = 2
|
|
||||||
)
|
|
||||||
|
|
||||||
const strTriStateMaybe = "maybe"
|
|
||||||
|
|
||||||
func (v *triStateValue) IsBoolFlag() bool {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v *triStateValue) Get() interface{} {
|
|
||||||
return triStateValue(*v)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v *triStateValue) Set(s string) error {
|
|
||||||
if s == strTriStateMaybe {
|
|
||||||
*v = triStateMaybe
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
boolVal, err := strconv.ParseBool(s)
|
|
||||||
if boolVal {
|
|
||||||
*v = triStateTrue
|
|
||||||
} else {
|
|
||||||
*v = triStateFalse
|
|
||||||
}
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v *triStateValue) String() string {
|
|
||||||
if *v == triStateMaybe {
|
|
||||||
return strTriStateMaybe
|
|
||||||
}
|
|
||||||
return strconv.FormatBool(*v == triStateTrue)
|
|
||||||
}
|
|
||||||
|
|
||||||
// The type of the flag as required by the pflag.Value interface
|
|
||||||
func (v *triStateValue) Type() string {
|
|
||||||
return "version"
|
|
||||||
}
|
|
||||||
|
|
||||||
func setUpFlagSet(tristate *triStateValue) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
*tristate = triStateFalse
|
|
||||||
flag := f.VarPF(tristate, "tristate", "t", "tristate value (true, maybe or false)")
|
|
||||||
flag.NoOptDefVal = "true"
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestExplicitTrue(t *testing.T) {
|
|
||||||
var tristate triStateValue
|
|
||||||
f := setUpFlagSet(&tristate)
|
|
||||||
err := f.Parse([]string{"--tristate=true"})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
if tristate != triStateTrue {
|
|
||||||
t.Fatal("expected", triStateTrue, "(triStateTrue) but got", tristate, "instead")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestImplicitTrue(t *testing.T) {
|
|
||||||
var tristate triStateValue
|
|
||||||
f := setUpFlagSet(&tristate)
|
|
||||||
err := f.Parse([]string{"--tristate"})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
if tristate != triStateTrue {
|
|
||||||
t.Fatal("expected", triStateTrue, "(triStateTrue) but got", tristate, "instead")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestShortFlag(t *testing.T) {
|
|
||||||
var tristate triStateValue
|
|
||||||
f := setUpFlagSet(&tristate)
|
|
||||||
err := f.Parse([]string{"-t"})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
if tristate != triStateTrue {
|
|
||||||
t.Fatal("expected", triStateTrue, "(triStateTrue) but got", tristate, "instead")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestShortFlagExtraArgument(t *testing.T) {
|
|
||||||
var tristate triStateValue
|
|
||||||
f := setUpFlagSet(&tristate)
|
|
||||||
// The"maybe"turns into an arg, since short boolean options will only do true/false
|
|
||||||
err := f.Parse([]string{"-t", "maybe"})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
if tristate != triStateTrue {
|
|
||||||
t.Fatal("expected", triStateTrue, "(triStateTrue) but got", tristate, "instead")
|
|
||||||
}
|
|
||||||
args := f.Args()
|
|
||||||
if len(args) != 1 || args[0] != "maybe" {
|
|
||||||
t.Fatal("expected an extra 'maybe' argument to stick around")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestExplicitMaybe(t *testing.T) {
|
|
||||||
var tristate triStateValue
|
|
||||||
f := setUpFlagSet(&tristate)
|
|
||||||
err := f.Parse([]string{"--tristate=maybe"})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
if tristate != triStateMaybe {
|
|
||||||
t.Fatal("expected", triStateMaybe, "(triStateMaybe) but got", tristate, "instead")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestExplicitFalse(t *testing.T) {
|
|
||||||
var tristate triStateValue
|
|
||||||
f := setUpFlagSet(&tristate)
|
|
||||||
err := f.Parse([]string{"--tristate=false"})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
if tristate != triStateFalse {
|
|
||||||
t.Fatal("expected", triStateFalse, "(triStateFalse) but got", tristate, "instead")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestImplicitFalse(t *testing.T) {
|
|
||||||
var tristate triStateValue
|
|
||||||
f := setUpFlagSet(&tristate)
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
if tristate != triStateFalse {
|
|
||||||
t.Fatal("expected", triStateFalse, "(triStateFalse) but got", tristate, "instead")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestInvalidValue(t *testing.T) {
|
|
||||||
var tristate triStateValue
|
|
||||||
f := setUpFlagSet(&tristate)
|
|
||||||
var buf bytes.Buffer
|
|
||||||
f.SetOutput(&buf)
|
|
||||||
err := f.Parse([]string{"--tristate=invalid"})
|
|
||||||
if err == nil {
|
|
||||||
t.Fatal("expected an error but did not get any, tristate has value", tristate)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBoolP(t *testing.T) {
|
|
||||||
b := BoolP("bool", "b", false, "bool value in CommandLine")
|
|
||||||
c := BoolP("c", "c", false, "other bool value")
|
|
||||||
args := []string{"--bool"}
|
|
||||||
if err := CommandLine.Parse(args); err != nil {
|
|
||||||
t.Error("expected no error, got ", err)
|
|
||||||
}
|
|
||||||
if *b != true {
|
|
||||||
t.Errorf("expected b=true got b=%v", *b)
|
|
||||||
}
|
|
||||||
if *c != false {
|
|
||||||
t.Errorf("expect c=false got c=%v", *c)
|
|
||||||
}
|
|
||||||
}
|
|
105
vendor/github.com/spf13/pflag/bytes.go
generated
vendored
105
vendor/github.com/spf13/pflag/bytes.go
generated
vendored
@ -1,105 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/hex"
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// BytesHex adapts []byte for use as a flag. Value of flag is HEX encoded
|
|
||||||
type bytesHexValue []byte
|
|
||||||
|
|
||||||
func (bytesHex bytesHexValue) String() string {
|
|
||||||
return fmt.Sprintf("%X", []byte(bytesHex))
|
|
||||||
}
|
|
||||||
|
|
||||||
func (bytesHex *bytesHexValue) Set(value string) error {
|
|
||||||
bin, err := hex.DecodeString(strings.TrimSpace(value))
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
*bytesHex = bin
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (*bytesHexValue) Type() string {
|
|
||||||
return "bytesHex"
|
|
||||||
}
|
|
||||||
|
|
||||||
func newBytesHexValue(val []byte, p *[]byte) *bytesHexValue {
|
|
||||||
*p = val
|
|
||||||
return (*bytesHexValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func bytesHexConv(sval string) (interface{}, error) {
|
|
||||||
|
|
||||||
bin, err := hex.DecodeString(sval)
|
|
||||||
|
|
||||||
if err == nil {
|
|
||||||
return bin, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil, fmt.Errorf("invalid string being converted to Bytes: %s %s", sval, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetBytesHex return the []byte value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetBytesHex(name string) ([]byte, error) {
|
|
||||||
val, err := f.getFlagType(name, "bytesHex", bytesHexConv)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
return []byte{}, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return val.([]byte), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// BytesHexVar defines an []byte flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an []byte variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) BytesHexVar(p *[]byte, name string, value []byte, usage string) {
|
|
||||||
f.VarP(newBytesHexValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BytesHexVarP is like BytesHexVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) BytesHexVarP(p *[]byte, name, shorthand string, value []byte, usage string) {
|
|
||||||
f.VarP(newBytesHexValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BytesHexVar defines an []byte flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an []byte variable in which to store the value of the flag.
|
|
||||||
func BytesHexVar(p *[]byte, name string, value []byte, usage string) {
|
|
||||||
CommandLine.VarP(newBytesHexValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BytesHexVarP is like BytesHexVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func BytesHexVarP(p *[]byte, name, shorthand string, value []byte, usage string) {
|
|
||||||
CommandLine.VarP(newBytesHexValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BytesHex defines an []byte flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an []byte variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) BytesHex(name string, value []byte, usage string) *[]byte {
|
|
||||||
p := new([]byte)
|
|
||||||
f.BytesHexVarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// BytesHexP is like BytesHex, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) BytesHexP(name, shorthand string, value []byte, usage string) *[]byte {
|
|
||||||
p := new([]byte)
|
|
||||||
f.BytesHexVarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// BytesHex defines an []byte flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an []byte variable that stores the value of the flag.
|
|
||||||
func BytesHex(name string, value []byte, usage string) *[]byte {
|
|
||||||
return CommandLine.BytesHexP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// BytesHexP is like BytesHex, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func BytesHexP(name, shorthand string, value []byte, usage string) *[]byte {
|
|
||||||
return CommandLine.BytesHexP(name, shorthand, value, usage)
|
|
||||||
}
|
|
72
vendor/github.com/spf13/pflag/bytes_test.go
generated
vendored
72
vendor/github.com/spf13/pflag/bytes_test.go
generated
vendored
@ -1,72 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpBytesHex(bytesHex *[]byte) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.BytesHexVar(bytesHex, "bytes", []byte{1, 2, 3, 4, 5, 6, 7, 8, 9, 0}, "Some bytes in HEX")
|
|
||||||
f.BytesHexVarP(bytesHex, "bytes2", "B", []byte{1, 2, 3, 4, 5, 6, 7, 8, 9, 0}, "Some bytes in HEX")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestBytesHex(t *testing.T) {
|
|
||||||
testCases := []struct {
|
|
||||||
input string
|
|
||||||
success bool
|
|
||||||
expected string
|
|
||||||
}{
|
|
||||||
/// Positive cases
|
|
||||||
{"", true, ""}, // Is empty string OK ?
|
|
||||||
{"01", true, "01"},
|
|
||||||
{"0101", true, "0101"},
|
|
||||||
{"1234567890abcdef", true, "1234567890ABCDEF"},
|
|
||||||
{"1234567890ABCDEF", true, "1234567890ABCDEF"},
|
|
||||||
|
|
||||||
// Negative cases
|
|
||||||
{"0", false, ""}, // Short string
|
|
||||||
{"000", false, ""}, /// Odd-length string
|
|
||||||
{"qq", false, ""}, /// non-hex character
|
|
||||||
}
|
|
||||||
|
|
||||||
devnull, _ := os.Open(os.DevNull)
|
|
||||||
os.Stderr = devnull
|
|
||||||
|
|
||||||
for i := range testCases {
|
|
||||||
var bytesHex []byte
|
|
||||||
f := setUpBytesHex(&bytesHex)
|
|
||||||
|
|
||||||
tc := &testCases[i]
|
|
||||||
|
|
||||||
// --bytes
|
|
||||||
args := []string{
|
|
||||||
fmt.Sprintf("--bytes=%s", tc.input),
|
|
||||||
fmt.Sprintf("-B %s", tc.input),
|
|
||||||
fmt.Sprintf("--bytes2=%s", tc.input),
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, arg := range args {
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
|
|
||||||
if err != nil && tc.success == true {
|
|
||||||
t.Errorf("expected success, got %q", err)
|
|
||||||
continue
|
|
||||||
} else if err == nil && tc.success == false {
|
|
||||||
// bytesHex, err := f.GetBytesHex("bytes")
|
|
||||||
t.Errorf("expected failure while processing %q", tc.input)
|
|
||||||
continue
|
|
||||||
} else if tc.success {
|
|
||||||
bytesHex, err := f.GetBytesHex("bytes")
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Got error trying to fetch the IP flag: %v", err)
|
|
||||||
}
|
|
||||||
if fmt.Sprintf("%X", bytesHex) != tc.expected {
|
|
||||||
t.Errorf("expected %q, got '%X'", tc.expected, bytesHex)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
96
vendor/github.com/spf13/pflag/count.go
generated
vendored
96
vendor/github.com/spf13/pflag/count.go
generated
vendored
@ -1,96 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- count Value
|
|
||||||
type countValue int
|
|
||||||
|
|
||||||
func newCountValue(val int, p *int) *countValue {
|
|
||||||
*p = val
|
|
||||||
return (*countValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *countValue) Set(s string) error {
|
|
||||||
// "+1" means that no specific value was passed, so increment
|
|
||||||
if s == "+1" {
|
|
||||||
*i = countValue(*i + 1)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
v, err := strconv.ParseInt(s, 0, 0)
|
|
||||||
*i = countValue(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *countValue) Type() string {
|
|
||||||
return "count"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *countValue) String() string { return strconv.Itoa(int(*i)) }
|
|
||||||
|
|
||||||
func countConv(sval string) (interface{}, error) {
|
|
||||||
i, err := strconv.Atoi(sval)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return i, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetCount return the int value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetCount(name string) (int, error) {
|
|
||||||
val, err := f.getFlagType(name, "count", countConv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(int), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// CountVar defines a count flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int variable in which to store the value of the flag.
|
|
||||||
// A count flag will add 1 to its value evey time it is found on the command line
|
|
||||||
func (f *FlagSet) CountVar(p *int, name string, usage string) {
|
|
||||||
f.CountVarP(p, name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// CountVarP is like CountVar only take a shorthand for the flag name.
|
|
||||||
func (f *FlagSet) CountVarP(p *int, name, shorthand string, usage string) {
|
|
||||||
flag := f.VarPF(newCountValue(0, p), name, shorthand, usage)
|
|
||||||
flag.NoOptDefVal = "+1"
|
|
||||||
}
|
|
||||||
|
|
||||||
// CountVar like CountVar only the flag is placed on the CommandLine instead of a given flag set
|
|
||||||
func CountVar(p *int, name string, usage string) {
|
|
||||||
CommandLine.CountVar(p, name, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// CountVarP is like CountVar only take a shorthand for the flag name.
|
|
||||||
func CountVarP(p *int, name, shorthand string, usage string) {
|
|
||||||
CommandLine.CountVarP(p, name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Count defines a count flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int variable that stores the value of the flag.
|
|
||||||
// A count flag will add 1 to its value evey time it is found on the command line
|
|
||||||
func (f *FlagSet) Count(name string, usage string) *int {
|
|
||||||
p := new(int)
|
|
||||||
f.CountVarP(p, name, "", usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// CountP is like Count only takes a shorthand for the flag name.
|
|
||||||
func (f *FlagSet) CountP(name, shorthand string, usage string) *int {
|
|
||||||
p := new(int)
|
|
||||||
f.CountVarP(p, name, shorthand, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Count defines a count flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int variable that stores the value of the flag.
|
|
||||||
// A count flag will add 1 to its value evey time it is found on the command line
|
|
||||||
func Count(name string, usage string) *int {
|
|
||||||
return CommandLine.CountP(name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// CountP is like Count only takes a shorthand for the flag name.
|
|
||||||
func CountP(name, shorthand string, usage string) *int {
|
|
||||||
return CommandLine.CountP(name, shorthand, usage)
|
|
||||||
}
|
|
56
vendor/github.com/spf13/pflag/count_test.go
generated
vendored
56
vendor/github.com/spf13/pflag/count_test.go
generated
vendored
@ -1,56 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"os"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpCount(c *int) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.CountVarP(c, "verbose", "v", "a counter")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestCount(t *testing.T) {
|
|
||||||
testCases := []struct {
|
|
||||||
input []string
|
|
||||||
success bool
|
|
||||||
expected int
|
|
||||||
}{
|
|
||||||
{[]string{}, true, 0},
|
|
||||||
{[]string{"-v"}, true, 1},
|
|
||||||
{[]string{"-vvv"}, true, 3},
|
|
||||||
{[]string{"-v", "-v", "-v"}, true, 3},
|
|
||||||
{[]string{"-v", "--verbose", "-v"}, true, 3},
|
|
||||||
{[]string{"-v=3", "-v"}, true, 4},
|
|
||||||
{[]string{"--verbose=0"}, true, 0},
|
|
||||||
{[]string{"-v=0"}, true, 0},
|
|
||||||
{[]string{"-v=a"}, false, 0},
|
|
||||||
}
|
|
||||||
|
|
||||||
devnull, _ := os.Open(os.DevNull)
|
|
||||||
os.Stderr = devnull
|
|
||||||
for i := range testCases {
|
|
||||||
var count int
|
|
||||||
f := setUpCount(&count)
|
|
||||||
|
|
||||||
tc := &testCases[i]
|
|
||||||
|
|
||||||
err := f.Parse(tc.input)
|
|
||||||
if err != nil && tc.success == true {
|
|
||||||
t.Errorf("expected success, got %q", err)
|
|
||||||
continue
|
|
||||||
} else if err == nil && tc.success == false {
|
|
||||||
t.Errorf("expected failure, got success")
|
|
||||||
continue
|
|
||||||
} else if tc.success {
|
|
||||||
c, err := f.GetCount("verbose")
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Got error trying to fetch the counter flag")
|
|
||||||
}
|
|
||||||
if c != tc.expected {
|
|
||||||
t.Errorf("expected %d, got %d", tc.expected, c)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
86
vendor/github.com/spf13/pflag/duration.go
generated
vendored
86
vendor/github.com/spf13/pflag/duration.go
generated
vendored
@ -1,86 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
// -- time.Duration Value
|
|
||||||
type durationValue time.Duration
|
|
||||||
|
|
||||||
func newDurationValue(val time.Duration, p *time.Duration) *durationValue {
|
|
||||||
*p = val
|
|
||||||
return (*durationValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *durationValue) Set(s string) error {
|
|
||||||
v, err := time.ParseDuration(s)
|
|
||||||
*d = durationValue(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *durationValue) Type() string {
|
|
||||||
return "duration"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *durationValue) String() string { return (*time.Duration)(d).String() }
|
|
||||||
|
|
||||||
func durationConv(sval string) (interface{}, error) {
|
|
||||||
return time.ParseDuration(sval)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetDuration return the duration value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetDuration(name string) (time.Duration, error) {
|
|
||||||
val, err := f.getFlagType(name, "duration", durationConv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(time.Duration), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationVar defines a time.Duration flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a time.Duration variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) DurationVar(p *time.Duration, name string, value time.Duration, usage string) {
|
|
||||||
f.VarP(newDurationValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationVarP is like DurationVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) DurationVarP(p *time.Duration, name, shorthand string, value time.Duration, usage string) {
|
|
||||||
f.VarP(newDurationValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationVar defines a time.Duration flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a time.Duration variable in which to store the value of the flag.
|
|
||||||
func DurationVar(p *time.Duration, name string, value time.Duration, usage string) {
|
|
||||||
CommandLine.VarP(newDurationValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationVarP is like DurationVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func DurationVarP(p *time.Duration, name, shorthand string, value time.Duration, usage string) {
|
|
||||||
CommandLine.VarP(newDurationValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Duration defines a time.Duration flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a time.Duration variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Duration(name string, value time.Duration, usage string) *time.Duration {
|
|
||||||
p := new(time.Duration)
|
|
||||||
f.DurationVarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationP is like Duration, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) DurationP(name, shorthand string, value time.Duration, usage string) *time.Duration {
|
|
||||||
p := new(time.Duration)
|
|
||||||
f.DurationVarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Duration defines a time.Duration flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a time.Duration variable that stores the value of the flag.
|
|
||||||
func Duration(name string, value time.Duration, usage string) *time.Duration {
|
|
||||||
return CommandLine.DurationP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationP is like Duration, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func DurationP(name, shorthand string, value time.Duration, usage string) *time.Duration {
|
|
||||||
return CommandLine.DurationP(name, shorthand, value, usage)
|
|
||||||
}
|
|
128
vendor/github.com/spf13/pflag/duration_slice.go
generated
vendored
128
vendor/github.com/spf13/pflag/duration_slice.go
generated
vendored
@ -1,128 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
// -- durationSlice Value
|
|
||||||
type durationSliceValue struct {
|
|
||||||
value *[]time.Duration
|
|
||||||
changed bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func newDurationSliceValue(val []time.Duration, p *[]time.Duration) *durationSliceValue {
|
|
||||||
dsv := new(durationSliceValue)
|
|
||||||
dsv.value = p
|
|
||||||
*dsv.value = val
|
|
||||||
return dsv
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *durationSliceValue) Set(val string) error {
|
|
||||||
ss := strings.Split(val, ",")
|
|
||||||
out := make([]time.Duration, len(ss))
|
|
||||||
for i, d := range ss {
|
|
||||||
var err error
|
|
||||||
out[i], err = time.ParseDuration(d)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
if !s.changed {
|
|
||||||
*s.value = out
|
|
||||||
} else {
|
|
||||||
*s.value = append(*s.value, out...)
|
|
||||||
}
|
|
||||||
s.changed = true
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *durationSliceValue) Type() string {
|
|
||||||
return "durationSlice"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *durationSliceValue) String() string {
|
|
||||||
out := make([]string, len(*s.value))
|
|
||||||
for i, d := range *s.value {
|
|
||||||
out[i] = fmt.Sprintf("%s", d)
|
|
||||||
}
|
|
||||||
return "[" + strings.Join(out, ",") + "]"
|
|
||||||
}
|
|
||||||
|
|
||||||
func durationSliceConv(val string) (interface{}, error) {
|
|
||||||
val = strings.Trim(val, "[]")
|
|
||||||
// Empty string would cause a slice with one (empty) entry
|
|
||||||
if len(val) == 0 {
|
|
||||||
return []time.Duration{}, nil
|
|
||||||
}
|
|
||||||
ss := strings.Split(val, ",")
|
|
||||||
out := make([]time.Duration, len(ss))
|
|
||||||
for i, d := range ss {
|
|
||||||
var err error
|
|
||||||
out[i], err = time.ParseDuration(d)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
return out, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetDurationSlice returns the []time.Duration value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetDurationSlice(name string) ([]time.Duration, error) {
|
|
||||||
val, err := f.getFlagType(name, "durationSlice", durationSliceConv)
|
|
||||||
if err != nil {
|
|
||||||
return []time.Duration{}, err
|
|
||||||
}
|
|
||||||
return val.([]time.Duration), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationSliceVar defines a durationSlice flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []time.Duration variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) DurationSliceVar(p *[]time.Duration, name string, value []time.Duration, usage string) {
|
|
||||||
f.VarP(newDurationSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationSliceVarP is like DurationSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) DurationSliceVarP(p *[]time.Duration, name, shorthand string, value []time.Duration, usage string) {
|
|
||||||
f.VarP(newDurationSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationSliceVar defines a duration[] flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a duration[] variable in which to store the value of the flag.
|
|
||||||
func DurationSliceVar(p *[]time.Duration, name string, value []time.Duration, usage string) {
|
|
||||||
CommandLine.VarP(newDurationSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationSliceVarP is like DurationSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func DurationSliceVarP(p *[]time.Duration, name, shorthand string, value []time.Duration, usage string) {
|
|
||||||
CommandLine.VarP(newDurationSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationSlice defines a []time.Duration flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []time.Duration variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) DurationSlice(name string, value []time.Duration, usage string) *[]time.Duration {
|
|
||||||
p := []time.Duration{}
|
|
||||||
f.DurationSliceVarP(&p, name, "", value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationSliceP is like DurationSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) DurationSliceP(name, shorthand string, value []time.Duration, usage string) *[]time.Duration {
|
|
||||||
p := []time.Duration{}
|
|
||||||
f.DurationSliceVarP(&p, name, shorthand, value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationSlice defines a []time.Duration flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []time.Duration variable that stores the value of the flag.
|
|
||||||
func DurationSlice(name string, value []time.Duration, usage string) *[]time.Duration {
|
|
||||||
return CommandLine.DurationSliceP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// DurationSliceP is like DurationSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func DurationSliceP(name, shorthand string, value []time.Duration, usage string) *[]time.Duration {
|
|
||||||
return CommandLine.DurationSliceP(name, shorthand, value, usage)
|
|
||||||
}
|
|
165
vendor/github.com/spf13/pflag/duration_slice_test.go
generated
vendored
165
vendor/github.com/spf13/pflag/duration_slice_test.go
generated
vendored
@ -1,165 +0,0 @@
|
|||||||
// Copyright 2009 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code ds governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
"testing"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpDSFlagSet(dsp *[]time.Duration) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.DurationSliceVar(dsp, "ds", []time.Duration{}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func setUpDSFlagSetWithDefault(dsp *[]time.Duration) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.DurationSliceVar(dsp, "ds", []time.Duration{0, 1}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmptyDS(t *testing.T) {
|
|
||||||
var ds []time.Duration
|
|
||||||
f := setUpDSFlagSet(&ds)
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getDS, err := f.GetDurationSlice("ds")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetDurationSlice():", err)
|
|
||||||
}
|
|
||||||
if len(getDS) != 0 {
|
|
||||||
t.Fatalf("got ds %v with len=%d but expected length=0", getDS, len(getDS))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDS(t *testing.T) {
|
|
||||||
var ds []time.Duration
|
|
||||||
f := setUpDSFlagSet(&ds)
|
|
||||||
|
|
||||||
vals := []string{"1ns", "2ms", "3m", "4h"}
|
|
||||||
arg := fmt.Sprintf("--ds=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ds {
|
|
||||||
d, err := time.ParseDuration(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected ds[%d] to be %s but got: %d", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
getDS, err := f.GetDurationSlice("ds")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
for i, v := range getDS {
|
|
||||||
d, err := time.ParseDuration(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected ds[%d] to be %s but got: %d from GetDurationSlice", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDSDefault(t *testing.T) {
|
|
||||||
var ds []time.Duration
|
|
||||||
f := setUpDSFlagSetWithDefault(&ds)
|
|
||||||
|
|
||||||
vals := []string{"0s", "1ns"}
|
|
||||||
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ds {
|
|
||||||
d, err := time.ParseDuration(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected ds[%d] to be %d but got: %d", i, d, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getDS, err := f.GetDurationSlice("ds")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetDurationSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getDS {
|
|
||||||
d, err := time.ParseDuration(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetDurationSlice():", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected ds[%d] to be %d from GetDurationSlice but got: %d", i, d, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDSWithDefault(t *testing.T) {
|
|
||||||
var ds []time.Duration
|
|
||||||
f := setUpDSFlagSetWithDefault(&ds)
|
|
||||||
|
|
||||||
vals := []string{"1ns", "2ns"}
|
|
||||||
arg := fmt.Sprintf("--ds=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ds {
|
|
||||||
d, err := time.ParseDuration(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected ds[%d] to be %d but got: %d", i, d, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getDS, err := f.GetDurationSlice("ds")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetDurationSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getDS {
|
|
||||||
d, err := time.ParseDuration(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected ds[%d] to be %d from GetDurationSlice but got: %d", i, d, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDSCalledTwice(t *testing.T) {
|
|
||||||
var ds []time.Duration
|
|
||||||
f := setUpDSFlagSet(&ds)
|
|
||||||
|
|
||||||
in := []string{"1ns,2ns", "3ns"}
|
|
||||||
expected := []time.Duration{1, 2, 3}
|
|
||||||
argfmt := "--ds=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
err := f.Parse([]string{arg1, arg2})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ds {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected ds[%d] to be %d but got: %d", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
36
vendor/github.com/spf13/pflag/example_test.go
generated
vendored
36
vendor/github.com/spf13/pflag/example_test.go
generated
vendored
@ -1,36 +0,0 @@
|
|||||||
// Copyright 2012 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package pflag_test
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
|
|
||||||
"github.com/spf13/pflag"
|
|
||||||
)
|
|
||||||
|
|
||||||
func ExampleShorthandLookup() {
|
|
||||||
name := "verbose"
|
|
||||||
short := name[:1]
|
|
||||||
|
|
||||||
pflag.BoolP(name, short, false, "verbose output")
|
|
||||||
|
|
||||||
// len(short) must be == 1
|
|
||||||
flag := pflag.ShorthandLookup(short)
|
|
||||||
|
|
||||||
fmt.Println(flag.Name)
|
|
||||||
}
|
|
||||||
|
|
||||||
func ExampleFlagSet_ShorthandLookup() {
|
|
||||||
name := "verbose"
|
|
||||||
short := name[:1]
|
|
||||||
|
|
||||||
fs := pflag.NewFlagSet("Example", pflag.ContinueOnError)
|
|
||||||
fs.BoolP(name, short, false, "verbose output")
|
|
||||||
|
|
||||||
// len(short) must be == 1
|
|
||||||
flag := fs.ShorthandLookup(short)
|
|
||||||
|
|
||||||
fmt.Println(flag.Name)
|
|
||||||
}
|
|
29
vendor/github.com/spf13/pflag/export_test.go
generated
vendored
29
vendor/github.com/spf13/pflag/export_test.go
generated
vendored
@ -1,29 +0,0 @@
|
|||||||
// Copyright 2010 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Additional routines compiled into the package only during testing.
|
|
||||||
|
|
||||||
// ResetForTesting clears all flag state and sets the usage function as directed.
|
|
||||||
// After calling ResetForTesting, parse errors in flag handling will not
|
|
||||||
// exit the program.
|
|
||||||
func ResetForTesting(usage func()) {
|
|
||||||
CommandLine = &FlagSet{
|
|
||||||
name: os.Args[0],
|
|
||||||
errorHandling: ContinueOnError,
|
|
||||||
output: ioutil.Discard,
|
|
||||||
}
|
|
||||||
Usage = usage
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetCommandLine returns the default FlagSet.
|
|
||||||
func GetCommandLine() *FlagSet {
|
|
||||||
return CommandLine
|
|
||||||
}
|
|
1223
vendor/github.com/spf13/pflag/flag.go
generated
vendored
1223
vendor/github.com/spf13/pflag/flag.go
generated
vendored
File diff suppressed because it is too large
Load Diff
1259
vendor/github.com/spf13/pflag/flag_test.go
generated
vendored
1259
vendor/github.com/spf13/pflag/flag_test.go
generated
vendored
File diff suppressed because it is too large
Load Diff
88
vendor/github.com/spf13/pflag/float32.go
generated
vendored
88
vendor/github.com/spf13/pflag/float32.go
generated
vendored
@ -1,88 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- float32 Value
|
|
||||||
type float32Value float32
|
|
||||||
|
|
||||||
func newFloat32Value(val float32, p *float32) *float32Value {
|
|
||||||
*p = val
|
|
||||||
return (*float32Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *float32Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseFloat(s, 32)
|
|
||||||
*f = float32Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *float32Value) Type() string {
|
|
||||||
return "float32"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *float32Value) String() string { return strconv.FormatFloat(float64(*f), 'g', -1, 32) }
|
|
||||||
|
|
||||||
func float32Conv(sval string) (interface{}, error) {
|
|
||||||
v, err := strconv.ParseFloat(sval, 32)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return float32(v), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetFloat32 return the float32 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetFloat32(name string) (float32, error) {
|
|
||||||
val, err := f.getFlagType(name, "float32", float32Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(float32), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float32Var defines a float32 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a float32 variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Float32Var(p *float32, name string, value float32, usage string) {
|
|
||||||
f.VarP(newFloat32Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float32VarP is like Float32Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Float32VarP(p *float32, name, shorthand string, value float32, usage string) {
|
|
||||||
f.VarP(newFloat32Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float32Var defines a float32 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a float32 variable in which to store the value of the flag.
|
|
||||||
func Float32Var(p *float32, name string, value float32, usage string) {
|
|
||||||
CommandLine.VarP(newFloat32Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float32VarP is like Float32Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Float32VarP(p *float32, name, shorthand string, value float32, usage string) {
|
|
||||||
CommandLine.VarP(newFloat32Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float32 defines a float32 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a float32 variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Float32(name string, value float32, usage string) *float32 {
|
|
||||||
p := new(float32)
|
|
||||||
f.Float32VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float32P is like Float32, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Float32P(name, shorthand string, value float32, usage string) *float32 {
|
|
||||||
p := new(float32)
|
|
||||||
f.Float32VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float32 defines a float32 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a float32 variable that stores the value of the flag.
|
|
||||||
func Float32(name string, value float32, usage string) *float32 {
|
|
||||||
return CommandLine.Float32P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float32P is like Float32, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Float32P(name, shorthand string, value float32, usage string) *float32 {
|
|
||||||
return CommandLine.Float32P(name, shorthand, value, usage)
|
|
||||||
}
|
|
84
vendor/github.com/spf13/pflag/float64.go
generated
vendored
84
vendor/github.com/spf13/pflag/float64.go
generated
vendored
@ -1,84 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- float64 Value
|
|
||||||
type float64Value float64
|
|
||||||
|
|
||||||
func newFloat64Value(val float64, p *float64) *float64Value {
|
|
||||||
*p = val
|
|
||||||
return (*float64Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *float64Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseFloat(s, 64)
|
|
||||||
*f = float64Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *float64Value) Type() string {
|
|
||||||
return "float64"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *float64Value) String() string { return strconv.FormatFloat(float64(*f), 'g', -1, 64) }
|
|
||||||
|
|
||||||
func float64Conv(sval string) (interface{}, error) {
|
|
||||||
return strconv.ParseFloat(sval, 64)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetFloat64 return the float64 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetFloat64(name string) (float64, error) {
|
|
||||||
val, err := f.getFlagType(name, "float64", float64Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(float64), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float64Var defines a float64 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a float64 variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Float64Var(p *float64, name string, value float64, usage string) {
|
|
||||||
f.VarP(newFloat64Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float64VarP is like Float64Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Float64VarP(p *float64, name, shorthand string, value float64, usage string) {
|
|
||||||
f.VarP(newFloat64Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float64Var defines a float64 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a float64 variable in which to store the value of the flag.
|
|
||||||
func Float64Var(p *float64, name string, value float64, usage string) {
|
|
||||||
CommandLine.VarP(newFloat64Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float64VarP is like Float64Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Float64VarP(p *float64, name, shorthand string, value float64, usage string) {
|
|
||||||
CommandLine.VarP(newFloat64Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float64 defines a float64 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a float64 variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Float64(name string, value float64, usage string) *float64 {
|
|
||||||
p := new(float64)
|
|
||||||
f.Float64VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float64P is like Float64, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Float64P(name, shorthand string, value float64, usage string) *float64 {
|
|
||||||
p := new(float64)
|
|
||||||
f.Float64VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float64 defines a float64 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a float64 variable that stores the value of the flag.
|
|
||||||
func Float64(name string, value float64, usage string) *float64 {
|
|
||||||
return CommandLine.Float64P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Float64P is like Float64, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Float64P(name, shorthand string, value float64, usage string) *float64 {
|
|
||||||
return CommandLine.Float64P(name, shorthand, value, usage)
|
|
||||||
}
|
|
105
vendor/github.com/spf13/pflag/golangflag.go
generated
vendored
105
vendor/github.com/spf13/pflag/golangflag.go
generated
vendored
@ -1,105 +0,0 @@
|
|||||||
// Copyright 2009 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
goflag "flag"
|
|
||||||
"reflect"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// flagValueWrapper implements pflag.Value around a flag.Value. The main
|
|
||||||
// difference here is the addition of the Type method that returns a string
|
|
||||||
// name of the type. As this is generally unknown, we approximate that with
|
|
||||||
// reflection.
|
|
||||||
type flagValueWrapper struct {
|
|
||||||
inner goflag.Value
|
|
||||||
flagType string
|
|
||||||
}
|
|
||||||
|
|
||||||
// We are just copying the boolFlag interface out of goflag as that is what
|
|
||||||
// they use to decide if a flag should get "true" when no arg is given.
|
|
||||||
type goBoolFlag interface {
|
|
||||||
goflag.Value
|
|
||||||
IsBoolFlag() bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func wrapFlagValue(v goflag.Value) Value {
|
|
||||||
// If the flag.Value happens to also be a pflag.Value, just use it directly.
|
|
||||||
if pv, ok := v.(Value); ok {
|
|
||||||
return pv
|
|
||||||
}
|
|
||||||
|
|
||||||
pv := &flagValueWrapper{
|
|
||||||
inner: v,
|
|
||||||
}
|
|
||||||
|
|
||||||
t := reflect.TypeOf(v)
|
|
||||||
if t.Kind() == reflect.Interface || t.Kind() == reflect.Ptr {
|
|
||||||
t = t.Elem()
|
|
||||||
}
|
|
||||||
|
|
||||||
pv.flagType = strings.TrimSuffix(t.Name(), "Value")
|
|
||||||
return pv
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v *flagValueWrapper) String() string {
|
|
||||||
return v.inner.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v *flagValueWrapper) Set(s string) error {
|
|
||||||
return v.inner.Set(s)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v *flagValueWrapper) Type() string {
|
|
||||||
return v.flagType
|
|
||||||
}
|
|
||||||
|
|
||||||
// PFlagFromGoFlag will return a *pflag.Flag given a *flag.Flag
|
|
||||||
// If the *flag.Flag.Name was a single character (ex: `v`) it will be accessiblei
|
|
||||||
// with both `-v` and `--v` in flags. If the golang flag was more than a single
|
|
||||||
// character (ex: `verbose`) it will only be accessible via `--verbose`
|
|
||||||
func PFlagFromGoFlag(goflag *goflag.Flag) *Flag {
|
|
||||||
// Remember the default value as a string; it won't change.
|
|
||||||
flag := &Flag{
|
|
||||||
Name: goflag.Name,
|
|
||||||
Usage: goflag.Usage,
|
|
||||||
Value: wrapFlagValue(goflag.Value),
|
|
||||||
// Looks like golang flags don't set DefValue correctly :-(
|
|
||||||
//DefValue: goflag.DefValue,
|
|
||||||
DefValue: goflag.Value.String(),
|
|
||||||
}
|
|
||||||
// Ex: if the golang flag was -v, allow both -v and --v to work
|
|
||||||
if len(flag.Name) == 1 {
|
|
||||||
flag.Shorthand = flag.Name
|
|
||||||
}
|
|
||||||
if fv, ok := goflag.Value.(goBoolFlag); ok && fv.IsBoolFlag() {
|
|
||||||
flag.NoOptDefVal = "true"
|
|
||||||
}
|
|
||||||
return flag
|
|
||||||
}
|
|
||||||
|
|
||||||
// AddGoFlag will add the given *flag.Flag to the pflag.FlagSet
|
|
||||||
func (f *FlagSet) AddGoFlag(goflag *goflag.Flag) {
|
|
||||||
if f.Lookup(goflag.Name) != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
newflag := PFlagFromGoFlag(goflag)
|
|
||||||
f.AddFlag(newflag)
|
|
||||||
}
|
|
||||||
|
|
||||||
// AddGoFlagSet will add the given *flag.FlagSet to the pflag.FlagSet
|
|
||||||
func (f *FlagSet) AddGoFlagSet(newSet *goflag.FlagSet) {
|
|
||||||
if newSet == nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
newSet.VisitAll(func(goflag *goflag.Flag) {
|
|
||||||
f.AddGoFlag(goflag)
|
|
||||||
})
|
|
||||||
if f.addedGoFlagSets == nil {
|
|
||||||
f.addedGoFlagSets = make([]*goflag.FlagSet, 0)
|
|
||||||
}
|
|
||||||
f.addedGoFlagSets = append(f.addedGoFlagSets, newSet)
|
|
||||||
}
|
|
47
vendor/github.com/spf13/pflag/golangflag_test.go
generated
vendored
47
vendor/github.com/spf13/pflag/golangflag_test.go
generated
vendored
@ -1,47 +0,0 @@
|
|||||||
// Copyright 2009 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
goflag "flag"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestGoflags(t *testing.T) {
|
|
||||||
goflag.String("stringFlag", "stringFlag", "stringFlag")
|
|
||||||
goflag.Bool("boolFlag", false, "boolFlag")
|
|
||||||
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
|
|
||||||
f.AddGoFlagSet(goflag.CommandLine)
|
|
||||||
err := f.Parse([]string{"--stringFlag=bob", "--boolFlag"})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; get", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getString, err := f.GetString("stringFlag")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; get", err)
|
|
||||||
}
|
|
||||||
if getString != "bob" {
|
|
||||||
t.Fatalf("expected getString=bob but got getString=%s", getString)
|
|
||||||
}
|
|
||||||
|
|
||||||
getBool, err := f.GetBool("boolFlag")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; get", err)
|
|
||||||
}
|
|
||||||
if getBool != true {
|
|
||||||
t.Fatalf("expected getBool=true but got getBool=%v", getBool)
|
|
||||||
}
|
|
||||||
if !f.Parsed() {
|
|
||||||
t.Fatal("f.Parsed() return false after f.Parse() called")
|
|
||||||
}
|
|
||||||
|
|
||||||
// in fact it is useless. because `go test` called flag.Parse()
|
|
||||||
if !goflag.CommandLine.Parsed() {
|
|
||||||
t.Fatal("goflag.CommandLine.Parsed() return false after f.Parse() called")
|
|
||||||
}
|
|
||||||
}
|
|
84
vendor/github.com/spf13/pflag/int.go
generated
vendored
84
vendor/github.com/spf13/pflag/int.go
generated
vendored
@ -1,84 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- int Value
|
|
||||||
type intValue int
|
|
||||||
|
|
||||||
func newIntValue(val int, p *int) *intValue {
|
|
||||||
*p = val
|
|
||||||
return (*intValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *intValue) Set(s string) error {
|
|
||||||
v, err := strconv.ParseInt(s, 0, 64)
|
|
||||||
*i = intValue(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *intValue) Type() string {
|
|
||||||
return "int"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *intValue) String() string { return strconv.Itoa(int(*i)) }
|
|
||||||
|
|
||||||
func intConv(sval string) (interface{}, error) {
|
|
||||||
return strconv.Atoi(sval)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetInt return the int value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetInt(name string) (int, error) {
|
|
||||||
val, err := f.getFlagType(name, "int", intConv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(int), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntVar defines an int flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) IntVar(p *int, name string, value int, usage string) {
|
|
||||||
f.VarP(newIntValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntVarP is like IntVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IntVarP(p *int, name, shorthand string, value int, usage string) {
|
|
||||||
f.VarP(newIntValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntVar defines an int flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int variable in which to store the value of the flag.
|
|
||||||
func IntVar(p *int, name string, value int, usage string) {
|
|
||||||
CommandLine.VarP(newIntValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntVarP is like IntVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IntVarP(p *int, name, shorthand string, value int, usage string) {
|
|
||||||
CommandLine.VarP(newIntValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int defines an int flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Int(name string, value int, usage string) *int {
|
|
||||||
p := new(int)
|
|
||||||
f.IntVarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntP is like Int, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IntP(name, shorthand string, value int, usage string) *int {
|
|
||||||
p := new(int)
|
|
||||||
f.IntVarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int defines an int flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int variable that stores the value of the flag.
|
|
||||||
func Int(name string, value int, usage string) *int {
|
|
||||||
return CommandLine.IntP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntP is like Int, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IntP(name, shorthand string, value int, usage string) *int {
|
|
||||||
return CommandLine.IntP(name, shorthand, value, usage)
|
|
||||||
}
|
|
88
vendor/github.com/spf13/pflag/int16.go
generated
vendored
88
vendor/github.com/spf13/pflag/int16.go
generated
vendored
@ -1,88 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- int16 Value
|
|
||||||
type int16Value int16
|
|
||||||
|
|
||||||
func newInt16Value(val int16, p *int16) *int16Value {
|
|
||||||
*p = val
|
|
||||||
return (*int16Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int16Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseInt(s, 0, 16)
|
|
||||||
*i = int16Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int16Value) Type() string {
|
|
||||||
return "int16"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int16Value) String() string { return strconv.FormatInt(int64(*i), 10) }
|
|
||||||
|
|
||||||
func int16Conv(sval string) (interface{}, error) {
|
|
||||||
v, err := strconv.ParseInt(sval, 0, 16)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return int16(v), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetInt16 returns the int16 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetInt16(name string) (int16, error) {
|
|
||||||
val, err := f.getFlagType(name, "int16", int16Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(int16), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int16Var defines an int16 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int16 variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Int16Var(p *int16, name string, value int16, usage string) {
|
|
||||||
f.VarP(newInt16Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int16VarP is like Int16Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Int16VarP(p *int16, name, shorthand string, value int16, usage string) {
|
|
||||||
f.VarP(newInt16Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int16Var defines an int16 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int16 variable in which to store the value of the flag.
|
|
||||||
func Int16Var(p *int16, name string, value int16, usage string) {
|
|
||||||
CommandLine.VarP(newInt16Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int16VarP is like Int16Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Int16VarP(p *int16, name, shorthand string, value int16, usage string) {
|
|
||||||
CommandLine.VarP(newInt16Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int16 defines an int16 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int16 variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Int16(name string, value int16, usage string) *int16 {
|
|
||||||
p := new(int16)
|
|
||||||
f.Int16VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int16P is like Int16, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Int16P(name, shorthand string, value int16, usage string) *int16 {
|
|
||||||
p := new(int16)
|
|
||||||
f.Int16VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int16 defines an int16 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int16 variable that stores the value of the flag.
|
|
||||||
func Int16(name string, value int16, usage string) *int16 {
|
|
||||||
return CommandLine.Int16P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int16P is like Int16, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Int16P(name, shorthand string, value int16, usage string) *int16 {
|
|
||||||
return CommandLine.Int16P(name, shorthand, value, usage)
|
|
||||||
}
|
|
88
vendor/github.com/spf13/pflag/int32.go
generated
vendored
88
vendor/github.com/spf13/pflag/int32.go
generated
vendored
@ -1,88 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- int32 Value
|
|
||||||
type int32Value int32
|
|
||||||
|
|
||||||
func newInt32Value(val int32, p *int32) *int32Value {
|
|
||||||
*p = val
|
|
||||||
return (*int32Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int32Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseInt(s, 0, 32)
|
|
||||||
*i = int32Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int32Value) Type() string {
|
|
||||||
return "int32"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int32Value) String() string { return strconv.FormatInt(int64(*i), 10) }
|
|
||||||
|
|
||||||
func int32Conv(sval string) (interface{}, error) {
|
|
||||||
v, err := strconv.ParseInt(sval, 0, 32)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return int32(v), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetInt32 return the int32 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetInt32(name string) (int32, error) {
|
|
||||||
val, err := f.getFlagType(name, "int32", int32Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(int32), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int32Var defines an int32 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int32 variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Int32Var(p *int32, name string, value int32, usage string) {
|
|
||||||
f.VarP(newInt32Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int32VarP is like Int32Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Int32VarP(p *int32, name, shorthand string, value int32, usage string) {
|
|
||||||
f.VarP(newInt32Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int32Var defines an int32 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int32 variable in which to store the value of the flag.
|
|
||||||
func Int32Var(p *int32, name string, value int32, usage string) {
|
|
||||||
CommandLine.VarP(newInt32Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int32VarP is like Int32Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Int32VarP(p *int32, name, shorthand string, value int32, usage string) {
|
|
||||||
CommandLine.VarP(newInt32Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int32 defines an int32 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int32 variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Int32(name string, value int32, usage string) *int32 {
|
|
||||||
p := new(int32)
|
|
||||||
f.Int32VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int32P is like Int32, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Int32P(name, shorthand string, value int32, usage string) *int32 {
|
|
||||||
p := new(int32)
|
|
||||||
f.Int32VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int32 defines an int32 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int32 variable that stores the value of the flag.
|
|
||||||
func Int32(name string, value int32, usage string) *int32 {
|
|
||||||
return CommandLine.Int32P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int32P is like Int32, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Int32P(name, shorthand string, value int32, usage string) *int32 {
|
|
||||||
return CommandLine.Int32P(name, shorthand, value, usage)
|
|
||||||
}
|
|
84
vendor/github.com/spf13/pflag/int64.go
generated
vendored
84
vendor/github.com/spf13/pflag/int64.go
generated
vendored
@ -1,84 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- int64 Value
|
|
||||||
type int64Value int64
|
|
||||||
|
|
||||||
func newInt64Value(val int64, p *int64) *int64Value {
|
|
||||||
*p = val
|
|
||||||
return (*int64Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int64Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseInt(s, 0, 64)
|
|
||||||
*i = int64Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int64Value) Type() string {
|
|
||||||
return "int64"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int64Value) String() string { return strconv.FormatInt(int64(*i), 10) }
|
|
||||||
|
|
||||||
func int64Conv(sval string) (interface{}, error) {
|
|
||||||
return strconv.ParseInt(sval, 0, 64)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetInt64 return the int64 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetInt64(name string) (int64, error) {
|
|
||||||
val, err := f.getFlagType(name, "int64", int64Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(int64), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int64Var defines an int64 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int64 variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Int64Var(p *int64, name string, value int64, usage string) {
|
|
||||||
f.VarP(newInt64Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int64VarP is like Int64Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Int64VarP(p *int64, name, shorthand string, value int64, usage string) {
|
|
||||||
f.VarP(newInt64Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int64Var defines an int64 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int64 variable in which to store the value of the flag.
|
|
||||||
func Int64Var(p *int64, name string, value int64, usage string) {
|
|
||||||
CommandLine.VarP(newInt64Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int64VarP is like Int64Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Int64VarP(p *int64, name, shorthand string, value int64, usage string) {
|
|
||||||
CommandLine.VarP(newInt64Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int64 defines an int64 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int64 variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Int64(name string, value int64, usage string) *int64 {
|
|
||||||
p := new(int64)
|
|
||||||
f.Int64VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int64P is like Int64, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Int64P(name, shorthand string, value int64, usage string) *int64 {
|
|
||||||
p := new(int64)
|
|
||||||
f.Int64VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int64 defines an int64 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int64 variable that stores the value of the flag.
|
|
||||||
func Int64(name string, value int64, usage string) *int64 {
|
|
||||||
return CommandLine.Int64P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int64P is like Int64, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Int64P(name, shorthand string, value int64, usage string) *int64 {
|
|
||||||
return CommandLine.Int64P(name, shorthand, value, usage)
|
|
||||||
}
|
|
88
vendor/github.com/spf13/pflag/int8.go
generated
vendored
88
vendor/github.com/spf13/pflag/int8.go
generated
vendored
@ -1,88 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- int8 Value
|
|
||||||
type int8Value int8
|
|
||||||
|
|
||||||
func newInt8Value(val int8, p *int8) *int8Value {
|
|
||||||
*p = val
|
|
||||||
return (*int8Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int8Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseInt(s, 0, 8)
|
|
||||||
*i = int8Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int8Value) Type() string {
|
|
||||||
return "int8"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *int8Value) String() string { return strconv.FormatInt(int64(*i), 10) }
|
|
||||||
|
|
||||||
func int8Conv(sval string) (interface{}, error) {
|
|
||||||
v, err := strconv.ParseInt(sval, 0, 8)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return int8(v), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetInt8 return the int8 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetInt8(name string) (int8, error) {
|
|
||||||
val, err := f.getFlagType(name, "int8", int8Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(int8), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int8Var defines an int8 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int8 variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Int8Var(p *int8, name string, value int8, usage string) {
|
|
||||||
f.VarP(newInt8Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int8VarP is like Int8Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Int8VarP(p *int8, name, shorthand string, value int8, usage string) {
|
|
||||||
f.VarP(newInt8Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int8Var defines an int8 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an int8 variable in which to store the value of the flag.
|
|
||||||
func Int8Var(p *int8, name string, value int8, usage string) {
|
|
||||||
CommandLine.VarP(newInt8Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int8VarP is like Int8Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Int8VarP(p *int8, name, shorthand string, value int8, usage string) {
|
|
||||||
CommandLine.VarP(newInt8Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int8 defines an int8 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int8 variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Int8(name string, value int8, usage string) *int8 {
|
|
||||||
p := new(int8)
|
|
||||||
f.Int8VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int8P is like Int8, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Int8P(name, shorthand string, value int8, usage string) *int8 {
|
|
||||||
p := new(int8)
|
|
||||||
f.Int8VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int8 defines an int8 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an int8 variable that stores the value of the flag.
|
|
||||||
func Int8(name string, value int8, usage string) *int8 {
|
|
||||||
return CommandLine.Int8P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int8P is like Int8, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Int8P(name, shorthand string, value int8, usage string) *int8 {
|
|
||||||
return CommandLine.Int8P(name, shorthand, value, usage)
|
|
||||||
}
|
|
128
vendor/github.com/spf13/pflag/int_slice.go
generated
vendored
128
vendor/github.com/spf13/pflag/int_slice.go
generated
vendored
@ -1,128 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// -- intSlice Value
|
|
||||||
type intSliceValue struct {
|
|
||||||
value *[]int
|
|
||||||
changed bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func newIntSliceValue(val []int, p *[]int) *intSliceValue {
|
|
||||||
isv := new(intSliceValue)
|
|
||||||
isv.value = p
|
|
||||||
*isv.value = val
|
|
||||||
return isv
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *intSliceValue) Set(val string) error {
|
|
||||||
ss := strings.Split(val, ",")
|
|
||||||
out := make([]int, len(ss))
|
|
||||||
for i, d := range ss {
|
|
||||||
var err error
|
|
||||||
out[i], err = strconv.Atoi(d)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
if !s.changed {
|
|
||||||
*s.value = out
|
|
||||||
} else {
|
|
||||||
*s.value = append(*s.value, out...)
|
|
||||||
}
|
|
||||||
s.changed = true
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *intSliceValue) Type() string {
|
|
||||||
return "intSlice"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *intSliceValue) String() string {
|
|
||||||
out := make([]string, len(*s.value))
|
|
||||||
for i, d := range *s.value {
|
|
||||||
out[i] = fmt.Sprintf("%d", d)
|
|
||||||
}
|
|
||||||
return "[" + strings.Join(out, ",") + "]"
|
|
||||||
}
|
|
||||||
|
|
||||||
func intSliceConv(val string) (interface{}, error) {
|
|
||||||
val = strings.Trim(val, "[]")
|
|
||||||
// Empty string would cause a slice with one (empty) entry
|
|
||||||
if len(val) == 0 {
|
|
||||||
return []int{}, nil
|
|
||||||
}
|
|
||||||
ss := strings.Split(val, ",")
|
|
||||||
out := make([]int, len(ss))
|
|
||||||
for i, d := range ss {
|
|
||||||
var err error
|
|
||||||
out[i], err = strconv.Atoi(d)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
return out, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetIntSlice return the []int value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetIntSlice(name string) ([]int, error) {
|
|
||||||
val, err := f.getFlagType(name, "intSlice", intSliceConv)
|
|
||||||
if err != nil {
|
|
||||||
return []int{}, err
|
|
||||||
}
|
|
||||||
return val.([]int), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntSliceVar defines a intSlice flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []int variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) IntSliceVar(p *[]int, name string, value []int, usage string) {
|
|
||||||
f.VarP(newIntSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntSliceVarP is like IntSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IntSliceVarP(p *[]int, name, shorthand string, value []int, usage string) {
|
|
||||||
f.VarP(newIntSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntSliceVar defines a int[] flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a int[] variable in which to store the value of the flag.
|
|
||||||
func IntSliceVar(p *[]int, name string, value []int, usage string) {
|
|
||||||
CommandLine.VarP(newIntSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntSliceVarP is like IntSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IntSliceVarP(p *[]int, name, shorthand string, value []int, usage string) {
|
|
||||||
CommandLine.VarP(newIntSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntSlice defines a []int flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []int variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) IntSlice(name string, value []int, usage string) *[]int {
|
|
||||||
p := []int{}
|
|
||||||
f.IntSliceVarP(&p, name, "", value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntSliceP is like IntSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IntSliceP(name, shorthand string, value []int, usage string) *[]int {
|
|
||||||
p := []int{}
|
|
||||||
f.IntSliceVarP(&p, name, shorthand, value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntSlice defines a []int flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []int variable that stores the value of the flag.
|
|
||||||
func IntSlice(name string, value []int, usage string) *[]int {
|
|
||||||
return CommandLine.IntSliceP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IntSliceP is like IntSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IntSliceP(name, shorthand string, value []int, usage string) *[]int {
|
|
||||||
return CommandLine.IntSliceP(name, shorthand, value, usage)
|
|
||||||
}
|
|
165
vendor/github.com/spf13/pflag/int_slice_test.go
generated
vendored
165
vendor/github.com/spf13/pflag/int_slice_test.go
generated
vendored
@ -1,165 +0,0 @@
|
|||||||
// Copyright 2009 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpISFlagSet(isp *[]int) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.IntSliceVar(isp, "is", []int{}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func setUpISFlagSetWithDefault(isp *[]int) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.IntSliceVar(isp, "is", []int{0, 1}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmptyIS(t *testing.T) {
|
|
||||||
var is []int
|
|
||||||
f := setUpISFlagSet(&is)
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getIS, err := f.GetIntSlice("is")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetIntSlice():", err)
|
|
||||||
}
|
|
||||||
if len(getIS) != 0 {
|
|
||||||
t.Fatalf("got is %v with len=%d but expected length=0", getIS, len(getIS))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestIS(t *testing.T) {
|
|
||||||
var is []int
|
|
||||||
f := setUpISFlagSet(&is)
|
|
||||||
|
|
||||||
vals := []string{"1", "2", "4", "3"}
|
|
||||||
arg := fmt.Sprintf("--is=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range is {
|
|
||||||
d, err := strconv.Atoi(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected is[%d] to be %s but got: %d", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
getIS, err := f.GetIntSlice("is")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
for i, v := range getIS {
|
|
||||||
d, err := strconv.Atoi(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected is[%d] to be %s but got: %d from GetIntSlice", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestISDefault(t *testing.T) {
|
|
||||||
var is []int
|
|
||||||
f := setUpISFlagSetWithDefault(&is)
|
|
||||||
|
|
||||||
vals := []string{"0", "1"}
|
|
||||||
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range is {
|
|
||||||
d, err := strconv.Atoi(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected is[%d] to be %d but got: %d", i, d, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getIS, err := f.GetIntSlice("is")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetIntSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getIS {
|
|
||||||
d, err := strconv.Atoi(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetIntSlice():", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected is[%d] to be %d from GetIntSlice but got: %d", i, d, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestISWithDefault(t *testing.T) {
|
|
||||||
var is []int
|
|
||||||
f := setUpISFlagSetWithDefault(&is)
|
|
||||||
|
|
||||||
vals := []string{"1", "2"}
|
|
||||||
arg := fmt.Sprintf("--is=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range is {
|
|
||||||
d, err := strconv.Atoi(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected is[%d] to be %d but got: %d", i, d, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getIS, err := f.GetIntSlice("is")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetIntSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getIS {
|
|
||||||
d, err := strconv.Atoi(vals[i])
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if d != v {
|
|
||||||
t.Fatalf("expected is[%d] to be %d from GetIntSlice but got: %d", i, d, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestISCalledTwice(t *testing.T) {
|
|
||||||
var is []int
|
|
||||||
f := setUpISFlagSet(&is)
|
|
||||||
|
|
||||||
in := []string{"1,2", "3"}
|
|
||||||
expected := []int{1, 2, 3}
|
|
||||||
argfmt := "--is=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
err := f.Parse([]string{arg1, arg2})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range is {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected is[%d] to be %d but got: %d", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
94
vendor/github.com/spf13/pflag/ip.go
generated
vendored
94
vendor/github.com/spf13/pflag/ip.go
generated
vendored
@ -1,94 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"net"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// -- net.IP value
|
|
||||||
type ipValue net.IP
|
|
||||||
|
|
||||||
func newIPValue(val net.IP, p *net.IP) *ipValue {
|
|
||||||
*p = val
|
|
||||||
return (*ipValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *ipValue) String() string { return net.IP(*i).String() }
|
|
||||||
func (i *ipValue) Set(s string) error {
|
|
||||||
ip := net.ParseIP(strings.TrimSpace(s))
|
|
||||||
if ip == nil {
|
|
||||||
return fmt.Errorf("failed to parse IP: %q", s)
|
|
||||||
}
|
|
||||||
*i = ipValue(ip)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *ipValue) Type() string {
|
|
||||||
return "ip"
|
|
||||||
}
|
|
||||||
|
|
||||||
func ipConv(sval string) (interface{}, error) {
|
|
||||||
ip := net.ParseIP(sval)
|
|
||||||
if ip != nil {
|
|
||||||
return ip, nil
|
|
||||||
}
|
|
||||||
return nil, fmt.Errorf("invalid string being converted to IP address: %s", sval)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetIP return the net.IP value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetIP(name string) (net.IP, error) {
|
|
||||||
val, err := f.getFlagType(name, "ip", ipConv)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return val.(net.IP), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPVar defines an net.IP flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an net.IP variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) IPVar(p *net.IP, name string, value net.IP, usage string) {
|
|
||||||
f.VarP(newIPValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPVarP is like IPVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IPVarP(p *net.IP, name, shorthand string, value net.IP, usage string) {
|
|
||||||
f.VarP(newIPValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPVar defines an net.IP flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an net.IP variable in which to store the value of the flag.
|
|
||||||
func IPVar(p *net.IP, name string, value net.IP, usage string) {
|
|
||||||
CommandLine.VarP(newIPValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPVarP is like IPVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IPVarP(p *net.IP, name, shorthand string, value net.IP, usage string) {
|
|
||||||
CommandLine.VarP(newIPValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IP defines an net.IP flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an net.IP variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) IP(name string, value net.IP, usage string) *net.IP {
|
|
||||||
p := new(net.IP)
|
|
||||||
f.IPVarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPP is like IP, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IPP(name, shorthand string, value net.IP, usage string) *net.IP {
|
|
||||||
p := new(net.IP)
|
|
||||||
f.IPVarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IP defines an net.IP flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an net.IP variable that stores the value of the flag.
|
|
||||||
func IP(name string, value net.IP, usage string) *net.IP {
|
|
||||||
return CommandLine.IPP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPP is like IP, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IPP(name, shorthand string, value net.IP, usage string) *net.IP {
|
|
||||||
return CommandLine.IPP(name, shorthand, value, usage)
|
|
||||||
}
|
|
148
vendor/github.com/spf13/pflag/ip_slice.go
generated
vendored
148
vendor/github.com/spf13/pflag/ip_slice.go
generated
vendored
@ -1,148 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"net"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// -- ipSlice Value
|
|
||||||
type ipSliceValue struct {
|
|
||||||
value *[]net.IP
|
|
||||||
changed bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func newIPSliceValue(val []net.IP, p *[]net.IP) *ipSliceValue {
|
|
||||||
ipsv := new(ipSliceValue)
|
|
||||||
ipsv.value = p
|
|
||||||
*ipsv.value = val
|
|
||||||
return ipsv
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set converts, and assigns, the comma-separated IP argument string representation as the []net.IP value of this flag.
|
|
||||||
// If Set is called on a flag that already has a []net.IP assigned, the newly converted values will be appended.
|
|
||||||
func (s *ipSliceValue) Set(val string) error {
|
|
||||||
|
|
||||||
// remove all quote characters
|
|
||||||
rmQuote := strings.NewReplacer(`"`, "", `'`, "", "`", "")
|
|
||||||
|
|
||||||
// read flag arguments with CSV parser
|
|
||||||
ipStrSlice, err := readAsCSV(rmQuote.Replace(val))
|
|
||||||
if err != nil && err != io.EOF {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// parse ip values into slice
|
|
||||||
out := make([]net.IP, 0, len(ipStrSlice))
|
|
||||||
for _, ipStr := range ipStrSlice {
|
|
||||||
ip := net.ParseIP(strings.TrimSpace(ipStr))
|
|
||||||
if ip == nil {
|
|
||||||
return fmt.Errorf("invalid string being converted to IP address: %s", ipStr)
|
|
||||||
}
|
|
||||||
out = append(out, ip)
|
|
||||||
}
|
|
||||||
|
|
||||||
if !s.changed {
|
|
||||||
*s.value = out
|
|
||||||
} else {
|
|
||||||
*s.value = append(*s.value, out...)
|
|
||||||
}
|
|
||||||
|
|
||||||
s.changed = true
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Type returns a string that uniquely represents this flag's type.
|
|
||||||
func (s *ipSliceValue) Type() string {
|
|
||||||
return "ipSlice"
|
|
||||||
}
|
|
||||||
|
|
||||||
// String defines a "native" format for this net.IP slice flag value.
|
|
||||||
func (s *ipSliceValue) String() string {
|
|
||||||
|
|
||||||
ipStrSlice := make([]string, len(*s.value))
|
|
||||||
for i, ip := range *s.value {
|
|
||||||
ipStrSlice[i] = ip.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
out, _ := writeAsCSV(ipStrSlice)
|
|
||||||
|
|
||||||
return "[" + out + "]"
|
|
||||||
}
|
|
||||||
|
|
||||||
func ipSliceConv(val string) (interface{}, error) {
|
|
||||||
val = strings.Trim(val, "[]")
|
|
||||||
// Emtpy string would cause a slice with one (empty) entry
|
|
||||||
if len(val) == 0 {
|
|
||||||
return []net.IP{}, nil
|
|
||||||
}
|
|
||||||
ss := strings.Split(val, ",")
|
|
||||||
out := make([]net.IP, len(ss))
|
|
||||||
for i, sval := range ss {
|
|
||||||
ip := net.ParseIP(strings.TrimSpace(sval))
|
|
||||||
if ip == nil {
|
|
||||||
return nil, fmt.Errorf("invalid string being converted to IP address: %s", sval)
|
|
||||||
}
|
|
||||||
out[i] = ip
|
|
||||||
}
|
|
||||||
return out, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetIPSlice returns the []net.IP value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetIPSlice(name string) ([]net.IP, error) {
|
|
||||||
val, err := f.getFlagType(name, "ipSlice", ipSliceConv)
|
|
||||||
if err != nil {
|
|
||||||
return []net.IP{}, err
|
|
||||||
}
|
|
||||||
return val.([]net.IP), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPSliceVar defines a ipSlice flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []net.IP variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) IPSliceVar(p *[]net.IP, name string, value []net.IP, usage string) {
|
|
||||||
f.VarP(newIPSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPSliceVarP is like IPSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IPSliceVarP(p *[]net.IP, name, shorthand string, value []net.IP, usage string) {
|
|
||||||
f.VarP(newIPSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPSliceVar defines a []net.IP flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []net.IP variable in which to store the value of the flag.
|
|
||||||
func IPSliceVar(p *[]net.IP, name string, value []net.IP, usage string) {
|
|
||||||
CommandLine.VarP(newIPSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPSliceVarP is like IPSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IPSliceVarP(p *[]net.IP, name, shorthand string, value []net.IP, usage string) {
|
|
||||||
CommandLine.VarP(newIPSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPSlice defines a []net.IP flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []net.IP variable that stores the value of that flag.
|
|
||||||
func (f *FlagSet) IPSlice(name string, value []net.IP, usage string) *[]net.IP {
|
|
||||||
p := []net.IP{}
|
|
||||||
f.IPSliceVarP(&p, name, "", value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPSliceP is like IPSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IPSliceP(name, shorthand string, value []net.IP, usage string) *[]net.IP {
|
|
||||||
p := []net.IP{}
|
|
||||||
f.IPSliceVarP(&p, name, shorthand, value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPSlice defines a []net.IP flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []net.IP variable that stores the value of the flag.
|
|
||||||
func IPSlice(name string, value []net.IP, usage string) *[]net.IP {
|
|
||||||
return CommandLine.IPSliceP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPSliceP is like IPSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IPSliceP(name, shorthand string, value []net.IP, usage string) *[]net.IP {
|
|
||||||
return CommandLine.IPSliceP(name, shorthand, value, usage)
|
|
||||||
}
|
|
222
vendor/github.com/spf13/pflag/ip_slice_test.go
generated
vendored
222
vendor/github.com/spf13/pflag/ip_slice_test.go
generated
vendored
@ -1,222 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"net"
|
|
||||||
"strings"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpIPSFlagSet(ipsp *[]net.IP) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.IPSliceVar(ipsp, "ips", []net.IP{}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func setUpIPSFlagSetWithDefault(ipsp *[]net.IP) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.IPSliceVar(ipsp, "ips",
|
|
||||||
[]net.IP{
|
|
||||||
net.ParseIP("192.168.1.1"),
|
|
||||||
net.ParseIP("0:0:0:0:0:0:0:1"),
|
|
||||||
},
|
|
||||||
"Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmptyIP(t *testing.T) {
|
|
||||||
var ips []net.IP
|
|
||||||
f := setUpIPSFlagSet(&ips)
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getIPS, err := f.GetIPSlice("ips")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetIPSlice():", err)
|
|
||||||
}
|
|
||||||
if len(getIPS) != 0 {
|
|
||||||
t.Fatalf("got ips %v with len=%d but expected length=0", getIPS, len(getIPS))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestIPS(t *testing.T) {
|
|
||||||
var ips []net.IP
|
|
||||||
f := setUpIPSFlagSet(&ips)
|
|
||||||
|
|
||||||
vals := []string{"192.168.1.1", "10.0.0.1", "0:0:0:0:0:0:0:2"}
|
|
||||||
arg := fmt.Sprintf("--ips=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ips {
|
|
||||||
if ip := net.ParseIP(vals[i]); ip == nil {
|
|
||||||
t.Fatalf("invalid string being converted to IP address: %s", vals[i])
|
|
||||||
} else if !ip.Equal(v) {
|
|
||||||
t.Fatalf("expected ips[%d] to be %s but got: %s from GetIPSlice", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestIPSDefault(t *testing.T) {
|
|
||||||
var ips []net.IP
|
|
||||||
f := setUpIPSFlagSetWithDefault(&ips)
|
|
||||||
|
|
||||||
vals := []string{"192.168.1.1", "0:0:0:0:0:0:0:1"}
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ips {
|
|
||||||
if ip := net.ParseIP(vals[i]); ip == nil {
|
|
||||||
t.Fatalf("invalid string being converted to IP address: %s", vals[i])
|
|
||||||
} else if !ip.Equal(v) {
|
|
||||||
t.Fatalf("expected ips[%d] to be %s but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getIPS, err := f.GetIPSlice("ips")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetIPSlice")
|
|
||||||
}
|
|
||||||
for i, v := range getIPS {
|
|
||||||
if ip := net.ParseIP(vals[i]); ip == nil {
|
|
||||||
t.Fatalf("invalid string being converted to IP address: %s", vals[i])
|
|
||||||
} else if !ip.Equal(v) {
|
|
||||||
t.Fatalf("expected ips[%d] to be %s but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestIPSWithDefault(t *testing.T) {
|
|
||||||
var ips []net.IP
|
|
||||||
f := setUpIPSFlagSetWithDefault(&ips)
|
|
||||||
|
|
||||||
vals := []string{"192.168.1.1", "0:0:0:0:0:0:0:1"}
|
|
||||||
arg := fmt.Sprintf("--ips=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ips {
|
|
||||||
if ip := net.ParseIP(vals[i]); ip == nil {
|
|
||||||
t.Fatalf("invalid string being converted to IP address: %s", vals[i])
|
|
||||||
} else if !ip.Equal(v) {
|
|
||||||
t.Fatalf("expected ips[%d] to be %s but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getIPS, err := f.GetIPSlice("ips")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetIPSlice")
|
|
||||||
}
|
|
||||||
for i, v := range getIPS {
|
|
||||||
if ip := net.ParseIP(vals[i]); ip == nil {
|
|
||||||
t.Fatalf("invalid string being converted to IP address: %s", vals[i])
|
|
||||||
} else if !ip.Equal(v) {
|
|
||||||
t.Fatalf("expected ips[%d] to be %s but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestIPSCalledTwice(t *testing.T) {
|
|
||||||
var ips []net.IP
|
|
||||||
f := setUpIPSFlagSet(&ips)
|
|
||||||
|
|
||||||
in := []string{"192.168.1.2,0:0:0:0:0:0:0:1", "10.0.0.1"}
|
|
||||||
expected := []net.IP{net.ParseIP("192.168.1.2"), net.ParseIP("0:0:0:0:0:0:0:1"), net.ParseIP("10.0.0.1")}
|
|
||||||
argfmt := "ips=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
err := f.Parse([]string{arg1, arg2})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ips {
|
|
||||||
if !expected[i].Equal(v) {
|
|
||||||
t.Fatalf("expected ips[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestIPSBadQuoting(t *testing.T) {
|
|
||||||
|
|
||||||
tests := []struct {
|
|
||||||
Want []net.IP
|
|
||||||
FlagArg []string
|
|
||||||
}{
|
|
||||||
{
|
|
||||||
Want: []net.IP{
|
|
||||||
net.ParseIP("a4ab:61d:f03e:5d7d:fad7:d4c2:a1a5:568"),
|
|
||||||
net.ParseIP("203.107.49.208"),
|
|
||||||
net.ParseIP("14.57.204.90"),
|
|
||||||
},
|
|
||||||
FlagArg: []string{
|
|
||||||
"a4ab:61d:f03e:5d7d:fad7:d4c2:a1a5:568",
|
|
||||||
"203.107.49.208",
|
|
||||||
"14.57.204.90",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []net.IP{
|
|
||||||
net.ParseIP("204.228.73.195"),
|
|
||||||
net.ParseIP("86.141.15.94"),
|
|
||||||
},
|
|
||||||
FlagArg: []string{
|
|
||||||
"204.228.73.195",
|
|
||||||
"86.141.15.94",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []net.IP{
|
|
||||||
net.ParseIP("c70c:db36:3001:890f:c6ea:3f9b:7a39:cc3f"),
|
|
||||||
net.ParseIP("4d17:1d6e:e699:bd7a:88c5:5e7e:ac6a:4472"),
|
|
||||||
},
|
|
||||||
FlagArg: []string{
|
|
||||||
"c70c:db36:3001:890f:c6ea:3f9b:7a39:cc3f",
|
|
||||||
"4d17:1d6e:e699:bd7a:88c5:5e7e:ac6a:4472",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []net.IP{
|
|
||||||
net.ParseIP("5170:f971:cfac:7be3:512a:af37:952c:bc33"),
|
|
||||||
net.ParseIP("93.21.145.140"),
|
|
||||||
net.ParseIP("2cac:61d3:c5ff:6caf:73e0:1b1a:c336:c1ca"),
|
|
||||||
},
|
|
||||||
FlagArg: []string{
|
|
||||||
" 5170:f971:cfac:7be3:512a:af37:952c:bc33 , 93.21.145.140 ",
|
|
||||||
"2cac:61d3:c5ff:6caf:73e0:1b1a:c336:c1ca",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Want: []net.IP{
|
|
||||||
net.ParseIP("2e5e:66b2:6441:848:5b74:76ea:574c:3a7b"),
|
|
||||||
net.ParseIP("2e5e:66b2:6441:848:5b74:76ea:574c:3a7b"),
|
|
||||||
net.ParseIP("2e5e:66b2:6441:848:5b74:76ea:574c:3a7b"),
|
|
||||||
net.ParseIP("2e5e:66b2:6441:848:5b74:76ea:574c:3a7b"),
|
|
||||||
},
|
|
||||||
FlagArg: []string{
|
|
||||||
`"2e5e:66b2:6441:848:5b74:76ea:574c:3a7b, 2e5e:66b2:6441:848:5b74:76ea:574c:3a7b,2e5e:66b2:6441:848:5b74:76ea:574c:3a7b "`,
|
|
||||||
" 2e5e:66b2:6441:848:5b74:76ea:574c:3a7b"},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
for i, test := range tests {
|
|
||||||
|
|
||||||
var ips []net.IP
|
|
||||||
f := setUpIPSFlagSet(&ips)
|
|
||||||
|
|
||||||
if err := f.Parse([]string{fmt.Sprintf("--ips=%s", strings.Join(test.FlagArg, ","))}); err != nil {
|
|
||||||
t.Fatalf("flag parsing failed with error: %s\nparsing:\t%#v\nwant:\t\t%s",
|
|
||||||
err, test.FlagArg, test.Want[i])
|
|
||||||
}
|
|
||||||
|
|
||||||
for j, b := range ips {
|
|
||||||
if !b.Equal(test.Want[j]) {
|
|
||||||
t.Fatalf("bad value parsed for test %d on net.IP %d:\nwant:\t%s\ngot:\t%s", i, j, test.Want[j], b)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
63
vendor/github.com/spf13/pflag/ip_test.go
generated
vendored
63
vendor/github.com/spf13/pflag/ip_test.go
generated
vendored
@ -1,63 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"net"
|
|
||||||
"os"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpIP(ip *net.IP) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.IPVar(ip, "address", net.ParseIP("0.0.0.0"), "IP Address")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestIP(t *testing.T) {
|
|
||||||
testCases := []struct {
|
|
||||||
input string
|
|
||||||
success bool
|
|
||||||
expected string
|
|
||||||
}{
|
|
||||||
{"0.0.0.0", true, "0.0.0.0"},
|
|
||||||
{" 0.0.0.0 ", true, "0.0.0.0"},
|
|
||||||
{"1.2.3.4", true, "1.2.3.4"},
|
|
||||||
{"127.0.0.1", true, "127.0.0.1"},
|
|
||||||
{"255.255.255.255", true, "255.255.255.255"},
|
|
||||||
{"", false, ""},
|
|
||||||
{"0", false, ""},
|
|
||||||
{"localhost", false, ""},
|
|
||||||
{"0.0.0", false, ""},
|
|
||||||
{"0.0.0.", false, ""},
|
|
||||||
{"0.0.0.0.", false, ""},
|
|
||||||
{"0.0.0.256", false, ""},
|
|
||||||
{"0 . 0 . 0 . 0", false, ""},
|
|
||||||
}
|
|
||||||
|
|
||||||
devnull, _ := os.Open(os.DevNull)
|
|
||||||
os.Stderr = devnull
|
|
||||||
for i := range testCases {
|
|
||||||
var addr net.IP
|
|
||||||
f := setUpIP(&addr)
|
|
||||||
|
|
||||||
tc := &testCases[i]
|
|
||||||
|
|
||||||
arg := fmt.Sprintf("--address=%s", tc.input)
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil && tc.success == true {
|
|
||||||
t.Errorf("expected success, got %q", err)
|
|
||||||
continue
|
|
||||||
} else if err == nil && tc.success == false {
|
|
||||||
t.Errorf("expected failure")
|
|
||||||
continue
|
|
||||||
} else if tc.success {
|
|
||||||
ip, err := f.GetIP("address")
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Got error trying to fetch the IP flag: %v", err)
|
|
||||||
}
|
|
||||||
if ip.String() != tc.expected {
|
|
||||||
t.Errorf("expected %q, got %q", tc.expected, ip.String())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
122
vendor/github.com/spf13/pflag/ipmask.go
generated
vendored
122
vendor/github.com/spf13/pflag/ipmask.go
generated
vendored
@ -1,122 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"net"
|
|
||||||
"strconv"
|
|
||||||
)
|
|
||||||
|
|
||||||
// -- net.IPMask value
|
|
||||||
type ipMaskValue net.IPMask
|
|
||||||
|
|
||||||
func newIPMaskValue(val net.IPMask, p *net.IPMask) *ipMaskValue {
|
|
||||||
*p = val
|
|
||||||
return (*ipMaskValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *ipMaskValue) String() string { return net.IPMask(*i).String() }
|
|
||||||
func (i *ipMaskValue) Set(s string) error {
|
|
||||||
ip := ParseIPv4Mask(s)
|
|
||||||
if ip == nil {
|
|
||||||
return fmt.Errorf("failed to parse IP mask: %q", s)
|
|
||||||
}
|
|
||||||
*i = ipMaskValue(ip)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *ipMaskValue) Type() string {
|
|
||||||
return "ipMask"
|
|
||||||
}
|
|
||||||
|
|
||||||
// ParseIPv4Mask written in IP form (e.g. 255.255.255.0).
|
|
||||||
// This function should really belong to the net package.
|
|
||||||
func ParseIPv4Mask(s string) net.IPMask {
|
|
||||||
mask := net.ParseIP(s)
|
|
||||||
if mask == nil {
|
|
||||||
if len(s) != 8 {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
// net.IPMask.String() actually outputs things like ffffff00
|
|
||||||
// so write a horrible parser for that as well :-(
|
|
||||||
m := []int{}
|
|
||||||
for i := 0; i < 4; i++ {
|
|
||||||
b := "0x" + s[2*i:2*i+2]
|
|
||||||
d, err := strconv.ParseInt(b, 0, 0)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
m = append(m, int(d))
|
|
||||||
}
|
|
||||||
s := fmt.Sprintf("%d.%d.%d.%d", m[0], m[1], m[2], m[3])
|
|
||||||
mask = net.ParseIP(s)
|
|
||||||
if mask == nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return net.IPv4Mask(mask[12], mask[13], mask[14], mask[15])
|
|
||||||
}
|
|
||||||
|
|
||||||
func parseIPv4Mask(sval string) (interface{}, error) {
|
|
||||||
mask := ParseIPv4Mask(sval)
|
|
||||||
if mask == nil {
|
|
||||||
return nil, fmt.Errorf("unable to parse %s as net.IPMask", sval)
|
|
||||||
}
|
|
||||||
return mask, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetIPv4Mask return the net.IPv4Mask value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetIPv4Mask(name string) (net.IPMask, error) {
|
|
||||||
val, err := f.getFlagType(name, "ipMask", parseIPv4Mask)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return val.(net.IPMask), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPMaskVar defines an net.IPMask flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an net.IPMask variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) IPMaskVar(p *net.IPMask, name string, value net.IPMask, usage string) {
|
|
||||||
f.VarP(newIPMaskValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPMaskVarP is like IPMaskVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IPMaskVarP(p *net.IPMask, name, shorthand string, value net.IPMask, usage string) {
|
|
||||||
f.VarP(newIPMaskValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPMaskVar defines an net.IPMask flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an net.IPMask variable in which to store the value of the flag.
|
|
||||||
func IPMaskVar(p *net.IPMask, name string, value net.IPMask, usage string) {
|
|
||||||
CommandLine.VarP(newIPMaskValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPMaskVarP is like IPMaskVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IPMaskVarP(p *net.IPMask, name, shorthand string, value net.IPMask, usage string) {
|
|
||||||
CommandLine.VarP(newIPMaskValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPMask defines an net.IPMask flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an net.IPMask variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) IPMask(name string, value net.IPMask, usage string) *net.IPMask {
|
|
||||||
p := new(net.IPMask)
|
|
||||||
f.IPMaskVarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPMaskP is like IPMask, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IPMaskP(name, shorthand string, value net.IPMask, usage string) *net.IPMask {
|
|
||||||
p := new(net.IPMask)
|
|
||||||
f.IPMaskVarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPMask defines an net.IPMask flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an net.IPMask variable that stores the value of the flag.
|
|
||||||
func IPMask(name string, value net.IPMask, usage string) *net.IPMask {
|
|
||||||
return CommandLine.IPMaskP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPMaskP is like IP, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IPMaskP(name, shorthand string, value net.IPMask, usage string) *net.IPMask {
|
|
||||||
return CommandLine.IPMaskP(name, shorthand, value, usage)
|
|
||||||
}
|
|
98
vendor/github.com/spf13/pflag/ipnet.go
generated
vendored
98
vendor/github.com/spf13/pflag/ipnet.go
generated
vendored
@ -1,98 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"net"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// IPNet adapts net.IPNet for use as a flag.
|
|
||||||
type ipNetValue net.IPNet
|
|
||||||
|
|
||||||
func (ipnet ipNetValue) String() string {
|
|
||||||
n := net.IPNet(ipnet)
|
|
||||||
return n.String()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (ipnet *ipNetValue) Set(value string) error {
|
|
||||||
_, n, err := net.ParseCIDR(strings.TrimSpace(value))
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
*ipnet = ipNetValue(*n)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (*ipNetValue) Type() string {
|
|
||||||
return "ipNet"
|
|
||||||
}
|
|
||||||
|
|
||||||
func newIPNetValue(val net.IPNet, p *net.IPNet) *ipNetValue {
|
|
||||||
*p = val
|
|
||||||
return (*ipNetValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func ipNetConv(sval string) (interface{}, error) {
|
|
||||||
_, n, err := net.ParseCIDR(strings.TrimSpace(sval))
|
|
||||||
if err == nil {
|
|
||||||
return *n, nil
|
|
||||||
}
|
|
||||||
return nil, fmt.Errorf("invalid string being converted to IPNet: %s", sval)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetIPNet return the net.IPNet value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetIPNet(name string) (net.IPNet, error) {
|
|
||||||
val, err := f.getFlagType(name, "ipNet", ipNetConv)
|
|
||||||
if err != nil {
|
|
||||||
return net.IPNet{}, err
|
|
||||||
}
|
|
||||||
return val.(net.IPNet), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPNetVar defines an net.IPNet flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an net.IPNet variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) IPNetVar(p *net.IPNet, name string, value net.IPNet, usage string) {
|
|
||||||
f.VarP(newIPNetValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPNetVarP is like IPNetVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IPNetVarP(p *net.IPNet, name, shorthand string, value net.IPNet, usage string) {
|
|
||||||
f.VarP(newIPNetValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPNetVar defines an net.IPNet flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to an net.IPNet variable in which to store the value of the flag.
|
|
||||||
func IPNetVar(p *net.IPNet, name string, value net.IPNet, usage string) {
|
|
||||||
CommandLine.VarP(newIPNetValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPNetVarP is like IPNetVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IPNetVarP(p *net.IPNet, name, shorthand string, value net.IPNet, usage string) {
|
|
||||||
CommandLine.VarP(newIPNetValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPNet defines an net.IPNet flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an net.IPNet variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) IPNet(name string, value net.IPNet, usage string) *net.IPNet {
|
|
||||||
p := new(net.IPNet)
|
|
||||||
f.IPNetVarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPNetP is like IPNet, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) IPNetP(name, shorthand string, value net.IPNet, usage string) *net.IPNet {
|
|
||||||
p := new(net.IPNet)
|
|
||||||
f.IPNetVarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPNet defines an net.IPNet flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of an net.IPNet variable that stores the value of the flag.
|
|
||||||
func IPNet(name string, value net.IPNet, usage string) *net.IPNet {
|
|
||||||
return CommandLine.IPNetP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// IPNetP is like IPNet, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func IPNetP(name, shorthand string, value net.IPNet, usage string) *net.IPNet {
|
|
||||||
return CommandLine.IPNetP(name, shorthand, value, usage)
|
|
||||||
}
|
|
70
vendor/github.com/spf13/pflag/ipnet_test.go
generated
vendored
70
vendor/github.com/spf13/pflag/ipnet_test.go
generated
vendored
@ -1,70 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"net"
|
|
||||||
"os"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpIPNet(ip *net.IPNet) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
_, def, _ := net.ParseCIDR("0.0.0.0/0")
|
|
||||||
f.IPNetVar(ip, "address", *def, "IP Address")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestIPNet(t *testing.T) {
|
|
||||||
testCases := []struct {
|
|
||||||
input string
|
|
||||||
success bool
|
|
||||||
expected string
|
|
||||||
}{
|
|
||||||
{"0.0.0.0/0", true, "0.0.0.0/0"},
|
|
||||||
{" 0.0.0.0/0 ", true, "0.0.0.0/0"},
|
|
||||||
{"1.2.3.4/8", true, "1.0.0.0/8"},
|
|
||||||
{"127.0.0.1/16", true, "127.0.0.0/16"},
|
|
||||||
{"255.255.255.255/19", true, "255.255.224.0/19"},
|
|
||||||
{"255.255.255.255/32", true, "255.255.255.255/32"},
|
|
||||||
{"", false, ""},
|
|
||||||
{"/0", false, ""},
|
|
||||||
{"0", false, ""},
|
|
||||||
{"0/0", false, ""},
|
|
||||||
{"localhost/0", false, ""},
|
|
||||||
{"0.0.0/4", false, ""},
|
|
||||||
{"0.0.0./8", false, ""},
|
|
||||||
{"0.0.0.0./12", false, ""},
|
|
||||||
{"0.0.0.256/16", false, ""},
|
|
||||||
{"0.0.0.0 /20", false, ""},
|
|
||||||
{"0.0.0.0/ 24", false, ""},
|
|
||||||
{"0 . 0 . 0 . 0 / 28", false, ""},
|
|
||||||
{"0.0.0.0/33", false, ""},
|
|
||||||
}
|
|
||||||
|
|
||||||
devnull, _ := os.Open(os.DevNull)
|
|
||||||
os.Stderr = devnull
|
|
||||||
for i := range testCases {
|
|
||||||
var addr net.IPNet
|
|
||||||
f := setUpIPNet(&addr)
|
|
||||||
|
|
||||||
tc := &testCases[i]
|
|
||||||
|
|
||||||
arg := fmt.Sprintf("--address=%s", tc.input)
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil && tc.success == true {
|
|
||||||
t.Errorf("expected success, got %q", err)
|
|
||||||
continue
|
|
||||||
} else if err == nil && tc.success == false {
|
|
||||||
t.Errorf("expected failure")
|
|
||||||
continue
|
|
||||||
} else if tc.success {
|
|
||||||
ip, err := f.GetIPNet("address")
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Got error trying to fetch the IP flag: %v", err)
|
|
||||||
}
|
|
||||||
if ip.String() != tc.expected {
|
|
||||||
t.Errorf("expected %q, got %q", tc.expected, ip.String())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
74
vendor/github.com/spf13/pflag/printusage_test.go
generated
vendored
74
vendor/github.com/spf13/pflag/printusage_test.go
generated
vendored
@ -1,74 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"io"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
const expectedOutput = ` --long-form Some description
|
|
||||||
--long-form2 Some description
|
|
||||||
with multiline
|
|
||||||
-s, --long-name Some description
|
|
||||||
-t, --long-name2 Some description with
|
|
||||||
multiline
|
|
||||||
`
|
|
||||||
|
|
||||||
func setUpPFlagSet(buf io.Writer) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ExitOnError)
|
|
||||||
f.Bool("long-form", false, "Some description")
|
|
||||||
f.Bool("long-form2", false, "Some description\n with multiline")
|
|
||||||
f.BoolP("long-name", "s", false, "Some description")
|
|
||||||
f.BoolP("long-name2", "t", false, "Some description with\n multiline")
|
|
||||||
f.SetOutput(buf)
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestPrintUsage(t *testing.T) {
|
|
||||||
buf := bytes.Buffer{}
|
|
||||||
f := setUpPFlagSet(&buf)
|
|
||||||
f.PrintDefaults()
|
|
||||||
res := buf.String()
|
|
||||||
if res != expectedOutput {
|
|
||||||
t.Errorf("Expected \n%s \nActual \n%s", expectedOutput, res)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func setUpPFlagSet2(buf io.Writer) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ExitOnError)
|
|
||||||
f.Bool("long-form", false, "Some description")
|
|
||||||
f.Bool("long-form2", false, "Some description\n with multiline")
|
|
||||||
f.BoolP("long-name", "s", false, "Some description")
|
|
||||||
f.BoolP("long-name2", "t", false, "Some description with\n multiline")
|
|
||||||
f.StringP("some-very-long-arg", "l", "test", "Some very long description having break the limit")
|
|
||||||
f.StringP("other-very-long-arg", "o", "long-default-value", "Some very long description having break the limit")
|
|
||||||
f.String("some-very-long-arg2", "very long default value", "Some very long description\nwith line break\nmultiple")
|
|
||||||
f.SetOutput(buf)
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
const expectedOutput2 = ` --long-form Some description
|
|
||||||
--long-form2 Some description
|
|
||||||
with multiline
|
|
||||||
-s, --long-name Some description
|
|
||||||
-t, --long-name2 Some description with
|
|
||||||
multiline
|
|
||||||
-o, --other-very-long-arg string Some very long description having
|
|
||||||
break the limit (default
|
|
||||||
"long-default-value")
|
|
||||||
-l, --some-very-long-arg string Some very long description having
|
|
||||||
break the limit (default "test")
|
|
||||||
--some-very-long-arg2 string Some very long description
|
|
||||||
with line break
|
|
||||||
multiple (default "very long default
|
|
||||||
value")
|
|
||||||
`
|
|
||||||
|
|
||||||
func TestPrintUsage_2(t *testing.T) {
|
|
||||||
buf := bytes.Buffer{}
|
|
||||||
f := setUpPFlagSet2(&buf)
|
|
||||||
res := f.FlagUsagesWrapped(80)
|
|
||||||
if res != expectedOutput2 {
|
|
||||||
t.Errorf("Expected \n%q \nActual \n%q", expectedOutput2, res)
|
|
||||||
}
|
|
||||||
}
|
|
80
vendor/github.com/spf13/pflag/string.go
generated
vendored
80
vendor/github.com/spf13/pflag/string.go
generated
vendored
@ -1,80 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
// -- string Value
|
|
||||||
type stringValue string
|
|
||||||
|
|
||||||
func newStringValue(val string, p *string) *stringValue {
|
|
||||||
*p = val
|
|
||||||
return (*stringValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *stringValue) Set(val string) error {
|
|
||||||
*s = stringValue(val)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
func (s *stringValue) Type() string {
|
|
||||||
return "string"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *stringValue) String() string { return string(*s) }
|
|
||||||
|
|
||||||
func stringConv(sval string) (interface{}, error) {
|
|
||||||
return sval, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetString return the string value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetString(name string) (string, error) {
|
|
||||||
val, err := f.getFlagType(name, "string", stringConv)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
return val.(string), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringVar defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a string variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) StringVar(p *string, name string, value string, usage string) {
|
|
||||||
f.VarP(newStringValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringVarP is like StringVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) StringVarP(p *string, name, shorthand string, value string, usage string) {
|
|
||||||
f.VarP(newStringValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringVar defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a string variable in which to store the value of the flag.
|
|
||||||
func StringVar(p *string, name string, value string, usage string) {
|
|
||||||
CommandLine.VarP(newStringValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringVarP is like StringVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func StringVarP(p *string, name, shorthand string, value string, usage string) {
|
|
||||||
CommandLine.VarP(newStringValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// String defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a string variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) String(name string, value string, usage string) *string {
|
|
||||||
p := new(string)
|
|
||||||
f.StringVarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringP is like String, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) StringP(name, shorthand string, value string, usage string) *string {
|
|
||||||
p := new(string)
|
|
||||||
f.StringVarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// String defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a string variable that stores the value of the flag.
|
|
||||||
func String(name string, value string, usage string) *string {
|
|
||||||
return CommandLine.StringP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringP is like String, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func StringP(name, shorthand string, value string, usage string) *string {
|
|
||||||
return CommandLine.StringP(name, shorthand, value, usage)
|
|
||||||
}
|
|
103
vendor/github.com/spf13/pflag/string_array.go
generated
vendored
103
vendor/github.com/spf13/pflag/string_array.go
generated
vendored
@ -1,103 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
// -- stringArray Value
|
|
||||||
type stringArrayValue struct {
|
|
||||||
value *[]string
|
|
||||||
changed bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func newStringArrayValue(val []string, p *[]string) *stringArrayValue {
|
|
||||||
ssv := new(stringArrayValue)
|
|
||||||
ssv.value = p
|
|
||||||
*ssv.value = val
|
|
||||||
return ssv
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *stringArrayValue) Set(val string) error {
|
|
||||||
if !s.changed {
|
|
||||||
*s.value = []string{val}
|
|
||||||
s.changed = true
|
|
||||||
} else {
|
|
||||||
*s.value = append(*s.value, val)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *stringArrayValue) Type() string {
|
|
||||||
return "stringArray"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *stringArrayValue) String() string {
|
|
||||||
str, _ := writeAsCSV(*s.value)
|
|
||||||
return "[" + str + "]"
|
|
||||||
}
|
|
||||||
|
|
||||||
func stringArrayConv(sval string) (interface{}, error) {
|
|
||||||
sval = sval[1 : len(sval)-1]
|
|
||||||
// An empty string would cause a array with one (empty) string
|
|
||||||
if len(sval) == 0 {
|
|
||||||
return []string{}, nil
|
|
||||||
}
|
|
||||||
return readAsCSV(sval)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetStringArray return the []string value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetStringArray(name string) ([]string, error) {
|
|
||||||
val, err := f.getFlagType(name, "stringArray", stringArrayConv)
|
|
||||||
if err != nil {
|
|
||||||
return []string{}, err
|
|
||||||
}
|
|
||||||
return val.([]string), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringArrayVar defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []string variable in which to store the values of the multiple flags.
|
|
||||||
// The value of each argument will not try to be separated by comma. Use a StringSlice for that.
|
|
||||||
func (f *FlagSet) StringArrayVar(p *[]string, name string, value []string, usage string) {
|
|
||||||
f.VarP(newStringArrayValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringArrayVarP is like StringArrayVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) StringArrayVarP(p *[]string, name, shorthand string, value []string, usage string) {
|
|
||||||
f.VarP(newStringArrayValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringArrayVar defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []string variable in which to store the value of the flag.
|
|
||||||
// The value of each argument will not try to be separated by comma. Use a StringSlice for that.
|
|
||||||
func StringArrayVar(p *[]string, name string, value []string, usage string) {
|
|
||||||
CommandLine.VarP(newStringArrayValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringArrayVarP is like StringArrayVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func StringArrayVarP(p *[]string, name, shorthand string, value []string, usage string) {
|
|
||||||
CommandLine.VarP(newStringArrayValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringArray defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []string variable that stores the value of the flag.
|
|
||||||
// The value of each argument will not try to be separated by comma. Use a StringSlice for that.
|
|
||||||
func (f *FlagSet) StringArray(name string, value []string, usage string) *[]string {
|
|
||||||
p := []string{}
|
|
||||||
f.StringArrayVarP(&p, name, "", value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringArrayP is like StringArray, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) StringArrayP(name, shorthand string, value []string, usage string) *[]string {
|
|
||||||
p := []string{}
|
|
||||||
f.StringArrayVarP(&p, name, shorthand, value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringArray defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []string variable that stores the value of the flag.
|
|
||||||
// The value of each argument will not try to be separated by comma. Use a StringSlice for that.
|
|
||||||
func StringArray(name string, value []string, usage string) *[]string {
|
|
||||||
return CommandLine.StringArrayP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringArrayP is like StringArray, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func StringArrayP(name, shorthand string, value []string, usage string) *[]string {
|
|
||||||
return CommandLine.StringArrayP(name, shorthand, value, usage)
|
|
||||||
}
|
|
233
vendor/github.com/spf13/pflag/string_array_test.go
generated
vendored
233
vendor/github.com/spf13/pflag/string_array_test.go
generated
vendored
@ -1,233 +0,0 @@
|
|||||||
// Copyright 2009 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpSAFlagSet(sap *[]string) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.StringArrayVar(sap, "sa", []string{}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func setUpSAFlagSetWithDefault(sap *[]string) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.StringArrayVar(sap, "sa", []string{"default", "values"}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmptySA(t *testing.T) {
|
|
||||||
var sa []string
|
|
||||||
f := setUpSAFlagSet(&sa)
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getSA, err := f.GetStringArray("sa")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetStringArray():", err)
|
|
||||||
}
|
|
||||||
if len(getSA) != 0 {
|
|
||||||
t.Fatalf("got sa %v with len=%d but expected length=0", getSA, len(getSA))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmptySAValue(t *testing.T) {
|
|
||||||
var sa []string
|
|
||||||
f := setUpSAFlagSet(&sa)
|
|
||||||
err := f.Parse([]string{"--sa="})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getSA, err := f.GetStringArray("sa")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetStringArray():", err)
|
|
||||||
}
|
|
||||||
if len(getSA) != 0 {
|
|
||||||
t.Fatalf("got sa %v with len=%d but expected length=0", getSA, len(getSA))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSADefault(t *testing.T) {
|
|
||||||
var sa []string
|
|
||||||
f := setUpSAFlagSetWithDefault(&sa)
|
|
||||||
|
|
||||||
vals := []string{"default", "values"}
|
|
||||||
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range sa {
|
|
||||||
if vals[i] != v {
|
|
||||||
t.Fatalf("expected sa[%d] to be %s but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getSA, err := f.GetStringArray("sa")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetStringArray():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getSA {
|
|
||||||
if vals[i] != v {
|
|
||||||
t.Fatalf("expected sa[%d] to be %s from GetStringArray but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSAWithDefault(t *testing.T) {
|
|
||||||
var sa []string
|
|
||||||
f := setUpSAFlagSetWithDefault(&sa)
|
|
||||||
|
|
||||||
val := "one"
|
|
||||||
arg := fmt.Sprintf("--sa=%s", val)
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(sa) != 1 {
|
|
||||||
t.Fatalf("expected number of values to be %d but %d", 1, len(sa))
|
|
||||||
}
|
|
||||||
|
|
||||||
if sa[0] != val {
|
|
||||||
t.Fatalf("expected value to be %s but got: %s", sa[0], val)
|
|
||||||
}
|
|
||||||
|
|
||||||
getSA, err := f.GetStringArray("sa")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetStringArray():", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(getSA) != 1 {
|
|
||||||
t.Fatalf("expected number of values to be %d but %d", 1, len(getSA))
|
|
||||||
}
|
|
||||||
|
|
||||||
if getSA[0] != val {
|
|
||||||
t.Fatalf("expected value to be %s but got: %s", getSA[0], val)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSACalledTwice(t *testing.T) {
|
|
||||||
var sa []string
|
|
||||||
f := setUpSAFlagSet(&sa)
|
|
||||||
|
|
||||||
in := []string{"one", "two"}
|
|
||||||
expected := []string{"one", "two"}
|
|
||||||
argfmt := "--sa=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
err := f.Parse([]string{arg1, arg2})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(sa) {
|
|
||||||
t.Fatalf("expected number of sa to be %d but got: %d", len(expected), len(sa))
|
|
||||||
}
|
|
||||||
for i, v := range sa {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
values, err := f.GetStringArray("sa")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(values) {
|
|
||||||
t.Fatalf("expected number of values to be %d but got: %d", len(expected), len(sa))
|
|
||||||
}
|
|
||||||
for i, v := range values {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected got sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSAWithSpecialChar(t *testing.T) {
|
|
||||||
var sa []string
|
|
||||||
f := setUpSAFlagSet(&sa)
|
|
||||||
|
|
||||||
in := []string{"one,two", `"three"`, `"four,five",six`, "seven eight"}
|
|
||||||
expected := []string{"one,two", `"three"`, `"four,five",six`, "seven eight"}
|
|
||||||
argfmt := "--sa=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
arg3 := fmt.Sprintf(argfmt, in[2])
|
|
||||||
arg4 := fmt.Sprintf(argfmt, in[3])
|
|
||||||
err := f.Parse([]string{arg1, arg2, arg3, arg4})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(sa) {
|
|
||||||
t.Fatalf("expected number of sa to be %d but got: %d", len(expected), len(sa))
|
|
||||||
}
|
|
||||||
for i, v := range sa {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
values, err := f.GetStringArray("sa")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(values) {
|
|
||||||
t.Fatalf("expected number of values to be %d but got: %d", len(expected), len(values))
|
|
||||||
}
|
|
||||||
for i, v := range values {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected got sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSAWithSquareBrackets(t *testing.T) {
|
|
||||||
var sa []string
|
|
||||||
f := setUpSAFlagSet(&sa)
|
|
||||||
|
|
||||||
in := []string{"][]-[", "[a-z]", "[a-z]+"}
|
|
||||||
expected := []string{"][]-[", "[a-z]", "[a-z]+"}
|
|
||||||
argfmt := "--sa=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
arg3 := fmt.Sprintf(argfmt, in[2])
|
|
||||||
err := f.Parse([]string{arg1, arg2, arg3})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(sa) {
|
|
||||||
t.Fatalf("expected number of sa to be %d but got: %d", len(expected), len(sa))
|
|
||||||
}
|
|
||||||
for i, v := range sa {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
values, err := f.GetStringArray("sa")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(values) {
|
|
||||||
t.Fatalf("expected number of values to be %d but got: %d", len(expected), len(values))
|
|
||||||
}
|
|
||||||
for i, v := range values {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected got sa[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
149
vendor/github.com/spf13/pflag/string_slice.go
generated
vendored
149
vendor/github.com/spf13/pflag/string_slice.go
generated
vendored
@ -1,149 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"encoding/csv"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// -- stringSlice Value
|
|
||||||
type stringSliceValue struct {
|
|
||||||
value *[]string
|
|
||||||
changed bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func newStringSliceValue(val []string, p *[]string) *stringSliceValue {
|
|
||||||
ssv := new(stringSliceValue)
|
|
||||||
ssv.value = p
|
|
||||||
*ssv.value = val
|
|
||||||
return ssv
|
|
||||||
}
|
|
||||||
|
|
||||||
func readAsCSV(val string) ([]string, error) {
|
|
||||||
if val == "" {
|
|
||||||
return []string{}, nil
|
|
||||||
}
|
|
||||||
stringReader := strings.NewReader(val)
|
|
||||||
csvReader := csv.NewReader(stringReader)
|
|
||||||
return csvReader.Read()
|
|
||||||
}
|
|
||||||
|
|
||||||
func writeAsCSV(vals []string) (string, error) {
|
|
||||||
b := &bytes.Buffer{}
|
|
||||||
w := csv.NewWriter(b)
|
|
||||||
err := w.Write(vals)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
w.Flush()
|
|
||||||
return strings.TrimSuffix(b.String(), "\n"), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *stringSliceValue) Set(val string) error {
|
|
||||||
v, err := readAsCSV(val)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if !s.changed {
|
|
||||||
*s.value = v
|
|
||||||
} else {
|
|
||||||
*s.value = append(*s.value, v...)
|
|
||||||
}
|
|
||||||
s.changed = true
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *stringSliceValue) Type() string {
|
|
||||||
return "stringSlice"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *stringSliceValue) String() string {
|
|
||||||
str, _ := writeAsCSV(*s.value)
|
|
||||||
return "[" + str + "]"
|
|
||||||
}
|
|
||||||
|
|
||||||
func stringSliceConv(sval string) (interface{}, error) {
|
|
||||||
sval = sval[1 : len(sval)-1]
|
|
||||||
// An empty string would cause a slice with one (empty) string
|
|
||||||
if len(sval) == 0 {
|
|
||||||
return []string{}, nil
|
|
||||||
}
|
|
||||||
return readAsCSV(sval)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetStringSlice return the []string value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetStringSlice(name string) ([]string, error) {
|
|
||||||
val, err := f.getFlagType(name, "stringSlice", stringSliceConv)
|
|
||||||
if err != nil {
|
|
||||||
return []string{}, err
|
|
||||||
}
|
|
||||||
return val.([]string), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringSliceVar defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []string variable in which to store the value of the flag.
|
|
||||||
// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly.
|
|
||||||
// For example:
|
|
||||||
// --ss="v1,v2" -ss="v3"
|
|
||||||
// will result in
|
|
||||||
// []string{"v1", "v2", "v3"}
|
|
||||||
func (f *FlagSet) StringSliceVar(p *[]string, name string, value []string, usage string) {
|
|
||||||
f.VarP(newStringSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringSliceVarP is like StringSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) StringSliceVarP(p *[]string, name, shorthand string, value []string, usage string) {
|
|
||||||
f.VarP(newStringSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringSliceVar defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []string variable in which to store the value of the flag.
|
|
||||||
// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly.
|
|
||||||
// For example:
|
|
||||||
// --ss="v1,v2" -ss="v3"
|
|
||||||
// will result in
|
|
||||||
// []string{"v1", "v2", "v3"}
|
|
||||||
func StringSliceVar(p *[]string, name string, value []string, usage string) {
|
|
||||||
CommandLine.VarP(newStringSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringSliceVarP is like StringSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func StringSliceVarP(p *[]string, name, shorthand string, value []string, usage string) {
|
|
||||||
CommandLine.VarP(newStringSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringSlice defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []string variable that stores the value of the flag.
|
|
||||||
// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly.
|
|
||||||
// For example:
|
|
||||||
// --ss="v1,v2" -ss="v3"
|
|
||||||
// will result in
|
|
||||||
// []string{"v1", "v2", "v3"}
|
|
||||||
func (f *FlagSet) StringSlice(name string, value []string, usage string) *[]string {
|
|
||||||
p := []string{}
|
|
||||||
f.StringSliceVarP(&p, name, "", value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringSliceP is like StringSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) StringSliceP(name, shorthand string, value []string, usage string) *[]string {
|
|
||||||
p := []string{}
|
|
||||||
f.StringSliceVarP(&p, name, shorthand, value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringSlice defines a string flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []string variable that stores the value of the flag.
|
|
||||||
// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly.
|
|
||||||
// For example:
|
|
||||||
// --ss="v1,v2" -ss="v3"
|
|
||||||
// will result in
|
|
||||||
// []string{"v1", "v2", "v3"}
|
|
||||||
func StringSlice(name string, value []string, usage string) *[]string {
|
|
||||||
return CommandLine.StringSliceP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// StringSliceP is like StringSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func StringSliceP(name, shorthand string, value []string, usage string) *[]string {
|
|
||||||
return CommandLine.StringSliceP(name, shorthand, value, usage)
|
|
||||||
}
|
|
253
vendor/github.com/spf13/pflag/string_slice_test.go
generated
vendored
253
vendor/github.com/spf13/pflag/string_slice_test.go
generated
vendored
@ -1,253 +0,0 @@
|
|||||||
// Copyright 2009 The Go Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpSSFlagSet(ssp *[]string) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.StringSliceVar(ssp, "ss", []string{}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func setUpSSFlagSetWithDefault(ssp *[]string) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.StringSliceVar(ssp, "ss", []string{"default", "values"}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmptySS(t *testing.T) {
|
|
||||||
var ss []string
|
|
||||||
f := setUpSSFlagSet(&ss)
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getSS, err := f.GetStringSlice("ss")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetStringSlice():", err)
|
|
||||||
}
|
|
||||||
if len(getSS) != 0 {
|
|
||||||
t.Fatalf("got ss %v with len=%d but expected length=0", getSS, len(getSS))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmptySSValue(t *testing.T) {
|
|
||||||
var ss []string
|
|
||||||
f := setUpSSFlagSet(&ss)
|
|
||||||
err := f.Parse([]string{"--ss="})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getSS, err := f.GetStringSlice("ss")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetStringSlice():", err)
|
|
||||||
}
|
|
||||||
if len(getSS) != 0 {
|
|
||||||
t.Fatalf("got ss %v with len=%d but expected length=0", getSS, len(getSS))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSS(t *testing.T) {
|
|
||||||
var ss []string
|
|
||||||
f := setUpSSFlagSet(&ss)
|
|
||||||
|
|
||||||
vals := []string{"one", "two", "4", "3"}
|
|
||||||
arg := fmt.Sprintf("--ss=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ss {
|
|
||||||
if vals[i] != v {
|
|
||||||
t.Fatalf("expected ss[%d] to be %s but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getSS, err := f.GetStringSlice("ss")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetStringSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getSS {
|
|
||||||
if vals[i] != v {
|
|
||||||
t.Fatalf("expected ss[%d] to be %s from GetStringSlice but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSSDefault(t *testing.T) {
|
|
||||||
var ss []string
|
|
||||||
f := setUpSSFlagSetWithDefault(&ss)
|
|
||||||
|
|
||||||
vals := []string{"default", "values"}
|
|
||||||
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ss {
|
|
||||||
if vals[i] != v {
|
|
||||||
t.Fatalf("expected ss[%d] to be %s but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getSS, err := f.GetStringSlice("ss")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetStringSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getSS {
|
|
||||||
if vals[i] != v {
|
|
||||||
t.Fatalf("expected ss[%d] to be %s from GetStringSlice but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSSWithDefault(t *testing.T) {
|
|
||||||
var ss []string
|
|
||||||
f := setUpSSFlagSetWithDefault(&ss)
|
|
||||||
|
|
||||||
vals := []string{"one", "two", "4", "3"}
|
|
||||||
arg := fmt.Sprintf("--ss=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range ss {
|
|
||||||
if vals[i] != v {
|
|
||||||
t.Fatalf("expected ss[%d] to be %s but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getSS, err := f.GetStringSlice("ss")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetStringSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getSS {
|
|
||||||
if vals[i] != v {
|
|
||||||
t.Fatalf("expected ss[%d] to be %s from GetStringSlice but got: %s", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSSCalledTwice(t *testing.T) {
|
|
||||||
var ss []string
|
|
||||||
f := setUpSSFlagSet(&ss)
|
|
||||||
|
|
||||||
in := []string{"one,two", "three"}
|
|
||||||
expected := []string{"one", "two", "three"}
|
|
||||||
argfmt := "--ss=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
err := f.Parse([]string{arg1, arg2})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(ss) {
|
|
||||||
t.Fatalf("expected number of ss to be %d but got: %d", len(expected), len(ss))
|
|
||||||
}
|
|
||||||
for i, v := range ss {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected ss[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
values, err := f.GetStringSlice("ss")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(values) {
|
|
||||||
t.Fatalf("expected number of values to be %d but got: %d", len(expected), len(ss))
|
|
||||||
}
|
|
||||||
for i, v := range values {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected got ss[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSSWithComma(t *testing.T) {
|
|
||||||
var ss []string
|
|
||||||
f := setUpSSFlagSet(&ss)
|
|
||||||
|
|
||||||
in := []string{`"one,two"`, `"three"`, `"four,five",six`}
|
|
||||||
expected := []string{"one,two", "three", "four,five", "six"}
|
|
||||||
argfmt := "--ss=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
arg3 := fmt.Sprintf(argfmt, in[2])
|
|
||||||
err := f.Parse([]string{arg1, arg2, arg3})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(ss) {
|
|
||||||
t.Fatalf("expected number of ss to be %d but got: %d", len(expected), len(ss))
|
|
||||||
}
|
|
||||||
for i, v := range ss {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected ss[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
values, err := f.GetStringSlice("ss")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(values) {
|
|
||||||
t.Fatalf("expected number of values to be %d but got: %d", len(expected), len(values))
|
|
||||||
}
|
|
||||||
for i, v := range values {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected got ss[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSSWithSquareBrackets(t *testing.T) {
|
|
||||||
var ss []string
|
|
||||||
f := setUpSSFlagSet(&ss)
|
|
||||||
|
|
||||||
in := []string{`"[a-z]"`, `"[a-z]+"`}
|
|
||||||
expected := []string{"[a-z]", "[a-z]+"}
|
|
||||||
argfmt := "--ss=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
err := f.Parse([]string{arg1, arg2})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(ss) {
|
|
||||||
t.Fatalf("expected number of ss to be %d but got: %d", len(expected), len(ss))
|
|
||||||
}
|
|
||||||
for i, v := range ss {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected ss[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
values, err := f.GetStringSlice("ss")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(expected) != len(values) {
|
|
||||||
t.Fatalf("expected number of values to be %d but got: %d", len(expected), len(values))
|
|
||||||
}
|
|
||||||
for i, v := range values {
|
|
||||||
if expected[i] != v {
|
|
||||||
t.Fatalf("expected got ss[%d] to be %s but got: %s", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
88
vendor/github.com/spf13/pflag/uint.go
generated
vendored
88
vendor/github.com/spf13/pflag/uint.go
generated
vendored
@ -1,88 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- uint Value
|
|
||||||
type uintValue uint
|
|
||||||
|
|
||||||
func newUintValue(val uint, p *uint) *uintValue {
|
|
||||||
*p = val
|
|
||||||
return (*uintValue)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uintValue) Set(s string) error {
|
|
||||||
v, err := strconv.ParseUint(s, 0, 64)
|
|
||||||
*i = uintValue(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uintValue) Type() string {
|
|
||||||
return "uint"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uintValue) String() string { return strconv.FormatUint(uint64(*i), 10) }
|
|
||||||
|
|
||||||
func uintConv(sval string) (interface{}, error) {
|
|
||||||
v, err := strconv.ParseUint(sval, 0, 0)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return uint(v), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetUint return the uint value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetUint(name string) (uint, error) {
|
|
||||||
val, err := f.getFlagType(name, "uint", uintConv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(uint), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintVar defines a uint flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) UintVar(p *uint, name string, value uint, usage string) {
|
|
||||||
f.VarP(newUintValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintVarP is like UintVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) UintVarP(p *uint, name, shorthand string, value uint, usage string) {
|
|
||||||
f.VarP(newUintValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintVar defines a uint flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint variable in which to store the value of the flag.
|
|
||||||
func UintVar(p *uint, name string, value uint, usage string) {
|
|
||||||
CommandLine.VarP(newUintValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintVarP is like UintVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func UintVarP(p *uint, name, shorthand string, value uint, usage string) {
|
|
||||||
CommandLine.VarP(newUintValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint defines a uint flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Uint(name string, value uint, usage string) *uint {
|
|
||||||
p := new(uint)
|
|
||||||
f.UintVarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintP is like Uint, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) UintP(name, shorthand string, value uint, usage string) *uint {
|
|
||||||
p := new(uint)
|
|
||||||
f.UintVarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint defines a uint flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint variable that stores the value of the flag.
|
|
||||||
func Uint(name string, value uint, usage string) *uint {
|
|
||||||
return CommandLine.UintP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintP is like Uint, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func UintP(name, shorthand string, value uint, usage string) *uint {
|
|
||||||
return CommandLine.UintP(name, shorthand, value, usage)
|
|
||||||
}
|
|
88
vendor/github.com/spf13/pflag/uint16.go
generated
vendored
88
vendor/github.com/spf13/pflag/uint16.go
generated
vendored
@ -1,88 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- uint16 value
|
|
||||||
type uint16Value uint16
|
|
||||||
|
|
||||||
func newUint16Value(val uint16, p *uint16) *uint16Value {
|
|
||||||
*p = val
|
|
||||||
return (*uint16Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint16Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseUint(s, 0, 16)
|
|
||||||
*i = uint16Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint16Value) Type() string {
|
|
||||||
return "uint16"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint16Value) String() string { return strconv.FormatUint(uint64(*i), 10) }
|
|
||||||
|
|
||||||
func uint16Conv(sval string) (interface{}, error) {
|
|
||||||
v, err := strconv.ParseUint(sval, 0, 16)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return uint16(v), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetUint16 return the uint16 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetUint16(name string) (uint16, error) {
|
|
||||||
val, err := f.getFlagType(name, "uint16", uint16Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(uint16), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint16Var defines a uint flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Uint16Var(p *uint16, name string, value uint16, usage string) {
|
|
||||||
f.VarP(newUint16Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint16VarP is like Uint16Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Uint16VarP(p *uint16, name, shorthand string, value uint16, usage string) {
|
|
||||||
f.VarP(newUint16Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint16Var defines a uint flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint variable in which to store the value of the flag.
|
|
||||||
func Uint16Var(p *uint16, name string, value uint16, usage string) {
|
|
||||||
CommandLine.VarP(newUint16Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint16VarP is like Uint16Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Uint16VarP(p *uint16, name, shorthand string, value uint16, usage string) {
|
|
||||||
CommandLine.VarP(newUint16Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint16 defines a uint flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Uint16(name string, value uint16, usage string) *uint16 {
|
|
||||||
p := new(uint16)
|
|
||||||
f.Uint16VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint16P is like Uint16, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Uint16P(name, shorthand string, value uint16, usage string) *uint16 {
|
|
||||||
p := new(uint16)
|
|
||||||
f.Uint16VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint16 defines a uint flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint variable that stores the value of the flag.
|
|
||||||
func Uint16(name string, value uint16, usage string) *uint16 {
|
|
||||||
return CommandLine.Uint16P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint16P is like Uint16, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Uint16P(name, shorthand string, value uint16, usage string) *uint16 {
|
|
||||||
return CommandLine.Uint16P(name, shorthand, value, usage)
|
|
||||||
}
|
|
88
vendor/github.com/spf13/pflag/uint32.go
generated
vendored
88
vendor/github.com/spf13/pflag/uint32.go
generated
vendored
@ -1,88 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- uint32 value
|
|
||||||
type uint32Value uint32
|
|
||||||
|
|
||||||
func newUint32Value(val uint32, p *uint32) *uint32Value {
|
|
||||||
*p = val
|
|
||||||
return (*uint32Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint32Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseUint(s, 0, 32)
|
|
||||||
*i = uint32Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint32Value) Type() string {
|
|
||||||
return "uint32"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint32Value) String() string { return strconv.FormatUint(uint64(*i), 10) }
|
|
||||||
|
|
||||||
func uint32Conv(sval string) (interface{}, error) {
|
|
||||||
v, err := strconv.ParseUint(sval, 0, 32)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return uint32(v), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetUint32 return the uint32 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetUint32(name string) (uint32, error) {
|
|
||||||
val, err := f.getFlagType(name, "uint32", uint32Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(uint32), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint32Var defines a uint32 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint32 variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Uint32Var(p *uint32, name string, value uint32, usage string) {
|
|
||||||
f.VarP(newUint32Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint32VarP is like Uint32Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Uint32VarP(p *uint32, name, shorthand string, value uint32, usage string) {
|
|
||||||
f.VarP(newUint32Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint32Var defines a uint32 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint32 variable in which to store the value of the flag.
|
|
||||||
func Uint32Var(p *uint32, name string, value uint32, usage string) {
|
|
||||||
CommandLine.VarP(newUint32Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint32VarP is like Uint32Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Uint32VarP(p *uint32, name, shorthand string, value uint32, usage string) {
|
|
||||||
CommandLine.VarP(newUint32Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint32 defines a uint32 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint32 variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Uint32(name string, value uint32, usage string) *uint32 {
|
|
||||||
p := new(uint32)
|
|
||||||
f.Uint32VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint32P is like Uint32, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Uint32P(name, shorthand string, value uint32, usage string) *uint32 {
|
|
||||||
p := new(uint32)
|
|
||||||
f.Uint32VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint32 defines a uint32 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint32 variable that stores the value of the flag.
|
|
||||||
func Uint32(name string, value uint32, usage string) *uint32 {
|
|
||||||
return CommandLine.Uint32P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint32P is like Uint32, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Uint32P(name, shorthand string, value uint32, usage string) *uint32 {
|
|
||||||
return CommandLine.Uint32P(name, shorthand, value, usage)
|
|
||||||
}
|
|
88
vendor/github.com/spf13/pflag/uint64.go
generated
vendored
88
vendor/github.com/spf13/pflag/uint64.go
generated
vendored
@ -1,88 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- uint64 Value
|
|
||||||
type uint64Value uint64
|
|
||||||
|
|
||||||
func newUint64Value(val uint64, p *uint64) *uint64Value {
|
|
||||||
*p = val
|
|
||||||
return (*uint64Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint64Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseUint(s, 0, 64)
|
|
||||||
*i = uint64Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint64Value) Type() string {
|
|
||||||
return "uint64"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint64Value) String() string { return strconv.FormatUint(uint64(*i), 10) }
|
|
||||||
|
|
||||||
func uint64Conv(sval string) (interface{}, error) {
|
|
||||||
v, err := strconv.ParseUint(sval, 0, 64)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return uint64(v), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetUint64 return the uint64 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetUint64(name string) (uint64, error) {
|
|
||||||
val, err := f.getFlagType(name, "uint64", uint64Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(uint64), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint64Var defines a uint64 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint64 variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Uint64Var(p *uint64, name string, value uint64, usage string) {
|
|
||||||
f.VarP(newUint64Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint64VarP is like Uint64Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Uint64VarP(p *uint64, name, shorthand string, value uint64, usage string) {
|
|
||||||
f.VarP(newUint64Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint64Var defines a uint64 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint64 variable in which to store the value of the flag.
|
|
||||||
func Uint64Var(p *uint64, name string, value uint64, usage string) {
|
|
||||||
CommandLine.VarP(newUint64Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint64VarP is like Uint64Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Uint64VarP(p *uint64, name, shorthand string, value uint64, usage string) {
|
|
||||||
CommandLine.VarP(newUint64Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint64 defines a uint64 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint64 variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Uint64(name string, value uint64, usage string) *uint64 {
|
|
||||||
p := new(uint64)
|
|
||||||
f.Uint64VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint64P is like Uint64, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Uint64P(name, shorthand string, value uint64, usage string) *uint64 {
|
|
||||||
p := new(uint64)
|
|
||||||
f.Uint64VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint64 defines a uint64 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint64 variable that stores the value of the flag.
|
|
||||||
func Uint64(name string, value uint64, usage string) *uint64 {
|
|
||||||
return CommandLine.Uint64P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint64P is like Uint64, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Uint64P(name, shorthand string, value uint64, usage string) *uint64 {
|
|
||||||
return CommandLine.Uint64P(name, shorthand, value, usage)
|
|
||||||
}
|
|
88
vendor/github.com/spf13/pflag/uint8.go
generated
vendored
88
vendor/github.com/spf13/pflag/uint8.go
generated
vendored
@ -1,88 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import "strconv"
|
|
||||||
|
|
||||||
// -- uint8 Value
|
|
||||||
type uint8Value uint8
|
|
||||||
|
|
||||||
func newUint8Value(val uint8, p *uint8) *uint8Value {
|
|
||||||
*p = val
|
|
||||||
return (*uint8Value)(p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint8Value) Set(s string) error {
|
|
||||||
v, err := strconv.ParseUint(s, 0, 8)
|
|
||||||
*i = uint8Value(v)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint8Value) Type() string {
|
|
||||||
return "uint8"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *uint8Value) String() string { return strconv.FormatUint(uint64(*i), 10) }
|
|
||||||
|
|
||||||
func uint8Conv(sval string) (interface{}, error) {
|
|
||||||
v, err := strconv.ParseUint(sval, 0, 8)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return uint8(v), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetUint8 return the uint8 value of a flag with the given name
|
|
||||||
func (f *FlagSet) GetUint8(name string) (uint8, error) {
|
|
||||||
val, err := f.getFlagType(name, "uint8", uint8Conv)
|
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return val.(uint8), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint8Var defines a uint8 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint8 variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) Uint8Var(p *uint8, name string, value uint8, usage string) {
|
|
||||||
f.VarP(newUint8Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint8VarP is like Uint8Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Uint8VarP(p *uint8, name, shorthand string, value uint8, usage string) {
|
|
||||||
f.VarP(newUint8Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint8Var defines a uint8 flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint8 variable in which to store the value of the flag.
|
|
||||||
func Uint8Var(p *uint8, name string, value uint8, usage string) {
|
|
||||||
CommandLine.VarP(newUint8Value(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint8VarP is like Uint8Var, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Uint8VarP(p *uint8, name, shorthand string, value uint8, usage string) {
|
|
||||||
CommandLine.VarP(newUint8Value(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint8 defines a uint8 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint8 variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) Uint8(name string, value uint8, usage string) *uint8 {
|
|
||||||
p := new(uint8)
|
|
||||||
f.Uint8VarP(p, name, "", value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint8P is like Uint8, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) Uint8P(name, shorthand string, value uint8, usage string) *uint8 {
|
|
||||||
p := new(uint8)
|
|
||||||
f.Uint8VarP(p, name, shorthand, value, usage)
|
|
||||||
return p
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint8 defines a uint8 flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a uint8 variable that stores the value of the flag.
|
|
||||||
func Uint8(name string, value uint8, usage string) *uint8 {
|
|
||||||
return CommandLine.Uint8P(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint8P is like Uint8, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func Uint8P(name, shorthand string, value uint8, usage string) *uint8 {
|
|
||||||
return CommandLine.Uint8P(name, shorthand, value, usage)
|
|
||||||
}
|
|
126
vendor/github.com/spf13/pflag/uint_slice.go
generated
vendored
126
vendor/github.com/spf13/pflag/uint_slice.go
generated
vendored
@ -1,126 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
// -- uintSlice Value
|
|
||||||
type uintSliceValue struct {
|
|
||||||
value *[]uint
|
|
||||||
changed bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func newUintSliceValue(val []uint, p *[]uint) *uintSliceValue {
|
|
||||||
uisv := new(uintSliceValue)
|
|
||||||
uisv.value = p
|
|
||||||
*uisv.value = val
|
|
||||||
return uisv
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *uintSliceValue) Set(val string) error {
|
|
||||||
ss := strings.Split(val, ",")
|
|
||||||
out := make([]uint, len(ss))
|
|
||||||
for i, d := range ss {
|
|
||||||
u, err := strconv.ParseUint(d, 10, 0)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
out[i] = uint(u)
|
|
||||||
}
|
|
||||||
if !s.changed {
|
|
||||||
*s.value = out
|
|
||||||
} else {
|
|
||||||
*s.value = append(*s.value, out...)
|
|
||||||
}
|
|
||||||
s.changed = true
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *uintSliceValue) Type() string {
|
|
||||||
return "uintSlice"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *uintSliceValue) String() string {
|
|
||||||
out := make([]string, len(*s.value))
|
|
||||||
for i, d := range *s.value {
|
|
||||||
out[i] = fmt.Sprintf("%d", d)
|
|
||||||
}
|
|
||||||
return "[" + strings.Join(out, ",") + "]"
|
|
||||||
}
|
|
||||||
|
|
||||||
func uintSliceConv(val string) (interface{}, error) {
|
|
||||||
val = strings.Trim(val, "[]")
|
|
||||||
// Empty string would cause a slice with one (empty) entry
|
|
||||||
if len(val) == 0 {
|
|
||||||
return []uint{}, nil
|
|
||||||
}
|
|
||||||
ss := strings.Split(val, ",")
|
|
||||||
out := make([]uint, len(ss))
|
|
||||||
for i, d := range ss {
|
|
||||||
u, err := strconv.ParseUint(d, 10, 0)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
out[i] = uint(u)
|
|
||||||
}
|
|
||||||
return out, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetUintSlice returns the []uint value of a flag with the given name.
|
|
||||||
func (f *FlagSet) GetUintSlice(name string) ([]uint, error) {
|
|
||||||
val, err := f.getFlagType(name, "uintSlice", uintSliceConv)
|
|
||||||
if err != nil {
|
|
||||||
return []uint{}, err
|
|
||||||
}
|
|
||||||
return val.([]uint), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintSliceVar defines a uintSlice flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a []uint variable in which to store the value of the flag.
|
|
||||||
func (f *FlagSet) UintSliceVar(p *[]uint, name string, value []uint, usage string) {
|
|
||||||
f.VarP(newUintSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintSliceVarP is like UintSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) UintSliceVarP(p *[]uint, name, shorthand string, value []uint, usage string) {
|
|
||||||
f.VarP(newUintSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintSliceVar defines a uint[] flag with specified name, default value, and usage string.
|
|
||||||
// The argument p points to a uint[] variable in which to store the value of the flag.
|
|
||||||
func UintSliceVar(p *[]uint, name string, value []uint, usage string) {
|
|
||||||
CommandLine.VarP(newUintSliceValue(value, p), name, "", usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintSliceVarP is like the UintSliceVar, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func UintSliceVarP(p *[]uint, name, shorthand string, value []uint, usage string) {
|
|
||||||
CommandLine.VarP(newUintSliceValue(value, p), name, shorthand, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintSlice defines a []uint flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []uint variable that stores the value of the flag.
|
|
||||||
func (f *FlagSet) UintSlice(name string, value []uint, usage string) *[]uint {
|
|
||||||
p := []uint{}
|
|
||||||
f.UintSliceVarP(&p, name, "", value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintSliceP is like UintSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func (f *FlagSet) UintSliceP(name, shorthand string, value []uint, usage string) *[]uint {
|
|
||||||
p := []uint{}
|
|
||||||
f.UintSliceVarP(&p, name, shorthand, value, usage)
|
|
||||||
return &p
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintSlice defines a []uint flag with specified name, default value, and usage string.
|
|
||||||
// The return value is the address of a []uint variable that stores the value of the flag.
|
|
||||||
func UintSlice(name string, value []uint, usage string) *[]uint {
|
|
||||||
return CommandLine.UintSliceP(name, "", value, usage)
|
|
||||||
}
|
|
||||||
|
|
||||||
// UintSliceP is like UintSlice, but accepts a shorthand letter that can be used after a single dash.
|
|
||||||
func UintSliceP(name, shorthand string, value []uint, usage string) *[]uint {
|
|
||||||
return CommandLine.UintSliceP(name, shorthand, value, usage)
|
|
||||||
}
|
|
161
vendor/github.com/spf13/pflag/uint_slice_test.go
generated
vendored
161
vendor/github.com/spf13/pflag/uint_slice_test.go
generated
vendored
@ -1,161 +0,0 @@
|
|||||||
package pflag
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func setUpUISFlagSet(uisp *[]uint) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.UintSliceVar(uisp, "uis", []uint{}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func setUpUISFlagSetWithDefault(uisp *[]uint) *FlagSet {
|
|
||||||
f := NewFlagSet("test", ContinueOnError)
|
|
||||||
f.UintSliceVar(uisp, "uis", []uint{0, 1}, "Command separated list!")
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEmptyUIS(t *testing.T) {
|
|
||||||
var uis []uint
|
|
||||||
f := setUpUISFlagSet(&uis)
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getUIS, err := f.GetUintSlice("uis")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetUintSlice():", err)
|
|
||||||
}
|
|
||||||
if len(getUIS) != 0 {
|
|
||||||
t.Fatalf("got is %v with len=%d but expected length=0", getUIS, len(getUIS))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestUIS(t *testing.T) {
|
|
||||||
var uis []uint
|
|
||||||
f := setUpUISFlagSet(&uis)
|
|
||||||
|
|
||||||
vals := []string{"1", "2", "4", "3"}
|
|
||||||
arg := fmt.Sprintf("--uis=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range uis {
|
|
||||||
u, err := strconv.ParseUint(vals[i], 10, 0)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if uint(u) != v {
|
|
||||||
t.Fatalf("expected uis[%d] to be %s but got %d", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
getUIS, err := f.GetUintSlice("uis")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
for i, v := range getUIS {
|
|
||||||
u, err := strconv.ParseUint(vals[i], 10, 0)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if uint(u) != v {
|
|
||||||
t.Fatalf("expected uis[%d] to be %s but got: %d from GetUintSlice", i, vals[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestUISDefault(t *testing.T) {
|
|
||||||
var uis []uint
|
|
||||||
f := setUpUISFlagSetWithDefault(&uis)
|
|
||||||
|
|
||||||
vals := []string{"0", "1"}
|
|
||||||
|
|
||||||
err := f.Parse([]string{})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range uis {
|
|
||||||
u, err := strconv.ParseUint(vals[i], 10, 0)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if uint(u) != v {
|
|
||||||
t.Fatalf("expect uis[%d] to be %d but got: %d", i, u, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getUIS, err := f.GetUintSlice("uis")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetUintSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getUIS {
|
|
||||||
u, err := strconv.ParseUint(vals[i], 10, 0)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetIntSlice():", err)
|
|
||||||
}
|
|
||||||
if uint(u) != v {
|
|
||||||
t.Fatalf("expected uis[%d] to be %d from GetUintSlice but got: %d", i, u, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestUISWithDefault(t *testing.T) {
|
|
||||||
var uis []uint
|
|
||||||
f := setUpUISFlagSetWithDefault(&uis)
|
|
||||||
|
|
||||||
vals := []string{"1", "2"}
|
|
||||||
arg := fmt.Sprintf("--uis=%s", strings.Join(vals, ","))
|
|
||||||
err := f.Parse([]string{arg})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range uis {
|
|
||||||
u, err := strconv.ParseUint(vals[i], 10, 0)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if uint(u) != v {
|
|
||||||
t.Fatalf("expected uis[%d] to be %d from GetUintSlice but got: %d", i, u, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getUIS, err := f.GetUintSlice("uis")
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("got an error from GetUintSlice():", err)
|
|
||||||
}
|
|
||||||
for i, v := range getUIS {
|
|
||||||
u, err := strconv.ParseUint(vals[i], 10, 0)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("got error: %v", err)
|
|
||||||
}
|
|
||||||
if uint(u) != v {
|
|
||||||
t.Fatalf("expected uis[%d] to be %d from GetUintSlice but got: %d", i, u, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestUISCalledTwice(t *testing.T) {
|
|
||||||
var uis []uint
|
|
||||||
f := setUpUISFlagSet(&uis)
|
|
||||||
|
|
||||||
in := []string{"1,2", "3"}
|
|
||||||
expected := []int{1, 2, 3}
|
|
||||||
argfmt := "--uis=%s"
|
|
||||||
arg1 := fmt.Sprintf(argfmt, in[0])
|
|
||||||
arg2 := fmt.Sprintf(argfmt, in[1])
|
|
||||||
err := f.Parse([]string{arg1, arg2})
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal("expected no error; got", err)
|
|
||||||
}
|
|
||||||
for i, v := range uis {
|
|
||||||
if uint(expected[i]) != v {
|
|
||||||
t.Fatalf("expected uis[%d] to be %d but got: %d", i, expected[i], v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
69
vendor/github.com/spf13/pflag/verify/all.sh
generated
vendored
69
vendor/github.com/spf13/pflag/verify/all.sh
generated
vendored
@ -1,69 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -o errexit
|
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
ROOT=$(dirname "${BASH_SOURCE}")/..
|
|
||||||
|
|
||||||
# Some useful colors.
|
|
||||||
if [[ -z "${color_start-}" ]]; then
|
|
||||||
declare -r color_start="\033["
|
|
||||||
declare -r color_red="${color_start}0;31m"
|
|
||||||
declare -r color_yellow="${color_start}0;33m"
|
|
||||||
declare -r color_green="${color_start}0;32m"
|
|
||||||
declare -r color_norm="${color_start}0m"
|
|
||||||
fi
|
|
||||||
|
|
||||||
SILENT=true
|
|
||||||
|
|
||||||
function is-excluded {
|
|
||||||
for e in $EXCLUDE; do
|
|
||||||
if [[ $1 -ef ${BASH_SOURCE} ]]; then
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
if [[ $1 -ef "$ROOT/hack/$e" ]]; then
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
|
|
||||||
while getopts ":v" opt; do
|
|
||||||
case $opt in
|
|
||||||
v)
|
|
||||||
SILENT=false
|
|
||||||
;;
|
|
||||||
\?)
|
|
||||||
echo "Invalid flag: -$OPTARG" >&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
if $SILENT ; then
|
|
||||||
echo "Running in the silent mode, run with -v if you want to see script logs."
|
|
||||||
fi
|
|
||||||
|
|
||||||
EXCLUDE="all.sh"
|
|
||||||
|
|
||||||
ret=0
|
|
||||||
for t in `ls $ROOT/verify/*.sh`
|
|
||||||
do
|
|
||||||
if is-excluded $t ; then
|
|
||||||
echo "Skipping $t"
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
if $SILENT ; then
|
|
||||||
echo -e "Verifying $t"
|
|
||||||
if bash "$t" &> /dev/null; then
|
|
||||||
echo -e "${color_green}SUCCESS${color_norm}"
|
|
||||||
else
|
|
||||||
echo -e "${color_red}FAILED${color_norm}"
|
|
||||||
ret=1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
bash "$t" || ret=1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
exit $ret
|
|
19
vendor/github.com/spf13/pflag/verify/gofmt.sh
generated
vendored
19
vendor/github.com/spf13/pflag/verify/gofmt.sh
generated
vendored
@ -1,19 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -o errexit
|
|
||||||
set -o nounset
|
|
||||||
set -o pipefail
|
|
||||||
|
|
||||||
ROOT=$(dirname "${BASH_SOURCE}")/..
|
|
||||||
|
|
||||||
pushd "${ROOT}" > /dev/null
|
|
||||||
|
|
||||||
GOFMT=${GOFMT:-"gofmt"}
|
|
||||||
bad_files=$(find . -name '*.go' | xargs $GOFMT -s -l)
|
|
||||||
if [[ -n "${bad_files}" ]]; then
|
|
||||||
echo "!!! '$GOFMT' needs to be run on the following files: "
|
|
||||||
echo "${bad_files}"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ex: ts=2 sw=2 et filetype=sh
|
|
15
vendor/github.com/spf13/pflag/verify/golint.sh
generated
vendored
15
vendor/github.com/spf13/pflag/verify/golint.sh
generated
vendored
@ -1,15 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
ROOT=$(dirname "${BASH_SOURCE}")/..
|
|
||||||
GOLINT=${GOLINT:-"golint"}
|
|
||||||
|
|
||||||
pushd "${ROOT}" > /dev/null
|
|
||||||
bad_files=$($GOLINT -min_confidence=0.9 ./...)
|
|
||||||
if [[ -n "${bad_files}" ]]; then
|
|
||||||
echo "!!! '$GOLINT' problems: "
|
|
||||||
echo "${bad_files}"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
popd > /dev/null
|
|
||||||
|
|
||||||
# ex: ts=2 sw=2 et filetype=sh
|
|
Loading…
Reference in New Issue
Block a user