package decoder

import (
	
	
	

	
	
)

type uintDecoder struct {
	typ        *runtime.Type
	kind       reflect.Kind
	op         func(unsafe.Pointer, uint64)
	structName string
	fieldName  string
}

func newUintDecoder( *runtime.Type, ,  string,  func(unsafe.Pointer, uint64)) *uintDecoder {
	return &uintDecoder{
		typ:        ,
		kind:       .Kind(),
		op:         ,
		structName: ,
		fieldName:  ,
	}
}

func ( *uintDecoder) ( []byte,  int64) *errors.UnmarshalTypeError {
	return &errors.UnmarshalTypeError{
		Value:  fmt.Sprintf("number %s", string()),
		Type:   runtime.RType2Type(.typ),
		Offset: ,
	}
}

var (
	pow10u64 = [...]uint64{
		1e00, 1e01, 1e02, 1e03, 1e04, 1e05, 1e06, 1e07, 1e08, 1e09,
		1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16, 1e17, 1e18, 1e19,
	}
	pow10u64Len = len(pow10u64)
)

func ( *uintDecoder) ( []byte) (uint64, error) {
	 := len()
	if  > pow10u64Len {
		return 0, fmt.Errorf("invalid length of number")
	}
	 := uint64(0)
	for  := 0;  < ; ++ {
		 := uint64([]) - 48
		 := pow10u64[--1]
		 +=  * 
	}
	return , nil
}

func ( *uintDecoder) ( *Stream) ([]byte, error) {
	for {
		switch .char() {
		case ' ', '\n', '\t', '\r':
			.cursor++
			continue
		case '0':
			.cursor++
			return numZeroBuf, nil
		case '1', '2', '3', '4', '5', '6', '7', '8', '9':
			 := .cursor
			for {
				.cursor++
				if numTable[.char()] {
					continue
				} else if .char() == nul {
					if .read() {
						.cursor-- // for retry current character
						continue
					}
				}
				break
			}
			 := .buf[:.cursor]
			return , nil
		case 'n':
			if  := nullBytes();  != nil {
				return nil, 
			}
			return nil, nil
		case nul:
			if .read() {
				continue
			}
		default:
			return nil, .typeError([]byte{.char()}, .totalOffset())
		}
		break
	}
	return nil, errors.ErrUnexpectedEndOfJSON("number(unsigned integer)", .totalOffset())
}

func ( *uintDecoder) ( []byte,  int64) ([]byte, int64, error) {
	for {
		switch [] {
		case ' ', '\n', '\t', '\r':
			++
			continue
		case '0':
			++
			return numZeroBuf, , nil
		case '1', '2', '3', '4', '5', '6', '7', '8', '9':
			 := 
			++
			for numTable[[]] {
				++
			}
			 := [:]
			return , , nil
		case 'n':
			if  := validateNull(, );  != nil {
				return nil, 0, 
			}
			 += 4
			return nil, , nil
		default:
			return nil, 0, .typeError([]byte{[]}, )
		}
	}
}

func ( *uintDecoder) ( *Stream,  int64,  unsafe.Pointer) error {
	,  := .decodeStreamByte()
	if  != nil {
		return 
	}
	if  == nil {
		return nil
	}
	,  := .parseUint()
	if  != nil {
		return .typeError(, .totalOffset())
	}
	switch .kind {
	case reflect.Uint8:
		if (1 << 8) <=  {
			return .typeError(, .totalOffset())
		}
	case reflect.Uint16:
		if (1 << 16) <=  {
			return .typeError(, .totalOffset())
		}
	case reflect.Uint32:
		if (1 << 32) <=  {
			return .typeError(, .totalOffset())
		}
	}
	.op(, )
	return nil
}

func ( *uintDecoder) ( *RuntimeContext, ,  int64,  unsafe.Pointer) (int64, error) {
	, ,  := .decodeByte(.Buf, )
	if  != nil {
		return 0, 
	}
	if  == nil {
		return , nil
	}
	 = 
	,  := .parseUint()
	if  != nil {
		return 0, .typeError(, )
	}
	switch .kind {
	case reflect.Uint8:
		if (1 << 8) <=  {
			return 0, .typeError(, )
		}
	case reflect.Uint16:
		if (1 << 16) <=  {
			return 0, .typeError(, )
		}
	case reflect.Uint32:
		if (1 << 32) <=  {
			return 0, .typeError(, )
		}
	}
	.op(, )
	return , nil
}

func ( *uintDecoder) ( *RuntimeContext, ,  int64) ([][]byte, int64, error) {
	return nil, 0, fmt.Errorf("json: uint decoder does not support decode path")
}