ruby-changes:5122
From: usa <ko1@a...>
Date: Tue, 27 May 2008 12:08:09 +0900 (JST)
Subject: [ruby-changes:5122] Ruby:r16617 (trunk): * file.c (BUFCHECK): wrong condition.
usa 2008-05-27 12:07:55 +0900 (Tue, 27 May 2008) New Revision: 16617 Modified files: trunk/ChangeLog trunk/file.c trunk/version.h Log: * file.c (BUFCHECK): wrong condition. [ruby-core:16921] * file.c (file_expand_buf): shouldn't use buflen for length of string. http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/version.h?r1=16617&r2=16616&diff_format=u http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/file.c?r1=16617&r2=16616&diff_format=u http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=16617&r2=16616&diff_format=u Index: ChangeLog =================================================================== --- ChangeLog (revision 16616) +++ ChangeLog (revision 16617) @@ -1,3 +1,9 @@ +Tue May 27 12:06:37 2008 NAKAMURA Usaku <usa@r...> + + * file.c (BUFCHECK): wrong condition. [ruby-core:16921] + + * file.c (file_expand_buf): shouldn't use buflen for length of string. + Mon May 26 18:24:48 2008 Nobuyoshi Nakada <nobu@r...> * file.c (BUFCHECK): no resize if enough room. Index: version.h =================================================================== --- version.h (revision 16616) +++ version.h (revision 16617) @@ -1,7 +1,7 @@ #define RUBY_VERSION "1.9.0" -#define RUBY_RELEASE_DATE "2008-05-26" +#define RUBY_RELEASE_DATE "2008-05-27" #define RUBY_VERSION_CODE 190 -#define RUBY_RELEASE_CODE 20080526 +#define RUBY_RELEASE_CODE 20080527 #define RUBY_PATCHLEVEL 0 #define RUBY_VERSION_MAJOR 1 @@ -9,7 +9,7 @@ #define RUBY_VERSION_TEENY 0 #define RUBY_RELEASE_YEAR 2008 #define RUBY_RELEASE_MONTH 5 -#define RUBY_RELEASE_DAY 26 +#define RUBY_RELEASE_DAY 27 #ifdef RUBY_EXTERN RUBY_EXTERN const char ruby_version[]; Index: file.c =================================================================== --- file.c (revision 16616) +++ file.c (revision 16617) @@ -2578,7 +2578,7 @@ #define BUFCHECK(cond) do {\ long bdiff = p - buf;\ - if (!(cond)) {\ + if (cond) {\ do {buflen *= 2;} while (cond);\ rb_str_resize(result, buflen);\ buf = RSTRING_PTR(result);\ @@ -2827,7 +2827,6 @@ p += s-b; } if (p == skiproot(buf) - 1) p++; - buflen = p - buf; #if USE_NTFS *p = '\0'; @@ -2877,15 +2876,16 @@ } #endif if (!p) p = buf; - ++p; + else ++p; BUFCHECK(bdiff + len >= buflen); memcpy(p, wfd.cFileName, len + 1); + p += len; } } #endif if (tainted) OBJ_TAINT(result); - rb_str_set_len(result, buflen); + rb_str_set_len(result, p - buf); rb_enc_check(fname, result); return result; } -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/