mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-03 21:08:25 +00:00 
			
		
		
		
	* 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 ...
		
			
				
	
	
		
			174 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			174 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
// Copyright (C) MongoDB, Inc. 2017-present.
 | 
						|
//
 | 
						|
// 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
 | 
						|
 | 
						|
package bsoncodec
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"math"
 | 
						|
	"reflect"
 | 
						|
 | 
						|
	"go.mongodb.org/mongo-driver/bson/bsonoptions"
 | 
						|
	"go.mongodb.org/mongo-driver/bson/bsonrw"
 | 
						|
	"go.mongodb.org/mongo-driver/bson/bsontype"
 | 
						|
)
 | 
						|
 | 
						|
// UIntCodec is the Codec used for uint values.
 | 
						|
type UIntCodec struct {
 | 
						|
	EncodeToMinSize bool
 | 
						|
}
 | 
						|
 | 
						|
var (
 | 
						|
	defaultUIntCodec = NewUIntCodec()
 | 
						|
 | 
						|
	_ ValueCodec  = defaultUIntCodec
 | 
						|
	_ typeDecoder = defaultUIntCodec
 | 
						|
)
 | 
						|
 | 
						|
// NewUIntCodec returns a UIntCodec with options opts.
 | 
						|
func NewUIntCodec(opts ...*bsonoptions.UIntCodecOptions) *UIntCodec {
 | 
						|
	uintOpt := bsonoptions.MergeUIntCodecOptions(opts...)
 | 
						|
 | 
						|
	codec := UIntCodec{}
 | 
						|
	if uintOpt.EncodeToMinSize != nil {
 | 
						|
		codec.EncodeToMinSize = *uintOpt.EncodeToMinSize
 | 
						|
	}
 | 
						|
	return &codec
 | 
						|
}
 | 
						|
 | 
						|
// EncodeValue is the ValueEncoder for uint types.
 | 
						|
