From 062478e66d03cc59ed73484a3032ef5f08db12a4 Mon Sep 17 00:00:00 2001 From: Damien George Date: Thu, 9 Jan 2014 20:57:50 +0000 Subject: Improved type/class/instance code; mp_obj_type_t now has load_attr, store_attr. Creating of classes (types) and instances is much more like CPython now. You can use "type('name', (), {...})" to create classes. --- py/objmodule.c | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) (limited to 'py/objmodule.c') diff --git a/py/objmodule.c b/py/objmodule.c index a5183b51e..ade936917 100644 --- a/py/objmodule.c +++ b/py/objmodule.c @@ -17,15 +17,32 @@ typedef struct _mp_obj_module_t { mp_map_t *globals; } mp_obj_module_t; -void module_print(void (*print)(void *env, const char *fmt, ...), void *env, mp_obj_t self_in) { +static void module_print(void (*print)(void *env, const char *fmt, ...), void *env, mp_obj_t self_in) { mp_obj_module_t *self = self_in; print(env, "", qstr_str(self->name)); } +static void module_load_attr(mp_obj_t self_in, qstr attr, mp_obj_t *dest) { + mp_obj_module_t *self = self_in; + mp_map_elem_t *elem = mp_map_lookup(self->globals, MP_OBJ_NEW_QSTR(attr), MP_MAP_LOOKUP); + if (elem != NULL) { + dest[1] = elem->value; + } +} + +static bool module_store_attr(mp_obj_t self_in, qstr attr, mp_obj_t value) { + mp_obj_module_t *self = self_in; + // TODO CPython allows STORE_ATTR to a module, but is this the correct implementation? + mp_map_lookup(self->globals, MP_OBJ_NEW_QSTR(attr), MP_MAP_LOOKUP_ADD_IF_NOT_FOUND)->value = value; + return true; +} + const mp_obj_type_t module_type = { { &mp_const_type }, "module", .print = module_print, + .load_attr = module_load_attr, + .store_attr = module_store_attr, }; mp_obj_t mp_obj_new_module(qstr module_name) { -- cgit v1.2.3