From d3fea6365f910a633c4c9aec15566b4bf830e5e8 Mon Sep 17 00:00:00 2001 From: Tobie Morgan Hitchcock Date: Tue, 5 Feb 2019 18:47:05 +0000 Subject: [PATCH] =?UTF-8?q?Don=E2=80=99t=20reorder=20array=20items=20when?= =?UTF-8?q?=20fetching=20records?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- db/fetch.go | 18 ++++++++++-------- db/yield.go | 10 +++++++++- 2 files changed, 19 insertions(+), 9 deletions(-) diff --git a/db/fetch.go b/db/fetch.go index 351cddb2..2c9417f1 100644 --- a/db/fetch.go +++ b/db/fetch.go @@ -92,15 +92,16 @@ func (e *executor) fetch(ctx context.Context, val interface{}, doc *data.Doc) (o if len(path) > 0 { switch res := val.(type) { case []interface{}: + val := make([]interface{}, len(res)) for k, v := range res { - switch val := v.(type) { + switch tng := v.(type) { case *sql.Thing: - res[k], _ = e.fetchThing(ctx, val, doc) + val[k], _ = e.fetchThing(ctx, tng, doc) default: - res[k] = v + val[k] = v } } - return res + return val case *sql.Thing: val, _ = e.fetchThing(ctx, res, doc) return val @@ -127,15 +128,16 @@ func (e *executor) fetch(ctx context.Context, val interface{}, doc *data.Doc) (o if len(path) > 0 { switch res := val.(type) { case []interface{}: + val := make([]interface{}, len(res)) for k, v := range res { - switch val := v.(type) { + switch tng := v.(type) { case *sql.Thing: - res[k], _ = e.fetchThing(ctx, val, doc) + val[k], _ = e.fetchThing(ctx, tng, doc) default: - res[k] = v + val[k] = v } } - return res + return val case *sql.Thing: val, _ = e.fetchThing(ctx, res, doc) return val diff --git a/db/yield.go b/db/yield.go index c172a2ee..716e7502 100644 --- a/db/yield.go +++ b/db/yield.go @@ -250,7 +250,15 @@ func (d *document) yield(ctx context.Context, stm sql.Statement, output sql.Toke switch res := val.(type) { case []interface{}: - val, _ = d.i.e.fetchArray(ctx, res, doc) + val := make([]interface{}, len(res)) + for k, v := range res { + switch tng := v.(type) { + case *sql.Thing: + val[k], _ = d.i.e.fetchThing(ctx, tng, doc) + default: + val[k] = v + } + } out.Set(val, key) case *sql.Thing: val, _ = d.i.e.fetchThing(ctx, res, doc)