ruby-changes:3193
From: ko1@a...
Date: 25 Dec 2007 18:07:46 +0900
Subject: [ruby-changes:3193] akr - Ruby:r14687 (trunk): * string.c (rb_str_inspect): don't call rb_enc_codepoint with empty
akr 2007-12-25 18:07:32 +0900 (Tue, 25 Dec 2007)
New Revision: 14687
Modified files:
trunk/ChangeLog
trunk/encoding.c
trunk/string.c
Log:
* string.c (rb_str_inspect): don't call rb_enc_codepoint with empty
string. fix '#'.inspect.
* encoding.c (rb_enc_codepoint): raise on empty string.
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/string.c?r1=14687&r2=14686
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=14687&r2=14686
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/encoding.c?r1=14687&r2=14686
Index: encoding.c
===================================================================
--- encoding.c (revision 14686)
+++ encoding.c (revision 14687)
@@ -662,7 +662,10 @@
int rb_enc_codepoint(const char *p, const char *e, rb_encoding *enc)
{
- int r = rb_enc_precise_mbclen(p, e, enc);
+ int r;
+ if (e <= p)
+ rb_raise(rb_eArgError, "empty string");
+ r = rb_enc_precise_mbclen(p, e, enc);
if (MBCLEN_CHARFOUND(r))
return ONIGENC_MBC_TO_CODE(enc,(UChar*)p,(UChar*)e);
else
Index: ChangeLog
===================================================================
--- ChangeLog (revision 14686)
+++ ChangeLog (revision 14687)
@@ -1,3 +1,10 @@
+Tue Dec 25 18:06:04 2007 Tanaka Akira <akr@f...>
+
+ * string.c (rb_str_inspect): don't call rb_enc_codepoint with empty
+ string. fix '#'.inspect.
+
+ * encoding.c (rb_enc_codepoint): raise on empty string.
+
Tue Dec 25 17:48:28 2007 Shugo Maeda <shugo@r...>
* vm.c (rb_frame_method_id_and_class): new function to get the
Index: string.c
===================================================================
--- string.c (revision 14686)
+++ string.c (revision 14687)
@@ -3025,7 +3025,8 @@
p += n;
if (c == '"'|| c == '\\' ||
- (c == '#' && (cc = rb_enc_codepoint(p,pend,enc),
+ (c == '#' && p < pend &&
+ (cc = rb_enc_codepoint(p,pend,enc),
(cc == '$' || cc == '@' || cc == '{')))) {
prefix_escape(result, c, enc);
}
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml