summaryrefslogtreecommitdiffstatshomepage
path: root/py/objtuple.c
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2014-01-14 15:13:40 -0800
committerDamien George <damien.p.george@gmail.com>2014-01-14 15:13:40 -0800
commit6c2401e935b38ca87fd8f52efbb614a428b6938c (patch)
tree9314200eddfd45d99491cb29f47533404ef030f5 /py/objtuple.c
parent8bc96471f0219b9d3f24ae879f60b509927e1df4 (diff)
parent93451002f04e0b89e41e1faa82f86e937bb219f1 (diff)
downloadmicropython-6c2401e935b38ca87fd8f52efbb614a428b6938c.tar.gz
micropython-6c2401e935b38ca87fd8f52efbb614a428b6938c.zip
Merge pull request #165 from chipaca/builtins
added zip()
Diffstat (limited to 'py/objtuple.c')
-rw-r--r--py/objtuple.c20
1 files changed, 16 insertions, 4 deletions
diff --git a/py/objtuple.c b/py/objtuple.c
index 9821dd2fbb..15e74636f8 100644
--- a/py/objtuple.c
+++ b/py/objtuple.c
@@ -111,8 +111,10 @@ mp_obj_t mp_obj_new_tuple(uint n, const mp_obj_t *items) {
mp_obj_tuple_t *o = m_new_obj_var(mp_obj_tuple_t, mp_obj_t, n);
o->base.type = &tuple_type;
o->len = n;
- for (int i = 0; i < n; i++) {
- o->items[i] = items[i];
+ if (items) {
+ for (int i = 0; i < n; i++) {
+ o->items[i] = items[i];
+ }
}
return o;
}
@@ -133,8 +135,18 @@ mp_obj_t mp_obj_new_tuple_reverse(uint n, const mp_obj_t *items) {
void mp_obj_tuple_get(mp_obj_t self_in, uint *len, mp_obj_t **items) {
assert(MP_OBJ_IS_TYPE(self_in, &tuple_type));
mp_obj_tuple_t *self = self_in;
- *len = self->len;
- *items = &self->items[0];
+ if (len) {
+ *len = self->len;
+ }
+ if (items) {
+ *items = &self->items[0];
+ }
+}
+
+void mp_obj_tuple_del(mp_obj_t self_in) {
+ assert(MP_OBJ_IS_TYPE(self_in, &tuple_type));
+ mp_obj_tuple_t *self = self_in;
+ m_del_var(mp_obj_tuple_t, mp_obj_t, self->len, self);
}
/******************************************************************************/