[#32910] NKF,Kconv — Kazuhiro NISHIYAMA <zn@...>
西山和広です。
[#32913] openの"b"とencoding — Kazuhiro NISHIYAMA <zn@...>
西山和広です。
[#32922] SEGV by regexp match in while loop — Tanaka Akira <akr@...>
Debian GNU/Linux (sarge) の gcc-3.4 を使ってビルドした ruby
[#32935] queue and timeout — Tanaka Akira <akr@...>
timeout で Queue#pop に時間制限をつけた時、タイムアウト時に
まつもと ゆきひろです
[#32940] ripper cannot build on win32 — yukimi_sake <yukimi_sake@...>
雪見酒です。
[#32945] Shift_JIS variants and UTF-16 support — "U.Nakamura" <usa@...>
こんにちは、なかむら(う)です。
中村さん、こんにちは。
まつもと ゆきひろです
成瀬です。
まつもと ゆきひろです
こんにちは、なかむら(う)です。
成瀬です。
こんにちは、なかむら(う)です。
成瀬です。
こんにちは、なかむら(う)です。
まつもと ゆきひろです
[#32946] replica と alias の違い(encoding) — KIMURA Koichi <kimura.koichi@...>
木村です。
[#32987] error with open-uri (instance_eval?) — "U.Nakamura" <usa@...>
こんにちは、なかむら(う)です。
[#32988] Re: [ruby-cvs:22194] Ruby:r14957 (trunk): * encoding.c (rb_enc_init): UTF-{16,32}{BE,LE} are not builtin. — Yukihiro Matsumoto <matz@...>
まつもと ゆきひろです
[#32992] ASCII is alias of US-ASCII; replica of dummy encoding is not a dummy — "NARUSE, Yui" <naruse@...>
成瀬です。
まつもと ゆきひろです
At 18:13 08/01/09, Yukihiro Matsumoto wrote:
成瀬です。
まつもと ゆきひろです
成瀬です。
まつもと ゆきひろです
なかだです。
まつもと ゆきひろです
[#32996] binmode and ASCII-8BIT — Kazuhiro NISHIYAMA <zn@...>
西山和広です。
[#33069] Re: [ruby-cvs:22244] Ruby:r15007 (trunk): * enc/make_encdb.rb: added. search enc/*.c and make encoding database. — Yukihiro Matsumoto <matz@...>
まつもと ゆきひろです
まつもと ゆきひろです
[#33076] Encoding.compatible? and dummy encodings — sheepman <sheepman@...>
こんにちは sheepman です。
成瀬です。
まつもと ゆきひろです
[#33078] NEW REPLICA ENCODINGS AND ENCODING ALIASES — "NARUSE, Yui" <naruse@...>
成瀬です。
[#33101] String#valid_encoding? shoud be strict? — Masayoshi Takahashi <maki@...>
高橋征義です。1.9のエンコーディングとString#valid_encoding?について。
[#33139] Bignum#* might invoke GC parallelly? — "Yusuke ENDOH" <mame@...>
遠藤と申します。
[#33156] default script encoding and -K option — sheepman <sheepman@...>
こんばんは sheepman です。
こんにちは、なかむら(う)です。
まつもと ゆきひろです
[#33164] default encoding for Marshal.load — "Shugo Maeda" <shugo@...>
前田です。
まつもと ゆきひろです
[#33185] コンパイルの問題 (r15218) — Martin Duerst <duerst@...>
r15128 当たりで (実はもう少し前から) コンパイルできなくなりました。
[#33218] Re: Ruby1.9String バイト列へのインデックス アクセス — "Hisanori Kiryu" <hkiryu@...>
> ちなみに、byte のではなく bytes の方が妥当だと思います。
[#33224] printf "%0x" — Tanaka Akira <akr@...>
printf の %0x に負の整数を与えると、値によって .. がついたり
[#33226] [PATCH] warnings of enc/trans/utf_16_32.c — Nobuyoshi Nakada <nobu@...>
なかだです。
[#33239] Re: [ruby-cvs:22386] Ruby:r15149 (trunk): * string.c (rb_str_each_char): move forward. — Tanaka Akira <akr@...>
In article <200801210259.m0L2x3CW017171@ci.ruby-lang.org>,
なかだです。
In article <20080121065650.55F60E0662@mail.bc9.jp>,
なかだです。
まつもと ゆきひろです
[#33247] requests to transcode — "U.Nakamura" <usa@...>
こんにちは、なかむら(う)です。
[#33303] Time#strftimeのエンコーディング — rubikitch@...
るびきちです。
まつもと ゆきひろです
なかだです。
西山和広です。
[#33368] summary of script encoding — "U.Nakamura" <usa@...>
こんにちは、なかむら(う)です。
まつもと ゆきひろです
こんにちは、なかむら(う)です。
まつもと ゆきひろです
永井@知能.九工大です.
[#33387] HashからStructを作る — rubikitch@...
るびきちです。
まつもと ゆきひろです
From: Yukihiro Matsumoto <matz@ruby-lang.org>
まつもと ゆきひろです
From: Yukihiro Matsumoto <matz@ruby-lang.org>
まつもと ゆきひろです
From: Yukihiro Matsumoto <matz@ruby-lang.org>
まつもと ゆきひろです
[#33399] regexp match /.../n against to UTF-8 string — Tanaka Akira <akr@...>
以下のように、つけてもいない正規表現の n オプションに関して
[#33400] /#{}/e.encoding — Tanaka Akira <akr@...>
以下のように /#{}/e の encoding が US-ASCII になります。
[#33403] wrapped String#gsub — "Park Ji-In" <tisphie@...>
こんにちは、朴 芝印です。
[#33417] コンパイルの問題 — Martin Duerst <duerst@...>
現在 (r15264 で) コンパイル使用とすると、エラーになります:
At 16:28 08/01/27, you wrote:
[#33433] Win32OLE: set encoding to OLE string — "U.Nakamura" <usa@...>
こんにちは、なかむら(う)です。
成瀬です。
助田です。
こんにちは、なかむら(う)です。
こんにちは、なかむら(う)です。
[#33452] enc/euc_kr.c (euckr_mbc_enc_len) euc_kr.c is also used by CP942 — "NARUSE, Yui" <naruse@...>
成瀬です。
まつもと ゆきひろです
成瀬です。
[#33461] Failed to make ruby-1.8.6-p111 on MacOSX 10.5(Leopard) — MORITA Hideyuki <h-morita@...>
=1B$B?9ED$H?=3D$7$^$9!#=1B(B
なかだです。
森田です。
なかだです。
森田です。
天野竜太郎と申します。
森田です。
天野です。
森田です。
天野です。
森田です。
天野です。
森田です。
天野です。
[#33488] 現在の script encoding の値を得る方法は? — Hidetoshi NAGAI <nagai@...>
永井@知能.九工大です.
まつもと ゆきひろです
永井@知能.九工大です.
成瀬です。
永井@知能.九工大です.
成瀬です。
永井@知能.九工大です.
成瀬です。
In article <47A00E86.4010701@airemix.com>,
成瀬です。
In article <47A03C9D.2090008@airemix.com>,
In article <87hcgvu1ng.fsf@fsij.org>,
[#33521] nkf の CP932 — Martin Duerst <duerst@...>
成瀬さん、皆さん、こんにちは。
[#33548] block parameter of String#gsub — "NARUSE, Yui" <naruse@...>
成瀬です。
まつもと ゆきひろです
[ruby-dev:33277] Re: [ruby-cvs:22386] Ruby:r15149 (trunk): * string.c (rb_str_each_char): move forward.
なかだです。
At Mon, 21 Jan 2008 21:08:36 +0900,
Yukihiro Matsumoto wrote in [ruby-dev:33255]:
> ||freezeしたコピーを作っておいて、変更の影響を受けないようにすると
> ||いうのを思い付きました。当然のことながら格段に速くなるようです。
> |
> |んじゃ、この線でコミットしてください。
>
> 他のyieldを呼ぶメソッド(each_lineとかgsubとか)もコピーを作っ
> た方がよいでしょうか。
こんなとこでしょうか。
Index: string.c
===================================================================
--- string.c (revision 15173)
+++ string.c (working copy)
@@ -229,5 +229,5 @@ int rb_enc_str_asciionly_p(VALUE str)
static inline void
-str_mod_check(VALUE s, char *p, long len)
+str_mod_check(VALUE s, const char *p, long len)
{
if (RSTRING_PTR(s) != p || RSTRING_LEN(s) != len){
@@ -416,4 +416,6 @@ rb_str_new4(VALUE orig)
}
+#define rb_str_shadow(p) (*(volatile VALUE *)(p) = rb_str_new4(*(p)))
+
VALUE
rb_str_new5(VALUE obj, const char *ptr, long len)
@@ -4463,10 +4465,8 @@ rb_str_each_line(int argc, VALUE *argv,
{
rb_encoding *enc;
- VALUE rs;
+ VALUE self = str, rs, line;
int newline;
- char *p = RSTRING_PTR(str), *pend = p + RSTRING_LEN(str), *s = p;
- char *ptr = p;
- long len = RSTRING_LEN(str), rslen;
- VALUE line;
+ const char *p, *pend, *s, *ptr, *rsptr;
+ long len, rslen;
int n;
@@ -4480,7 +4480,13 @@ rb_str_each_line(int argc, VALUE *argv,
return str;
}
- StringValue(rs);
+
+ rb_str_shadow(&str);
enc = rb_enc_check(str, rs);
- if (rs == rb_default_rs) {
+ ptr = s = p = RSTRING_PTR(str);
+ len = RSTRING_LEN(str);
+ pend = p + len;
+
+ StringValue(rs);
+ if (rs == rb_default_rs || rb_str_shadow(&rs) == rb_default_rs) {
while (p < pend) {
n = rb_enc_mbclen(p, pend, enc);
@@ -4490,5 +4496,4 @@ rb_str_each_line(int argc, VALUE *argv,
rb_enc_copy(line, str);
rb_yield(line);
- str_mod_check(str, ptr, len);
s = p + n;
}
@@ -4498,4 +4503,5 @@ rb_str_each_line(int argc, VALUE *argv,
}
+ rsptr = RSTRING_PTR(rs);
rslen = RSTRING_LEN(rs);
if (rslen == 0) {
@@ -4503,5 +4509,5 @@ rb_str_each_line(int argc, VALUE *argv,
}
else {
- newline = rb_enc_codepoint(RSTRING_PTR(rs), RSTRING_END(rs), enc);
+ newline = rb_enc_codepoint(rsptr, rsptr+rslen, enc);
}
@@ -4517,10 +4523,9 @@ rb_str_each_line(int argc, VALUE *argv,
}
if (c == newline &&
- (rslen <= 1 || memcmp(RSTRING_PTR(rs), p, rslen) == 0)) {
+ (rslen <= 1 || memcmp(rsptr, p, rslen) == 0)) {
line = rb_str_new5(str, s, p - s + (rslen ? rslen : n));
OBJ_INFECT(line, str);
rb_enc_copy(line, str);
rb_yield(line);
- str_mod_check(str, ptr, len);
s = p + (rslen ? rslen : n);
}
@@ -4537,5 +4542,5 @@ rb_str_each_line(int argc, VALUE *argv,
}
- return str;
+ return self;
}
@@ -4570,11 +4575,16 @@ static VALUE
rb_str_each_byte(VALUE str)
{
- long i;
+ VALUE self = str;
+ const char *ptr;
+ long i, len;
RETURN_ENUMERATOR(str, 0, 0);
- for (i=0; i<RSTRING_LEN(str); i++) {
- rb_yield(INT2FIX(RSTRING_PTR(str)[i] & 0xff));
+ rb_str_shadow(&str);
+ ptr = RSTRING_PTR(str);
+ len = RSTRING_LEN(str);
+ for (i=0; i < len; i++) {
+ rb_yield(INT2FIX(ptr[i] & 0xff));
}
- return str;
+ return self;
}
@@ -4612,7 +4622,8 @@ rb_str_each_char(VALUE str)
const char *ptr;
rb_encoding *enc;
+ VALUE self = str;
RETURN_ENUMERATOR(str, 0, 0);
- str = rb_str_new4(str);
+ rb_str_shadow(&str);
ptr = RSTRING_PTR(str);
len = RSTRING_LEN(str);
@@ -4622,5 +4633,5 @@ rb_str_each_char(VALUE str)
rb_yield(rb_str_subseq(str, i, n));
}
- return str;
+ return self;
}
--
--- 僕の前にBugはない。
--- 僕の後ろにBugはできる。
中田 伸悦