mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* sample/rss/list_description.rb: untabified.
* sample/rss/rss_recent.rb: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@7389 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
5e5fe659fa
commit
b325d73c13
3 changed files with 120 additions and 114 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
Sat Nov 27 17:21:30 2004 Kouhei Sutou <kou@cozmixng.org>
|
||||||
|
|
||||||
|
* sample/rss/list_description.rb: untabified.
|
||||||
|
|
||||||
|
* sample/rss/rss_recent.rb: ditto.
|
||||||
|
|
||||||
Sat Nov 27 09:41:21 2004 Yukihiro Matsumoto <matz@ruby-lang.org>
|
Sat Nov 27 09:41:21 2004 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
* io.c (io_fread): [ruby-dev:24964]
|
* io.c (io_fread): [ruby-dev:24964]
|
||||||
|
|
|
@ -2,12 +2,12 @@
|
||||||
|
|
||||||
require "nkf"
|
require "nkf"
|
||||||
class String
|
class String
|
||||||
# From tdiary.rb
|
# From tdiary.rb
|
||||||
def shorten( len = 120 )
|
def shorten( len = 120 )
|
||||||
lines = NKF::nkf( "-e -m0 -f#{len}", self.gsub( /\n/, ' ' ) ).split( /\n/ )
|
lines = NKF::nkf( "-e -m0 -f#{len}", self.gsub( /\n/, ' ' ) ).split( /\n/ )
|
||||||
lines[0].concat( '...' ) if lines[0] and lines[1]
|
lines[0].concat( '...' ) if lines[0] and lines[1]
|
||||||
lines[0]
|
lines[0]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
require "rss/1.0"
|
require "rss/1.0"
|
||||||
|
@ -18,66 +18,66 @@ channels = {}
|
||||||
verbose = false
|
verbose = false
|
||||||
|
|
||||||
def error(exception)
|
def error(exception)
|
||||||
mark = "=" * 20
|
mark = "=" * 20
|
||||||
mark = "#{mark} error #{mark}"
|
mark = "#{mark} error #{mark}"
|
||||||
puts mark
|
puts mark
|
||||||
puts exception.class
|
puts exception.class
|
||||||
puts exception.message
|
puts exception.message
|
||||||
puts exception.backtrace
|
puts exception.backtrace
|
||||||
puts mark
|
puts mark
|
||||||
end
|
end
|
||||||
|
|
||||||
before_time = Time.now
|
before_time = Time.now
|
||||||
ARGV.each do |fname|
|
ARGV.each do |fname|
|
||||||
if fname == '-v'
|
if fname == '-v'
|
||||||
verbose = true
|
verbose = true
|
||||||
next
|
next
|
||||||
end
|
end
|
||||||
rss = nil
|
rss = nil
|
||||||
f = File.new(fname).read
|
f = File.new(fname).read
|
||||||
begin
|
begin
|
||||||
## do validate parse
|
## do validate parse
|
||||||
rss = RSS::Parser.parse(f)
|
rss = RSS::Parser.parse(f)
|
||||||
rescue RSS::InvalidRSSError
|
rescue RSS::InvalidRSSError
|
||||||
error($!) if verbose
|
error($!) if verbose
|
||||||
## do non validate parse for invalid RSS 1.0
|
## do non validate parse for invalid RSS 1.0
|
||||||
begin
|
begin
|
||||||
rss = RSS::Parser.parse(f, false)
|
rss = RSS::Parser.parse(f, false)
|
||||||
rescue RSS::Error
|
rescue RSS::Error
|
||||||
## invalid RSS.
|
## invalid RSS.
|
||||||
error($!) if verbose
|
error($!) if verbose
|
||||||
end
|
end
|
||||||
rescue RSS::Error
|
rescue RSS::Error
|
||||||
error($!) if verbose
|
error($!) if verbose
|
||||||
end
|
end
|
||||||
if rss.nil?
|
if rss.nil?
|
||||||
puts "#{fname} does not include RSS 1.0 or 0.9x/2.0"
|
puts "#{fname} does not include RSS 1.0 or 0.9x/2.0"
|
||||||
else
|
else
|
||||||
begin
|
begin
|
||||||
rss.output_encoding = "euc-jp"
|
rss.output_encoding = "euc-jp"
|
||||||
rescue RSS::UnknownConversionMethodError
|
rescue RSS::UnknownConversionMethodError
|
||||||
error($!) if verbose
|
error($!) if verbose
|
||||||
end
|
end
|
||||||
rss.channel.title ||= "Unknown"
|
rss.channel.title ||= "Unknown"
|
||||||
rss.items.each do |item|
|
rss.items.each do |item|
|
||||||
item.title ||= "Unknown"
|
item.title ||= "Unknown"
|
||||||
channels[rss.channel.title] ||= []
|
channels[rss.channel.title] ||= []
|
||||||
channels[rss.channel.title] << item if item.description
|
channels[rss.channel.title] << item if item.description
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
processing_time = Time.now - before_time
|
processing_time = Time.now - before_time
|
||||||
|
|
||||||
channels.sort do |x, y|
|
channels.sort do |x, y|
|
||||||
x[0] <=> y[0]
|
x[0] <=> y[0]
|
||||||
end[0..20].each do |title, items|
|
end[0..20].each do |title, items|
|
||||||
puts "Channel: #{title}" unless items.empty?
|
puts "Channel: #{title}" unless items.empty?
|
||||||
items.sort do |x, y|
|
items.sort do |x, y|
|
||||||
x.title <=> y.title
|
x.title <=> y.title
|
||||||
end[0..10].each do |item|
|
end[0..10].each do |item|
|
||||||
puts " Item: #{item.title.shorten(50)}"
|
puts " Item: #{item.title.shorten(50)}"
|
||||||
puts " Description: #{item.description.shorten(50)}"
|
puts " Description: #{item.description.shorten(50)}"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
puts "Used XML parser: #{RSS::Parser.default_parser}"
|
puts "Used XML parser: #{RSS::Parser.default_parser}"
|
||||||
|
|
|
@ -2,12 +2,12 @@
|
||||||
|
|
||||||
require "nkf"
|
require "nkf"
|
||||||
class String
|
class String
|
||||||
# From tdiary.rb
|
# From tdiary.rb
|
||||||
def shorten( len = 120 )
|
def shorten( len = 120 )
|
||||||
lines = NKF::nkf( "-e -m0 -f#{len}", self.gsub( /\n/, ' ' ) ).split( /\n/ )
|
lines = NKF::nkf( "-e -m0 -f#{len}", self.gsub( /\n/, ' ' ) ).split( /\n/ )
|
||||||
lines[0].concat( '...' ) if lines[0] and lines[1]
|
lines[0].concat( '...' ) if lines[0] and lines[1]
|
||||||
lines[0]
|
lines[0]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
require "rss/1.0"
|
require "rss/1.0"
|
||||||
|
@ -18,65 +18,65 @@ items = []
|
||||||
verbose = false
|
verbose = false
|
||||||
|
|
||||||
def error(exception)
|
def error(exception)
|
||||||
mark = "=" * 20
|
mark = "=" * 20
|
||||||
mark = "#{mark} error #{mark}"
|
mark = "#{mark} error #{mark}"
|
||||||
puts mark
|
puts mark
|
||||||
puts exception.class
|
puts exception.class
|
||||||
puts exception.message
|
puts exception.message
|
||||||
puts exception.backtrace
|
puts exception.backtrace
|
||||||
puts mark
|
puts mark
|
||||||
end
|
end
|
||||||
before_time = Time.now
|
before_time = Time.now
|
||||||
ARGV.each do |fname|
|
ARGV.each do |fname|
|
||||||
if fname == '-v'
|
if fname == '-v'
|
||||||
verbose = true
|
verbose = true
|
||||||
next
|
next
|
||||||
end
|
end
|
||||||
rss = nil
|
rss = nil
|
||||||
f = File.new(fname).read
|
f = File.new(fname).read
|
||||||
begin
|
begin
|
||||||
## do validate parse
|
## do validate parse
|
||||||
rss = RSS::Parser.parse(f)
|
rss = RSS::Parser.parse(f)
|
||||||
rescue RSS::InvalidRSSError
|
rescue RSS::InvalidRSSError
|
||||||
error($!) if verbose
|
error($!) if verbose
|
||||||
## do non validate parse for invalid RSS 1.0
|
## do non validate parse for invalid RSS 1.0
|
||||||
begin
|
begin
|
||||||
rss = RSS::Parser.parse(f, false)
|
rss = RSS::Parser.parse(f, false)
|
||||||
rescue RSS::Error
|
rescue RSS::Error
|
||||||
## invalid RSS.
|
## invalid RSS.
|
||||||
error($!) if verbose
|
error($!) if verbose
|
||||||
end
|
end
|
||||||
rescue RSS::Error
|
rescue RSS::Error
|
||||||
error($!) if verbose
|
error($!) if verbose
|
||||||
end
|
end
|
||||||
if rss.nil?
|
if rss.nil?
|
||||||
puts "#{fname} does not include RSS 1.0 or 0.9x/2.0"
|
puts "#{fname} does not include RSS 1.0 or 0.9x/2.0"
|
||||||
else
|
else
|
||||||
begin
|
begin
|
||||||
rss.output_encoding = "euc-jp"
|
rss.output_encoding = "euc-jp"
|
||||||
rescue RSS::UnknownConversionMethodError
|
rescue RSS::UnknownConversionMethodError
|
||||||
error($!) if verbose
|
error($!) if verbose
|
||||||
end
|
end
|
||||||
rss.items.each do |item|
|
rss.items.each do |item|
|
||||||
if item.respond_to?(:pubDate) and item.pubDate
|
if item.respond_to?(:pubDate) and item.pubDate
|
||||||
class << item
|
class << item
|
||||||
alias_method(:dc_date, :pubDate)
|
alias_method(:dc_date, :pubDate)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if item.respond_to?(:dc_date) and item.dc_date
|
if item.respond_to?(:dc_date) and item.dc_date
|
||||||
items << [rss.channel, item]
|
items << [rss.channel, item]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
processing_time = Time.now - before_time
|
processing_time = Time.now - before_time
|
||||||
|
|
||||||
items.sort do |x, y|
|
items.sort do |x, y|
|
||||||
y[1].dc_date <=> x[1].dc_date
|
y[1].dc_date <=> x[1].dc_date
|
||||||
end[0..20].each do |channel, item|
|
end[0..20].each do |channel, item|
|
||||||
puts "#{item.dc_date.localtime.iso8601}: " <<
|
puts "#{item.dc_date.localtime.iso8601}: " <<
|
||||||
"#{channel.title}: #{item.title}"
|
"#{channel.title}: #{item.title}"
|
||||||
puts " Description: #{item.description.shorten(50)}" if item.description
|
puts " Description: #{item.description.shorten(50)}" if item.description
|
||||||
end
|
end
|
||||||
|
|
||||||
puts "Used XML parser: #{RSS::Parser.default_parser}"
|
puts "Used XML parser: #{RSS::Parser.default_parser}"
|
||||||
|
|
Loading…
Add table
Reference in a new issue