py: Restore CPython compatibility in compiler for closures with def args.

This commit is contained in:
Damien George 2014-03-26 23:15:35 +00:00
parent d6f9434091
commit bdcbf0fcd1
1 changed files with 5 additions and 3 deletions

View File

@ -766,9 +766,13 @@ void c_assign(compiler_t *comp, mp_parse_node_t pn, assign_kind_t assign_kind) {
// stuff for lambda and comprehensions and generators // stuff for lambda and comprehensions and generators
void close_over_variables_etc(compiler_t *comp, scope_t *this_scope, int n_dict_params, int n_default_params) { void close_over_variables_etc(compiler_t *comp, scope_t *this_scope, int n_dict_params, int n_default_params) {
#if !MICROPY_EMIT_CPYTHON
// in Micro Python we put the default params into a tuple using the bytecode
if (n_default_params) { if (n_default_params) {
EMIT_ARG(build_tuple, n_default_params); EMIT_ARG(build_tuple, n_default_params);
} }
#endif
// make closed over variables, if any // make closed over variables, if any
// ensure they are closed over in the order defined in the outer scope (mainly to agree with CPython) // ensure they are closed over in the order defined in the outer scope (mainly to agree with CPython)
int nfree = 0; int nfree = 0;
@ -791,14 +795,12 @@ void close_over_variables_etc(compiler_t *comp, scope_t *this_scope, int n_dict_
} }
} }
} }
if (nfree > 0) {
EMIT_ARG(build_tuple, nfree);
}
// make the function/closure // make the function/closure
if (nfree == 0) { if (nfree == 0) {
EMIT_ARG(make_function, this_scope, n_dict_params, n_default_params); EMIT_ARG(make_function, this_scope, n_dict_params, n_default_params);
} else { } else {
EMIT_ARG(build_tuple, nfree);
EMIT_ARG(make_closure, this_scope, n_dict_params, n_default_params); EMIT_ARG(make_closure, this_scope, n_dict_params, n_default_params);
} }
} }