summaryrefslogtreecommitdiff
path: root/lib/rss/taxonomy.rb
diff options
context:
space:
mode:
authorkou <kou@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-06-18 09:22:12 +0000
committerkou <kou@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-06-18 09:22:12 +0000
commitc849d2692ba964baabf536024a24b164ca622510 (patch)
treeab54ab154fa8ec3327adc9dbbf17fe828e595539 /lib/rss/taxonomy.rb
parente49a4c952cfdf32abf3d6ba946f94d152dae988d (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.rb16
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