Sha256: 91189c0a62aeda3afe772a6b2e988ae21856833ed280ccdec8894155b2f69d75
Contents?: true
Size: 1.61 KB
Versions: 3
Compression:
Stored size: 1.61 KB
Contents
require 'facets/functor' #-- # TODO: Consider Enumerator methods. #++ module Enumerable # Per element meta-functor. # # [1,2,3].per + 3 #=> [4,5,6] # [1,2,3].per(:map) + 3 #=> [4,5,6] # [1,2,3].per(:select) > 1 #=> [2,3] # # [1,2,3].per.map + 3 #=> [4,5,6] # [1,2,3].per.select > 1 #=> [2,3] # def per(enum_method=nil, *enum_args) if enum_method Permeator.new(self, enum_method, *enum_args) #Functor.new do |op, *args| # __send__(enum_method, *enum_args){ |x| x.__send__(op, *args) } #, &blk) } #end else Functor.new do |enum_method, *enum_args| Permeator.new(self, enum_method, *enum_args) #Functor.new do |op, *args| # __send__(enum_method, *enum_args){ |x| x.__send__(op, *args) } #, &blk) } #end end end end # Permeator is a Functor for operating over each element of an Enumearble. # (Note: This used to be called an Elementor.) # # TODO: With Ruby 1.9+ this would not be required, as it can be replaced # by a generic Functor, becuase then lambda definitions can pass blocks. # class Permeator #:nodoc: private(*instance_methods.select{|x| x !~ /^__/ }) def initialize(enum_object, enum_method=nil, *enum_args) @enum_object = enum_object @enum_method = enum_method || :map @enum_args = enum_args end def instance_delegate @enum_object end def instance_operator @enum_method end def method_missing(sym, *args, &blk) @enum_object.__send__(@enum_method){ |x| x.__send__(sym, *args, &blk) } end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
facets-2.8.4 | lib/core/facets/enumerable/per.rb |
facets-2.8.3 | lib/core/facets/enumerable/per.rb |
facets-2.8.2 | lib/core/facets/enumerable/per.rb |