ruby-changes:3385
From: ko1@a...
Date: 4 Jan 2008 10:24:28 +0900
Subject: [ruby-changes:3385] matz - Ruby:r14878 (trunk): * re.c (rb_reg_search): avoid inner loop for reverse search.
matz 2008-01-04 10:24:12 +0900 (Fri, 04 Jan 2008)
New Revision: 14878
Modified files:
trunk/ChangeLog
trunk/re.c
trunk/regexec.c
Log:
* re.c (rb_reg_search): avoid inner loop for reverse search.
* regexec.c: unset USE_MATCH_RANGE_MUST_BE_INSIDE_OF_SPECIFIED_RANGE
which is turned on since oniguruma 5.9.1.
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/regexec.c?r1=14878&r2=14877&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=14878&r2=14877&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/re.c?r1=14878&r2=14877&diff_format=u
Index: re.c
===================================================================
--- re.c (revision 14877)
+++ re.c (revision 14878)
@@ -1035,7 +1035,7 @@
int result;
VALUE match;
static struct re_registers regs;
- int range;
+ char *range = RSTRING_PTR(str);
rb_encoding *enc = rb_enc_get(str);
if (pos > RSTRING_LEN(str) || pos < 0) {
@@ -1045,33 +1045,15 @@
rb_reg_prepare_re(re, str);
- if (reverse) {
- char *p = RSTRING_PTR(str) + pos;
- while (1) {
- result = onig_match(RREGEXP(re)->ptr,
- (UChar*)(RSTRING_PTR(str)),
- ((UChar*)(RSTRING_PTR(str)) + RSTRING_LEN(str)),
- (UChar*)p,
- ®s,
- ONIG_OPTION_NONE);
- if (result != ONIG_MISMATCH) {
- result = p - RSTRING_PTR(str);
- break;
- }
- if (RSTRING_PTR(str) == p)
- break;
- p = rb_enc_prev_char(RSTRING_PTR(str), p, enc);
- }
+ if (!reverse) {
+ range += RSTRING_LEN(str);
}
- else {
- range = RSTRING_LEN(str) - pos;
- result = onig_search(RREGEXP(re)->ptr,
- (UChar*)(RSTRING_PTR(str)),
- ((UChar*)(RSTRING_PTR(str)) + RSTRING_LEN(str)),
- ((UChar*)(RSTRING_PTR(str)) + pos),
- ((UChar*)(RSTRING_PTR(str)) + pos + range),
- ®s, ONIG_OPTION_NONE);
- }
+ result = onig_search(RREGEXP(re)->ptr,
+ (UChar*)(RSTRING_PTR(str)),
+ ((UChar*)(RSTRING_PTR(str)) + RSTRING_LEN(str)),
+ ((UChar*)(RSTRING_PTR(str)) + pos),
+ ((UChar*)range),
+ ®s, ONIG_OPTION_NONE);
if (result < 0) {
if (result == ONIG_MISMATCH) {
Index: ChangeLog
===================================================================
--- ChangeLog (revision 14877)
+++ ChangeLog (revision 14878)
@@ -1,3 +1,10 @@
+Fri Jan 4 10:22:25 2008 Yukihiro Matsumoto <matz@r...>
+
+ * re.c (rb_reg_search): avoid inner loop for reverse search.
+
+ * regexec.c: unset USE_MATCH_RANGE_MUST_BE_INSIDE_OF_SPECIFIED_RANGE
+ which is turned on since oniguruma 5.9.1.
+
Fri Jan 4 02:53:31 2008 Tanaka Akira <akr@f...>
* enc/euc_jp.c: remove eucjp_ prefix. breakpoint can be specified as
Index: regexec.c
===================================================================
--- regexec.c (revision 14877)
+++ regexec.c (revision 14878)
@@ -29,7 +29,7 @@
#include "regint.h"
-#define USE_MATCH_RANGE_MUST_BE_INSIDE_OF_SPECIFIED_RANGE
+/* #define USE_MATCH_RANGE_MUST_BE_INSIDE_OF_SPECIFIED_RANGE */
#ifdef USE_CRNL_AS_LINE_TERMINATOR
#define ONIGENC_IS_MBC_CRNL(enc,p,end) \
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml