summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2015-06-23 14:54:13 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2015-06-23 14:54:13 +0900
commit1001be2e99720f6745159295aa73c649e08adec8 (patch)
tree47d6c1548501860c42aff29ccc0ffb39b5c0b003
parent0b720ffa61debd9c16d513db9740078609d20252 (diff)
parent9ad632559efc6392d4650eedb27090ec27f78776 (diff)
downloadmruby-1001be2e99720f6745159295aa73c649e08adec8.tar.gz
mruby-1001be2e99720f6745159295aa73c649e08adec8.zip
Merge pull request #2852 from jbreeden/mrb_string_value_cstr_patch
Mrb string value cstr patch
-rw-r--r--src/string.c7
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);