modgc: Add new module for GC-related functionality.
This commit is contained in:
parent
912ca7701d
commit
f9e54e0ea5
@ -77,3 +77,4 @@ extern const mp_obj_module_t mp_module_cmath;
|
|||||||
extern const mp_obj_module_t mp_module_micropython;
|
extern const mp_obj_module_t mp_module_micropython;
|
||||||
extern const mp_obj_module_t mp_module_struct;
|
extern const mp_obj_module_t mp_module_struct;
|
||||||
extern const mp_obj_module_t mp_module_sys;
|
extern const mp_obj_module_t mp_module_sys;
|
||||||
|
extern const mp_obj_module_t mp_module_gc;
|
||||||
|
@ -174,6 +174,9 @@ STATIC const mp_map_elem_t mp_builtin_module_table[] = {
|
|||||||
#if MICROPY_ENABLE_MOD_SYS
|
#if MICROPY_ENABLE_MOD_SYS
|
||||||
{ MP_OBJ_NEW_QSTR(MP_QSTR_sys), (mp_obj_t)&mp_module_sys },
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_sys), (mp_obj_t)&mp_module_sys },
|
||||||
#endif
|
#endif
|
||||||
|
#if MICROPY_ENABLE_MOD_GC && MICROPY_ENABLE_GC
|
||||||
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_gc), (mp_obj_t)&mp_module_gc },
|
||||||
|
#endif
|
||||||
|
|
||||||
// extra builtin modules as defined by a port
|
// extra builtin modules as defined by a port
|
||||||
MICROPY_EXTRA_BUILTIN_MODULES
|
MICROPY_EXTRA_BUILTIN_MODULES
|
||||||
|
68
py/modgc.c
Normal file
68
py/modgc.c
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of the Micro Python project, http://micropython.org/
|
||||||
|
*
|
||||||
|
* The MIT License (MIT)
|
||||||
|
*
|
||||||
|
* Copyright (c) 2013, 2014 Damien P. George
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
|
* in the Software without restriction, including without limitation the rights
|
||||||
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in
|
||||||
|
* all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
* THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "misc.h"
|
||||||
|
#include "mpconfig.h"
|
||||||
|
#include "qstr.h"
|
||||||
|
#include "obj.h"
|
||||||
|
#include "builtin.h"
|
||||||
|
#include "runtime.h"
|
||||||
|
#include "objlist.h"
|
||||||
|
#include "objtuple.h"
|
||||||
|
#include "objstr.h"
|
||||||
|
#include "gc.h"
|
||||||
|
|
||||||
|
#if MICROPY_ENABLE_MOD_GC && MICROPY_ENABLE_GC
|
||||||
|
|
||||||
|
STATIC mp_obj_t py_gc_collect(void) {
|
||||||
|
gc_collect();
|
||||||
|
return mp_const_none;
|
||||||
|
}
|
||||||
|
MP_DEFINE_CONST_FUN_OBJ_0(gc_collect_obj, py_gc_collect);
|
||||||
|
|
||||||
|
STATIC const mp_map_elem_t mp_module_gc_globals_table[] = {
|
||||||
|
{ MP_OBJ_NEW_QSTR(MP_QSTR___name__), MP_OBJ_NEW_QSTR(MP_QSTR_gc) },
|
||||||
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_collect), (mp_obj_t)&gc_collect_obj },
|
||||||
|
};
|
||||||
|
|
||||||
|
STATIC const mp_obj_dict_t mp_module_gc_globals = {
|
||||||
|
.base = {&mp_type_dict},
|
||||||
|
.map = {
|
||||||
|
.all_keys_are_qstrs = 1,
|
||||||
|
.table_is_fixed_array = 1,
|
||||||
|
.used = ARRAY_SIZE(mp_module_gc_globals_table),
|
||||||
|
.alloc = ARRAY_SIZE(mp_module_gc_globals_table),
|
||||||
|
.table = (mp_map_elem_t*)mp_module_gc_globals_table,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
const mp_obj_module_t mp_module_gc = {
|
||||||
|
.base = { &mp_type_module },
|
||||||
|
.name = MP_QSTR_gc,
|
||||||
|
.globals = (mp_obj_dict_t*)&mp_module_gc_globals,
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
@ -200,6 +200,11 @@ typedef double mp_float_t;
|
|||||||
#define MICROPY_ENABLE_MOD_CMATH (0)
|
#define MICROPY_ENABLE_MOD_CMATH (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Whether to provide "gc" module
|
||||||
|
#ifndef MICROPY_ENABLE_MOD_GC
|
||||||
|
#define MICROPY_ENABLE_MOD_GC (1)
|
||||||
|
#endif
|
||||||
|
|
||||||
// Whether to provide "io" module
|
// Whether to provide "io" module
|
||||||
#ifndef MICROPY_ENABLE_MOD_IO
|
#ifndef MICROPY_ENABLE_MOD_IO
|
||||||
#define MICROPY_ENABLE_MOD_IO (1)
|
#define MICROPY_ENABLE_MOD_IO (1)
|
||||||
|
1
py/py.mk
1
py/py.mk
@ -88,6 +88,7 @@ PY_O_BASENAME = \
|
|||||||
builtintables.o \
|
builtintables.o \
|
||||||
modarray.o \
|
modarray.o \
|
||||||
modcollections.o \
|
modcollections.o \
|
||||||
|
modgc.o \
|
||||||
modio.o \
|
modio.o \
|
||||||
modmath.o \
|
modmath.o \
|
||||||
modcmath.o \
|
modcmath.o \
|
||||||
|
@ -346,6 +346,11 @@ Q(BytesIO)
|
|||||||
Q(getvalue)
|
Q(getvalue)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if MICROPY_ENABLE_MOD_GC
|
||||||
|
Q(gc)
|
||||||
|
Q(collect)
|
||||||
|
#endif
|
||||||
|
|
||||||
#if MICROPY_ENABLE_PROPERTY
|
#if MICROPY_ENABLE_PROPERTY
|
||||||
Q(property)
|
Q(property)
|
||||||
Q(getter)
|
Q(getter)
|
||||||
|
12
unix/main.c
12
unix/main.c
@ -247,15 +247,6 @@ mp_obj_t qstr_info(void) {
|
|||||||
return mp_const_none;
|
return mp_const_none;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MICROPY_ENABLE_GC
|
|
||||||
// TODO: this doesn't belong here
|
|
||||||
STATIC mp_obj_t pyb_gc(void) {
|
|
||||||
gc_collect();
|
|
||||||
return mp_const_none;
|
|
||||||
}
|
|
||||||
MP_DEFINE_CONST_FUN_OBJ_0(pyb_gc_obj, pyb_gc);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Process options which set interpreter init options
|
// Process options which set interpreter init options
|
||||||
void pre_process_options(int argc, char **argv) {
|
void pre_process_options(int argc, char **argv) {
|
||||||
for (int a = 1; a < argc; a++) {
|
for (int a = 1; a < argc; a++) {
|
||||||
@ -338,9 +329,6 @@ int main(int argc, char **argv) {
|
|||||||
|
|
||||||
mp_store_name(qstr_from_str("mem_info"), mp_make_function_n(0, mem_info));
|
mp_store_name(qstr_from_str("mem_info"), mp_make_function_n(0, mem_info));
|
||||||
mp_store_name(qstr_from_str("qstr_info"), mp_make_function_n(0, qstr_info));
|
mp_store_name(qstr_from_str("qstr_info"), mp_make_function_n(0, qstr_info));
|
||||||
#if MICROPY_ENABLE_GC
|
|
||||||
mp_store_name(qstr_from_str("gc"), (mp_obj_t)&pyb_gc_obj);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Here is some example code to create a class and instance of that class.
|
// Here is some example code to create a class and instance of that class.
|
||||||
// First is the Python, then the C code.
|
// First is the Python, then the C code.
|
||||||
|
Loading…
Reference in New Issue
Block a user