From aa8e1885265ac1052cbf12aa9a5c045c3c805e8d Mon Sep 17 00:00:00 2001 From: knu Date: Thu, 7 May 2009 17:32:48 +0000 Subject: * lib/set.rb (SortedSet#add): Do not require each newly added element to be Comparable but to respond to <=>. [ruby-dev:38371] git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@23363 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- lib/set.rb | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'lib') diff --git a/lib/set.rb b/lib/set.rb index 6d298d3f8..8f2bef91b 100644 --- a/lib/set.rb +++ b/lib/set.rb @@ -456,8 +456,8 @@ end # yielded in sorted order (according to the return values of their # #<=> methods) when iterating over them. # -# All elements that are added to a SortedSet must include the -# Comparable module. +# All elements that are added to a SortedSet must respond to the <=> +# method for comparison. # # Also, all elements must be mutually comparable: el1 <=> # el2 must not return nil for any elements el1 @@ -506,7 +506,7 @@ class SortedSet < Set end def add(o) - o.is_a?(Comparable) or raise ArgumentError, "value must be comparable" + o.respond_to?(:<=>) or raise ArgumentError, "value must repond to <=>" super end alias << add @@ -529,7 +529,7 @@ class SortedSet < Set end def add(o) - o.is_a?(Comparable) or raise ArgumentError, "value must be comparable" + o.respond_to?(:<=>) or raise ArgumentError, "value must respond to <=>" @keys = nil super end -- cgit