diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2021-12-29 16:44:35 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2021-12-29 16:44:35 +0900 |
| commit | 66a099b1b3084d0f591ad9b5b8bf614ca17a30b2 (patch) | |
| tree | 4e825049ccccb70d9e36458f3928f07c48ef2b8c /src | |
| parent | b6d31810feca09ac284eda84cf0d2215ced5ec6c (diff) | |
| download | mruby-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.c | 15 |
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; |
