diff --git a/src/converter.js b/src/converter.js index 44d952e61..d0467dcd2 100644 --- a/src/converter.js +++ b/src/converter.js @@ -71,7 +71,7 @@ function genValuePartial_fromObject(gen, field, fieldIndex, prop) { case "bytes": gen ("if(typeof d%s===\"string\")", prop) ("util.base64.decode(d%s,m%s=util.newBuffer(util.base64.length(d%s)),0)", prop, prop, prop) - ("else if(d%s.length)", prop) + ("else if(d%s.length >= 0)", prop) ("m%s=d%s", prop, prop); break; case "string": gen diff --git a/tests/data/convert.js b/tests/data/convert.js index b0658940f..6a031dc71 100644 --- a/tests/data/convert.js +++ b/tests/data/convert.js @@ -421,7 +421,7 @@ $root.Message = (function() { for (var i = 0; i < object.bytesRepeated.length; ++i) if (typeof object.bytesRepeated[i] === "string") $util.base64.decode(object.bytesRepeated[i], message.bytesRepeated[i] = $util.newBuffer($util.base64.length(object.bytesRepeated[i])), 0); - else if (object.bytesRepeated[i].length) + else if (object.bytesRepeated[i].length >= 0) message.bytesRepeated[i] = object.bytesRepeated[i]; } switch (object.enumVal) {