diff options
| author | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2014-01-23 23:05:47 +0200 | 
|---|---|---|
| committer | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2014-01-23 23:16:18 +0200 | 
| commit | fd31358505dd794feb153c00bec6d4ee92c851d1 (patch) | |
| tree | 9aef5af499cf72b1ae1124ae6fb6d0394d32a0db | |
| parent | 624ed5d563613f592dbb65b52982bbd14822e3f4 (diff) | |
mp_compile(): Properly free module_scope and all nested scopes.
| -rw-r--r-- | py/compile.c | 10 | ||||
| -rw-r--r-- | py/scope.c | 5 | ||||
| -rw-r--r-- | py/scope.h | 1 | 
3 files changed, 14 insertions, 2 deletions
| diff --git a/py/compile.c b/py/compile.c index 0704cc457..7e77832bc 100644 --- a/py/compile.c +++ b/py/compile.c @@ -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      }  } diff --git a/py/scope.c b/py/scope.c index 1d240bb63..1f602ac9c 100644 --- a/py/scope.c +++ b/py/scope.c @@ -60,6 +60,11 @@ scope_t *scope_new(scope_kind_t kind, mp_parse_node_t pn, qstr source_file, uint      return scope;  } +void scope_free(scope_t *scope) { +    m_del(id_info_t, scope->id_info, scope->id_info_alloc); +    m_del(scope_t, scope, 1); +} +  id_info_t *scope_find_or_add_id(scope_t *scope, qstr qstr, bool *added) {      for (int i = 0; i < scope->id_info_len; i++) {          if (scope->id_info[i].qstr == qstr) { diff --git a/py/scope.h b/py/scope.h index 718ce46ec..015a8ba93 100644 --- a/py/scope.h +++ b/py/scope.h @@ -56,6 +56,7 @@ typedef struct _scope_t {  } scope_t;  scope_t *scope_new(scope_kind_t kind, mp_parse_node_t pn, qstr source_file, uint unique_code_id, uint emit_options); +void scope_free(scope_t *scope);  id_info_t *scope_find_or_add_id(scope_t *scope, qstr qstr, bool *added);  id_info_t *scope_find(scope_t *scope, qstr qstr);  id_info_t *scope_find_global(scope_t *scope, qstr qstr); | 
