diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2015-06-23 14:54:13 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2015-06-23 14:54:13 +0900 |
| commit | 1001be2e99720f6745159295aa73c649e08adec8 (patch) | |
| tree | 47d6c1548501860c42aff29ccc0ffb39b5c0b003 /src/string.c | |
| parent | 0b720ffa61debd9c16d513db9740078609d20252 (diff) | |
| parent | 9ad632559efc6392d4650eedb27090ec27f78776 (diff) | |
| download | mruby-1001be2e99720f6745159295aa73c649e08adec8.tar.gz mruby-1001be2e99720f6745159295aa73c649e08adec8.zip | |
Merge pull request #2852 from jbreeden/mrb_string_value_cstr_patch
Mrb string value cstr patch
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); |
