diff options
author | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2014-02-13 00:36:54 +0200 |
---|---|---|
committer | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2014-02-13 00:36:54 +0200 |
commit | 2aa217b97473932e1b49b5332942f4aaf74e7a34 (patch) | |
tree | 3b2ed54aeada6eb24db12d81c5503c57083aaef6 /py/builtinevex.c | |
parent | 780ba22bb8d4451761952a5401cb15935c8eb4fb (diff) | |
download | micropython-2aa217b97473932e1b49b5332942f4aaf74e7a34.tar.gz micropython-2aa217b97473932e1b49b5332942f4aaf74e7a34.zip |
Implement full arg handling for exec().
Diffstat (limited to 'py/builtinevex.c')
-rw-r--r-- | py/builtinevex.c | 24 |
1 files changed, 21 insertions, 3 deletions
diff --git a/py/builtinevex.c b/py/builtinevex.c index af12bea1c4..3e3c9a6109 100644 --- a/py/builtinevex.c +++ b/py/builtinevex.c @@ -57,8 +57,26 @@ STATIC mp_obj_t mp_builtin_eval(mp_obj_t o_in) { MP_DEFINE_CONST_FUN_OBJ_1(mp_builtin_eval_obj, mp_builtin_eval); -STATIC mp_obj_t mp_builtin_exec(mp_obj_t o_in) { - return parse_compile_execute(o_in, MP_PARSE_FILE_INPUT); +STATIC mp_obj_t mp_builtin_exec(uint n_args, const mp_obj_t *args) { + // Unconditional getting/setting assumes that these operations + // are cheap, which is the case when this comment was written. + mp_map_t *old_globals = rt_globals_get(); + mp_map_t *old_locals = rt_locals_get(); + if (n_args > 1) { + mp_obj_t globals = args[1]; + mp_obj_t locals; + if (n_args > 2) { + locals = args[2]; + } else { + locals = globals; + } + rt_globals_set(mp_obj_dict_get_map(globals)); + rt_locals_set(mp_obj_dict_get_map(locals)); + } + mp_obj_t res = parse_compile_execute(args[0], MP_PARSE_FILE_INPUT); + rt_globals_set(old_globals); + rt_locals_set(old_locals); + return res; } -MP_DEFINE_CONST_FUN_OBJ_1(mp_builtin_exec_obj, mp_builtin_exec); +MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mp_builtin_exec_obj, 1, 3, mp_builtin_exec); |