script_core 0.2.7 → 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (283) hide show
  1. checksums.yaml +4 -4
  2. data/.ruby-version +1 -1
  3. data/Gemfile +2 -2
  4. data/ext/enterprise_script_service/Rakefile +1 -1
  5. data/ext/enterprise_script_service/mruby/.github/workflows/build.yml +117 -74
  6. data/ext/enterprise_script_service/mruby/.github/workflows/codeql-analysis.yml +41 -37
  7. data/ext/enterprise_script_service/mruby/.github/workflows/lint.yml +23 -0
  8. data/ext/enterprise_script_service/mruby/.github/workflows/oss-fuzz.yml +27 -0
  9. data/ext/enterprise_script_service/mruby/.github/workflows/spell-checker.yml +17 -0
  10. data/ext/enterprise_script_service/mruby/.gitlab-ci.yml +3 -3
  11. data/ext/enterprise_script_service/mruby/.markdownlint.yml +16 -0
  12. data/ext/enterprise_script_service/mruby/.travis.yml +2 -2
  13. data/ext/enterprise_script_service/mruby/.yamllint +8 -0
  14. data/ext/enterprise_script_service/mruby/AUTHORS +3 -0
  15. data/ext/enterprise_script_service/mruby/CODEOWNERS +1 -0
  16. data/ext/enterprise_script_service/mruby/CONTRIBUTING.md +6 -13
  17. data/ext/enterprise_script_service/mruby/Doxyfile +4 -4
  18. data/ext/enterprise_script_service/mruby/LICENSE +1 -1
  19. data/ext/enterprise_script_service/mruby/Makefile +1 -1
  20. data/ext/enterprise_script_service/mruby/README.md +4 -14
  21. data/ext/enterprise_script_service/mruby/Rakefile +18 -108
  22. data/ext/enterprise_script_service/mruby/TODO.md +17 -0
  23. data/ext/enterprise_script_service/mruby/appveyor.yml +31 -25
  24. data/ext/enterprise_script_service/mruby/benchmark/bm_ao_render.rb +1 -1
  25. data/ext/enterprise_script_service/mruby/build_config.rb +9 -152
  26. data/ext/enterprise_script_service/mruby/{examples/targets/build_config_ArduinoDue.rb → build_config/ArduinoDue.rb} +2 -19
  27. data/ext/enterprise_script_service/mruby/{examples/targets/build_config_IntelEdison.rb → build_config/IntelEdison.rb} +2 -2
  28. data/ext/enterprise_script_service/mruby/{examples/targets/build_config_IntelGalileo.rb → build_config/IntelGalileo.rb} +1 -18
  29. data/ext/enterprise_script_service/mruby/{examples/targets/build_config_RX630.rb → build_config/RX630.rb} +2 -19
  30. data/ext/enterprise_script_service/mruby/build_config/android_arm64-v8a.rb +11 -0
  31. data/ext/enterprise_script_service/mruby/build_config/android_armeabi.rb +11 -0
  32. data/ext/enterprise_script_service/mruby/{examples/targets/build_config_android_armeabi_v7a_neon_hard.rb → build_config/android_armeabi_v7a_neon_hard.rb} +0 -15
  33. data/ext/enterprise_script_service/mruby/build_config/bench.rb +11 -0
  34. data/ext/enterprise_script_service/mruby/build_config/boxing.rb +21 -0
  35. data/ext/enterprise_script_service/mruby/{examples/targets/build_config_chipKITMax32.rb → build_config/chipKITMax32.rb} +2 -19
  36. data/ext/enterprise_script_service/mruby/{travis_config.rb → build_config/ci/gcc-clang.rb} +10 -10
  37. data/ext/enterprise_script_service/mruby/build_config/ci/msvc.rb +20 -0
  38. data/ext/enterprise_script_service/mruby/build_config/clang-asan.rb +11 -0
  39. data/ext/enterprise_script_service/mruby/build_config/cross-32bit.rb +14 -0
  40. data/ext/enterprise_script_service/mruby/build_config/default.rb +80 -0
  41. data/ext/enterprise_script_service/mruby/{examples/targets/build_config_dreamcast_shelf.rb → build_config/dreamcast_shelf.rb} +5 -19
  42. data/ext/enterprise_script_service/mruby/build_config/gameboyadvance.rb +73 -0
  43. data/ext/enterprise_script_service/mruby/build_config/host-cxx.rb +12 -0
  44. data/ext/enterprise_script_service/mruby/build_config/host-debug.rb +20 -0
  45. data/ext/enterprise_script_service/mruby/build_config/host-gprof.rb +14 -0
  46. data/ext/enterprise_script_service/mruby/build_config/host-m32.rb +15 -0
  47. data/ext/enterprise_script_service/mruby/build_config/host-shared.rb +36 -0
  48. data/ext/enterprise_script_service/mruby/build_config/mrbc.rb +11 -0
  49. data/ext/enterprise_script_service/mruby/build_config/no-float.rb +17 -0
  50. data/ext/enterprise_script_service/mruby/doc/guides/compile.md +138 -49
  51. data/ext/enterprise_script_service/mruby/doc/guides/debugger.md +5 -4
  52. data/ext/enterprise_script_service/mruby/doc/guides/gc-arena-howto.md +1 -1
  53. data/ext/enterprise_script_service/mruby/doc/guides/mrbconf.md +49 -22
  54. data/ext/enterprise_script_service/mruby/doc/guides/mrbgems.md +31 -14
  55. data/ext/enterprise_script_service/mruby/doc/guides/symbol.md +83 -0
  56. data/ext/enterprise_script_service/mruby/doc/limitations.md +35 -36
  57. data/ext/enterprise_script_service/mruby/doc/mruby3.md +163 -0
  58. data/ext/enterprise_script_service/mruby/doc/opcode.md +93 -107
  59. data/ext/enterprise_script_service/mruby/examples/mrbgems/c_and_ruby_extension_example/mrblib/example.rb +1 -1
  60. data/ext/enterprise_script_service/mruby/examples/mrbgems/c_and_ruby_extension_example/src/example.c +5 -1
  61. data/ext/enterprise_script_service/mruby/examples/mrbgems/c_extension_example/src/example.c +5 -1
  62. data/ext/enterprise_script_service/mruby/examples/mrbgems/ruby_extension_example/mrblib/example.rb +1 -1
  63. data/ext/enterprise_script_service/mruby/include/mrbconf.h +81 -62
  64. data/ext/enterprise_script_service/mruby/include/mruby.h +137 -96
  65. data/ext/enterprise_script_service/mruby/include/mruby/array.h +23 -6
  66. data/ext/enterprise_script_service/mruby/include/mruby/boxing_nan.h +73 -48
  67. data/ext/enterprise_script_service/mruby/include/mruby/boxing_no.h +8 -8
  68. data/ext/enterprise_script_service/mruby/include/mruby/boxing_word.h +79 -48
  69. data/ext/enterprise_script_service/mruby/include/mruby/class.h +10 -8
  70. data/ext/enterprise_script_service/mruby/include/mruby/common.h +4 -1
  71. data/ext/enterprise_script_service/mruby/include/mruby/compile.h +13 -7
  72. data/ext/enterprise_script_service/mruby/include/mruby/debug.h +2 -2
  73. data/ext/enterprise_script_service/mruby/include/mruby/dump.h +17 -35
  74. data/ext/enterprise_script_service/mruby/include/mruby/endian.h +44 -0
  75. data/ext/enterprise_script_service/mruby/include/mruby/error.h +39 -5
  76. data/ext/enterprise_script_service/mruby/include/mruby/gc.h +1 -0
  77. data/ext/enterprise_script_service/mruby/include/mruby/hash.h +33 -13
  78. data/ext/enterprise_script_service/mruby/include/mruby/irep.h +64 -14
  79. data/ext/enterprise_script_service/mruby/include/mruby/khash.h +6 -14
  80. data/ext/enterprise_script_service/mruby/include/mruby/numeric.h +36 -63
  81. data/ext/enterprise_script_service/mruby/include/mruby/opcode.h +1 -27
  82. data/ext/enterprise_script_service/mruby/include/mruby/ops.h +27 -23
  83. data/ext/enterprise_script_service/mruby/include/mruby/presym.h +40 -0
  84. data/ext/enterprise_script_service/mruby/include/mruby/presym/disable.h +70 -0
  85. data/ext/enterprise_script_service/mruby/include/mruby/presym/enable.h +37 -0
  86. data/ext/enterprise_script_service/mruby/include/mruby/presym/scanning.h +73 -0
  87. data/ext/enterprise_script_service/mruby/include/mruby/proc.h +80 -13
  88. data/ext/enterprise_script_service/mruby/include/mruby/string.h +10 -15
  89. data/ext/enterprise_script_service/mruby/include/mruby/throw.h +14 -3
  90. data/ext/enterprise_script_service/mruby/include/mruby/value.h +29 -19
  91. data/ext/enterprise_script_service/mruby/include/mruby/variable.h +1 -0
  92. data/ext/enterprise_script_service/mruby/include/mruby/version.h +26 -7
  93. data/ext/enterprise_script_service/mruby/lib/mruby/build.rb +198 -44
  94. data/ext/enterprise_script_service/mruby/lib/mruby/build/command.rb +55 -37
  95. data/ext/enterprise_script_service/mruby/lib/mruby/build/load_gems.rb +12 -10
  96. data/ext/enterprise_script_service/mruby/lib/{mruby-core-ext.rb → mruby/core_ext.rb} +10 -3
  97. data/ext/enterprise_script_service/mruby/lib/mruby/gem.rb +75 -32
  98. data/ext/enterprise_script_service/mruby/lib/mruby/lockfile.rb +1 -1
  99. data/ext/enterprise_script_service/mruby/lib/mruby/presym.rb +132 -0
  100. data/ext/enterprise_script_service/mruby/mrbgems/default-no-fpu.gembox +3 -0
  101. data/ext/enterprise_script_service/mruby/mrbgems/default-no-stdio.gembox +4 -0
  102. data/ext/enterprise_script_service/mruby/mrbgems/default.gembox +9 -88
  103. data/ext/enterprise_script_service/mruby/mrbgems/full-core.gembox +1 -4
  104. data/ext/enterprise_script_service/mruby/mrbgems/math.gembox +10 -0
  105. data/ext/enterprise_script_service/mruby/mrbgems/metaprog.gembox +15 -0
  106. data/ext/enterprise_script_service/mruby/mrbgems/mruby-array-ext/mrblib/array.rb +1 -1
  107. data/ext/enterprise_script_service/mruby/mrbgems/mruby-array-ext/src/array.c +5 -4
  108. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-config/mrbgem.rake +28 -19
  109. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-config/mruby-config +18 -8
  110. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-debugger/bintest/mrdb.rb +3 -6
  111. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-debugger/bintest/print.rb +10 -10
  112. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apibreak.c +14 -9
  113. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apiprint.c +3 -2
  114. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdb.c +4 -3
  115. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdb.h +2 -6
  116. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdbconf.h +4 -4
  117. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-mirb/bintest/mirb.rb +23 -5
  118. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-mirb/mrbgem.rake +11 -2
  119. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c +41 -34
  120. data/ext/enterprise_script_service/mruby/mrbgems/{mruby-compiler → mruby-bin-mrbc}/bintest/mrbc.rb +0 -0
  121. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-mrbc/mrbgem.rake +3 -4
  122. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-mrbc/tools/mrbc/mrbc.c +19 -9
  123. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-mruby/bintest/mruby.rb +25 -4
  124. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-mruby/mrbgem.rake +1 -1
  125. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-mruby/tools/mruby/mruby.c +22 -6
  126. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-strip/bintest/mruby-strip.rb +1 -1
  127. data/ext/enterprise_script_service/mruby/mrbgems/mruby-bin-strip/tools/mruby-strip/mruby-strip.c +2 -2
  128. data/ext/enterprise_script_service/mruby/mrbgems/mruby-catch/mrbgem.rake +5 -0
  129. data/ext/enterprise_script_service/mruby/mrbgems/mruby-catch/mrblib/catch.rb +27 -0
  130. data/ext/enterprise_script_service/mruby/mrbgems/mruby-class-ext/src/class.c +2 -1
  131. data/ext/enterprise_script_service/mruby/mrbgems/mruby-compiler/core/codegen.c +430 -399
  132. data/ext/enterprise_script_service/mruby/mrbgems/mruby-compiler/core/keywords +5 -0
  133. data/ext/enterprise_script_service/mruby/mrbgems/mruby-compiler/core/lex.def +49 -44
  134. data/ext/enterprise_script_service/mruby/mrbgems/mruby-compiler/core/parse.y +559 -217
  135. data/ext/enterprise_script_service/mruby/mrbgems/mruby-compiler/core/y.tab.c +4774 -4193
  136. data/ext/enterprise_script_service/mruby/mrbgems/mruby-compiler/mrbgem.rake +18 -19
  137. data/ext/enterprise_script_service/mruby/mrbgems/mruby-complex/mrblib/complex.rb +1 -1
  138. data/ext/enterprise_script_service/mruby/mrbgems/mruby-complex/src/complex.c +8 -7
  139. data/ext/enterprise_script_service/mruby/mrbgems/mruby-complex/test/complex.rb +4 -4
  140. data/ext/enterprise_script_service/mruby/mrbgems/mruby-enumerator/mrblib/enumerator.rb +1 -0
  141. data/ext/enterprise_script_service/mruby/mrbgems/mruby-enumerator/test/enumerator.rb +2 -2
  142. data/ext/enterprise_script_service/mruby/mrbgems/mruby-error/mrbgem.rake +2 -2
  143. data/ext/enterprise_script_service/mruby/mrbgems/mruby-eval/src/eval.c +17 -25
  144. data/ext/enterprise_script_service/mruby/mrbgems/mruby-fiber/src/fiber.c +18 -13
  145. data/ext/enterprise_script_service/mruby/mrbgems/mruby-hash-ext/src/hash-ext.c +30 -2
  146. data/ext/enterprise_script_service/mruby/mrbgems/mruby-hash-ext/test/hash.rb +7 -0
  147. data/ext/enterprise_script_service/mruby/mrbgems/mruby-inline-struct/test/inline.c +2 -2
  148. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/README.md +18 -16
  149. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/include/mruby/ext/io.h +2 -2
  150. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/mrblib/file.rb +9 -4
  151. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/mrblib/io.rb +2 -2
  152. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/src/file.c +55 -52
  153. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/src/file_test.c +4 -2
  154. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/src/io.c +99 -87
  155. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/test/file.rb +2 -0
  156. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/test/io.rb +2 -3
  157. data/ext/enterprise_script_service/mruby/mrbgems/mruby-io/test/mruby_io_test.c +1 -1
  158. data/ext/enterprise_script_service/mruby/mrbgems/mruby-kernel-ext/src/kernel.c +7 -6
  159. data/ext/enterprise_script_service/mruby/mrbgems/mruby-math/src/math.c +13 -12
  160. data/ext/enterprise_script_service/mruby/mrbgems/mruby-math/test/math.rb +5 -4
  161. data/ext/enterprise_script_service/mruby/mrbgems/mruby-metaprog/src/metaprog.c +43 -58
  162. data/ext/enterprise_script_service/mruby/mrbgems/mruby-metaprog/test/metaprog.rb +4 -4
  163. data/ext/enterprise_script_service/mruby/mrbgems/mruby-method/README.md +4 -3
  164. data/ext/enterprise_script_service/mruby/mrbgems/mruby-method/src/method.c +77 -74
  165. data/ext/enterprise_script_service/mruby/mrbgems/mruby-method/test/method.rb +4 -4
  166. data/ext/enterprise_script_service/mruby/mrbgems/mruby-numeric-ext/src/numeric_ext.c +14 -13
  167. data/ext/enterprise_script_service/mruby/mrbgems/mruby-object-ext/src/object.c +5 -4
  168. data/ext/enterprise_script_service/mruby/mrbgems/mruby-objectspace/src/mruby_objectspace.c +18 -12
  169. data/ext/enterprise_script_service/mruby/mrbgems/mruby-os-memsize/mrbgem.rake +10 -0
  170. data/ext/enterprise_script_service/mruby/mrbgems/mruby-os-memsize/src/memsize.c +231 -0
  171. data/ext/enterprise_script_service/mruby/mrbgems/mruby-os-memsize/test/memsize.rb +63 -0
  172. data/ext/enterprise_script_service/mruby/mrbgems/mruby-pack/README.md +15 -18
  173. data/ext/enterprise_script_service/mruby/mrbgems/mruby-pack/src/pack.c +38 -88
  174. data/ext/enterprise_script_service/mruby/mrbgems/mruby-print/mrblib/print.rb +1 -30
  175. data/ext/enterprise_script_service/mruby/mrbgems/mruby-print/src/print.c +62 -26
  176. data/ext/enterprise_script_service/mruby/mrbgems/mruby-proc-ext/src/proc.c +32 -19
  177. data/ext/enterprise_script_service/mruby/mrbgems/mruby-proc-ext/test/proc.c +1 -1
  178. data/ext/enterprise_script_service/mruby/mrbgems/mruby-random/src/random.c +98 -43
  179. data/ext/enterprise_script_service/mruby/mrbgems/mruby-random/test/random.rb +2 -2
  180. data/ext/enterprise_script_service/mruby/mrbgems/mruby-range-ext/mrblib/range.rb +39 -6
  181. data/ext/enterprise_script_service/mruby/mrbgems/mruby-range-ext/src/range.c +20 -40
  182. data/ext/enterprise_script_service/mruby/mrbgems/mruby-range-ext/test/range.rb +27 -3
  183. data/ext/enterprise_script_service/mruby/mrbgems/mruby-rational/mrblib/rational.rb +11 -17
  184. data/ext/enterprise_script_service/mruby/mrbgems/mruby-rational/src/rational.c +216 -38
  185. data/ext/enterprise_script_service/mruby/mrbgems/mruby-rational/test/rational.rb +6 -6
  186. data/ext/enterprise_script_service/mruby/mrbgems/mruby-sleep/README.md +6 -4
  187. data/ext/enterprise_script_service/mruby/mrbgems/mruby-sleep/src/mrb_sleep.c +4 -4
  188. data/ext/enterprise_script_service/mruby/mrbgems/mruby-socket/README.md +3 -2
  189. data/ext/enterprise_script_service/mruby/mrbgems/mruby-socket/src/socket.c +47 -45
  190. data/ext/enterprise_script_service/mruby/mrbgems/mruby-sprintf/src/sprintf.c +102 -71
  191. data/ext/enterprise_script_service/mruby/mrbgems/mruby-sprintf/test/sprintf.rb +4 -2
  192. data/ext/enterprise_script_service/mruby/mrbgems/mruby-string-ext/mrblib/string.rb +23 -1
  193. data/ext/enterprise_script_service/mruby/mrbgems/mruby-string-ext/src/string.c +13 -9
  194. data/ext/enterprise_script_service/mruby/mrbgems/mruby-struct/mrblib/struct.rb +1 -1
  195. data/ext/enterprise_script_service/mruby/mrbgems/mruby-struct/src/struct.c +18 -25
  196. data/ext/enterprise_script_service/mruby/mrbgems/mruby-symbol-ext/src/symbol.c +6 -5
  197. data/ext/enterprise_script_service/mruby/mrbgems/mruby-symbol-ext/test/symbol.rb +1 -1
  198. data/ext/enterprise_script_service/mruby/mrbgems/mruby-test/README.md +0 -1
  199. data/ext/enterprise_script_service/mruby/mrbgems/mruby-test/driver.c +5 -5
  200. data/ext/enterprise_script_service/mruby/mrbgems/mruby-test/mrbgem.rake +16 -44
  201. data/ext/enterprise_script_service/mruby/mrbgems/mruby-test/vformat.c +4 -4
  202. data/ext/enterprise_script_service/mruby/mrbgems/mruby-time/src/time.c +27 -27
  203. data/ext/enterprise_script_service/mruby/mrbgems/stdlib-ext.gembox +18 -0
  204. data/ext/enterprise_script_service/mruby/mrbgems/stdlib-io.gembox +12 -0
  205. data/ext/enterprise_script_service/mruby/mrbgems/stdlib.gembox +54 -0
  206. data/ext/enterprise_script_service/mruby/mrblib/10error.rb +4 -0
  207. data/ext/enterprise_script_service/mruby/mrblib/array.rb +17 -9
  208. data/ext/enterprise_script_service/mruby/mrblib/enum.rb +1 -1
  209. data/ext/enterprise_script_service/mruby/mrblib/hash.rb +0 -20
  210. data/ext/enterprise_script_service/mruby/mrblib/init_mrblib.c +0 -11
  211. data/ext/enterprise_script_service/mruby/mrblib/numeric.rb +36 -11
  212. data/ext/enterprise_script_service/mruby/mrblib/range.rb +25 -3
  213. data/ext/enterprise_script_service/mruby/oss-fuzz/mruby_proto_fuzzer.cpp +2 -2
  214. data/ext/enterprise_script_service/mruby/oss-fuzz/proto_to_ruby.h +1 -1
  215. data/ext/enterprise_script_service/mruby/src/array.c +43 -80
  216. data/ext/enterprise_script_service/mruby/src/backtrace.c +16 -17
  217. data/ext/enterprise_script_service/mruby/src/class.c +774 -182
  218. data/ext/enterprise_script_service/mruby/src/codedump.c +223 -198
  219. data/ext/enterprise_script_service/mruby/src/debug.c +6 -6
  220. data/ext/enterprise_script_service/mruby/src/dump.c +466 -141
  221. data/ext/enterprise_script_service/mruby/src/enum.c +1 -1
  222. data/ext/enterprise_script_service/mruby/src/error.c +36 -13
  223. data/ext/enterprise_script_service/mruby/src/etc.c +43 -34
  224. data/ext/enterprise_script_service/mruby/src/fmt_fp.c +5 -6
  225. data/ext/enterprise_script_service/mruby/src/gc.c +73 -71
  226. data/ext/enterprise_script_service/mruby/src/hash.c +1050 -707
  227. data/ext/enterprise_script_service/mruby/src/kernel.c +75 -220
  228. data/ext/enterprise_script_service/mruby/src/load.c +196 -166
  229. data/ext/enterprise_script_service/mruby/src/numeric.c +352 -314
  230. data/ext/enterprise_script_service/mruby/src/object.c +97 -90
  231. data/ext/enterprise_script_service/mruby/src/print.c +4 -3
  232. data/ext/enterprise_script_service/mruby/src/proc.c +48 -56
  233. data/ext/enterprise_script_service/mruby/src/range.c +45 -21
  234. data/ext/enterprise_script_service/mruby/src/state.c +25 -32
  235. data/ext/enterprise_script_service/mruby/src/string.c +59 -101
  236. data/ext/enterprise_script_service/mruby/src/symbol.c +121 -56
  237. data/ext/enterprise_script_service/mruby/src/value_array.h +1 -0
  238. data/ext/enterprise_script_service/mruby/src/variable.c +158 -158
  239. data/ext/enterprise_script_service/mruby/src/vm.c +617 -602
  240. data/ext/enterprise_script_service/mruby/tasks/benchmark.rake +6 -6
  241. data/ext/enterprise_script_service/mruby/tasks/bin.rake +23 -0
  242. data/ext/enterprise_script_service/mruby/tasks/core.rake +12 -0
  243. data/ext/enterprise_script_service/mruby/tasks/doc.rake +50 -38
  244. data/ext/enterprise_script_service/mruby/tasks/gitlab.rake +83 -77
  245. data/ext/enterprise_script_service/mruby/tasks/libmruby.rake +10 -1
  246. data/ext/enterprise_script_service/mruby/tasks/mrbgems.rake +13 -1
  247. data/ext/enterprise_script_service/mruby/tasks/mrblib.rake +40 -0
  248. data/ext/enterprise_script_service/mruby/tasks/presym.rake +44 -0
  249. data/ext/enterprise_script_service/mruby/tasks/test.rake +68 -0
  250. data/ext/enterprise_script_service/mruby/tasks/toolchains/gcc.rake +6 -5
  251. data/ext/enterprise_script_service/mruby/tasks/toolchains/openwrt.rake +10 -14
  252. data/ext/enterprise_script_service/mruby/tasks/toolchains/visualcpp.rake +17 -21
  253. data/ext/enterprise_script_service/mruby/test/bintest.rb +5 -5
  254. data/ext/enterprise_script_service/mruby/test/t/argumenterror.rb +16 -0
  255. data/ext/enterprise_script_service/mruby/test/t/array.rb +7 -3
  256. data/ext/enterprise_script_service/mruby/test/t/bs_literal.rb +1 -1
  257. data/ext/enterprise_script_service/mruby/test/t/float.rb +18 -8
  258. data/ext/enterprise_script_service/mruby/test/t/hash.rb +903 -281
  259. data/ext/enterprise_script_service/mruby/test/t/integer.rb +10 -38
  260. data/ext/enterprise_script_service/mruby/test/t/kernel.rb +1 -1
  261. data/ext/enterprise_script_service/mruby/test/t/literals.rb +50 -0
  262. data/ext/enterprise_script_service/mruby/test/t/module.rb +2 -2
  263. data/ext/enterprise_script_service/mruby/test/t/numeric.rb +1 -1
  264. data/ext/enterprise_script_service/mruby/test/t/range.rb +83 -1
  265. data/ext/enterprise_script_service/mruby/test/t/string.rb +4 -0
  266. data/ext/enterprise_script_service/mruby/test/t/superclass.rb +10 -10
  267. data/ext/enterprise_script_service/mruby/test/t/syntax.rb +24 -0
  268. data/ext/enterprise_script_service/mruby/test/t/vformat.rb +3 -3
  269. data/ext/enterprise_script_service/mruby_config.rb +2 -5
  270. data/ext/enterprise_script_service/mruby_engine.cpp +1 -1
  271. data/lib/script_core/version.rb +1 -1
  272. data/spec/script_core_spec.rb +13 -0
  273. metadata +61 -23
  274. data/ext/enterprise_script_service/mruby/.github/workflows/main.yml +0 -24
  275. data/ext/enterprise_script_service/mruby/TODO +0 -8
  276. data/ext/enterprise_script_service/mruby/appveyor_config.rb +0 -46
  277. data/ext/enterprise_script_service/mruby/benchmark/build_config_boxing.rb +0 -28
  278. data/ext/enterprise_script_service/mruby/examples/targets/build_config_android_arm64-v8a.rb +0 -26
  279. data/ext/enterprise_script_service/mruby/examples/targets/build_config_android_armeabi.rb +0 -26
  280. data/ext/enterprise_script_service/mruby/mrbgems/mruby-sprintf/src/kernel.c +0 -30
  281. data/ext/enterprise_script_service/mruby/mrblib/mrblib.rake +0 -18
  282. data/ext/enterprise_script_service/mruby/src/crc.c +0 -39
  283. data/ext/enterprise_script_service/mruby/src/mruby_core.rake +0 -19
