diff options
author | John R. Lenton <jlenton@gmail.com> | 2014-01-13 23:09:04 +0000 |
---|---|---|
committer | John R. Lenton <jlenton@gmail.com> | 2014-01-13 23:09:04 +0000 |
commit | f5a0a7d2b30d390f03dd0b6f8866ec619d2c5ee3 (patch) | |
tree | ae93f78ed97e4d820150a7b0d8c026f94cfb790e /py/obj.c | |
parent | 189c8e1cc46896382b6d19da8b89a4cc4f7e3864 (diff) | |
parent | ca318bba0d97c66d8fb14a089d8fa269a0e1b424 (diff) | |
download | micropython-f5a0a7d2b30d390f03dd0b6f8866ec619d2c5ee3.tar.gz micropython-f5a0a7d2b30d390f03dd0b6f8866ec619d2c5ee3.zip |
Merge remote-tracking branch 'upstream/master' into containment
Diffstat (limited to 'py/obj.c')
-rw-r--r-- | py/obj.c | 10 |
1 files changed, 8 insertions, 2 deletions
@@ -108,9 +108,15 @@ bool mp_obj_equal(mp_obj_t o1, mp_obj_t o2) { return val == 0; } else if (o2 == mp_const_true) { return val == 1; - } else { - return false; + } else if (MP_OBJ_IS_TYPE(o2, &int_type)) { + // If o2 is long int, dispatch to its virtual methods + mp_obj_base_t *o = o2; + if (o->type->binary_op != NULL) { + mp_obj_t r = o->type->binary_op(RT_COMPARE_OP_EQUAL, o2, o1); + return r == mp_const_true ? true : false; + } } + return false; } } else if (MP_OBJ_IS_QSTR(o1) || MP_OBJ_IS_QSTR(o2)) { return false; |