File: //proc/self/root/proc/thread-self/root/usr/lib/ruby/gems/3.0.0/gems/rbs-1.0.4/core/proc.rbs
# A `Proc` object is an encapsulation of a block of code, which can be
# stored in a local variable, passed to a method or another
# [Proc](Proc), and can be called.
# [Proc](Proc) is an essential concept in Ruby and a
# core of its functional programming features.
#
# ```ruby
# square = Proc.new {|x| x**2 }
#
# square.call(3) #=> 9
# # shorthands:
# square.(3) #=> 9
# square[3] #=> 9
# ```
#
# [Proc](Proc) objects are *closures* , meaning they
# remember and can use the entire context in which they were created.
#
# ```ruby
# def gen_times(factor)
# Proc.new {|n| n*factor } # remembers the value of factor at the moment of creation
# end
#
# times3 = gen_times(3)
# times5 = gen_times(5)
#
# times3.call(12) #=> 36
# times5.call(5) #=> 25
# times3.call(times5.call(4)) #=> 60
# ```
#
#
# There are several methods to create a [Proc](Proc)
#
# - Use the [Proc](Proc) class constructor:
#
# ```ruby
# proc1 = Proc.new {|x| x**2 }
# ```
#
# - Use the
# [Kernel\#proc](https://ruby-doc.org/core-2.6.3/Kernel.html#method-i-proc)
# method as a shorthand of
# [::new](Proc#method-c-new):
#
# ```ruby
# proc2 = proc {|x| x**2 }
# ```
#
# - Receiving a block of code into proc argument (note the `&` ):
#
# ```ruby
# def make_proc(&block)
# block
# end
#
# proc3 = make_proc {|x| x**2 }
# ```
#
# - Construct a proc with lambda semantics using the
# [Kernel\#lambda](https://ruby-doc.org/core-2.6.3/Kernel.html#method-i-lambda)
# method (see below for explanations about lambdas):
#
# ```ruby
# lambda1 = lambda {|x| x**2 }
# ```
#
# - Use the Lambda literal syntax (also constructs a proc with lambda
# semantics):
#
# ```ruby
# lambda2 = ->(x) { x**2 }
# ```
#
#
# Procs are coming in two flavors: lambda and non-lambda (regular procs).
# Differences are:
#
# - In lambdas, `return` means exit from this lambda;
#
# - In regular procs, `return` means exit from embracing method (and
# will throw `LocalJumpError` if invoked outside the method);
#
# - In lambdas, arguments are treated in the same way as in methods:
# strict, with `ArgumentError` for mismatching argument number, and no
# additional argument processing;
#
# - Regular procs accept arguments more generously: missing arguments
# are filled with `nil`, single
# [Array](https://ruby-doc.org/core-2.6.3/Array.html) arguments are
# deconstructed if the proc has multiple arguments, and there is no
# error raised on extra arguments.
#
# Examples:
#
# ```ruby
# p = proc {|x, y| "x=#{x}, y=#{y}" }
# p.call(1, 2) #=> "x=1, y=2"
# p.call([1, 2]) #=> "x=1, y=2", array deconstructed
# p.call(1, 2, 8) #=> "x=1, y=2", extra argument discarded
# p.call(1) #=> "x=1, y=", nil substituted instead of error
#
# l = lambda {|x, y| "x=#{x}, y=#{y}" }
# l.call(1, 2) #=> "x=1, y=2"
# l.call([1, 2]) # ArgumentError: wrong number of arguments (given 1, expected 2)
# l.call(1, 2, 8) # ArgumentError: wrong number of arguments (given 3, expected 2)
# l.call(1) # ArgumentError: wrong number of arguments (given 1, expected 2)
#
# def test_return
# -> { return 3 }.call # just returns from lambda into method body
# proc { return 4 }.call # returns from method
# return 5
# end
#
# test_return # => 4, return from proc
# ```
#
# Lambdas are useful as self-sufficient functions, in particular useful as
# arguments to higher-order functions, behaving exactly like Ruby methods.
#
# Procs are useful for implementing iterators:
#
# ```ruby
# def test
# [[1, 2], [3, 4], [5, 6]].map {|a, b| return a if a + b > 10 }
# # ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
# end
# ```
#
# Inside `map`, the block of code is treated as a regular (non-lambda)
# proc, which means that the internal arrays will be deconstructed to
# pairs of arguments, and `return` will exit from the method `test` . That
# would not be possible with a stricter lambda.
#
# You can tell a lambda from a regular proc by using the
# [lambda?](Proc#method-i-lambda-3F) instance method.
#
# Lambda semantics is typically preserved during the proc lifetime,
# including `&` -deconstruction to a block of code:
#
# ```ruby
# p = proc {|x, y| x }
# l = lambda {|x, y| x }
# [[1, 2], [3, 4]].map(&p) #=> [1, 2]
# [[1, 2], [3, 4]].map(&l) # ArgumentError: wrong number of arguments (given 1, expected 2)
# ```
#
# The only exception is dynamic method definition: even if defined by
# passing a non-lambda proc, methods still have normal semantics of
# argument checking.
#
# ```ruby
# class C
# define_method(:e, &proc {})
# end
# C.new.e(1,2) #=> ArgumentError
# C.new.method(:e).to_proc.lambda? #=> true
# ```
#
# This exception ensures that methods never have unusual argument passing
# conventions, and makes it easy to have wrappers defining methods that
# behave as usual.
#
# ```ruby
# class C
# def self.def2(name, &body)
# define_method(name, &body)
# end
#
# def2(:f) {}
# end
# C.new.f(1,2) #=> ArgumentError
# ```
#
# The wrapper *def2* receives `body` as a non-lambda proc, yet defines a
# method which has normal semantics.
#
#
# Any object that implements the `to_proc` method can be converted into a
# proc by the `&` operator, and therefore con be consumed by iterators.
#
# ```ruby
# class Greater
# def initialize(greating)
# @greating = greating
# end
#
# def to_proc
# proc {|name| "#{@greating}, #{name}!" }
# end
# end
#
# hi = Greater.new("Hi")
# hey = Greater.new("Hey")
# ["Bob", "Jane"].map(&hi) #=> ["Hi, Bob!", "Hi, Jane!"]
# ["Bob", "Jane"].map(&hey) #=> ["Hey, Bob!", "Hey, Jane!"]
# ```
#
# Of the Ruby core classes, this method is implemented by
# [Symbol](https://ruby-doc.org/core-2.6.3/Symbol.html),
# [Method](https://ruby-doc.org/core-2.6.3/Method.html), and
# [Hash](https://ruby-doc.org/core-2.6.3/Hash.html).
#
# :to_s.to_proc.call(1) #=> "1"
# [1, 2].map(&:to_s) #=> ["1", "2"]
#
# method(:puts).to_proc.call(1) # prints 1
# [1, 2].each(&method(:puts)) # prints 1, 2
#
# {test: 1}.to_proc.call(:test) #=> 1
# %i[test many keys].map(&{test: 1}) #=> [1, nil, nil]
class Proc < Object
# Returns the number of mandatory arguments. If the block is declared to
# take no arguments, returns 0. If the block is known to take exactly n
# arguments, returns n. If the block has optional arguments, returns -n-1,
# where n is the number of mandatory arguments, with the exception for
# blocks that are not lambdas and have only a finite number of optional
# arguments; in this latter case, returns n. Keyword arguments will be
# considered as a single additional argument, that argument being
# mandatory if any keyword argument is mandatory. A `proc` with no
# argument declarations is the same as a block declaring `||` as its
# arguments.
#
# proc {}.arity #=> 0
# proc { || }.arity #=> 0
# proc { |a| }.arity #=> 1
# proc { |a, b| }.arity #=> 2
# proc { |a, b, c| }.arity #=> 3
# proc { |*a| }.arity #=> -1
# proc { |a, *b| }.arity #=> -2
# proc { |a, *b, c| }.arity #=> -3
# proc { |x:, y:, z:0| }.arity #=> 1
# proc { |*a, x:, y:0| }.arity #=> -2
#
# proc { |a=0| }.arity #=> 0
# lambda { |a=0| }.arity #=> -1
# proc { |a=0, b| }.arity #=> 1
# lambda { |a=0, b| }.arity #=> -2
# proc { |a=0, b=0| }.arity #=> 0
# lambda { |a=0, b=0| }.arity #=> -1
# proc { |a, b=0| }.arity #=> 1
# lambda { |a, b=0| }.arity #=> -2
# proc { |(a, b), c=0| }.arity #=> 1
# lambda { |(a, b), c=0| }.arity #=> -2
# proc { |a, x:0, y:0| }.arity #=> 1
# lambda { |a, x:0, y:0| }.arity #=> -2
def arity: () -> Integer
# Returns the binding associated with *prc* .
#
# ```ruby
# def fred(param)
# proc {}
# end
#
# b = fred(99)
# eval("param", b.binding) #=> 99
# ```
def binding: () -> Binding
def call: (*untyped arg0) -> untyped
def []: (*untyped arg0) -> untyped
def curry: (?Integer arity) -> Proc
# Returns a hash value corresponding to proc body.
#
# See also Object\#hash.
def hash: () -> Integer
def initialize: () { (*untyped) -> untyped } -> void
# Returns `true` for a [Proc](Proc.downloaded.ruby_doc) object for which
# argument handling is rigid. Such procs are typically generated by
# `lambda` .
#
# A [Proc](Proc.downloaded.ruby_doc) object generated by `proc` ignores
# extra arguments.
#
# ```ruby
# proc {|a,b| [a,b] }.call(1,2,3) #=> [1,2]
# ```
#
# It provides `nil` for missing arguments.
#
# ```ruby
# proc {|a,b| [a,b] }.call(1) #=> [1,nil]
# ```
#
# It expands a single array argument.
#
# ```ruby
# proc {|a,b| [a,b] }.call([1,2]) #=> [1,2]
# ```
#
# A [Proc](Proc.downloaded.ruby_doc) object generated by `lambda` doesn’t
# have such tricks.
#
# ```ruby
# lambda {|a,b| [a,b] }.call(1,2,3) #=> ArgumentError
# lambda {|a,b| [a,b] }.call(1) #=> ArgumentError
# lambda {|a,b| [a,b] }.call([1,2]) #=> ArgumentError
# ```
#
# [\#lambda?](Proc.downloaded.ruby_doc#method-i-lambda-3F) is a predicate
# for the tricks. It returns `true` if no tricks apply.
#
# ```ruby
# lambda {}.lambda? #=> true
# proc {}.lambda? #=> false
# ```
#
# [::new](Proc.downloaded.ruby_doc#method-c-new) is the same as `proc` .
#
# ```ruby
# Proc.new {}.lambda? #=> false
# ```
#
# `lambda`, `proc` and [::new](Proc.downloaded.ruby_doc#method-c-new)
# preserve the tricks of a [Proc](Proc.downloaded.ruby_doc) object given
# by `&` argument.
#
# ```ruby
# lambda(&lambda {}).lambda? #=> true
# proc(&lambda {}).lambda? #=> true
# Proc.new(&lambda {}).lambda? #=> true
#
# lambda(&proc {}).lambda? #=> false
# proc(&proc {}).lambda? #=> false
# Proc.new(&proc {}).lambda? #=> false
# ```
#
# A [Proc](Proc.downloaded.ruby_doc) object generated by `&` argument has
# the tricks
#
# ```ruby
# def n(&b) b.lambda? end
# n {} #=> false
# ```
#
# The `&` argument preserves the tricks if a
# [Proc](Proc.downloaded.ruby_doc) object is given by `&` argument.
#
# ```ruby
# n(&lambda {}) #=> true
# n(&proc {}) #=> false
# n(&Proc.new {}) #=> false
# ```
#
# A [Proc](Proc.downloaded.ruby_doc) object converted from a method has no
# tricks.
#
# ```ruby
# def m() end
# method(:m).to_proc.lambda? #=> true
#
# n(&method(:m)) #=> true
# n(&method(:m).to_proc) #=> true
# ```
#
# `define_method` is treated the same as method definition. The defined
# method has no tricks.
#
# ```ruby
# class C
# define_method(:d) {}
# end
# C.new.d(1,2) #=> ArgumentError
# C.new.method(:d).to_proc.lambda? #=> true
# ```
#
# `define_method` always defines a method without the tricks, even if a
# non-lambda [Proc](Proc.downloaded.ruby_doc) object is given. This is the
# only exception for which the tricks are not preserved.
#
# ```ruby
# class C
# define_method(:e, &proc {})
# end
# C.new.e(1,2) #=> ArgumentError
# C.new.method(:e).to_proc.lambda? #=> true
# ```
#
# This exception ensures that methods never have tricks and makes it easy
# to have wrappers to define methods that behave as usual.
#
# ```ruby
# class C
# def self.def2(name, &body)
# define_method(name, &body)
# end
#
# def2(:f) {}
# end
# C.new.f(1,2) #=> ArgumentError
# ```
#
# The wrapper *def2* defines a method which has no tricks.
def lambda?: () -> bool
# Returns the parameter information of this proc.
#
# ```ruby
# prc = lambda{|x, y=42, *other|}
# prc.parameters #=> [[:req, :x], [:opt, :y], [:rest, :other]]
# ```
def parameters: () -> ::Array[[ Symbol, Symbol ]]
# Returns the Ruby source filename and line number containing this proc or
# `nil` if this proc was not defined in Ruby (i.e. native).
def source_location: () -> [ String, Integer ]
# Part of the protocol for converting objects to `Proc` objects. Instances
# of class `Proc` simply return themselves.
def to_proc: () -> self
# Returns the unique identifier for this proc, along with an indication of
# where the proc was defined.
#
#
#
# Also aliased as: [inspect](Proc.downloaded.ruby_doc#method-i-inspect)
def to_s: () -> String
# Alias for: [to\_s](Proc.downloaded.ruby_doc#method-i-to_s)
def inspect: () -> String
end