decode.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702
  1. // Copyright 2019 The Go Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. package jsonpb
  5. import (
  6. "encoding/base64"
  7. "fmt"
  8. "math"
  9. "strconv"
  10. "strings"
  11. "github.com/golang/protobuf/v2/internal/encoding/json"
  12. "github.com/golang/protobuf/v2/internal/errors"
  13. "github.com/golang/protobuf/v2/internal/pragma"
  14. "github.com/golang/protobuf/v2/internal/set"
  15. "github.com/golang/protobuf/v2/proto"
  16. pref "github.com/golang/protobuf/v2/reflect/protoreflect"
  17. "github.com/golang/protobuf/v2/reflect/protoregistry"
  18. )
  19. // Unmarshal reads the given []byte into the given proto.Message.
  20. func Unmarshal(m proto.Message, b []byte) error {
  21. return UnmarshalOptions{}.Unmarshal(m, b)
  22. }
  23. // UnmarshalOptions is a configurable JSON format parser.
  24. type UnmarshalOptions struct {
  25. pragma.NoUnkeyedLiterals
  26. // Resolver is the registry used for type lookups when unmarshaling extensions
  27. // and processing Any. If Resolver is not set, unmarshaling will default to
  28. // using protoregistry.GlobalTypes.
  29. Resolver *protoregistry.Types
  30. }
  31. // Unmarshal reads the given []byte and populates the given proto.Message using
  32. // options in UnmarshalOptions object. It will clear the message first before
  33. // setting the fields. If it returns an error, the given message may be
  34. // partially set.
  35. func (o UnmarshalOptions) Unmarshal(m proto.Message, b []byte) error {
  36. mr := m.ProtoReflect()
  37. // TODO: Determine if we would like to have an option for merging or only
  38. // have merging behavior. We should at least be consistent with textproto
  39. // marshaling.
  40. resetMessage(mr)
  41. resolver := o.Resolver
  42. if resolver == nil {
  43. resolver = protoregistry.GlobalTypes
  44. }
  45. dec := decoder{
  46. Decoder: json.NewDecoder(b),
  47. resolver: resolver,
  48. }
  49. var nerr errors.NonFatal
  50. if err := dec.unmarshalMessage(mr); !nerr.Merge(err) {
  51. return err
  52. }
  53. // Check for EOF.
  54. val, err := dec.Read()
  55. if err != nil {
  56. return err
  57. }
  58. if val.Type() != json.EOF {
  59. return unexpectedJSONError{val}
  60. }
  61. return nerr.E
  62. }
  63. // resetMessage clears all fields of given protoreflect.Message.
  64. func resetMessage(m pref.Message) {
  65. knownFields := m.KnownFields()
  66. knownFields.Range(func(num pref.FieldNumber, _ pref.Value) bool {
  67. knownFields.Clear(num)
  68. return true
  69. })
  70. unknownFields := m.UnknownFields()
  71. unknownFields.Range(func(num pref.FieldNumber, _ pref.RawFields) bool {
  72. unknownFields.Set(num, nil)
  73. return true
  74. })
  75. extTypes := knownFields.ExtensionTypes()
  76. extTypes.Range(func(xt pref.ExtensionType) bool {
  77. extTypes.Remove(xt)
  78. return true
  79. })
  80. }
  81. // unexpectedJSONError is an error that contains the unexpected json.Value. This
  82. // is used by decoder methods to provide callers the read json.Value that it
  83. // did not expect.
  84. // TODO: Consider moving this to internal/encoding/json for consistency with
  85. // errors that package returns.
  86. type unexpectedJSONError struct {
  87. value json.Value
  88. }
  89. func (e unexpectedJSONError) Error() string {
  90. return newError("unexpected value %s", e.value).Error()
  91. }
  92. // newError returns an error object. If one of the values passed in is of
  93. // json.Value type, it produces an error with position info.
  94. func newError(f string, x ...interface{}) error {
  95. var hasValue bool
  96. var line, column int
  97. for i := 0; i < len(x); i++ {
  98. if val, ok := x[i].(json.Value); ok {
  99. line, column = val.Position()
  100. hasValue = true
  101. break
  102. }
  103. }
  104. e := errors.New(f, x...)
  105. if hasValue {
  106. return errors.New("(line %d:%d): %v", line, column, e)
  107. }
  108. return e
  109. }
  110. // decoder decodes JSON into protoreflect values.
  111. type decoder struct {
  112. *json.Decoder
  113. resolver *protoregistry.Types
  114. }
  115. // unmarshalMessage unmarshals a message into the given protoreflect.Message.
  116. func (d decoder) unmarshalMessage(m pref.Message) error {
  117. var nerr errors.NonFatal
  118. if isCustomType(m.Type().FullName()) {
  119. return d.unmarshalCustomType(m)
  120. }
  121. jval, err := d.Read()
  122. if !nerr.Merge(err) {
  123. return err
  124. }
  125. if jval.Type() != json.StartObject {
  126. return unexpectedJSONError{jval}
  127. }
  128. if err := d.unmarshalFields(m); !nerr.Merge(err) {
  129. return err
  130. }
  131. return nerr.E
  132. }
  133. // unmarshalFields unmarshals the fields into the given protoreflect.Message.
  134. func (d decoder) unmarshalFields(m pref.Message) error {
  135. var nerr errors.NonFatal
  136. var reqNums set.Ints
  137. var seenNums set.Ints
  138. msgType := m.Type()
  139. knownFields := m.KnownFields()
  140. fieldDescs := msgType.Fields()
  141. xtTypes := knownFields.ExtensionTypes()
  142. Loop:
  143. for {
  144. // Read field name.
  145. jval, err := d.Read()
  146. if !nerr.Merge(err) {
  147. return err
  148. }
  149. switch jval.Type() {
  150. default:
  151. return unexpectedJSONError{jval}
  152. case json.EndObject:
  153. break Loop
  154. case json.Name:
  155. // Continue below.
  156. }
  157. name, err := jval.Name()
  158. if !nerr.Merge(err) {
  159. return err
  160. }
  161. // Get the FieldDescriptor.
  162. var fd pref.FieldDescriptor
  163. if strings.HasPrefix(name, "[") && strings.HasSuffix(name, "]") {
  164. // Only extension names are in [name] format.
  165. xtName := pref.FullName(name[1 : len(name)-1])
  166. xt := xtTypes.ByName(xtName)
  167. if xt == nil {
  168. xt, err = d.findExtension(xtName)
  169. if err != nil && err != protoregistry.NotFound {
  170. return errors.New("unable to resolve [%v]: %v", xtName, err)
  171. }
  172. if xt != nil {
  173. xtTypes.Register(xt)
  174. }
  175. }
  176. fd = xt
  177. } else {
  178. // The name can either be the JSON name or the proto field name.
  179. fd = fieldDescs.ByJSONName(name)
  180. if fd == nil {
  181. fd = fieldDescs.ByName(pref.Name(name))
  182. }
  183. }
  184. if fd == nil {
  185. // Field is unknown.
  186. // TODO: Provide option to ignore unknown message fields.
  187. return newError("%v contains unknown field %s", msgType.FullName(), jval)
  188. }
  189. // Do not allow duplicate fields.
  190. num := uint64(fd.Number())
  191. if seenNums.Has(num) {
  192. return newError("%v contains repeated field %s", msgType.FullName(), jval)
  193. }
  194. seenNums.Set(num)
  195. // No need to set values for JSON null unless the field type is
  196. // google.protobuf.Value.
  197. if d.Peek() == json.Null && !isKnownValue(fd) {
  198. d.Read()
  199. continue
  200. }
  201. if cardinality := fd.Cardinality(); cardinality == pref.Repeated {
  202. // Map or list fields have cardinality of repeated.
  203. if err := d.unmarshalRepeated(knownFields, fd); !nerr.Merge(err) {
  204. return errors.New("%v|%q: %v", fd.FullName(), name, err)
  205. }
  206. } else {
  207. // Required or optional fields.
  208. if err := d.unmarshalSingular(knownFields, fd); !nerr.Merge(err) {
  209. return errors.New("%v|%q: %v", fd.FullName(), name, err)
  210. }
  211. if cardinality == pref.Required {
  212. reqNums.Set(num)
  213. }
  214. }
  215. }
  216. // Check for any missing required fields.
  217. allReqNums := msgType.RequiredNumbers()
  218. if reqNums.Len() != allReqNums.Len() {
  219. for i := 0; i < allReqNums.Len(); i++ {
  220. if num := allReqNums.Get(i); !reqNums.Has(uint64(num)) {
  221. nerr.AppendRequiredNotSet(string(fieldDescs.ByNumber(num).FullName()))
  222. }
  223. }
  224. }
  225. return nerr.E
  226. }
  227. // findExtension returns protoreflect.ExtensionType from the resolver if found.
  228. func (d decoder) findExtension(xtName pref.FullName) (pref.ExtensionType, error) {
  229. xt, err := d.resolver.FindExtensionByName(xtName)
  230. if err == nil {
  231. return xt, nil
  232. }
  233. // Check if this is a MessageSet extension field.
  234. xt, err = d.resolver.FindExtensionByName(xtName + ".message_set_extension")
  235. if err == nil && isMessageSetExtension(xt) {
  236. return xt, nil
  237. }
  238. return nil, protoregistry.NotFound
  239. }
  240. // unmarshalSingular unmarshals to the non-repeated field specified by the given
  241. // FieldDescriptor.
  242. func (d decoder) unmarshalSingular(knownFields pref.KnownFields, fd pref.FieldDescriptor) error {
  243. var val pref.Value
  244. var err error
  245. num := fd.Number()
  246. switch fd.Kind() {
  247. case pref.MessageKind, pref.GroupKind:
  248. m := knownFields.NewMessage(num)
  249. err = d.unmarshalMessage(m)
  250. val = pref.ValueOf(m)
  251. default:
  252. val, err = d.unmarshalScalar(fd)
  253. }
  254. var nerr errors.NonFatal
  255. if !nerr.Merge(err) {
  256. return err
  257. }
  258. knownFields.Set(num, val)
  259. return nerr.E
  260. }
  261. // unmarshalScalar unmarshals to a scalar/enum protoreflect.Value specified by
  262. // the given FieldDescriptor.
  263. func (d decoder) unmarshalScalar(fd pref.FieldDescriptor) (pref.Value, error) {
  264. const b32 int = 32
  265. const b64 int = 64
  266. var nerr errors.NonFatal
  267. jval, err := d.Read()
  268. if !nerr.Merge(err) {
  269. return pref.Value{}, err
  270. }
  271. kind := fd.Kind()
  272. switch kind {
  273. case pref.BoolKind:
  274. return unmarshalBool(jval)
  275. case pref.Int32Kind, pref.Sint32Kind, pref.Sfixed32Kind:
  276. return unmarshalInt(jval, b32)
  277. case pref.Int64Kind, pref.Sint64Kind, pref.Sfixed64Kind:
  278. return unmarshalInt(jval, b64)
  279. case pref.Uint32Kind, pref.Fixed32Kind:
  280. return unmarshalUint(jval, b32)
  281. case pref.Uint64Kind, pref.Fixed64Kind:
  282. return unmarshalUint(jval, b64)
  283. case pref.FloatKind:
  284. return unmarshalFloat(jval, b32)
  285. case pref.DoubleKind:
  286. return unmarshalFloat(jval, b64)
  287. case pref.StringKind:
  288. pval, err := unmarshalString(jval)
  289. if !nerr.Merge(err) {
  290. return pval, err
  291. }
  292. return pval, nerr.E
  293. case pref.BytesKind:
  294. return unmarshalBytes(jval)
  295. case pref.EnumKind:
  296. return unmarshalEnum(jval, fd)
  297. }
  298. panic(fmt.Sprintf("invalid scalar kind %v", kind))
  299. }
  300. func unmarshalBool(jval json.Value) (pref.Value, error) {
  301. if jval.Type() != json.Bool {
  302. return pref.Value{}, unexpectedJSONError{jval}
  303. }
  304. b, err := jval.Bool()
  305. return pref.ValueOf(b), err
  306. }
  307. func unmarshalInt(jval json.Value, bitSize int) (pref.Value, error) {
  308. switch jval.Type() {
  309. case json.Number:
  310. return getInt(jval, bitSize)
  311. case json.String:
  312. // Decode number from string.
  313. dec := json.NewDecoder([]byte(jval.String()))
  314. var nerr errors.NonFatal
  315. jval, err := dec.Read()
  316. if !nerr.Merge(err) {
  317. return pref.Value{}, err
  318. }
  319. return getInt(jval, bitSize)
  320. }
  321. return pref.Value{}, unexpectedJSONError{jval}
  322. }
  323. func getInt(jval json.Value, bitSize int) (pref.Value, error) {
  324. n, err := jval.Int(bitSize)
  325. if err != nil {
  326. return pref.Value{}, err
  327. }
  328. if bitSize == 32 {
  329. return pref.ValueOf(int32(n)), nil
  330. }
  331. return pref.ValueOf(n), nil
  332. }
  333. func unmarshalUint(jval json.Value, bitSize int) (pref.Value, error) {
  334. switch jval.Type() {
  335. case json.Number:
  336. return getUint(jval, bitSize)
  337. case json.String:
  338. // Decode number from string.
  339. dec := json.NewDecoder([]byte(jval.String()))
  340. var nerr errors.NonFatal
  341. jval, err := dec.Read()
  342. if !nerr.Merge(err) {
  343. return pref.Value{}, err
  344. }
  345. return getUint(jval, bitSize)
  346. }
  347. return pref.Value{}, unexpectedJSONError{jval}
  348. }
  349. func getUint(jval json.Value, bitSize int) (pref.Value, error) {
  350. n, err := jval.Uint(bitSize)
  351. if err != nil {
  352. return pref.Value{}, err
  353. }
  354. if bitSize == 32 {
  355. return pref.ValueOf(uint32(n)), nil
  356. }
  357. return pref.ValueOf(n), nil
  358. }
  359. func unmarshalFloat(jval json.Value, bitSize int) (pref.Value, error) {
  360. switch jval.Type() {
  361. case json.Number:
  362. return getFloat(jval, bitSize)
  363. case json.String:
  364. s := jval.String()
  365. switch s {
  366. case "NaN":
  367. if bitSize == 32 {
  368. return pref.ValueOf(float32(math.NaN())), nil
  369. }
  370. return pref.ValueOf(math.NaN()), nil
  371. case "Infinity":
  372. if bitSize == 32 {
  373. return pref.ValueOf(float32(math.Inf(+1))), nil
  374. }
  375. return pref.ValueOf(math.Inf(+1)), nil
  376. case "-Infinity":
  377. if bitSize == 32 {
  378. return pref.ValueOf(float32(math.Inf(-1))), nil
  379. }
  380. return pref.ValueOf(math.Inf(-1)), nil
  381. }
  382. // Decode number from string.
  383. dec := json.NewDecoder([]byte(s))
  384. var nerr errors.NonFatal
  385. jval, err := dec.Read()
  386. if !nerr.Merge(err) {
  387. return pref.Value{}, err
  388. }
  389. return getFloat(jval, bitSize)
  390. }
  391. return pref.Value{}, unexpectedJSONError{jval}
  392. }
  393. func getFloat(jval json.Value, bitSize int) (pref.Value, error) {
  394. n, err := jval.Float(bitSize)
  395. if err != nil {
  396. return pref.Value{}, err
  397. }
  398. if bitSize == 32 {
  399. return pref.ValueOf(float32(n)), nil
  400. }
  401. return pref.ValueOf(n), nil
  402. }
  403. func unmarshalString(jval json.Value) (pref.Value, error) {
  404. if jval.Type() != json.String {
  405. return pref.Value{}, unexpectedJSONError{jval}
  406. }
  407. return pref.ValueOf(jval.String()), nil
  408. }
  409. func unmarshalBytes(jval json.Value) (pref.Value, error) {
  410. if jval.Type() != json.String {
  411. return pref.Value{}, unexpectedJSONError{jval}
  412. }
  413. s := jval.String()
  414. enc := base64.StdEncoding
  415. if strings.ContainsAny(s, "-_") {
  416. enc = base64.URLEncoding
  417. }
  418. if len(s)%4 != 0 {
  419. enc = enc.WithPadding(base64.NoPadding)
  420. }
  421. b, err := enc.DecodeString(s)
  422. if err != nil {
  423. return pref.Value{}, err
  424. }
  425. return pref.ValueOf(b), nil
  426. }
  427. func unmarshalEnum(jval json.Value, fd pref.FieldDescriptor) (pref.Value, error) {
  428. switch jval.Type() {
  429. case json.String:
  430. // Lookup EnumNumber based on name.
  431. s := jval.String()
  432. if enumVal := fd.EnumType().Values().ByName(pref.Name(s)); enumVal != nil {
  433. return pref.ValueOf(enumVal.Number()), nil
  434. }
  435. return pref.Value{}, newError("invalid enum value %q", jval)
  436. case json.Number:
  437. n, err := jval.Int(32)
  438. if err != nil {
  439. return pref.Value{}, err
  440. }
  441. return pref.ValueOf(pref.EnumNumber(n)), nil
  442. }
  443. return pref.Value{}, unexpectedJSONError{jval}
  444. }
  445. // unmarshalRepeated unmarshals into a repeated field.
  446. func (d decoder) unmarshalRepeated(knownFields pref.KnownFields, fd pref.FieldDescriptor) error {
  447. var nerr errors.NonFatal
  448. num := fd.Number()
  449. val := knownFields.Get(num)
  450. if !fd.IsMap() {
  451. if err := d.unmarshalList(val.List(), fd); !nerr.Merge(err) {
  452. return err
  453. }
  454. } else {
  455. if err := d.unmarshalMap(val.Map(), fd); !nerr.Merge(err) {
  456. return err
  457. }
  458. }
  459. return nerr.E
  460. }
  461. // unmarshalList unmarshals into given protoreflect.List.
  462. func (d decoder) unmarshalList(list pref.List, fd pref.FieldDescriptor) error {
  463. var nerr errors.NonFatal
  464. jval, err := d.Read()
  465. if !nerr.Merge(err) {
  466. return err
  467. }
  468. if jval.Type() != json.StartArray {
  469. return unexpectedJSONError{jval}
  470. }
  471. switch fd.Kind() {
  472. case pref.MessageKind, pref.GroupKind:
  473. for {
  474. m := list.NewMessage()
  475. err := d.unmarshalMessage(m)
  476. if !nerr.Merge(err) {
  477. if e, ok := err.(unexpectedJSONError); ok {
  478. if e.value.Type() == json.EndArray {
  479. // Done with list.
  480. return nerr.E
  481. }
  482. }
  483. return err
  484. }
  485. list.Append(pref.ValueOf(m))
  486. }
  487. default:
  488. for {
  489. val, err := d.unmarshalScalar(fd)
  490. if !nerr.Merge(err) {
  491. if e, ok := err.(unexpectedJSONError); ok {
  492. if e.value.Type() == json.EndArray {
  493. // Done with list.
  494. return nerr.E
  495. }
  496. }
  497. return err
  498. }
  499. list.Append(val)
  500. }
  501. }
  502. return nerr.E
  503. }
  504. // unmarshalMap unmarshals into given protoreflect.Map.
  505. func (d decoder) unmarshalMap(mmap pref.Map, fd pref.FieldDescriptor) error {
  506. var nerr errors.NonFatal
  507. jval, err := d.Read()
  508. if !nerr.Merge(err) {
  509. return err
  510. }
  511. if jval.Type() != json.StartObject {
  512. return unexpectedJSONError{jval}
  513. }
  514. fields := fd.MessageType().Fields()
  515. keyDesc := fields.ByNumber(1)
  516. valDesc := fields.ByNumber(2)
  517. // Determine ahead whether map entry is a scalar type or a message type in
  518. // order to call the appropriate unmarshalMapValue func inside the for loop
  519. // below.
  520. unmarshalMapValue := func() (pref.Value, error) {
  521. return d.unmarshalScalar(valDesc)
  522. }
  523. switch valDesc.Kind() {
  524. case pref.MessageKind, pref.GroupKind:
  525. unmarshalMapValue = func() (pref.Value, error) {
  526. var nerr errors.NonFatal
  527. m := mmap.NewMessage()
  528. if err := d.unmarshalMessage(m); !nerr.Merge(err) {
  529. return pref.Value{}, err
  530. }
  531. return pref.ValueOf(m), nerr.E
  532. }
  533. }
  534. Loop:
  535. for {
  536. // Read field name.
  537. jval, err := d.Read()
  538. if !nerr.Merge(err) {
  539. return err
  540. }
  541. switch jval.Type() {
  542. default:
  543. return unexpectedJSONError{jval}
  544. case json.EndObject:
  545. break Loop
  546. case json.Name:
  547. // Continue.
  548. }
  549. name, err := jval.Name()
  550. if !nerr.Merge(err) {
  551. return err
  552. }
  553. // Unmarshal field name.
  554. pkey, err := unmarshalMapKey(name, keyDesc)
  555. if !nerr.Merge(err) {
  556. return err
  557. }
  558. // Check for duplicate field name.
  559. if mmap.Has(pkey) {
  560. return newError("duplicate map key %q", jval)
  561. }
  562. // Read and unmarshal field value.
  563. pval, err := unmarshalMapValue()
  564. if !nerr.Merge(err) {
  565. return err
  566. }
  567. mmap.Set(pkey, pval)
  568. }
  569. return nerr.E
  570. }
  571. // unmarshalMapKey converts given string into a protoreflect.MapKey. A map key type is any
  572. // integral or string type.
  573. func unmarshalMapKey(name string, fd pref.FieldDescriptor) (pref.MapKey, error) {
  574. const b32 = 32
  575. const b64 = 64
  576. const base10 = 10
  577. kind := fd.Kind()
  578. switch kind {
  579. case pref.StringKind:
  580. return pref.ValueOf(name).MapKey(), nil
  581. case pref.BoolKind:
  582. switch name {
  583. case "true":
  584. return pref.ValueOf(true).MapKey(), nil
  585. case "false":
  586. return pref.ValueOf(false).MapKey(), nil
  587. }
  588. return pref.MapKey{}, errors.New("invalid value for boolean key %q", name)
  589. case pref.Int32Kind, pref.Sint32Kind, pref.Sfixed32Kind:
  590. n, err := strconv.ParseInt(name, base10, b32)
  591. if err != nil {
  592. return pref.MapKey{}, err
  593. }
  594. return pref.ValueOf(int32(n)).MapKey(), nil
  595. case pref.Int64Kind, pref.Sint64Kind, pref.Sfixed64Kind:
  596. n, err := strconv.ParseInt(name, base10, b64)
  597. if err != nil {
  598. return pref.MapKey{}, err
  599. }
  600. return pref.ValueOf(int64(n)).MapKey(), nil
  601. case pref.Uint32Kind, pref.Fixed32Kind:
  602. n, err := strconv.ParseUint(name, base10, b32)
  603. if err != nil {
  604. return pref.MapKey{}, err
  605. }
  606. return pref.ValueOf(uint32(n)).MapKey(), nil
  607. case pref.Uint64Kind, pref.Fixed64Kind:
  608. n, err := strconv.ParseUint(name, base10, b64)
  609. if err != nil {
  610. return pref.MapKey{}, err
  611. }
  612. return pref.ValueOf(uint64(n)).MapKey(), nil
  613. }
  614. panic(fmt.Sprintf("%s: invalid kind %s for map key", fd.FullName(), kind))
  615. }