mirror of
https://github.com/protocolbuffers/protobuf-go.git
synced 2025-01-09 03:39:24 +00:00
edf7bdda31
The code organization is simpler if we keep the functions encoding and decoding a particular type (e.g., maps) together rather than split across files. Rename various "encode" files to "codec" in preparation for adding fast-path decoding. Change-Id: If1e271da99d31533ffefc19b1fc847936fa9484a Reviewed-on: https://go-review.googlesource.com/c/protobuf/+/185241 Reviewed-by: Joe Tsai <thebrokentoaster@gmail.com>
38 lines
720 B
Go
38 lines
720 B
Go
// Copyright 2019 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.
|
|
|
|
// +build !go1.12
|
|
|
|
package impl
|
|
|
|
import "reflect"
|
|
|
|
type mapIter struct {
|
|
v reflect.Value
|
|
keys []reflect.Value
|
|
}
|
|
|
|
// mapRange provides a less-efficient equivalent to
|
|
// the Go 1.12 reflect.Value.MapRange method.
|
|
func mapRange(v reflect.Value) *mapIter {
|
|
return &mapIter{v: v}
|
|
}
|
|
|
|
func (i *mapIter) Next() bool {
|
|
if i.keys == nil {
|
|
i.keys = i.v.MapKeys()
|
|
} else {
|
|
i.keys = i.keys[1:]
|
|
}
|
|
return len(i.keys) > 0
|
|
}
|
|
|
|
func (i *mapIter) Key() reflect.Value {
|
|
return i.keys[0]
|
|
}
|
|
|
|
func (i *mapIter) Value() reflect.Value {
|
|
return i.v.MapIndex(i.keys[0])
|
|
}
|