mirror of
https://github.com/go-gitea/gitea.git
synced 2025-01-18 22:43:16 +08:00
604 lines
16 KiB
Go
604 lines
16 KiB
Go
|
// Copyright 2018 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.
|
||
|
|
||
|
// Code generated by generate-types. DO NOT EDIT.
|
||
|
|
||
|
package proto
|
||
|
|
||
|
import (
|
||
|
"math"
|
||
|
"unicode/utf8"
|
||
|
|
||
|
"google.golang.org/protobuf/encoding/protowire"
|
||
|
"google.golang.org/protobuf/internal/errors"
|
||
|
"google.golang.org/protobuf/internal/strs"
|
||
|
"google.golang.org/protobuf/reflect/protoreflect"
|
||
|
)
|
||
|
|
||
|
// unmarshalScalar decodes a value of the given kind.
|
||
|
//
|
||
|
// Message values are decoded into a []byte which aliases the input data.
|
||
|
func (o UnmarshalOptions) unmarshalScalar(b []byte, wtyp protowire.Type, fd protoreflect.FieldDescriptor) (val protoreflect.Value, n int, err error) {
|
||
|
switch fd.Kind() {
|
||
|
case protoreflect.BoolKind:
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfBool(protowire.DecodeBool(v)), n, nil
|
||
|
case protoreflect.EnumKind:
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfEnum(protoreflect.EnumNumber(v)), n, nil
|
||
|
case protoreflect.Int32Kind:
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfInt32(int32(v)), n, nil
|
||
|
case protoreflect.Sint32Kind:
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfInt32(int32(protowire.DecodeZigZag(v & math.MaxUint32))), n, nil
|
||
|
case protoreflect.Uint32Kind:
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfUint32(uint32(v)), n, nil
|
||
|
case protoreflect.Int64Kind:
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfInt64(int64(v)), n, nil
|
||
|
case protoreflect.Sint64Kind:
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfInt64(protowire.DecodeZigZag(v)), n, nil
|
||
|
case protoreflect.Uint64Kind:
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfUint64(v), n, nil
|
||
|
case protoreflect.Sfixed32Kind:
|
||
|
if wtyp != protowire.Fixed32Type {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed32(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfInt32(int32(v)), n, nil
|
||
|
case protoreflect.Fixed32Kind:
|
||
|
if wtyp != protowire.Fixed32Type {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed32(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfUint32(uint32(v)), n, nil
|
||
|
case protoreflect.FloatKind:
|
||
|
if wtyp != protowire.Fixed32Type {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed32(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfFloat32(math.Float32frombits(uint32(v))), n, nil
|
||
|
case protoreflect.Sfixed64Kind:
|
||
|
if wtyp != protowire.Fixed64Type {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed64(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfInt64(int64(v)), n, nil
|
||
|
case protoreflect.Fixed64Kind:
|
||
|
if wtyp != protowire.Fixed64Type {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed64(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfUint64(v), n, nil
|
||
|
case protoreflect.DoubleKind:
|
||
|
if wtyp != protowire.Fixed64Type {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed64(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfFloat64(math.Float64frombits(v)), n, nil
|
||
|
case protoreflect.StringKind:
|
||
|
if wtyp != protowire.BytesType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
if strs.EnforceUTF8(fd) && !utf8.Valid(v) {
|
||
|
return protoreflect.Value{}, 0, errors.InvalidUTF8(string(fd.FullName()))
|
||
|
}
|
||
|
return protoreflect.ValueOfString(string(v)), n, nil
|
||
|
case protoreflect.BytesKind:
|
||
|
if wtyp != protowire.BytesType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfBytes(append(emptyBuf[:], v...)), n, nil
|
||
|
case protoreflect.MessageKind:
|
||
|
if wtyp != protowire.BytesType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfBytes(v), n, nil
|
||
|
case protoreflect.GroupKind:
|
||
|
if wtyp != protowire.StartGroupType {
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeGroup(fd.Number(), b)
|
||
|
if n < 0 {
|
||
|
return val, 0, protowire.ParseError(n)
|
||
|
}
|
||
|
return protoreflect.ValueOfBytes(v), n, nil
|
||
|
default:
|
||
|
return val, 0, errUnknown
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (o UnmarshalOptions) unmarshalList(b []byte, wtyp protowire.Type, list protoreflect.List, fd protoreflect.FieldDescriptor) (n int, err error) {
|
||
|
switch fd.Kind() {
|
||
|
case protoreflect.BoolKind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeVarint(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfBool(protowire.DecodeBool(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfBool(protowire.DecodeBool(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.EnumKind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeVarint(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfEnum(protoreflect.EnumNumber(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfEnum(protoreflect.EnumNumber(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.Int32Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeVarint(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfInt32(int32(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfInt32(int32(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.Sint32Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeVarint(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfInt32(int32(protowire.DecodeZigZag(v & math.MaxUint32))))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfInt32(int32(protowire.DecodeZigZag(v & math.MaxUint32))))
|
||
|
return n, nil
|
||
|
case protoreflect.Uint32Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeVarint(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfUint32(uint32(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfUint32(uint32(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.Int64Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeVarint(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfInt64(int64(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfInt64(int64(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.Sint64Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeVarint(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfInt64(protowire.DecodeZigZag(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfInt64(protowire.DecodeZigZag(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.Uint64Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeVarint(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfUint64(v))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.VarintType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeVarint(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfUint64(v))
|
||
|
return n, nil
|
||
|
case protoreflect.Sfixed32Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeFixed32(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfInt32(int32(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.Fixed32Type {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed32(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfInt32(int32(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.Fixed32Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeFixed32(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfUint32(uint32(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.Fixed32Type {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed32(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfUint32(uint32(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.FloatKind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeFixed32(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfFloat32(math.Float32frombits(uint32(v))))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.Fixed32Type {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed32(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfFloat32(math.Float32frombits(uint32(v))))
|
||
|
return n, nil
|
||
|
case protoreflect.Sfixed64Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeFixed64(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfInt64(int64(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.Fixed64Type {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed64(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfInt64(int64(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.Fixed64Kind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeFixed64(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfUint64(v))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.Fixed64Type {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed64(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfUint64(v))
|
||
|
return n, nil
|
||
|
case protoreflect.DoubleKind:
|
||
|
if wtyp == protowire.BytesType {
|
||
|
buf, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
for len(buf) > 0 {
|
||
|
v, n := protowire.ConsumeFixed64(buf)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
buf = buf[n:]
|
||
|
list.Append(protoreflect.ValueOfFloat64(math.Float64frombits(v)))
|
||
|
}
|
||
|
return n, nil
|
||
|
}
|
||
|
if wtyp != protowire.Fixed64Type {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeFixed64(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfFloat64(math.Float64frombits(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.StringKind:
|
||
|
if wtyp != protowire.BytesType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
if strs.EnforceUTF8(fd) && !utf8.Valid(v) {
|
||
|
return 0, errors.InvalidUTF8(string(fd.FullName()))
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfString(string(v)))
|
||
|
return n, nil
|
||
|
case protoreflect.BytesKind:
|
||
|
if wtyp != protowire.BytesType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
list.Append(protoreflect.ValueOfBytes(append(emptyBuf[:], v...)))
|
||
|
return n, nil
|
||
|
case protoreflect.MessageKind:
|
||
|
if wtyp != protowire.BytesType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeBytes(b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
m := list.NewElement()
|
||
|
if err := o.unmarshalMessage(v, m.Message()); err != nil {
|
||
|
return 0, err
|
||
|
}
|
||
|
list.Append(m)
|
||
|
return n, nil
|
||
|
case protoreflect.GroupKind:
|
||
|
if wtyp != protowire.StartGroupType {
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
v, n := protowire.ConsumeGroup(fd.Number(), b)
|
||
|
if n < 0 {
|
||
|
return 0, protowire.ParseError(n)
|
||
|
}
|
||
|
m := list.NewElement()
|
||
|
if err := o.unmarshalMessage(v, m.Message()); err != nil {
|
||
|
return 0, err
|
||
|
}
|
||
|
list.Append(m)
|
||
|
return n, nil
|
||
|
default:
|
||
|
return 0, errUnknown
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// We append to an empty array rather than a nil []byte to get non-nil zero-length byte slices.
|
||
|
var emptyBuf [0]byte
|