enclave 0.1.0
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/README.md +182 -0
- data/Rakefile +30 -0
- data/ext/enclave/enclave.c +390 -0
- data/ext/enclave/extconf.rb +33 -0
- data/ext/enclave/mruby/Makefile +63 -0
- data/ext/enclave/mruby/Rakefile +102 -0
- data/ext/enclave/mruby/benchmark/bm_ao_render.rb +309 -0
- data/ext/enclave/mruby/benchmark/bm_app_lc_fizzbuzz.rb +51 -0
- data/ext/enclave/mruby/benchmark/bm_fib.rb +6 -0
- data/ext/enclave/mruby/benchmark/bm_mandel_term.rb +34 -0
- data/ext/enclave/mruby/benchmark/bm_so_lists.rb +49 -0
- data/ext/enclave/mruby/benchmark/bm_so_mandelbrot.rb +65 -0
- data/ext/enclave/mruby/benchmark/vm_dispatch_bench.c +197 -0
- data/ext/enclave/mruby/benchmark/vm_optimization_bench.rb +513 -0
- data/ext/enclave/mruby/build/host/include/mrbconf.h +230 -0
- data/ext/enclave/mruby/build/host/include/mruby/array.h +303 -0
- data/ext/enclave/mruby/build/host/include/mruby/boxing_nan.h +169 -0
- data/ext/enclave/mruby/build/host/include/mruby/boxing_no.h +59 -0
- data/ext/enclave/mruby/build/host/include/mruby/boxing_word.h +248 -0
- data/ext/enclave/mruby/build/host/include/mruby/class.h +157 -0
- data/ext/enclave/mruby/build/host/include/mruby/common.h +127 -0
- data/ext/enclave/mruby/build/host/include/mruby/compile.h +187 -0
- data/ext/enclave/mruby/build/host/include/mruby/data.h +76 -0
- data/ext/enclave/mruby/build/host/include/mruby/debug.h +75 -0
- data/ext/enclave/mruby/build/host/include/mruby/dump.h +159 -0
- data/ext/enclave/mruby/build/host/include/mruby/endian.h +44 -0
- data/ext/enclave/mruby/build/host/include/mruby/error.h +168 -0
- data/ext/enclave/mruby/build/host/include/mruby/gc.h +77 -0
- data/ext/enclave/mruby/build/host/include/mruby/hash.h +234 -0
- data/ext/enclave/mruby/build/host/include/mruby/internal.h +278 -0
- data/ext/enclave/mruby/build/host/include/mruby/irep.h +142 -0
- data/ext/enclave/mruby/build/host/include/mruby/istruct.h +50 -0
- data/ext/enclave/mruby/build/host/include/mruby/khash.h +455 -0
- data/ext/enclave/mruby/build/host/include/mruby/mempool.h +19 -0
- data/ext/enclave/mruby/build/host/include/mruby/numeric.h +174 -0
- data/ext/enclave/mruby/build/host/include/mruby/object.h +44 -0
- data/ext/enclave/mruby/build/host/include/mruby/opcode.h +73 -0
- data/ext/enclave/mruby/build/host/include/mruby/ops.h +133 -0
- data/ext/enclave/mruby/build/host/include/mruby/presym/id.h +895 -0
- data/ext/enclave/mruby/build/host/include/mruby/presym/scanning.h +82 -0
- data/ext/enclave/mruby/build/host/include/mruby/presym/table.h +1787 -0
- data/ext/enclave/mruby/build/host/include/mruby/presym.h +65 -0
- data/ext/enclave/mruby/build/host/include/mruby/proc.h +184 -0
- data/ext/enclave/mruby/build/host/include/mruby/range.h +77 -0
- data/ext/enclave/mruby/build/host/include/mruby/re.h +16 -0
- data/ext/enclave/mruby/build/host/include/mruby/string.h +428 -0
- data/ext/enclave/mruby/build/host/include/mruby/throw.h +81 -0
- data/ext/enclave/mruby/build/host/include/mruby/value.h +471 -0
- data/ext/enclave/mruby/build/host/include/mruby/variable.h +108 -0
- data/ext/enclave/mruby/build/host/include/mruby/version.h +143 -0
- data/ext/enclave/mruby/build/host/include/mruby.h +1632 -0
- data/ext/enclave/mruby/build/host/mrbc/include/mruby/presym/id.h +281 -0
- data/ext/enclave/mruby/build/host/mrbc/include/mruby/presym/table.h +559 -0
- data/ext/enclave/mruby/build/host/mrbgems/gem_init.c +164 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-array-ext/gem_init.c +650 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-binding/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-catch/gem_init.c +86 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-class-ext/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-compar-ext/gem_init.c +99 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-complex/gem_init.c +362 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-data/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-enum-chain/gem_init.c +229 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-enum-ext/gem_init.c +1420 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-enum-lazy/gem_init.c +602 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-enumerator/gem_init.c +822 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-eval/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-fiber/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-hash-ext/gem_init.c +591 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-kernel-ext/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-math/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-metaprog/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-method/gem_init.c +153 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-numeric-ext/gem_init.c +211 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-object-ext/gem_init.c +94 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-objectspace/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-pack/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-proc-binding/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-proc-ext/gem_init.c +237 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-random/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-range-ext/gem_init.c +205 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-rational/gem_init.c +147 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-set/gem_init.c +487 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-sprintf/gem_init.c +83 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-string-ext/gem_init.c +220 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-struct/gem_init.c +175 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-symbol-ext/gem_init.c +153 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-time/gem_init.c +21 -0
- data/ext/enclave/mruby/build/host/mrbgems/mruby-toplevel-ext/gem_init.c +78 -0
- data/ext/enclave/mruby/build/host/mrblib/mrblib.c +1758 -0
- data/ext/enclave/mruby/build_config/ArduinoDue.rb +72 -0
- data/ext/enclave/mruby/build_config/IntelEdison.rb +69 -0
- data/ext/enclave/mruby/build_config/IntelGalileo.rb +88 -0
- data/ext/enclave/mruby/build_config/RX630.rb +63 -0
- data/ext/enclave/mruby/build_config/android_arm64_v8a.rb +11 -0
- data/ext/enclave/mruby/build_config/android_armeabi_v7a_neon_hard.rb +13 -0
- data/ext/enclave/mruby/build_config/bench.rb +11 -0
- data/ext/enclave/mruby/build_config/boxing.rb +19 -0
- data/ext/enclave/mruby/build_config/chipKITMax32.rb +68 -0
- data/ext/enclave/mruby/build_config/ci/gcc-clang.rb +40 -0
- data/ext/enclave/mruby/build_config/ci/msvc.rb +20 -0
- data/ext/enclave/mruby/build_config/clang-asan.rb +11 -0
- data/ext/enclave/mruby/build_config/cosmopolitan.rb +86 -0
- data/ext/enclave/mruby/build_config/cross-32bit.rb +14 -0
- data/ext/enclave/mruby/build_config/cross-mingw-winetest.rb +90 -0
- data/ext/enclave/mruby/build_config/cross-mingw.rb +14 -0
- data/ext/enclave/mruby/build_config/default.rb +83 -0
- data/ext/enclave/mruby/build_config/dreamcast_shelf.rb +81 -0
- data/ext/enclave/mruby/build_config/emscripten-cxx.rb +12 -0
- data/ext/enclave/mruby/build_config/emscripten.rb +10 -0
- data/ext/enclave/mruby/build_config/gameboyadvance.rb +72 -0
- data/ext/enclave/mruby/build_config/helpers/wine_runner.rb +71 -0
- data/ext/enclave/mruby/build_config/host-cxx.rb +12 -0
- data/ext/enclave/mruby/build_config/host-debug.rb +20 -0
- data/ext/enclave/mruby/build_config/host-f32.rb +14 -0
- data/ext/enclave/mruby/build_config/host-gprof.rb +14 -0
- data/ext/enclave/mruby/build_config/host-m32.rb +15 -0
- data/ext/enclave/mruby/build_config/host-nofloat.rb +22 -0
- data/ext/enclave/mruby/build_config/host-shared.rb +36 -0
- data/ext/enclave/mruby/build_config/i586-pc-msdosdjgpp.rb +76 -0
- data/ext/enclave/mruby/build_config/luckfox_pico.rb +106 -0
- data/ext/enclave/mruby/build_config/milkv_duo.rb +106 -0
- data/ext/enclave/mruby/build_config/minimal.rb +4 -0
- data/ext/enclave/mruby/build_config/mrbc.rb +10 -0
- data/ext/enclave/mruby/build_config/nintendo_switch.rb +73 -0
- data/ext/enclave/mruby/build_config/nintendo_wii.rb +95 -0
- data/ext/enclave/mruby/build_config/no-float.rb +17 -0
- data/ext/enclave/mruby/build_config/playstationportable.rb +78 -0
- data/ext/enclave/mruby/build_config/serenity.rb +26 -0
- data/ext/enclave/mruby/build_config.rb +9 -0
- data/ext/enclave/mruby/examples/mrbgems/c_and_ruby_extension_example/mrblib/example.rb +5 -0
- data/ext/enclave/mruby/examples/mrbgems/c_and_ruby_extension_example/src/example.c +23 -0
- data/ext/enclave/mruby/examples/mrbgems/c_and_ruby_extension_example/test/example.rb +7 -0
- data/ext/enclave/mruby/examples/mrbgems/c_extension_example/src/example.c +23 -0
- data/ext/enclave/mruby/examples/mrbgems/c_extension_example/test/example.c +7 -0
- data/ext/enclave/mruby/examples/mrbgems/c_extension_example/test/example.rb +3 -0
- data/ext/enclave/mruby/examples/mrbgems/cdata_extension_example/src/example.c +77 -0
- data/ext/enclave/mruby/examples/mrbgems/cdata_extension_example/test/example.c +7 -0
- data/ext/enclave/mruby/examples/mrbgems/mruby-YOUR-bigint/core/bigint.c +70 -0
- data/ext/enclave/mruby/examples/mrbgems/ruby_extension_example/mrblib/example.rb +5 -0
- data/ext/enclave/mruby/examples/mrbgems/ruby_extension_example/test/example.rb +3 -0
- data/ext/enclave/mruby/include/mrbconf.h +230 -0
- data/ext/enclave/mruby/include/mruby/array.h +303 -0
- data/ext/enclave/mruby/include/mruby/boxing_nan.h +169 -0
- data/ext/enclave/mruby/include/mruby/boxing_no.h +59 -0
- data/ext/enclave/mruby/include/mruby/boxing_word.h +248 -0
- data/ext/enclave/mruby/include/mruby/class.h +157 -0
- data/ext/enclave/mruby/include/mruby/common.h +127 -0
- data/ext/enclave/mruby/include/mruby/compile.h +187 -0
- data/ext/enclave/mruby/include/mruby/data.h +76 -0
- data/ext/enclave/mruby/include/mruby/debug.h +75 -0
- data/ext/enclave/mruby/include/mruby/dump.h +159 -0
- data/ext/enclave/mruby/include/mruby/endian.h +44 -0
- data/ext/enclave/mruby/include/mruby/error.h +168 -0
- data/ext/enclave/mruby/include/mruby/gc.h +77 -0
- data/ext/enclave/mruby/include/mruby/hash.h +234 -0
- data/ext/enclave/mruby/include/mruby/internal.h +278 -0
- data/ext/enclave/mruby/include/mruby/irep.h +142 -0
- data/ext/enclave/mruby/include/mruby/istruct.h +50 -0
- data/ext/enclave/mruby/include/mruby/khash.h +455 -0
- data/ext/enclave/mruby/include/mruby/mempool.h +19 -0
- data/ext/enclave/mruby/include/mruby/numeric.h +174 -0
- data/ext/enclave/mruby/include/mruby/object.h +44 -0
- data/ext/enclave/mruby/include/mruby/opcode.h +73 -0
- data/ext/enclave/mruby/include/mruby/ops.h +133 -0
- data/ext/enclave/mruby/include/mruby/presym/scanning.h +82 -0
- data/ext/enclave/mruby/include/mruby/presym.h +65 -0
- data/ext/enclave/mruby/include/mruby/proc.h +184 -0
- data/ext/enclave/mruby/include/mruby/range.h +77 -0
- data/ext/enclave/mruby/include/mruby/re.h +16 -0
- data/ext/enclave/mruby/include/mruby/string.h +428 -0
- data/ext/enclave/mruby/include/mruby/throw.h +81 -0
- data/ext/enclave/mruby/include/mruby/value.h +471 -0
- data/ext/enclave/mruby/include/mruby/variable.h +108 -0
- data/ext/enclave/mruby/include/mruby/version.h +143 -0
- data/ext/enclave/mruby/include/mruby.h +1632 -0
- data/ext/enclave/mruby/lib/mruby/amalgam.rb +568 -0
- data/ext/enclave/mruby/lib/mruby/build/command.rb +383 -0
- data/ext/enclave/mruby/lib/mruby/build/load_gems.rb +383 -0
- data/ext/enclave/mruby/lib/mruby/build.rb +616 -0
- data/ext/enclave/mruby/lib/mruby/core_ext.rb +61 -0
- data/ext/enclave/mruby/lib/mruby/doc.rb +51 -0
- data/ext/enclave/mruby/lib/mruby/gem.rb +585 -0
- data/ext/enclave/mruby/lib/mruby/lockfile.rb +81 -0
- data/ext/enclave/mruby/lib/mruby/presym.rb +167 -0
- data/ext/enclave/mruby/lib/mruby/source.rb +32 -0
- data/ext/enclave/mruby/mrbgems/default-no-fpu.gembox +3 -0
- data/ext/enclave/mruby/mrbgems/default-no-stdio.gembox +4 -0
- data/ext/enclave/mruby/mrbgems/default.gembox +25 -0
- data/ext/enclave/mruby/mrbgems/full-core.gembox +6 -0
- data/ext/enclave/mruby/mrbgems/hal-posix-dir/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/hal-posix-dir/src/dir_hal.c +193 -0
- data/ext/enclave/mruby/mrbgems/hal-posix-io/mrbgem.rake +8 -0
- data/ext/enclave/mruby/mrbgems/hal-posix-io/src/io_hal.c +602 -0
- data/ext/enclave/mruby/mrbgems/hal-posix-socket/mrbgem.rake +8 -0
- data/ext/enclave/mruby/mrbgems/hal-posix-socket/src/socket_hal.c +158 -0
- data/ext/enclave/mruby/mrbgems/hal-posix-task/README.md +102 -0
- data/ext/enclave/mruby/mrbgems/hal-posix-task/mrbgem.rake +8 -0
- data/ext/enclave/mruby/mrbgems/hal-posix-task/src/task_hal.c +252 -0
- data/ext/enclave/mruby/mrbgems/hal-win-dir/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/hal-win-dir/src/dir_hal.c +249 -0
- data/ext/enclave/mruby/mrbgems/hal-win-io/mrbgem.rake +11 -0
- data/ext/enclave/mruby/mrbgems/hal-win-io/src/io_hal.c +646 -0
- data/ext/enclave/mruby/mrbgems/hal-win-socket/mrbgem.rake +12 -0
- data/ext/enclave/mruby/mrbgems/hal-win-socket/src/socket_hal.c +177 -0
- data/ext/enclave/mruby/mrbgems/hal-win-task/README.md +109 -0
- data/ext/enclave/mruby/mrbgems/hal-win-task/mrbgem.rake +11 -0
- data/ext/enclave/mruby/mrbgems/hal-win-task/src/task_hal.c +187 -0
- data/ext/enclave/mruby/mrbgems/math.gembox +12 -0
- data/ext/enclave/mruby/mrbgems/metaprog.gembox +21 -0
- data/ext/enclave/mruby/mrbgems/mruby-array-ext/README.md +87 -0
- data/ext/enclave/mruby/mrbgems/mruby-array-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-array-ext/mrblib/array.rb +784 -0
- data/ext/enclave/mruby/mrbgems/mruby-array-ext/src/array.c +1583 -0
- data/ext/enclave/mruby/mrbgems/mruby-array-ext/test/array.rb +849 -0
- data/ext/enclave/mruby/mrbgems/mruby-benchmark/README.md +257 -0
- data/ext/enclave/mruby/mrbgems/mruby-benchmark/mrbgem.rake +10 -0
- data/ext/enclave/mruby/mrbgems/mruby-benchmark/mrblib/benchmark.rb +131 -0
- data/ext/enclave/mruby/mrbgems/mruby-benchmark/test/benchmark.rb +244 -0
- data/ext/enclave/mruby/mrbgems/mruby-bigint/README-fgmp.md +154 -0
- data/ext/enclave/mruby/mrbgems/mruby-bigint/README.md +44 -0
- data/ext/enclave/mruby/mrbgems/mruby-bigint/core/bigint.c +6335 -0
- data/ext/enclave/mruby/mrbgems/mruby-bigint/core/bigint.h +117 -0
- data/ext/enclave/mruby/mrbgems/mruby-bigint/mrbgem.rake +10 -0
- data/ext/enclave/mruby/mrbgems/mruby-bigint/test/bigint.rb +157 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-config/README.md +46 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-config/mrbgem.rake +49 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-config/mruby-config +46 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-config/mruby-config.bat +92 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/README.md +63 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/bintest/mrdb.rb +283 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/bintest/print.rb +703 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/mrbgem.rake +10 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apibreak.c +523 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apibreak.h +26 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apilist.c +238 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apilist.h +14 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apiprint.c +88 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apiprint.h +13 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apistring.c +34 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apistring.h +14 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/cmdbreak.c +436 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/cmdmisc.c +509 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/cmdprint.c +71 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/cmdrun.c +64 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdb.c +768 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdb.h +159 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdbconf.h +24 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdberror.h +19 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/README.md +94 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/bintest/mirb.rb +58 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c +808 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_buffer.c +1035 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_buffer.h +185 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_completion.c +797 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_completion.h +132 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_editor.c +1118 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_editor.h +153 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_highlight.c +516 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_highlight.h +95 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_history.c +185 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_history.h +76 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_term.c +491 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb_term.h +137 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mrbc/README.md +58 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mrbc/bintest/mrbc.rb +30 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mrbc/mrbgem.rake +15 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mrbc/tools/mrbc/mrbc.c +362 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mrbc/tools/mrbc/stub.c +104 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mruby/README.md +47 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mruby/bintest/mruby.rb +178 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mruby/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-mruby/tools/mruby/mruby.c +380 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-strip/README.md +38 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-strip/bintest/mruby_strip.rb +73 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-strip/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-bin-strip/tools/mruby-strip/mruby_strip.c +139 -0
- data/ext/enclave/mruby/mrbgems/mruby-binding/README.md +256 -0
- data/ext/enclave/mruby/mrbgems/mruby-binding/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-binding/src/binding.c +518 -0
- data/ext/enclave/mruby/mrbgems/mruby-binding/test/binding.c +14 -0
- data/ext/enclave/mruby/mrbgems/mruby-binding/test/binding.rb +64 -0
- data/ext/enclave/mruby/mrbgems/mruby-catch/README.md +94 -0
- data/ext/enclave/mruby/mrbgems/mruby-catch/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-catch/mrblib/catch.rb +29 -0
- data/ext/enclave/mruby/mrbgems/mruby-catch/src/catch.c +149 -0
- data/ext/enclave/mruby/mrbgems/mruby-catch/test/catch.rb +86 -0
- data/ext/enclave/mruby/mrbgems/mruby-class-ext/README.md +81 -0
- data/ext/enclave/mruby/mrbgems/mruby-class-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-class-ext/src/class.c +377 -0
- data/ext/enclave/mruby/mrbgems/mruby-class-ext/test/class.rb +46 -0
- data/ext/enclave/mruby/mrbgems/mruby-class-ext/test/module.rb +109 -0
- data/ext/enclave/mruby/mrbgems/mruby-cmath/README.md +45 -0
- data/ext/enclave/mruby/mrbgems/mruby-cmath/mrbgem.rake +8 -0
- data/ext/enclave/mruby/mrbgems/mruby-cmath/src/cmath.c +426 -0
- data/ext/enclave/mruby/mrbgems/mruby-cmath/test/cmath.rb +41 -0
- data/ext/enclave/mruby/mrbgems/mruby-compar-ext/README.md +65 -0
- data/ext/enclave/mruby/mrbgems/mruby-compar-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-compar-ext/mrblib/compar.rb +75 -0
- data/ext/enclave/mruby/mrbgems/mruby-compar-ext/test/compar.rb +21 -0
- data/ext/enclave/mruby/mrbgems/mruby-compiler/README.md +28 -0
- data/ext/enclave/mruby/mrbgems/mruby-compiler/core/codegen.c +7316 -0
- data/ext/enclave/mruby/mrbgems/mruby-compiler/core/keywords +52 -0
- data/ext/enclave/mruby/mrbgems/mruby-compiler/core/lex.def +207 -0
- data/ext/enclave/mruby/mrbgems/mruby-compiler/core/node.h +784 -0
- data/ext/enclave/mruby/mrbgems/mruby-compiler/core/parse.y +8977 -0
- data/ext/enclave/mruby/mrbgems/mruby-compiler/core/y.tab.c +16136 -0
- data/ext/enclave/mruby/mrbgems/mruby-compiler/mrbgem.rake +42 -0
- data/ext/enclave/mruby/mrbgems/mruby-complex/README.md +55 -0
- data/ext/enclave/mruby/mrbgems/mruby-complex/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-complex/mrblib/complex.rb +259 -0
- data/ext/enclave/mruby/mrbgems/mruby-complex/src/complex.c +597 -0
- data/ext/enclave/mruby/mrbgems/mruby-complex/test/complex.rb +174 -0
- data/ext/enclave/mruby/mrbgems/mruby-data/README.md +126 -0
- data/ext/enclave/mruby/mrbgems/mruby-data/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-data/src/data.c +550 -0
- data/ext/enclave/mruby/mrbgems/mruby-data/test/data.rb +76 -0
- data/ext/enclave/mruby/mrbgems/mruby-dir/README.md +53 -0
- data/ext/enclave/mruby/mrbgems/mruby-dir/include/dir_hal.h +79 -0
- data/ext/enclave/mruby/mrbgems/mruby-dir/mrbgem.rake +35 -0
- data/ext/enclave/mruby/mrbgems/mruby-dir/mrblib/dir.rb +124 -0
- data/ext/enclave/mruby/mrbgems/mruby-dir/src/dir.c +493 -0
- data/ext/enclave/mruby/mrbgems/mruby-dir/test/dir.rb +138 -0
- data/ext/enclave/mruby/mrbgems/mruby-dir/test/dirtest.c +125 -0
- data/ext/enclave/mruby/mrbgems/mruby-encoding/README.md +96 -0
- data/ext/enclave/mruby/mrbgems/mruby-encoding/mrbgem.rake +8 -0
- data/ext/enclave/mruby/mrbgems/mruby-encoding/src/encoding.c +128 -0
- data/ext/enclave/mruby/mrbgems/mruby-encoding/test/numeric.rb +27 -0
- data/ext/enclave/mruby/mrbgems/mruby-encoding/test/string.rb +30 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-chain/README.md +80 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-chain/mrbgem.rake +6 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-chain/mrblib/chain.rb +149 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-chain/test/enum_chain.rb +108 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-ext/README.md +487 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-ext/mrblib/enum.rb +938 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-ext/test/enum.rb +223 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-lazy/README.md +91 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-lazy/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-lazy/mrblib/lazy.rb +363 -0
- data/ext/enclave/mruby/mrbgems/mruby-enum-lazy/test/lazy.rb +59 -0
- data/ext/enclave/mruby/mrbgems/mruby-enumerator/README.md +89 -0
- data/ext/enclave/mruby/mrbgems/mruby-enumerator/mrbgem.rake +6 -0
- data/ext/enclave/mruby/mrbgems/mruby-enumerator/mrblib/enumerator.rb +861 -0
- data/ext/enclave/mruby/mrbgems/mruby-enumerator/test/enumerator.rb +664 -0
- data/ext/enclave/mruby/mrbgems/mruby-errno/README.md +83 -0
- data/ext/enclave/mruby/mrbgems/mruby-errno/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-errno/mrblib/errno.rb +50 -0
- data/ext/enclave/mruby/mrbgems/mruby-errno/src/errno.c +335 -0
- data/ext/enclave/mruby/mrbgems/mruby-errno/src/gen.rb +18 -0
- data/ext/enclave/mruby/mrbgems/mruby-errno/src/known_errors.def +156 -0
- data/ext/enclave/mruby/mrbgems/mruby-errno/src/known_errors_def.cstub +780 -0
- data/ext/enclave/mruby/mrbgems/mruby-errno/test/errno.rb +57 -0
- data/ext/enclave/mruby/mrbgems/mruby-error/README.md +103 -0
- data/ext/enclave/mruby/mrbgems/mruby-error/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-error/src/exception.c +143 -0
- data/ext/enclave/mruby/mrbgems/mruby-error/test/exception.c +60 -0
- data/ext/enclave/mruby/mrbgems/mruby-error/test/exception.rb +55 -0
- data/ext/enclave/mruby/mrbgems/mruby-eval/README.md +26 -0
- data/ext/enclave/mruby/mrbgems/mruby-eval/mrbgem.rake +10 -0
- data/ext/enclave/mruby/mrbgems/mruby-eval/src/eval.c +437 -0
- data/ext/enclave/mruby/mrbgems/mruby-eval/test/binding.rb +81 -0
- data/ext/enclave/mruby/mrbgems/mruby-eval/test/eval.rb +185 -0
- data/ext/enclave/mruby/mrbgems/mruby-exit/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-exit/src/mruby_exit.c +83 -0
- data/ext/enclave/mruby/mrbgems/mruby-fiber/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-fiber/src/fiber.c +575 -0
- data/ext/enclave/mruby/mrbgems/mruby-fiber/test/fiber.rb +210 -0
- data/ext/enclave/mruby/mrbgems/mruby-fiber/test/fiber2.rb +155 -0
- data/ext/enclave/mruby/mrbgems/mruby-fiber/test/fibertest.c +87 -0
- data/ext/enclave/mruby/mrbgems/mruby-hash-ext/README.md +392 -0
- data/ext/enclave/mruby/mrbgems/mruby-hash-ext/mrbgem.rake +6 -0
- data/ext/enclave/mruby/mrbgems/mruby-hash-ext/mrblib/hash.rb +408 -0
- data/ext/enclave/mruby/mrbgems/mruby-hash-ext/src/hash_ext.c +392 -0
- data/ext/enclave/mruby/mrbgems/mruby-hash-ext/test/hash.rb +317 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/README.md +198 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/include/io_hal.h +451 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/include/mruby/io.h +76 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/mrbgem.rake +34 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/mrblib/file.rb +109 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/mrblib/file_constants.rb +24 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/mrblib/io.rb +303 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/mrblib/kernel.rb +175 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/src/file.c +1192 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/src/file_test.c +403 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/src/io.c +2260 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/src/mruby_io_gem.c +21 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/test/file.rb +415 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/test/file_test.rb +112 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/test/io.rb +668 -0
- data/ext/enclave/mruby/mrbgems/mruby-io/test/mruby_io_test.c +293 -0
- data/ext/enclave/mruby/mrbgems/mruby-kernel-ext/README.md +165 -0
- data/ext/enclave/mruby/mrbgems/mruby-kernel-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-kernel-ext/src/kernel.c +316 -0
- data/ext/enclave/mruby/mrbgems/mruby-kernel-ext/test/kernel.rb +134 -0
- data/ext/enclave/mruby/mrbgems/mruby-math/README.md +77 -0
- data/ext/enclave/mruby/mrbgems/mruby-math/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-math/src/math.c +753 -0
- data/ext/enclave/mruby/mrbgems/mruby-math/test/math.rb +201 -0
- data/ext/enclave/mruby/mrbgems/mruby-metaprog/README.md +123 -0
- data/ext/enclave/mruby/mrbgems/mruby-metaprog/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-metaprog/src/metaprog.c +739 -0
- data/ext/enclave/mruby/mrbgems/mruby-metaprog/test/metaprog.rb +465 -0
- data/ext/enclave/mruby/mrbgems/mruby-method/README.md +66 -0
- data/ext/enclave/mruby/mrbgems/mruby-method/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-method/mrblib/method.rb +73 -0
- data/ext/enclave/mruby/mrbgems/mruby-method/src/method.c +890 -0
- data/ext/enclave/mruby/mrbgems/mruby-method/test/method.rb +514 -0
- data/ext/enclave/mruby/mrbgems/mruby-numeric-ext/README.md +78 -0
- data/ext/enclave/mruby/mrbgems/mruby-numeric-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-numeric-ext/mrblib/numeric_ext.rb +125 -0
- data/ext/enclave/mruby/mrbgems/mruby-numeric-ext/src/numeric_ext.c +527 -0
- data/ext/enclave/mruby/mrbgems/mruby-numeric-ext/test/numeric.rb +137 -0
- data/ext/enclave/mruby/mrbgems/mruby-object-ext/README.md +144 -0
- data/ext/enclave/mruby/mrbgems/mruby-object-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-object-ext/mrblib/object.rb +33 -0
- data/ext/enclave/mruby/mrbgems/mruby-object-ext/src/object.c +128 -0
- data/ext/enclave/mruby/mrbgems/mruby-object-ext/test/nil.rb +16 -0
- data/ext/enclave/mruby/mrbgems/mruby-object-ext/test/object.rb +67 -0
- data/ext/enclave/mruby/mrbgems/mruby-object-ext/test/object_ext.c +17 -0
- data/ext/enclave/mruby/mrbgems/mruby-objectspace/README.md +59 -0
- data/ext/enclave/mruby/mrbgems/mruby-objectspace/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-objectspace/src/mruby_objectspace.c +188 -0
- data/ext/enclave/mruby/mrbgems/mruby-objectspace/test/objectspace.rb +60 -0
- data/ext/enclave/mruby/mrbgems/mruby-os-memsize/README.md +75 -0
- data/ext/enclave/mruby/mrbgems/mruby-os-memsize/mrbgem.rake +10 -0
- data/ext/enclave/mruby/mrbgems/mruby-os-memsize/src/memsize.c +271 -0
- data/ext/enclave/mruby/mrbgems/mruby-os-memsize/test/memsize.rb +63 -0
- data/ext/enclave/mruby/mrbgems/mruby-pack/README.md +140 -0
- data/ext/enclave/mruby/mrbgems/mruby-pack/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-pack/src/pack.c +2129 -0
- data/ext/enclave/mruby/mrbgems/mruby-pack/test/pack.rb +202 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-binding/README.md +140 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-binding/mrbgem.rake +10 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-binding/src/proc_binding.c +76 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-binding/test/proc_binding.c +14 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-binding/test/proc_binding.rb +22 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-ext/README.md +107 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-ext/mrblib/proc.rb +130 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-ext/src/proc.c +267 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-ext/test/proc.c +62 -0
- data/ext/enclave/mruby/mrbgems/mruby-proc-ext/test/proc.rb +130 -0
- data/ext/enclave/mruby/mrbgems/mruby-random/README.md +272 -0
- data/ext/enclave/mruby/mrbgems/mruby-random/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-random/src/random.c +608 -0
- data/ext/enclave/mruby/mrbgems/mruby-random/test/random.rb +151 -0
- data/ext/enclave/mruby/mrbgems/mruby-range-ext/README.md +93 -0
- data/ext/enclave/mruby/mrbgems/mruby-range-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-range-ext/mrblib/range.rb +155 -0
- data/ext/enclave/mruby/mrbgems/mruby-range-ext/src/range.c +236 -0
- data/ext/enclave/mruby/mrbgems/mruby-range-ext/test/range.rb +211 -0
- data/ext/enclave/mruby/mrbgems/mruby-rational/README.md +61 -0
- data/ext/enclave/mruby/mrbgems/mruby-rational/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-rational/mrblib/rational.rb +66 -0
- data/ext/enclave/mruby/mrbgems/mruby-rational/src/rational.c +1269 -0
- data/ext/enclave/mruby/mrbgems/mruby-rational/test/rational.rb +316 -0
- data/ext/enclave/mruby/mrbgems/mruby-set/LICENSE +24 -0
- data/ext/enclave/mruby/mrbgems/mruby-set/README.md +260 -0
- data/ext/enclave/mruby/mrbgems/mruby-set/mrbgem.rake +9 -0
- data/ext/enclave/mruby/mrbgems/mruby-set/mrblib/set.rb +325 -0
- data/ext/enclave/mruby/mrbgems/mruby-set/mruby-set.gem +6 -0
- data/ext/enclave/mruby/mrbgems/mruby-set/src/set.c +1535 -0
- data/ext/enclave/mruby/mrbgems/mruby-set/test/set.rb +764 -0
- data/ext/enclave/mruby/mrbgems/mruby-sleep/README.md +29 -0
- data/ext/enclave/mruby/mrbgems/mruby-sleep/example/sleep.rb +2 -0
- data/ext/enclave/mruby/mrbgems/mruby-sleep/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-sleep/src/sleep.c +187 -0
- data/ext/enclave/mruby/mrbgems/mruby-sleep/test/sleep_test.rb +29 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/README.md +56 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/include/socket_hal.h +83 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/mrbgem.rake +37 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/mrblib/socket.rb +1131 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/src/const.cstub +480 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/src/const.def +172 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/src/gen.rb +17 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/src/socket.c +1374 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/test/addrinfo.rb +91 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/test/basicsocket.rb +17 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/test/ipsocket.rb +44 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/test/socket.rb +38 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/test/sockettest.c +84 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/test/tcpsocket.rb +4 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/test/udpsocket.rb +16 -0
- data/ext/enclave/mruby/mrbgems/mruby-socket/test/unix.rb +130 -0
- data/ext/enclave/mruby/mrbgems/mruby-sprintf/README.md +235 -0
- data/ext/enclave/mruby/mrbgems/mruby-sprintf/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-sprintf/mrblib/string.rb +24 -0
- data/ext/enclave/mruby/mrbgems/mruby-sprintf/src/sprintf.c +1195 -0
- data/ext/enclave/mruby/mrbgems/mruby-sprintf/test/sprintf.rb +92 -0
- data/ext/enclave/mruby/mrbgems/mruby-strftime/README.md +140 -0
- data/ext/enclave/mruby/mrbgems/mruby-strftime/mrbgem.rake +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-strftime/src/strftime.c +119 -0
- data/ext/enclave/mruby/mrbgems/mruby-strftime/test/strftime.rb +152 -0
- data/ext/enclave/mruby/mrbgems/mruby-string-ext/README.md +886 -0
- data/ext/enclave/mruby/mrbgems/mruby-string-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-string-ext/mrblib/string.rb +166 -0
- data/ext/enclave/mruby/mrbgems/mruby-string-ext/src/string.c +2290 -0
- data/ext/enclave/mruby/mrbgems/mruby-string-ext/test/numeric.rb +27 -0
- data/ext/enclave/mruby/mrbgems/mruby-string-ext/test/range.rb +26 -0
- data/ext/enclave/mruby/mrbgems/mruby-string-ext/test/string.rb +765 -0
- data/ext/enclave/mruby/mrbgems/mruby-struct/README.md +105 -0
- data/ext/enclave/mruby/mrbgems/mruby-struct/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-struct/mrblib/struct.rb +69 -0
- data/ext/enclave/mruby/mrbgems/mruby-struct/src/struct.c +812 -0
- data/ext/enclave/mruby/mrbgems/mruby-struct/test/struct.rb +303 -0
- data/ext/enclave/mruby/mrbgems/mruby-symbol-ext/README.md +50 -0
- data/ext/enclave/mruby/mrbgems/mruby-symbol-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-symbol-ext/mrblib/symbol.rb +72 -0
- data/ext/enclave/mruby/mrbgems/mruby-symbol-ext/src/symbol.c +79 -0
- data/ext/enclave/mruby/mrbgems/mruby-symbol-ext/test/symbol.rb +55 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/README.md +770 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/examples/inspection.rb +65 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/examples/priority.rb +41 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/examples/producer_consumer.rb +58 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/examples/simple.rb +27 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/examples/statistics.rb +59 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/examples/suspend_resume.rb +47 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/examples/task_pass.rb +21 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/include/task.h +143 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/include/task_hal.h +162 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/mrbgem.rake +36 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/src/task.c +1573 -0
- data/ext/enclave/mruby/mrbgems/mruby-task/test/task.rb +185 -0
- data/ext/enclave/mruby/mrbgems/mruby-test/README.md +7 -0
- data/ext/enclave/mruby/mrbgems/mruby-test/driver.c +315 -0
- data/ext/enclave/mruby/mrbgems/mruby-test/mrbgem.rake +173 -0
- data/ext/enclave/mruby/mrbgems/mruby-test/vformat.c +151 -0
- data/ext/enclave/mruby/mrbgems/mruby-test-inline-struct/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-test-inline-struct/test/inline.c +92 -0
- data/ext/enclave/mruby/mrbgems/mruby-test-inline-struct/test/inline.rb +118 -0
- data/ext/enclave/mruby/mrbgems/mruby-time/README.md +102 -0
- data/ext/enclave/mruby/mrbgems/mruby-time/include/mruby/time.h +27 -0
- data/ext/enclave/mruby/mrbgems/mruby-time/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-time/src/time.c +1739 -0
- data/ext/enclave/mruby/mrbgems/mruby-time/test/time.rb +313 -0
- data/ext/enclave/mruby/mrbgems/mruby-toplevel-ext/README.md +32 -0
- data/ext/enclave/mruby/mrbgems/mruby-toplevel-ext/mrbgem.rake +5 -0
- data/ext/enclave/mruby/mrbgems/mruby-toplevel-ext/mrblib/toplevel.rb +24 -0
- data/ext/enclave/mruby/mrbgems/mruby-toplevel-ext/test/toplevel.rb +23 -0
- data/ext/enclave/mruby/mrbgems/stdlib-ext.gembox +21 -0
- data/ext/enclave/mruby/mrbgems/stdlib-io.gembox +15 -0
- data/ext/enclave/mruby/mrbgems/stdlib.gembox +63 -0
- data/ext/enclave/mruby/mrblib/10error.rb +23 -0
- data/ext/enclave/mruby/mrblib/array.rb +102 -0
- data/ext/enclave/mruby/mrblib/compar.rb +102 -0
- data/ext/enclave/mruby/mrblib/enum.rb +358 -0
- data/ext/enclave/mruby/mrblib/hash.rb +276 -0
- data/ext/enclave/mruby/mrblib/kernel.rb +45 -0
- data/ext/enclave/mruby/mrblib/numeric.rb +160 -0
- data/ext/enclave/mruby/mrblib/range.rb +98 -0
- data/ext/enclave/mruby/mrblib/string.rb +173 -0
- data/ext/enclave/mruby/mrblib/symbol.rb +8 -0
- data/ext/enclave/mruby/oss-fuzz/mruby_fuzzer.c +18 -0
- data/ext/enclave/mruby/oss-fuzz/proto_to_ruby.h +55 -0
- data/ext/enclave/mruby/src/allocf.c +37 -0
- data/ext/enclave/mruby/src/array.c +2302 -0
- data/ext/enclave/mruby/src/backtrace.c +294 -0
- data/ext/enclave/mruby/src/cdump.c +498 -0
- data/ext/enclave/mruby/src/class.c +4394 -0
- data/ext/enclave/mruby/src/codedump.c +693 -0
- data/ext/enclave/mruby/src/debug.c +290 -0
- data/ext/enclave/mruby/src/dump.c +998 -0
- data/ext/enclave/mruby/src/enum.c +30 -0
- data/ext/enclave/mruby/src/error.c +937 -0
- data/ext/enclave/mruby/src/etc.c +421 -0
- data/ext/enclave/mruby/src/fmt_fp.c +372 -0
- data/ext/enclave/mruby/src/gc.c +1610 -0
- data/ext/enclave/mruby/src/hash.c +2355 -0
- data/ext/enclave/mruby/src/init.c +50 -0
- data/ext/enclave/mruby/src/kernel.c +718 -0
- data/ext/enclave/mruby/src/load.c +760 -0
- data/ext/enclave/mruby/src/mempool.c +225 -0
- data/ext/enclave/mruby/src/numeric.c +2420 -0
- data/ext/enclave/mruby/src/numops.c +112 -0
- data/ext/enclave/mruby/src/object.c +883 -0
- data/ext/enclave/mruby/src/print.c +136 -0
- data/ext/enclave/mruby/src/proc.c +572 -0
- data/ext/enclave/mruby/src/range.c +597 -0
- data/ext/enclave/mruby/src/readfloat.c +228 -0
- data/ext/enclave/mruby/src/readint.c +27 -0
- data/ext/enclave/mruby/src/readnum.c +43 -0
- data/ext/enclave/mruby/src/state.c +247 -0
- data/ext/enclave/mruby/src/string.c +3577 -0
- data/ext/enclave/mruby/src/symbol.c +1023 -0
- data/ext/enclave/mruby/src/value_array.h +28 -0
- data/ext/enclave/mruby/src/variable.c +1475 -0
- data/ext/enclave/mruby/src/version.c +17 -0
- data/ext/enclave/mruby/src/vm.c +3696 -0
- data/ext/enclave/mruby/tasks/amalgam.rake +34 -0
- data/ext/enclave/mruby/tasks/benchmark.rake +93 -0
- data/ext/enclave/mruby/tasks/bin.rake +23 -0
- data/ext/enclave/mruby/tasks/core.rake +12 -0
- data/ext/enclave/mruby/tasks/doc.rake +118 -0
- data/ext/enclave/mruby/tasks/install.rake +40 -0
- data/ext/enclave/mruby/tasks/libmruby.rake +90 -0
- data/ext/enclave/mruby/tasks/mrbgems.rake +152 -0
- data/ext/enclave/mruby/tasks/mrblib.rake +29 -0
- data/ext/enclave/mruby/tasks/presym.rake +57 -0
- data/ext/enclave/mruby/tasks/test.rake +84 -0
- data/ext/enclave/mruby/tasks/toolchains/android.rake +228 -0
- data/ext/enclave/mruby/tasks/toolchains/clang.rake +8 -0
- data/ext/enclave/mruby/tasks/toolchains/emscripten.rake +57 -0
- data/ext/enclave/mruby/tasks/toolchains/gcc.rake +74 -0
- data/ext/enclave/mruby/tasks/toolchains/openwrt.rake +32 -0
- data/ext/enclave/mruby/tasks/toolchains/visualcpp.rake +48 -0
- data/ext/enclave/mruby/test/assert.rb +404 -0
- data/ext/enclave/mruby/test/bintest.rb +55 -0
- data/ext/enclave/mruby/test/t/argumenterror.rb +37 -0
- data/ext/enclave/mruby/test/t/array.rb +478 -0
- data/ext/enclave/mruby/test/t/basicobject.rb +10 -0
- data/ext/enclave/mruby/test/t/bs_block.rb +621 -0
- data/ext/enclave/mruby/test/t/bs_literal.rb +38 -0
- data/ext/enclave/mruby/test/t/class.rb +505 -0
- data/ext/enclave/mruby/test/t/codegen.rb +196 -0
- data/ext/enclave/mruby/test/t/comparable.rb +79 -0
- data/ext/enclave/mruby/test/t/ensure.rb +36 -0
- data/ext/enclave/mruby/test/t/enumerable.rb +134 -0
- data/ext/enclave/mruby/test/t/exception.rb +425 -0
- data/ext/enclave/mruby/test/t/false.rb +31 -0
- data/ext/enclave/mruby/test/t/float.rb +296 -0
- data/ext/enclave/mruby/test/t/gc.rb +45 -0
- data/ext/enclave/mruby/test/t/hash.rb +976 -0
- data/ext/enclave/mruby/test/t/indexerror.rb +6 -0
- data/ext/enclave/mruby/test/t/integer.rb +247 -0
- data/ext/enclave/mruby/test/t/iterations.rb +61 -0
- data/ext/enclave/mruby/test/t/kernel.rb +462 -0
- data/ext/enclave/mruby/test/t/lang.rb +74 -0
- data/ext/enclave/mruby/test/t/literals.rb +386 -0
- data/ext/enclave/mruby/test/t/localjumperror.rb +13 -0
- data/ext/enclave/mruby/test/t/methods.rb +138 -0
- data/ext/enclave/mruby/test/t/module.rb +931 -0
- data/ext/enclave/mruby/test/t/nameerror.rb +28 -0
- data/ext/enclave/mruby/test/t/nil.rb +39 -0
- data/ext/enclave/mruby/test/t/nomethoderror.rb +22 -0
- data/ext/enclave/mruby/test/t/numeric.rb +114 -0
- data/ext/enclave/mruby/test/t/object.rb +10 -0
- data/ext/enclave/mruby/test/t/proc.rb +198 -0
- data/ext/enclave/mruby/test/t/range.rb +194 -0
- data/ext/enclave/mruby/test/t/rangeerror.rb +6 -0
- data/ext/enclave/mruby/test/t/regexperror.rb +4 -0
- data/ext/enclave/mruby/test/t/runtimeerror.rb +6 -0
- data/ext/enclave/mruby/test/t/standarderror.rb +6 -0
- data/ext/enclave/mruby/test/t/string.rb +981 -0
- data/ext/enclave/mruby/test/t/superclass.rb +46 -0
- data/ext/enclave/mruby/test/t/symbol.rb +30 -0
- data/ext/enclave/mruby/test/t/syntax.rb +1296 -0
- data/ext/enclave/mruby/test/t/true.rb +31 -0
- data/ext/enclave/mruby/test/t/typeerror.rb +6 -0
- data/ext/enclave/mruby/test/t/unicode.rb +39 -0
- data/ext/enclave/mruby/test/t/vformat.rb +57 -0
- data/ext/enclave/mruby/tools/lrama/LEGAL.md +12 -0
- data/ext/enclave/mruby/tools/lrama/MIT +21 -0
- data/ext/enclave/mruby/tools/lrama/NEWS.md +696 -0
- data/ext/enclave/mruby/tools/lrama/exe/lrama +7 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/bitmap.rb +34 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/command.rb +68 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/context.rb +499 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/counterexamples/derivation.rb +66 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/counterexamples/example.rb +129 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/counterexamples/path.rb +29 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/counterexamples/production_path.rb +19 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/counterexamples/start_path.rb +23 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/counterexamples/state_item.rb +8 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/counterexamples/transition_path.rb +19 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/counterexamples/triple.rb +23 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/counterexamples.rb +298 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/diagnostics.rb +36 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/digraph.rb +83 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/auxiliary.rb +9 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/binding.rb +67 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/code/destructor_code.rb +42 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/code/initial_action_code.rb +36 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/code/no_reference_code.rb +30 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/code/printer_code.rb +42 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/code/rule_action.rb +92 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/code.rb +53 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/counter.rb +17 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/destructor.rb +11 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/error_token.rb +11 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/parameterizing_rule/resolver.rb +62 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/parameterizing_rule/rhs.rb +40 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/parameterizing_rule/rule.rb +24 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/parameterizing_rule.rb +5 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/percent_code.rb +14 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/precedence.rb +13 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/printer.rb +11 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/reference.rb +16 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/rule.rb +75 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/rule_builder.rb +255 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/stdlib.y +122 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/symbol.rb +105 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/symbols/resolver.rb +301 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/symbols.rb +3 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/type.rb +20 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar/union.rb +12 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar.rb +407 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/grammar_validator.rb +37 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/lexer/grammar_file.rb +40 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/lexer/location.rb +115 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/lexer/token/char.rb +11 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/lexer/token/ident.rb +11 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/lexer/token/instantiate_rule.rb +30 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/lexer/token/tag.rb +16 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/lexer/token/user_code.rb +83 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/lexer/token.rb +70 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/lexer.rb +191 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/logger.rb +21 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/option_parser.rb +169 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/options.rb +28 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/output.rb +459 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/parser.rb +2144 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/report/duration.rb +27 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/report/profile.rb +16 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/report.rb +4 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/state/reduce.rb +37 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/state/reduce_reduce_conflict.rb +11 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/state/resolved_conflict.rb +31 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/state/shift.rb +15 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/state/shift_reduce_conflict.rb +11 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/state.rb +433 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/states/item.rb +91 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/states.rb +595 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/states_reporter.rb +362 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/trace_reporter.rb +45 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama/version.rb +5 -0
- data/ext/enclave/mruby/tools/lrama/lib/lrama.rb +22 -0
- data/ext/enclave/mruby/tools/lrama/template/bison/_yacc.h +71 -0
- data/ext/enclave/mruby/tools/lrama/template/bison/yacc.c +2068 -0
- data/ext/enclave/mruby/tools/lrama/template/bison/yacc.h +40 -0
- data/ext/enclave/sandbox_build_config.rb +15 -0
- data/ext/enclave/sandbox_core.c +722 -0
- data/ext/enclave/sandbox_core.h +87 -0
- data/lib/enclave/result.rb +29 -0
- data/lib/enclave/tool.rb +38 -0
- data/lib/enclave/version.rb +3 -0
- data/lib/enclave.rb +73 -0
- metadata +819 -0
|
@@ -0,0 +1,784 @@
|
|
|
1
|
+
class Array
|
|
2
|
+
##
|
|
3
|
+
# call-seq:
|
|
4
|
+
# ary.uniq! -> ary or nil
|
|
5
|
+
# ary.uniq! { |item| ... } -> ary or nil
|
|
6
|
+
#
|
|
7
|
+
# Removes duplicate elements from `self`.
|
|
8
|
+
# Returns `nil` if no changes are made (that is, no
|
|
9
|
+
# duplicates are found).
|
|
10
|
+
#
|
|
11
|
+
# a = [ "a", "a", "b", "b", "c" ]
|
|
12
|
+
# a.uniq! #=> ["a", "b", "c"]
|
|
13
|
+
# b = [ "a", "b", "c" ]
|
|
14
|
+
# b.uniq! #=> nil
|
|
15
|
+
# c = [["student","sam"], ["student","george"], ["teacher","matz"]]
|
|
16
|
+
# c.uniq! { |s| s.first } # => [["student", "sam"], ["teacher", "matz"]]
|
|
17
|
+
#
|
|
18
|
+
def uniq!(&block)
|
|
19
|
+
if block
|
|
20
|
+
hash = {}
|
|
21
|
+
result = []
|
|
22
|
+
self.each do |val|
|
|
23
|
+
key = block.call(val)
|
|
24
|
+
unless hash.key?(key)
|
|
25
|
+
hash[key] = true
|
|
26
|
+
result << val
|
|
27
|
+
end
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
if result.size == self.size
|
|
31
|
+
nil
|
|
32
|
+
else
|
|
33
|
+
self.replace(result)
|
|
34
|
+
end
|
|
35
|
+
else
|
|
36
|
+
__uniq!
|
|
37
|
+
end
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
##
|
|
41
|
+
# call-seq:
|
|
42
|
+
# ary.uniq -> new_ary
|
|
43
|
+
# ary.uniq { |item| ... } -> new_ary
|
|
44
|
+
#
|
|
45
|
+
# Returns a new array by removing duplicate values in `self`.
|
|
46
|
+
#
|
|
47
|
+
# a = [ "a", "a", "b", "b", "c" ]
|
|
48
|
+
# a.uniq #=> ["a", "b", "c"]
|
|
49
|
+
#
|
|
50
|
+
# b = [["student","sam"], ["student","george"], ["teacher","matz"]]
|
|
51
|
+
# b.uniq { |s| s.first } # => [["student", "sam"], ["teacher", "matz"]]
|
|
52
|
+
#
|
|
53
|
+
def uniq(&block)
|
|
54
|
+
if block
|
|
55
|
+
ary = self.dup
|
|
56
|
+
ary.uniq!(&block)
|
|
57
|
+
ary
|
|
58
|
+
else
|
|
59
|
+
__uniq
|
|
60
|
+
end
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
# for efficiency
|
|
64
|
+
def reverse_each(&block)
|
|
65
|
+
return to_enum(:reverse_each) unless block
|
|
66
|
+
|
|
67
|
+
i = self.size - 1
|
|
68
|
+
while i>=0
|
|
69
|
+
block.call(self[i])
|
|
70
|
+
i -= 1
|
|
71
|
+
end
|
|
72
|
+
self
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
##
|
|
76
|
+
# call-seq:
|
|
77
|
+
# ary.fetch(index) -> obj
|
|
78
|
+
# ary.fetch(index, default) -> obj
|
|
79
|
+
# ary.fetch(index) { |index| block } -> obj
|
|
80
|
+
#
|
|
81
|
+
# Tries to return the element at position `index`, but throws an IndexError
|
|
82
|
+
# exception if the referenced `index` lies outside of the array bounds. This
|
|
83
|
+
# error can be prevented by supplying a second argument, which will act as a
|
|
84
|
+
# `default` value.
|
|
85
|
+
#
|
|
86
|
+
# Alternatively, if a block is given it will only be executed when an
|
|
87
|
+
# invalid `index` is referenced.
|
|
88
|
+
#
|
|
89
|
+
# Negative values of `index` count from the end of the array.
|
|
90
|
+
#
|
|
91
|
+
# a = [ 11, 22, 33, 44 ]
|
|
92
|
+
# a.fetch(1) #=> 22
|
|
93
|
+
# a.fetch(-1) #=> 44
|
|
94
|
+
# a.fetch(4, 'cat') #=> "cat"
|
|
95
|
+
# a.fetch(100) { |i| puts "#{i} is out of bounds" }
|
|
96
|
+
# #=> "100 is out of bounds"
|
|
97
|
+
#
|
|
98
|
+
|
|
99
|
+
def fetch(n, ifnone=NONE, &block)
|
|
100
|
+
#warn "block supersedes default value argument" if !n.nil? && ifnone != NONE && block
|
|
101
|
+
|
|
102
|
+
if block
|
|
103
|
+
# Block case: use shared index helper + Ruby block handling
|
|
104
|
+
normalized_index = __normalize_index(n)
|
|
105
|
+
if normalized_index
|
|
106
|
+
self[normalized_index]
|
|
107
|
+
else
|
|
108
|
+
block.call(n)
|
|
109
|
+
end
|
|
110
|
+
else
|
|
111
|
+
# Fast C implementation for non-block cases
|
|
112
|
+
__fetch(n, ifnone, NONE)
|
|
113
|
+
end
|
|
114
|
+
end
|
|
115
|
+
|
|
116
|
+
##
|
|
117
|
+
# call-seq:
|
|
118
|
+
# ary.fill(obj) -> ary
|
|
119
|
+
# ary.fill(obj, start [, length]) -> ary
|
|
120
|
+
# ary.fill(obj, range ) -> ary
|
|
121
|
+
# ary.fill { |index| block } -> ary
|
|
122
|
+
# ary.fill(start [, length] ) { |index| block } -> ary
|
|
123
|
+
# ary.fill(range) { |index| block } -> ary
|
|
124
|
+
#
|
|
125
|
+
# The first three forms set the selected elements of `self` (which
|
|
126
|
+
# may be the entire array) to `obj`.
|
|
127
|
+
#
|
|
128
|
+
# A `start` of `nil` is equivalent to zero.
|
|
129
|
+
#
|
|
130
|
+
# A `length` of `nil` is equivalent to the length of the array.
|
|
131
|
+
#
|
|
132
|
+
# The last three forms fill the array with the value of the given block,
|
|
133
|
+
# which is passed the absolute index of each element to be filled.
|
|
134
|
+
#
|
|
135
|
+
# Negative values of `start` count from the end of the array, where +-1+ is
|
|
136
|
+
# the last element.
|
|
137
|
+
#
|
|
138
|
+
# a = [ "a", "b", "c", "d" ]
|
|
139
|
+
# a.fill("x") #=> ["x", "x", "x", "x"]
|
|
140
|
+
# a.fill("w", -1) #=> ["x", "x", "x", "w"]
|
|
141
|
+
# a.fill("z", 2, 2) #=> ["x", "x", "z", "z"]
|
|
142
|
+
# a.fill("y", 0..1) #=> ["y", "y", "z", "z"]
|
|
143
|
+
# a.fill { |i| i*i } #=> [0, 1, 4, 9]
|
|
144
|
+
# a.fill(-2) { |i| i*i*i } #=> [0, 1, 8, 27]
|
|
145
|
+
# a.fill(1, 2) { |i| i+1 } #=> [0, 2, 3, 27]
|
|
146
|
+
# a.fill(0..1) { |i| i+1 } #=> [1, 2, 3, 27]
|
|
147
|
+
#
|
|
148
|
+
|
|
149
|
+
def fill(arg0=nil, arg1=nil, arg2=nil, &block)
|
|
150
|
+
if arg0.nil? && arg1.nil? && arg2.nil? && !block
|
|
151
|
+
raise ArgumentError, "wrong number of arguments (given 0, expected 1..3)"
|
|
152
|
+
end
|
|
153
|
+
|
|
154
|
+
# Use shared C argument parser for all cases
|
|
155
|
+
start, length = __fill_parse_arg(arg0, arg1, arg2, &block)
|
|
156
|
+
|
|
157
|
+
if block
|
|
158
|
+
# Block-based filling in Ruby
|
|
159
|
+
i = start
|
|
160
|
+
while i < start + length
|
|
161
|
+
self[i] = block.call(i)
|
|
162
|
+
i += 1
|
|
163
|
+
end
|
|
164
|
+
else
|
|
165
|
+
# Use fast C implementation for value filling
|
|
166
|
+
__fill_exec(start, length, arg0)
|
|
167
|
+
end
|
|
168
|
+
|
|
169
|
+
self
|
|
170
|
+
end
|
|
171
|
+
|
|
172
|
+
##
|
|
173
|
+
# call-seq:
|
|
174
|
+
# ary.delete_if { |item| block } -> ary
|
|
175
|
+
# ary.delete_if -> Enumerator
|
|
176
|
+
#
|
|
177
|
+
# Deletes every element of `self` for which block evaluates to `true`.
|
|
178
|
+
#
|
|
179
|
+
# The array is changed instantly every time the block is called, not after
|
|
180
|
+
# the iteration is over.
|
|
181
|
+
#
|
|
182
|
+
# See also Array#reject!
|
|
183
|
+
#
|
|
184
|
+
# If no block is given, an Enumerator is returned instead.
|
|
185
|
+
#
|
|
186
|
+
# scores = [ 97, 42, 75 ]
|
|
187
|
+
# scores.delete_if {|score| score < 80 } #=> [97]
|
|
188
|
+
|
|
189
|
+
def delete_if(&block)
|
|
190
|
+
return to_enum(:delete_if) unless block
|
|
191
|
+
|
|
192
|
+
result = []
|
|
193
|
+
idx = 0
|
|
194
|
+
len = size
|
|
195
|
+
while idx < len
|
|
196
|
+
elem = self[idx]
|
|
197
|
+
result << elem unless block.call(elem)
|
|
198
|
+
idx += 1
|
|
199
|
+
end
|
|
200
|
+
|
|
201
|
+
self.replace(result)
|
|
202
|
+
end
|
|
203
|
+
|
|
204
|
+
##
|
|
205
|
+
# call-seq:
|
|
206
|
+
# ary.reject! { |item| block } -> ary or nil
|
|
207
|
+
# ary.reject! -> Enumerator
|
|
208
|
+
#
|
|
209
|
+
# Equivalent to Array#delete_if, deleting elements from `self` for which the
|
|
210
|
+
# block evaluates to `true`, but returns `nil` if no changes were made.
|
|
211
|
+
#
|
|
212
|
+
# The array is changed instantly every time the block is called, not after
|
|
213
|
+
# the iteration is over.
|
|
214
|
+
#
|
|
215
|
+
# See also Enumerable#reject and Array#delete_if.
|
|
216
|
+
#
|
|
217
|
+
# If no block is given, an Enumerator is returned instead.
|
|
218
|
+
|
|
219
|
+
def reject!(&block)
|
|
220
|
+
return to_enum(:reject!) unless block
|
|
221
|
+
|
|
222
|
+
result = []
|
|
223
|
+
idx = 0
|
|
224
|
+
len = size
|
|
225
|
+
while idx < len
|
|
226
|
+
elem = self[idx]
|
|
227
|
+
result << elem unless block.call(elem)
|
|
228
|
+
idx += 1
|
|
229
|
+
end
|
|
230
|
+
|
|
231
|
+
return nil if len == result.size
|
|
232
|
+
|
|
233
|
+
self.replace(result)
|
|
234
|
+
end
|
|
235
|
+
|
|
236
|
+
|
|
237
|
+
|
|
238
|
+
##
|
|
239
|
+
# call-seq:
|
|
240
|
+
# ary.bsearch {|x| block } -> elem
|
|
241
|
+
#
|
|
242
|
+
# By using binary search, finds a value from this array which meets
|
|
243
|
+
# the given condition in O(log n) where n is the size of the array.
|
|
244
|
+
#
|
|
245
|
+
# You can use this method in two use cases: a find-minimum mode and
|
|
246
|
+
# a find-any mode. In either case, the elements of the array must be
|
|
247
|
+
# monotone (or sorted) with respect to the block.
|
|
248
|
+
#
|
|
249
|
+
# In find-minimum mode (this is a good choice for typical use case),
|
|
250
|
+
# the block must return true or false, and there must be an index i
|
|
251
|
+
# (0 <= i <= ary.size) so that:
|
|
252
|
+
#
|
|
253
|
+
# - the block returns false for any element whose index is less than
|
|
254
|
+
# i, and
|
|
255
|
+
# - the block returns true for any element whose index is greater
|
|
256
|
+
# than or equal to i.
|
|
257
|
+
#
|
|
258
|
+
# This method returns the i-th element. If i is equal to ary.size,
|
|
259
|
+
# it returns nil.
|
|
260
|
+
#
|
|
261
|
+
# ary = [0, 4, 7, 10, 12]
|
|
262
|
+
# ary.bsearch {|x| x >= 4 } #=> 4
|
|
263
|
+
# ary.bsearch {|x| x >= 6 } #=> 7
|
|
264
|
+
# ary.bsearch {|x| x >= -1 } #=> 0
|
|
265
|
+
# ary.bsearch {|x| x >= 100 } #=> nil
|
|
266
|
+
#
|
|
267
|
+
# In find-any mode (this behaves like libc's bsearch(3)), the block
|
|
268
|
+
# must return a number, and there must be two indices i and j
|
|
269
|
+
# (0 <= i <= j <= ary.size) so that:
|
|
270
|
+
#
|
|
271
|
+
# - the block returns a positive number for ary[k] if 0 <= k < i,
|
|
272
|
+
# - the block returns zero for ary[k] if i <= k < j, and
|
|
273
|
+
# - the block returns a negative number for ary[k] if
|
|
274
|
+
# j <= k < ary.size.
|
|
275
|
+
#
|
|
276
|
+
# Under this condition, this method returns any element whose index
|
|
277
|
+
# is within i...j. If i is equal to j (i.e., there is no element
|
|
278
|
+
# that satisfies the block), this method returns nil.
|
|
279
|
+
#
|
|
280
|
+
# ary = [0, 4, 7, 10, 12]
|
|
281
|
+
# # try to find v such that 4 <= v < 8
|
|
282
|
+
# ary.bsearch {|x| 1 - (x / 4).truncate } #=> 4 or 7
|
|
283
|
+
# # try to find v such that 8 <= v < 10
|
|
284
|
+
# ary.bsearch {|x| 4 - (x / 2).truncate } #=> nil
|
|
285
|
+
#
|
|
286
|
+
# You must not mix the two modes at a time; the block must always
|
|
287
|
+
# return either true/false, or always return a number. It is
|
|
288
|
+
# undefined which value is actually picked up at each iteration.
|
|
289
|
+
|
|
290
|
+
def bsearch(&block)
|
|
291
|
+
return to_enum(:bsearch) unless block
|
|
292
|
+
|
|
293
|
+
if idx = bsearch_index(&block)
|
|
294
|
+
self[idx]
|
|
295
|
+
else
|
|
296
|
+
nil
|
|
297
|
+
end
|
|
298
|
+
end
|
|
299
|
+
|
|
300
|
+
##
|
|
301
|
+
# call-seq:
|
|
302
|
+
# ary.bsearch_index {|x| block } -> int or nil
|
|
303
|
+
#
|
|
304
|
+
# By using binary search, finds an index of a value from this array which
|
|
305
|
+
# meets the given condition in O(log n) where n is the size of the array.
|
|
306
|
+
#
|
|
307
|
+
# It supports two modes, depending on the nature of the block and they are
|
|
308
|
+
# exactly the same as in the case of #bsearch method with the only difference
|
|
309
|
+
# being that this method returns the index of the element instead of the
|
|
310
|
+
# element itself. For more details consult the documentation for #bsearch.
|
|
311
|
+
|
|
312
|
+
def bsearch_index(&block)
|
|
313
|
+
return to_enum(:bsearch_index) unless block
|
|
314
|
+
|
|
315
|
+
low = 0
|
|
316
|
+
high = size
|
|
317
|
+
satisfied = false
|
|
318
|
+
|
|
319
|
+
while low < high
|
|
320
|
+
mid = ((low+high)/2).truncate
|
|
321
|
+
res = block.call(self[mid])
|
|
322
|
+
|
|
323
|
+
case res
|
|
324
|
+
when 0 # find-any mode: Found!
|
|
325
|
+
return mid
|
|
326
|
+
when Numeric # find-any mode: Continue...
|
|
327
|
+
in_lower_half = res < 0
|
|
328
|
+
when true # find-min mode
|
|
329
|
+
in_lower_half = true
|
|
330
|
+
satisfied = true
|
|
331
|
+
when false, nil # find-min mode
|
|
332
|
+
in_lower_half = false
|
|
333
|
+
else
|
|
334
|
+
raise TypeError, 'invalid block result (must be numeric, true, false or nil)'
|
|
335
|
+
end
|
|
336
|
+
|
|
337
|
+
if in_lower_half
|
|
338
|
+
high = mid
|
|
339
|
+
else
|
|
340
|
+
low = mid + 1
|
|
341
|
+
end
|
|
342
|
+
end
|
|
343
|
+
|
|
344
|
+
satisfied ? low : nil
|
|
345
|
+
end
|
|
346
|
+
|
|
347
|
+
##
|
|
348
|
+
# call-seq:
|
|
349
|
+
# ary.keep_if { |item| block } -> ary
|
|
350
|
+
# ary.keep_if -> Enumerator
|
|
351
|
+
#
|
|
352
|
+
# Deletes every element of `self` for which the given block evaluates to
|
|
353
|
+
# `false`.
|
|
354
|
+
#
|
|
355
|
+
# See also Array#select!
|
|
356
|
+
#
|
|
357
|
+
# If no block is given, an Enumerator is returned instead.
|
|
358
|
+
#
|
|
359
|
+
# a = [1, 2, 3, 4, 5]
|
|
360
|
+
# a.keep_if { |val| val > 3 } #=> [4, 5]
|
|
361
|
+
|
|
362
|
+
def keep_if(&block)
|
|
363
|
+
return to_enum(:keep_if) unless block
|
|
364
|
+
|
|
365
|
+
result = []
|
|
366
|
+
idx = 0
|
|
367
|
+
len = size
|
|
368
|
+
while idx < len
|
|
369
|
+
elem = self[idx]
|
|
370
|
+
result << elem if block.call(elem)
|
|
371
|
+
idx += 1
|
|
372
|
+
end
|
|
373
|
+
|
|
374
|
+
self.replace(result)
|
|
375
|
+
end
|
|
376
|
+
|
|
377
|
+
##
|
|
378
|
+
# call-seq:
|
|
379
|
+
# ary.select! {|item| block } -> ary or nil
|
|
380
|
+
# ary.select! -> Enumerator
|
|
381
|
+
#
|
|
382
|
+
# Invokes the given block passing in successive elements from `self`,
|
|
383
|
+
# deleting elements for which the block returns a `false` value.
|
|
384
|
+
#
|
|
385
|
+
# If changes were made, it will return `self`, otherwise it returns `nil`.
|
|
386
|
+
#
|
|
387
|
+
# See also Array#keep_if
|
|
388
|
+
#
|
|
389
|
+
# If no block is given, an Enumerator is returned instead.
|
|
390
|
+
|
|
391
|
+
def select!(&block)
|
|
392
|
+
return to_enum(:select!) unless block
|
|
393
|
+
|
|
394
|
+
result = []
|
|
395
|
+
idx = 0
|
|
396
|
+
len = size
|
|
397
|
+
while idx < len
|
|
398
|
+
elem = self[idx]
|
|
399
|
+
result << elem if block.call(elem)
|
|
400
|
+
idx += 1
|
|
401
|
+
end
|
|
402
|
+
|
|
403
|
+
return nil if len == result.size
|
|
404
|
+
|
|
405
|
+
self.replace(result)
|
|
406
|
+
end
|
|
407
|
+
|
|
408
|
+
##
|
|
409
|
+
# call-seq:
|
|
410
|
+
# ary.dig(idx, ...) -> object
|
|
411
|
+
#
|
|
412
|
+
# Extracts the nested value specified by the sequence of *idx*
|
|
413
|
+
# objects by calling `dig` at each step, returning `nil` if any
|
|
414
|
+
# intermediate step is `nil`.
|
|
415
|
+
#
|
|
416
|
+
def dig(idx,*args)
|
|
417
|
+
idx = idx.__to_int
|
|
418
|
+
n = self[idx]
|
|
419
|
+
if args.size > 0
|
|
420
|
+
n&.dig(*args)
|
|
421
|
+
else
|
|
422
|
+
n
|
|
423
|
+
end
|
|
424
|
+
end
|
|
425
|
+
|
|
426
|
+
##
|
|
427
|
+
# call-seq:
|
|
428
|
+
# ary.permutation { |p| block } -> ary
|
|
429
|
+
# ary.permutation -> Enumerator
|
|
430
|
+
# ary.permutation(n) { |p| block } -> ary
|
|
431
|
+
# ary.permutation(n) -> Enumerator
|
|
432
|
+
#
|
|
433
|
+
# When invoked with a block, yield all permutations of length `n` of the
|
|
434
|
+
# elements of the array, then return the array itself.
|
|
435
|
+
#
|
|
436
|
+
# If `n` is not specified, yield all permutations of all elements.
|
|
437
|
+
#
|
|
438
|
+
# The implementation makes no guarantees about the order in which the
|
|
439
|
+
# permutations are yielded.
|
|
440
|
+
#
|
|
441
|
+
# If no block is given, an Enumerator is returned instead.
|
|
442
|
+
#
|
|
443
|
+
# Examples:
|
|
444
|
+
#
|
|
445
|
+
# a = [1, 2, 3]
|
|
446
|
+
# a.permutation.to_a #=> [[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]
|
|
447
|
+
# a.permutation(1).to_a #=> [[1],[2],[3]]
|
|
448
|
+
# a.permutation(2).to_a #=> [[1,2],[1,3],[2,1],[2,3],[3,1],[3,2]]
|
|
449
|
+
# a.permutation(3).to_a #=> [[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]
|
|
450
|
+
# a.permutation(0).to_a #=> [[]] # one permutation of length 0
|
|
451
|
+
# a.permutation(4).to_a #=> [] # no permutations of length 4
|
|
452
|
+
def permutation(n=self.size, &block)
|
|
453
|
+
n = n.__to_int
|
|
454
|
+
return to_enum(:permutation, n) unless block
|
|
455
|
+
size = self.size
|
|
456
|
+
if n == 0
|
|
457
|
+
yield []
|
|
458
|
+
elsif 0 < n && n <= size
|
|
459
|
+
i = 0
|
|
460
|
+
while i<size
|
|
461
|
+
result = [self[i]]
|
|
462
|
+
if n-1 > 0
|
|
463
|
+
ary = self[0...i] + self[i+1..-1]
|
|
464
|
+
ary.permutation(n-1) do |c|
|
|
465
|
+
yield result + c
|
|
466
|
+
end
|
|
467
|
+
else
|
|
468
|
+
yield result
|
|
469
|
+
end
|
|
470
|
+
i += 1
|
|
471
|
+
end
|
|
472
|
+
end
|
|
473
|
+
self
|
|
474
|
+
end
|
|
475
|
+
|
|
476
|
+
##
|
|
477
|
+
# call-seq:
|
|
478
|
+
# ary.combination(n) { |c| block } -> ary
|
|
479
|
+
# ary.combination(n) -> Enumerator
|
|
480
|
+
#
|
|
481
|
+
# When invoked with a block, yields all combinations of length `n` of elements
|
|
482
|
+
# from the array and then returns the array itself.
|
|
483
|
+
#
|
|
484
|
+
# The implementation makes no guarantees about the order in which the
|
|
485
|
+
# combinations are yielded.
|
|
486
|
+
#
|
|
487
|
+
# If no block is given, an Enumerator is returned instead.
|
|
488
|
+
#
|
|
489
|
+
# Examples:
|
|
490
|
+
#
|
|
491
|
+
# a = [1, 2, 3, 4]
|
|
492
|
+
# a.combination(1).to_a #=> [[1],[2],[3],[4]]
|
|
493
|
+
# a.combination(2).to_a #=> [[1,2],[1,3],[1,4],[2,3],[2,4],[3,4]]
|
|
494
|
+
# a.combination(3).to_a #=> [[1,2,3],[1,2,4],[1,3,4],[2,3,4]]
|
|
495
|
+
# a.combination(4).to_a #=> [[1,2,3,4]]
|
|
496
|
+
# a.combination(0).to_a #=> [[]] # one combination of length 0
|
|
497
|
+
# a.combination(5).to_a #=> [] # no combinations of length 5
|
|
498
|
+
|
|
499
|
+
def combination(n, &block)
|
|
500
|
+
n = n.__to_int
|
|
501
|
+
return to_enum(:combination, n) unless block
|
|
502
|
+
size = self.size
|
|
503
|
+
if n == 0
|
|
504
|
+
yield []
|
|
505
|
+
elsif n == 1
|
|
506
|
+
i = 0
|
|
507
|
+
while i<size
|
|
508
|
+
yield [self[i]]
|
|
509
|
+
i += 1
|
|
510
|
+
end
|
|
511
|
+
elsif n <= size
|
|
512
|
+
i = 0
|
|
513
|
+
while i<size
|
|
514
|
+
result = [self[i]]
|
|
515
|
+
self[i+1..-1].combination(n-1) do |c|
|
|
516
|
+
yield result + c
|
|
517
|
+
end
|
|
518
|
+
i += 1
|
|
519
|
+
end
|
|
520
|
+
end
|
|
521
|
+
self
|
|
522
|
+
end
|
|
523
|
+
|
|
524
|
+
##
|
|
525
|
+
# call-seq:
|
|
526
|
+
# ary.transpose -> new_ary
|
|
527
|
+
#
|
|
528
|
+
# Assumes that self is an array of arrays and transposes the rows and columns.
|
|
529
|
+
#
|
|
530
|
+
# If the length of the subarrays don't match, an IndexError is raised.
|
|
531
|
+
#
|
|
532
|
+
# Examples:
|
|
533
|
+
#
|
|
534
|
+
# a = [[1,2], [3,4], [5,6]]
|
|
535
|
+
# a.transpose #=> [[1, 3, 5], [2, 4, 6]]
|
|
536
|
+
|
|
537
|
+
def transpose
|
|
538
|
+
return [] if empty?
|
|
539
|
+
|
|
540
|
+
column_count = nil
|
|
541
|
+
self.each do |row|
|
|
542
|
+
raise TypeError unless row.is_a?(Array)
|
|
543
|
+
column_count ||= row.size
|
|
544
|
+
raise IndexError, 'element size differs' unless column_count == row.size
|
|
545
|
+
end
|
|
546
|
+
|
|
547
|
+
Array.new(column_count) do |column_index|
|
|
548
|
+
self.map {|row| row[column_index] }
|
|
549
|
+
end
|
|
550
|
+
end
|
|
551
|
+
|
|
552
|
+
##
|
|
553
|
+
# call-seq:
|
|
554
|
+
# ary.to_h -> Hash
|
|
555
|
+
# ary.to_h{|item| ... } -> Hash
|
|
556
|
+
#
|
|
557
|
+
# Returns the result of interpreting *array* as an array of
|
|
558
|
+
# `[key, value]` pairs. If a block is given, it should
|
|
559
|
+
# return `[key, value]` pairs to construct a hash.
|
|
560
|
+
#
|
|
561
|
+
# [[:foo, :bar], [1, 2]].to_h
|
|
562
|
+
# # => {:foo => :bar, 1 => 2}
|
|
563
|
+
# [1, 2].to_h{|x| [x, x*2]}
|
|
564
|
+
# # => {1 => 2, 2 => 4}
|
|
565
|
+
#
|
|
566
|
+
def to_h(&blk)
|
|
567
|
+
h = {}
|
|
568
|
+
self.each do |v|
|
|
569
|
+
v = blk.call(v) if blk
|
|
570
|
+
raise TypeError, "wrong element type #{v.class}" unless Array === v
|
|
571
|
+
raise ArgumentError, "wrong array length (expected 2, was #{v.length})" unless v.length == 2
|
|
572
|
+
h[v[0]] = v[1]
|
|
573
|
+
end
|
|
574
|
+
h
|
|
575
|
+
end
|
|
576
|
+
|
|
577
|
+
alias append push
|
|
578
|
+
alias prepend unshift
|
|
579
|
+
alias filter! select!
|
|
580
|
+
|
|
581
|
+
##
|
|
582
|
+
# call-seq:
|
|
583
|
+
# ary.fetch_values(idx, ...) -> array
|
|
584
|
+
# ary.fetch_values(idx, ...) { |i| block } -> array
|
|
585
|
+
#
|
|
586
|
+
# Returns an array containing the values associated with the given indexes.
|
|
587
|
+
# but also raises `IndexError` when one of indexes can't be found.
|
|
588
|
+
# Also see `Array#values_at` and `Array#fetch`.
|
|
589
|
+
#
|
|
590
|
+
# a = ["cat", "dog", "cow"]
|
|
591
|
+
#
|
|
592
|
+
# a.fetch_values(2, 0) #=> ["cow", "cat"]
|
|
593
|
+
# a.fetch_values(2, 5) # raises KeyError
|
|
594
|
+
# a.fetch_values(2, 5) {|i| "BIRD" } #=> ["cow", "BIRD"]
|
|
595
|
+
#
|
|
596
|
+
def fetch_values(*idx, &block)
|
|
597
|
+
if block
|
|
598
|
+
idx.map do |i|
|
|
599
|
+
self.fetch(i, &block)
|
|
600
|
+
end
|
|
601
|
+
else
|
|
602
|
+
# Fast path: use C implementation for non-block cases
|
|
603
|
+
idx.map do |i|
|
|
604
|
+
__fetch(i, NONE, NONE)
|
|
605
|
+
end
|
|
606
|
+
end
|
|
607
|
+
end
|
|
608
|
+
|
|
609
|
+
##
|
|
610
|
+
# call-seq:
|
|
611
|
+
# ary.product(*arys) -> array
|
|
612
|
+
# ary.product(*arys) { |item| ... } -> self
|
|
613
|
+
def product(*arys, &block)
|
|
614
|
+
size = arys.size
|
|
615
|
+
i = size
|
|
616
|
+
while i > 0
|
|
617
|
+
i -= 1
|
|
618
|
+
unless arys[i].kind_of?(Array)
|
|
619
|
+
raise TypeError, "no implicit conversion into Array"
|
|
620
|
+
end
|
|
621
|
+
end
|
|
622
|
+
|
|
623
|
+
i = size
|
|
624
|
+
total = self.size
|
|
625
|
+
total *= arys[i -= 1].size while i > 0
|
|
626
|
+
|
|
627
|
+
if block
|
|
628
|
+
i = 0
|
|
629
|
+
while i < total
|
|
630
|
+
group = self.__product_group(arys, i, size + 1)
|
|
631
|
+
block.call(group)
|
|
632
|
+
i += 1
|
|
633
|
+
end
|
|
634
|
+
return self
|
|
635
|
+
else
|
|
636
|
+
result = [nil] * total
|
|
637
|
+
i = 0
|
|
638
|
+
while i < total
|
|
639
|
+
group = self.__product_group(arys, i, size + 1)
|
|
640
|
+
result[i] = group
|
|
641
|
+
i += 1
|
|
642
|
+
end
|
|
643
|
+
return result
|
|
644
|
+
end
|
|
645
|
+
end
|
|
646
|
+
|
|
647
|
+
##
|
|
648
|
+
# call-seq:
|
|
649
|
+
# ary.repeated_combination(n) { |combination| ... } -> ary
|
|
650
|
+
# ary.repeated_combination(n) -> Enumerator
|
|
651
|
+
#
|
|
652
|
+
# When invoked with a block, yields all length `n` combinations of elements
|
|
653
|
+
# from the array, with replacement, and then returns the array itself.
|
|
654
|
+
#
|
|
655
|
+
# This means that, unlike `combination`, elements can be chosen more than once.
|
|
656
|
+
#
|
|
657
|
+
# The implementation makes no guarantees about the order in which the
|
|
658
|
+
# combinations are yielded.
|
|
659
|
+
#
|
|
660
|
+
# If no block is given, an Enumerator is returned instead.
|
|
661
|
+
#
|
|
662
|
+
# Examples:
|
|
663
|
+
#
|
|
664
|
+
# a = [1, 2, 3]
|
|
665
|
+
# a.repeated_combination(2).to_a #=> [[1,1],[1,2],[1,3],[2,2],[2,3],[3,3]]
|
|
666
|
+
def repeated_combination(n, &block)
|
|
667
|
+
raise TypeError, "no implicit conversion into Integer" unless 0 <=> n
|
|
668
|
+
return to_enum(:repeated_combination, n) unless block
|
|
669
|
+
__repeated_combination(n, false, &block)
|
|
670
|
+
end
|
|
671
|
+
|
|
672
|
+
##
|
|
673
|
+
# call-seq:
|
|
674
|
+
# ary.repeated_permutation(n) { |permutation| ... } -> ary
|
|
675
|
+
# ary.repeated_permutation(n) -> Enumerator
|
|
676
|
+
#
|
|
677
|
+
# When invoked with a block, yields all length `n` permutations of elements
|
|
678
|
+
# from the array, with replacement, and then returns the array itself.
|
|
679
|
+
#
|
|
680
|
+
# This means that, unlike `permutation`, elements can be chosen more than once.
|
|
681
|
+
#
|
|
682
|
+
# The implementation makes no guarantees about the order in which the
|
|
683
|
+
# permutations are yielded.
|
|
684
|
+
#
|
|
685
|
+
# If no block is given, an Enumerator is returned instead.
|
|
686
|
+
#
|
|
687
|
+
# Examples:
|
|
688
|
+
#
|
|
689
|
+
# a = [1, 2]
|
|
690
|
+
# a.repeated_permutation(2).to_a #=> [[1,1],[1,2],[2,1],[2,2]]
|
|
691
|
+
def repeated_permutation(n, &block)
|
|
692
|
+
n = n.__to_int
|
|
693
|
+
raise TypeError, "no implicit conversion into Integer" unless 0 <=> n
|
|
694
|
+
return to_enum(:repeated_permutation, n) unless block
|
|
695
|
+
__repeated_combination(n, true, &block)
|
|
696
|
+
end
|
|
697
|
+
|
|
698
|
+
def __repeated_combination(n, permutation, &block)
|
|
699
|
+
n = n.__to_int
|
|
700
|
+
case n
|
|
701
|
+
when 0
|
|
702
|
+
yield []
|
|
703
|
+
when 1
|
|
704
|
+
# Keep fast Ruby path for n=1
|
|
705
|
+
i = 0
|
|
706
|
+
while i < self.size
|
|
707
|
+
yield [self[i]]
|
|
708
|
+
i += 1
|
|
709
|
+
end
|
|
710
|
+
else
|
|
711
|
+
if n > 0
|
|
712
|
+
# Use C iterator for complex cases
|
|
713
|
+
state = __combination_init(n, permutation)
|
|
714
|
+
while (indices = __combination_next(state))
|
|
715
|
+
# Convert indices to elements in Ruby
|
|
716
|
+
tmp = [nil] * n
|
|
717
|
+
i = 0
|
|
718
|
+
while i < n
|
|
719
|
+
tmp[i] = self[indices[i]]
|
|
720
|
+
i += 1
|
|
721
|
+
end
|
|
722
|
+
yield tmp
|
|
723
|
+
end
|
|
724
|
+
end
|
|
725
|
+
end
|
|
726
|
+
|
|
727
|
+
self
|
|
728
|
+
end
|
|
729
|
+
|
|
730
|
+
##
|
|
731
|
+
# call-seq:
|
|
732
|
+
# ary.find(ifnone = nil) { |elem| block } -> obj or nil
|
|
733
|
+
# ary.find(ifnone = nil) -> Enumerator
|
|
734
|
+
#
|
|
735
|
+
# Returns the first element for which the block returns a true value.
|
|
736
|
+
# If no element matches and +ifnone+ is given, calls +ifnone+ and
|
|
737
|
+
# returns its result. Otherwise returns +nil+.
|
|
738
|
+
#
|
|
739
|
+
# This is an optimized version of Enumerable#find for arrays.
|
|
740
|
+
#
|
|
741
|
+
# [1, 2, 3, 4].find { |x| x > 2 } #=> 3
|
|
742
|
+
# [1, 2, 3, 4].find { |x| x > 10 } #=> nil
|
|
743
|
+
# [1, 2, 3, 4].find(->{0}) { |x| x > 10 } #=> 0
|
|
744
|
+
#
|
|
745
|
+
def find(ifnone=nil, &block)
|
|
746
|
+
return to_enum(:find, ifnone) unless block
|
|
747
|
+
|
|
748
|
+
idx = 0
|
|
749
|
+
len = self.size
|
|
750
|
+
while idx < len
|
|
751
|
+
elem = self[idx]
|
|
752
|
+
return elem if block.call(elem)
|
|
753
|
+
idx += 1
|
|
754
|
+
end
|
|
755
|
+
ifnone&.call
|
|
756
|
+
end
|
|
757
|
+
|
|
758
|
+
##
|
|
759
|
+
# call-seq:
|
|
760
|
+
# ary.rfind(ifnone = nil) { |elem| block } -> obj or nil
|
|
761
|
+
# ary.rfind(ifnone = nil) -> Enumerator
|
|
762
|
+
#
|
|
763
|
+
# Returns the last element for which the block returns a true value.
|
|
764
|
+
# Searches from the end of the array to the beginning.
|
|
765
|
+
# If no element matches and +ifnone+ is given, calls +ifnone+ and
|
|
766
|
+
# returns its result. Otherwise returns +nil+.
|
|
767
|
+
#
|
|
768
|
+
# [1, 2, 3, 4, 3].rfind { |x| x == 3 } #=> 3 (the last one)
|
|
769
|
+
# [1, 2, 3, 4].rfind { |x| x > 2 } #=> 4
|
|
770
|
+
# [1, 2, 3, 4].rfind { |x| x > 10 } #=> nil
|
|
771
|
+
# [1, 2, 3, 4].rfind(->{0}) { |x| x > 10 } #=> 0
|
|
772
|
+
#
|
|
773
|
+
def rfind(ifnone=nil, &block)
|
|
774
|
+
return to_enum(:rfind, ifnone) unless block
|
|
775
|
+
|
|
776
|
+
idx = self.size - 1
|
|
777
|
+
while idx >= 0
|
|
778
|
+
elem = self[idx]
|
|
779
|
+
return elem if block.call(elem)
|
|
780
|
+
idx -= 1
|
|
781
|
+
end
|
|
782
|
+
ifnone&.call
|
|
783
|
+
end
|
|
784
|
+
end
|