diff options
| author | kou <kou@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-12-11 12:06:26 +0000 |
|---|---|---|
| committer | kou <kou@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-12-11 12:06:26 +0000 |
| commit | e6eb9e35f17930fa6cf49d823a52fc4e8e3774c0 (patch) | |
| tree | cb1d87a72fd558e9b97ac2f9811ce47bc5809a62 /lib/rss | |
| parent | 1f0dca2c56f3bb11d0eefda3e79a0a5a191d2940 (diff) | |
| download | ruby-e6eb9e35f17930fa6cf49d823a52fc4e8e3774c0.tar.gz ruby-e6eb9e35f17930fa6cf49d823a52fc4e8e3774c0.tar.xz ruby-e6eb9e35f17930fa6cf49d823a52fc4e8e3774c0.zip | |
* lib/rss/maker.rb, lib/rss/maker/0.9.rb, lib/rss/maker/base.rb:
RSS::Maker.[] returns a maker class corresponds to passed version.
* test/rss/test_maker_*.rb: add tests for RSS::Maker.[].
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@20643 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/rss')
| -rw-r--r-- | lib/rss/maker.rb | 5 | ||||
| -rw-r--r-- | lib/rss/maker/0.9.rb | 54 | ||||
| -rw-r--r-- | lib/rss/maker/base.rb | 6 |
3 files changed, 52 insertions, 13 deletions
diff --git a/lib/rss/maker.rb b/lib/rss/maker.rb index ff32f5cb0..ed3fff47d 100644 --- a/lib/rss/maker.rb +++ b/lib/rss/maker.rb @@ -6,14 +6,13 @@ module RSS class << self def make(version, &block) - maker_info = self[version] - maker_info[:maker].make(maker_info[:version], &block) + self[version].make(&block) end def [](version) maker_info = maker(version) raise UnsupportedMakerVersionError.new(version) if maker_info.nil? - maker_info + maker_info[:maker] end def add_maker(version, normalized_version, maker) diff --git a/lib/rss/maker/0.9.rb b/lib/rss/maker/0.9.rb index 72b14dc97..cc7db8c63 100644 --- a/lib/rss/maker/0.9.rb +++ b/lib/rss/maker/0.9.rb @@ -7,7 +7,7 @@ module RSS class RSS09 < RSSBase - def initialize(feed_version="0.92") + def initialize(feed_version) super @feed_type = "rss" end @@ -457,11 +457,51 @@ module RSS end end end - - add_maker("0.9", "0.92", RSS09) - add_maker("0.91", "0.91", RSS09) - add_maker("0.92", "0.92", RSS09) - add_maker("rss0.91", "0.91", RSS09) - add_maker("rss0.92", "0.92", RSS09) + + class RSS091 < RSS09 + def initialize(feed_version="0.91") + super + end + + class Channel < RSS09::Channel + end + + class Items < RSS09::Items + class Item < RSS09::Items::Item + end + end + + class Image < RSS09::Image + end + + class Textinput < RSS09::Textinput + end + end + + class RSS092 < RSS09 + def initialize(feed_version="0.92") + super + end + + class Channel < RSS09::Channel + end + + class Items < RSS09::Items + class Item < RSS09::Items::Item + end + end + + class Image < RSS09::Image + end + + class Textinput < RSS09::Textinput + end + end + + add_maker("0.9", "0.92", RSS092) + add_maker("0.91", "0.91", RSS091) + add_maker("0.92", "0.92", RSS092) + add_maker("rss0.91", "0.91", RSS091) + add_maker("rss0.92", "0.92", RSS092) end end diff --git a/lib/rss/maker/base.rb b/lib/rss/maker/base.rb index 2262a764e..3a7d255ae 100644 --- a/lib/rss/maker/base.rb +++ b/lib/rss/maker/base.rb @@ -374,8 +374,8 @@ module RSS class RSSBase < Base class << self - def make(version, &block) - new(version).make(&block) + def make(*args, &block) + new(*args).make(&block) end end @@ -384,7 +384,7 @@ module RSS add_need_initialize_variable(element) do |object| object.send("make_#{element}") end - module_eval(<<-EOC, __FILE__, __LINE__) + module_eval(<<-EOC, __FILE__, __LINE__ + 1) private def setup_#{element}(feed) @#{element}.to_feed(feed) |
