From 49a272d728c2003064182869cfdbca140f3acc81 Mon Sep 17 00:00:00 2001 From: nobu Date: Thu, 18 Feb 2016 12:06:20 +0000 Subject: string.c: Symbol#match * string.c (sym_match_m): delegate to String#match but not String#=~. [ruby-core:72864] [Bug #11991] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@53866 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- string.c | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) (limited to 'string.c') diff --git a/string.c b/string.c index 7850bcd1d5..2782d28e52 100644 --- a/string.c +++ b/string.c @@ -9423,7 +9423,6 @@ sym_casecmp(VALUE sym, VALUE other) /* * call-seq: * sym =~ obj -> fixnum or nil - * sym.match(obj) -> fixnum or nil * * Returns sym.to_s =~ obj. */ @@ -9434,6 +9433,19 @@ sym_match(VALUE sym, VALUE other) return rb_str_match(rb_sym2str(sym), other); } +/* + * call-seq: + * sym.match(obj) -> MatchData or nil + * + * Returns sym.to_s.match(obj). + */ + +static VALUE +sym_match_m(int argc, VALUE *argv, VALUE sym) +{ + return rb_str_match_m(argc, argv, rb_sym2str(sym)); +} + /* * call-seq: * sym[idx] -> char @@ -9763,7 +9775,7 @@ Init_String(void) rb_define_method(rb_cSymbol, "length", sym_length, 0); rb_define_method(rb_cSymbol, "size", sym_length, 0); rb_define_method(rb_cSymbol, "empty?", sym_empty, 0); - rb_define_method(rb_cSymbol, "match", sym_match, 1); + rb_define_method(rb_cSymbol, "match", sym_match_m, -1); rb_define_method(rb_cSymbol, "upcase", sym_upcase, -1); rb_define_method(rb_cSymbol, "downcase", sym_downcase, -1); -- cgit v1.2.3