From d42b845c92d3681a65d490b0a0dff68108f7022c Mon Sep 17 00:00:00 2001 From: Eric Chlebek Date: Tue, 21 Nov 2017 20:31:29 -0800 Subject: [PATCH] Simplify logic. Refs #586 --- types/dynamic/dynamic.go | 19 ++++++------------- 1 file changed, 6 insertions(+), 13 deletions(-) diff --git a/types/dynamic/dynamic.go b/types/dynamic/dynamic.go index bfb1bfa435..fc349f6cb9 100644 --- a/types/dynamic/dynamic.go +++ b/types/dynamic/dynamic.go @@ -203,25 +203,21 @@ func ExtractExtendedAttributes(v interface{}, msg []byte) ([]byte, error) { if err := jsoniter.Unmarshal(msg, &anys); err != nil { return nil, err } - objectStarted := false + stream.WriteObjectStart() + j := 0 for _, any := range sortAnys(anys) { _, ok := fields[any.Name] if ok { // Not a extended attribute continue } - if !objectStarted { - objectStarted = true - stream.WriteObjectStart() - } else { + if j > 0 { stream.WriteMore() } + j++ stream.WriteObjectField(any.Name) any.WriteTo(stream) } - if !objectStarted { - stream.WriteObjectStart() - } stream.WriteObjectEnd() return stream.Buffer(), nil } @@ -263,11 +259,8 @@ func encodeStructFields(v interface{}, s *jsoniter.Stream) error { sort.Slice(fields, func(i, j int) bool { return fields[i].JSONName < fields[j].JSONName }) - objectStarted := false - for _, field := range fields { - if !objectStarted { - objectStarted = true - } else { + for i, field := range fields { + if i > 0 { s.WriteMore() } s.WriteObjectField(field.JSONName)