barometer: update DMA's vendoring packages
[barometer.git] / src / dma / vendor / github.com / go-redis / redis / internal / proto / reader.go
index 8c28c7b..896b6f6 100644 (file)
@@ -9,8 +9,6 @@ import (
        "github.com/go-redis/redis/internal/util"
 )
 
-const bytesAllocLimit = 1024 * 1024 // 1mb
-
 const (
        ErrorReply  = '-'
        StatusReply = '+'
@@ -32,40 +30,23 @@ func (e RedisError) Error() string { return string(e) }
 type MultiBulkParse func(*Reader, int64) (interface{}, error)
 
 type Reader struct {
-       src *bufio.Reader
-       buf []byte
+       rd   *bufio.Reader
+       _buf []byte
 }
 
 func NewReader(rd io.Reader) *Reader {
        return &Reader{
-               src: bufio.NewReader(rd),
-               buf: make([]byte, 4096),
+               rd:   bufio.NewReader(rd),
+               _buf: make([]byte, 64),
        }
 }
 
 func (r *Reader) Reset(rd io.Reader) {
-       r.src.Reset(rd)
-}
-
-func (r *Reader) PeekBuffered() []byte {
-       if n := r.src.Buffered(); n != 0 {
-               b, _ := r.src.Peek(n)
-               return b
-       }
-       return nil
-}
-
-func (r *Reader) ReadN(n int) ([]byte, error) {
-       b, err := readN(r.src, r.buf, n)
-       if err != nil {
-               return nil, err
-       }
-       r.buf = b
-       return b, nil
+       r.rd.Reset(rd)
 }
 
 func (r *Reader) ReadLine() ([]byte, error) {
-       line, isPrefix, err := r.src.ReadLine()
+       line, isPrefix, err := r.rd.ReadLine()
        if err != nil {
                return nil, err
        }
@@ -91,11 +72,11 @@ func (r *Reader) ReadReply(m MultiBulkParse) (interface{}, error) {
        case ErrorReply:
                return nil, ParseErrorReply(line)
        case StatusReply:
-               return parseTmpStatusReply(line), nil
+               return string(line[1:]), nil
        case IntReply:
                return util.ParseInt(line[1:], 10, 64)
        case StringReply:
-               return r.readTmpBytesReply(line)
+               return r.readStringReply(line)
        case ArrayReply:
                n, err := parseArrayLen(line)
                if err != nil {
@@ -121,47 +102,42 @@ func (r *Reader) ReadIntReply() (int64, error) {
        }
 }
 
-func (r *Reader) ReadTmpBytesReply() ([]byte, error) {
+func (r *Reader) ReadString() (string, error) {
        line, err := r.ReadLine()
        if err != nil {
-               return nil, err
+               return "", err
        }
        switch line[0] {
        case ErrorReply:
-               return nil, ParseErrorReply(line)
+               return "", ParseErrorReply(line)
        case StringReply:
-               return r.readTmpBytesReply(line)
+               return r.readStringReply(line)
        case StatusReply:
-               return parseTmpStatusReply(line), nil
+               return string(line[1:]), nil
+       case IntReply:
+               return string(line[1:]), nil
        default:
-               return nil, fmt.Errorf("redis: can't parse string reply: %.100q", line)
+               return "", fmt.Errorf("redis: can't parse reply=%.100q reading string", line)
        }
 }
 
-func (r *Reader) ReadBytesReply() ([]byte, error) {
-       b, err := r.ReadTmpBytesReply()
-       if err != nil {
-               return nil, err
+func (r *Reader) readStringReply(line []byte) (string, error) {
+       if isNilReply(line) {
+               return "", Nil
        }
-       cp := make([]byte, len(b))
-       copy(cp, b)
-       return cp, nil
-}
 
-func (r *Reader) ReadStringReply() (string, error) {
-       b, err := r.ReadTmpBytesReply()
+       replyLen, err := strconv.Atoi(string(line[1:]))
        if err != nil {
                return "", err
        }
-       return string(b), nil
-}
 
-func (r *Reader) ReadFloatReply() (float64, error) {
-       b, err := r.ReadTmpBytesReply()
+       b := make([]byte, replyLen+2)
+       _, err = io.ReadFull(r.rd, b)
        if err != nil {
-               return 0, err
+               return "", err
        }
-       return util.ParseFloat(b, 64)
+
+       return util.BytesToString(b[:replyLen]), nil
 }
 
 func (r *Reader) ReadArrayReply(m MultiBulkParse) (interface{}, error) {
@@ -219,7 +195,7 @@ func (r *Reader) ReadScanReply() ([]string, uint64, error) {
 
        keys := make([]string, n)
        for i := int64(0); i < n; i++ {
-               key, err := r.ReadStringReply()
+               key, err := r.ReadString()
                if err != nil {
                        return nil, 0, err
                }
@@ -229,69 +205,71 @@ func (r *Reader) ReadScanReply() ([]string, uint64, error) {
        return keys, cursor, err
 }
 
-func (r *Reader) readTmpBytesReply(line []byte) ([]byte, error) {
-       if isNilReply(line) {
-               return nil, Nil
-       }
-
-       replyLen, err := strconv.Atoi(string(line[1:]))
+func (r *Reader) ReadInt() (int64, error) {
+       b, err := r.readTmpBytesReply()
        if err != nil {
-               return nil, err
+               return 0, err
        }
+       return util.ParseInt(b, 10, 64)
+}
 
-       b, err := r.ReadN(replyLen + 2)
+func (r *Reader) ReadUint() (uint64, error) {
+       b, err := r.readTmpBytesReply()
        if err != nil {
-               return nil, err
+               return 0, err
        }
-       return b[:replyLen], nil
+       return util.ParseUint(b, 10, 64)
 }
 
-func (r *Reader) ReadInt() (int64, error) {
-       b, err := r.ReadTmpBytesReply()
+func (r *Reader) ReadFloatReply() (float64, error) {
+       b, err := r.readTmpBytesReply()
        if err != nil {
                return 0, err
        }
-       return util.ParseInt(b, 10, 64)
+       return util.ParseFloat(b, 64)
 }
 
-func (r *Reader) ReadUint() (uint64, error) {
-       b, err := r.ReadTmpBytesReply()
+func (r *Reader) readTmpBytesReply() ([]byte, error) {
+       line, err := r.ReadLine()
        if err != nil {
-               return 0, err
+               return nil, err
+       }
+       switch line[0] {
+       case ErrorReply:
+               return nil, ParseErrorReply(line)
+       case StringReply:
+               return r._readTmpBytesReply(line)
+       case StatusReply:
+               return line[1:], nil
+       default:
+               return nil, fmt.Errorf("redis: can't parse string reply: %.100q", line)
        }
-       return util.ParseUint(b, 10, 64)
 }
 
-// --------------------------------------------------------------------
+func (r *Reader) _readTmpBytesReply(line []byte) ([]byte, error) {
+       if isNilReply(line) {
+               return nil, Nil
+       }
 
-func readN(r io.Reader, b []byte, n int) ([]byte, error) {
-       if n == 0 && b == nil {
-               return make([]byte, 0), nil
+       replyLen, err := strconv.Atoi(string(line[1:]))
+       if err != nil {
+               return nil, err
        }
 
-       if cap(b) >= n {
-               b = b[:n]
-               _, err := io.ReadFull(r, b)
-               return b, err
+       buf := r.buf(replyLen + 2)
+       _, err = io.ReadFull(r.rd, buf)
+       if err != nil {
+               return nil, err
        }
-       b = b[:cap(b)]
 
-       pos := 0
-       for pos < n {
-               diff := n - len(b)
-               if diff > bytesAllocLimit {
-                       diff = bytesAllocLimit
-               }
-               b = append(b, make([]byte, diff)...)
+       return buf[:replyLen], nil
+}
 
-               nn, err := io.ReadFull(r, b[pos:])
-               if err != nil {
-                       return nil, err
-               }
-               pos += nn
+func (r *Reader) buf(n int) []byte {
+       if d := n - cap(r._buf); d > 0 {
+               r._buf = append(r._buf, make([]byte, d)...)
        }
-
-       return b, nil
+       return r._buf[:n]
 }
 
 func isNilReply(b []byte) bool {
@@ -304,10 +282,6 @@ func ParseErrorReply(line []byte) error {
        return RedisError(string(line[1:]))
 }
 
-func parseTmpStatusReply(line []byte) []byte {
-       return line[1:]
-}
-
 func parseArrayLen(line []byte) (int64, error) {
        if isNilReply(line) {
                return 0, Nil