symbol length make size_t from mrb_int; cancel #993 monaka/pr-cleanup-symbol.c-20130312

parent b75805b1
...@@ -190,10 +190,10 @@ mrb_value mrb_funcall(mrb_state*, mrb_value, const char*, int,...); ...@@ -190,10 +190,10 @@ mrb_value mrb_funcall(mrb_state*, mrb_value, const char*, int,...);
mrb_value mrb_funcall_argv(mrb_state*, mrb_value, mrb_sym, int, mrb_value*); mrb_value mrb_funcall_argv(mrb_state*, mrb_value, mrb_sym, int, mrb_value*);
mrb_value mrb_funcall_with_block(mrb_state*, mrb_value, mrb_sym, int, mrb_value*, mrb_value); mrb_value mrb_funcall_with_block(mrb_state*, mrb_value, mrb_sym, int, mrb_value*, mrb_value);
mrb_sym mrb_intern(mrb_state*,const char*); mrb_sym mrb_intern(mrb_state*,const char*);
mrb_sym mrb_intern2(mrb_state*,const char*,int); mrb_sym mrb_intern2(mrb_state*,const char*,size_t);
mrb_sym mrb_intern_str(mrb_state*,mrb_value); mrb_sym mrb_intern_str(mrb_state*,mrb_value);
const char *mrb_sym2name(mrb_state*,mrb_sym); const char *mrb_sym2name(mrb_state*,mrb_sym);
const char *mrb_sym2name_len(mrb_state*,mrb_sym,int*); const char *mrb_sym2name_len(mrb_state*,mrb_sym,size_t*);
mrb_value mrb_str_format(mrb_state *, int, const mrb_value *, mrb_value); mrb_value mrb_str_format(mrb_state *, int, const mrb_value *, mrb_value);
void *mrb_malloc(mrb_state*, size_t); void *mrb_malloc(mrb_state*, size_t);
......
...@@ -1184,7 +1184,7 @@ mrb_class_path(mrb_state *mrb, struct RClass *c) ...@@ -1184,7 +1184,7 @@ mrb_class_path(mrb_state *mrb, struct RClass *c)
{ {
mrb_value path; mrb_value path;
const char *name; const char *name;
int len; size_t len;
path = mrb_obj_iv_get(mrb, (struct RObject*)c, mrb_intern(mrb, "__classpath__")); path = mrb_obj_iv_get(mrb, (struct RObject*)c, mrb_intern(mrb, "__classpath__"));
if (mrb_nil_p(path)) { if (mrb_nil_p(path)) {
...@@ -1461,7 +1461,7 @@ static void ...@@ -1461,7 +1461,7 @@ static void
check_cv_name(mrb_state *mrb, mrb_sym id) check_cv_name(mrb_state *mrb, mrb_sym id)
{ {
const char *s; const char *s;
int len; size_t len;
s = mrb_sym2name_len(mrb, id, &len); s = mrb_sym2name_len(mrb, id, &len);
if (len < 3 || !(s[0] == '@' && s[1] == '@')) { if (len < 3 || !(s[0] == '@' && s[1] == '@')) {
...@@ -1683,7 +1683,7 @@ static void ...@@ -1683,7 +1683,7 @@ static void
check_const_name(mrb_state *mrb, mrb_sym id) check_const_name(mrb_state *mrb, mrb_sym id)
{ {
const char *s; const char *s;
int len; size_t len;
s = mrb_sym2name_len(mrb, id, &len); s = mrb_sym2name_len(mrb, id, &len);
if (len < 1 || !ISUPPER(*s)) { if (len < 1 || !ISUPPER(*s)) {
......
...@@ -690,7 +690,7 @@ static mrb_sym ...@@ -690,7 +690,7 @@ static mrb_sym
attrsym(codegen_scope *s, mrb_sym a) attrsym(codegen_scope *s, mrb_sym a)
{ {
const char *name; const char *name;
int len; size_t len;
char *name2; char *name2;
name = mrb_sym2name_len(s->mrb, a, &len); name = mrb_sym2name_len(s->mrb, a, &len);
...@@ -789,7 +789,7 @@ gen_call(codegen_scope *s, node *tree, mrb_sym name, int sp, int val) ...@@ -789,7 +789,7 @@ gen_call(codegen_scope *s, node *tree, mrb_sym name, int sp, int val)
} }
pop_n(n+1); pop_n(n+1);
{ {
int len; size_t len;
const char *name = mrb_sym2name_len(s->mrb, sym, &len); const char *name = mrb_sym2name_len(s->mrb, sym, &len);
if (!noop && len == 1 && name[0] == '+') { if (!noop && len == 1 && name[0] == '+') {
...@@ -1491,7 +1491,7 @@ codegen(codegen_scope *s, node *tree, int val) ...@@ -1491,7 +1491,7 @@ codegen(codegen_scope *s, node *tree, int val)
case NODE_OP_ASGN: case NODE_OP_ASGN:
{ {
mrb_sym sym = sym(tree->cdr->car); mrb_sym sym = sym(tree->cdr->car);
int len; size_t len;
const char *name = mrb_sym2name_len(s->mrb, sym, &len); const char *name = mrb_sym2name_len(s->mrb, sym, &len);
int idx; int idx;
......
...@@ -279,7 +279,7 @@ get_syms_block_size(mrb_state *mrb, mrb_irep *irep, int type) ...@@ -279,7 +279,7 @@ get_syms_block_size(mrb_state *mrb, mrb_irep *irep, int type)
size += DUMP_SIZE(MRB_DUMP_SIZE_OF_SHORT, type); /* snl(n) */ size += DUMP_SIZE(MRB_DUMP_SIZE_OF_SHORT, type); /* snl(n) */
if (irep->syms[sym_no] != 0) { if (irep->syms[sym_no] != 0) {
int len; size_t len;
name = mrb_sym2name_len(mrb, irep->syms[sym_no], &len); name = mrb_sym2name_len(mrb, irep->syms[sym_no], &len);
nlen = str_dump_len((char*)name, len, type); nlen = str_dump_len((char*)name, len, type);
...@@ -421,9 +421,10 @@ write_syms_block(mrb_state *mrb, mrb_irep *irep, char *buf, int type) ...@@ -421,9 +421,10 @@ write_syms_block(mrb_state *mrb, mrb_irep *irep, char *buf, int type)
uint16_t nlen =0; uint16_t nlen =0;
if (irep->syms[sym_no] != 0) { if (irep->syms[sym_no] != 0) {
int len; size_t len;
name = mrb_sym2name_len(mrb, irep->syms[sym_no], &len); name = mrb_sym2name_len(mrb, irep->syms[sym_no], &len);
if (len > UINT16_MAX) goto error_exit;
nlen = str_dump_len((char*)name, len, type); nlen = str_dump_len((char*)name, len, type);
if ( nlen > buf_size - 1) { if ( nlen > buf_size - 1) {
buf_size = nlen + 1; buf_size = nlen + 1;
......
...@@ -555,7 +555,7 @@ static void ...@@ -555,7 +555,7 @@ static void
check_iv_name(mrb_state *mrb, mrb_sym id) check_iv_name(mrb_state *mrb, mrb_sym id)
{ {
const char *s; const char *s;
int len; size_t len;
s = mrb_sym2name_len(mrb, id, &len); s = mrb_sym2name_len(mrb, id, &len);
if (len < 2 || !(s[0] == '@' && s[1] != '@')) { if (len < 2 || !(s[0] == '@' && s[1] != '@')) {
......
...@@ -10,10 +10,11 @@ ...@@ -10,10 +10,11 @@
#include "mruby/string.h" #include "mruby/string.h"
#include <ctype.h> #include <ctype.h>
#include <limits.h>
/* ------------------------------------------------------ */ /* ------------------------------------------------------ */
typedef struct symbol_name { typedef struct symbol_name {
mrb_int len; size_t len;
const char *name; const char *name;
} symbol_name; } symbol_name;
...@@ -21,7 +22,7 @@ static inline khint_t ...@@ -21,7 +22,7 @@ static inline khint_t
sym_hash_func(mrb_state *mrb, const symbol_name s) sym_hash_func(mrb_state *mrb, const symbol_name s)
{ {
khint_t h = 0; khint_t h = 0;
mrb_int i; size_t i;
const char *p = s.name; const char *p = s.name;
for (i=0; i<s.len; i++) { for (i=0; i<s.len; i++) {
...@@ -35,7 +36,7 @@ KHASH_DECLARE(n2s, symbol_name, mrb_sym, 1) ...@@ -35,7 +36,7 @@ KHASH_DECLARE(n2s, symbol_name, mrb_sym, 1)
KHASH_DEFINE (n2s, symbol_name, mrb_sym, 1, sym_hash_func, sym_hash_equal) KHASH_DEFINE (n2s, symbol_name, mrb_sym, 1, sym_hash_func, sym_hash_equal)
/* ------------------------------------------------------ */ /* ------------------------------------------------------ */
mrb_sym mrb_sym
mrb_intern2(mrb_state *mrb, const char *name, mrb_int len) mrb_intern2(mrb_state *mrb, const char *name, size_t len)
{ {
khash_t(n2s) *h = mrb->name2sym; khash_t(n2s) *h = mrb->name2sym;
symbol_name sname; symbol_name sname;
...@@ -43,11 +44,7 @@ mrb_intern2(mrb_state *mrb, const char *name, mrb_int len) ...@@ -43,11 +44,7 @@ mrb_intern2(mrb_state *mrb, const char *name, mrb_int len)
mrb_sym sym; mrb_sym sym;
char *p; char *p;
if (len > MRB_INT_MAX - 1) { if (len < 0) len = 0;
/* In case inspect method called, the result is ":" + symname. */
len = MRB_INT_MAX - 1;
}
sname.len = len; sname.len = len;
sname.name = name; sname.name = name;
k = kh_get(n2s, h, sname); k = kh_get(n2s, h, sname);
...@@ -55,8 +52,8 @@ mrb_intern2(mrb_state *mrb, const char *name, mrb_int len) ...@@ -55,8 +52,8 @@ mrb_intern2(mrb_state *mrb, const char *name, mrb_int len)
return kh_value(h, k); return kh_value(h, k);
sym = ++mrb->symidx; sym = ++mrb->symidx;
p = (char *)mrb_malloc(mrb, (size_t)len+1); p = (char *)mrb_malloc(mrb, len+1);
memcpy(p, name, (size_t)len); memcpy(p, name, len);
p[len] = 0; p[len] = 0;
sname.name = (const char*)p; sname.name = (const char*)p;
k = kh_put(n2s, h, sname); k = kh_put(n2s, h, sname);
...@@ -68,14 +65,7 @@ mrb_intern2(mrb_state *mrb, const char *name, mrb_int len) ...@@ -68,14 +65,7 @@ mrb_intern2(mrb_state *mrb, const char *name, mrb_int len)
mrb_sym mrb_sym
mrb_intern(mrb_state *mrb, const char *name) mrb_intern(mrb_state *mrb, const char *name)
{ {
size_t len; return mrb_intern2(mrb, name, strlen(name));
len = strlen(name);
if (len > MRB_INT_MAX) {
len = MRB_INT_MAX;
}
return mrb_intern2(mrb, name, (mrb_int)len);
} }
mrb_sym mrb_sym
...@@ -84,8 +74,9 @@ mrb_intern_str(mrb_state *mrb, mrb_value str) ...@@ -84,8 +74,9 @@ mrb_intern_str(mrb_state *mrb, mrb_value str)
return mrb_intern2(mrb, RSTRING_PTR(str), RSTRING_LEN(str)); return mrb_intern2(mrb, RSTRING_PTR(str), RSTRING_LEN(str));
} }
/* lenp must be a pointer to a size_t variable */
const char* const char*
mrb_sym2name_len(mrb_state *mrb, mrb_sym sym, mrb_int *lenp) mrb_sym2name_len(mrb_state *mrb, mrb_sym sym, size_t *lenp)
{ {
khash_t(n2s) *h = mrb->name2sym; khash_t(n2s) *h = mrb->name2sym;
khiter_t k; khiter_t k;
...@@ -95,16 +86,12 @@ mrb_sym2name_len(mrb_state *mrb, mrb_sym sym, mrb_int *lenp) ...@@ -95,16 +86,12 @@ mrb_sym2name_len(mrb_state *mrb, mrb_sym sym, mrb_int *lenp)
if (kh_exist(h, k)) { if (kh_exist(h, k)) {
if (kh_value(h, k) == sym) { if (kh_value(h, k) == sym) {
sname = kh_key(h, k); sname = kh_key(h, k);
if (lenp) {
*lenp = sname.len; *lenp = sname.len;
}
return sname.name; return sname.name;
} }
} }
} }
if (lenp) {
*lenp = 0; *lenp = 0;
}
return NULL; /* missing */ return NULL; /* missing */
} }
...@@ -194,7 +181,7 @@ mrb_sym_to_s(mrb_state *mrb, mrb_value sym) ...@@ -194,7 +181,7 @@ mrb_sym_to_s(mrb_state *mrb, mrb_value sym)
{ {
mrb_sym id = mrb_symbol(sym); mrb_sym id = mrb_symbol(sym);
const char *p; const char *p;
mrb_int len; size_t len;
p = mrb_sym2name_len(mrb, id, &len); p = mrb_sym2name_len(mrb, id, &len);
return mrb_str_new(mrb, p, len); return mrb_str_new(mrb, p, len);
...@@ -345,7 +332,7 @@ sym_inspect(mrb_state *mrb, mrb_value sym) ...@@ -345,7 +332,7 @@ sym_inspect(mrb_state *mrb, mrb_value sym)
{ {
mrb_value str; mrb_value str;
const char *name; const char *name;
mrb_int len; size_t len;
mrb_sym id = mrb_symbol(sym); mrb_sym id = mrb_symbol(sym);
name = mrb_sym2name_len(mrb, id, &len); name = mrb_sym2name_len(mrb, id, &len);
...@@ -362,7 +349,7 @@ sym_inspect(mrb_state *mrb, mrb_value sym) ...@@ -362,7 +349,7 @@ sym_inspect(mrb_state *mrb, mrb_value sym)
const char* const char*
mrb_sym2name(mrb_state *mrb, mrb_sym sym) mrb_sym2name(mrb_state *mrb, mrb_sym sym)
{ {
mrb_int len; size_t len;
const char *name = mrb_sym2name_len(mrb, sym, &len); const char *name = mrb_sym2name_len(mrb, sym, &len);
if (!name) return NULL; if (!name) return NULL;
...@@ -391,9 +378,7 @@ sym_cmp(mrb_state *mrb, mrb_value s1) ...@@ -391,9 +378,7 @@ sym_cmp(mrb_state *mrb, mrb_value s1)
else { else {
const char *p1, *p2; const char *p1, *p2;
int retval; int retval;
mrb_int len; size_t len, len1, len2;
mrb_int len1;
mrb_int len2;
p1 = mrb_sym2name_len(mrb, sym1, &len1); p1 = mrb_sym2name_len(mrb, sym1, &len1);
p2 = mrb_sym2name_len(mrb, sym2, &len2); p2 = mrb_sym2name_len(mrb, sym2, &len2);
......
...@@ -520,7 +520,7 @@ inspect_i(mrb_state *mrb, mrb_sym sym, mrb_value v, void *p) ...@@ -520,7 +520,7 @@ inspect_i(mrb_state *mrb, mrb_sym sym, mrb_value v, void *p)
{ {
mrb_value str = *(mrb_value*)p; mrb_value str = *(mrb_value*)p;
const char *s; const char *s;
int len; size_t len;
/* need not to show internal data */ /* need not to show internal data */
if (RSTRING_PTR(str)[0] == '-') { /* first element */ if (RSTRING_PTR(str)[0] == '-') { /* first element */
...@@ -587,7 +587,7 @@ iv_i(mrb_state *mrb, mrb_sym sym, mrb_value v, void *p) ...@@ -587,7 +587,7 @@ iv_i(mrb_state *mrb, mrb_sym sym, mrb_value v, void *p)
{ {
mrb_value ary; mrb_value ary;
const char* s; const char* s;
int len; size_t len;
ary = *(mrb_value*)p; ary = *(mrb_value*)p;
s = mrb_sym2name_len(mrb, sym, &len); s = mrb_sym2name_len(mrb, sym, &len);
...@@ -631,7 +631,7 @@ cv_i(mrb_state *mrb, mrb_sym sym, mrb_value v, void *p) ...@@ -631,7 +631,7 @@ cv_i(mrb_state *mrb, mrb_sym sym, mrb_value v, void *p)
{ {
mrb_value ary; mrb_value ary;
const char* s; const char* s;
int len; size_t len;
ary = *(mrb_value*)p; ary = *(mrb_value*)p;
s = mrb_sym2name_len(mrb, sym, &len); s = mrb_sym2name_len(mrb, sym, &len);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment