ruby-changes:2771
From: ko1@a...
Date: 17 Dec 2007 17:09:58 +0900
Subject: [ruby-changes:2771] akr - Ruby:r14262 (trunk): * string.c (rb_enc_str_coderange): set ENC_CODERANGE_BROKEN using
akr 2007-12-17 16:41:21 +0900 (Mon, 17 Dec 2007)
New Revision: 14262
Modified files:
trunk/ChangeLog
trunk/string.c
Log:
* string.c (rb_enc_str_coderange): set ENC_CODERANGE_BROKEN using
rb_enc_precise_mbclen.
(rb_str_valid_encoding_p): just check coderange is
ENC_CODERANGE_BROKEN or not.
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/string.c?r1=14262&r2=14261
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=14262&r2=14261
Index: ChangeLog
===================================================================
--- ChangeLog (revision 14261)
+++ ChangeLog (revision 14262)
@@ -1,3 +1,10 @@
+Mon Dec 17 16:39:25 2007 Tanaka Akira <akr@f...>
+
+ * string.c (rb_enc_str_coderange): set ENC_CODERANGE_BROKEN using
+ rb_enc_precise_mbclen.
+ (rb_str_valid_encoding_p): just check coderange is
+ ENC_CODERANGE_BROKEN or not.
+
Mon Dec 17 16:04:16 2007 GOTOU Yuuzou <gotoyuzo@n...>
* ext/openssl/lib/openssl/buffering.rb (Buffering#gets): added second
Index: string.c
===================================================================
--- string.c (revision 14261)
+++ string.c (revision 14262)
@@ -105,27 +105,26 @@
if (cr == ENC_CODERANGE_UNKNOWN) {
rb_encoding *enc = rb_enc_get(str);
- if (!rb_enc_asciicompat(enc)) {
- cr = ENC_CODERANGE_VALID;
- ENC_CODERANGE_SET(str, cr);
- return cr;
- }
- else {
- const char *p = RSTRING_PTR(str);
- const char *e = p + RSTRING_LEN(str);
+ const char *p = RSTRING_PTR(str);
+ const char *e = p + RSTRING_LEN(str);
- cr = ENC_CODERANGE_7BIT;
- while (p < e) {
- int c = (unsigned char)*p;
+ cr = rb_enc_asciicompat(enc) ? ENC_CODERANGE_7BIT : ENC_CODERANGE_VALID;
+ while (p < e) {
+ int ret = rb_enc_precise_mbclen(p, e, enc);
+ int len = MBCLEN_CHARFOUND(ret);
- if (!rb_enc_isascii(c, enc)) {
- cr = ENC_CODERANGE_VALID;
- break;
- }
- p++;
- }
- ENC_CODERANGE_SET(str, cr);
- }
+ if (len) {
+ if (len != 1 || !rb_enc_isascii((unsigned char)*p, enc)) {
+ cr = ENC_CODERANGE_VALID;
+ }
+ p += len;
+ }
+ else {
+ cr = ENC_CODERANGE_BROKEN;
+ break;
+ }
+ }
+ ENC_CODERANGE_SET(str, cr);
}
return cr;
}
@@ -5316,20 +5315,9 @@
static VALUE
rb_str_valid_encoding_p(VALUE str)
{
- char *p = RSTRING_PTR(str);
- char *pend = RSTRING_END(str);
- rb_encoding *enc = rb_enc_get(str);
+ int cr = rb_enc_str_coderange(str);
- while (p < pend) {
- int n;
-
- n = rb_enc_precise_mbclen(p, pend, enc);
- if (!MBCLEN_CHARFOUND(n)) {
- return Qfalse;
- }
- p += n;
- }
- return Qtrue;
+ return cr == ENC_CODERANGE_BROKEN ? Qfalse : Qtrue;
}
/**********************************************************************
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml