mirror of
https://github.com/ruby/ruby.git
synced 2025-08-24 21:44:30 +02:00
re.c: fix match?
* re.c (rb_reg_match_m_p): fix match against empty string. rb_str_offset returns the end when the position exceeds the length. fix the range parameter of onig_search. [ruby-core:75604] [Bug #12394] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55069 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
0c221f631c
commit
a28c12af14
3 changed files with 24 additions and 13 deletions
|
@ -528,14 +528,21 @@ class TestRegexp < Test::Unit::TestCase
|
|||
|
||||
def test_match_p
|
||||
/backref/ =~ 'backref'
|
||||
# must match here, but not in a separate method, e.g., assert_send,
|
||||
# to check if $~ is affected or not.
|
||||
assert_equal(false, //.match?(nil))
|
||||
assert_equal(true, //.match?(""))
|
||||
assert_equal(true, /.../.match?(:abc))
|
||||
assert_raise(TypeError) { /.../.match?(Object.new) }
|
||||
assert_equal(true, /b/.match?('abc'))
|
||||
assert_equal(true, /b/.match?('abc', 1))
|
||||
assert_equal(true, /../.match?('abc', 1))
|
||||
assert_equal(true, /../.match?('abc', -2))
|
||||
assert_equal(false, /../.match?("abc", -4))
|
||||
assert_equal(false, /../.match?("abc", 4))
|
||||
assert_equal(true, /../n.match?("\u3042" + '\x', 1))
|
||||
assert_equal(true, /\z/.match?(""))
|
||||
assert_equal(true, /\z/.match?("abc"))
|
||||
assert_equal('backref', $&)
|
||||
end
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue