[#37248] [Feature:1.9] Enumerator#inspect — "Yusuke ENDOH" <mame@...>

遠藤です。

12 messages 2008/12/02

[#37337] [Feature #841] Object#self — "rubikitch ." <redmine@...>

Feature #841: Object#self

13 messages 2008/12/09

[#37513] Current status of 1.9.1 RC1's issues — "Yugui (Yuki Sonoda)" <yugui@...>

Hi, folks

14 messages 2008/12/20
[#37516] Re: Current status of 1.9.1 RC1's issues — Masatoshi SEKI <m_seki@...> 2008/12/20

咳といいます。

[#37576] [BUG:trunk] encoding for stdio's — "Yugui (Yuki Sonoda)" <yugui@...>

Yuguiです。

11 messages 2008/12/24

[ruby-dev:37349] Re: RSS::Maker.create(version)

From: "Akinori MUSHA" <knu@...>
Date: 2008-12-10 13:22:07 UTC
List: ruby-dev #37349
At Wed, 10 Dec 2008 21:44:53 +0900,
Kouhei Sutou wrote:
>
> 須藤です。
>
> In <86bpvl3ayx.knu@iDaemons.org>
>   "[ruby-dev:37333] Re: RSS::Maker.create(version)" on Tue, 9 Dec 2008 19:15:04 +0900,
>   "Akinori MUSHA" <knu@iDaemons.org> wrote:
>
> >  ということで RSS::Maker[], RSS::Maker.find() ともに賛成です。
>
> RSS::Maker[]の方でコミットしました。
>
> で、コミットしてから気付いてしまったのですが、RSS::Maker[]で
> はクラスではなくオブジェクトを返した方が使いやすそうな気がし
> ました。(今はクラスですらなく、クラスとバージョンを持ってい
> るハッシュを返すようにしてしまったので、いずれにしても後で直
> します。)
>
> makerオブジェクトを作るときはフィードのバージョンを引数に与え
> ることができるのできます。これは、RSS 0.91と0.92を同じ
> RSS::Maker::RSS09クラスで対応しているためです。
>
> デフォルトでは、RSS::Maker::RSS09クラスは0.92用のRSSを生成し
> ます。0.91用のRSSを生成するためには明示的に0.91を指定する必
> 要があり、その場合はこのように書かなければいけなくなります。
>
>   maker = RSS::Maker["0.91"].new("0.91")
>   # 参考: 0.92の場合
>   #   maker = RSS::Maker["0.92"].new

 なるほど…。new()でも引数を取るのはどうしてだろうと思ったら
そういうことでしたか。まったく意識から抜けていました。

 RSS::Maker["0.9"].new("0.91") という形ならありだと思います。

 しかし、 0.91 と 0.92 のクラスが同じで new() の引数で分ける、
という実装上の都合はあまり利用者には意識させたくないですね。

 0.91 用にサブクラスを作り、 RSS::Maker["0.91"] と指定されたら
それを返すようにした方がいいかもしれません。

> そのため、RSS::Maker[]でクラスを返すのではなく、オブジェクト
> を返してこのように使えた方がよい気がするのですが、これでもよ
> いでしょうか?
>
>   maker = RSS::Maker["0.91"]

 コンテナの中身に(同じキーで)アクセスすると毎回新しいものが
出てくるというのは、少し違和感があるかも…。

 インスタンスを返す形だと、始めに戻ってしまいますが

    maker = RSS::Maker.create("0.91")

の方が読みやすく感じます。create という語にはやはり強い抵抗を
お感じになるでしょうか。

--
Akinori MUSHA / http://akinori.org/

In This Thread