* update github.com/blevesearch/bleve v2.0.2 -> v2.0.3 * github.com/denisenkom/go-mssqldb v0.9.0 -> v0.10.0 * github.com/editorconfig/editorconfig-core-go v2.4.1 -> v2.4.2 * github.com/go-chi/cors v1.1.1 -> v1.2.0 * github.com/go-git/go-billy v5.0.0 -> v5.1.0 * github.com/go-git/go-git v5.2.0 -> v5.3.0 * github.com/go-ldap/ldap v3.2.4 -> v3.3.0 * github.com/go-redis/redis v8.6.0 -> v8.8.2 * github.com/go-sql-driver/mysql v1.5.0 -> v1.6.0 * github.com/go-swagger/go-swagger v0.26.1 -> v0.27.0 * github.com/lib/pq v1.9.0 -> v1.10.1 * github.com/mattn/go-sqlite3 v1.14.6 -> v1.14.7 * github.com/go-testfixtures/testfixtures v3.5.0 -> v3.6.0 * github.com/issue9/identicon v1.0.1 -> v1.2.0 * github.com/klauspost/compress v1.11.8 -> v1.12.1 * github.com/mgechev/revive v1.0.3 -> v1.0.6 * github.com/microcosm-cc/bluemonday v1.0.7 -> v1.0.8 * github.com/niklasfasching/go-org v1.4.0 -> v1.5.0 * github.com/olivere/elastic v7.0.22 -> v7.0.24 * github.com/pelletier/go-toml v1.8.1 -> v1.9.0 * github.com/prometheus/client_golang v1.9.0 -> v1.10.0 * github.com/xanzy/go-gitlab v0.44.0 -> v0.48.0 * github.com/yuin/goldmark v1.3.3 -> v1.3.5 * github.com/6543/go-version v1.2.4 -> v1.3.1 * do github.com/lib/pq v1.10.0 -> v1.10.1 again ...
		
			
				
	
	
		
			173 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			173 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| package proto
 | |
| 
 | |
| import (
 | |
| 	"encoding"
 | |
| 	"fmt"
 | |
| 	"reflect"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/go-redis/redis/v8/internal/util"
 | |
| )
 | |
| 
 | |
| // Scan parses bytes `b` to `v` with appropriate type.
 | |
| func Scan(b []byte, v interface{}) error {
 | |
| 	switch v := v.(type) {
 | |
| 	case nil:
 | |
| 		return fmt.Errorf("redis: Scan(nil)")
 | |
| 	case *string:
 | |
| 		*v = util.BytesToString(b)
 | |
| 		return nil
 | |
| 	case *[]byte:
 | |
| 		*v = b
 | |
| 		return nil
 | |
| 	case *int:
 | |
| 		var err error
 | |
| 		*v, err = util.Atoi(b)
 | |
| 		return err
 | |
| 	case *int8:
 | |
| 		n, err := util.ParseInt(b, 10, 8)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = int8(n)
 | |
| 		return nil
 | |
| 	case *int16:
 | |
| 		n, err := util.ParseInt(b, 10, 16)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = int16(n)
 | |
| 		return nil
 | |
| 	case *int32:
 | |
| 		n, err := util.ParseInt(b, 10, 32)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = int32(n)
 | |
| 		return nil
 | |
| 	case *int64:
 | |
| 		n, err := util.ParseInt(b, 10, 64)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = n
 | |
| 		return nil
 | |
| 	case *uint:
 | |
| 		n, err := util.ParseUint(b, 10, 64)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = uint(n)
 | |
| 		return nil
 | |
| 	case *uint8:
 | |
| 		n, err := util.ParseUint(b, 10, 8)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = uint8(n)
 | |
| 		return nil
 | |
| 	case *uint16:
 | |
| 		n, err := util.ParseUint(b, 10, 16)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = uint16(n)
 | |
| 		return nil
 | |
| 	case *uint32:
 | |
| 		n, err := util.ParseUint(b, 10, 32)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = uint32(n)
 | |
| 		return nil
 | |
| 	case *uint64:
 | |
| 		n, err := util.ParseUint(b, 10, 64)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = n
 | |
| 		return nil
 | |
| 	case *float32:
 | |
| 		n, err := util.ParseFloat(b, 32)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 		*v = float32(n)
 | |
| 		return err
 | |
| 	case *float64:
 | |
| 		var err error
 | |
| 		*v, err = util.ParseFloat(b, 64)
 | |
| 		return err
 | |
| 	case *bool:
 | |
| 		*v = len(b) == 1 && b[0] == '1'
 | |
| 		return nil
 | |
| 	case *time.Time:
 | |
| 		var err error
 | |
| 		*v, err = time.Parse(time.RFC3339Nano, util.BytesToString(b))
 | |
| 		return err
 | |
| 	case encoding.BinaryUnmarshaler:
 | |
| 		return v.UnmarshalBinary(b)
 | |
| 	default:
 | |
| 		return fmt.Errorf(
 | |
| 			"redis: can't unmarshal %T (consider implementing BinaryUnmarshaler)", v)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func ScanSlice(data []string, slice interface{}) error {
 | |
| 	v := reflect.ValueOf(slice)
 | |
| 	if !v.IsValid() {
 | |
| 		return fmt.Errorf("redis: ScanSlice(nil)")
 | |
| 	}
 | |
| 	if v.Kind() != reflect.Ptr {
 | |
| 		return fmt.Errorf("redis: ScanSlice(non-pointer %T)", slice)
 | |
| 	}
 | |
| 	v = v.Elem()
 | |
| 	if v.Kind() != reflect.Slice {
 | |
| 		return fmt.Errorf("redis: ScanSlice(non-slice %T)", slice)
 | |
| 	}
 | |
| 
 | |
| 	next := makeSliceNextElemFunc(v)
 | |
| 	for i, s := range data {
 | |
| 		elem := next()
 | |
| 		if err := Scan([]byte(s), elem.Addr().Interface()); err != nil {
 | |
| 			err = fmt.Errorf("redis: ScanSlice index=%d value=%q failed: %w", i, s, err)
 | |
| 			return err
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func makeSliceNextElemFunc(v reflect.Value) func() reflect.Value {
 | |
| 	elemType := v.Type().Elem()
 | |
| 
 | |
| 	if elemType.Kind() == reflect.Ptr {
 | |
| 		elemType = elemType.Elem()
 | |
| 		return func() reflect.Value {
 | |
| 			if v.Len() < v.Cap() {
 | |
| 				v.Set(v.Slice(0, v.Len()+1))
 | |
| 				elem := v.Index(v.Len() - 1)
 | |
| 				if elem.IsNil() {
 | |
| 					elem.Set(reflect.New(elemType))
 | |
| 				}
 | |
| 				return elem.Elem()
 | |
| 			}
 | |
| 
 | |
| 			elem := reflect.New(elemType)
 | |
| 			v.Set(reflect.Append(v, elem))
 | |
| 			return elem.Elem()
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	zero := reflect.Zero(elemType)
 | |
| 	return func() reflect.Value {
 | |
| 		if v.Len() < v.Cap() {
 | |
| 			v.Set(v.Slice(0, v.Len()+1))
 | |
| 			return v.Index(v.Len() - 1)
 | |
| 		}
 | |
| 
 | |
| 		v.Set(reflect.Append(v, zero))
 | |
| 		return v.Index(v.Len() - 1)
 | |
| 	}
 | |
| }
 |