diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-04-04 05:13:06 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-04-04 05:13:06 +0000 |
commit | 1d6949b9fc85156368d093a38a0db67676c663c3 (patch) | |
tree | 8c206507b7bd2782aeb89b0ca7d7635499331076 /re.c | |
parent | 2e374187127fd961dcac0a0ed8b7697af35f4f20 (diff) | |
download | ruby-1d6949b9fc85156368d093a38a0db67676c663c3.tar.gz ruby-1d6949b9fc85156368d093a38a0db67676c663c3.tar.xz ruby-1d6949b9fc85156368d093a38a0db67676c663c3.zip |
* re.c (rb_memsearch_qs): wrong boundary condition. a patch from
wanabe <s.wanabe AT gmail.com> in [ruby-dev:34248].
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@15902 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 're.c')
-rw-r--r-- | re.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -144,7 +144,7 @@ rb_memsearch_qs(const unsigned char *xs, long m, const unsigned char *ys, long n for (; x < xe; ++x) qstable[*x] = xe - x; /* Searching */ - for (; y < ye; y += *(qstable + y[m])) { + for (; y + m < ye; y += *(qstable + y[m])) { if (*xs == *y && memcmp(xs, y, m) == 0) return y - ys; } |