From 5e263fa0c0db7deedeef9ba6d991f9950c47e416 Mon Sep 17 00:00:00 2001 From: yugui Date: Mon, 4 May 2009 12:30:33 +0000 Subject: [PATCH] merges r23190 from trunk into ruby_1_9_1. -- * dir.c (fnmatch_helper): use rb_enc_precise_mbclen and fail if bytes are invalid. [ruby-dev:38307] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@23337 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ dir.c | 4 +++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index 9e79038daa..17a1d56d60 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Wed Apr 15 11:53:35 2009 NARUSE, Yui + + * dir.c (fnmatch_helper): use rb_enc_precise_mbclen and + fail if bytes are invalid. [ruby-dev:38307] + Tue Apr 14 18:11:26 2009 Nobuyoshi Nakada * dir.c (bracket): if same in bytes, path is matching. diff --git a/dir.c b/dir.c index f62fc416b6..f27f04c40a 100644 --- a/dir.c +++ b/dir.c @@ -224,7 +224,9 @@ fnmatch_helper( RETURN(ISEND(p) ? 0 : FNM_NOMATCH); if (ISEND(p)) goto failed; - r = rb_enc_mbclen(p, pend, enc); + r = rb_enc_precise_mbclen(p, pend, enc); + if (!MBCLEN_CHARFOUND_P(r)) + goto failed; if (r <= (send-s) && memcmp(p, s, r) == 0) { p += r; s += r;