Class: Proc
- Inherits:
-
Object
- Object
- Proc
- Defined in:
- mrbgems/mruby-proc-ext/mrblib/proc.rb
Instance Method Summary collapse
-
#<<(other) ⇒ Object
call-seq: prc << other_proc -> new_proc.
-
#===(*args) ⇒ Object
call-seq: prc === obj -> result_of_proc.
-
#>>(other) ⇒ Object
call-seq: prc >> other_proc -> new_proc.
-
#curry(arity = self.arity) ⇒ Object
call-seq: prc.curry -> curried_proc prc.curry(arity) -> curried_proc.
-
#to_proc ⇒ Object
call-seq: prc.to_proc -> prc.
-
#yield(*args) ⇒ Object
call-seq: prc.yield(params,...) -> obj.
Instance Method Details
#<<(other) ⇒ Object
call-seq:
prc << other_proc -> new_proc
Returns a new Proc which is the composition of this proc and the given other_proc. The returned proc takes a variable number of arguments, calls other_proc with them then calls this proc with the result.
f = proc {|x| x * x }
g = proc {|x| x + x }
p (f << g).call(2) #=> 16
110 111 112 |
# File 'mrbgems/mruby-proc-ext/mrblib/proc.rb', line 110 def <<(other) ->(*args, **opts, &block) { call(other.call(*args, **opts, &block)) } end |
#===(*args) ⇒ Object
call-seq:
prc === obj -> result_of_proc
Invokes the block with obj as the parameter like Proc#call. This allows a proc object to be the target of a when clause in a case statement.
def the_answer
42
end
case the_answer
when proc { |x| x > 40 }
"correct"
else
"incorrect"
end
#=> "correct"
23 24 25 |
# File 'mrbgems/mruby-proc-ext/mrblib/proc.rb', line 23 def ===(*args) call(*args) end |
#>>(other) ⇒ Object
call-seq:
prc >> other_proc -> new_proc
Returns a new Proc which is the composition of this proc and the given other_proc. The returned proc takes a variable number of arguments, calls this proc with them then calls other_proc with the result.
f = proc {|x| x * x }
g = proc {|x| x + x }
p (f >> g).call(2) #=> 8
126 127 128 |
# File 'mrbgems/mruby-proc-ext/mrblib/proc.rb', line 126 def >>(other) ->(*args, **opts, &block) { other.call(call(*args, **opts, &block)) } end |
#curry(arity = self.arity) ⇒ Object
call-seq:
prc.curry -> curried_proc
prc.curry(arity) -> curried_proc
Returns a curried proc. If the optional arity argument is given, it determines the number of arguments. A curried proc receives some arguments. If a sufficient number of arguments are supplied, it passes the supplied arguments to the original proc and returns the result. Otherwise, returns another curried proc that takes the rest of arguments.
b = proc {|x, y, z| (x||0) + (y||0) + (z||0) }
p b.curry[1][2][3] #=> 6
p b.curry[1, 2][3, 4] #=> 6
p b.curry(5)[1][2][3][4][5] #=> 6
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
# File 'mrbgems/mruby-proc-ext/mrblib/proc.rb', line 71 def curry(arity=self.arity) type = :proc abs = lambda {|a| a < 0 ? -a - 1 : a} arity = abs[arity] if lambda? type = :lambda self_arity = self.arity if (self_arity >= 0 && arity != self_arity) || (self_arity < 0 && abs[self_arity] > arity) raise ArgumentError, "wrong number of arguments (given #{arity}, expected #{abs[self_arity]})" end end pproc = self make_curry = proc do |given_args=[]| __send__(type) do |*args| new_args = given_args + args if new_args.size >= arity pproc[*new_args] else make_curry[new_args] end end end make_curry.call end |
#to_proc ⇒ Object
call-seq:
prc.to_proc -> prc
Part of the protocol for converting objects to Proc objects. Instances of class Proc simply return themselves.
prc = proc { "hello" }
prc.to_proc #=> #<Proc:0x401b3d30@(irb):3>
51 52 53 |
# File 'mrbgems/mruby-proc-ext/mrblib/proc.rb', line 51 def to_proc self end |
#yield(*args) ⇒ Object
call-seq:
prc.yield(params,...) -> obj
Invokes the block with the given arguments. This method is provided for compatibility and is equivalent to Proc#call.
prc = proc { |x| x * 2 }
prc.yield(5) #=> 10
37 38 39 |
# File 'mrbgems/mruby-proc-ext/mrblib/proc.rb', line 37 def yield(*args) call(*args) end |