[#38241] MinGW における拡張ライブラリ作成と Ruby 1.8/1.9 共存について — Hajime Hoshi <hajimehoshi@...>
星と申します。
8 messages
2009/04/01
[#38252] Hashのデフォルト値のブロックで無限ループするとcore — "KISHIMOTO, Makoto" <ksmakoto@...4u.or.jp>
きしもとです
7 messages
2009/04/02
[#38284] Re: Hashのデフォルト値のブロックで無限ループするとcore
— Yukihiro Matsumoto <matz@...>
2009/04/06
まつもと ゆきひろです
[#38255] --program-suffix 指定時の ri の探索先あるいは rdoc のインストール先 — "KISHIMOTO, Makoto" <ksmakoto@...4u.or.jp>
きしもとです
7 messages
2009/04/02
[#38278] [BUG:1.9] io does not convert str when ext == intern — sheepman <sh@...>
こんばんは sheepman です。
6 messages
2009/04/05
[#38303] [BUG:1.9] Dir.glob should not convert entries on UNIX — sheepman <sh@...>
こんばんは sheepman です。
5 messages
2009/04/11
[#38309] [Feature:1.9] transcode for UTF8-MAC — sheepman <sh@...>
こんばんは sheepman です。
8 messages
2009/04/16
[#38323] [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合 — oshida@...
押田です。
22 messages
2009/04/24
[#38331] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— Hidetoshi NAGAI <nagai@...>
2009/04/26
永井@知能.九工大です.
[#38339] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— oshida@...
2009/04/27
押田です。
[#38340] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— Hidetoshi NAGAI <nagai@...>
2009/04/27
永井@知能.九工大です.
[#38697] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— Hidetoshi NAGAI <nagai@...>
2009/06/21
永井@知能.九工大です.
[#38711] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— oshida@...
2009/06/24
押田です。
[#38723] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— Hidetoshi NAGAI <nagai@...>
2009/07/01
永井@知能.九工大です.
[#38743] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— oshida@...
2009/07/07
押田です。
[#38747] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— Hidetoshi NAGAI <nagai@...>
2009/07/08
永井@知能.九工大です.
[#38748] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— oshida@...
2009/07/08
押田です。
[#38749] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— Hidetoshi NAGAI <nagai@...>
2009/07/08
永井@知能.九工大です.
[#38750] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— oshida@...
2009/07/08
押田です。
[#38752] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— Hidetoshi NAGAI <nagai@...>
2009/07/08
永井@知能.九工大です.
[#38754] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— oshida@...
2009/07/09
押田です。
[#38755] Re: [1.8.7][1.9.1][tk] 自前実装の拡張 widget を使いたい場合
— Hidetoshi NAGAI <nagai@...>
2009/07/09
永井@知能.九工大です.
[#38326] Time with arbitrary offset — Tanaka Akira <akr@...>
Time で、オブジェクト毎に任意の時差を指定できるようにするの
9 messages
2009/04/25
[#38338] Re: Time with arbitrary offset
— Yukihiro Matsumoto <matz@...>
2009/04/26
まつもと ゆきひろです
[#38341] Re: Time with arbitrary offset
— Tanaka Akira <akr@...>
2009/04/27
In article <E1LyBkf-0000x1-UO@x61.netlab.jp>,
[#38348] Re: Time with arbitrary offset
— Yukihiro Matsumoto <matz@...>
2009/04/27
まつもと ゆきひろです
[#38353] Re: Time with arbitrary offset
— Tanaka Akira <akr@...>
2009/04/28
In article <E1LyTuj-0003h2-28@x61.netlab.jp>,
[#38336] [Bug #1410] irb shows some messages on boot — Nobuhiro IMAI <redmine@...>
Bug #1410: irb shows some messages on boot
6 messages
2009/04/26
[ruby-dev:38274] Re: big time
From:
Tanaka Akira <akr@...>
Date:
2009-04-04 05:36:11 UTC
List:
ruby-dev #38274
In article <49D5FA02.6090809@ruby-lang.org>, Urabe Shyouhei <shyouhei@ruby-lang.org> writes: > なるほど。検査メソッドという表現から述語メソッドを想像していましたが、例外を発 > 生するメソッドであればありかもしれないと思います。 あとからもうひとつの可能性を考えつきました。 もしかして、卜部さんが想定する TypeError というのは、 File.utime が発生するものだったりしませんか? File.utime が発生する例外については、サブクラスを作らなくて も「時刻が time_t の範囲外である」というメッセージで例外を発 生するのは簡単だし、そうすべきだと思います。 > 利点がないんでしょうか。ライブラリ作者が責任範囲を明確にできるのは利点ではない > ですかね。それがアプリケーション開発者の不幸に繋がるかは分かりませんが。 どう明確になるんでしょう? File.utime に渡す時刻を引数に指定するのがアプリケーションの 責任なら、それはそれで明確ではないですか? それに失敗したら time_t の範囲外という例外が出るわけですし。 > utimeの直後にfstatで確認するとか。いやもちろん競合状態でうまくいかないのは理解 > できますので、難しそうかなとは思いますが。 GNU/Linux で VFAT なファイルシステムを mount して あるファイルを 1970-01-01 に File.utime すると、失敗しないし、 stat すると設定できたように見えるんだけど、マウントし直すと 1980-01-01 になっているという現象を見つけてしまいました。 stat しても実際になにが起きているのかはわからないようです。 > [ruby-dev:38202] のケースを救いたいです。 読み直してみました。 touch クローンであれば、コマンドライン引数解釈器が生成した Time オブジェクトがそのまま File.utime までたどりつくでしょ うから、File.utime が「time_t の範囲外である」というメッセー ジで失敗すれば、Time オブジェクトを生成した、touch クローン の作者が問題を見つけるのは別に難しくないのではないでしょうか。 ライブラリ側からから見ると、アプリケーションから渡された Time オブジェクトをそのまま File.utime に渡している限り、そ のエラーメッセージは外部の問題であることを明らかに示している のでその旨を述べてバグレポートを却下すればいいのではないでしょ うか。 >> その解決による利点は、互換性を損なうことを含む欠点よりも大き >> なものですか? > > 前から理解できないので言及してこなかったわけですが、その大きさってのはどうやっ > て定量的に評価するんですか?大きさを比較するには量的な評価ができないことには不可 > 能だと思います。 File.utime が Time オブジェクトを受け付けなくなると、 いままで File.utime に Time を渡していたすべてのコードで問題 が起きます。 それに対して、File.utime が、time_t の範囲外の Time オブジェ クトを受け付けないというのは、すべてよりは少ないコードでしか 問題が起きないでしょう。 卜部さんが救いたいというのは後者に関する話ですが、それは前者 の問題よりは少ないでしょう。 また、File.utime がなんらかの範囲外でうまく動かないという意 味で、似た問題は 64bit time_t で NFSv3 とか GNU/Linux で VFAT とか既にあるので、そこからの類推も可能です。ML の過去の メールを検索しても範囲外の問題と明確にわかるものはありません でした。これから類推すると問題は例外的な話におさまるでしょう。 あと、前から、ということなので、Time を拡大する利点と それによる File.utime に対する欠点の比較についても触れておき ます。 利点のほうが大きいと私が考えるのは、Time を使うケースと File.utime を使うケースで前者がずっと多いという経験から来て います。 このことは、Google Code Seach で検索すると * lang:ruby Time が約230,000件 * lang:ruby File.utime が 924件 という数になることからも裏付けられます。Time 検索結果がすべ て Time クラスを指しているわけではないでしょうが、これだけの 差があれば、Time クラスがずいぶんと多いのは確かでしょう。 (実際、検索結果を眺めると、1/100 よりはずいぶんと大きな割合 で Time クラスを使うコードがヒットしています) 従って、ある変更によって、File.utime に使うときの欠点とそれ 以外での利点が両方あった場合、実際に使う回数を考えると、利点 のほうがずっと多くなることが推測できます。 -- [田中 哲][たなか あきら][Tanaka Akira]