summaryrefslogtreecommitdiffhomepage
path: root/src/string.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2021-12-31 15:28:11 +0900
committerGitHub <[email protected]>2021-12-31 15:28:11 +0900
commit9fc26eacd17394a20c49315b9996dbfbd73ce238 (patch)
tree9f2cfa4d057831d443afb7faedae2ec1acbc4814 /src/string.c
parentb9e1b9b32852e2fb5836c1d4fd622a5a9a41119e (diff)
parenta137ef12f981b517f1e6b64e39edc7ac15d7e1eb (diff)
downloadmruby-9fc26eacd17394a20c49315b9996dbfbd73ce238.tar.gz
mruby-9fc26eacd17394a20c49315b9996dbfbd73ce238.zip
Merge pull request #5619 from dearblue/properties
Get object properties after `mrb_get_args()`
Diffstat (limited to 'src/string.c')
-rw-r--r--src/string.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/src/string.c b/src/string.c
index 58f83e6f9..332c4e777 100644
--- a/src/string.c
+++ b/src/string.c
@@ -2038,9 +2038,11 @@ static mrb_value
mrb_str_rindex(mrb_state *mrb, mrb_value str)
{
mrb_value sub;
- mrb_int pos, len = RSTRING_CHAR_LEN(str);
+ mrb_int pos;
+ int argc = mrb_get_args(mrb, "S|i", &sub, &pos);
+ mrb_int len = RSTRING_CHAR_LEN(str);
- if (mrb_get_args(mrb, "S|i", &sub, &pos) == 1) {
+ if (argc == 1) {
pos = len;
}
else {
@@ -2819,16 +2821,18 @@ static mrb_value
mrb_str_byteslice(mrb_state *mrb, mrb_value str)
{
mrb_value a1;
- mrb_int str_len = RSTRING_LEN(str), beg, len;
+ mrb_int str_len, beg, len;
mrb_bool empty = TRUE;
len = mrb_get_argc(mrb);
switch (len) {
case 2:
mrb_get_args(mrb, "ii", &beg, &len);
+ str_len = RSTRING_LEN(str);
break;
case 1:
a1 = mrb_get_arg1(mrb);
+ str_len = RSTRING_LEN(str);
if (mrb_range_p(a1)) {
if (mrb_range_beg_len(mrb, a1, &beg, &len, str_len, TRUE) != MRB_RANGE_OK) {
return mrb_nil_value();