2012-10-02 13:21:00 -05:00
|
|
|
require 'set'
|
|
|
|
|
|
|
|
class ComparableSet < Set
|
|
|
|
def add new
|
|
|
|
# smileys only
|
|
|
|
return super new unless new.respond_to? :>
|
|
|
|
|
2014-07-01 21:39:09 -05:00
|
|
|
grep(new.class) do |o|
|
2012-10-02 13:21:00 -05:00
|
|
|
return self if o > new
|
|
|
|
delete o
|
|
|
|
end
|
|
|
|
super new
|
|
|
|
end
|
|
|
|
|
|
|
|
alias_method :<<, :add
|
|
|
|
|
|
|
|
# Set#merge bypasses enumerating the set's contents,
|
|
|
|
# so the subclassed #add would never be called
|
|
|
|
def merge enum
|
|
|
|
enum.is_a?(Enumerable) or raise ArgumentError, "value must be enumerable"
|
|
|
|
enum.each { |o| add(o) }
|
2012-10-25 15:45:42 -05:00
|
|
|
self
|
2012-10-02 13:21:00 -05:00
|
|
|
end
|
|
|
|
end
|