@@ -11,6 +11,47 @@
11
11
  #include <mruby/string.h>
12
12
  #include <mruby/dump.h>
13
13
  #include <mruby/class.h>
14
+ #include <mruby/presym.h>
15
+
16
+ #ifndef MRB_NO_PRESYM
17
+
18
+ #ifndef MRB_PRESYM_SCANNING
19
+ /* const uint16_t presym_length_table[] */
20
+ /* const char * const presym_name_table[] */
21
+ # include <mruby/presym/table.h>
22
+ #endif
23
+
24
+ static mrb_sym
25
+ presym_find(const char *name, size_t len)
26
+ {
27
+ if (presym_length_table[MRB_PRESYM_MAX-1] < len) return 0;
28
+
29
+ mrb_sym start, idx, presym_size = MRB_PRESYM_MAX;
30
+ int cmp;
31
+ for (start = 0; presym_size != 0; presym_size/=2) {
32
+ idx = start+presym_size/2;
33
+ cmp = (int)len-(int)presym_length_table[idx];
34
+ if (cmp == 0) {
35
+ cmp = memcmp(name, presym_name_table[idx], len);
36
+ if (cmp == 0) return idx+1;
37
+ }
38
+ if (0 < cmp) {
39
+ start = ++idx;
40
+ --presym_size;
41
+ }
42
+ }
43
+ return 0;
44
+ }
45
+
46
+ static const char*
47
+ presym_sym2name(mrb_sym sym, mrb_int *lenp)
48
+ {
49
+ if (sym > MRB_PRESYM_MAX) return NULL;
50
+ if (lenp) *lenp = presym_length_table[sym-1];
51
+ return presym_name_table[sym-1];
52
+ }
53
+
54
+ #endif /* MRB_NO_PRESYM */
14
55
 
