summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2013-03-14 02:50:24 -0700
committerYukihiro "Matz" Matsumoto <[email protected]>2013-03-14 02:50:24 -0700
commitb75805b15ec46cbcd7561ffd571e2c892de96f25 (patch)
treef276b0cc600bdbbf210dbbd24ab5699b23453fee /src
parent535a5489c7028378d9388aa187c7edb946595ec7 (diff)
parent48cc92b3c6d2a4ef1895e398c0268b40f03ccad5 (diff)
downloadmruby-b75805b15ec46cbcd7561ffd571e2c892de96f25.tar.gz
mruby-b75805b15ec46cbcd7561ffd571e2c892de96f25.zip
Merge pull request #993 from monaka/pr-cleanup-symbol.c-20130312
Cleanup symbol.c.
Diffstat (limited to 'src')
-rw-r--r--src/symbol.c45
1 files changed, 32 insertions, 13 deletions
diff --git a/src/symbol.c b/src/symbol.c
index 72a5bea6b..a98d59f42 100644
--- a/src/symbol.c
+++ b/src/symbol.c
@@ -13,7 +13,7 @@
/* ------------------------------------------------------ */
typedef struct symbol_name {
- int len;
+ mrb_int len;
const char *name;
} symbol_name;
@@ -21,7 +21,7 @@ static inline khint_t
sym_hash_func(mrb_state *mrb, const symbol_name s)
{
khint_t h = 0;
- size_t i;
+ mrb_int i;
const char *p = s.name;
for (i=0; i<s.len; i++) {
@@ -35,7 +35,7 @@ KHASH_DECLARE(n2s, symbol_name, mrb_sym, 1)
KHASH_DEFINE (n2s, symbol_name, mrb_sym, 1, sym_hash_func, sym_hash_equal)
/* ------------------------------------------------------ */
mrb_sym
-mrb_intern2(mrb_state *mrb, const char *name, int len)
+mrb_intern2(mrb_state *mrb, const char *name, mrb_int len)
{
khash_t(n2s) *h = mrb->name2sym;
symbol_name sname;
@@ -43,6 +43,11 @@ mrb_intern2(mrb_state *mrb, const char *name, int len)
mrb_sym sym;
char *p;
+ if (len > MRB_INT_MAX - 1) {
+ /* In case inspect method called, the result is ":" + symname. */
+ len = MRB_INT_MAX - 1;
+ }
+
sname.len = len;
sname.name = name;
k = kh_get(n2s, h, sname);
@@ -50,8 +55,8 @@ mrb_intern2(mrb_state *mrb, const char *name, int len)
return kh_value(h, k);
sym = ++mrb->symidx;
- p = (char *)mrb_malloc(mrb, len+1);
- memcpy(p, name, len);
+ p = (char *)mrb_malloc(mrb, (size_t)len+1);
+ memcpy(p, name, (size_t)len);
p[len] = 0;
sname.name = (const char*)p;
k = kh_put(n2s, h, sname);
@@ -63,7 +68,14 @@ mrb_intern2(mrb_state *mrb, const char *name, int len)
mrb_sym
mrb_intern(mrb_state *mrb, const char *name)
{
- return mrb_intern2(mrb, name, strlen(name));
+ size_t len;
+
+ len = strlen(name);
+ if (len > MRB_INT_MAX) {
+ len = MRB_INT_MAX;
+ }
+
+ return mrb_intern2(mrb, name, (mrb_int)len);
}
mrb_sym
@@ -73,7 +85,7 @@ mrb_intern_str(mrb_state *mrb, mrb_value str)
}
const char*
-mrb_sym2name_len(mrb_state *mrb, mrb_sym sym, int *lenp)
+mrb_sym2name_len(mrb_state *mrb, mrb_sym sym, mrb_int *lenp)
{
khash_t(n2s) *h = mrb->name2sym;
khiter_t k;
@@ -83,12 +95,16 @@ mrb_sym2name_len(mrb_state *mrb, mrb_sym sym, int *lenp)
if (kh_exist(h, k)) {
if (kh_value(h, k) == sym) {
sname = kh_key(h, k);
- *lenp = sname.len;
+ if (lenp) {
+ *lenp = sname.len;
+ }
return sname.name;
}
}
}
- *lenp = 0;
+ if (lenp) {
+ *lenp = 0;
+ }
return NULL; /* missing */
}
@@ -178,7 +194,7 @@ mrb_sym_to_s(mrb_state *mrb, mrb_value sym)
{
mrb_sym id = mrb_symbol(sym);
const char *p;
- int len;
+ mrb_int len;
p = mrb_sym2name_len(mrb, id, &len);
return mrb_str_new(mrb, p, len);
@@ -329,7 +345,7 @@ sym_inspect(mrb_state *mrb, mrb_value sym)
{
mrb_value str;
const char *name;
- int len;
+ mrb_int len;
mrb_sym id = mrb_symbol(sym);
name = mrb_sym2name_len(mrb, id, &len);
@@ -346,7 +362,7 @@ sym_inspect(mrb_state *mrb, mrb_value sym)
const char*
mrb_sym2name(mrb_state *mrb, mrb_sym sym)
{
- int len;
+ mrb_int len;
const char *name = mrb_sym2name_len(mrb, sym, &len);
if (!name) return NULL;
@@ -374,7 +390,10 @@ sym_cmp(mrb_state *mrb, mrb_value s1)
if (sym1 == sym2) return mrb_fixnum_value(0);
else {
const char *p1, *p2;
- int len, len1, len2, retval;
+ int retval;
+ mrb_int len;
+ mrb_int len1;
+ mrb_int len2;
p1 = mrb_sym2name_len(mrb, sym1, &len1);
p2 = mrb_sym2name_len(mrb, sym2, &len2);