diff options
| author | Jared Breeden <[email protected]> | 2015-06-22 23:20:24 -0700 |
|---|---|---|
| committer | Jared Breeden <[email protected]> | 2015-06-22 23:20:24 -0700 |
| commit | 18337266f838003d631d2c02e6d847ae5375a839 (patch) | |
| tree | ccf038939213da30b99ba8931d87bc0d719dbc8a /src/string.c | |
| parent | 9781580c7134fcee7bf5a6d4356bc47593549da8 (diff) | |
| parent | 1001be2e99720f6745159295aa73c649e08adec8 (diff) | |
| download | mruby-18337266f838003d631d2c02e6d847ae5375a839.tar.gz mruby-18337266f838003d631d2c02e6d847ae5375a839.zip | |
Merge branch 'master' of http://github.com/mruby/mruby into alloc_doc
Diffstat (limited to 'src/string.c')
| -rw-r--r-- | src/string.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/src/string.c b/src/string.c index 0a28f2565..22a289ade 100644 --- a/src/string.c +++ b/src/string.c @@ -1985,7 +1985,8 @@ bad: MRB_API const char* mrb_string_value_cstr(mrb_state *mrb, mrb_value *ptr) { - struct RString *ps = mrb_str_ptr(*ptr); + mrb_value str = mrb_str_to_str(mrb, *ptr); + struct RString *ps = mrb_str_ptr(str); mrb_int len = mrb_str_strlen(mrb, ps); char *p = RSTR_PTR(ps); @@ -2002,12 +2003,12 @@ mrb_str_to_inum(mrb_state *mrb, mrb_value str, mrb_int base, mrb_bool badcheck) const char *s; mrb_int len; - str = mrb_str_to_str(mrb, str); if (badcheck) { + /* Raises if the string contains a null character (the badcheck) */ s = mrb_string_value_cstr(mrb, &str); } else { - s = RSTRING_PTR(str); + s = mrb_string_value_ptr(mrb, str); } if (s) { len = RSTRING_LEN(str); |
