NotRegexp -> NegRegexp. #map implemented. very simple. #reduce: not yet.

This commit is contained in:
Denis Knauf 2010-05-23 22:20:53 +02:00
parent aaa7f106c8
commit 76d141c101

View file

@ -1,5 +1,6 @@
class NotRegexp
class ::Regexp
class NegRegexp
def initialize r
@rx = r
end
@ -12,11 +13,16 @@ class NotRegexp
def -@
@rx
end
end
def -@
NegRegexp.new self
end
end
class Regexp
def -@
NotRegexp.new self
class ::Object
def functional meth = nil
Functional.new self, meth
end
end
@ -37,6 +43,10 @@ class Functional
def end
@next.end
end
def to_proc
method( :call).to_proc
end
end
class Collect <Base
@ -137,6 +147,24 @@ class Functional
end
end
class Map <Collect
def call *a
@next.call *@exe.call(*a, &@next)
end
end
class Reduce <Base
def initialize *a, &e
super iv, *a, &e
@buf = {}
@buf.default = iv
end
def call *a
@buf[]
end
end
attr_accessor :next, :stack, :obj, :func, :args
def initialize obj = nil, func = nil, *args
@ -153,11 +181,11 @@ class Functional
end
def map *a, &exe
raise "Reserved for MapReduce. Install TokyoCabinet, if you want to use it."
push Map.new( &exe)
end
def reduce *a, &exe
raise "Reserved for MapReduce. Install TokyoCabinet, if you want to use it."
raise "Reserved for MapReduce."
end
def select &exe
@ -197,7 +225,7 @@ class Functional
end
def run
@obj.send @func||:each, *@args, &@next.method(:call)
@obj.send @func||:each, *@args, &@next #.method(:call)
@next.end
end
@ -217,7 +245,7 @@ begin
end
def call *a
@exe.call( *a).each &@next.method(:call)
@exe.call( *a).each &@next
end
end
@ -232,4 +260,4 @@ begin
rescue MissingSourceFile
# TokyoCabinet not installed?
end
end if false