py: Use mp_arg_check_num in some _make_new functions.

Reduces stmhal code size by about 250 bytes.
This commit is contained in:
Damien George 2015-01-20 14:11:27 +00:00
parent ff8dd3f486
commit 50149a5730
5 changed files with 10 additions and 31 deletions

View File

@ -30,11 +30,11 @@
#include <stdio.h> #include <stdio.h>
#include "py/mpstate.h" #include "py/mpstate.h"
#include "py/nlr.h"
#include "py/objlist.h" #include "py/objlist.h"
#include "py/objstr.h" #include "py/objstr.h"
#include "py/objtuple.h" #include "py/objtuple.h"
#include "py/objtype.h" #include "py/objtype.h"
#include "py/runtime.h"
#include "py/gc.h" #include "py/gc.h"
// Instance of MemoryError exception - needed by mp_malloc_fail // Instance of MemoryError exception - needed by mp_malloc_fail
@ -115,23 +115,17 @@ STATIC void mp_obj_exception_print(void (*print)(void *env, const char *fmt, ...
} }
mp_obj_t mp_obj_exception_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) { mp_obj_t mp_obj_exception_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) {
mp_obj_type_t *type = type_in; mp_arg_check_num(n_args, n_kw, 0, MP_OBJ_FUN_ARGS_MAX, false);
if (n_kw != 0) {
nlr_raise(mp_obj_new_exception_msg_varg(&mp_type_TypeError, "%s does not take keyword arguments", mp_obj_get_type_str(type_in)));
}
mp_obj_exception_t *o = m_new_obj_var_maybe(mp_obj_exception_t, mp_obj_t, 0); mp_obj_exception_t *o = m_new_obj_var_maybe(mp_obj_exception_t, mp_obj_t, 0);
if (o == NULL) { if (o == NULL) {
// Couldn't allocate heap memory; use local data instead. // Couldn't allocate heap memory; use local data instead.
o = &MP_STATE_VM(mp_emergency_exception_obj); o = &MP_STATE_VM(mp_emergency_exception_obj);
// We can't store any args. // We can't store any args.
n_args = 0;
o->args = mp_const_empty_tuple; o->args = mp_const_empty_tuple;
} else { } else {
o->args = mp_obj_new_tuple(n_args, args); o->args = mp_obj_new_tuple(n_args, args);
} }
o->base.type = type; o->base.type = type_in;
o->traceback = MP_OBJ_NULL; o->traceback = MP_OBJ_NULL;
return o; return o;
} }

View File

@ -24,7 +24,6 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
#include "py/nlr.h"
#include "py/runtime.h" #include "py/runtime.h"
typedef struct _mp_obj_filter_t { typedef struct _mp_obj_filter_t {
@ -34,10 +33,7 @@ typedef struct _mp_obj_filter_t {
} mp_obj_filter_t; } mp_obj_filter_t;
STATIC mp_obj_t filter_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) { STATIC mp_obj_t filter_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) {
if (n_args != 2 || n_kw != 0) { mp_arg_check_num(n_args, n_kw, 2, 2, false);
nlr_raise(mp_obj_new_exception_msg(&mp_type_TypeError, "filter expected 2 arguments"));
}
assert(n_args == 2);
mp_obj_filter_t *o = m_new_obj(mp_obj_filter_t); mp_obj_filter_t *o = m_new_obj(mp_obj_filter_t);
o->base.type = type_in; o->base.type = type_in;
o->fun = args[0]; o->fun = args[0];

View File

@ -27,7 +27,6 @@
#include <stdlib.h> #include <stdlib.h>
#include <assert.h> #include <assert.h>
#include "py/nlr.h"
#include "py/runtime.h" #include "py/runtime.h"
typedef struct _mp_obj_map_t { typedef struct _mp_obj_map_t {
@ -38,10 +37,7 @@ typedef struct _mp_obj_map_t {
} mp_obj_map_t; } mp_obj_map_t;
STATIC mp_obj_t map_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) { STATIC mp_obj_t map_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) {
if (n_args < 2 || n_kw != 0) { mp_arg_check_num(n_args, n_kw, 2, MP_OBJ_FUN_ARGS_MAX, false);
nlr_raise(mp_obj_new_exception_msg(&mp_type_TypeError, "map must have at least 2 arguments and no keyword arguments"));
}
assert(n_args >= 2);
mp_obj_map_t *o = m_new_obj_var(mp_obj_map_t, mp_obj_t, n_args - 1); mp_obj_map_t *o = m_new_obj_var(mp_obj_map_t, mp_obj_t, n_args - 1);
o->base.type = type_in; o->base.type = type_in;
o->n_iters = n_args - 1; o->n_iters = n_args - 1;

View File

@ -26,9 +26,7 @@
#include <stdlib.h> #include <stdlib.h>
#include "py/nlr.h" #include "py/runtime.h"
#include "py/obj.h"
#include "py/runtime0.h"
mp_obj_t instance_make_new(mp_obj_t self_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args); mp_obj_t instance_make_new(mp_obj_t self_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args);
@ -38,10 +36,7 @@ typedef struct _mp_obj_object_t {
STATIC mp_obj_t object_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) { STATIC mp_obj_t object_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) {
(void)args; (void)args;
if (n_args != 0 || n_kw != 0) { mp_arg_check_num(n_args, n_kw, 0, 0, false);
nlr_raise(mp_obj_new_exception_msg(&mp_type_TypeError, "object takes no arguments"));
}
mp_obj_object_t *o = m_new_obj(mp_obj_object_t); mp_obj_object_t *o = m_new_obj(mp_obj_object_t);
o->base.type = type_in; o->base.type = type_in;
return o; return o;

View File

@ -855,11 +855,9 @@ STATIC void super_print(void (*print)(void *env, const char *fmt, ...), void *en
STATIC mp_obj_t super_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) { STATIC mp_obj_t super_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) {
(void)type_in; (void)type_in;
if (n_args != 2 || n_kw != 0) {
// 0 arguments are turned into 2 in the compiler // 0 arguments are turned into 2 in the compiler
// 1 argument is not yet implemented // 1 argument is not yet implemented
nlr_raise(mp_obj_new_exception_msg(&mp_type_TypeError, "super() requires 2 arguments")); mp_arg_check_num(n_args, n_kw, 2, 2, false);
}
return mp_obj_new_super(args[0], args[1]); return mp_obj_new_super(args[0], args[1]);
} }