mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/rss/rss.rb: fixed a indentation bug.
* lib/rss/taxonomy.rb: fixed <taxo:topic> #to_s bug. * test/rss/test_taxonomy.rb: added a #to_s test. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@9595 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
7ff5d02f8b
commit
f988ceb53b
4 changed files with 37 additions and 12 deletions
|
@ -1,3 +1,11 @@
|
||||||
|
Wed Nov 23 17:42:24 2005 Kouhei Sutou <kou@cozmixng.org>
|
||||||
|
|
||||||
|
* lib/rss/rss.rb: fixed a indentation bug.
|
||||||
|
|
||||||
|
* lib/rss/taxonomy.rb: fixed <taxo:topic> #to_s bug.
|
||||||
|
|
||||||
|
* test/rss/test_taxonomy.rb: added a #to_s test.
|
||||||
|
|
||||||
Wed Nov 23 03:40:49 2005 Guy Decoux <ts@moulon.inra.fr>
|
Wed Nov 23 03:40:49 2005 Guy Decoux <ts@moulon.inra.fr>
|
||||||
|
|
||||||
* re.c (KR_REHASH): should cast to unsigned for 64bit CPU.
|
* re.c (KR_REHASH): should cast to unsigned for 64bit CPU.
|
||||||
|
|
|
@ -725,8 +725,8 @@ EOC
|
||||||
private_methods.each do |meth|
|
private_methods.each do |meth|
|
||||||
if /\A([^_]+)_[^_]+_elements?\z/ =~ meth and
|
if /\A([^_]+)_[^_]+_elements?\z/ =~ meth and
|
||||||
self.class::NSPOOL.has_key?($1)
|
self.class::NSPOOL.has_key?($1)
|
||||||
res = __send__(meth, need_convert)
|
res = __send__(meth, need_convert, indent)
|
||||||
rv << "#{indent}#{res}" if /\A\s*\z/ !~ res
|
rv << res if /\A\s*\z/ !~ res
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
rv.join("\n")
|
rv.join("\n")
|
||||||
|
|
|
@ -163,7 +163,6 @@ module RSS
|
||||||
def to_s(need_convert=true, indent=calc_indent)
|
def to_s(need_convert=true, indent=calc_indent)
|
||||||
rv = tag(indent) do |next_indent|
|
rv = tag(indent) do |next_indent|
|
||||||
[
|
[
|
||||||
link_element(need_convert, next_indent),
|
|
||||||
other_element(need_convert, next_indent),
|
other_element(need_convert, next_indent),
|
||||||
]
|
]
|
||||||
end
|
end
|
||||||
|
@ -189,6 +188,12 @@ module RSS
|
||||||
[@taxo_link, @taxo_topics]
|
[@taxo_link, @taxo_topics]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def _attrs
|
||||||
|
[
|
||||||
|
["#{RDF::PREFIX}:about", true, "about"]
|
||||||
|
]
|
||||||
|
end
|
||||||
|
|
||||||
def _tags
|
def _tags
|
||||||
rv = []
|
rv = []
|
||||||
rv << [TAXO_URI, "link"] unless @taxo_link.nil?
|
rv << [TAXO_URI, "link"] unless @taxo_link.nil?
|
||||||
|
|
|
@ -20,7 +20,7 @@ module RSS
|
||||||
@dc_prefix => @dc_uri,
|
@dc_prefix => @dc_uri,
|
||||||
}
|
}
|
||||||
|
|
||||||
@parents = %w(channel item)
|
@topics_parents = %w(channel item)
|
||||||
|
|
||||||
@topics_lis = [
|
@topics_lis = [
|
||||||
"http://meerkat.oreillynet.com/?c=cat23",
|
"http://meerkat.oreillynet.com/?c=cat23",
|
||||||
|
@ -66,28 +66,28 @@ module RSS
|
||||||
info.each do |name, value|
|
info.each do |name, value|
|
||||||
case name
|
case name
|
||||||
when :topics
|
when :topics
|
||||||
rv << "<#{@prefix}:topics>\n"
|
rv << " <#{@prefix}:topics>\n"
|
||||||
rv << " <rdf:Bag>\n"
|
rv << " <rdf:Bag>\n"
|
||||||
value.each do |li|
|
value.each do |li|
|
||||||
resource = CGI.escapeHTML(li)
|
resource = CGI.escapeHTML(li)
|
||||||
rv << " <rdf:li resource=\"#{resource}\"/>\n"
|
rv << " <rdf:li resource=\"#{resource}\"/>\n"
|
||||||
end
|
end
|
||||||
rv << " </rdf:Bag>\n"
|
rv << " </rdf:Bag>\n"
|
||||||
rv << "</#{@prefix}:topics>"
|
rv << " </#{@prefix}:topics>\n"
|
||||||
else
|
else
|
||||||
prefix = (name == :link ? @prefix : @dc_prefix)
|
prefix = (name == :link ? @prefix : @dc_prefix)
|
||||||
rv << " <#{prefix}:#{name}>#{value}</#{prefix}:#{name}>\n"
|
rv << " <#{prefix}:#{name}>#{value}</#{prefix}:#{name}>\n"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
rv << "</#{@prefix}:topic>"
|
rv << "</#{@prefix}:topic>"
|
||||||
end.join("\n")
|
end
|
||||||
|
|
||||||
@rss_source = make_RDF(<<-EOR, @ns)
|
@rss_source = make_RDF(<<-EOR, @ns)
|
||||||
#{make_channel(@topics_node)}
|
#{make_channel(@topics_node)}
|
||||||
#{make_image()}
|
#{make_image()}
|
||||||
#{make_item(@topics_node)}
|
#{make_item(@topics_node)}
|
||||||
#{make_textinput()}
|
#{make_textinput()}
|
||||||
#{@topic_nodes}
|
#{@topic_nodes.join("\n")}
|
||||||
EOR
|
EOR
|
||||||
|
|
||||||
@rss = Parser.parse(@rss_source)
|
@rss = Parser.parse(@rss_source)
|
||||||
|
@ -138,10 +138,22 @@ EOR
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_to_s
|
def test_to_s
|
||||||
@parents.each do |parent|
|
@topics_parents.each do |parent|
|
||||||
meth = "taxo_topics_element"
|
meth = "taxo_topics_element"
|
||||||
assert_equal(@topics_node, @rss.__send__(parent).funcall(meth))
|
assert_equal(@topics_node, @rss.__send__(parent).funcall(meth))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@topic_nodes.each_with_index do |node, i|
|
||||||
|
expected = REXML::Document.new(node).root
|
||||||
|
actual = REXML::Document.new(@rss.taxo_topics[i].to_s(true, "")).root
|
||||||
|
expected_elems = expected.children.reject {|x| x.is_a?(REXML::Text)}
|
||||||
|
actual_elems = actual.children.reject {|x| x.is_a?(REXML::Text)}
|
||||||
|
expected_elems.sort! {|x, y| x.name <=> y.name}
|
||||||
|
actual_elems.sort! {|x, y| x.name <=> y.name}
|
||||||
|
assert_equal(expected_elems.collect {|x| x.to_s},
|
||||||
|
actual_elems.collect {|x| x.to_s})
|
||||||
|
assert_equal(expected.attributes.sort, actual.attributes.sort)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Reference in a new issue