module RaaP type symbolic_call = [:call, untyped, Symbol, Array[untyped], Hash[Symbol, untyped], Proc?] VERSION: String def self.logger: () -> ::Logger def self.logger=: (::Logger) -> void module BindCall def self.define_singleton_method: (untyped, Symbol) { (*untyped, **untyped) -> untyped } -> void def self.respond_to?: (untyped, Symbol, ?bool) -> bool def self.instance_of?: (untyped, Module) -> bool def self.is_a?: (untyped, Module) -> bool def self.extend: (untyped, Module) -> void def self.name: (Module) -> String? def self.to_s: (untyped) -> String def self.class: (untyped) -> untyped def self.inspect: (untyped) -> String end class CLI class Option < ::Struct[untyped] def self.new: (?dirs: ::Array[String], ?requires: ::Array[String], ?libraries: ::Array[String], ?timeout: (Integer | Float | nil), ?size_from: ::Integer, ?size_to: ::Integer, ?size_by: ::Integer, ?allow_private: bool) -> instance def self.[]: (?dirs: ::Array[String], ?requires: ::Array[String], ?libraries: ::Array[String], ?timeout: (Integer | Float | nil), ?size_from: ::Integer, ?size_to: ::Integer, ?size_by: ::Integer, ?allow_private: bool) -> instance def self.keyword_init?: () -> true def self.members: () -> [ :dirs, :requires, :library, :timeout, :size_from, :size_to, :size_by, :allow_private] def members: () -> [ :dirs, :requires, :library, :timeout, :size_from, :size_to, :size_by, :allow_private] attr_accessor dirs: ::Array[String] attr_accessor requires: ::Array[String] attr_accessor libraries: ::Array[String] attr_accessor timeout: (Integer | Float | nil) attr_accessor size_from: ::Integer attr_accessor size_to: ::Integer attr_accessor size_by: ::Integer attr_accessor allow_private: bool end @argv: Array[String] def self.option: () -> Option def self.option=: (Option) -> void def initialize: (Array[String]) -> void def load: () -> self type property_result = [Integer, Symbol, ::RBS::MethodType] def run: () -> self def run_by: (tag: String) -> Array[Array[property_result]] def run_by_instance: (tag: String) -> Array[Array[property_result]] def run_by_singleton: (tag: String) -> Array[Array[property_result]] def run_by_type_name: (tag: String) -> Array[Array[property_result]] def run_by_type_name_with_search: (tag: String) -> Array[Array[property_result]] def property: (receiver_type: Type, type_params_decl: Array[::RBS::AST::TypeParam], method_name: Symbol, method_type: ::RBS::MethodType) -> property_result end class FunctionType @fun: ::RBS::Types::Function def initialize: (::RBS::Types::Function) -> void def pick_arguments: (?size: Integer, ?eval: bool) -> [Array[untyped], Hash[Symbol, untyped]] private def recursive_pick: (untyped, size: Integer, eval: bool) -> untyped def build_args_type: () -> Array[Type] def build_kwargs_type: () -> Hash[Symbol, Type] end class MethodProperty class Stats attr_accessor success: Integer attr_accessor skip: Integer attr_accessor exception: Integer end @receiver_type: Type @method_name: Symbol @method_type: MethodType @size_step: _Each[Integer] @timeout: (Integer | Float | nil) @allow_private: bool def initialize: (receiver_type: Type, method_name: Symbol, method_type: MethodType, size_step: _Each[Integer], timeout: (Integer | Float | nil), ?allow_private: bool) -> void def run: () { (Result::Success | Result::Failure | Result::Skip | Result::Exception) -> void } -> Stats private def call: (size: Integer, stats: Stats) -> (Result::Success | Result::Failure | Result::Skip | Result::Exception) def check_return: (receiver_value: untyped, return_value: untyped, method_type: MethodType) -> bool def return_type: () -> RBS::Types::t end class MethodType attr_reader rbs: ::RBS::MethodType @fun_type: FunctionType def initialize: (::RBS::MethodType | String method, ?type_params_decl: Array[untyped], ?type_args: Array[untyped], ?self_type: ::RBS::Types::ClassInstance?, ?instance_type: ::RBS::Types::ClassInstance?, ?class_type: ::RBS::Types::ClassSingleton?) -> void def pick_arguments: (?size: Integer, ?eval: bool) -> [Array[untyped], Hash[Symbol, untyped], ::Proc?] def pick_block: (?size: Integer, ?eval: bool) -> ::Proc? def check_return: (untyped) -> bool end module Minitest end module RBS self.@builder: ::RBS::DefinitionBuilder self.@env: ::RBS::Environment self.@loader: ::RBS::EnvironmentLoader def self.builder: () -> ::RBS::DefinitionBuilder def self.env: () -> ::RBS::Environment def self.loader: () -> ::RBS::EnvironmentLoader def self.parse_type: (String) -> ::RBS::Types::t end module Result interface _MethodValueReturnValue def symbolic_call: () -> symbolic_call def return_value: () -> untyped end module CalledStr : _MethodValueReturnValue def called_str: () -> String end class Success < Data def self.new: (symbolic_call: symbolic_call, return_value: untyped) -> instance attr_reader symbolic_call: symbolic_call attr_reader return_value: untyped include CalledStr end class Failure < Data def self.new: (symbolic_call: symbolic_call, return_value: untyped, ?exception: ::Exception?) -> instance attr_reader symbolic_call: symbolic_call attr_reader return_value: untyped attr_reader exception: ::Exception? include CalledStr end class Skip < Data def self.new: (symbolic_call: symbolic_call?, exception: ::Exception) -> instance attr_reader symbolic_call: symbolic_call? attr_reader exception: ::Exception end class Exception < Data def self.new: (symbolic_call: symbolic_call?, exception: ::Exception) -> instance attr_reader symbolic_call: symbolic_call? attr_reader exception: ::Exception end end class Sized[T] @block: ::Proc @such_that: ::Proc? def initialize: () { (Integer) -> untyped } -> void def pick: (size: Integer) -> T def such_that: () { (untyped) -> boolish } -> self def such_that_loop: [R] () { (Integer) -> R } -> R end class SymbolicCaller class Var attr_reader name: String def initialize: (String name) -> void def +: (String) -> String def to_s: () -> String end attr_reader symbolic_call: untyped attr_reader allow_private: bool def initialize: (untyped, ?allow_private: bool) -> void def eval: () -> untyped def call_str: () -> String def to_lines: () -> Array[String] private def try_eval: (untyped) -> untyped def walk: () ?{ (symbolic_call) -> untyped} -> untyped def _walk: (untyped) ?{ (symbolic_call) -> untyped} -> untyped def eval_one: (symbolic_call) -> untyped def var_name: (Module) -> String def printable?: (untyped) -> bool def printable: (untyped) -> String end class TypeSubstitution @type_params: ::Array[::RBS::AST::TypeParam] @type_args: ::Array[::RBS::Types::t] def initialize: (::Array[::RBS::AST::TypeParam], ::Array[::RBS::Types::t]) -> void def build: () -> ::RBS::Substitution def method_type_sub: (::RBS::MethodType, ?self_type: ::RBS::Types::ClassInstance?, ?instance_type: ::RBS::Types::ClassInstance?, ?class_type: ::RBS::Types::ClassSingleton?) -> ::RBS::MethodType private interface _MapType def map_type: { (untyped) -> untyped } -> untyped end def sub: (_MapType search, self_type: ::RBS::Types::ClassInstance?, instance_type: ::RBS::Types::ClassInstance?, class_type: ::RBS::Types::ClassSingleton?) -> untyped end class Type module Arithmetic def self.float: () -> Float def self.positive_float: () -> Float end @such_that: (^(untyped) -> ::boolish)? GENERATORS: Hash[String, ^() -> Sized[untyped]] SIMPLE_SOURCE: Array[String] RECURSION: Hash[String, :found | :logged] def self.register: (String) { () [self: instance] -> Sized[untyped] } -> void attr_reader type: ::RBS::Types::t attr_reader range: Range[untyped] def initialize: (String | ::RBS::Types::t, ?range: Range[untyped]) -> void # Define rule for generating values # type.such_that { |i| i != 0 }.pick #=> ensure that the value is not 0 def such_that: () { (untyped) -> boolish } -> self # Basic API for materializing values def pick: (?size: Integer, ?eval: bool) -> untyped def to_symbolic_call: (?size: Integer) -> untyped def sized: [T] () { (Integer size) -> T } -> Sized[T] private def pick_from_initialize: (::RBS::Types::ClassInstance, size: Integer) -> (symbolic_call | Value::Module) def parse: (String | ::RBS::Types::t) -> ::RBS::Types::t? def try: (times: Integer, size: Integer) { (Integer size) -> untyped } -> untyped def numeric: () -> Sized[Numeric] def integer: () -> Sized[Integer] def none_zero_integer: () -> Sized[Integer] def float: () -> Sized[Float] def rational: () -> Sized[symbolic_call] def complex: () -> Sized[symbolic_call] def string: () -> Sized[String] def symbol: () -> Sized[Symbol] def array: (Type) -> Sized[Array[untyped]] def encoding: () -> Sized[symbolic_call] def bool: () -> Sized[bool] def untyped: () -> Sized[untyped] def temp_method_object: () -> ::Method end module Value class Bottom < BasicObject def inspect: () -> String def class: () -> class end class Interface < BasicObject @type: ::RBS::Types::Interface @size: Integer @definition: ::RBS::Definition def initialize: (String | ::RBS::Types::Interface, ?size: Integer) -> void def inspect: () -> String def class: () -> class end class Intersection < BasicObject @type: ::RBS::Types::Intersection @children: Array[Type] @size: Integer def initialize: (::RBS::Types::Intersection, size: Integer) -> void def inspect: () -> String def class: () -> class end class Module attr_reader type: ::RBS::Types::ClassInstance def initialize: (::RBS::Types::ClassInstance) -> void def inspect: () -> String def class: () -> class end class Top < BasicObject def inspect: () -> String def class: () -> class end class Variable < BasicObject attr_reader type: ::RBS::Types::Variable def initialize: (::RBS::Types::Variable) -> void def inspect: () -> String def class: () -> class end class Void < BasicObject def inspect: () -> String def class: () -> class end end end