- if (!strcmp(ec_strvec_val(vec, 0), "*"))
- eval = NULL; //XXX
- else
+ if (!strcmp(ec_strvec_val(vec, 0), "*")) {
+ out = ec_node_many(EC_NO_ID,
+ ec_node_clone(in), 0, 0);
+ if (out == NULL)
+ return -EINVAL;
+ ec_node_free(in);
+ *result = out;
+ } else {
/* get parsed string vector, it should contain only one str */
vec = ec_parsed_strvec(operator);
if (ec_strvec_len(vec) != 1)
/* get parsed string vector, it should contain only one str */
vec = ec_parsed_strvec(operator);
if (ec_strvec_len(vec) != 1)
- "command [option] (subset1, subset2, subset3) x|y",
+ "command [option] (subset1, subset2, subset3) x|y z*",
ec_node_int("x", 0, 10, 10),
ec_node_int("y", 20, 30, 10)
);
ec_node_int("x", 0, 10, 10),
ec_node_int("y", 20, 30, 10)
);
ret |= EC_TEST_CHECK_PARSE(node, 2, "command", "1");
ret |= EC_TEST_CHECK_PARSE(node, 2, "command", "23");
ret |= EC_TEST_CHECK_PARSE(node, 3, "command", "option", "23");
ret |= EC_TEST_CHECK_PARSE(node, 2, "command", "1");
ret |= EC_TEST_CHECK_PARSE(node, 2, "command", "23");
ret |= EC_TEST_CHECK_PARSE(node, 3, "command", "option", "23");
ret |= EC_TEST_CHECK_PARSE(node, -1, "command", "15");
ret |= EC_TEST_CHECK_PARSE(node, -1, "foo");
ec_node_free(node);
ret |= EC_TEST_CHECK_PARSE(node, -1, "command", "15");
ret |= EC_TEST_CHECK_PARSE(node, -1, "foo");
ec_node_free(node);