diff --git a/py/builtintables.c b/py/builtintables.c index 940647d25f634d817cf77c636475b1ddbd2dfc68..e6461ad80b48575fa145bf69ab6ed2728a207e3c 100644 --- a/py/builtintables.c +++ b/py/builtintables.c @@ -132,7 +132,9 @@ STATIC const mp_map_elem_t mp_builtin_module_table[] = { #if MICROPY_ENABLE_MOD_IO { MP_OBJ_NEW_QSTR(MP_QSTR_io), (mp_obj_t)&mp_module_io }, #endif +#if MICROPY_ENABLE_MOD_COLLECTIONS { MP_OBJ_NEW_QSTR(MP_QSTR__collections), (mp_obj_t)&mp_module_collections }, +#endif #if MICROPY_ENABLE_MOD_STRUCT { MP_OBJ_NEW_QSTR(MP_QSTR_struct), (mp_obj_t)&mp_module_struct }, #endif diff --git a/py/modcollections.c b/py/modcollections.c index 11845a00ce2020630cb136e5ee8d322c2569359a..5278a526fbd29afbc810f52fc03bf9e1901a8d23 100644 --- a/py/modcollections.c +++ b/py/modcollections.c @@ -4,6 +4,8 @@ #include "obj.h" #include "builtin.h" +#if MICROPY_ENABLE_MOD_COLLECTIONS + STATIC const mp_map_elem_t mp_module_collections_globals_table[] = { { MP_OBJ_NEW_QSTR(MP_QSTR___name__), MP_OBJ_NEW_QSTR(MP_QSTR__collections) }, { MP_OBJ_NEW_QSTR(MP_QSTR_namedtuple), (mp_obj_t)&mp_namedtuple_obj }, @@ -25,3 +27,5 @@ const mp_obj_module_t mp_module_collections = { .name = MP_QSTR__collections, .globals = (mp_obj_dict_t*)&mp_module_collections_globals, }; + +#endif // MICROPY_ENABLE_MOD_COLLECTIONS diff --git a/py/mpconfig.h b/py/mpconfig.h index b669128ea0b3ce0c1c7d564ffc8948098cdc01c1..13918e8398141bb9d06146139d7a50dd1035c104 100644 --- a/py/mpconfig.h +++ b/py/mpconfig.h @@ -115,6 +115,11 @@ typedef double mp_float_t; #define MICROPY_ENABLE_FLOAT (0) #endif +// Whether to provide "collections" module +#ifndef MICROPY_ENABLE_MOD_COLLECTIONS +#define MICROPY_ENABLE_MOD_COLLECTIONS (1) +#endif + // Whether to provide "math" module #ifndef MICROPY_ENABLE_MOD_MATH #define MICROPY_ENABLE_MOD_MATH (1) diff --git a/py/objnamedtuple.c b/py/objnamedtuple.c index 10cf40c9ce2502a922b603433fffc130d3fc3b16..42399835891ff389670ee2ddf138cf2a49a30efb 100644 --- a/py/objnamedtuple.c +++ b/py/objnamedtuple.c @@ -7,6 +7,8 @@ #include "obj.h" #include "objtuple.h" +#if MICROPY_ENABLE_MOD_COLLECTIONS + typedef struct _mp_obj_namedtuple_type_t { mp_obj_type_t base; const char *fields; @@ -143,3 +145,5 @@ STATIC mp_obj_t new_namedtuple_type(mp_obj_t name_in, mp_obj_t fields_in) { return mp_obj_new_namedtuple_type(name, fields); } MP_DEFINE_CONST_FUN_OBJ_2(mp_namedtuple_obj, new_namedtuple_type); + +#endif // MICROPY_ENABLE_MOD_COLLECTIONS