func (uic *UIntCodec) EncodeValue(ec EncodeContext, vw bsonrw.ValueWriter, val reflect.Value) error {
 | 
						|
	switch val.Kind() {
 | 
						|
	case reflect.Uint8, reflect.Uint16:
 | 
						|
		return vw.WriteInt32(int32(val.Uint()))
 | 
						|
	case reflect.Uint, reflect.Uint32, reflect.Uint64:
 | 
						|
		u64 := val.Uint()
 | 
						|
 | 
						|
		// If ec.MinSize or if encodeToMinSize is true for a non-uint64 value we should write val as an int32
 | 
						|
		useMinSize := ec.MinSize || (uic.EncodeToMinSize && val.Kind() != reflect.Uint64)
 | 
						|
 | 
						|
		if u64 <= math.MaxInt32 && useMinSize {
 | 
						|
			return vw.WriteInt32(int32(u64))
 | 
						|
		}
 | 
						|
		if u64 > math.MaxInt64 {
 | 
						|
			return fmt.Errorf("%d overflows int64", u64)
 | 
						|
		}
 | 
						|
		return vw.WriteInt64(int64(u64))
 | 
						|
	}
 | 
						|
 | 
						|
	return ValueEncoderError{
 | 
						|
		Name:     "UintEncodeValue",
 | 
						|
		Kinds:    []reflect.Kind{reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uint},
 | 
						|
		Received: val,
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func (uic *UIntCodec) decodeType(dc DecodeContext, vr bsonrw.ValueReader, t reflect.Type) (reflect.Value, error) {
 | 
						|
	var i64 int64
 | 
						|
	var err error
 | 
						|
	switch vrType := vr.Type(); vrType {
 | 
						|
	case bsontype.Int32:
 | 
						|
		i32, err := vr.ReadInt32()
 | 
						|
		if err != nil {
 | 
						|
			return emptyValue, err
 | 
						|
		}
 | 
						|
		i64 = int64(i32)
 | 
						|
	case bsontype.Int64:
 | 
						|
		i64, err = vr.ReadInt64()
 | 
						|
		if err != nil {
 | 
						|
			return emptyValue, err
 | 
						|
		}
 | 
						|
	case bsontype.Double:
 | 
						|
		f64, err := vr.ReadDouble()
 | 
						|
		if err != nil {
 | 
						|
			return emptyValue, err
 | 
						|
		}
 | 
						|
		if !dc.Truncate && math.Floor(f64) != f64 {
 | 
						|
			return emptyValue, errCannotTruncate
 | 
						|
		}
 | 
						|
		if f64 > float64(math.MaxInt64) {
 | 
						|
			return emptyValue, fmt.Errorf("%g overflows int64", f64)
 | 
						|
		}
 | 
						|
		i64 = int64(f64)
 | 
						|
	case bsontype.Boolean:
 | 
						|
		b, err := vr.ReadBoolean()
 | 
						|
		if err != nil {
 | 
						|
			return emptyValue, err
 | 
						|
		}
 | 
						|
		if b {
 | 
						|
			i64 = 1
 | 
						|
		}
 | 
						|
	case bsontype.Null:
 | 
						|
		if err = vr.ReadNull(); err != nil {
 | 
						|
			return emptyValue, err
 | 
						|
		}
 | 
						|
	case bsontype.Undefined:
 | 
						|
		if err = vr.ReadUndefined(); err != nil {
 | 
						|
			return emptyValue, err
 | 
						|
		}
 | 
						|
	default:
 | 
						|
		return emptyValue, fmt.Errorf("cannot decode %v into an integer type", vrType)
 | 
						|
	}
 | 
						|
 | 
						|
	switch t.Kind() {
 | 
						|
	case reflect.Uint8:
 | 
						|
		if i64 < 0 || i64 > math.MaxUint8 {
 | 
						|
			return emptyValue, fmt.Errorf("%d overflows uint8", i64)
 | 
						|
		}
 | 
						|
 | 
						|
		return reflect.ValueOf(uint8(i64)), nil
 | 
						|
	case reflect.Uint16:
 | 
						|
		if i64 < 0 || i64 > math.MaxUint16 {
 | 
						|
			return emptyValue, fmt.Errorf("%d overflows uint16", i64)
 | 
						|
		}
 | 
						|
 | 
						|
		return reflect.ValueOf(uint16(i64)), nil
 | 
						|
	case reflect.Uint32:
 | 
						|
		if i64 < 0 || i64 > math.MaxUint32 {
 | 
						|
			return emptyValue, fmt.Errorf("%d overflows uint32", i64)
 | 
						|
		}
 | 
						|
 | 
						|
		return reflect.ValueOf(uint32(i64)), nil
 | 
						|
	case reflect.Uint64:
 | 
						|
		if i64 < 0 {
 | 
						|
			return emptyValue, fmt.Errorf("%d overflows uint64", i64)
 | 
						|
		}
 | 
						|
 | 
						|
		return reflect.ValueOf(uint64(i64)), nil
 | 
						|
	case reflect.Uint:
 | 
						|
		if i64 < 0 || int64(uint(i64)) != i64 { // Can we fit this inside of an uint
 | 
						|
			return emptyValue, fmt.Errorf("%d overflows uint", i64)
 | 
						|
		}
 | 
						|
 | 
						|
		return reflect.ValueOf(uint(i64)), nil
 | 
						|
	default:
 | 
						|
		return emptyValue, ValueDecoderError{
 | 
						|
			Name:     "UintDecodeValue",
 | 
						|
			Kinds:    []reflect.Kind{reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uint},
 | 
						|
			Received: reflect.Zero(t),
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// DecodeValue is the ValueDecoder for uint types.
 | 
						|
func (uic *UIntCodec) DecodeValue(dc DecodeContext, vr bsonrw.ValueReader, val reflect.Value) error {
 | 
						|
	if !val.CanSet() {
 | 
						|
		return ValueDecoderError{
 | 
						|
			Name:     "UintDecodeValue",
 | 
						|
			Kinds:    []reflect.Kind{reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uint},
 | 
						|
			Received: val,
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	elem, err := uic.decodeType(dc, vr, val.Type())
 | 
						|
	if err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
 | 
						|
	val.SetUint(elem.Uint())
 | 
						|
	return nil
 | 
						|
}
 |