diff options
author | Damien George <damien.p.george@gmail.com> | 2014-01-09 20:57:50 +0000 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2014-01-09 20:57:50 +0000 |
commit | 062478e66d03cc59ed73484a3032ef5f08db12a4 (patch) | |
tree | 6d3beb59ade6fe3d1ab7a5f05ff876e63062717f /py/objmodule.c | |
parent | d944a66ead38b15b5a3c7a4ae8b054451fd5c077 (diff) | |
download | micropython-062478e66d03cc59ed73484a3032ef5f08db12a4.tar.gz micropython-062478e66d03cc59ed73484a3032ef5f08db12a4.zip |
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.
Diffstat (limited to 'py/objmodule.c')
-rw-r--r-- | py/objmodule.c | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/py/objmodule.c b/py/objmodule.c index a5183b51e3..ade9369176 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, "<module '%s' from '-unknown-file-'>", 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) { |