py: Change [u]int to mp_[u]int_t in qstr.[ch], and some other places.

This should pretty much resolve issue #50.
This commit is contained in:
Damien George 2014-10-03 19:52:22 +01:00
parent 3eaa0c3833
commit 39dc145478
12 changed files with 44 additions and 69 deletions

View File

@ -42,7 +42,7 @@ typedef struct _mp_code_state {
mp_obj_t *sp; mp_obj_t *sp;
// bit 0 is saved currently_in_except_block value // bit 0 is saved currently_in_except_block value
mp_exc_stack_t *exc_sp; mp_exc_stack_t *exc_sp;
uint n_state; mp_uint_t n_state;
// Variable-length // Variable-length
mp_obj_t state[0]; mp_obj_t state[0];
// Variable-length, never accessed by name, only as (void*)(state + n_state) // Variable-length, never accessed by name, only as (void*)(state + n_state)

View File

@ -1459,7 +1459,7 @@ STATIC void do_import_name(compiler_t *comp, mp_parse_node_t pn, qstr *q_base) {
if (i > 0) { if (i > 0) {
*str_dest++ = '.'; *str_dest++ = '.';
} }
uint str_src_len; mp_uint_t str_src_len;
const byte *str_src = qstr_data(MP_PARSE_NODE_LEAF_ARG(pns->nodes[i]), &str_src_len); const byte *str_src = qstr_data(MP_PARSE_NODE_LEAF_ARG(pns->nodes[i]), &str_src_len);
memcpy(str_dest, str_src, str_src_len); memcpy(str_dest, str_src, str_src_len);
str_dest += str_src_len; str_dest += str_src_len;
@ -2563,7 +2563,7 @@ void compile_atom_string(compiler_t *comp, mp_parse_node_struct_t *pns) {
byte *s_dest = qstr_build_start(n_bytes, &q_ptr); byte *s_dest = qstr_build_start(n_bytes, &q_ptr);
for (int i = 0; i < n; i++) { for (int i = 0; i < n; i++) {
if (MP_PARSE_NODE_IS_LEAF(pns->nodes[i])) { if (MP_PARSE_NODE_IS_LEAF(pns->nodes[i])) {
uint s_len; mp_uint_t s_len;
const byte *s = qstr_data(MP_PARSE_NODE_LEAF_ARG(pns->nodes[i]), &s_len); const byte *s = qstr_data(MP_PARSE_NODE_LEAF_ARG(pns->nodes[i]), &s_len);
memcpy(s_dest, s, s_len); memcpy(s_dest, s, s_len);
s_dest += s_len; s_dest += s_len;

View File

@ -1075,7 +1075,7 @@ STATIC void emit_native_import_star(emit_t *emit) {
STATIC void emit_native_load_const_tok(emit_t *emit, mp_token_kind_t tok) { STATIC void emit_native_load_const_tok(emit_t *emit, mp_token_kind_t tok) {
DEBUG_printf("load_const_tok(tok=%u)\n", tok); DEBUG_printf("load_const_tok(tok=%u)\n", tok);
emit_native_pre(emit); emit_native_pre(emit);
int vtype; vtype_kind_t vtype;
mp_uint_t val; mp_uint_t val;
if (emit->do_viper_types) { if (emit->do_viper_types) {
switch (tok) { switch (tok) {

View File

@ -55,7 +55,7 @@ mp_obj_t bound_meth_call(mp_obj_t self_in, mp_uint_t n_args, mp_uint_t n_kw, con
// need to insert self->self before all other args and then call self->meth // need to insert self->self before all other args and then call self->meth
int n_total = n_args + 2 * n_kw; mp_uint_t n_total = n_args + 2 * n_kw;
if (n_total <= 4) { if (n_total <= 4) {
// use stack to allocate temporary args array // use stack to allocate temporary args array
mp_obj_t args2[5]; mp_obj_t args2[5];

View File

@ -46,7 +46,7 @@ mp_obj_t closure_call(mp_obj_t self_in, mp_uint_t n_args, mp_uint_t n_kw, const
// need to concatenate closed-over-vars and args // need to concatenate closed-over-vars and args
int n_total = self->n_closed + n_args + 2 * n_kw; mp_uint_t n_total = self->n_closed + n_args + 2 * n_kw;
if (n_total <= 5) { if (n_total <= 5) {
// use stack to allocate temporary args array // use stack to allocate temporary args array
mp_obj_t args2[5]; mp_obj_t args2[5];
@ -68,7 +68,7 @@ mp_obj_t closure_call(mp_obj_t self_in, mp_uint_t n_args, mp_uint_t n_kw, const
STATIC void closure_print(void (*print)(void *env, const char *fmt, ...), void *env, mp_obj_t o_in, mp_print_kind_t kind) { STATIC void closure_print(void (*print)(void *env, const char *fmt, ...), void *env, mp_obj_t o_in, mp_print_kind_t kind) {
mp_obj_closure_t *o = o_in; mp_obj_closure_t *o = o_in;
print(env, "<closure %s at %p, n_closed=%u ", mp_obj_fun_get_name(o->fun), o, o->n_closed); print(env, "<closure %s at %p, n_closed=%u ", mp_obj_fun_get_name(o->fun), o, o->n_closed);
for (int i = 0; i < o->n_closed; i++) { for (mp_uint_t i = 0; i < o->n_closed; i++) {
if (o->closed[i] == MP_OBJ_NULL) { if (o->closed[i] == MP_OBJ_NULL) {
print(env, "(nil)"); print(env, "(nil)");
} else { } else {

View File

@ -116,29 +116,6 @@ const mp_obj_type_t mp_type_fun_builtin = {
.binary_op = mp_obj_fun_binary_op, .binary_op = mp_obj_fun_binary_op,
}; };
#if 0 // currently unused, and semi-obsolete
mp_obj_t mp_make_function_var(int n_args_min, mp_fun_var_t fun) {
mp_obj_fun_builtin_t *o = m_new_obj(mp_obj_fun_builtin_t);
o->base.type = &mp_type_fun_native;
o->is_kw = false;
o->n_args_min = n_args_min;
o->n_args_max = MP_OBJ_FUN_ARGS_MAX;
o->fun = fun;
return o;
}
// min and max are inclusive
mp_obj_t mp_make_function_var_between(int n_args_min, int n_args_max, mp_fun_var_t fun) {
mp_obj_fun_builtin_t *o = m_new_obj(mp_obj_fun_builtin_t);
o->base.type = &mp_type_fun_native;
o->is_kw = false;
o->n_args_min = n_args_min;
o->n_args_max = n_args_max;
o->fun = fun;
return o;
}
#endif
/******************************************************************************/ /******************************************************************************/
/* byte code functions */ /* byte code functions */
@ -161,9 +138,9 @@ STATIC void fun_bc_print(void (*print)(void *env, const char *fmt, ...), void *e
#endif #endif
#if DEBUG_PRINT #if DEBUG_PRINT
STATIC void dump_args(const mp_obj_t *a, int sz) { STATIC void dump_args(const mp_obj_t *a, mp_uint_t sz) {
DEBUG_printf("%p: ", a); DEBUG_printf("%p: ", a);
for (int i = 0; i < sz; i++) { for (mp_uint_t i = 0; i < sz; i++) {
DEBUG_printf("%p ", a[i]); DEBUG_printf("%p ", a[i]);
} }
DEBUG_printf("\n"); DEBUG_printf("\n");

View File

@ -213,7 +213,7 @@ STATIC mp_obj_t bytes_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_k
return mp_obj_str_builder_end(o); return mp_obj_str_builder_end(o);
} }
int len; mp_int_t len;
byte *data; byte *data;
vstr_t *vstr = NULL; vstr_t *vstr = NULL;
mp_obj_t o = NULL; mp_obj_t o = NULL;
@ -293,7 +293,7 @@ mp_obj_t mp_obj_str_binary_op(mp_uint_t op, mp_obj_t lhs_in, mp_obj_t rhs_in) {
// add 2 strings or bytes // add 2 strings or bytes
GET_STR_DATA_LEN(rhs_in, rhs_data, rhs_len); GET_STR_DATA_LEN(rhs_in, rhs_data, rhs_len);
int alloc_len = lhs_len + rhs_len; mp_uint_t alloc_len = lhs_len + rhs_len;
/* code for making qstr /* code for making qstr
byte *q_ptr; byte *q_ptr;
@ -440,8 +440,8 @@ STATIC mp_obj_t str_join(mp_obj_t self_in, mp_obj_t arg) {
} }
// count required length // count required length
int required_len = 0; mp_uint_t required_len = 0;
for (int i = 0; i < seq_len; i++) { for (mp_uint_t i = 0; i < seq_len; i++) {
if (mp_obj_get_type(seq_items[i]) != self_type) { if (mp_obj_get_type(seq_items[i]) != self_type) {
nlr_raise(mp_obj_new_exception_msg(&mp_type_TypeError, nlr_raise(mp_obj_new_exception_msg(&mp_type_TypeError,
"join expects a list of str/bytes objects consistent with self object")); "join expects a list of str/bytes objects consistent with self object"));
@ -456,7 +456,7 @@ STATIC mp_obj_t str_join(mp_obj_t self_in, mp_obj_t arg) {
// make joined string // make joined string
byte *data; byte *data;
mp_obj_t joined_str = mp_obj_str_builder_start(self_type, required_len, &data); mp_obj_t joined_str = mp_obj_str_builder_start(self_type, required_len, &data);
for (int i = 0; i < seq_len; i++) { for (mp_uint_t i = 0; i < seq_len; i++) {
if (i > 0) { if (i > 0) {
memcpy(data, sep_str, sep_len); memcpy(data, sep_str, sep_len);
data += sep_len; data += sep_len;
@ -562,7 +562,7 @@ STATIC mp_obj_t str_rsplit(mp_uint_t n_args, const mp_obj_t *args) {
// Preallocate list to the max expected # of elements, as we // Preallocate list to the max expected # of elements, as we
// will fill it from the end. // will fill it from the end.
mp_obj_list_t *res = mp_obj_new_list(splits + 1, NULL); mp_obj_list_t *res = mp_obj_new_list(splits + 1, NULL);
int idx = splits; mp_int_t idx = splits;
if (sep == mp_const_none) { if (sep == mp_const_none) {
assert(!"TODO: rsplit(None,n) not implemented"); assert(!"TODO: rsplit(None,n) not implemented");
@ -598,7 +598,7 @@ STATIC mp_obj_t str_rsplit(mp_uint_t n_args, const mp_obj_t *args) {
} }
if (idx != 0) { if (idx != 0) {
// We split less parts than split limit, now go cleanup surplus // We split less parts than split limit, now go cleanup surplus
int used = org_splits + 1 - idx; mp_int_t used = org_splits + 1 - idx;
memmove(res->items, &res->items[idx], used * sizeof(mp_obj_t)); memmove(res->items, &res->items[idx], used * sizeof(mp_obj_t));
mp_seq_clear(res->items, used, res->alloc, sizeof(*res->items)); mp_seq_clear(res->items, used, res->alloc, sizeof(*res->items));
res->len = used; res->len = used;
@ -1554,7 +1554,7 @@ STATIC mp_obj_t str_caseconv(unichar (*op)(unichar), mp_obj_t self_in) {
GET_STR_DATA_LEN(self_in, self_data, self_len); GET_STR_DATA_LEN(self_in, self_data, self_len);
byte *data; byte *data;
mp_obj_t s = mp_obj_str_builder_start(mp_obj_get_type(self_in), self_len, &data); mp_obj_t s = mp_obj_str_builder_start(mp_obj_get_type(self_in), self_len, &data);
for (int i = 0; i < self_len; i++) { for (mp_uint_t i = 0; i < self_len; i++) {
*data++ = op(*self_data++); *data++ = op(*self_data++);
} }
*data = 0; *data = 0;
@ -1577,7 +1577,7 @@ STATIC mp_obj_t str_uni_istype(bool (*f)(unichar), mp_obj_t self_in) {
} }
if (f != unichar_isupper && f != unichar_islower) { if (f != unichar_isupper && f != unichar_islower) {
for (int i = 0; i < self_len; i++) { for (mp_uint_t i = 0; i < self_len; i++) {
if (!f(*self_data++)) { if (!f(*self_data++)) {
return mp_const_false; return mp_const_false;
} }
@ -1585,7 +1585,7 @@ STATIC mp_obj_t str_uni_istype(bool (*f)(unichar), mp_obj_t self_in) {
} else { } else {
bool contains_alpha = false; bool contains_alpha = false;
for (int i = 0; i < self_len; i++) { // only check alphanumeric characters for (mp_uint_t i = 0; i < self_len; i++) { // only check alphanumeric characters
if (unichar_isalpha(*self_data++)) { if (unichar_isalpha(*self_data++)) {
contains_alpha = true; contains_alpha = true;
if (!f(*(self_data - 1))) { // -1 because we already incremented above if (!f(*(self_data - 1))) { // -1 because we already incremented above

View File

@ -36,17 +36,17 @@ typedef struct _mp_obj_str_t {
// use this macro to extract the string hash // use this macro to extract the string hash
#define GET_STR_HASH(str_obj_in, str_hash) \ #define GET_STR_HASH(str_obj_in, str_hash) \
uint str_hash; if (MP_OBJ_IS_QSTR(str_obj_in)) \ mp_uint_t str_hash; if (MP_OBJ_IS_QSTR(str_obj_in)) \
{ str_hash = qstr_hash(MP_OBJ_QSTR_VALUE(str_obj_in)); } else { str_hash = ((mp_obj_str_t*)str_obj_in)->hash; } { str_hash = qstr_hash(MP_OBJ_QSTR_VALUE(str_obj_in)); } else { str_hash = ((mp_obj_str_t*)str_obj_in)->hash; }
// use this macro to extract the string length // use this macro to extract the string length
#define GET_STR_LEN(str_obj_in, str_len) \ #define GET_STR_LEN(str_obj_in, str_len) \
uint str_len; if (MP_OBJ_IS_QSTR(str_obj_in)) \ mp_uint_t str_len; if (MP_OBJ_IS_QSTR(str_obj_in)) \
{ str_len = qstr_len(MP_OBJ_QSTR_VALUE(str_obj_in)); } else { str_len = ((mp_obj_str_t*)str_obj_in)->len; } { str_len = qstr_len(MP_OBJ_QSTR_VALUE(str_obj_in)); } else { str_len = ((mp_obj_str_t*)str_obj_in)->len; }
// use this macro to extract the string data and length // use this macro to extract the string data and length
#define GET_STR_DATA_LEN(str_obj_in, str_data, str_len) \ #define GET_STR_DATA_LEN(str_obj_in, str_data, str_len) \
const byte *str_data; uint str_len; if (MP_OBJ_IS_QSTR(str_obj_in)) \ const byte *str_data; mp_uint_t str_len; if (MP_OBJ_IS_QSTR(str_obj_in)) \
{ str_data = qstr_data(MP_OBJ_QSTR_VALUE(str_obj_in), &str_len); } \ { str_data = qstr_data(MP_OBJ_QSTR_VALUE(str_obj_in), &str_len); } \
else { str_len = ((mp_obj_str_t*)str_obj_in)->len; str_data = ((mp_obj_str_t*)str_obj_in)->data; } else { str_len = ((mp_obj_str_t*)str_obj_in)->len; str_data = ((mp_obj_str_t*)str_obj_in)->data; }

View File

@ -55,7 +55,7 @@
#define Q_GET_DATA(q) ((q) + 4) #define Q_GET_DATA(q) ((q) + 4)
// this must match the equivalent function in makeqstrdata.py // this must match the equivalent function in makeqstrdata.py
mp_uint_t qstr_compute_hash(const byte *data, uint len) { mp_uint_t qstr_compute_hash(const byte *data, mp_uint_t len) {
// djb2 algorithm; see http://www.cse.yorku.ca/~oz/hash.html // djb2 algorithm; see http://www.cse.yorku.ca/~oz/hash.html
mp_uint_t hash = 5381; mp_uint_t hash = 5381;
for (const byte *top = data + len; data < top; data++) { for (const byte *top = data + len; data < top; data++) {
@ -71,9 +71,9 @@ mp_uint_t qstr_compute_hash(const byte *data, uint len) {
typedef struct _qstr_pool_t { typedef struct _qstr_pool_t {
struct _qstr_pool_t *prev; struct _qstr_pool_t *prev;
uint total_prev_len; mp_uint_t total_prev_len;
uint alloc; mp_uint_t alloc;
uint len; mp_uint_t len;
const byte *qstrs[]; const byte *qstrs[];
} qstr_pool_t; } qstr_pool_t;
@ -130,7 +130,7 @@ STATIC qstr qstr_add(const byte *q_ptr) {
return last_pool->total_prev_len + last_pool->len - 1; return last_pool->total_prev_len + last_pool->len - 1;
} }
qstr qstr_find_strn(const char *str, uint str_len) { qstr qstr_find_strn(const char *str, mp_uint_t str_len) {
// work out hash of str // work out hash of str
mp_uint_t str_hash = qstr_compute_hash((const byte*)str, str_len); mp_uint_t str_hash = qstr_compute_hash((const byte*)str, str_len);
@ -151,7 +151,7 @@ qstr qstr_from_str(const char *str) {
return qstr_from_strn(str, strlen(str)); return qstr_from_strn(str, strlen(str));
} }
qstr qstr_from_strn(const char *str, uint len) { qstr qstr_from_strn(const char *str, mp_uint_t len) {
qstr q = qstr_find_strn(str, len); qstr q = qstr_find_strn(str, len);
if (q == 0) { if (q == 0) {
mp_uint_t hash = qstr_compute_hash((const byte*)str, len); mp_uint_t hash = qstr_compute_hash((const byte*)str, len);
@ -167,7 +167,7 @@ qstr qstr_from_strn(const char *str, uint len) {
return q; return q;
} }
byte *qstr_build_start(uint len, byte **q_ptr) { byte *qstr_build_start(mp_uint_t len, byte **q_ptr) {
assert(len <= 65535); assert(len <= 65535);
*q_ptr = m_new(byte, 4 + len + 1); *q_ptr = m_new(byte, 4 + len + 1);
(*q_ptr)[2] = len; (*q_ptr)[2] = len;
@ -194,7 +194,7 @@ mp_uint_t qstr_hash(qstr q) {
return Q_GET_HASH(find_qstr(q)); return Q_GET_HASH(find_qstr(q));
} }
uint qstr_len(qstr q) { mp_uint_t qstr_len(qstr q) {
const byte *qd = find_qstr(q); const byte *qd = find_qstr(q);
return Q_GET_LENGTH(qd); return Q_GET_LENGTH(qd);
} }
@ -205,13 +205,13 @@ const char *qstr_str(qstr q) {
return (const char*)Q_GET_DATA(qd); return (const char*)Q_GET_DATA(qd);
} }
const byte *qstr_data(qstr q, uint *len) { const byte *qstr_data(qstr q, mp_uint_t *len) {
const byte *qd = find_qstr(q); const byte *qd = find_qstr(q);
*len = Q_GET_LENGTH(qd); *len = Q_GET_LENGTH(qd);
return Q_GET_DATA(qd); return Q_GET_DATA(qd);
} }
void qstr_pool_info(uint *n_pool, uint *n_qstr, uint *n_str_data_bytes, uint *n_total_bytes) { void qstr_pool_info(mp_uint_t *n_pool, mp_uint_t *n_qstr, mp_uint_t *n_str_data_bytes, mp_uint_t *n_total_bytes) {
*n_pool = 0; *n_pool = 0;
*n_qstr = 0; *n_qstr = 0;
*n_str_data_bytes = 0; *n_str_data_bytes = 0;

View File

@ -45,20 +45,18 @@ typedef mp_uint_t qstr;
void qstr_init(void); void qstr_init(void);
mp_uint_t qstr_compute_hash(const byte *data, uint len); mp_uint_t qstr_compute_hash(const byte *data, mp_uint_t len);
qstr qstr_find_strn(const char *str, uint str_len); // returns MP_QSTR_NULL if not found qstr qstr_find_strn(const char *str, mp_uint_t str_len); // returns MP_QSTR_NULL if not found
qstr qstr_from_str(const char *str); qstr qstr_from_str(const char *str);
qstr qstr_from_strn(const char *str, uint len); qstr qstr_from_strn(const char *str, mp_uint_t len);
//qstr qstr_from_str_static(const char *str);
//qstr qstr_from_strn_copy(const char *str, int len);
byte* qstr_build_start(uint len, byte **q_ptr); byte* qstr_build_start(mp_uint_t len, byte **q_ptr);
qstr qstr_build_end(byte *q_ptr); qstr qstr_build_end(byte *q_ptr);
mp_uint_t qstr_hash(qstr q); mp_uint_t qstr_hash(qstr q);
const char* qstr_str(qstr q); const char* qstr_str(qstr q);
uint qstr_len(qstr q); mp_uint_t qstr_len(qstr q);
const byte* qstr_data(qstr q, uint *len); const byte* qstr_data(qstr q, mp_uint_t *len);
void qstr_pool_info(uint *n_pool, uint *n_qstr, uint *n_str_data_bytes, uint *n_total_bytes); void qstr_pool_info(mp_uint_t *n_pool, mp_uint_t *n_qstr, mp_uint_t *n_str_data_bytes, mp_uint_t *n_total_bytes);

View File

@ -109,14 +109,14 @@ void mp_deinit(void) {
mp_obj_t mp_load_const_int(qstr qstr) { mp_obj_t mp_load_const_int(qstr qstr) {
DEBUG_OP_printf("load '%s'\n", qstr_str(qstr)); DEBUG_OP_printf("load '%s'\n", qstr_str(qstr));
uint len; mp_uint_t len;
const byte* data = qstr_data(qstr, &len); const byte* data = qstr_data(qstr, &len);
return mp_parse_num_integer((const char*)data, len, 0); return mp_parse_num_integer((const char*)data, len, 0);
} }
mp_obj_t mp_load_const_dec(qstr qstr) { mp_obj_t mp_load_const_dec(qstr qstr) {
DEBUG_OP_printf("load '%s'\n", qstr_str(qstr)); DEBUG_OP_printf("load '%s'\n", qstr_str(qstr));
uint len; mp_uint_t len;
const byte* data = qstr_data(qstr, &len); const byte* data = qstr_data(qstr, &len);
return mp_parse_num_decimal((const char*)data, len, true, false); return mp_parse_num_decimal((const char*)data, len, true, false);
} }
@ -128,7 +128,7 @@ mp_obj_t mp_load_const_str(qstr qstr) {
mp_obj_t mp_load_const_bytes(qstr qstr) { mp_obj_t mp_load_const_bytes(qstr qstr) {
DEBUG_OP_printf("load b'%s'\n", qstr_str(qstr)); DEBUG_OP_printf("load b'%s'\n", qstr_str(qstr));
uint len; mp_uint_t len;
const byte *data = qstr_data(qstr, &len); const byte *data = qstr_data(qstr, &len);
return mp_obj_new_bytes(data, len); return mp_obj_new_bytes(data, len);
} }

View File

@ -242,9 +242,9 @@ STATIC MP_DEFINE_CONST_FUN_OBJ_0(mem_info_obj, mem_info);
#endif #endif
STATIC mp_obj_t qstr_info(void) { STATIC mp_obj_t qstr_info(void) {
uint n_pool, n_qstr, n_str_data_bytes, n_total_bytes; mp_uint_t n_pool, n_qstr, n_str_data_bytes, n_total_bytes;
qstr_pool_info(&n_pool, &n_qstr, &n_str_data_bytes, &n_total_bytes); qstr_pool_info(&n_pool, &n_qstr, &n_str_data_bytes, &n_total_bytes);
printf("qstr pool: n_pool=%u, n_qstr=%u, n_str_data_bytes=%u, n_total_bytes=%u\n", n_pool, n_qstr, n_str_data_bytes, n_total_bytes); printf("qstr pool: n_pool=" UINT_FMT ", n_qstr=" UINT_FMT ", n_str_data_bytes=" UINT_FMT ", n_total_bytes=" UINT_FMT "\n", n_pool, n_qstr, n_str_data_bytes, n_total_bytes);
return mp_const_none; return mp_const_none;
} }
STATIC MP_DEFINE_CONST_FUN_OBJ_0(qstr_info_obj, qstr_info); STATIC MP_DEFINE_CONST_FUN_OBJ_0(qstr_info_obj, qstr_info);