diff options
| author | Damien George | 2014-04-14 23:44:20 +0100 |
|---|---|---|
| committer | Damien George | 2014-04-14 23:44:20 +0100 |
| commit | e10da77a5c4711287319b762c3238121ac10f48e (patch) | |
| tree | ed3e62de403a95d1c58a55fb5bcbc8eb7f7e837c /py/objtype.c | |
| parent | 8341725b6513d01045787bdb51952cceb35c29da (diff) | |
| parent | a5854d2bc5717cb5b6f589f367acaa6d0c8b0179 (diff) | |
Merge branch 'master' of github.com:micropython/micropython
Diffstat (limited to 'py/objtype.c')
| -rw-r--r-- | py/objtype.c | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/py/objtype.c b/py/objtype.c index c1749ff5f..198f76746 100644 --- a/py/objtype.c +++ b/py/objtype.c @@ -309,16 +309,20 @@ STATIC bool class_store_attr(mp_obj_t self_in, qstr attr, mp_obj_t value) { } bool class_store_item(mp_obj_t self_in, mp_obj_t index, mp_obj_t value) { + mp_obj_class_t *self = self_in; + mp_obj_t member; + uint meth_args; if (value == MP_OBJ_NULL) { // delete item - // TODO implement me! - return false; + member = mp_obj_class_lookup(self->base.type, MP_QSTR___delitem__); + meth_args = 2; + } else { + member = mp_obj_class_lookup(self->base.type, MP_QSTR___setitem__); + meth_args = 3; } - mp_obj_class_t *self = self_in; - mp_obj_t member = mp_obj_class_lookup(self->base.type, MP_QSTR___setitem__); if (member != MP_OBJ_NULL) { mp_obj_t args[3] = {self_in, index, value}; - mp_call_function_n_kw(member, 3, 0, args); + mp_call_function_n_kw(member, meth_args, 0, args); return true; } else { return false; |
