ruby-changes:4989
From: ko1@a...
Date: Mon, 19 May 2008 23:21:35 +0900 (JST)
Subject: [ruby-changes:4989] mame - Ruby:r16482 (trunk): * regexec.c (slow_search): check the case when the length is 1.
mame 2008-05-19 23:21:15 +0900 (Mon, 19 May 2008) New Revision: 16482 Modified files: trunk/ChangeLog trunk/regexec.c Log: * regexec.c (slow_search): check the case when the length is 1. The behavior of memcmp is undefined if the third argument is 0. http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/regexec.c?r1=16482&r2=16481&diff_format=u http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=16482&r2=16481&diff_format=u Index: ChangeLog =================================================================== --- ChangeLog (revision 16481) +++ ChangeLog (revision 16482) @@ -1,3 +1,8 @@ +Mon May 19 23:19:35 2008 Yusuke Endoh <mame@t...> + + * regexec.c (slow_search): check the case when the length is 1. + The behavior of memcmp is undefined if the third argument is 0. + Mon May 19 21:07:48 2008 Koichi Sasada <ko1@a...> * thread_pthread.c (native_thread_apply_priority): Index: regexec.c =================================================================== --- regexec.c (revision 16481) +++ regexec.c (revision 16482) @@ -2765,7 +2765,7 @@ if (*s == *target) { p = s + 1; t = target + 1; - if (memcmp(t, p, target_end - t) == 0) + if (target_end == t || memcmp(t, p, target_end - t) == 0) return s; } s += n; @@ -2776,7 +2776,7 @@ if (*s == *target) { p = s + 1; t = target + 1; - if (memcmp(t, p, target_end - t) == 0) + if (target_end == t || memcmp(t, p, target_end - t) == 0) return s; } s += enclen(enc, s, end); -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/