convert_map.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. // Copyright 2018 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 impl
  5. import (
  6. "fmt"
  7. "reflect"
  8. pref "google.golang.org/protobuf/reflect/protoreflect"
  9. )
  10. type mapConverter struct {
  11. goType reflect.Type
  12. keyConv, valConv Converter
  13. }
  14. func newMapConverter(t reflect.Type, fd pref.FieldDescriptor) Converter {
  15. if t.Kind() != reflect.Map {
  16. panic(fmt.Sprintf("invalid Go type %v for field %v", t, fd.FullName()))
  17. }
  18. return &mapConverter{
  19. goType: t,
  20. keyConv: newSingularConverter(t.Key(), fd.MapKey()),
  21. valConv: newSingularConverter(t.Elem(), fd.MapValue()),
  22. }
  23. }
  24. func (c *mapConverter) PBValueOf(v reflect.Value) pref.Value {
  25. if v.Type() != c.goType {
  26. panic(fmt.Sprintf("invalid type: got %v, want %v", v.Type(), c.goType))
  27. }
  28. return pref.ValueOf(&mapReflect{v, c.keyConv, c.valConv})
  29. }
  30. func (c *mapConverter) GoValueOf(v pref.Value) reflect.Value {
  31. return v.Map().(*mapReflect).v
  32. }
  33. func (c *mapConverter) New() pref.Value {
  34. return c.PBValueOf(reflect.MakeMap(c.goType))
  35. }
  36. func (c *mapConverter) Zero() pref.Value {
  37. return c.PBValueOf(reflect.Zero(c.goType))
  38. }
  39. type mapReflect struct {
  40. v reflect.Value // map[K]V
  41. keyConv Converter
  42. valConv Converter
  43. }
  44. func (ms *mapReflect) Len() int {
  45. return ms.v.Len()
  46. }
  47. func (ms *mapReflect) Has(k pref.MapKey) bool {
  48. rk := ms.keyConv.GoValueOf(k.Value())
  49. rv := ms.v.MapIndex(rk)
  50. return rv.IsValid()
  51. }
  52. func (ms *mapReflect) Get(k pref.MapKey) pref.Value {
  53. rk := ms.keyConv.GoValueOf(k.Value())
  54. rv := ms.v.MapIndex(rk)
  55. if !rv.IsValid() {
  56. return pref.Value{}
  57. }
  58. return ms.valConv.PBValueOf(rv)
  59. }
  60. func (ms *mapReflect) Set(k pref.MapKey, v pref.Value) {
  61. rk := ms.keyConv.GoValueOf(k.Value())
  62. rv := ms.valConv.GoValueOf(v)
  63. ms.v.SetMapIndex(rk, rv)
  64. }
  65. func (ms *mapReflect) Clear(k pref.MapKey) {
  66. rk := ms.keyConv.GoValueOf(k.Value())
  67. ms.v.SetMapIndex(rk, reflect.Value{})
  68. }
  69. func (ms *mapReflect) Range(f func(pref.MapKey, pref.Value) bool) {
  70. for _, k := range ms.v.MapKeys() {
  71. if v := ms.v.MapIndex(k); v.IsValid() {
  72. pk := ms.keyConv.PBValueOf(k).MapKey()
  73. pv := ms.valConv.PBValueOf(v)
  74. if !f(pk, pv) {
  75. return
  76. }
  77. }
  78. }
  79. }
  80. func (ms *mapReflect) NewMessage() pref.Message {
  81. return ms.NewValue().Message()
  82. }
  83. func (ms *mapReflect) NewValue() pref.Value {
  84. return ms.valConv.New()
  85. }
  86. func (ms *mapReflect) ProtoUnwrap() interface{} {
  87. return ms.v.Interface()
  88. }