aboutsummaryrefslogtreecommitdiff
path: root/py/objtype.c
diff options
context:
space:
mode:
authorDamien George2014-04-14 23:44:20 +0100
committerDamien George2014-04-14 23:44:20 +0100
commite10da77a5c4711287319b762c3238121ac10f48e (patch)
treeed3e62de403a95d1c58a55fb5bcbc8eb7f7e837c /py/objtype.c
parent8341725b6513d01045787bdb51952cceb35c29da (diff)
parenta5854d2bc5717cb5b6f589f367acaa6d0c8b0179 (diff)
Merge branch 'master' of github.com:micropython/micropython
Diffstat (limited to 'py/objtype.c')
-rw-r--r--py/objtype.c14
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;