diff options
author | kou <kou@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-06-18 09:22:12 +0000 |
---|---|---|
committer | kou <kou@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-06-18 09:22:12 +0000 |
commit | c849d2692ba964baabf536024a24b164ca622510 (patch) | |
tree | ab54ab154fa8ec3327adc9dbbf17fe828e595539 /lib/rss/taxonomy.rb | |
parent | e49a4c952cfdf32abf3d6ba946f94d152dae988d (diff) |
* lib/rss/rss.rb: improved ignore_unknown_element
handling. RSS::NotExpectedTagError provides tag URI.
* lib/rss/parser.rb: ditto.
* lib/rss/0.9.rb: ditto.
* lib/rss/1.0.rb: ditto.
* lib/rss/content.rb: ditto.
* lib/rss/dublincore.rb: ditto.
* lib/rss/image.rb: ditto.
* lib/rss/syndication.rb: ditto.
* lib/rss/taxonomy.rb: ditto.
* lib/rss/trackback.rb: ditto.
* test/rss/rss-assertions.rb: checked URI of not expected tag too.
* test/rss/test_parser.rb: ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@10313 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/rss/taxonomy.rb')
-rw-r--r-- | lib/rss/taxonomy.rb | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/lib/rss/taxonomy.rb b/lib/rss/taxonomy.rb index 93eeac7b98..5b7d33821d 100644 --- a/lib/rss/taxonomy.rb +++ b/lib/rss/taxonomy.rb @@ -32,7 +32,7 @@ module RSS klass.install_have_child_element(var_name) end - def taxo_validate(tags) + def taxo_validate(ignore_unknown_element, tags, uri) found_topics = false tags.each do |tag| if tag == "topics" @@ -41,7 +41,7 @@ module RSS else found_topics = true end - else + elsif !ignore_unknown_element raise UnknownTagError.new(tag, TAXO_URI) end end @@ -111,8 +111,8 @@ module RSS rv end - def rdf_validate(tags) - _validate(tags, [["Bag", nil]]) + def rdf_validate(ignore_unknown_element, tags, uri) + _validate(ignore_unknown_element, tags, uri, [["Bag", nil]]) end end end @@ -126,9 +126,9 @@ module RSS klass.install_have_children_element(var_name) end - def taxo_validate(tags) + def taxo_validate(ignore_unknown_element, tags, uri) tags.each do |tag| - if tag != "topic" + if !ignore_unknown_element and tag != "topic" raise UnknownTagError.new(tag, TAXO_URI) end end @@ -172,7 +172,7 @@ module RSS end end - def taxo_validate(tags) + def taxo_validate(ignore_unknown_element, tags, uri) elements = %w(link topics) counter = {} @@ -181,7 +181,7 @@ module RSS counter[tag] ||= 0 counter[tag] += 1 raise TooMuchTagError.new(tag, tag_name) if counter[tag] > 1 - else + elsif !ignore_unknown_element raise UnknownTagError.new(tag, TAXO_URI) end end |