[#11357] [PATCH] an analogue of `long long' — "Nobuyoshi.Nakada" <nobu.nakada@...>
なかだです。
まつもと ゆきひろです
えぐち@エスアンドイー です。
まつもと ゆきひろです
えぐち@エスアンドイー です。
まつもと ゆきひろです
>From: matz@zetabits.com (Yukihiro Matsumoto)
まつもと ゆきひろです
[#11440] class Character (was: Ruby I18N) — Yasushi Shoji <yashi@...>
[ruby-dev:11428] からの続きですが、threadは切りました。
高橋征義です。用語について。
At Wed, 8 Nov 2000 20:44:55 +0900,
高橋征義です。
At Thu, 9 Nov 2000 13:30:34 +0900,
まつもと ゆきひろです
[#11447] gets は secure? — Kazuhiro NISHIYAMA <zn@...>
出力がInsecureなのに入力はsecureなのでしょうか?
[#11467] debug write in regex.c? — "Nobuyoshi.Nakada" <nobu.nakada@...>
なかだです。
[#11500] rb_to_integer/rb_to_int — "Nobuyoshi.Nakada" <nobu.nakada@...>
なかだです。
[#11520] A problem of Socket methods on Windows — OKA Toshiyuki <oka@...>
岡と申します。
なかだです。
まつもと ゆきひろです
なかだです。
岡です。
なかだです。
なかだです。
岡です。
なかだです。
[#11569] blocking on socket? — Shugo Maeda <shugo@...>
前田です。
[#11591] object.c パッチ — Kazuhiro NISHIYAMA <zn@...>
使われてなかったnil_plusの削除とOBJ_INFECTへの変更です。
[#11611] return value of waitpid2 — Koji Arai <JCA02266@...>
新井です。
まつもと ゆきひろです
荒井です。いや、新井です。(よくあることさ)
まつもと ゆきひろです
新井です。
新井です。
[#11618] Re: class variable — "Koji Arai" <jca02266@...>
新井です
なかだです。
まつもと ゆきひろです
> まつもと ゆきひろです
まつもと ゆきひろです
まつもと ゆきひろです
新井です。
[#11641] eval too slow — Wakou Aoyama <wakou@...>
青山です。
[#11650] conflict of NODE_DREGX_ONCE — "Nobuyoshi.Nakada" <nobu.nakada@...>
なかだです。
まつもと ゆきひろです
[#11662] IO (Re: fork problem?) — Tanaka Akira <akr@...17n.org>
In article <E140cR3-0002ls-00@ev.netlab.zetabits.co.jp>,
まつもと ゆきひろです
In article <E140fxW-0002u9-00@ev.netlab.zetabits.co.jp>,
In article <hvor93w5wb8.fsf@coulee.m17n.org>,
In article <hvoofz05uwz.fsf@coulee.m17n.org>,
まつもと ゆきひろです
新井です。
まつもと ゆきひろです
In article <E141eaC-0003w0-00@ev.netlab.zetabits.co.jp>,
まつもと ゆきひろです
In article <E142ZqF-0004rX-00@ev.netlab.zetabits.co.jp>,
まつもと ゆきひろです
In article <E143Zem-000271-00@ev.netlab.zetabits.co.jp>,
まつもと ゆきひろです
In article <E143amj-00028V-00@ev.netlab.zetabits.co.jp>,
[ruby-dev:11662] IO (Re: fork problem?)
In article <E140cR3-0002ls-00@ev.netlab.zetabits.co.jp>,
matz@zetabits.com (Yukihiro Matsumoto) writes:
> そろそろ ruby-dev ですかね。
では。
> もうちょっと考えさせてください。F_DUPFDとかの問題もあります
> し。F_DUPFDではfのfdだけdupすればそれはそれで良いと言う考え
> 方もないではないですし。
私としては fcntl などのシステムコールが素直に表に出ているので、その操
作対象(file descriptor)も素直に表に出ていて欲しいなぁ、と思うわけです。
わざわざ dup して事態を複雑にすることはない、と。
ただ、たしかにふたつの file descriptor をひとつの IO オブジェクトにま
とめなければならない場合は存在するのでしょうが、その場合でも、fcntl と
かは別々に発行できるといいなぁ、と思います。
あと fcntl(2) を見直したのですが、dup して作った f2 に関していえば、ど
ちらかというと、F_SETFD だけを特別扱いした方がいい気がします。
# F_SETLKW を 2回やるとどうなるのだろう?
> |# fcntl といえば、O_NONBLOCK にして IO#read して EAGAIN になると途中ま
> |# で読んだぶんが蒸発してしまう、という話は報告しましたっけ?
>
> まだです。readの実装の問題ですかね。
思い起こしつつ再現実験をしてみました。
% (echo -n a; sleep 1; echo bcdef)|./ruby -e 'require "fcntl"
STDIN.fcntl(Fcntl::F_SETFL, Fcntl::O_NONBLOCK)
begin
p STDIN.read(2)
rescue Errno::EWOULDBLOCK
sleep 2
retry
end'
"bc"
こんなふうに最初の 1byte の "a" が蒸発してしまいます。つまり、
IO#read(2) の途中で例外が発生すると、それ以前に読まれたぶんが消えてし
まうわけです。
あと、なんか、試していたらこんなふうに Errno::E000 が発生することも発
見してしまいました。
% (echo a; sleep 1; echo b)|./ruby -e 'require "fcntl"
STDIN.fcntl(Fcntl::F_SETFL, Fcntl::O_NONBLOCK)
loop { begin p STDIN.read; rescue Errno::EWOULDBLOCK; end }'
-e:3:in `read': Undefined error: 0 (Errno::E000)
from -e:3
from -e:2:in `loop'
from -e:2
蒸発する方がバグか仕様かは非常に悩ましいのですが、Errno::E000 はバグな
気がします。
--
[田中 哲][たなか あきら][Tanaka Akira]
「くっだらないコト聞いちゃったねー$(C⊇ ごっめーん$(C⊇」
(魔法使い養成専門 マジックスター学院 2, 南澤ミヅキ)