mp_compile(): Properly free module_scope and all nested scopes.

This commit is contained in:
Paul Sokolovsky
2014-01-23 23:05:47 +02:00
parent 624ed5d563
commit fd31358505
3 changed files with 14 additions and 2 deletions

View File

@@ -3156,6 +3156,12 @@ mp_obj_t mp_compile(mp_parse_node_t pn, qstr source_file, bool is_repl) {
bool had_error = comp->had_error;
m_del_obj(compiler_t, comp);
uint unique_code_id = module_scope->unique_code_id;
for (scope_t *s = module_scope; s;) {
scope_t *next = s->next;
scope_free(s);
s = next;
}
if (had_error) {
// TODO return a proper error message
@@ -3163,11 +3169,11 @@ mp_obj_t mp_compile(mp_parse_node_t pn, qstr source_file, bool is_repl) {
} else {
#if MICROPY_EMIT_CPYTHON
// can't create code, so just return true
(void)module_scope; // to suppress warning that module_scope is unused
(void)unique_code_id; // to suppress warning that module_scope is unused
return mp_const_true;
#else
// return function that executes the outer module
return rt_make_function_from_id(module_scope->unique_code_id);
return rt_make_function_from_id(unique_code_id);
#endif
}
}