[#29374] nil.to_s — Shugo Maeda <shugo@...>

前田です。

59 messages 2006/09/01
[#29375] Re: nil.to_s — "U.Nakamura" <usa@...> 2006/09/01

こんにちは、なかむら(う)です。

[#29380] Re: nil.to_s — Yukihiro Matsumoto <matz@...> 2006/09/01

まつもと ゆきひろです

[#29387] Re: nil.to_s — Shugo Maeda <shugo@...> 2006/09/01

前田です。

[#29390] Re: nil.to_s — Yukihiro Matsumoto <matz@...> 2006/09/01

まつもと ゆきひろです

[#29398] Re: nil.to_s — "NARUSE, Yui" <naruse@...> 2006/09/01

成瀬です。

[#29400] Re: nil.to_s — Yukihiro Matsumoto <matz@...> 2006/09/01

まつもと ゆきひろです

[#29491] symbol and string — Tanaka Akira <akr@...>

open-uri で :proxy=>nil という指定を行うと、以下のようにエラーになります。

33 messages 2006/09/05
[#29499] Re: symbol and string — Yukihiro Matsumoto <matz@...> 2006/09/05

まつもと ゆきひろです

[#29500] Re: symbol and string — Tanaka Akira <akr@...> 2006/09/05

In article <1157470154.047826.13379.nullmailer@x31.priv.netlab.jp>,

[#29503] Re: symbol and string — Yukihiro Matsumoto <matz@...> 2006/09/06

まつもと ゆきひろです

[#29504] Re: symbol and string — Tanaka Akira <akr@...> 2006/09/06

In article <1157505538.340126.8472.nullmailer@x31.priv.netlab.jp>,

[#29507] Re: symbol and string — Yukihiro Matsumoto <matz@...> 2006/09/06

まつもと ゆきひろです

[#29512] Re: symbol and string — keiju@... (石塚圭樹) 2006/09/06

けいじゅ@いしつかです.

[#29529] Re: symbol and string — SASADA Koichi <ko1@...> 2006/09/08

 ささだです。

[#29530] Re: symbol and string — Yukihiro Matsumoto <matz@...> 2006/09/08

まつもと ゆきひろです

[ruby-dev:29482] Re: nil.to_s

From: "NARUSE, Yui" <naruse@...>
Date: 2006-09-04 23:25:45 UTC
List: ruby-dev #29482
成瀬です。

Tatsuki Sugiura wrote:
> 個人的には成瀬さんの書かれている、
> 
>>>> In Message "[ruby-dev:29419] Re: nil.to_s"
>>>>            <44FA2227.9010209@airemix.com>,
>>>> "NARUSE, Yui" <naruse@airemix.com>  said;
>> nil は例外の一種だと思っています。
>> http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-dev/7999
>> を見るともともと IndexError だったようですし。
> 
>> あくまでエラー値であり、無というよりも悪意のこもった無だけれど、
>> 強制的に変換した場合は、「なかったことにする」零元になる、とか。
> 
> と言うエラー値の話が個人的には一番しっくりきます。

賛同ありがとうございます(ぉ

> ただ、「なんにもない」と「なんでもない」は概念的にはかなり違いがあるん
> ではないでしょうか。nil が「なんでもない」というか「未定義/不明」を
> 表すものなら、"nil" という文字列を返すよりも、いっそ全部のメソッドが
> 失敗するようにしておくのが自然に思えます。

現在の Ruby の組み込みクラスで、nil の意味をざっと調べてみました。
* array[2..5] = nil (配列の範囲削除)
* print "hoge" の戻り値 (void)
* hash[key] のような「IndexError」の nil
* str.capitalize! のような「変更なし」の nil
* IO#close のような「成功」の nil
* /a/=~'B' で返る「失敗」の nil
* EOF に達した時の nil
* IO#readlines の行区切り指定等、デフォルト値を用いることを示す nil

ちょっと意外だったのは、TypeError に相当するものが無いことと、
明らかな「未定義/不明」が無いことでしょうか。
Ruby が 代入 = 宣言 であることの影響なのですかね。

to_s はそもそも String でないものを String にするものですから、
String 自身のような自明のもの以外をどこまで変換可能かは程度の問題で、
どれが自然というのはそこまでないように感じます。
なので、全てが String になる、方が、人工的ではあれど一貫性があるかと。
# 自明なものを変換するために to_str がありますね

むしろ to_s とは何か、が問題なのですかね、
Array#to_s や Hash#to_s のことも考えると。

# Ruby の nil を見ていると、攻殻機動隊でのタチコマの言葉を思い出します。
# 「神は 0 と似ているのではないか。
#  システムをシステムたらしめるための存在なんだろう」という

-- 
NARUSE, Yui  <naruse@airemix.com>
DBDB A476 FDBD 9450 02CD 0EFC BCE3 C388 472E C1EA

In This Thread