15
56
  /* ------------------------------------------------------ */
16
57
  typedef struct symbol_name {
@@ -20,46 +61,35 @@ typedef struct symbol_name {
20
61
  const char *name;
21
62
  } symbol_name;
22
63
 
23
- #define SYMBOL_INLINE_BIT_POS 1
24
- #define SYMBOL_INLINE_LOWER_BIT_POS 2
25
- #define SYMBOL_INLINE (1 << (SYMBOL_INLINE_BIT_POS - 1))
26
- #define SYMBOL_INLINE_LOWER (1 << (SYMBOL_INLINE_LOWER_BIT_POS - 1))
27
- #define SYMBOL_NORMAL_SHIFT SYMBOL_INLINE_BIT_POS
28
- #define SYMBOL_INLINE_SHIFT SYMBOL_INLINE_LOWER_BIT_POS
29
- #ifdef MRB_ENABLE_ALL_SYMBOLS
30
- # define SYMBOL_INLINE_P(sym) FALSE
31
- # define SYMBOL_INLINE_LOWER_P(sym) FALSE
32
- # define sym_inline_pack(name, len) 0
33
- # define sym_inline_unpack(sym, buf, lenp) NULL
34
- #else
35
- # define SYMBOL_INLINE_P(sym) ((sym) & SYMBOL_INLINE)
36
- # define SYMBOL_INLINE_LOWER_P(sym) ((sym) & SYMBOL_INLINE_LOWER)
37
- #endif
38
-
39
64
  static void
40
65
  sym_validate_len(mrb_state *mrb, size_t len)
41
66
  {
42
- if (len >= RITE_LV_NULL_MARK) {
67
+ if (len >= UINT16_MAX) {
43
68
  mrb_raise(mrb, E_ARGUMENT_ERROR, "symbol length too long");
44
69
  }
45
70
  }
46
71
 
47
- #ifndef MRB_ENABLE_ALL_SYMBOLS
72
+ #ifdef MRB_USE_ALL_SYMBOLS
73
+ # define SYMBOL_INLINE_P(sym) FALSE
74
+ # define sym_inline_pack(name, len) 0
75
+ # define sym_inline_unpack(sym, buf, lenp) NULL
76
+ #else
77
+ # define SYMBOL_INLINE_P(sym) ((sym) >= (1<<24))
78
+
48
79
  static const char pack_table[] = "_abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
49
80
 
50
81
  static mrb_sym
51
82
  sym_inline_pack(const char *name, size_t len)
52
83
  {
53
- const size_t lower_length_max = (MRB_SYMBOL_BIT - 2) / 5;
54
- const size_t mix_length_max = (MRB_SYMBOL_BIT - 2) / 6;
84
+ const size_t pack_length_max = 5;
55
85
 
56
86
  char c;
57
87
  const char *p;
58
88
  size_t i;
59
89
  mrb_sym sym = 0;
60
- mrb_bool lower = TRUE;
61
90
 
62
- if (len > lower_length_max) return 0; /* too long */
91
+ if (len > pack_length_max) return 0; /* too long */
92
+ if (len == 0) return 0; /* empty string */
63
93
  for (i=0; i<len; i++) {
64
94
  uint32_t bits;
65
95
 
@@ -68,36 +98,21 @@ sym_inline_pack(const char *name, size_t len)
68
98
  p = strchr(pack_table, (int)c);
69
99
  if (p == 0) return 0; /* non alnum char */
70
100
  bits = (uint32_t)(p - pack_table)+1;
71
- if (bits > 27) lower = FALSE;
72
- if (i >= mix_length_max) break;
73
- sym |= bits<<(i*6+SYMBOL_INLINE_SHIFT);
101
+ sym |= bits<<(24-i*6);
74
102
  }
75
- if (lower) {
76
- sym = 0;
77
- for (i=0; i<len; i++) {
78
- uint32_t bits;
79
-
80
- c = name[i];
81
- p = strchr(pack_table, (int)c);
82
- bits = (uint32_t)(p - pack_table)+1;
83
- sym |= bits<<(i*5+SYMBOL_INLINE_SHIFT);
84
- }
85
- return sym | SYMBOL_INLINE | SYMBOL_INLINE_LOWER;
86
- }
87
- if (len > mix_length_max) return 0;
88
- return sym | SYMBOL_INLINE;
103
+ mrb_assert(SYMBOL_INLINE_P(sym));
104
+ return sym;
89
105
  }
90
106
 
91
107
  static const char*
92
108
  sym_inline_unpack(mrb_sym sym, char *buf, mrb_int *lenp)
93
109
  {
94
- int bit_per_char = SYMBOL_INLINE_LOWER_P(sym) ? 5 : 6;
95
110
  int i;
96
111
 
97
112
  mrb_assert(SYMBOL_INLINE_P(sym));
98
113
 
99
- for (i=0; i<30/bit_per_char; i++) {
100
- uint32_t bits = sym>>(i*bit_per_char+SYMBOL_INLINE_SHIFT) & ((1<<bit_per_char)-1);
114
+ for (i=0; i<5; i++) {
115
+ uint32_t bits = sym>>(24-i*6) & 0x3f;
101
116
  if (bits == 0) break;
102
117
  buf[i] = pack_table[bits-1];;
103
118
  }
@@ -130,6 +145,12 @@ find_symbol(mrb_state *mrb, const char *name, size_t len, uint8_t *hashp)
130
145
  symbol_name *sname;
131
146
  uint8_t hash;
132
147
 
148
+ #ifndef MRB_NO_PRESYM
149
+ /* presym */
150
+ i = presym_find(name, len);
151
+ if (i > 0) return i;
152
+ #endif
153
+
133
154
  /* inline symbol */
134
155
  i = sym_inline_pack(name, len);
135
156
  if (i > 0) return i;
@@ -142,14 +163,14 @@ find_symbol(mrb_state *mrb, const char *name, size_t len, uint8_t *hashp)
142
163
  do {
143
164
  sname = &mrb->symtbl[i];
144
165
  if (sname->len == len && memcmp(sname->name, name, len) == 0) {
145
- return i<<SYMBOL_NORMAL_SHIFT;
166
+ return (i+MRB_PRESYM_MAX);
146
167
  }
147
168
  if (sname->prev == 0xff) {
148
169
  i -= 0xff;
149
170
  sname = &mrb->symtbl[i];
150
171
  while (mrb->symtbl < sname) {
151
172
  if (sname->len == len && memcmp(sname->name, name, len) == 0) {
152
- return (mrb_sym)(sname - mrb->symtbl)<<SYMBOL_NORMAL_SHIFT;
173
+ return (mrb_sym)((sname - mrb->symtbl)+MRB_PRESYM_MAX);
153
174
  }
154
175
  sname--;
155
176
  }
@@ -205,7 +226,7 @@ sym_intern(mrb_state *mrb, const char *name, size_t len, mrb_bool lit)
205
226
  }
206
227
  mrb->symhash[hash] = mrb->symidx = sym;
207
228
 
208
- return sym<<SYMBOL_NORMAL_SHIFT;
229
+ return (sym+MRB_PRESYM_MAX);
209
230
  }
210
231
 
211
232
  MRB_API mrb_sym
@@ -232,36 +253,69 @@ mrb_intern_str(mrb_state *mrb, mrb_value str)
232
253
  return mrb_intern(mrb, RSTRING_PTR(str), RSTRING_LEN(str));
233
254
  }
234
255
 
235
- MRB_API mrb_value
236
- mrb_check_intern(mrb_state *mrb, const char *name, size_t len)
256
+ MRB_API mrb_sym
257
+ mrb_intern_check(mrb_state *mrb, const char *name, size_t len)
237
258
  {
238
259
  mrb_sym sym;
239
260
 
240
261
  sym_validate_len(mrb, len);
241
262
  sym = find_symbol(mrb, name, len, NULL);
242
- if (sym > 0) return mrb_symbol_value(sym);
243
- return mrb_nil_value();
263
+ if (sym > 0) return sym;
264
+ return 0;
265
+ }
266
+
267
+ MRB_API mrb_value
268
+ mrb_check_intern(mrb_state *mrb, const char *name, size_t len)
269
+ {
270
+ mrb_sym sym = mrb_intern_check(mrb, name, len);
271
+ if (sym == 0) return mrb_nil_value();
272
+ return mrb_symbol_value(sym);
273
+ }
274
+
275
+ MRB_API mrb_sym
276
+ mrb_intern_check_cstr(mrb_state *mrb, const char *name)
277
+ {
278
+ return mrb_intern_check(mrb, name, strlen(name));
244
279
  }
245
280
 
246
281
  MRB_API mrb_value
247
282
  mrb_check_intern_cstr(mrb_state *mrb, const char *name)
248
283
  {
249
- return mrb_check_intern(mrb, name, strlen(name));
284
+ mrb_sym sym = mrb_intern_check_cstr(mrb, name);
285
+ if (sym == 0) return mrb_nil_value();
286
+ return mrb_symbol_value(sym);
287
+ }
288
+
289
+ MRB_API mrb_sym
290
+ mrb_intern_check_str(mrb_state *mrb, mrb_value str)
291
+ {
292
+ return mrb_intern_check(mrb, RSTRING_PTR(str), RSTRING_LEN(str));
250
293
  }
251
294
 
252
295
  MRB_API mrb_value
253
296
  mrb_check_intern_str(mrb_state *mrb, mrb_value str)
254
297
  {
255
- return mrb_check_intern(mrb, RSTRING_PTR(str), RSTRING_LEN(str));
298
+ mrb_sym sym = mrb_intern_check_str(mrb, str);
299
+ if (sym == 0) return mrb_nil_value();
300
+ return mrb_symbol_value(sym);
256
301
  }
257
302
 
258
303
  static const char*
259
304
  sym2name_len(mrb_state *mrb, mrb_sym sym, char *buf, mrb_int *lenp)
260
305
  {
306
+ if (sym == 0) goto outofsym;
261
307
  if (SYMBOL_INLINE_P(sym)) return sym_inline_unpack(sym, buf, lenp);
262
308
 
263
- sym >>= SYMBOL_NORMAL_SHIFT;
264
- if (sym == 0 || mrb->symidx < sym) {
309
+ #ifndef MRB_NO_PRESYM
310
+ {
311
+ const char *name = presym_sym2name(sym, lenp);
312
+ if (name) return name;
313
+ }
314
+ #endif
315
+ sym -= MRB_PRESYM_MAX;
316
+
317
+ if (mrb->symidx < sym) {
318
+ outofsym:
265
319
  if (lenp) *lenp = 0;
266
320
  return NULL;
267
321
  }
@@ -273,7 +327,19 @@ sym2name_len(mrb_state *mrb, mrb_sym sym, char *buf, mrb_int *lenp)
273
327
  MRB_API const char*
274
328
  mrb_sym_name_len(mrb_state *mrb, mrb_sym sym, mrb_int *lenp)
275
329
  {
330
+ #ifdef MRB_USE_ALL_SYMBOLS
331
+ return sym2name_len(mrb, sym, NULL, lenp);
332
+ #else
276
333
  return sym2name_len(mrb, sym, mrb->symbuf, lenp);
334
+ #endif
335
+ }
336
+
337
+ mrb_bool
338
+ mrb_sym_static_p(mrb_state *mrb, mrb_sym sym)
339
+ {
340
+ if (SYMBOL_INLINE_P(sym)) return TRUE;
341
+ if (sym > MRB_PRESYM_MAX) return FALSE;
342
+ return TRUE;
277
343
  }
278
344
 
279
345
  void
@@ -497,7 +563,7 @@ sym_inspect(mrb_state *mrb, mrb_value sym)
497
563
  char *sp;
498
564
 
499
565
  name = mrb_sym_name_len(mrb, id, &len);
500
- str = mrb_str_new(mrb, 0, len+1);
566
+ str = mrb_str_new(mrb, NULL, len+1);
501
567
  sp = RSTRING_PTR(str);
502
568
  sp[0] = ':';
503
569
  memcpy(sp+1, name, len);
@@ -540,8 +606,7 @@ sym_name(mrb_state *mrb, mrb_sym sym, mrb_bool dump)
540
606
  return name;
541
607
  }
542
608
  else {
543
- mrb_value str = SYMBOL_INLINE_P(sym) ?
544
- mrb_str_new(mrb, name, len) : mrb_str_new_static(mrb, name, len);
609
+ mrb_value str = mrb_str_new_static(mrb, name, len);
545
610
  str = mrb_str_dump(mrb, str);
546
611
  return RSTRING_PTR(str);
547
612
  }
@@ -6,6 +6,7 @@
6
6
  static inline void
7
7
  value_move(mrb_value *s1, const mrb_value *s2, size_t n)
8
8
  {
9
+ if (n == 0) return;
9
10
  if (s1 > s2 && s1 < s2 + n)
10
11
  {
11
12
  s1 += n;
@@ -10,22 +10,18 @@
10
10
  #include <mruby/proc.h>
11
11
  #include <mruby/string.h>
12
12
  #include <mruby/variable.h>
13
+ #include <mruby/presym.h>
13
14
 
14
- #ifndef MRB_IV_SEGMENT_SIZE
15
- #define MRB_IV_SEGMENT_SIZE 4
16
- #endif
17
-
18
- typedef struct segment {
19
- mrb_sym key[MRB_IV_SEGMENT_SIZE];
20
- mrb_value val[MRB_IV_SEGMENT_SIZE];
21
- struct segment *next;
22
- } segment;
15
+ struct iv_elem {
16
+ mrb_sym key;
17
+ mrb_value val;
18
+ };
23
19
 
24
20
  /* Instance variable table structure */
25
21
  typedef struct iv_tbl {
26
- segment *rootseg;
27
22
  size_t size;
28
- size_t last_len;
23
+ size_t alloc;
24
+ struct iv_elem *table;
29
25
  } iv_tbl;
30
26
 
31
27
  /* Creates the instance variable table. */
@@ -36,67 +32,82 @@ iv_new(mrb_state *mrb)
36
32
 
37
33
  t = (iv_tbl*)mrb_malloc(mrb, sizeof(iv_tbl));
38
34
  t->size = 0;
39
- t->rootseg = NULL;
40
- t->last_len = 0;
35
+ t->alloc = 0;
36
+ t->table = NULL;
41
37
 
42
38
  return t;
43
39
  }
44
40
 
41
+ static void iv_put(mrb_state *mrb, iv_tbl *t, mrb_sym sym, mrb_value val);
42
+
43
+ static void
44
+ iv_rehash(mrb_state *mrb, iv_tbl *t)
45
+ {
46
+ size_t old_alloc = t->alloc;
47
+ size_t new_alloc = old_alloc+1;
48
+ struct iv_elem *old_table = t->table;
49
+
50
+ khash_power2(new_alloc);
51
+ if (old_alloc == new_alloc) return;
52
+
53
+ t->alloc = new_alloc;
54
+ t->size = 0;
55
+ t->table = (struct iv_elem*)mrb_calloc(mrb, sizeof(struct iv_elem), new_alloc);
56
+
57
+ for (size_t i = 0; i < old_alloc; i++) {
58
+ struct iv_elem *slot = &old_table[i];
59
+
60
+ /* key = 0 means empty; val = undef means deleted */
61
+ if (slot->key != 0 && !mrb_undef_p(slot->val)) {
62
+ iv_put(mrb, t, slot->key, slot->val);
63
+ }
64
+ }
65
+ mrb_free(mrb, old_table);
66
+ }
67
+
68
+ #define slot_empty_p(slot) ((slot)->key == 0 && !mrb_undef_p((slot)->val))
69
+
45
70
  /* Set the value for the symbol in the instance variable table. */
46
71
  static void
47
72
  iv_put(mrb_state *mrb, iv_tbl *t, mrb_sym sym, mrb_value val)
48
73
  {
49
- segment *seg;
50
- segment *prev = NULL;
51
- segment *matched_seg = NULL;
52
- size_t matched_idx = 0;
53
- size_t i;
74
+ size_t hash, pos, start;
75
+ struct iv_elem *dslot = NULL;
54
76
 
55
77
  if (t == NULL) return;
56
- seg = t->rootseg;
57
- while (seg) {
58
- for (i=0; i<MRB_IV_SEGMENT_SIZE; i++) {
59
- mrb_sym key = seg->key[i];
60
- /* Found room in last segment after last_len */
61
- if (!seg->next && i >= t->last_len) {
62
- seg->key[i] = sym;
63
- seg->val[i] = val;
64
- t->last_len = i+1;
78
+ if (t->alloc == 0) {
79
+ iv_rehash(mrb, t);
80
+ }
81
+ hash = kh_int_hash_func(mrb, sym);
82
+ start = pos = hash & (t->alloc-1);
83
+ for (;;) {
84
+ struct iv_elem *slot = &t->table[pos];
85
+
86
+ if (slot->key == sym) {
87
+ slot->val = val;
88
+ return;
89
+ }
90
+ else if (slot_empty_p(slot)) {
91
+ t->size++;
92
+ slot->key = sym;
93
+ slot->val = val;
94
+ return;
95
+ }
96
+ else if (!dslot && mrb_undef_p(slot->val)) { /* deleted */
97
+ dslot = slot;
98
+ }
99
+ pos = (pos+1) & (t->alloc-1);
100
+ if (pos == start) { /* not found */
101
+ if (dslot) {
65
102
  t->size++;
103
+ dslot->key = sym;
104
+ dslot->val = val;
66
105
  return;
67
106
  }
68
- if (!matched_seg && key == 0) {
69
- matched_seg = seg;
70
- matched_idx = i;
71
- }
72
- else if (key == sym) {
73
- seg->val[i] = val;
74
- return;
75
- }
107
+ /* no room */
108
+ iv_rehash(mrb, t);
109
+ start = pos = hash & (t->alloc-1);
76
110
  }
77
- prev = seg;
78
- seg = seg->next;
79
- }
80
-
81
- /* Not found */
82
- if (matched_seg) {
83
- matched_seg->key[matched_idx] = sym;
84
- matched_seg->val[matched_idx] = val;
85
- t->size++;
86
- return;
87
- }
88
-
89
- seg = (segment*)mrb_malloc(mrb, sizeof(segment));
90
- seg->next = NULL;
91
- seg->key[0] = sym;
92
- seg->val[0] = val;
93
- t->last_len = 1;
94
- t->size++;
95
- if (prev) {
96
- prev->next = seg;
97
- }
98
- else {
99
- t->rootseg = seg;
100
111
  }
101
112
  }
102
113
 
@@ -104,80 +115,81 @@ iv_put(mrb_state *mrb, iv_tbl *t, mrb_sym sym, mrb_value val)
104
115
  static mrb_bool
105
116
  iv_get(mrb_state *mrb, iv_tbl *t, mrb_sym sym, mrb_value *vp)
106
117
  {
107
- segment *seg;
108
- size_t i;
118
+ size_t hash, pos, start;
109
119
 
110
120
  if (t == NULL) return FALSE;
111
- seg = t->rootseg;
112
- while (seg) {
113
- for (i=0; i<MRB_IV_SEGMENT_SIZE; i++) {
114
- mrb_sym key = seg->key[i];
121
+ if (t->alloc == 0) return FALSE;
122
+ if (t->size == 0) return FALSE;
115
123
 
116
- if (!seg->next && i >= t->last_len) {
117
- return FALSE;
118
- }
119
- if (key == sym) {
120
- if (vp) *vp = seg->val[i];
121
- return TRUE;
122
- }
124
+ hash = kh_int_hash_func(mrb, sym);
125
+ start = pos = hash & (t->alloc-1);
126
+ for (;;) {
127
+ struct iv_elem *slot = &t->table[pos];
128
+
129
+ if (slot->key == sym) {
130
+ if (vp) *vp = slot->val;
131
+ return TRUE;
132
+ }
133
+ else if (slot_empty_p(slot)) {
134
+ return FALSE;
135
+ }
136
+ pos = (pos+1) & (t->alloc-1);
137
+ if (pos == start) { /* not found */
138
+ return FALSE;
123
139
  }
124
- seg = seg->next;
125
140
  }
126
- return FALSE;
127
141
  }
128
142
 
129
143
  /* Deletes the value for the symbol from the instance variable table. */
130
144
  static mrb_bool
131
145
  iv_del(mrb_state *mrb, iv_tbl *t, mrb_sym sym, mrb_value *vp)
132
146
  {
133
- segment *seg;
134
- size_t i;
147
+ size_t hash, pos, start;
135
148
 
136
149
  if (t == NULL) return FALSE;
137
- seg = t->rootseg;
138
- while (seg) {
139
- for (i=0; i<MRB_IV_SEGMENT_SIZE; i++) {
140
- mrb_sym key = seg->key[i];
150
+ if (t->alloc == 0) return FALSE;
151
+ if (t->size == 0) return FALSE;
141
152
 
142
- if (!seg->next && i >= t->last_len) {
143
- return FALSE;
144
- }
145
- if (key == sym) {
146
- t->size--;
147
- seg->key[i] = 0;
148
- if (vp) *vp = seg->val[i];
149
- return TRUE;
150
- }
153
+ hash = kh_int_hash_func(mrb, sym);
154
+ start = pos = hash & (t->alloc-1);
155
+ for (;;) {
156
+ struct iv_elem *slot = &t->table[pos];
157
+
158
+ if (slot->key == sym) {
159
+ if (vp) *vp = slot->val;
160
+ t->size--;
161
+ slot->key = 0;
162
+ slot->val = mrb_undef_value();
163
+ return TRUE;
164
+ }
165
+ else if (slot_empty_p(slot)) {
166
+ return FALSE;
167
+ }
168
+ pos = (pos+1) & (t->alloc-1);
169
+ if (pos == start) { /* not found */
170
+ return FALSE;
151
171
  }
152
- seg = seg->next;
153
172
  }
154
- return FALSE;
155
173
  }
156
174
 
157
175
  /* Iterates over the instance variable table. */
158
176
  static void
159
177
  iv_foreach(mrb_state *mrb, iv_tbl *t, mrb_iv_foreach_func *func, void *p)
160
178
  {
161
- segment *seg;
162
179
  size_t i;
163
180
 
164
181
  if (t == NULL) return;
165
- seg = t->rootseg;
166
- while (seg) {
167
- for (i=0; i<MRB_IV_SEGMENT_SIZE; i++) {
168
- mrb_sym key = seg->key[i];
182
+ if (t->alloc == 0) return;
183
+ if (t->size == 0) return;
184
+
185
+ for (i=0; i<t->alloc; i++) {
186
+ struct iv_elem *slot = &t->table[i];
169
187
 
170
- /* no value in last segment after last_len */
171
- if (!seg->next && i >= t->last_len) {
188
+ if (slot->key && !mrb_undef_p(slot->val)) {
189
+ if ((*func)(mrb, slot->key, slot->val, p) != 0) {
172
190
  return;
173
191
  }
174
- if (key != 0) {
175
- if ((*func)(mrb, key, seg->val[i], p) != 0) {
176
- return;
177
- }
178
- }
179
192
  }
180
- seg = seg->next;
181
193
  }
182
194
  return;
183
195
  }
@@ -186,47 +198,28 @@ iv_foreach(mrb_state *mrb, iv_tbl *t, mrb_iv_foreach_func *func, void *p)
186
198
  static size_t
187
199
  iv_size(mrb_state *mrb, iv_tbl *t)
188
200
  {
189
- segment *seg;
190
- size_t size = 0;
191
-
192
201
  if (t == NULL) return 0;
193
- if (t->size > 0) return t->size;
194
- seg = t->rootseg;
195
- while (seg) {
196
- if (seg->next == NULL) {
197
- size += t->last_len;
198
- return size;
199
- }
200
- seg = seg->next;
201
- size += MRB_IV_SEGMENT_SIZE;
202
- }
203
- /* empty iv_tbl */
204
- return 0;
202
+ return t->size;
205
203
  }
206
204
 
207
205
  /* Copy the instance variable table. */
208
206
  static iv_tbl*
209
207
  iv_copy(mrb_state *mrb, iv_tbl *t)
210
208
  {
211
- segment *seg;
212
209
  iv_tbl *t2;
213
-
214
210
  size_t i;
215
211
 
216
- seg = t->rootseg;
217
- t2 = iv_new(mrb);
212
+ if (t == NULL) return NULL;
213
+ if (t->alloc == 0) return NULL;
214
+ if (t->size == 0) return NULL;
218
215
 
219
- while (seg != NULL) {
220
- for (i=0; i<MRB_IV_SEGMENT_SIZE; i++) {
221
- mrb_sym key = seg->key[i];
222
- mrb_value val = seg->val[i];
216
+ t2 = iv_new(mrb);
217
+ for (i=0; i<t->alloc; i++) {
218
+ struct iv_elem *slot = &t->table[i];
223
219
 
224
- if ((seg->next == NULL) && (i >= t->last_len)) {
225
- return t2;
226
- }
227
- iv_put(mrb, t2, key, val);
220
+ if (slot->key && !mrb_undef_p(slot->val)) {
221
+ iv_put(mrb, t2, slot->key, slot->val);
228
222
  }
229
- seg = seg->next;
230
223
  }
231
224
  return t2;
232
225
  }
@@ -235,14 +228,7 @@ iv_copy(mrb_state *mrb, iv_tbl *t)
235
228
  static void
236
229
  iv_free(mrb_state *mrb, iv_tbl *t)
237
230
  {
238
- segment *seg;
239
-
240
- seg = t->rootseg;
241
- while (seg) {
242
- segment *p = seg;
243
- seg = seg->next;
244
- mrb_free(mrb, p);
245
- }
231
+ mrb_free(mrb, t->table);
246
232
  mrb_free(mrb, t);
247
233
  }
248
234
 
@@ -349,7 +335,7 @@ mrb_obj_iv_set_force(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value
349
335
  obj->iv = iv_new(mrb);
350
336
  }
351
337
  iv_put(mrb, obj->iv, sym, v);
352
- mrb_write_barrier(mrb, (struct RBasic*)obj);
338
+ mrb_field_write_barrier_value(mrb, (struct RBasic*)obj, v);
353
339
  }
354
340
 
355
341
  MRB_API void
@@ -379,11 +365,11 @@ assign_class_name(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v)
379
365
  if (namespace_p(obj->tt) && namespace_p(mrb_type(v))) {
380
366
  struct RObject *c = mrb_obj_ptr(v);
381
367
  if (obj != c && ISUPPER(mrb_sym_name_len(mrb, sym, NULL)[0])) {
382
- mrb_sym id_classname = mrb_intern_lit(mrb, "__classname__");
368
+ mrb_sym id_classname = MRB_SYM(__classname__);
383
369
  mrb_value o = mrb_obj_iv_get(mrb, c, id_classname);
384
370
 
385
371
  if (mrb_nil_p(o)) {
386
- mrb_sym id_outer = mrb_intern_lit(mrb, "__outer__");
372
+ mrb_sym id_outer = MRB_SYM(__outer__);
387
373
  o = mrb_obj_iv_get(mrb, c, id_outer);
388
374
 
389
375
  if (mrb_nil_p(o)) {
@@ -643,8 +629,7 @@ mrb_mod_cv_get(mrb_state *mrb, struct RClass *c, mrb_sym sym)
643
629
  if (cls && cls->tt == MRB_TT_SCLASS) {
644
630
  mrb_value klass;
645
631
 
646
- klass = mrb_obj_iv_get(mrb, (struct RObject *)cls,
647
- mrb_intern_lit(mrb, "__attached__"));
632
+ klass = mrb_obj_iv_get(mrb, (struct RObject *)cls, MRB_SYM(__attached__));
648
633
  c = mrb_class_ptr(klass);
649
634
  if (c->tt == MRB_TT_CLASS || c->tt == MRB_TT_MODULE) {
650
635
  given = FALSE;
@@ -679,7 +664,7 @@ mrb_mod_cv_set(mrb_state *mrb, struct RClass *c, mrb_sym sym, mrb_value v)
679
664
  if (iv_get(mrb, t, sym, NULL)) {
680
665
  mrb_check_frozen(mrb, c);
681
666
  iv_put(mrb, t, sym, v);
682
- mrb_write_barrier(mrb, (struct RBasic*)c);
667
+ mrb_field_write_barrier_value(mrb, (struct RBasic*)c, v);
683
668
  return;
684
669
  }
685
670
  c = c->super;
@@ -688,8 +673,7 @@ mrb_mod_cv_set(mrb_state *mrb, struct RClass *c, mrb_sym sym, mrb_value v)
688
673
  if (cls && cls->tt == MRB_TT_SCLASS) {
689
674
  mrb_value klass;
690
675
 
691
- klass = mrb_obj_iv_get(mrb, (struct RObject*)cls,
692
- mrb_intern_lit(mrb, "__attached__"));
676
+ klass = mrb_obj_iv_get(mrb, (struct RObject*)cls, MRB_SYM(__attached__));
693
677
  switch (mrb_type(klass)) {
694
678
  case MRB_TT_CLASS:
695
679
  case MRB_TT_MODULE:
@@ -711,7 +695,7 @@ mrb_mod_cv_set(mrb_state *mrb, struct RClass *c, mrb_sym sym, mrb_value v)
711
695
  }
712
696
 
713
697
  iv_put(mrb, c->iv, sym, v);
714
- mrb_write_barrier(mrb, (struct RBasic*)c);
698
+ mrb_field_write_barrier_value(mrb, (struct RBasic*)c, v);
715
699
  }
716
700
 
717
701
  MRB_API void
@@ -743,11 +727,11 @@ mrb_vm_cv_get(mrb_state *mrb, mrb_sym sym)
743
727
  {
744
728
  struct RClass *c;
745
729
 
746
- struct RProc *p = mrb->c->ci->proc;
730
+ const struct RProc *p = mrb->c->ci->proc;
747
731
 
748
732
  for (;;) {
749
733
  c = MRB_PROC_TARGET_CLASS(p);
750
- if (c->tt != MRB_TT_SCLASS) break;
734
+ if (c && c->tt != MRB_TT_SCLASS) break;
751
735
  p = p->upper;
752
736
  }
753
737
  return mrb_mod_cv_get(mrb, c, sym);
@@ -757,11 +741,11 @@ void
757
741
  mrb_vm_cv_set(mrb_state *mrb, mrb_sym sym, mrb_value v)
758
742
  {
759
743
  struct RClass *c;
760
- struct RProc *p = mrb->c->ci->proc;
744
+ const struct RProc *p = mrb->c->ci->proc;
761
745
 
762
746
  for (;;) {
763
747
  c = MRB_PROC_TARGET_CLASS(p);
764
- if (c->tt != MRB_TT_SCLASS) break;
748
+ if (c && c->tt != MRB_TT_SCLASS) break;
765
749
  p = p->upper;
766
750
  }
767
751
  mrb_mod_cv_set(mrb, c, sym, v);
@@ -803,7 +787,7 @@ L_RETRY:
803
787
  goto L_RETRY;
804
788
  }
805
789
  name = mrb_symbol_value(sym);
806
- return mrb_funcall_argv(mrb, mrb_obj_value(base), mrb_intern_lit(mrb, "const_missing"), 1, &name);
790
+ return mrb_funcall_argv(mrb, mrb_obj_value(base), MRB_SYM(const_missing), 1, &name);
807
791
  }
808
792
 
809
793
  MRB_API mrb_value
@@ -819,9 +803,10 @@ mrb_vm_const_get(mrb_state *mrb, mrb_sym sym)
819
803
  struct RClass *c;
820
804
  struct RClass *c2;
821
805
  mrb_value v;
822
- struct RProc *proc;
806
+ const struct RProc *proc;
823
807
 
824
808
  c = MRB_PROC_TARGET_CLASS(mrb->c->ci->proc);
809
+ if (!c) c = mrb->object_class;
825
810
  if (iv_get(mrb, c->iv, sym, &v)) {
826
811
  return v;
827
812
  }
@@ -829,7 +814,7 @@ mrb_vm_const_get(mrb_state *mrb, mrb_sym sym)
829
814
  while (c2 && c2->tt == MRB_TT_SCLASS) {
830
815
  mrb_value klass;
831
816
 
832
- if (!iv_get(mrb, c2->iv, mrb_intern_lit(mrb, "__attached__"), &klass)) {
817
+ if (!iv_get(mrb, c2->iv, MRB_SYM(__attached__), &klass)) {
833
818
  c2 = NULL;
834
819
  break;
835
820
  }
@@ -864,6 +849,7 @@ mrb_vm_const_set(mrb_state *mrb, mrb_sym sym, mrb_value v)
864
849
  struct RClass *c;
865
850
 
866
851
  c = MRB_PROC_TARGET_CLASS(mrb->c->ci->proc);
852
+ if (!c) c = mrb->object_class;
867
853
  mrb_obj_iv_set(mrb, (struct RObject*)c, sym, v);
868
854
  }
869
855
 
@@ -874,6 +860,12 @@ mrb_const_remove(mrb_state *mrb, mrb_value mod, mrb_sym sym)
874
860
  mrb_iv_remove(mrb, mod, sym);
875
861
  }
876
862
 
863
+ MRB_API void
864
+ mrb_define_const_id(mrb_state *mrb, struct RClass *mod, mrb_sym name, mrb_value v)
865
+ {
866
+ mrb_obj_iv_set(mrb, (struct RObject*)mod, name, v);
867
+ }
868
+
877
869
  MRB_API void
878
870
  mrb_define_const(mrb_state *mrb, struct RClass *mod, const char *name, mrb_value v)
879
871
  {
@@ -1070,7 +1062,7 @@ outer_class(mrb_state *mrb, struct RClass *c)
1070
1062
  {
1071
1063
  mrb_value ov;
1072
1064
 
1073
- ov = mrb_obj_iv_get(mrb, (struct RObject*)c, mrb_intern_lit(mrb, "__outer__"));
1065
+ ov = mrb_obj_iv_get(mrb, (struct RObject*)c, MRB_SYM(__outer__));
1074
1066
  if (mrb_nil_p(ov)) return NULL;
1075
1067
  switch (mrb_type(ov)) {
1076
1068
  case MRB_TT_CLASS:
@@ -1120,14 +1112,22 @@ mrb_class_find_path(mrb_state *mrb, struct RClass *c)
1120
1112
  str = mrb_sym_name_len(mrb, name, &len);
1121
1113
  mrb_str_cat(mrb, path, str, len);
1122
1114
  if (RSTRING_PTR(path)[0] != '#') {
1123
- iv_del(mrb, c->iv, mrb_intern_lit(mrb, "__outer__"), NULL);
1124
- iv_put(mrb, c->iv, mrb_intern_lit(mrb, "__classname__"), path);
1115
+ iv_del(mrb, c->iv, MRB_SYM(__outer__), NULL);
1116
+ iv_put(mrb, c->iv, MRB_SYM(__classname__), path);
1125
1117
  mrb_field_write_barrier_value(mrb, (struct RBasic*)c, path);
1126
1118
  path = mrb_str_dup(mrb, path);
1127
1119
  }
1128
1120
  return path;
1129
1121
  }
1130
1122
 
1123
+ size_t
1124
+ mrb_obj_iv_tbl_memsize(mrb_value obj)
1125
+ {
1126
+ iv_tbl *t = mrb_obj_ptr(obj)->iv;
1127
+ if (t == NULL) return 0;
1128
+ return sizeof(iv_tbl) + t->alloc*sizeof(struct iv_elem);
1129
+ }
1130
+
1131
1131
  #define identchar(c) (ISALNUM(c) || (c) == '_' || !ISASCII(c))
1132
1132
 
1133
1133
  mrb_bool