ruby-changes:6162
From: kou <ko1@a...>
Date: Sun, 29 Jun 2008 17:47:55 +0900 (JST)
Subject: [ruby-changes:6162] Ruby:r17674 (trunk): * lib/rss/parser.rb (RSS::ListenerMixin#known_class): define to
kou 2008-06-29 17:44:53 +0900 (Sun, 29 Jun 2008)
New Revision: 17674
Modified files:
trunk/ChangeLog
trunk/lib/rss/parser.rb
Log:
* lib/rss/parser.rb (RSS::ListenerMixin#known_class): define to
work with ruby 1.8.x too.
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=17674&r2=17673&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/lib/rss/parser.rb?r1=17674&r2=17673&diff_format=u
Index: ChangeLog
===================================================================
--- ChangeLog (revision 17673)
+++ ChangeLog (revision 17674)
@@ -1,3 +1,8 @@
+Sun Jun 29 17:44:23 2008 Kouhei Sutou <kou@c...>
+
+ * lib/rss/parser.rb (RSS::ListenerMixin#known_class): define to
+ work with ruby 1.8.x too.
+
Sun Jun 29 17:41:42 2008 Kouhei Sutou <kou@c...>
* lib/rss/maker/base.rb (RSS::Maker::RSSBase#to_feed): raise
Index: lib/rss/parser.rb
===================================================================
--- lib/rss/parser.rb (revision 17673)
+++ lib/rss/parser.rb (revision 17674)
@@ -361,9 +361,7 @@
def start_else_element(local, prefix, attrs, ns)
class_name = self.class.class_name(_ns(ns, prefix), local)
current_class = @last_element.class
- if class_name and
- (current_class.const_defined?(class_name, false) or
- current_class.constants.include?(class_name.to_sym))
+ if known_class?(current_class, class_name)
next_class = current_class.const_get(class_name)
start_have_something_element(local, prefix, attrs, ns, next_class)
else
@@ -379,6 +377,20 @@
end
end
+ if Module.method(:const_defined?).arity == -1
+ def known_class?(target_class, class_name)
+ class_name and
+ (target_class.const_defined?(class_name, false) or
+ target_class.constants.include?(class_name.to_sym))
+ end
+ else
+ def known_class?(target_class, class_name)
+ class_name and
+ (target_class.const_defined?(class_name) or
+ target_class.constants.include?(class_name))
+ end
+ end
+
NAMESPLIT = /^(?:([\w:][-\w\d.]*):)?([\w:][-\w\d.]*)/
def split_name(name)
name =~ NAMESPLIT
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/