[前][次][番号順一覧][スレッド一覧]

ruby-changes:2275

From: ko1@a...
Date: 24 Oct 2007 17:09:58 +0900
Subject: [ruby-changes:2275] nobu - Ruby:r13766 (trunk): * parse.y (parser_tokspace): make space in token buffer.

nobu	2007-10-24 17:09:40 +0900 (Wed, 24 Oct 2007)

  New Revision: 13766

  Modified files:
    trunk/ChangeLog
    trunk/parse.y
    trunk/version.h

  Log:
    * parse.y (parser_tokspace): make space in token buffer.
    
    * parse.y (parser_yylex): fix encoding of single character literal.


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/version.h?r1=13766&r2=13765
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/parse.y?r1=13766&r2=13765
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=13766&r2=13765

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 13765)
+++ ChangeLog	(revision 13766)
@@ -1,3 +1,9 @@
+Wed Oct 24 17:09:39 2007  Nobuyoshi Nakada  <nobu@r...>
+
+	* parse.y (parser_tokspace): make space in token buffer.
+
+	* parse.y (parser_yylex): fix encoding of single character literal.
+
 Tue Oct 23 13:44:14 2007  Nobuyoshi Nakada  <nobu@r...>
 
 	* parse.y (call_args2): nd_head of NODE_BLOCK_PASS should be a list.
Index: parse.y
===================================================================
--- parse.y	(revision 13765)
+++ parse.y	(revision 13766)
@@ -4494,6 +4494,7 @@
 # define nextc()                   parser_nextc(parser)
 # define pushback(c)               parser_pushback(parser, c)
 # define newtok()                  parser_newtok(parser)
+# define tokspace(n)               parser_tokspace(parser, n)
 # define tokadd(c)                 parser_tokadd(parser, c)
 # define read_escape(m)            parser_read_escape(parser, m)
 # define tokadd_escape(t,m)        parser_tokadd_escape(parser, t, m)
@@ -4913,6 +4914,18 @@
     return tokenbuf;
 }
 
+static char *
+parser_tokspace(struct parser_params *parser, int n)
+{
+    int idx = tokidx + n;
+
+    if (idx >= toksiz) {
+	do {toksiz *= 2;} while (toksiz < idx);
+	REALLOC_N(tokenbuf, char, toksiz);
+    }
+    return &tokenbuf[tokidx];
+}
+
 static void
 parser_tokadd(struct parser_params *parser, int c)
 {
@@ -6086,21 +6099,24 @@
 	}
 	newtok();
 	if (parser_ismbchar()) {
+	    mb = ENC_CODERANGE_MULTI;
 	    tokadd_mbchar(c);
 	}
 	else if ((rb_enc_isalnum(c, parser->enc) || c == '_') &&
 		 lex_p < lex_pend && is_identchar(lex_p, lex_pend, parser->enc)) {
 	    goto ternary;
 	}
-	else if (c == '\\') {
-	    c = read_escape(0);
-	    tokadd(c);
+	else if (c == '\\' && (c = read_escape(0)) >= 0x80) {
+	    rb_encoding *enc = parser->enc;
+	    mb = ENC_CODERANGE_UNKNOWN;
+	    rb_enc_mbcput(c, tokspace(rb_enc_codelen(c, enc)), enc);
 	}
 	else {
+	    mb = ENC_CODERANGE_SINGLE;
 	    tokadd(c);
 	}
 	tokfix();
-	set_yylval_str(STR_NEW(tok(), toklen()));
+	set_yylval_str(STR_NEW3(tok(), toklen(), mb));
 	lex_state = EXPR_ENDARG;
 	return tCHAR;
 
@@ -6865,9 +6881,9 @@
 	break;
     }
 
-    mb = 0;
+    mb = ENC_CODERANGE_SINGLE;
     do {
-	if (!ISASCII(c)) mb = 1;
+	if (!ISASCII(c)) mb = ENC_CODERANGE_UNKNOWN;
 	tokadd_mbchar(c);
 	c = nextc();
     } while (parser_is_identchar());
@@ -6920,7 +6936,7 @@
 		}
 	    }
 
-	    if (!mb && lex_state != EXPR_DOT) {
+	    if (mb == ENC_CODERANGE_SINGLE && lex_state != EXPR_DOT) {
 		const struct kwtable *kw;
 
 		/* See if it is a reserved word.  */
Index: version.h
===================================================================
--- version.h	(revision 13765)
+++ version.h	(revision 13766)
@@ -1,7 +1,7 @@
 #define RUBY_VERSION "1.9.0"
-#define RUBY_RELEASE_DATE "2007-10-23"
+#define RUBY_RELEASE_DATE "2007-10-24"
 #define RUBY_VERSION_CODE 190
-#define RUBY_RELEASE_CODE 20071023
+#define RUBY_RELEASE_CODE 20071024
 #define RUBY_PATCHLEVEL 0
 
 #define RUBY_VERSION_MAJOR 1
@@ -9,7 +9,7 @@
 #define RUBY_VERSION_TEENY 0
 #define RUBY_RELEASE_YEAR 2007
 #define RUBY_RELEASE_MONTH 10
-#define RUBY_RELEASE_DAY 23
+#define RUBY_RELEASE_DAY 24
 
 #ifdef RUBY_EXTERN
 RUBY_EXTERN const char ruby_version[];

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml

[前][次][番号順一覧][スレッド一覧]