summaryrefslogtreecommitdiff
path: root/py/objdict.c
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2014-01-30 01:29:32 -0800
committerDamien George <damien.p.george@gmail.com>2014-01-30 01:29:32 -0800
commitb25711ea8fdc1588b5a69f7d0941de09b50fa28c (patch)
treedb7cd93c99583a858ef94b3dab95b882832da251 /py/objdict.c
parentcdd2c62e07549e36dba00bc37d7ba7a4cd41ad50 (diff)
parentc1d9bbc3453454aceb28f51e72e4aeb8ef1c12eb (diff)
Merge pull request #238 from pfalcon/bool_len
Implement __bool__ and __len__ via unary_op virtual method for all types.
Diffstat (limited to 'py/objdict.c')
-rw-r--r--py/objdict.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/py/objdict.c b/py/objdict.c
index 93ff1af90..f78a7358b 100644
--- a/py/objdict.c
+++ b/py/objdict.c
@@ -46,7 +46,8 @@ static mp_obj_t dict_make_new(mp_obj_t type_in, uint n_args, uint n_kw, const mp
static mp_obj_t dict_unary_op(int op, mp_obj_t self_in) {
mp_obj_dict_t *self = self_in;
switch (op) {
- case RT_UNARY_OP_NOT: if (self->map.used == 0) { return mp_const_true; } else { return mp_const_false; }
+ case RT_UNARY_OP_BOOL: return MP_BOOL(self->map.used != 0);
+ case RT_UNARY_OP_LEN: return MP_OBJ_NEW_SMALL_INT(self->map.used);
default: return MP_OBJ_NULL; // op not supported for None
}
}