[#39804] CGIでのリダイレクションの書き方 — Yoichiro Takehora <yoichiro@...>
こんにちは、竹洞です。
7 messages
2004/07/02
[#39811] keyword-argument-like argument passing via Hash — NISHIMATSU Takeshi <t-nissie@...>
西松と申します.
4 messages
2004/07/02
[#39814] Socket:IPヘッダの編集方法 — takeshi honda <moecho21@...>
本田と申します。
6 messages
2004/07/02
[#39819] [ANN] Ruby-GetText-Package-0.6.0 — Masao Mutoh <mutoh@...>
むとうです。
4 messages
2004/07/04
[#39822] (要素がString, Fixnum 以外の)配列の集合演算 — Hiroshi Takagi <gollum@...>
高木といいます、よろしく。
11 messages
2004/07/05
[#39823] Re: (要素がString, Fixnum 以外の)配列の集合演算
— 卜部昌平 <s-urabe@...>
2004/07/05
mput です。
[#39824] Re: (要素がString, Fixnum 以外の)配列の集合演算
— Hiroshi Takagi <gollum@...>
2004/07/05
高木です。
[#39826] Re: (要素がString, Fixnum 以外の)配列の集合演算
— nobu.nakada@...
2004/07/06
なかだです。
[#39856] 直接関係のない配列の有無が、ある配列の値に影響する不具合 — "Hisashi Yahata" <yahatah@...>
5 messages
2004/07/17
[#39863] forループの速度 — Masahiro Sato <msato@...>
15 messages
2004/07/20
[#39868] イテレータとfor文 — OOTANI TAKASHI <otn@...5.so-net.ne.jp>
大谷と申します。
31 messages
2004/07/20
[#39870] Re: イテレータとfor文
— Nowake <nowake@...>
2004/07/20
[#39886] Re: イテレータとfor文
— Tietew <tietew-ml-ruby-list@...>
2004/07/21
[#39891] Re: イテレータとfor文
— OOTANI TAKASHI <otn@...5.so-net.ne.jp>
2004/07/21
大谷です。
[#39910] Re: イテレータとfor文
— Atoh <atoh@...7.jp>
2004/07/23
あとうです。
[#39911] Re: イテレータとfor文
— OOTANI TAKASHI <otn@...5.so-net.ne.jp>
2004/07/23
大谷です。
[#39889] dRuby: 急に遅くなる — ちば けいすけ <chowder@...>
ちばです。
7 messages
2004/07/21
[#39908] htreeの高速化 — MoonWolf <moonwolf@...>
MoonWolfです。
6 messages
2004/07/23
[ruby-list:39812] Re: keyword-argument-like argument passing via Hash
From:
SASADA Koichi <ko1@...>
Date:
2004-07-02 11:54:53 UTC
List:
ruby-list #39812
NISHIMATSU Takeshi <t-nissie@imr.tohoku.ac.jp> wrote :
[ [ruby-list:39811] keyword-argument-like argument passing via Hash ]
at Fri, 2 Jul 2004 20:20:27 +0900
ささだです.
> た. しかし, Hashのキーのシンボルなどのtypo(綴り間違い)
> を検出して例外を揚げるうまい方法が思い浮かびません. 実際,
Hash のキーをチェックするなら,ハッシュのキーに変なもの
を指定されてたら例外を発生させればいいのではないでしょうか.
インスタンス変数のチェックは,簡単にはいかない気がします.
> when Hash
> __create do
> @attrib1 = arg[:attrib1] || arg['attrib1'] || @attrib1
> @attrib2 = arg[:attrib2] || arg['attrib2'] || @attrib2
> @attrib3 = arg[:attrib3] || arg['attrib3'] || @attrib3
> instance_eval(&block) unless block.nil?
> end
は,
when Hash
__create do
keys = ['attrib1', 'attrib2', 'attrib3']
arg.each{|k,v|
k = k.to_s
raise 'こんなキーしりません' unless keys.include?(k)
instance_variable_set('@'+k, v)
}
end
...
とか?
インスタンス変数の typo をチェックしたいのなら,セットする
前とあとで Object#instance_variables でチェックするってのは
手かもしれませんが,新しく追加されるインスタンス変数しかチェック
できないのであんまり使えない気がします.直接 instance_eval を
実行してしまうのは,ほかにも変なことやっちゃうかもしれないので,
できれば避けた方がいいんじゃないかと思います.
--
// SASADA Koichi at atdot dot net
//