summaryrefslogtreecommitdiff
path: root/re.c
diff options
context:
space:
mode:
authorksaito <ksaito@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-04-24 05:34:54 +0000
committerksaito <ksaito@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-04-24 05:34:54 +0000
commitfa659c14490d24277b56d14127b547a2a758796e (patch)
tree77b31aac8d1deac9e7b1829470bd5347d1efb111 /re.c
parenteb93c7431490c3f2a54895d50a297fb0823ff305 (diff)
re.c: applied stack error handling patch. [ruby-dev:22431]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@6213 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 're.c')
-rw-r--r--re.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/re.c b/re.c
index 6a60a099fc..23196bb171 100644
--- a/re.c
+++ b/re.c
@@ -920,14 +920,16 @@ rb_reg_search(re, str, pos, reverse)
if (FL_TEST(re, KCODE_FIXED))
kcode_reset_option();
- if (result == -2) {
- rb_reg_raise(RREGEXP(re)->str, RREGEXP(re)->len,
- "Stack overflow in regexp matcher", re);
- }
-
if (result < 0) {
- rb_backref_set(Qnil);
- return result;
+ if (result == ONIG_MISMATCH) {
+ rb_backref_set(Qnil);
+ return result;
+ }
+ else {
+ char err[ONIG_MAX_ERROR_MESSAGE_LEN];
+ re_error_code_to_str((UChar* )err, result);
+ rb_reg_raise(RREGEXP(re)->str, RREGEXP(re)->len, err, 0);
+ }
}
match = rb_backref_get();