summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2021-12-29 16:44:35 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2021-12-29 16:44:35 +0900
commit66a099b1b3084d0f591ad9b5b8bf614ca17a30b2 (patch)
tree4e825049ccccb70d9e36458f3928f07c48ef2b8c /src
parentb6d31810feca09ac284eda84cf0d2215ced5ec6c (diff)
downloadmruby-66a099b1b3084d0f591ad9b5b8bf614ca17a30b2.tar.gz
mruby-66a099b1b3084d0f591ad9b5b8bf614ca17a30b2.zip
string.c: reorganize `str_convert_range` using `mrb_ensure_int_type`
Diffstat (limited to 'src')
-rw-r--r--src/string.c15
1 files changed, 3 insertions, 12 deletions
diff --git a/src/string.c b/src/string.c
index f05ac8e1c..58f83e6f9 100644
--- a/src/string.c
+++ b/src/string.c
@@ -1108,6 +1108,9 @@ str_convert_range(mrb_state *mrb, mrb_value str, mrb_value indx, mrb_value alen,
}
else {
switch (mrb_type(indx)) {
+ default:
+ indx = mrb_ensure_int_type(mrb, indx);
+ /* fall through */
case MRB_TT_INTEGER:
*beg = mrb_integer(indx);
*len = 1;
@@ -1120,16 +1123,6 @@ str_convert_range(mrb_state *mrb, mrb_value str, mrb_value indx, mrb_value alen,
return STR_BYTE_RANGE_CORRECTED;
case MRB_TT_RANGE:
- goto range_arg;
-
- default:
- indx = mrb_to_integer(mrb, indx);
- if (mrb_integer_p(indx)) {
- *beg = mrb_integer(indx);
- *len = 1;
- return STR_CHAR_RANGE;
- }
-range_arg:
*len = RSTRING_CHAR_LEN(str);
switch (mrb_range_beg_len(mrb, indx, beg, len, *len, TRUE)) {
case MRB_RANGE_OK:
@@ -1139,8 +1132,6 @@ range_arg:
default:
break;
}
-
- mrb_raise(mrb, E_TYPE_ERROR, "can't convert to Integer");
}
}
return STR_OUT_OF_RANGE;