From eb77eb4ed1cdfed455fc23494d1d014eb6ec66b6 Mon Sep 17 00:00:00 2001 From: Josh Slate Date: Mon, 6 Nov 2023 14:13:40 -0800 Subject: [PATCH] fix: don't throw on empty repeated options --- src/parse.js | 19 ++++++++++++------- tests/comp_options-parse.js | 1 + tests/data/options_test.proto | 1 + 3 files changed, 14 insertions(+), 7 deletions(-) diff --git a/src/parse.js b/src/parse.js index 739f3265e..147dc7e90 100644 --- a/src/parse.js +++ b/src/parse.js @@ -639,13 +639,18 @@ function parse(source, root, options) { value = []; var lastValue; if (skip("[", true)) { - do { - lastValue = readValue(true); - value.push(lastValue); - } while (skip(",", true)); - skip("]"); - if (typeof lastValue !== "undefined") { - setOption(parent, name + "." + token, lastValue); + if (peek() === "]") { + setOption(parent, name, "." + token, []); + next(); + } else { + do { + lastValue = readValue(true); + value.push(lastValue); + } while (skip(",", true)); + skip("]"); + if (typeof lastValue !== "undefined") { + setOption(parent, name + "." + token, lastValue); + } } } } else { diff --git a/tests/comp_options-parse.js b/tests/comp_options-parse.js index ed4a00572..35de46592 100644 --- a/tests/comp_options-parse.js +++ b/tests/comp_options-parse.js @@ -134,6 +134,7 @@ tape.test("Options", function (test) { { "(method_rep_msg)": { value: 1, + empty_repeated: [], nested: {nested: {value: "x"}}, rep_nested: [{value: "y"}, {value: "z"}], rep_value: 3 diff --git a/tests/data/options_test.proto b/tests/data/options_test.proto index 52f022818..ede3334fd 100644 --- a/tests/data/options_test.proto +++ b/tests/data/options_test.proto @@ -119,6 +119,7 @@ service TestOptionsService { rpc TestOptionsRpc(Msg) returns (Msg) { option (method_rep_msg) = { value: 1 + empty_repeated: [] nested { nested { value: "x"