rbs-relaxed 3.9.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.github/dependabot.yml +22 -0
- data/.github/workflows/comments.yml +35 -0
- data/.github/workflows/dependabot.yml +30 -0
- data/.github/workflows/ruby.yml +82 -0
- data/.github/workflows/typecheck.yml +38 -0
- data/.github/workflows/windows.yml +43 -0
- data/.gitignore +23 -0
- data/.rubocop.yml +68 -0
- data/BSDL +22 -0
- data/CHANGELOG.md +1868 -0
- data/COPYING +56 -0
- data/README.md +203 -0
- data/Rakefile +417 -0
- data/Steepfile +44 -0
- data/config.yml +313 -0
- data/core/array.rbs +4062 -0
- data/core/basic_object.rbs +375 -0
- data/core/binding.rbs +150 -0
- data/core/builtin.rbs +277 -0
- data/core/class.rbs +220 -0
- data/core/comparable.rbs +171 -0
- data/core/complex.rbs +786 -0
- data/core/constants.rbs +96 -0
- data/core/data.rbs +415 -0
- data/core/dir.rbs +981 -0
- data/core/encoding.rbs +1371 -0
- data/core/enumerable.rbs +2405 -0
- data/core/enumerator/product.rbs +92 -0
- data/core/enumerator.rbs +630 -0
- data/core/env.rbs +6 -0
- data/core/errno.rbs +673 -0
- data/core/errors.rbs +760 -0
- data/core/exception.rbs +485 -0
- data/core/false_class.rbs +82 -0
- data/core/fiber.rbs +550 -0
- data/core/fiber_error.rbs +11 -0
- data/core/file.rbs +2936 -0
- data/core/file_test.rbs +331 -0
- data/core/float.rbs +1151 -0
- data/core/gc.rbs +644 -0
- data/core/global_variables.rbs +184 -0
- data/core/hash.rbs +1861 -0
- data/core/integer.rbs +1413 -0
- data/core/io/buffer.rbs +984 -0
- data/core/io/wait.rbs +70 -0
- data/core/io.rbs +3406 -0
- data/core/kernel.rbs +3096 -0
- data/core/marshal.rbs +207 -0
- data/core/match_data.rbs +635 -0
- data/core/math.rbs +729 -0
- data/core/method.rbs +386 -0
- data/core/module.rbs +1704 -0
- data/core/nil_class.rbs +209 -0
- data/core/numeric.rbs +818 -0
- data/core/object.rbs +110 -0
- data/core/object_space/weak_key_map.rbs +166 -0
- data/core/object_space.rbs +190 -0
- data/core/proc.rbs +868 -0
- data/core/process.rbs +2296 -0
- data/core/ractor.rbs +1068 -0
- data/core/random.rbs +237 -0
- data/core/range.rbs +1107 -0
- data/core/rational.rbs +531 -0
- data/core/rb_config.rbs +88 -0
- data/core/rbs/unnamed/argf.rbs +1229 -0
- data/core/rbs/unnamed/env_class.rbs +1209 -0
- data/core/rbs/unnamed/random.rbs +293 -0
- data/core/refinement.rbs +59 -0
- data/core/regexp.rbs +1930 -0
- data/core/ruby_vm.rbs +765 -0
- data/core/rubygems/basic_specification.rbs +6 -0
- data/core/rubygems/config_file.rbs +38 -0
- data/core/rubygems/dependency_installer.rbs +6 -0
- data/core/rubygems/errors.rbs +176 -0
- data/core/rubygems/installer.rbs +15 -0
- data/core/rubygems/path_support.rbs +6 -0
- data/core/rubygems/platform.rbs +7 -0
- data/core/rubygems/request_set.rbs +49 -0
- data/core/rubygems/requirement.rbs +148 -0
- data/core/rubygems/rubygems.rbs +1171 -0
- data/core/rubygems/source_list.rbs +15 -0
- data/core/rubygems/specification.rbs +23 -0
- data/core/rubygems/stream_ui.rbs +5 -0
- data/core/rubygems/uninstaller.rbs +10 -0
- data/core/rubygems/version.rbs +294 -0
- data/core/set.rbs +621 -0
- data/core/signal.rbs +100 -0
- data/core/string.rbs +3583 -0
- data/core/struct.rbs +667 -0
- data/core/symbol.rbs +475 -0
- data/core/thread.rbs +1765 -0
- data/core/thread_group.rbs +79 -0
- data/core/time.rbs +1762 -0
- data/core/trace_point.rbs +477 -0
- data/core/true_class.rbs +98 -0
- data/core/unbound_method.rbs +329 -0
- data/core/warning.rbs +87 -0
- data/docs/CONTRIBUTING.md +106 -0
- data/docs/architecture.md +110 -0
- data/docs/collection.md +192 -0
- data/docs/data_and_struct.md +86 -0
- data/docs/gem.md +57 -0
- data/docs/rbs_by_example.md +309 -0
- data/docs/repo.md +125 -0
- data/docs/sigs.md +167 -0
- data/docs/stdlib.md +147 -0
- data/docs/syntax.md +910 -0
- data/docs/tools.md +17 -0
- data/exe/rbs +7 -0
- data/ext/rbs_extension/extconf.rb +15 -0
- data/ext/rbs_extension/lexer.c +2728 -0
- data/ext/rbs_extension/lexer.h +179 -0
- data/ext/rbs_extension/lexer.re +147 -0
- data/ext/rbs_extension/lexstate.c +175 -0
- data/ext/rbs_extension/location.c +325 -0
- data/ext/rbs_extension/location.h +85 -0
- data/ext/rbs_extension/main.c +33 -0
- data/ext/rbs_extension/parser.c +2973 -0
- data/ext/rbs_extension/parser.h +18 -0
- data/ext/rbs_extension/parserstate.c +397 -0
- data/ext/rbs_extension/parserstate.h +163 -0
- data/ext/rbs_extension/rbs_extension.h +31 -0
- data/ext/rbs_extension/unescape.c +32 -0
- data/goodcheck.yml +91 -0
- data/include/rbs/constants.h +82 -0
- data/include/rbs/ruby_objs.h +72 -0
- data/include/rbs/util/rbs_constant_pool.h +219 -0
- data/include/rbs.h +7 -0
- data/lib/rbs/ancestor_graph.rb +92 -0
- data/lib/rbs/annotate/annotations.rb +199 -0
- data/lib/rbs/annotate/formatter.rb +92 -0
- data/lib/rbs/annotate/rdoc_annotator.rb +400 -0
- data/lib/rbs/annotate/rdoc_source.rb +131 -0
- data/lib/rbs/annotate.rb +8 -0
- data/lib/rbs/ast/annotation.rb +29 -0
- data/lib/rbs/ast/comment.rb +29 -0
- data/lib/rbs/ast/declarations.rb +467 -0
- data/lib/rbs/ast/directives.rb +49 -0
- data/lib/rbs/ast/members.rb +451 -0
- data/lib/rbs/ast/type_param.rb +225 -0
- data/lib/rbs/ast/visitor.rb +137 -0
- data/lib/rbs/buffer.rb +67 -0
- data/lib/rbs/builtin_names.rb +58 -0
- data/lib/rbs/cli/colored_io.rb +48 -0
- data/lib/rbs/cli/diff.rb +83 -0
- data/lib/rbs/cli/validate.rb +357 -0
- data/lib/rbs/cli.rb +1223 -0
- data/lib/rbs/collection/cleaner.rb +38 -0
- data/lib/rbs/collection/config/lockfile.rb +92 -0
- data/lib/rbs/collection/config/lockfile_generator.rb +218 -0
- data/lib/rbs/collection/config.rb +81 -0
- data/lib/rbs/collection/installer.rb +32 -0
- data/lib/rbs/collection/sources/base.rb +14 -0
- data/lib/rbs/collection/sources/git.rb +258 -0
- data/lib/rbs/collection/sources/local.rb +81 -0
- data/lib/rbs/collection/sources/rubygems.rb +48 -0
- data/lib/rbs/collection/sources/stdlib.rb +50 -0
- data/lib/rbs/collection/sources.rb +38 -0
- data/lib/rbs/collection.rb +16 -0
- data/lib/rbs/constant.rb +28 -0
- data/lib/rbs/definition.rb +401 -0
- data/lib/rbs/definition_builder/ancestor_builder.rb +620 -0
- data/lib/rbs/definition_builder/method_builder.rb +254 -0
- data/lib/rbs/definition_builder.rb +845 -0
- data/lib/rbs/diff.rb +125 -0
- data/lib/rbs/environment/use_map.rb +77 -0
- data/lib/rbs/environment.rb +829 -0
- data/lib/rbs/environment_loader.rb +173 -0
- data/lib/rbs/environment_walker.rb +155 -0
- data/lib/rbs/errors.rb +645 -0
- data/lib/rbs/factory.rb +18 -0
- data/lib/rbs/file_finder.rb +28 -0
- data/lib/rbs/location_aux.rb +138 -0
- data/lib/rbs/locator.rb +243 -0
- data/lib/rbs/method_type.rb +143 -0
- data/lib/rbs/namespace.rb +125 -0
- data/lib/rbs/parser/lex_result.rb +15 -0
- data/lib/rbs/parser/token.rb +23 -0
- data/lib/rbs/parser_aux.rb +114 -0
- data/lib/rbs/prototype/helpers.rb +140 -0
- data/lib/rbs/prototype/node_usage.rb +99 -0
- data/lib/rbs/prototype/rb.rb +840 -0
- data/lib/rbs/prototype/rbi.rb +641 -0
- data/lib/rbs/prototype/runtime/helpers.rb +59 -0
- data/lib/rbs/prototype/runtime/reflection.rb +19 -0
- data/lib/rbs/prototype/runtime/value_object_generator.rb +279 -0
- data/lib/rbs/prototype/runtime.rb +667 -0
- data/lib/rbs/repository.rb +127 -0
- data/lib/rbs/resolver/constant_resolver.rb +219 -0
- data/lib/rbs/resolver/type_name_resolver.rb +91 -0
- data/lib/rbs/sorter.rb +198 -0
- data/lib/rbs/substitution.rb +83 -0
- data/lib/rbs/subtractor.rb +201 -0
- data/lib/rbs/test/errors.rb +80 -0
- data/lib/rbs/test/guaranteed.rb +30 -0
- data/lib/rbs/test/hook.rb +212 -0
- data/lib/rbs/test/observer.rb +19 -0
- data/lib/rbs/test/setup.rb +84 -0
- data/lib/rbs/test/setup_helper.rb +50 -0
- data/lib/rbs/test/tester.rb +167 -0
- data/lib/rbs/test/type_check.rb +435 -0
- data/lib/rbs/test.rb +112 -0
- data/lib/rbs/type_alias_dependency.rb +100 -0
- data/lib/rbs/type_alias_regularity.rb +126 -0
- data/lib/rbs/type_name.rb +109 -0
- data/lib/rbs/types.rb +1596 -0
- data/lib/rbs/unit_test/convertibles.rb +176 -0
- data/lib/rbs/unit_test/spy.rb +138 -0
- data/lib/rbs/unit_test/type_assertions.rb +347 -0
- data/lib/rbs/unit_test/with_aliases.rb +143 -0
- data/lib/rbs/unit_test.rb +6 -0
- data/lib/rbs/validator.rb +186 -0
- data/lib/rbs/variance_calculator.rb +189 -0
- data/lib/rbs/vendorer.rb +71 -0
- data/lib/rbs/version.rb +5 -0
- data/lib/rbs/writer.rb +424 -0
- data/lib/rbs.rb +94 -0
- data/lib/rdoc/discover.rb +20 -0
- data/lib/rdoc_plugin/parser.rb +163 -0
- data/rbs-relaxed.gemspec +48 -0
- data/schema/annotation.json +14 -0
- data/schema/comment.json +26 -0
- data/schema/decls.json +326 -0
- data/schema/function.json +87 -0
- data/schema/location.json +56 -0
- data/schema/members.json +266 -0
- data/schema/methodType.json +50 -0
- data/schema/typeParam.json +36 -0
- data/schema/types.json +317 -0
- data/sig/ancestor_builder.rbs +163 -0
- data/sig/ancestor_graph.rbs +60 -0
- data/sig/annotate/annotations.rbs +102 -0
- data/sig/annotate/formatter.rbs +24 -0
- data/sig/annotate/rdoc_annotater.rbs +82 -0
- data/sig/annotate/rdoc_source.rbs +30 -0
- data/sig/annotation.rbs +27 -0
- data/sig/buffer.rbs +32 -0
- data/sig/builtin_names.rbs +44 -0
- data/sig/cli/colored_io.rbs +15 -0
- data/sig/cli/diff.rbs +21 -0
- data/sig/cli/validate.rbs +43 -0
- data/sig/cli.rbs +87 -0
- data/sig/collection/cleaner.rbs +13 -0
- data/sig/collection/config/lockfile.rbs +74 -0
- data/sig/collection/config/lockfile_generator.rbs +66 -0
- data/sig/collection/config.rbs +46 -0
- data/sig/collection/installer.rbs +17 -0
- data/sig/collection/sources.rbs +214 -0
- data/sig/collection.rbs +4 -0
- data/sig/comment.rbs +26 -0
- data/sig/constant.rbs +21 -0
- data/sig/declarations.rbs +267 -0
- data/sig/definition.rbs +173 -0
- data/sig/definition_builder.rbs +165 -0
- data/sig/diff.rbs +28 -0
- data/sig/directives.rbs +77 -0
- data/sig/environment.rbs +279 -0
- data/sig/environment_loader.rbs +111 -0
- data/sig/environment_walker.rbs +65 -0
- data/sig/errors.rbs +405 -0
- data/sig/factory.rbs +5 -0
- data/sig/file_finder.rbs +28 -0
- data/sig/location.rbs +110 -0
- data/sig/locator.rbs +58 -0
- data/sig/manifest.yaml +7 -0
- data/sig/members.rbs +258 -0
- data/sig/method_builder.rbs +84 -0
- data/sig/method_types.rbs +58 -0
- data/sig/namespace.rbs +146 -0
- data/sig/parser.rbs +100 -0
- data/sig/prototype/helpers.rbs +27 -0
- data/sig/prototype/node_usage.rbs +20 -0
- data/sig/prototype/rb.rbs +96 -0
- data/sig/prototype/rbi.rbs +75 -0
- data/sig/prototype/runtime.rbs +182 -0
- data/sig/rbs.rbs +21 -0
- data/sig/rdoc/rbs.rbs +67 -0
- data/sig/repository.rbs +85 -0
- data/sig/resolver/constant_resolver.rbs +92 -0
- data/sig/resolver/context.rbs +34 -0
- data/sig/resolver/type_name_resolver.rbs +35 -0
- data/sig/shims/bundler.rbs +38 -0
- data/sig/shims/enumerable.rbs +5 -0
- data/sig/shims/rubygems.rbs +19 -0
- data/sig/sorter.rbs +41 -0
- data/sig/substitution.rbs +48 -0
- data/sig/subtractor.rbs +37 -0
- data/sig/test/errors.rbs +52 -0
- data/sig/test/guranteed.rbs +9 -0
- data/sig/test/type_check.rbs +19 -0
- data/sig/test.rbs +82 -0
- data/sig/type_alias_dependency.rbs +53 -0
- data/sig/type_alias_regularity.rbs +98 -0
- data/sig/type_param.rbs +110 -0
- data/sig/typename.rbs +79 -0
- data/sig/types.rbs +579 -0
- data/sig/unit_test/convertibles.rbs +154 -0
- data/sig/unit_test/spy.rbs +30 -0
- data/sig/unit_test/type_assertions.rbs +196 -0
- data/sig/unit_test/with_aliases.rbs +136 -0
- data/sig/use_map.rbs +35 -0
- data/sig/util.rbs +9 -0
- data/sig/validator.rbs +63 -0
- data/sig/variance_calculator.rbs +87 -0
- data/sig/vendorer.rbs +51 -0
- data/sig/version.rbs +3 -0
- data/sig/visitor.rbs +47 -0
- data/sig/writer.rbs +127 -0
- data/src/constants.c +153 -0
- data/src/ruby_objs.c +795 -0
- data/src/util/rbs_constant_pool.c +342 -0
- data/stdlib/abbrev/0/abbrev.rbs +66 -0
- data/stdlib/abbrev/0/array.rbs +26 -0
- data/stdlib/base64/0/base64.rbs +355 -0
- data/stdlib/benchmark/0/benchmark.rbs +452 -0
- data/stdlib/bigdecimal/0/big_decimal.rbs +1629 -0
- data/stdlib/bigdecimal-math/0/big_math.rbs +119 -0
- data/stdlib/bigdecimal-math/0/manifest.yaml +2 -0
- data/stdlib/cgi/0/core.rbs +1285 -0
- data/stdlib/cgi/0/manifest.yaml +3 -0
- data/stdlib/coverage/0/coverage.rbs +263 -0
- data/stdlib/csv/0/csv.rbs +3776 -0
- data/stdlib/csv/0/manifest.yaml +3 -0
- data/stdlib/date/0/date.rbs +1585 -0
- data/stdlib/date/0/date_time.rbs +616 -0
- data/stdlib/date/0/time.rbs +26 -0
- data/stdlib/dbm/0/dbm.rbs +421 -0
- data/stdlib/delegate/0/delegator.rbs +184 -0
- data/stdlib/delegate/0/kernel.rbs +47 -0
- data/stdlib/delegate/0/simple_delegator.rbs +96 -0
- data/stdlib/did_you_mean/0/did_you_mean.rbs +343 -0
- data/stdlib/digest/0/digest.rbs +577 -0
- data/stdlib/erb/0/erb.rbs +532 -0
- data/stdlib/etc/0/etc.rbs +865 -0
- data/stdlib/fileutils/0/fileutils.rbs +1734 -0
- data/stdlib/find/0/find.rbs +49 -0
- data/stdlib/forwardable/0/forwardable.rbs +268 -0
- data/stdlib/io-console/0/io-console.rbs +414 -0
- data/stdlib/ipaddr/0/ipaddr.rbs +428 -0
- data/stdlib/json/0/json.rbs +1916 -0
- data/stdlib/kconv/0/kconv.rbs +166 -0
- data/stdlib/logger/0/formatter.rbs +45 -0
- data/stdlib/logger/0/log_device.rbs +100 -0
- data/stdlib/logger/0/logger.rbs +796 -0
- data/stdlib/logger/0/manifest.yaml +2 -0
- data/stdlib/logger/0/period.rbs +17 -0
- data/stdlib/logger/0/severity.rbs +34 -0
- data/stdlib/minitest/0/kernel.rbs +42 -0
- data/stdlib/minitest/0/minitest/abstract_reporter.rbs +52 -0
- data/stdlib/minitest/0/minitest/assertion.rbs +17 -0
- data/stdlib/minitest/0/minitest/assertions.rbs +590 -0
- data/stdlib/minitest/0/minitest/backtrace_filter.rbs +23 -0
- data/stdlib/minitest/0/minitest/bench_spec.rbs +102 -0
- data/stdlib/minitest/0/minitest/benchmark.rbs +259 -0
- data/stdlib/minitest/0/minitest/composite_reporter.rbs +25 -0
- data/stdlib/minitest/0/minitest/compress.rbs +13 -0
- data/stdlib/minitest/0/minitest/error_on_warning.rbs +3 -0
- data/stdlib/minitest/0/minitest/expectation.rbs +2 -0
- data/stdlib/minitest/0/minitest/expectations.rbs +21 -0
- data/stdlib/minitest/0/minitest/guard.rbs +64 -0
- data/stdlib/minitest/0/minitest/mock.rbs +64 -0
- data/stdlib/minitest/0/minitest/parallel/executor.rbs +46 -0
- data/stdlib/minitest/0/minitest/parallel/test/class_methods.rbs +5 -0
- data/stdlib/minitest/0/minitest/parallel/test.rbs +3 -0
- data/stdlib/minitest/0/minitest/parallel.rbs +2 -0
- data/stdlib/minitest/0/minitest/pride_io.rbs +62 -0
- data/stdlib/minitest/0/minitest/pride_lol.rbs +19 -0
- data/stdlib/minitest/0/minitest/progress_reporter.rbs +11 -0
- data/stdlib/minitest/0/minitest/reportable.rbs +53 -0
- data/stdlib/minitest/0/minitest/reporter.rbs +5 -0
- data/stdlib/minitest/0/minitest/result.rbs +28 -0
- data/stdlib/minitest/0/minitest/runnable.rbs +163 -0
- data/stdlib/minitest/0/minitest/skip.rbs +6 -0
- data/stdlib/minitest/0/minitest/spec/dsl/instance_methods.rbs +48 -0
- data/stdlib/minitest/0/minitest/spec/dsl.rbs +129 -0
- data/stdlib/minitest/0/minitest/spec.rbs +11 -0
- data/stdlib/minitest/0/minitest/statistics_reporter.rbs +81 -0
- data/stdlib/minitest/0/minitest/summary_reporter.rbs +18 -0
- data/stdlib/minitest/0/minitest/test/lifecycle_hooks.rbs +92 -0
- data/stdlib/minitest/0/minitest/test.rbs +69 -0
- data/stdlib/minitest/0/minitest/unexpected_error.rbs +12 -0
- data/stdlib/minitest/0/minitest/unexpected_warning.rbs +6 -0
- data/stdlib/minitest/0/minitest/unit/test_case.rbs +3 -0
- data/stdlib/minitest/0/minitest/unit.rbs +4 -0
- data/stdlib/minitest/0/minitest.rbs +115 -0
- data/stdlib/monitor/0/monitor.rbs +363 -0
- data/stdlib/mutex_m/0/mutex_m.rbs +104 -0
- data/stdlib/net-http/0/manifest.yaml +3 -0
- data/stdlib/net-http/0/net-http.rbs +5552 -0
- data/stdlib/net-protocol/0/manifest.yaml +2 -0
- data/stdlib/net-protocol/0/net-protocol.rbs +56 -0
- data/stdlib/net-smtp/0/manifest.yaml +2 -0
- data/stdlib/net-smtp/0/net-smtp.rbs +55 -0
- data/stdlib/nkf/0/nkf.rbs +402 -0
- data/stdlib/objspace/0/objspace.rbs +487 -0
- data/stdlib/observable/0/observable.rbs +217 -0
- data/stdlib/open-uri/0/manifest.yaml +4 -0
- data/stdlib/open-uri/0/open-uri.rbs +393 -0
- data/stdlib/open3/0/open3.rbs +147 -0
- data/stdlib/openssl/0/manifest.yaml +3 -0
- data/stdlib/openssl/0/openssl.rbs +12113 -0
- data/stdlib/optparse/0/optparse.rbs +1725 -0
- data/stdlib/pathname/0/pathname.rbs +1406 -0
- data/stdlib/pp/0/manifest.yaml +2 -0
- data/stdlib/pp/0/pp.rbs +300 -0
- data/stdlib/prettyprint/0/prettyprint.rbs +383 -0
- data/stdlib/pstore/0/pstore.rbs +603 -0
- data/stdlib/psych/0/core_ext.rbs +12 -0
- data/stdlib/psych/0/dbm.rbs +237 -0
- data/stdlib/psych/0/manifest.yaml +3 -0
- data/stdlib/psych/0/psych.rbs +402 -0
- data/stdlib/psych/0/store.rbs +59 -0
- data/stdlib/pty/0/pty.rbs +237 -0
- data/stdlib/rdoc/0/code_object.rbs +51 -0
- data/stdlib/rdoc/0/comment.rbs +59 -0
- data/stdlib/rdoc/0/context.rbs +153 -0
- data/stdlib/rdoc/0/markup.rbs +117 -0
- data/stdlib/rdoc/0/parser.rbs +56 -0
- data/stdlib/rdoc/0/rdoc.rbs +391 -0
- data/stdlib/rdoc/0/ri.rbs +17 -0
- data/stdlib/rdoc/0/store.rbs +48 -0
- data/stdlib/rdoc/0/top_level.rbs +97 -0
- data/stdlib/resolv/0/manifest.yaml +3 -0
- data/stdlib/resolv/0/resolv.rbs +1830 -0
- data/stdlib/ripper/0/ripper.rbs +1648 -0
- data/stdlib/securerandom/0/securerandom.rbs +62 -0
- data/stdlib/shellwords/0/shellwords.rbs +229 -0
- data/stdlib/singleton/0/singleton.rbs +131 -0
- data/stdlib/socket/0/addrinfo.rbs +666 -0
- data/stdlib/socket/0/basic_socket.rbs +590 -0
- data/stdlib/socket/0/constants.rbs +2295 -0
- data/stdlib/socket/0/ip_socket.rbs +92 -0
- data/stdlib/socket/0/socket.rbs +4157 -0
- data/stdlib/socket/0/socket_error.rbs +5 -0
- data/stdlib/socket/0/tcp_server.rbs +192 -0
- data/stdlib/socket/0/tcp_socket.rbs +79 -0
- data/stdlib/socket/0/udp_socket.rbs +133 -0
- data/stdlib/socket/0/unix_server.rbs +169 -0
- data/stdlib/socket/0/unix_socket.rbs +172 -0
- data/stdlib/stringio/0/stringio.rbs +567 -0
- data/stdlib/strscan/0/string_scanner.rbs +1627 -0
- data/stdlib/tempfile/0/tempfile.rbs +479 -0
- data/stdlib/time/0/time.rbs +432 -0
- data/stdlib/timeout/0/timeout.rbs +81 -0
- data/stdlib/tmpdir/0/tmpdir.rbs +69 -0
- data/stdlib/tsort/0/cyclic.rbs +5 -0
- data/stdlib/tsort/0/interfaces.rbs +20 -0
- data/stdlib/tsort/0/tsort.rbs +409 -0
- data/stdlib/uri/0/common.rbs +582 -0
- data/stdlib/uri/0/file.rbs +118 -0
- data/stdlib/uri/0/ftp.rbs +13 -0
- data/stdlib/uri/0/generic.rbs +1108 -0
- data/stdlib/uri/0/http.rbs +104 -0
- data/stdlib/uri/0/https.rbs +14 -0
- data/stdlib/uri/0/ldap.rbs +230 -0
- data/stdlib/uri/0/ldaps.rbs +14 -0
- data/stdlib/uri/0/mailto.rbs +92 -0
- data/stdlib/uri/0/rfc2396_parser.rbs +189 -0
- data/stdlib/uri/0/rfc3986_parser.rbs +2 -0
- data/stdlib/uri/0/ws.rbs +13 -0
- data/stdlib/uri/0/wss.rbs +9 -0
- data/stdlib/yaml/0/manifest.yaml +2 -0
- data/stdlib/yaml/0/yaml.rbs +1 -0
- data/stdlib/zlib/0/buf_error.rbs +10 -0
- data/stdlib/zlib/0/data_error.rbs +10 -0
- data/stdlib/zlib/0/deflate.rbs +210 -0
- data/stdlib/zlib/0/error.rbs +20 -0
- data/stdlib/zlib/0/gzip_file/crc_error.rbs +12 -0
- data/stdlib/zlib/0/gzip_file/error.rbs +23 -0
- data/stdlib/zlib/0/gzip_file/length_error.rbs +12 -0
- data/stdlib/zlib/0/gzip_file/no_footer.rbs +11 -0
- data/stdlib/zlib/0/gzip_file.rbs +156 -0
- data/stdlib/zlib/0/gzip_reader.rbs +293 -0
- data/stdlib/zlib/0/gzip_writer.rbs +166 -0
- data/stdlib/zlib/0/inflate.rbs +180 -0
- data/stdlib/zlib/0/mem_error.rbs +10 -0
- data/stdlib/zlib/0/need_dict.rbs +13 -0
- data/stdlib/zlib/0/stream_end.rbs +11 -0
- data/stdlib/zlib/0/stream_error.rbs +11 -0
- data/stdlib/zlib/0/version_error.rbs +11 -0
- data/stdlib/zlib/0/zlib.rbs +449 -0
- data/stdlib/zlib/0/zstream.rbs +200 -0
- metadata +532 -0
@@ -0,0 +1,452 @@
|
|
1
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
2
|
+
# The Benchmark module provides methods to measure and report the time used to
|
3
|
+
# execute Ruby code.
|
4
|
+
#
|
5
|
+
# * Measure the time to construct the string given by the expression
|
6
|
+
# `"a"*1_000_000_000`:
|
7
|
+
#
|
8
|
+
# require 'benchmark'
|
9
|
+
#
|
10
|
+
# puts Benchmark.measure { "a"*1_000_000_000 }
|
11
|
+
#
|
12
|
+
# On my machine (OSX 10.8.3 on i5 1.7 GHz) this generates:
|
13
|
+
#
|
14
|
+
# 0.350000 0.400000 0.750000 ( 0.835234)
|
15
|
+
#
|
16
|
+
# This report shows the user CPU time, system CPU time, the sum of the user
|
17
|
+
# and system CPU times, and the elapsed real time. The unit of time is
|
18
|
+
# seconds.
|
19
|
+
#
|
20
|
+
# * Do some experiments sequentially using the #bm method:
|
21
|
+
#
|
22
|
+
# require 'benchmark'
|
23
|
+
#
|
24
|
+
# n = 5000000
|
25
|
+
# Benchmark.bm do |x|
|
26
|
+
# x.report { for i in 1..n; a = "1"; end }
|
27
|
+
# x.report { n.times do ; a = "1"; end }
|
28
|
+
# x.report { 1.upto(n) do ; a = "1"; end }
|
29
|
+
# end
|
30
|
+
#
|
31
|
+
# The result:
|
32
|
+
#
|
33
|
+
# user system total real
|
34
|
+
# 1.010000 0.000000 1.010000 ( 1.014479)
|
35
|
+
# 1.000000 0.000000 1.000000 ( 0.998261)
|
36
|
+
# 0.980000 0.000000 0.980000 ( 0.981335)
|
37
|
+
#
|
38
|
+
# * Continuing the previous example, put a label in each report:
|
39
|
+
#
|
40
|
+
# require 'benchmark'
|
41
|
+
#
|
42
|
+
# n = 5000000
|
43
|
+
# Benchmark.bm(7) do |x|
|
44
|
+
# x.report("for:") { for i in 1..n; a = "1"; end }
|
45
|
+
# x.report("times:") { n.times do ; a = "1"; end }
|
46
|
+
# x.report("upto:") { 1.upto(n) do ; a = "1"; end }
|
47
|
+
# end
|
48
|
+
#
|
49
|
+
# The result:
|
50
|
+
#
|
51
|
+
# user system total real
|
52
|
+
# for: 1.010000 0.000000 1.010000 ( 1.015688)
|
53
|
+
# times: 1.000000 0.000000 1.000000 ( 1.003611)
|
54
|
+
# upto: 1.030000 0.000000 1.030000 ( 1.028098)
|
55
|
+
#
|
56
|
+
# * The times for some benchmarks depend on the order in which items are run.
|
57
|
+
# These differences are due to the cost of memory allocation and garbage
|
58
|
+
# collection. To avoid these discrepancies, the #bmbm method is provided.
|
59
|
+
# For example, to compare ways to sort an array of floats:
|
60
|
+
#
|
61
|
+
# require 'benchmark'
|
62
|
+
#
|
63
|
+
# array = (1..1000000).map { rand }
|
64
|
+
#
|
65
|
+
# Benchmark.bmbm do |x|
|
66
|
+
# x.report("sort!") { array.dup.sort! }
|
67
|
+
# x.report("sort") { array.dup.sort }
|
68
|
+
# end
|
69
|
+
#
|
70
|
+
# The result:
|
71
|
+
#
|
72
|
+
# Rehearsal -----------------------------------------
|
73
|
+
# sort! 1.490000 0.010000 1.500000 ( 1.490520)
|
74
|
+
# sort 1.460000 0.000000 1.460000 ( 1.463025)
|
75
|
+
# -------------------------------- total: 2.960000sec
|
76
|
+
#
|
77
|
+
# user system total real
|
78
|
+
# sort! 1.460000 0.000000 1.460000 ( 1.460465)
|
79
|
+
# sort 1.450000 0.010000 1.460000 ( 1.448327)
|
80
|
+
#
|
81
|
+
# * Report statistics of sequential experiments with unique labels, using the
|
82
|
+
# #benchmark method:
|
83
|
+
#
|
84
|
+
# require 'benchmark'
|
85
|
+
# include Benchmark # we need the CAPTION and FORMAT constants
|
86
|
+
#
|
87
|
+
# n = 5000000
|
88
|
+
# Benchmark.benchmark(CAPTION, 7, FORMAT, ">total:", ">avg:") do |x|
|
89
|
+
# tf = x.report("for:") { for i in 1..n; a = "1"; end }
|
90
|
+
# tt = x.report("times:") { n.times do ; a = "1"; end }
|
91
|
+
# tu = x.report("upto:") { 1.upto(n) do ; a = "1"; end }
|
92
|
+
# [tf+tt+tu, (tf+tt+tu)/3]
|
93
|
+
# end
|
94
|
+
#
|
95
|
+
# The result:
|
96
|
+
#
|
97
|
+
# user system total real
|
98
|
+
# for: 0.950000 0.000000 0.950000 ( 0.952039)
|
99
|
+
# times: 0.980000 0.000000 0.980000 ( 0.984938)
|
100
|
+
# upto: 0.950000 0.000000 0.950000 ( 0.946787)
|
101
|
+
# >total: 2.880000 0.000000 2.880000 ( 2.883764)
|
102
|
+
# >avg: 0.960000 0.000000 0.960000 ( 0.961255)
|
103
|
+
#
|
104
|
+
module Benchmark
|
105
|
+
# <!--
|
106
|
+
# rdoc-file=lib/benchmark.rb
|
107
|
+
# - benchmark(caption = "", label_width = nil, format = nil, *labels) { |report| ... }
|
108
|
+
# -->
|
109
|
+
# Invokes the block with a Benchmark::Report object, which may be used to
|
110
|
+
# collect and report on the results of individual benchmark tests. Reserves
|
111
|
+
# `label_width` leading spaces for labels on each line. Prints `caption` at the
|
112
|
+
# top of the report, and uses `format` to format each line. (Note: `caption`
|
113
|
+
# must contain a terminating newline character, see the default
|
114
|
+
# Benchmark::Tms::CAPTION for an example.)
|
115
|
+
#
|
116
|
+
# Returns an array of Benchmark::Tms objects.
|
117
|
+
#
|
118
|
+
# If the block returns an array of Benchmark::Tms objects, these will be used to
|
119
|
+
# format additional lines of output. If `labels` parameter are given, these are
|
120
|
+
# used to label these extra lines.
|
121
|
+
#
|
122
|
+
# *Note*: Other methods provide a simpler interface to this one, and are
|
123
|
+
# suitable for nearly all benchmarking requirements. See the examples in
|
124
|
+
# Benchmark, and the #bm and #bmbm methods.
|
125
|
+
#
|
126
|
+
# Example:
|
127
|
+
#
|
128
|
+
# require 'benchmark'
|
129
|
+
# include Benchmark # we need the CAPTION and FORMAT constants
|
130
|
+
#
|
131
|
+
# n = 5000000
|
132
|
+
# Benchmark.benchmark(CAPTION, 7, FORMAT, ">total:", ">avg:") do |x|
|
133
|
+
# tf = x.report("for:") { for i in 1..n; a = "1"; end }
|
134
|
+
# tt = x.report("times:") { n.times do ; a = "1"; end }
|
135
|
+
# tu = x.report("upto:") { 1.upto(n) do ; a = "1"; end }
|
136
|
+
# [tf+tt+tu, (tf+tt+tu)/3]
|
137
|
+
# end
|
138
|
+
#
|
139
|
+
# Generates:
|
140
|
+
#
|
141
|
+
# user system total real
|
142
|
+
# for: 0.970000 0.000000 0.970000 ( 0.970493)
|
143
|
+
# times: 0.990000 0.000000 0.990000 ( 0.989542)
|
144
|
+
# upto: 0.970000 0.000000 0.970000 ( 0.972854)
|
145
|
+
# >total: 2.930000 0.000000 2.930000 ( 2.932889)
|
146
|
+
# >avg: 0.976667 0.000000 0.976667 ( 0.977630)
|
147
|
+
#
|
148
|
+
def self?.benchmark: (String caption, ?Integer? label_width, ?String? format, *String labels) { (Report report) -> (Array[Tms] | untyped) } -> Array[Tms]
|
149
|
+
|
150
|
+
# <!--
|
151
|
+
# rdoc-file=lib/benchmark.rb
|
152
|
+
# - bm(label_width = 0, *labels) { |report| ... }
|
153
|
+
# -->
|
154
|
+
# A simple interface to the #benchmark method, #bm generates sequential reports
|
155
|
+
# with labels. `label_width` and `labels` parameters have the same meaning as
|
156
|
+
# for #benchmark.
|
157
|
+
#
|
158
|
+
# require 'benchmark'
|
159
|
+
#
|
160
|
+
# n = 5000000
|
161
|
+
# Benchmark.bm(7) do |x|
|
162
|
+
# x.report("for:") { for i in 1..n; a = "1"; end }
|
163
|
+
# x.report("times:") { n.times do ; a = "1"; end }
|
164
|
+
# x.report("upto:") { 1.upto(n) do ; a = "1"; end }
|
165
|
+
# end
|
166
|
+
#
|
167
|
+
# Generates:
|
168
|
+
#
|
169
|
+
# user system total real
|
170
|
+
# for: 0.960000 0.000000 0.960000 ( 0.957966)
|
171
|
+
# times: 0.960000 0.000000 0.960000 ( 0.960423)
|
172
|
+
# upto: 0.950000 0.000000 0.950000 ( 0.954864)
|
173
|
+
#
|
174
|
+
def self?.bm: (?Integer label_width, *String labels) { (Report report) -> void } -> Array[Tms]
|
175
|
+
|
176
|
+
# <!--
|
177
|
+
# rdoc-file=lib/benchmark.rb
|
178
|
+
# - bmbm(width = 0) { |job| ... }
|
179
|
+
# -->
|
180
|
+
# Sometimes benchmark results are skewed because code executed earlier
|
181
|
+
# encounters different garbage collection overheads than that run later. #bmbm
|
182
|
+
# attempts to minimize this effect by running the tests twice, the first time as
|
183
|
+
# a rehearsal in order to get the runtime environment stable, the second time
|
184
|
+
# for real. GC.start is executed before the start of each of the real timings;
|
185
|
+
# the cost of this is not included in the timings. In reality, though, there's
|
186
|
+
# only so much that #bmbm can do, and the results are not guaranteed to be
|
187
|
+
# isolated from garbage collection and other effects.
|
188
|
+
#
|
189
|
+
# Because #bmbm takes two passes through the tests, it can calculate the
|
190
|
+
# required label width.
|
191
|
+
#
|
192
|
+
# require 'benchmark'
|
193
|
+
#
|
194
|
+
# array = (1..1000000).map { rand }
|
195
|
+
#
|
196
|
+
# Benchmark.bmbm do |x|
|
197
|
+
# x.report("sort!") { array.dup.sort! }
|
198
|
+
# x.report("sort") { array.dup.sort }
|
199
|
+
# end
|
200
|
+
#
|
201
|
+
# Generates:
|
202
|
+
#
|
203
|
+
# Rehearsal -----------------------------------------
|
204
|
+
# sort! 1.440000 0.010000 1.450000 ( 1.446833)
|
205
|
+
# sort 1.440000 0.000000 1.440000 ( 1.448257)
|
206
|
+
# -------------------------------- total: 2.890000sec
|
207
|
+
#
|
208
|
+
# user system total real
|
209
|
+
# sort! 1.460000 0.000000 1.460000 ( 1.458065)
|
210
|
+
# sort 1.450000 0.000000 1.450000 ( 1.455963)
|
211
|
+
#
|
212
|
+
# #bmbm yields a Benchmark::Job object and returns an array of Benchmark::Tms
|
213
|
+
# objects.
|
214
|
+
#
|
215
|
+
def self?.bmbm: (?Integer width) { (Job job) -> void } -> Array[Tms]
|
216
|
+
|
217
|
+
# <!--
|
218
|
+
# rdoc-file=lib/benchmark.rb
|
219
|
+
# - measure(label = "") { || ... }
|
220
|
+
# -->
|
221
|
+
# Returns the time used to execute the given block as a Benchmark::Tms object.
|
222
|
+
# Takes `label` option.
|
223
|
+
#
|
224
|
+
# require 'benchmark'
|
225
|
+
#
|
226
|
+
# n = 1000000
|
227
|
+
#
|
228
|
+
# time = Benchmark.measure do
|
229
|
+
# n.times { a = "1" }
|
230
|
+
# end
|
231
|
+
# puts time
|
232
|
+
#
|
233
|
+
# Generates:
|
234
|
+
#
|
235
|
+
# 0.220000 0.000000 0.220000 ( 0.227313)
|
236
|
+
#
|
237
|
+
def self?.measure: (?String label) { () -> void } -> Tms
|
238
|
+
|
239
|
+
# <!--
|
240
|
+
# rdoc-file=lib/benchmark.rb
|
241
|
+
# - realtime() { || ... }
|
242
|
+
# -->
|
243
|
+
# Returns the elapsed real time used to execute the given block. The unit of
|
244
|
+
# time is seconds.
|
245
|
+
#
|
246
|
+
# Benchmark.realtime { "a" * 1_000_000_000 }
|
247
|
+
# #=> 0.5098029999935534
|
248
|
+
#
|
249
|
+
def self?.realtime: () { () -> void } -> Float
|
250
|
+
|
251
|
+
BENCHMARK_VERSION: String
|
252
|
+
|
253
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
254
|
+
# The default caption string (heading above the output times).
|
255
|
+
#
|
256
|
+
CAPTION: String
|
257
|
+
|
258
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
259
|
+
# The default format string used to display times. See also
|
260
|
+
# Benchmark::Tms#format.
|
261
|
+
#
|
262
|
+
FORMAT: String
|
263
|
+
|
264
|
+
class Job
|
265
|
+
# Prints the `label` and measured time for the block,
|
266
|
+
# formatted by `format`. See Tms#format for the
|
267
|
+
# formatting rules.
|
268
|
+
def item: (?String label) { () -> void } -> self
|
269
|
+
|
270
|
+
# An array of 2-element arrays, consisting of label and block pairs.
|
271
|
+
def list: () -> Array[untyped]
|
272
|
+
|
273
|
+
alias report item
|
274
|
+
|
275
|
+
# Length of the widest label in the #list.
|
276
|
+
def width: () -> Integer
|
277
|
+
end
|
278
|
+
|
279
|
+
class Report
|
280
|
+
# Prints the `label` and measured time for the block,
|
281
|
+
# formatted by `format`. See Tms#format for the
|
282
|
+
# formatting rules.
|
283
|
+
def item: (?String label, *untyped format) { () -> void } -> Tms
|
284
|
+
|
285
|
+
# An array of Benchmark::Tms objects representing each item.
|
286
|
+
def list: () -> Array[Tms]
|
287
|
+
|
288
|
+
alias report item
|
289
|
+
end
|
290
|
+
|
291
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
292
|
+
# A data object, representing the times associated with a benchmark measurement.
|
293
|
+
#
|
294
|
+
class Tms
|
295
|
+
# <!--
|
296
|
+
# rdoc-file=lib/benchmark.rb
|
297
|
+
# - *(x)
|
298
|
+
# -->
|
299
|
+
# Returns a new Tms object obtained by memberwise multiplication of the
|
300
|
+
# individual times for this Tms object by `x`.
|
301
|
+
#
|
302
|
+
def *: (untyped x) -> untyped
|
303
|
+
|
304
|
+
# <!--
|
305
|
+
# rdoc-file=lib/benchmark.rb
|
306
|
+
# - +(other)
|
307
|
+
# -->
|
308
|
+
# Returns a new Tms object obtained by memberwise summation of the individual
|
309
|
+
# times for this Tms object with those of the `other` Tms object. This method
|
310
|
+
# and #/() are useful for taking statistics.
|
311
|
+
#
|
312
|
+
def +: (untyped other) -> untyped
|
313
|
+
|
314
|
+
# <!--
|
315
|
+
# rdoc-file=lib/benchmark.rb
|
316
|
+
# - -(other)
|
317
|
+
# -->
|
318
|
+
# Returns a new Tms object obtained by memberwise subtraction of the individual
|
319
|
+
# times for the `other` Tms object from those of this Tms object.
|
320
|
+
#
|
321
|
+
def -: (untyped other) -> untyped
|
322
|
+
|
323
|
+
# <!--
|
324
|
+
# rdoc-file=lib/benchmark.rb
|
325
|
+
# - /(x)
|
326
|
+
# -->
|
327
|
+
# Returns a new Tms object obtained by memberwise division of the individual
|
328
|
+
# times for this Tms object by `x`. This method and #+() are useful for taking
|
329
|
+
# statistics.
|
330
|
+
#
|
331
|
+
def /: (untyped x) -> untyped
|
332
|
+
|
333
|
+
# <!--
|
334
|
+
# rdoc-file=lib/benchmark.rb
|
335
|
+
# - add() { || ... }
|
336
|
+
# -->
|
337
|
+
# Returns a new Tms object whose times are the sum of the times for this Tms
|
338
|
+
# object, plus the time required to execute the code block (`blk`).
|
339
|
+
#
|
340
|
+
def add: () { (*untyped) -> untyped } -> untyped
|
341
|
+
|
342
|
+
# <!--
|
343
|
+
# rdoc-file=lib/benchmark.rb
|
344
|
+
# - add!(&blk)
|
345
|
+
# -->
|
346
|
+
# An in-place version of #add. Changes the times of this Tms object by making it
|
347
|
+
# the sum of the times for this Tms object, plus the time required to execute
|
348
|
+
# the code block (`blk`).
|
349
|
+
#
|
350
|
+
def add!: () { (*untyped) -> untyped } -> untyped
|
351
|
+
|
352
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
353
|
+
# System CPU time of children
|
354
|
+
#
|
355
|
+
def cstime: () -> Float
|
356
|
+
|
357
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
358
|
+
# User CPU time of children
|
359
|
+
#
|
360
|
+
def cutime: () -> Float
|
361
|
+
|
362
|
+
# <!--
|
363
|
+
# rdoc-file=lib/benchmark.rb
|
364
|
+
# - format(format = nil, *args)
|
365
|
+
# -->
|
366
|
+
# Returns the contents of this Tms object as a formatted string, according to a
|
367
|
+
# `format` string like that passed to Kernel.format. In addition, #format
|
368
|
+
# accepts the following extensions:
|
369
|
+
#
|
370
|
+
# `%u`
|
371
|
+
# : Replaced by the user CPU time, as reported by Tms#utime.
|
372
|
+
#
|
373
|
+
# `%y`
|
374
|
+
# : Replaced by the system CPU time, as reported by #stime (Mnemonic: y of
|
375
|
+
# "s*y*stem")
|
376
|
+
#
|
377
|
+
# `%U`
|
378
|
+
# : Replaced by the children's user CPU time, as reported by Tms#cutime
|
379
|
+
#
|
380
|
+
# `%Y`
|
381
|
+
# : Replaced by the children's system CPU time, as reported by Tms#cstime
|
382
|
+
#
|
383
|
+
# `%t`
|
384
|
+
# : Replaced by the total CPU time, as reported by Tms#total
|
385
|
+
#
|
386
|
+
# `%r`
|
387
|
+
# : Replaced by the elapsed real time, as reported by Tms#real
|
388
|
+
#
|
389
|
+
# `%n`
|
390
|
+
# : Replaced by the label string, as reported by Tms#label (Mnemonic: n of
|
391
|
+
# "*n*ame")
|
392
|
+
#
|
393
|
+
#
|
394
|
+
# If `format` is not given, FORMAT is used as default value, detailing the user,
|
395
|
+
# system and real elapsed time.
|
396
|
+
#
|
397
|
+
def format: (?String format, *untyped args) -> String
|
398
|
+
|
399
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
400
|
+
# Label
|
401
|
+
#
|
402
|
+
def label: () -> String
|
403
|
+
|
404
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
405
|
+
# Elapsed real time
|
406
|
+
#
|
407
|
+
def real: () -> Float
|
408
|
+
|
409
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
410
|
+
# System CPU time
|
411
|
+
#
|
412
|
+
def stime: () -> Float
|
413
|
+
|
414
|
+
# <!--
|
415
|
+
# rdoc-file=lib/benchmark.rb
|
416
|
+
# - to_a()
|
417
|
+
# -->
|
418
|
+
# Returns a new 6-element array, consisting of the label, user CPU time, system
|
419
|
+
# CPU time, children's user CPU time, children's system CPU time and elapsed
|
420
|
+
# real time.
|
421
|
+
#
|
422
|
+
def to_a: () -> untyped
|
423
|
+
|
424
|
+
# <!--
|
425
|
+
# rdoc-file=lib/benchmark.rb
|
426
|
+
# - to_s()
|
427
|
+
# -->
|
428
|
+
# Same as #format.
|
429
|
+
#
|
430
|
+
def to_s: () -> String
|
431
|
+
|
432
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
433
|
+
# Total time, that is `utime` + `stime` + `cutime` + `cstime`
|
434
|
+
#
|
435
|
+
def total: () -> Float
|
436
|
+
|
437
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
438
|
+
# User CPU time
|
439
|
+
#
|
440
|
+
def utime: () -> Float
|
441
|
+
|
442
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
443
|
+
# Default caption, see also Benchmark::CAPTION
|
444
|
+
#
|
445
|
+
CAPTION: String
|
446
|
+
|
447
|
+
# <!-- rdoc-file=lib/benchmark.rb -->
|
448
|
+
# Default format string, see also Benchmark::FORMAT
|
449
|
+
#
|
450
|
+
FORMAT: String
|
451
|
+
end
|
452
|
+
end
|