diff options
author | Damien George <damien.p.george@gmail.com> | 2014-05-06 16:38:54 +0000 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2014-05-06 16:38:54 +0000 |
commit | 491cbd6a7cd0a212e28c548789db432b4e64327e (patch) | |
tree | 5e8ff14972d26e05c7ef5f047f6f1c799836fc40 /py/objenumerate.c | |
parent | 33b3a6905d30157efa8393893fd11a5104834354 (diff) |
py: Add keyword arg support to enumerate constructor.
Need to have a policy as to how far we go adding keyword support to
built ins. It's nice to have, and gets better CPython compatibility,
but hurts the micro nature of uPy.
Addresses issue #577.
Diffstat (limited to 'py/objenumerate.c')
-rw-r--r-- | py/objenumerate.c | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/py/objenumerate.c b/py/objenumerate.c index fd428da4e..611b9b52e 100644 --- a/py/objenumerate.c +++ b/py/objenumerate.c @@ -41,14 +41,23 @@ typedef struct _mp_obj_enumerate_t { STATIC mp_obj_t enumerate_iternext(mp_obj_t self_in); -/* TODO: enumerate is one of the ones that can take args or kwargs. - Sticking to args for now */ +STATIC const mp_arg_t enumerate_make_new_args[] = { + { MP_QSTR_iterable, MP_ARG_REQUIRED | MP_ARG_OBJ, {.u_obj = MP_OBJ_NULL} }, + { MP_QSTR_start, MP_ARG_INT, {.u_int = 0} }, +}; +#define ENUMERATE_MAKE_NEW_NUM_ARGS ARRAY_SIZE(enumerate_make_new_args) + STATIC mp_obj_t enumerate_make_new(mp_obj_t type_in, uint n_args, uint n_kw, const mp_obj_t *args) { - assert(n_args > 0); + // parse args + mp_arg_val_t vals[ENUMERATE_MAKE_NEW_NUM_ARGS]; + mp_arg_parse_all_kw_array(n_args, n_kw, args, ENUMERATE_MAKE_NEW_NUM_ARGS, enumerate_make_new_args, vals); + + // create enumerate object mp_obj_enumerate_t *o = m_new_obj(mp_obj_enumerate_t); o->base.type = &mp_type_enumerate; - o->iter = mp_getiter(args[0]); - o->cur = n_args > 1 ? mp_obj_get_int(args[1]) : 0; + o->iter = mp_getiter(vals[0].u_obj); + o->cur = vals[1].u_int; + return o; } |