Unverified Commit 59e04d80 authored by Joshua Haberman's avatar Joshua Haberman Committed by GitHub

Merge pull request #4321 from devwout/ruby_json_omit_repeated

Ruby JSON encoding omits zero-length repeated fields by default.
parents 0ea3d74c 7b8f5717
...@@ -963,13 +963,15 @@ static void putary(VALUE ary, const upb_fielddef *f, upb_sink *sink, ...@@ -963,13 +963,15 @@ static void putary(VALUE ary, const upb_fielddef *f, upb_sink *sink,
if (ary == Qnil) return; if (ary == Qnil) return;
size = NUM2INT(RepeatedField_length(ary));
if (size == 0 && !emit_defaults) return;
upb_sink_startseq(sink, getsel(f, UPB_HANDLER_STARTSEQ), &subsink); upb_sink_startseq(sink, getsel(f, UPB_HANDLER_STARTSEQ), &subsink);
if (upb_fielddef_isprimitive(f)) { if (upb_fielddef_isprimitive(f)) {
sel = getsel(f, upb_handlers_getprimitivehandlertype(f)); sel = getsel(f, upb_handlers_getprimitivehandlertype(f));
} }
size = NUM2INT(RepeatedField_length(ary));
for (int i = 0; i < size; i++) { for (int i = 0; i < size; i++) {
void* memory = RepeatedField_index_native(ary, i); void* memory = RepeatedField_index_native(ary, i);
switch (type) { switch (type) {
......
...@@ -1273,6 +1273,10 @@ module BasicTest ...@@ -1273,6 +1273,10 @@ module BasicTest
Foo.encode_json(Foo.new(bar: bar, baz: [baz1, baz2])) Foo.encode_json(Foo.new(bar: bar, baz: [baz1, baz2]))
end end
def test_json_empty
assert TestMessage.encode_json(TestMessage.new) == '{}'
end
def test_json_emit_defaults def test_json_emit_defaults
# TODO: Fix JSON in JRuby version. # TODO: Fix JSON in JRuby version.
return if RUBY_PLATFORM == "java" return if RUBY_PLATFORM == "java"
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment