From b68680eecaa20805604f08ae6c5931f292e5c6b3 Mon Sep 17 00:00:00 2001 From: Matthew Nibecker Date: Fri, 24 May 2024 00:19:19 -0700 Subject: [PATCH] JSON pretty: empty containers (#5127) For the JSON writer in pretty mode ensure that empty objects and array are printed on the same line. --- zio/jsonio/writer.go | 12 ++++++++++++ zio/jsonio/ztests/pretty.yaml | 8 +++++++- 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/zio/jsonio/writer.go b/zio/jsonio/writer.go index cc0fb00b9d..27f663b794 100644 --- a/zio/jsonio/writer.go +++ b/zio/jsonio/writer.go @@ -94,6 +94,10 @@ func (w *Writer) writeAny(tab int, val zed.Value) { func (w *Writer) writeRecord(tab int, typ *zed.TypeRecord, bytes zcode.Bytes) { tab += w.tab w.punc('{') + if len(bytes) == 0 { + w.punc('}') + return + } it := bytes.Iter() for i, f := range typ.Fields { if i != 0 { @@ -109,6 +113,10 @@ func (w *Writer) writeRecord(tab int, typ *zed.TypeRecord, bytes zcode.Bytes) { func (w *Writer) writeArray(tab int, typ zed.Type, bytes zcode.Bytes) { tab += w.tab w.punc('[') + if len(bytes) == 0 { + w.punc(']') + return + } it := bytes.Iter() for i := 0; !it.Done(); i++ { if i != 0 { @@ -126,6 +134,10 @@ func (w *Writer) writeArray(tab int, typ zed.Type, bytes zcode.Bytes) { func (w *Writer) writeMap(tab int, typ *zed.TypeMap, bytes zcode.Bytes) { tab += w.tab w.punc('{') + if len(bytes) == 0 { + w.punc('}') + return + } it := bytes.Iter() for i := 0; !it.Done(); i++ { if i != 0 { diff --git a/zio/jsonio/ztests/pretty.yaml b/zio/jsonio/ztests/pretty.yaml index c4a0c727c1..7b9b436677 100644 --- a/zio/jsonio/ztests/pretty.yaml +++ b/zio/jsonio/ztests/pretty.yaml @@ -8,6 +8,9 @@ input: | f4: "a string", f5: [1,2,3], f6: {foo: "bar"}, + f7: {}, + f8: |{}|, + f9: [], } output-flags: -f json -pretty 4 @@ -25,5 +28,8 @@ output: | ], "f6": { "foo": "bar" - } + }, + "f7": {}, + "f8": {}, + "f9": [] }