esruby 0.0.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.
Files changed (763) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +21 -0
  3. data/README.md +22 -0
  4. data/bin/esruby +34 -0
  5. data/lib/esruby.rb +26 -0
  6. data/lib/esruby/build.rb +140 -0
  7. data/lib/esruby/build/configuration.rb +77 -0
  8. data/lib/esruby/gem.rb +5 -0
  9. data/lib/esruby/gem/specification.rb +35 -0
  10. data/resources/build_config.eruby +53 -0
  11. data/resources/cpp/esruby.cpp +64 -0
  12. data/resources/cpp/esruby.hpp +42 -0
  13. data/resources/cpp/main.cpp +9 -0
  14. data/resources/js/esruby.js +45 -0
  15. data/resources/mruby/AUTHORS +40 -0
  16. data/resources/mruby/CONTRIBUTING.md +68 -0
  17. data/resources/mruby/LEGAL +6 -0
  18. data/resources/mruby/MITL +20 -0
  19. data/resources/mruby/Makefile +17 -0
  20. data/resources/mruby/NEWS +13 -0
  21. data/resources/mruby/README.md +92 -0
  22. data/resources/mruby/Rakefile +152 -0
  23. data/resources/mruby/TODO +10 -0
  24. data/resources/mruby/appveyor.yml +38 -0
  25. data/resources/mruby/appveyor_config.rb +50 -0
  26. data/resources/mruby/benchmark/bm_ao_render.rb +314 -0
  27. data/resources/mruby/benchmark/bm_app_lc_fizzbuzz.rb +52 -0
  28. data/resources/mruby/benchmark/bm_fib.rb +7 -0
  29. data/resources/mruby/benchmark/bm_so_lists.rb +47 -0
  30. data/resources/mruby/benchmark/build_config_boxing.rb +28 -0
  31. data/resources/mruby/benchmark/build_config_cc.rb +13 -0
  32. data/resources/mruby/benchmark/plot.gpl +5 -0
  33. data/resources/mruby/bin/mirb +0 -0
  34. data/resources/mruby/bin/mrbc +0 -0
  35. data/resources/mruby/bin/mruby +0 -0
  36. data/resources/mruby/bin/mruby-strip +0 -0
  37. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/README.md +82 -0
  38. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/mrbgem.rake +63 -0
  39. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/mrblib/regexp_pcre.rb +232 -0
  40. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/mrblib/string_pcre.rb +333 -0
  41. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/132html +313 -0
  42. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/AUTHORS +45 -0
  43. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/CMakeLists.txt +959 -0
  44. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/COPYING +5 -0
  45. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/ChangeLog +4981 -0
  46. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/CheckMan +67 -0
  47. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/CleanTxt +113 -0
  48. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/Detrail +35 -0
  49. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/HACKING +473 -0
  50. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/INSTALL +370 -0
  51. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/LICENCE +92 -0
  52. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/Makefile.am +877 -0
  53. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/Makefile.in +2917 -0
  54. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/NEWS +611 -0
  55. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/NON-AUTOTOOLS-BUILD +639 -0
  56. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/NON-UNIX-USE +7 -0
  57. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/PrepareRelease +253 -0
  58. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/README +935 -0
  59. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/RunGrepTest +551 -0
  60. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/RunTest +1015 -0
  61. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/RunTest.bat +616 -0
  62. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/aclocal.m4 +1230 -0
  63. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/autom4te.cache/output.0 +21280 -0
  64. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/autom4te.cache/output.1 +21280 -0
  65. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/autom4te.cache/requests +273 -0
  66. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/autom4te.cache/traces.0 +2421 -0
  67. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/autom4te.cache/traces.1 +1144 -0
  68. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/cmake/COPYING-CMAKE-SCRIPTS +22 -0
  69. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/cmake/FindEditline.cmake +17 -0
  70. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/cmake/FindPackageHandleStandardArgs.cmake +58 -0
  71. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/cmake/FindReadline.cmake +29 -0
  72. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/compile +343 -0
  73. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/config-cmake.h.in +54 -0
  74. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/config.guess +1552 -0
  75. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/config.h +392 -0
  76. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/config.h.generic +392 -0
  77. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/config.h.in +343 -0
  78. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/config.sub +1804 -0
  79. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/configure +21280 -0
  80. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/configure.ac +1082 -0
  81. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/depcomp +708 -0
  82. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/dftables.c +212 -0
  83. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/index.html +180 -0
  84. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre-config.html +109 -0
  85. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre.html +204 -0
  86. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre16.html +383 -0
  87. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_assign_jit_stack.html +76 -0
  88. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_compile.html +108 -0
  89. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_compile2.html +112 -0
  90. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_config.html +91 -0
  91. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_copy_named_substring.html +65 -0
  92. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_copy_substring.html +61 -0
  93. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_dfa_exec.html +128 -0
  94. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_exec.html +110 -0
  95. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_free_study.html +46 -0
  96. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_free_substring.html +46 -0
  97. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_free_substring_list.html +46 -0
  98. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_fullinfo.html +108 -0
  99. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_get_named_substring.html +68 -0
  100. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_get_stringnumber.html +57 -0
  101. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_get_stringtable_entries.html +60 -0
  102. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_get_substring.html +64 -0
  103. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_get_substring_list.html +61 -0
  104. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_jit_exec.html +108 -0
  105. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_jit_stack_alloc.html +55 -0
  106. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_jit_stack_free.html +48 -0
  107. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_maketables.html +48 -0
  108. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_pattern_to_host_byte_order.html +58 -0
  109. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_refcount.html +51 -0
  110. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_study.html +68 -0
  111. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_utf16_to_host_byte_order.html +57 -0
  112. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcre_version.html +46 -0
  113. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcreapi.html +2786 -0
  114. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrebuild.html +517 -0
  115. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrecallout.html +243 -0
  116. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrecompat.html +216 -0
  117. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrecpp.html +368 -0
  118. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcredemo.html +426 -0
  119. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcregrep.html +757 -0
  120. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrejit.html +458 -0
  121. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrelimits.html +86 -0
  122. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrematching.html +233 -0
  123. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrepartial.html +474 -0
  124. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrepattern.html +2953 -0
  125. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcreperform.html +195 -0
  126. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcreposix.html +292 -0
  127. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcreprecompile.html +158 -0
  128. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcresample.html +110 -0
  129. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcrestack.html +225 -0
  130. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcresyntax.html +521 -0
  131. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcretest.html +1082 -0
  132. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/html/pcreunicode.html +270 -0
  133. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/index.html.src +180 -0
  134. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre-config.1 +92 -0
  135. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre-config.txt +86 -0
  136. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre.3 +202 -0
  137. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre.txt +9909 -0
  138. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre16.3 +390 -0
  139. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre32.3 +389 -0
  140. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_assign_jit_stack.3 +61 -0
  141. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_compile.3 +98 -0
  142. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_compile2.3 +106 -0
  143. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_config.3 +76 -0
  144. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_copy_named_substring.3 +59 -0
  145. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_copy_substring.3 +52 -0
  146. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_dfa_exec.3 +125 -0
  147. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_exec.3 +103 -0
  148. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_free_study.3 +31 -0
  149. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_free_substring.3 +31 -0
  150. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_free_substring_list.3 +31 -0
  151. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_fullinfo.3 +95 -0
  152. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_get_named_substring.3 +62 -0
  153. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_get_stringnumber.3 +45 -0
  154. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_get_stringtable_entries.3 +48 -0
  155. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_get_substring.3 +55 -0
  156. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_get_substring_list.3 +49 -0
  157. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_jit_exec.3 +104 -0
  158. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_jit_stack_alloc.3 +45 -0
  159. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_jit_stack_free.3 +35 -0
  160. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_maketables.3 +33 -0
  161. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_pattern_to_host_byte_order.3 +46 -0
  162. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_refcount.3 +36 -0
  163. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_study.3 +56 -0
  164. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_utf16_to_host_byte_order.3 +46 -0
  165. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_utf32_to_host_byte_order.3 +46 -0
  166. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcre_version.3 +31 -0
  167. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcreapi.3 +2823 -0
  168. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrebuild.3 +520 -0
  169. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrecallout.3 +214 -0
  170. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrecompat.3 +185 -0
  171. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrecpp.3 +348 -0
  172. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcregrep.1 +679 -0
  173. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcregrep.txt +740 -0
  174. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrejit.3 +437 -0
  175. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrelimits.3 +67 -0
  176. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrematching.3 +206 -0
  177. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrepartial.3 +445 -0
  178. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrepattern.3 +2983 -0
  179. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcreperform.3 +177 -0
  180. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcreposix.3 +270 -0
  181. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcreprecompile.3 +151 -0
  182. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcresample.3 +99 -0
  183. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcrestack.3 +215 -0
  184. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcresyntax.3 +496 -0
  185. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcretest.1 +1079 -0
  186. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcretest.txt +1012 -0
  187. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/pcreunicode.3 +255 -0
  188. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/doc/perltest.txt +42 -0
  189. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/install-sh +527 -0
  190. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/libpcre.pc.in +12 -0
  191. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/libpcre16.pc.in +12 -0
  192. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/libpcre32.pc.in +12 -0
  193. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/libpcrecpp.pc.in +12 -0
  194. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/libpcreposix.pc.in +13 -0
  195. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/ltmain.sh +9636 -0
  196. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/m4/ax_pthread.m4 +309 -0
  197. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/m4/libtool.m4 +7844 -0
  198. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/m4/ltoptions.m4 +369 -0
  199. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/m4/ltsugar.m4 +123 -0
  200. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/m4/ltversion.m4 +23 -0
  201. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/m4/lt~obsolete.m4 +98 -0
  202. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/m4/pcre_visibility.m4 +89 -0
  203. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/makevp.bat +66 -0
  204. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/makevp_c.txt +20 -0
  205. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/makevp_l.txt +20 -0
  206. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/missing +331 -0
  207. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre-config.in +133 -0
  208. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre.h +653 -0
  209. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre.h.generic +653 -0
  210. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre.h.in +653 -0
  211. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_byte_order.c +45 -0
  212. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_chartables.c +45 -0
  213. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_compile.c +45 -0
  214. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_config.c +45 -0
  215. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_dfa_exec.c +45 -0
  216. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_exec.c +45 -0
  217. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_fullinfo.c +45 -0
  218. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_get.c +45 -0
  219. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_globals.c +45 -0
  220. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_jit_compile.c +45 -0
  221. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_maketables.c +45 -0
  222. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_newline.c +45 -0
  223. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_ord2utf16.c +90 -0
  224. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_printint.c +45 -0
  225. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_refcount.c +45 -0
  226. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_string_utils.c +45 -0
  227. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_study.c +45 -0
  228. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_tables.c +45 -0
  229. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_ucd.c +45 -0
  230. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_utf16_utils.c +130 -0
  231. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_valid_utf16.c +156 -0
  232. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_version.c +45 -0
  233. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre16_xclass.c +45 -0
  234. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_byte_order.c +45 -0
  235. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_chartables.c +45 -0
  236. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_compile.c +45 -0
  237. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_config.c +45 -0
  238. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_dfa_exec.c +45 -0
  239. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_exec.c +45 -0
  240. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_fullinfo.c +45 -0
  241. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_get.c +45 -0
  242. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_globals.c +45 -0
  243. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_jit_compile.c +45 -0
  244. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_maketables.c +45 -0
  245. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_newline.c +45 -0
  246. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_ord2utf32.c +82 -0
  247. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_printint.c +45 -0
  248. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_refcount.c +45 -0
  249. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_string_utils.c +45 -0
  250. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_study.c +45 -0
  251. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_tables.c +45 -0
  252. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_ucd.c +45 -0
  253. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_utf32_utils.c +141 -0
  254. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_valid_utf32.c +131 -0
  255. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_version.c +45 -0
  256. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre32_xclass.c +45 -0
  257. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_byte_order.c +318 -0
  258. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_chartables.c +198 -0
  259. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_chartables.c.dist +198 -0
  260. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_compile.c +8386 -0
  261. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_config.c +186 -0
  262. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_dfa_exec.c +3582 -0
  263. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_exec.c +7049 -0
  264. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_fullinfo.c +231 -0
  265. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_get.c +662 -0
  266. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_globals.c +84 -0
  267. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_internal.h +2744 -0
  268. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_jit_compile.c +8560 -0
  269. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_jit_test.c +1614 -0
  270. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_maketables.c +151 -0
  271. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_newline.c +210 -0
  272. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_ord2utf8.c +94 -0
  273. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_printint.c +766 -0
  274. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_refcount.c +92 -0
  275. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_scanner.cc +199 -0
  276. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_scanner.h +172 -0
  277. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_scanner_unittest.cc +159 -0
  278. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_string_utils.c +211 -0
  279. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_stringpiece.cc +43 -0
  280. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_stringpiece.h.in +179 -0
  281. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_stringpiece_unittest.cc +150 -0
  282. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_study.c +1562 -0
  283. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_tables.c +655 -0
  284. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_ucd.c +3298 -0
  285. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_valid_utf8.c +312 -0
  286. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_version.c +98 -0
  287. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcre_xclass.c +198 -0
  288. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcrecpp.cc +922 -0
  289. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcrecpp.h +710 -0
  290. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcrecpp_internal.h +71 -0
  291. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcrecpp_unittest.cc +1291 -0
  292. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcrecpparg.h.in +174 -0
  293. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcredemo.c +406 -0
  294. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcregexp.pas +845 -0
  295. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcregrep.c +3180 -0
  296. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcreposix.c +419 -0
  297. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcreposix.h +146 -0
  298. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/pcretest.c +5488 -0
  299. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/perltest.pl +237 -0
  300. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitConfig.h +110 -0
  301. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitConfigInternal.h +484 -0
  302. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitExecAllocator.c +289 -0
  303. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitLir.c +1766 -0
  304. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitLir.h +985 -0
  305. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativeARM_Thumb2.c +2008 -0
  306. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativeARM_v5.c +2515 -0
  307. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativeMIPS_32.c +404 -0
  308. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativeMIPS_common.c +1881 -0
  309. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativePPC_32.c +269 -0
  310. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativePPC_64.c +421 -0
  311. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativePPC_common.c +2014 -0
  312. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativeSPARC_32.c +164 -0
  313. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativeSPARC_common.c +1348 -0
  314. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativeX86_32.c +547 -0
  315. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativeX86_64.c +810 -0
  316. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitNativeX86_common.c +2836 -0
  317. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/sljit/sljitUtils.c +332 -0
  318. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepbinary +0 -0
  319. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepfilelist +3 -0
  320. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepinput +611 -0
  321. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepinput3 +15 -0
  322. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepinput8 +11 -0
  323. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepinputv +4 -0
  324. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepinputx +43 -0
  325. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/greplist +7 -0
  326. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepoutput +707 -0
  327. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepoutput8 +12 -0
  328. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/grepoutputN +16 -1
  329. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/greppatN4 +2 -0
  330. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved16 +0 -0
  331. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved16BE-1 +0 -0
  332. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved16BE-2 +0 -0
  333. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved16LE-1 +0 -0
  334. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved16LE-2 +0 -0
  335. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved32 +0 -0
  336. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved32BE-1 +0 -0
  337. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved32BE-2 +0 -0
  338. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved32LE-1 +0 -0
  339. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved32LE-2 +0 -0
  340. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/saved8 +0 -0
  341. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput1 +5306 -0
  342. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput10 +1337 -0
  343. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput11 +135 -0
  344. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput12 +89 -0
  345. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput13 +9 -0
  346. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput14 +329 -0
  347. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput15 +430 -0
  348. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput16 +35 -0
  349. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput17 +296 -0
  350. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput18 +296 -0
  351. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput19 +22 -0
  352. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput2 +3813 -0
  353. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput20 +19 -0
  354. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput21 +16 -0
  355. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput22 +13 -0
  356. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput23 +16 -0
  357. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput24 +77 -0
  358. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput25 +32 -0
  359. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput26 +80 -0
  360. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput3 +95 -0
  361. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput4 +624 -0
  362. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput5 +772 -0
  363. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput6 +1319 -0
  364. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput7 +672 -0
  365. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput8 +4801 -0
  366. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinput9 +717 -0
  367. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testinputEBC +121 -0
  368. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput1 +8798 -0
  369. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput10 +2726 -0
  370. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput11-16 +713 -0
  371. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput11-32 +713 -0
  372. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput11-8 +713 -0
  373. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput12 +181 -0
  374. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput13 +21 -0
  375. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput14 +476 -0
  376. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput15 +1269 -0
  377. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput16 +121 -0
  378. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput17 +505 -0
  379. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput18-16 +1022 -0
  380. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput18-32 +1019 -0
  381. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput19 +88 -0
  382. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput2 +12484 -0
  383. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput20 +27 -0
  384. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput21-16 +90 -0
  385. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput21-32 +90 -0
  386. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput22-16 +71 -0
  387. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput22-32 +71 -0
  388. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput23 +42 -0
  389. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput24 +145 -0
  390. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput25 +79 -0
  391. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput26 +148 -0
  392. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput3 +169 -0
  393. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput4 +1094 -0
  394. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput5 +1849 -0
  395. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput6 +2137 -0
  396. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput7 +1473 -0
  397. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput8 +8019 -0
  398. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutput9 +1371 -0
  399. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/testoutputEBC +182 -0
  400. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/wintestinput3 +91 -0
  401. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/testdata/wintestoutput3 +166 -0
  402. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/pcre/ucp.h +197 -0
  403. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/run_test.rb +23 -0
  404. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/src/mruby_regexp_pcre.c +364 -0
  405. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/test/matchdata.rb +94 -0
  406. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/test/regexp.rb +264 -0
  407. data/resources/mruby/build/mrbgems/mruby-regexp-pcre/test/string.rb +201 -0
  408. data/resources/mruby/build_config.rb +152 -0
  409. data/resources/mruby/doc/guides/compile.md +488 -0
  410. data/resources/mruby/doc/guides/debugger.md +370 -0
  411. data/resources/mruby/doc/guides/gc-arena-howto.md +177 -0
  412. data/resources/mruby/doc/guides/mrbconf.md +146 -0
  413. data/resources/mruby/doc/guides/mrbgems.md +340 -0
  414. data/resources/mruby/doc/limitations.md +187 -0
  415. data/resources/mruby/examples/mrbgems/c_and_ruby_extension_example/README.md +4 -0
  416. data/resources/mruby/examples/mrbgems/c_and_ruby_extension_example/mrbgem.rake +23 -0
  417. data/resources/mruby/examples/mrbgems/c_and_ruby_extension_example/mrblib/example.rb +5 -0
  418. data/resources/mruby/examples/mrbgems/c_and_ruby_extension_example/src/example.c +20 -0
  419. data/resources/mruby/examples/mrbgems/c_and_ruby_extension_example/test/example.rb +7 -0
  420. data/resources/mruby/examples/mrbgems/c_extension_example/README.md +4 -0
  421. data/resources/mruby/examples/mrbgems/c_extension_example/mrbgem.rake +23 -0
  422. data/resources/mruby/examples/mrbgems/c_extension_example/src/example.c +20 -0
  423. data/resources/mruby/examples/mrbgems/c_extension_example/test/example.c +7 -0
  424. data/resources/mruby/examples/mrbgems/c_extension_example/test/example.rb +3 -0
  425. data/resources/mruby/examples/mrbgems/ruby_extension_example/README.md +4 -0
  426. data/resources/mruby/examples/mrbgems/ruby_extension_example/mrbgem.rake +25 -0
  427. data/resources/mruby/examples/mrbgems/ruby_extension_example/mrblib/example.rb +5 -0
  428. data/resources/mruby/examples/mrbgems/ruby_extension_example/test/example.rb +3 -0
  429. data/resources/mruby/examples/targets/build_config_ArduinoDue.rb +90 -0
  430. data/resources/mruby/examples/targets/build_config_IntelEdison.rb +69 -0
  431. data/resources/mruby/examples/targets/build_config_IntelGalileo.rb +106 -0
  432. data/resources/mruby/examples/targets/build_config_RX630.rb +81 -0
  433. data/resources/mruby/examples/targets/build_config_android_arm64-v8a.rb +26 -0
  434. data/resources/mruby/examples/targets/build_config_android_armeabi.rb +26 -0
  435. data/resources/mruby/examples/targets/build_config_android_armeabi_v7a_neon_hard.rb +28 -0
  436. data/resources/mruby/examples/targets/build_config_chipKITMax32.rb +86 -0
  437. data/resources/mruby/include/mrbconf.h +145 -0
  438. data/resources/mruby/include/mruby.h +1280 -0
  439. data/resources/mruby/include/mruby/array.h +279 -0
  440. data/resources/mruby/include/mruby/boxing_nan.h +102 -0
  441. data/resources/mruby/include/mruby/boxing_no.h +56 -0
  442. data/resources/mruby/include/mruby/boxing_word.h +136 -0
  443. data/resources/mruby/include/mruby/class.h +94 -0
  444. data/resources/mruby/include/mruby/common.h +72 -0
  445. data/resources/mruby/include/mruby/compile.h +194 -0
  446. data/resources/mruby/include/mruby/data.h +75 -0
  447. data/resources/mruby/include/mruby/debug.h +66 -0
  448. data/resources/mruby/include/mruby/dump.h +196 -0
  449. data/resources/mruby/include/mruby/error.h +75 -0
  450. data/resources/mruby/include/mruby/gc.h +91 -0
  451. data/resources/mruby/include/mruby/hash.h +182 -0
  452. data/resources/mruby/include/mruby/irep.h +62 -0
  453. data/resources/mruby/include/mruby/istruct.h +47 -0
  454. data/resources/mruby/include/mruby/khash.h +274 -0
  455. data/resources/mruby/include/mruby/numeric.h +161 -0
  456. data/resources/mruby/include/mruby/object.h +45 -0
  457. data/resources/mruby/include/mruby/opcode.h +161 -0
  458. data/resources/mruby/include/mruby/proc.h +131 -0
  459. data/resources/mruby/include/mruby/range.h +49 -0
  460. data/resources/mruby/include/mruby/re.h +16 -0
  461. data/resources/mruby/include/mruby/string.h +440 -0
  462. data/resources/mruby/include/mruby/throw.h +55 -0
  463. data/resources/mruby/include/mruby/value.h +309 -0
  464. data/resources/mruby/include/mruby/variable.h +138 -0
  465. data/resources/mruby/include/mruby/version.h +110 -0
  466. data/resources/mruby/lib/mruby-core-ext.rb +79 -0
  467. data/resources/mruby/lib/mruby/build.rb +355 -0
  468. data/resources/mruby/lib/mruby/build/command.rb +324 -0
  469. data/resources/mruby/lib/mruby/build/load_gems.rb +122 -0
  470. data/resources/mruby/lib/mruby/gem.rb +459 -0
  471. data/resources/mruby/lib/mruby/source.rb +30 -0
  472. data/resources/mruby/minirake +484 -0
  473. data/resources/mruby/mrbgems/default.gembox +82 -0
  474. data/resources/mruby/mrbgems/full-core.gembox +9 -0
  475. data/resources/mruby/mrbgems/mruby-array-ext/mrbgem.rake +6 -0
  476. data/resources/mruby/mrbgems/mruby-array-ext/mrblib/array.rb +935 -0
  477. data/resources/mruby/mrbgems/mruby-array-ext/src/array.c +246 -0
  478. data/resources/mruby/mrbgems/mruby-array-ext/test/array.rb +422 -0
  479. data/resources/mruby/mrbgems/mruby-bin-debugger/bintest/mrdb.rb +286 -0
  480. data/resources/mruby/mrbgems/mruby-bin-debugger/bintest/print.rb +701 -0
  481. data/resources/mruby/mrbgems/mruby-bin-debugger/mrbgem.rake +9 -0
  482. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apibreak.c +505 -0
  483. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apibreak.h +26 -0
  484. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apilist.c +240 -0
  485. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apilist.h +14 -0
  486. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apiprint.c +78 -0
  487. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/apiprint.h +13 -0
  488. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/cmdbreak.c +436 -0
  489. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/cmdmisc.c +502 -0
  490. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/cmdprint.c +58 -0
  491. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/cmdrun.c +64 -0
  492. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdb.c +759 -0
  493. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdb.h +165 -0
  494. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdbconf.h +16 -0
  495. data/resources/mruby/mrbgems/mruby-bin-debugger/tools/mrdb/mrdberror.h +20 -0
  496. data/resources/mruby/mrbgems/mruby-bin-mirb/bintest/mirb.rb +12 -0
  497. data/resources/mruby/mrbgems/mruby-bin-mirb/mrbgem.rake +33 -0
  498. data/resources/mruby/mrbgems/mruby-bin-mirb/tools/mirb/mirb.c +611 -0
  499. data/resources/mruby/mrbgems/mruby-bin-mrbc/mrbgem.rake +16 -0
  500. data/resources/mruby/mrbgems/mruby-bin-mrbc/tools/mrbc/mrbc.c +336 -0
  501. data/resources/mruby/mrbgems/mruby-bin-mruby-config/mrbgem.rake +30 -0
  502. data/resources/mruby/mrbgems/mruby-bin-mruby-config/mruby-config +20 -0
  503. data/resources/mruby/mrbgems/mruby-bin-mruby-config/mruby-config.bat +42 -0
  504. data/resources/mruby/mrbgems/mruby-bin-mruby/bintest/mruby.rb +60 -0
  505. data/resources/mruby/mrbgems/mruby-bin-mruby/mrbgem.rake +12 -0
  506. data/resources/mruby/mrbgems/mruby-bin-mruby/tools/mruby/mruby.c +254 -0
  507. data/resources/mruby/mrbgems/mruby-bin-strip/bintest/mruby-strip.rb +73 -0
  508. data/resources/mruby/mrbgems/mruby-bin-strip/mrbgem.rake +6 -0
  509. data/resources/mruby/mrbgems/mruby-bin-strip/tools/mruby-strip/mruby-strip.c +155 -0
  510. data/resources/mruby/mrbgems/mruby-class-ext/mrbgem.rake +5 -0
  511. data/resources/mruby/mrbgems/mruby-class-ext/src/class.c +68 -0
  512. data/resources/mruby/mrbgems/mruby-class-ext/test/module.rb +55 -0
  513. data/resources/mruby/mrbgems/mruby-compar-ext/mrbgem.rake +5 -0
  514. data/resources/mruby/mrbgems/mruby-compar-ext/mrblib/compar.rb +31 -0
  515. data/resources/mruby/mrbgems/mruby-compiler/bintest/mrbc.rb +30 -0
  516. data/resources/mruby/mrbgems/mruby-compiler/core/codegen.c +3083 -0
  517. data/resources/mruby/mrbgems/mruby-compiler/core/keywords +50 -0
  518. data/resources/mruby/mrbgems/mruby-compiler/core/lex.def +211 -0
  519. data/resources/mruby/mrbgems/mruby-compiler/core/node.h +118 -0
  520. data/resources/mruby/mrbgems/mruby-compiler/core/parse.y +6661 -0
  521. data/resources/mruby/mrbgems/mruby-compiler/mrbgem.rake +40 -0
  522. data/resources/mruby/mrbgems/mruby-enum-ext/mrbgem.rake +5 -0
  523. data/resources/mruby/mrbgems/mruby-enum-ext/mrblib/enum.rb +813 -0
  524. data/resources/mruby/mrbgems/mruby-enum-ext/test/enum.rb +185 -0
  525. data/resources/mruby/mrbgems/mruby-enum-lazy/mrbgem.rake +7 -0
  526. data/resources/mruby/mrbgems/mruby-enum-lazy/mrblib/lazy.rb +178 -0
  527. data/resources/mruby/mrbgems/mruby-enum-lazy/test/lazy.rb +53 -0
  528. data/resources/mruby/mrbgems/mruby-enumerator/mrbgem.rake +7 -0
  529. data/resources/mruby/mrbgems/mruby-enumerator/mrblib/enumerator.rb +645 -0
  530. data/resources/mruby/mrbgems/mruby-enumerator/test/enumerator.rb +546 -0
  531. data/resources/mruby/mrbgems/mruby-error/mrbgem.rake +10 -0
  532. data/resources/mruby/mrbgems/mruby-error/src/exception.c +100 -0
  533. data/resources/mruby/mrbgems/mruby-error/test/exception.c +59 -0
  534. data/resources/mruby/mrbgems/mruby-error/test/exception.rb +55 -0
  535. data/resources/mruby/mrbgems/mruby-eval/mrbgem.rake +7 -0
  536. data/resources/mruby/mrbgems/mruby-eval/src/eval.c +346 -0
  537. data/resources/mruby/mrbgems/mruby-eval/test/eval.rb +101 -0
  538. data/resources/mruby/mrbgems/mruby-exit/mrbgem.rake +5 -0
  539. data/resources/mruby/mrbgems/mruby-exit/src/mruby-exit.c +24 -0
  540. data/resources/mruby/mrbgems/mruby-fiber/mrbgem.rake +5 -0
  541. data/resources/mruby/mrbgems/mruby-fiber/src/fiber.c +420 -0
  542. data/resources/mruby/mrbgems/mruby-fiber/test/fiber.rb +208 -0
  543. data/resources/mruby/mrbgems/mruby-hash-ext/mrbgem.rake +8 -0
  544. data/resources/mruby/mrbgems/mruby-hash-ext/mrblib/hash.rb +502 -0
  545. data/resources/mruby/mrbgems/mruby-hash-ext/src/hash-ext.c +128 -0
  546. data/resources/mruby/mrbgems/mruby-hash-ext/test/hash.rb +300 -0
  547. data/resources/mruby/mrbgems/mruby-inline-struct/mrbgem.rake +5 -0
  548. data/resources/mruby/mrbgems/mruby-inline-struct/test/inline.c +83 -0
  549. data/resources/mruby/mrbgems/mruby-inline-struct/test/inline.rb +151 -0
  550. data/resources/mruby/mrbgems/mruby-io/README.md +193 -0
  551. data/resources/mruby/mrbgems/mruby-io/include/mruby/ext/io.h +38 -0
  552. data/resources/mruby/mrbgems/mruby-io/mrbgem.rake +17 -0
  553. data/resources/mruby/mrbgems/mruby-io/mrblib/file.rb +208 -0
  554. data/resources/mruby/mrbgems/mruby-io/mrblib/file_constants.rb +29 -0
  555. data/resources/mruby/mrbgems/mruby-io/mrblib/io.rb +387 -0
  556. data/resources/mruby/mrbgems/mruby-io/mrblib/kernel.rb +15 -0
  557. data/resources/mruby/mrbgems/mruby-io/run_test.rb +26 -0
  558. data/resources/mruby/mrbgems/mruby-io/src/file.c +489 -0
  559. data/resources/mruby/mrbgems/mruby-io/src/file_test.c +381 -0
  560. data/resources/mruby/mrbgems/mruby-io/src/io.c +1320 -0
  561. data/resources/mruby/mrbgems/mruby-io/src/mruby_io_gem.c +20 -0
  562. data/resources/mruby/mrbgems/mruby-io/test/file.rb +197 -0
  563. data/resources/mruby/mrbgems/mruby-io/test/file_test.rb +117 -0
  564. data/resources/mruby/mrbgems/mruby-io/test/gc_filedes.sh +4 -0
  565. data/resources/mruby/mrbgems/mruby-io/test/io.rb +642 -0
  566. data/resources/mruby/mrbgems/mruby-io/test/mruby_io_test.c +256 -0
  567. data/resources/mruby/mrbgems/mruby-kernel-ext/mrbgem.rake +5 -0
  568. data/resources/mruby/mrbgems/mruby-kernel-ext/mrblib/kernel.rb +13 -0
  569. data/resources/mruby/mrbgems/mruby-kernel-ext/src/kernel.c +264 -0
  570. data/resources/mruby/mrbgems/mruby-kernel-ext/test/kernel.rb +86 -0
  571. data/resources/mruby/mrbgems/mruby-math/mrbgem.rake +5 -0
  572. data/resources/mruby/mrbgems/mruby-math/src/math.c +783 -0
  573. data/resources/mruby/mrbgems/mruby-math/test/math.rb +152 -0
  574. data/resources/mruby/mrbgems/mruby-method/README.md +59 -0
  575. data/resources/mruby/mrbgems/mruby-method/mrbgem.rake +7 -0
  576. data/resources/mruby/mrbgems/mruby-method/mrblib/kernel.rb +9 -0
  577. data/resources/mruby/mrbgems/mruby-method/mrblib/method.rb +20 -0
  578. data/resources/mruby/mrbgems/mruby-method/mrblib/unbound_method.rb +9 -0
  579. data/resources/mruby/mrbgems/mruby-method/src/method.c +418 -0
  580. data/resources/mruby/mrbgems/mruby-method/test/method.rb +425 -0
  581. data/resources/mruby/mrbgems/mruby-numeric-ext/mrbgem.rake +5 -0
  582. data/resources/mruby/mrbgems/mruby-numeric-ext/mrblib/numeric_ext.rb +25 -0
  583. data/resources/mruby/mrbgems/mruby-numeric-ext/src/numeric_ext.c +102 -0
  584. data/resources/mruby/mrbgems/mruby-numeric-ext/test/numeric.rb +28 -0
  585. data/resources/mruby/mrbgems/mruby-object-ext/mrbgem.rake +5 -0
  586. data/resources/mruby/mrbgems/mruby-object-ext/mrblib/object.rb +19 -0
  587. data/resources/mruby/mrbgems/mruby-object-ext/src/object.c +112 -0
  588. data/resources/mruby/mrbgems/mruby-object-ext/test/nil.rb +11 -0
  589. data/resources/mruby/mrbgems/mruby-object-ext/test/object.rb +53 -0
  590. data/resources/mruby/mrbgems/mruby-objectspace/mrbgem.rake +5 -0
  591. data/resources/mruby/mrbgems/mruby-objectspace/src/mruby_objectspace.c +187 -0
  592. data/resources/mruby/mrbgems/mruby-objectspace/test/objectspace.rb +60 -0
  593. data/resources/mruby/mrbgems/mruby-pack/README.md +70 -0
  594. data/resources/mruby/mrbgems/mruby-pack/mrbgem.rake +7 -0
  595. data/resources/mruby/mrbgems/mruby-pack/packtest.rb +157 -0
  596. data/resources/mruby/mrbgems/mruby-pack/run_test.rb +26 -0
  597. data/resources/mruby/mrbgems/mruby-pack/src/pack.c +1281 -0
  598. data/resources/mruby/mrbgems/mruby-pack/test/pack.rb +165 -0
  599. data/resources/mruby/mrbgems/mruby-print/mrbgem.rake +5 -0
  600. data/resources/mruby/mrbgems/mruby-print/mrblib/print.rb +64 -0
  601. data/resources/mruby/mrbgems/mruby-print/src/print.c +64 -0
  602. data/resources/mruby/mrbgems/mruby-proc-ext/mrbgem.rake +5 -0
  603. data/resources/mruby/mrbgems/mruby-proc-ext/mrblib/proc.rb +42 -0
  604. data/resources/mruby/mrbgems/mruby-proc-ext/src/proc.c +173 -0
  605. data/resources/mruby/mrbgems/mruby-proc-ext/test/proc.c +62 -0
  606. data/resources/mruby/mrbgems/mruby-proc-ext/test/proc.rb +96 -0
  607. data/resources/mruby/mrbgems/mruby-random/mrbgem.rake +5 -0
  608. data/resources/mruby/mrbgems/mruby-random/src/mt19937ar.c +224 -0
  609. data/resources/mruby/mrbgems/mruby-random/src/mt19937ar.h +80 -0
  610. data/resources/mruby/mrbgems/mruby-random/src/random.c +349 -0
  611. data/resources/mruby/mrbgems/mruby-random/src/random.h +12 -0
  612. data/resources/mruby/mrbgems/mruby-random/test/random.rb +88 -0
  613. data/resources/mruby/mrbgems/mruby-range-ext/mrbgem.rake +5 -0
  614. data/resources/mruby/mrbgems/mruby-range-ext/mrblib/range.rb +31 -0
  615. data/resources/mruby/mrbgems/mruby-range-ext/src/range.c +176 -0
  616. data/resources/mruby/mrbgems/mruby-range-ext/test/range.rb +32 -0
  617. data/resources/mruby/mrbgems/mruby-socket/README.md +55 -0
  618. data/resources/mruby/mrbgems/mruby-socket/mrbgem.rake +17 -0
  619. data/resources/mruby/mrbgems/mruby-socket/mrblib/socket.rb +621 -0
  620. data/resources/mruby/mrbgems/mruby-socket/run_test.rb +28 -0
  621. data/resources/mruby/mrbgems/mruby-socket/src/const.cstub +453 -0
  622. data/resources/mruby/mrbgems/mruby-socket/src/const.def +163 -0
  623. data/resources/mruby/mrbgems/mruby-socket/src/gen.rb +17 -0
  624. data/resources/mruby/mrbgems/mruby-socket/src/socket.c +928 -0
  625. data/resources/mruby/mrbgems/mruby-socket/test/addrinfo.rb +91 -0
  626. data/resources/mruby/mrbgems/mruby-socket/test/basicsocket.rb +17 -0
  627. data/resources/mruby/mrbgems/mruby-socket/test/ipsocket.rb +44 -0
  628. data/resources/mruby/mrbgems/mruby-socket/test/socket.rb +38 -0
  629. data/resources/mruby/mrbgems/mruby-socket/test/sockettest.c +46 -0
  630. data/resources/mruby/mrbgems/mruby-socket/test/tcpsocket.rb +4 -0
  631. data/resources/mruby/mrbgems/mruby-socket/test/udpsocket.rb +16 -0
  632. data/resources/mruby/mrbgems/mruby-socket/test/unix.rb +130 -0
  633. data/resources/mruby/mrbgems/mruby-sprintf/mrbgem.rake +5 -0
  634. data/resources/mruby/mrbgems/mruby-sprintf/mrblib/string.rb +9 -0
  635. data/resources/mruby/mrbgems/mruby-sprintf/src/kernel.c +30 -0
  636. data/resources/mruby/mrbgems/mruby-sprintf/src/sprintf.c +1126 -0
  637. data/resources/mruby/mrbgems/mruby-sprintf/test/sprintf.rb +110 -0
  638. data/resources/mruby/mrbgems/mruby-string-ext/mrbgem.rake +6 -0
  639. data/resources/mruby/mrbgems/mruby-string-ext/mrblib/string.rb +368 -0
  640. data/resources/mruby/mrbgems/mruby-string-ext/src/string.c +804 -0
  641. data/resources/mruby/mrbgems/mruby-string-ext/test/string.rb +682 -0
  642. data/resources/mruby/mrbgems/mruby-struct/mrbgem.rake +5 -0
  643. data/resources/mruby/mrbgems/mruby-struct/mrblib/struct.rb +103 -0
  644. data/resources/mruby/mrbgems/mruby-struct/src/struct.c +726 -0
  645. data/resources/mruby/mrbgems/mruby-struct/test/struct.rb +205 -0
  646. data/resources/mruby/mrbgems/mruby-symbol-ext/mrbgem.rake +5 -0
  647. data/resources/mruby/mrbgems/mruby-symbol-ext/mrblib/symbol.rb +78 -0
  648. data/resources/mruby/mrbgems/mruby-symbol-ext/src/symbol.c +64 -0
  649. data/resources/mruby/mrbgems/mruby-symbol-ext/test/symbol.rb +48 -0
  650. data/resources/mruby/mrbgems/mruby-test/README.md +7 -0
  651. data/resources/mruby/mrbgems/mruby-test/driver.c +175 -0
  652. data/resources/mruby/mrbgems/mruby-test/init_mrbtest.c +38 -0
  653. data/resources/mruby/mrbgems/mruby-test/mrbgem.rake +191 -0
  654. data/resources/mruby/mrbgems/mruby-time/mrbgem.rake +5 -0
  655. data/resources/mruby/mrbgems/mruby-time/mrblib/time.rb +9 -0
  656. data/resources/mruby/mrbgems/mruby-time/src/time.c +869 -0
  657. data/resources/mruby/mrbgems/mruby-time/test/time.rb +228 -0
  658. data/resources/mruby/mrbgems/mruby-toplevel-ext/mrbgem.rake +5 -0
  659. data/resources/mruby/mrbgems/mruby-toplevel-ext/mrblib/toplevel.rb +11 -0
  660. data/resources/mruby/mrbgems/mruby-toplevel-ext/test/toplevel.rb +24 -0
  661. data/resources/mruby/mrblib/00class.rb +29 -0
  662. data/resources/mruby/mrblib/10error.rb +59 -0
  663. data/resources/mruby/mrblib/array.rb +243 -0
  664. data/resources/mruby/mrblib/compar.rb +84 -0
  665. data/resources/mruby/mrblib/enum.rb +348 -0
  666. data/resources/mruby/mrblib/float.rb +9 -0
  667. data/resources/mruby/mrblib/hash.rb +358 -0
  668. data/resources/mruby/mrblib/init_mrblib.c +11 -0
  669. data/resources/mruby/mrblib/kernel.rb +50 -0
  670. data/resources/mruby/mrblib/mrblib.rake +21 -0
  671. data/resources/mruby/mrblib/numeric.rb +163 -0
  672. data/resources/mruby/mrblib/range.rb +67 -0
  673. data/resources/mruby/mrblib/string.rb +275 -0
  674. data/resources/mruby/mruby-source.gemspec +18 -0
  675. data/resources/mruby/src/array.c +1251 -0
  676. data/resources/mruby/src/backtrace.c +285 -0
  677. data/resources/mruby/src/class.c +2546 -0
  678. data/resources/mruby/src/codedump.c +477 -0
  679. data/resources/mruby/src/compar.c +13 -0
  680. data/resources/mruby/src/crc.c +39 -0
  681. data/resources/mruby/src/debug.c +217 -0
  682. data/resources/mruby/src/dump.c +1106 -0
  683. data/resources/mruby/src/enum.c +14 -0
  684. data/resources/mruby/src/error.c +513 -0
  685. data/resources/mruby/src/error.h +3 -0
  686. data/resources/mruby/src/etc.c +246 -0
  687. data/resources/mruby/src/fmt_fp.c +374 -0
  688. data/resources/mruby/src/gc.c +1835 -0
  689. data/resources/mruby/src/hash.c +916 -0
  690. data/resources/mruby/src/init.c +51 -0
  691. data/resources/mruby/src/kernel.c +1264 -0
  692. data/resources/mruby/src/load.c +706 -0
  693. data/resources/mruby/src/mruby_core.rake +20 -0
  694. data/resources/mruby/src/numeric.c +1574 -0
  695. data/resources/mruby/src/object.c +618 -0
  696. data/resources/mruby/src/opcode.h +2 -0
  697. data/resources/mruby/src/pool.c +209 -0
  698. data/resources/mruby/src/print.c +47 -0
  699. data/resources/mruby/src/proc.c +313 -0
  700. data/resources/mruby/src/range.c +446 -0
  701. data/resources/mruby/src/state.c +307 -0
  702. data/resources/mruby/src/string.c +3025 -0
  703. data/resources/mruby/src/symbol.c +494 -0
  704. data/resources/mruby/src/value_array.h +27 -0
  705. data/resources/mruby/src/variable.c +982 -0
  706. data/resources/mruby/src/version.c +17 -0
  707. data/resources/mruby/src/vm.c +3020 -0
  708. data/resources/mruby/tasks/benchmark.rake +91 -0
  709. data/resources/mruby/tasks/gitlab.rake +118 -0
  710. data/resources/mruby/tasks/libmruby.rake +24 -0
  711. data/resources/mruby/tasks/mrbgems.rake +98 -0
  712. data/resources/mruby/tasks/toolchains/android.rake +321 -0
  713. data/resources/mruby/tasks/toolchains/clang.rake +9 -0
  714. data/resources/mruby/tasks/toolchains/gcc.rake +66 -0
  715. data/resources/mruby/tasks/toolchains/openwrt.rake +38 -0
  716. data/resources/mruby/tasks/toolchains/visualcpp.rake +68 -0
  717. data/resources/mruby/test/assert.rb +249 -0
  718. data/resources/mruby/test/bintest.rb +33 -0
  719. data/resources/mruby/test/report.rb +4 -0
  720. data/resources/mruby/test/t/argumenterror.rb +16 -0
  721. data/resources/mruby/test/t/array.rb +394 -0
  722. data/resources/mruby/test/t/basicobject.rb +11 -0
  723. data/resources/mruby/test/t/bs_block.rb +521 -0
  724. data/resources/mruby/test/t/bs_literal.rb +38 -0
  725. data/resources/mruby/test/t/class.rb +451 -0
  726. data/resources/mruby/test/t/codegen.rb +197 -0
  727. data/resources/mruby/test/t/comparable.rb +80 -0
  728. data/resources/mruby/test/t/ensure.rb +54 -0
  729. data/resources/mruby/test/t/enumerable.rb +134 -0
  730. data/resources/mruby/test/t/exception.rb +422 -0
  731. data/resources/mruby/test/t/false.rb +31 -0
  732. data/resources/mruby/test/t/float.rb +209 -0
  733. data/resources/mruby/test/t/gc.rb +45 -0
  734. data/resources/mruby/test/t/hash.rb +375 -0
  735. data/resources/mruby/test/t/indexerror.rb +6 -0
  736. data/resources/mruby/test/t/integer.rb +277 -0
  737. data/resources/mruby/test/t/iterations.rb +61 -0
  738. data/resources/mruby/test/t/kernel.rb +600 -0
  739. data/resources/mruby/test/t/lang.rb +74 -0
  740. data/resources/mruby/test/t/literals.rb +337 -0
  741. data/resources/mruby/test/t/localjumperror.rb +13 -0
  742. data/resources/mruby/test/t/methods.rb +109 -0
  743. data/resources/mruby/test/t/module.rb +914 -0
  744. data/resources/mruby/test/t/nameerror.rb +28 -0
  745. data/resources/mruby/test/t/nil.rb +39 -0
  746. data/resources/mruby/test/t/nomethoderror.rb +22 -0
  747. data/resources/mruby/test/t/numeric.rb +43 -0
  748. data/resources/mruby/test/t/object.rb +11 -0
  749. data/resources/mruby/test/t/proc.rb +180 -0
  750. data/resources/mruby/test/t/range.rb +95 -0
  751. data/resources/mruby/test/t/rangeerror.rb +6 -0
  752. data/resources/mruby/test/t/regexperror.rb +4 -0
  753. data/resources/mruby/test/t/runtimeerror.rb +6 -0
  754. data/resources/mruby/test/t/standarderror.rb +6 -0
  755. data/resources/mruby/test/t/string.rb +728 -0
  756. data/resources/mruby/test/t/superclass.rb +47 -0
  757. data/resources/mruby/test/t/symbol.rb +30 -0
  758. data/resources/mruby/test/t/syntax.rb +468 -0
  759. data/resources/mruby/test/t/true.rb +31 -0
  760. data/resources/mruby/test/t/typeerror.rb +6 -0
  761. data/resources/mruby/test/t/unicode.rb +39 -0
  762. data/resources/mruby/travis_config.rb +53 -0
  763. metadata +806 -0
@@ -0,0 +1,17 @@
1
+ #include <mruby.h>
2
+ #include <mruby/variable.h>
3
+
4
+ void
5
+ mrb_init_version(mrb_state* mrb)
6
+ {
7
+ mrb_value mruby_version = mrb_str_new_lit(mrb, MRUBY_VERSION);
8
+
9
+ mrb_define_global_const(mrb, "RUBY_VERSION", mrb_str_new_lit(mrb, MRUBY_RUBY_VERSION));
10
+ mrb_define_global_const(mrb, "RUBY_ENGINE", mrb_str_new_lit(mrb, MRUBY_RUBY_ENGINE));
11
+ mrb_define_global_const(mrb, "RUBY_ENGINE_VERSION", mruby_version);
12
+ mrb_define_global_const(mrb, "MRUBY_VERSION", mruby_version);
13
+ mrb_define_global_const(mrb, "MRUBY_RELEASE_NO", mrb_fixnum_value(MRUBY_RELEASE_NO));
14
+ mrb_define_global_const(mrb, "MRUBY_RELEASE_DATE", mrb_str_new_lit(mrb, MRUBY_RELEASE_DATE));
15
+ mrb_define_global_const(mrb, "MRUBY_DESCRIPTION", mrb_str_new_lit(mrb, MRUBY_DESCRIPTION));
16
+ mrb_define_global_const(mrb, "MRUBY_COPYRIGHT", mrb_str_new_lit(mrb, MRUBY_COPYRIGHT));
17
+ }
@@ -0,0 +1,3020 @@
1
+ /*
2
+ ** vm.c - virtual machine for mruby
3
+ **
4
+ ** See Copyright Notice in mruby.h
5
+ */
6
+
7
+ #include <stddef.h>
8
+ #include <stdarg.h>
9
+ #include <math.h>
10
+ #include <mruby.h>
11
+ #include <mruby/array.h>
12
+ #include <mruby/class.h>
13
+ #include <mruby/hash.h>
14
+ #include <mruby/irep.h>
15
+ #include <mruby/numeric.h>
16
+ #include <mruby/proc.h>
17
+ #include <mruby/range.h>
18
+ #include <mruby/string.h>
19
+ #include <mruby/variable.h>
20
+ #include <mruby/error.h>
21
+ #include <mruby/opcode.h>
22
+ #include "value_array.h"
23
+ #include <mruby/throw.h>
24
+
25
+ #ifdef MRB_DISABLE_STDIO
26
+ #if defined(__cplusplus)
27
+ extern "C" {
28
+ #endif
29
+ void abort(void);
30
+ #if defined(__cplusplus)
31
+ } /* extern "C" { */
32
+ #endif
33
+ #endif
34
+
35
+ #define STACK_INIT_SIZE 128
36
+ #define CALLINFO_INIT_SIZE 32
37
+
38
+ #ifndef ENSURE_STACK_INIT_SIZE
39
+ #define ENSURE_STACK_INIT_SIZE 16
40
+ #endif
41
+
42
+ #ifndef RESCUE_STACK_INIT_SIZE
43
+ #define RESCUE_STACK_INIT_SIZE 16
44
+ #endif
45
+
46
+ /* Define amount of linear stack growth. */
47
+ #ifndef MRB_STACK_GROWTH
48
+ #define MRB_STACK_GROWTH 128
49
+ #endif
50
+
51
+ /* Maximum mrb_funcall() depth. Should be set lower on memory constrained systems. */
52
+ #ifndef MRB_FUNCALL_DEPTH_MAX
53
+ #define MRB_FUNCALL_DEPTH_MAX 512
54
+ #endif
55
+
56
+ /* Maximum depth of ecall() recursion. */
57
+ #ifndef MRB_ECALL_DEPTH_MAX
58
+ #define MRB_ECALL_DEPTH_MAX 32
59
+ #endif
60
+
61
+ /* Maximum stack depth. Should be set lower on memory constrained systems.
62
+ The value below allows about 60000 recursive calls in the simplest case. */
63
+ #ifndef MRB_STACK_MAX
64
+ #define MRB_STACK_MAX (0x40000 - MRB_STACK_GROWTH)
65
+ #endif
66
+
67
+ #ifdef VM_DEBUG
68
+ # define DEBUG(x) (x)
69
+ #else
70
+ # define DEBUG(x)
71
+ #endif
72
+
73
+
74
+ #ifndef MRB_GC_FIXED_ARENA
75
+ static void
76
+ mrb_gc_arena_shrink(mrb_state *mrb, int idx)
77
+ {
78
+ mrb_gc *gc = &mrb->gc;
79
+ int capa = gc->arena_capa;
80
+
81
+ if (idx < capa / 4) {
82
+ capa >>= 2;
83
+ if (capa < MRB_GC_ARENA_SIZE) {
84
+ capa = MRB_GC_ARENA_SIZE;
85
+ }
86
+ if (capa != gc->arena_capa) {
87
+ gc->arena = (struct RBasic**)mrb_realloc(mrb, gc->arena, sizeof(struct RBasic*)*capa);
88
+ gc->arena_capa = capa;
89
+ }
90
+ }
91
+ }
92
+ #else
93
+ #define mrb_gc_arena_shrink(mrb,idx)
94
+ #endif
95
+
96
+ #define CALL_MAXARGS 127
97
+
98
+ void mrb_method_missing(mrb_state *mrb, mrb_sym name, mrb_value self, mrb_value args);
99
+
100
+ static inline void
101
+ stack_clear(mrb_value *from, size_t count)
102
+ {
103
+ #ifndef MRB_NAN_BOXING
104
+ const mrb_value mrb_value_zero = { { 0 } };
105
+
106
+ while (count-- > 0) {
107
+ *from++ = mrb_value_zero;
108
+ }
109
+ #else
110
+ while (count-- > 0) {
111
+ SET_NIL_VALUE(*from);
112
+ from++;
113
+ }
114
+ #endif
115
+ }
116
+
117
+ static inline void
118
+ stack_copy(mrb_value *dst, const mrb_value *src, size_t size)
119
+ {
120
+ while (size-- > 0) {
121
+ *dst++ = *src++;
122
+ }
123
+ }
124
+
125
+ static void
126
+ stack_init(mrb_state *mrb)
127
+ {
128
+ struct mrb_context *c = mrb->c;
129
+
130
+ /* mrb_assert(mrb->stack == NULL); */
131
+ c->stbase = (mrb_value *)mrb_calloc(mrb, STACK_INIT_SIZE, sizeof(mrb_value));
132
+ c->stend = c->stbase + STACK_INIT_SIZE;
133
+ c->stack = c->stbase;
134
+
135
+ /* mrb_assert(ci == NULL); */
136
+ c->cibase = (mrb_callinfo *)mrb_calloc(mrb, CALLINFO_INIT_SIZE, sizeof(mrb_callinfo));
137
+ c->ciend = c->cibase + CALLINFO_INIT_SIZE;
138
+ c->ci = c->cibase;
139
+ c->ci->target_class = mrb->object_class;
140
+ c->ci->stackent = c->stack;
141
+ }
142
+
143
+ static inline void
144
+ envadjust(mrb_state *mrb, mrb_value *oldbase, mrb_value *newbase, size_t size)
145
+ {
146
+ mrb_callinfo *ci = mrb->c->cibase;
147
+
148
+ if (newbase == oldbase) return;
149
+ while (ci <= mrb->c->ci) {
150
+ struct REnv *e = ci->env;
151
+ mrb_value *st;
152
+
153
+ if (e && MRB_ENV_STACK_SHARED_P(e) &&
154
+ (st = e->stack) && oldbase <= st && st < oldbase+size) {
155
+ ptrdiff_t off = e->stack - oldbase;
156
+
157
+ e->stack = newbase + off;
158
+ }
159
+ ci->stackent = newbase + (ci->stackent - oldbase);
160
+ ci++;
161
+ }
162
+ }
163
+
164
+ /** def rec ; $deep =+ 1 ; if $deep > 1000 ; return 0 ; end ; rec ; end */
165
+
166
+ static void
167
+ stack_extend_alloc(mrb_state *mrb, int room)
168
+ {
169
+ mrb_value *oldbase = mrb->c->stbase;
170
+ mrb_value *newstack;
171
+ size_t oldsize = mrb->c->stend - mrb->c->stbase;
172
+ size_t size = oldsize;
173
+ size_t off = mrb->c->stack - mrb->c->stbase;
174
+
175
+ if (off > size) size = off;
176
+ #ifdef MRB_STACK_EXTEND_DOUBLING
177
+ if (room <= size)
178
+ size *= 2;
179
+ else
180
+ size += room;
181
+ #else
182
+ /* Use linear stack growth.
183
+ It is slightly slower than doubling the stack space,
184
+ but it saves memory on small devices. */
185
+ if (room <= MRB_STACK_GROWTH)
186
+ size += MRB_STACK_GROWTH;
187
+ else
188
+ size += room;
189
+ #endif
190
+
191
+ newstack = (mrb_value *)mrb_realloc(mrb, mrb->c->stbase, sizeof(mrb_value) * size);
192
+ if (newstack == NULL) {
193
+ mrb_exc_raise(mrb, mrb_obj_value(mrb->stack_err));
194
+ }
195
+ stack_clear(&(newstack[oldsize]), size - oldsize);
196
+ envadjust(mrb, oldbase, newstack, size);
197
+ mrb->c->stbase = newstack;
198
+ mrb->c->stack = mrb->c->stbase + off;
199
+ mrb->c->stend = mrb->c->stbase + size;
200
+
201
+ /* Raise an exception if the new stack size will be too large,
202
+ to prevent infinite recursion. However, do this only after resizing the stack, so mrb_raise has stack space to work with. */
203
+ if (size > MRB_STACK_MAX) {
204
+ mrb_exc_raise(mrb, mrb_obj_value(mrb->stack_err));
205
+ }
206
+ }
207
+
208
+ static inline void
209
+ stack_extend(mrb_state *mrb, int room)
210
+ {
211
+ if (mrb->c->stack + room >= mrb->c->stend) {
212
+ stack_extend_alloc(mrb, room);
213
+ }
214
+ }
215
+
216
+ static inline struct REnv*
217
+ uvenv(mrb_state *mrb, int up)
218
+ {
219
+ struct RProc *proc = mrb->c->ci->proc;
220
+ struct REnv *e;
221
+
222
+ while (up--) {
223
+ proc = proc->upper;
224
+ if (!proc) return NULL;
225
+ }
226
+ e = MRB_PROC_ENV(proc);
227
+ if (e) return e; /* proc has enclosed env */
228
+ else {
229
+ mrb_callinfo *ci = mrb->c->ci;
230
+ mrb_callinfo *cb = mrb->c->cibase;
231
+
232
+ while (cb <= ci) {
233
+ if (ci->proc == proc) {
234
+ return ci->env;
235
+ }
236
+ ci--;
237
+ }
238
+ }
239
+ return NULL;
240
+ }
241
+
242
+ static inline struct RProc*
243
+ top_proc(mrb_state *mrb, struct RProc *proc)
244
+ {
245
+ while (proc->upper) {
246
+ if (MRB_PROC_SCOPE_P(proc) || MRB_PROC_STRICT_P(proc))
247
+ return proc;
248
+ proc = proc->upper;
249
+ }
250
+ return proc;
251
+ }
252
+
253
+ #define CI_ACC_SKIP -1
254
+ #define CI_ACC_DIRECT -2
255
+ #define CI_ACC_RESUMED -3
256
+
257
+ static inline mrb_callinfo*
258
+ cipush(mrb_state *mrb)
259
+ {
260
+ struct mrb_context *c = mrb->c;
261
+ static const mrb_callinfo ci_zero = { 0 };
262
+ mrb_callinfo *ci = c->ci;
263
+
264
+ int ridx = ci->ridx;
265
+
266
+ if (ci + 1 == c->ciend) {
267
+ ptrdiff_t size = ci - c->cibase;
268
+
269
+ c->cibase = (mrb_callinfo *)mrb_realloc(mrb, c->cibase, sizeof(mrb_callinfo)*size*2);
270
+ c->ci = c->cibase + size;
271
+ c->ciend = c->cibase + size * 2;
272
+ }
273
+ ci = ++c->ci;
274
+ *ci = ci_zero;
275
+ ci->epos = mrb->c->eidx;
276
+ ci->ridx = ridx;
277
+
278
+ return ci;
279
+ }
280
+
281
+ void
282
+ mrb_env_unshare(mrb_state *mrb, struct REnv *e)
283
+ {
284
+ if (e == NULL) return;
285
+ else {
286
+ size_t len = (size_t)MRB_ENV_STACK_LEN(e);
287
+ mrb_value *p;
288
+
289
+ if (!MRB_ENV_STACK_SHARED_P(e)) return;
290
+ if (e->cxt != mrb->c) return;
291
+ p = (mrb_value *)mrb_malloc(mrb, sizeof(mrb_value)*len);
292
+ if (len > 0) {
293
+ stack_copy(p, e->stack, len);
294
+ }
295
+ e->stack = p;
296
+ MRB_ENV_UNSHARE_STACK(e);
297
+ mrb_write_barrier(mrb, (struct RBasic *)e);
298
+ }
299
+ }
300
+
301
+ static inline void
302
+ cipop(mrb_state *mrb)
303
+ {
304
+ struct mrb_context *c = mrb->c;
305
+ struct REnv *env = c->ci->env;
306
+
307
+ c->ci--;
308
+ if (env) mrb_env_unshare(mrb, env);
309
+ }
310
+
311
+ void mrb_exc_set(mrb_state *mrb, mrb_value exc);
312
+
313
+ static void
314
+ ecall(mrb_state *mrb)
315
+ {
316
+ struct RProc *p;
317
+ struct mrb_context *c = mrb->c;
318
+ mrb_callinfo *ci = c->ci;
319
+ struct RObject *exc;
320
+ struct REnv *env;
321
+ ptrdiff_t cioff;
322
+ int ai = mrb_gc_arena_save(mrb);
323
+ int i = --c->eidx;
324
+ int nregs;
325
+
326
+ if (i<0) return;
327
+ if (ci - c->cibase > MRB_ECALL_DEPTH_MAX) {
328
+ mrb_exc_raise(mrb, mrb_obj_value(mrb->stack_err));
329
+ }
330
+ p = c->ensure[i];
331
+ if (!p) return;
332
+ mrb_assert(!MRB_PROC_CFUNC_P(p));
333
+ c->ensure[i] = NULL;
334
+ nregs = p->upper->body.irep->nregs;
335
+ if (ci->proc && !MRB_PROC_CFUNC_P(ci->proc) &&
336
+ ci->proc->body.irep->nregs > nregs) {
337
+ nregs = ci->proc->body.irep->nregs;
338
+ }
339
+ cioff = ci - c->cibase;
340
+ ci = cipush(mrb);
341
+ ci->stackent = mrb->c->stack;
342
+ ci->mid = ci[-1].mid;
343
+ ci->acc = CI_ACC_SKIP;
344
+ ci->argc = 0;
345
+ ci->proc = p;
346
+ ci->nregs = p->body.irep->nregs;
347
+ ci->target_class = MRB_PROC_TARGET_CLASS(p);
348
+ env = MRB_PROC_ENV(p);
349
+ mrb_assert(env);
350
+ c->stack += nregs;
351
+ exc = mrb->exc; mrb->exc = 0;
352
+ if (exc) {
353
+ mrb_gc_protect(mrb, mrb_obj_value(exc));
354
+ }
355
+ mrb_run(mrb, p, env->stack[0]);
356
+ mrb->c = c;
357
+ c->ci = c->cibase + cioff;
358
+ if (!mrb->exc) mrb->exc = exc;
359
+ mrb_gc_arena_restore(mrb, ai);
360
+ }
361
+
362
+ #ifndef MRB_FUNCALL_ARGC_MAX
363
+ #define MRB_FUNCALL_ARGC_MAX 16
364
+ #endif
365
+
366
+ MRB_API mrb_value
367
+ mrb_funcall(mrb_state *mrb, mrb_value self, const char *name, mrb_int argc, ...)
368
+ {
369
+ mrb_value argv[MRB_FUNCALL_ARGC_MAX];
370
+ va_list ap;
371
+ mrb_int i;
372
+ mrb_sym mid = mrb_intern_cstr(mrb, name);
373
+
374
+ if (argc > MRB_FUNCALL_ARGC_MAX) {
375
+ mrb_raise(mrb, E_ARGUMENT_ERROR, "Too long arguments. (limit=" MRB_STRINGIZE(MRB_FUNCALL_ARGC_MAX) ")");
376
+ }
377
+
378
+ va_start(ap, argc);
379
+ for (i = 0; i < argc; i++) {
380
+ argv[i] = va_arg(ap, mrb_value);
381
+ }
382
+ va_end(ap);
383
+ return mrb_funcall_argv(mrb, self, mid, argc, argv);
384
+ }
385
+
386
+ MRB_API mrb_value
387
+ mrb_funcall_with_block(mrb_state *mrb, mrb_value self, mrb_sym mid, mrb_int argc, const mrb_value *argv, mrb_value blk)
388
+ {
389
+ mrb_value val;
390
+
391
+ if (!mrb->jmp) {
392
+ struct mrb_jmpbuf c_jmp;
393
+ ptrdiff_t nth_ci = mrb->c->ci - mrb->c->cibase;
394
+
395
+ MRB_TRY(&c_jmp) {
396
+ mrb->jmp = &c_jmp;
397
+ /* recursive call */
398
+ val = mrb_funcall_with_block(mrb, self, mid, argc, argv, blk);
399
+ mrb->jmp = 0;
400
+ }
401
+ MRB_CATCH(&c_jmp) { /* error */
402
+ while (nth_ci < (mrb->c->ci - mrb->c->cibase)) {
403
+ mrb->c->stack = mrb->c->ci->stackent;
404
+ cipop(mrb);
405
+ }
406
+ mrb->jmp = 0;
407
+ val = mrb_obj_value(mrb->exc);
408
+ }
409
+ MRB_END_EXC(&c_jmp);
410
+ mrb->jmp = 0;
411
+ }
412
+ else {
413
+ mrb_method_t m;
414
+ struct RClass *c;
415
+ mrb_callinfo *ci;
416
+ int n;
417
+ ptrdiff_t voff = -1;
418
+
419
+ if (!mrb->c->stack) {
420
+ stack_init(mrb);
421
+ }
422
+ n = mrb->c->ci->nregs;
423
+ if (argc < 0) {
424
+ mrb_raisef(mrb, E_ARGUMENT_ERROR, "negative argc for funcall (%S)", mrb_fixnum_value(argc));
425
+ }
426
+ c = mrb_class(mrb, self);
427
+ m = mrb_method_search_vm(mrb, &c, mid);
428
+ if (MRB_METHOD_UNDEF_P(m)) {
429
+ mrb_sym missing = mrb_intern_lit(mrb, "method_missing");
430
+ mrb_value args = mrb_ary_new_from_values(mrb, argc, argv);
431
+ m = mrb_method_search_vm(mrb, &c, missing);
432
+ if (MRB_METHOD_UNDEF_P(m)) {
433
+ mrb_method_missing(mrb, mid, self, args);
434
+ }
435
+ mrb_ary_unshift(mrb, args, mrb_symbol_value(mid));
436
+ stack_extend(mrb, n+2);
437
+ mrb->c->stack[n+1] = args;
438
+ argc = -1;
439
+ }
440
+ if (mrb->c->ci - mrb->c->cibase > MRB_FUNCALL_DEPTH_MAX) {
441
+ mrb_exc_raise(mrb, mrb_obj_value(mrb->stack_err));
442
+ }
443
+ ci = cipush(mrb);
444
+ ci->mid = mid;
445
+ ci->stackent = mrb->c->stack;
446
+ ci->argc = (int)argc;
447
+ ci->target_class = c;
448
+ mrb->c->stack = mrb->c->stack + n;
449
+ if (mrb->c->stbase <= argv && argv < mrb->c->stend) {
450
+ voff = argv - mrb->c->stbase;
451
+ }
452
+ if (MRB_METHOD_CFUNC_P(m)) {
453
+ ci->nregs = (int)(argc + 2);
454
+ stack_extend(mrb, ci->nregs);
455
+ }
456
+ else if (argc >= CALL_MAXARGS) {
457
+ mrb_value args = mrb_ary_new_from_values(mrb, argc, argv);
458
+ stack_extend(mrb, ci->nregs+2);
459
+ mrb->c->stack[1] = args;
460
+ ci->argc = -1;
461
+ argc = 1;
462
+ }
463
+ else {
464
+ struct RProc *p = MRB_METHOD_PROC(m);
465
+ ci->proc = p;
466
+ if (argc < 0) argc = 1;
467
+ ci->nregs = (int)(p->body.irep->nregs + argc);
468
+ stack_extend(mrb, ci->nregs);
469
+ }
470
+ if (voff >= 0) {
471
+ argv = mrb->c->stbase + voff;
472
+ }
473
+ mrb->c->stack[0] = self;
474
+ if (ci->argc > 0) {
475
+ stack_copy(mrb->c->stack+1, argv, argc);
476
+ }
477
+ mrb->c->stack[argc+1] = blk;
478
+
479
+ if (MRB_METHOD_CFUNC_P(m)) {
480
+ int ai = mrb_gc_arena_save(mrb);
481
+
482
+ ci->acc = CI_ACC_DIRECT;
483
+ if (MRB_METHOD_PROC_P(m)) {
484
+ ci->proc = MRB_METHOD_PROC(m);
485
+ }
486
+ val = MRB_METHOD_CFUNC(m)(mrb, self);
487
+ mrb->c->stack = mrb->c->ci->stackent;
488
+ cipop(mrb);
489
+ mrb_gc_arena_restore(mrb, ai);
490
+ }
491
+ else {
492
+ ci->acc = CI_ACC_SKIP;
493
+ val = mrb_run(mrb, MRB_METHOD_PROC(m), self);
494
+ }
495
+ }
496
+ mrb_gc_protect(mrb, val);
497
+ return val;
498
+ }
499
+
500
+ MRB_API mrb_value
501
+ mrb_funcall_argv(mrb_state *mrb, mrb_value self, mrb_sym mid, mrb_int argc, const mrb_value *argv)
502
+ {
503
+ return mrb_funcall_with_block(mrb, self, mid, argc, argv, mrb_nil_value());
504
+ }
505
+
506
+ mrb_value
507
+ mrb_exec_irep(mrb_state *mrb, mrb_value self, struct RProc *p)
508
+ {
509
+ mrb_callinfo *ci = mrb->c->ci;
510
+ int keep;
511
+
512
+ mrb->c->stack[0] = self;
513
+ ci->proc = p;
514
+ if (MRB_PROC_CFUNC_P(p)) {
515
+ return MRB_PROC_CFUNC(p)(mrb, self);
516
+ }
517
+ ci->nregs = p->body.irep->nregs;
518
+ if (ci->argc < 0) keep = 3;
519
+ else keep = ci->argc + 1;
520
+ if (ci->nregs < keep) {
521
+ stack_extend(mrb, keep);
522
+ }
523
+ else {
524
+ stack_extend(mrb, ci->nregs);
525
+ stack_clear(mrb->c->stack+keep, ci->nregs-keep);
526
+ }
527
+
528
+ ci = cipush(mrb);
529
+ ci->nregs = 0;
530
+ ci->target_class = 0;
531
+ ci->pc = p->body.irep->iseq;
532
+ ci->stackent = mrb->c->stack;
533
+ ci->acc = 0;
534
+
535
+ return self;
536
+ }
537
+
538
+ /* 15.3.1.3.4 */
539
+ /* 15.3.1.3.44 */
540
+ /*
541
+ * call-seq:
542
+ * obj.send(symbol [, args...]) -> obj
543
+ * obj.__send__(symbol [, args...]) -> obj
544
+ *
545
+ * Invokes the method identified by _symbol_, passing it any
546
+ * arguments specified. You can use <code>__send__</code> if the name
547
+ * +send+ clashes with an existing method in _obj_.
548
+ *
549
+ * class Klass
550
+ * def hello(*args)
551
+ * "Hello " + args.join(' ')
552
+ * end
553
+ * end
554
+ * k = Klass.new
555
+ * k.send :hello, "gentle", "readers" #=> "Hello gentle readers"
556
+ */
557
+ MRB_API mrb_value
558
+ mrb_f_send(mrb_state *mrb, mrb_value self)
559
+ {
560
+ mrb_sym name;
561
+ mrb_value block, *argv, *regs;
562
+ mrb_int argc, i, len;
563
+ mrb_method_t m;
564
+ struct RClass *c;
565
+ mrb_callinfo *ci;
566
+
567
+ mrb_get_args(mrb, "n*&", &name, &argv, &argc, &block);
568
+ ci = mrb->c->ci;
569
+ if (ci->acc < 0) {
570
+ funcall:
571
+ return mrb_funcall_with_block(mrb, self, name, argc, argv, block);
572
+ }
573
+
574
+ c = mrb_class(mrb, self);
575
+ m = mrb_method_search_vm(mrb, &c, name);
576
+ if (MRB_METHOD_UNDEF_P(m)) { /* call method_mising */
577
+ goto funcall;
578
+ }
579
+
580
+ ci->mid = name;
581
+ ci->target_class = c;
582
+ regs = mrb->c->stack+1;
583
+ /* remove first symbol from arguments */
584
+ if (ci->argc >= 0) {
585
+ for (i=0,len=ci->argc; i<len; i++) {
586
+ regs[i] = regs[i+1];
587
+ }
588
+ ci->argc--;
589
+ }
590
+ else { /* variable length arguments */
591
+ mrb_ary_shift(mrb, regs[0]);
592
+ }
593
+
594
+ if (MRB_METHOD_CFUNC_P(m)) {
595
+ if (MRB_METHOD_PROC_P(m)) {
596
+ ci->proc = MRB_METHOD_PROC(m);
597
+ }
598
+ return MRB_METHOD_CFUNC(m)(mrb, self);
599
+ }
600
+ return mrb_exec_irep(mrb, self, MRB_METHOD_PROC(m));
601
+ }
602
+
603
+ static mrb_value
604
+ eval_under(mrb_state *mrb, mrb_value self, mrb_value blk, struct RClass *c)
605
+ {
606
+ struct RProc *p;
607
+ mrb_callinfo *ci;
608
+
609
+ if (mrb_nil_p(blk)) {
610
+ mrb_raise(mrb, E_ARGUMENT_ERROR, "no block given");
611
+ }
612
+ ci = mrb->c->ci;
613
+ if (ci->acc == CI_ACC_DIRECT) {
614
+ ci->target_class = c;
615
+ return mrb_yield_cont(mrb, blk, self, 1, &self);
616
+ }
617
+ ci->target_class = c;
618
+ p = mrb_proc_ptr(blk);
619
+ ci->proc = p;
620
+ ci->argc = 1;
621
+ ci->mid = ci[-1].mid;
622
+ if (MRB_PROC_CFUNC_P(p)) {
623
+ stack_extend(mrb, 3);
624
+ mrb->c->stack[0] = self;
625
+ mrb->c->stack[1] = self;
626
+ mrb->c->stack[2] = mrb_nil_value();
627
+ return MRB_PROC_CFUNC(p)(mrb, self);
628
+ }
629
+ ci->nregs = p->body.irep->nregs;
630
+ stack_extend(mrb, (ci->nregs < 3) ? 3 : ci->nregs);
631
+ mrb->c->stack[0] = self;
632
+ mrb->c->stack[1] = self;
633
+ mrb->c->stack[2] = mrb_nil_value();
634
+ ci = cipush(mrb);
635
+ ci->nregs = 0;
636
+ ci->target_class = 0;
637
+ ci->pc = p->body.irep->iseq;
638
+ ci->stackent = mrb->c->stack;
639
+ ci->acc = 0;
640
+
641
+ return self;
642
+ }
643
+
644
+ /* 15.2.2.4.35 */
645
+ /*
646
+ * call-seq:
647
+ * mod.class_eval {| | block } -> obj
648
+ * mod.module_eval {| | block } -> obj
649
+ *
650
+ * Evaluates block in the context of _mod_. This can
651
+ * be used to add methods to a class. <code>module_eval</code> returns
652
+ * the result of evaluating its argument.
653
+ */
654
+ mrb_value
655
+ mrb_mod_module_eval(mrb_state *mrb, mrb_value mod)
656
+ {
657
+ mrb_value a, b;
658
+
659
+ if (mrb_get_args(mrb, "|S&", &a, &b) == 1) {
660
+ mrb_raise(mrb, E_NOTIMP_ERROR, "module_eval/class_eval with string not implemented");
661
+ }
662
+ return eval_under(mrb, mod, b, mrb_class_ptr(mod));
663
+ }
664
+
665
+ /* 15.3.1.3.18 */
666
+ /*
667
+ * call-seq:
668
+ * obj.instance_eval {| | block } -> obj
669
+ *
670
+ * Evaluates the given block,within the context of the receiver (_obj_).
671
+ * In order to set the context, the variable +self+ is set to _obj_ while
672
+ * the code is executing, giving the code access to _obj_'s
673
+ * instance variables. In the version of <code>instance_eval</code>
674
+ * that takes a +String+, the optional second and third
675
+ * parameters supply a filename and starting line number that are used
676
+ * when reporting compilation errors.
677
+ *
678
+ * class KlassWithSecret
679
+ * def initialize
680
+ * @secret = 99
681
+ * end
682
+ * end
683
+ * k = KlassWithSecret.new
684
+ * k.instance_eval { @secret } #=> 99
685
+ */
686
+ mrb_value
687
+ mrb_obj_instance_eval(mrb_state *mrb, mrb_value self)
688
+ {
689
+ mrb_value a, b;
690
+ mrb_value cv;
691
+ struct RClass *c;
692
+
693
+ if (mrb_get_args(mrb, "|S&", &a, &b) == 1) {
694
+ mrb_raise(mrb, E_NOTIMP_ERROR, "instance_eval with string not implemented");
695
+ }
696
+ switch (mrb_type(self)) {
697
+ case MRB_TT_SYMBOL:
698
+ case MRB_TT_FIXNUM:
699
+ #ifndef MRB_WITHOUT_FLOAT
700
+ case MRB_TT_FLOAT:
701
+ #endif
702
+ c = 0;
703
+ break;
704
+ default:
705
+ cv = mrb_singleton_class(mrb, self);
706
+ c = mrb_class_ptr(cv);
707
+ break;
708
+ }
709
+ return eval_under(mrb, self, b, c);
710
+ }
711
+
712
+ MRB_API mrb_value
713
+ mrb_yield_with_class(mrb_state *mrb, mrb_value b, mrb_int argc, const mrb_value *argv, mrb_value self, struct RClass *c)
714
+ {
715
+ struct RProc *p;
716
+ mrb_sym mid = mrb->c->ci->mid;
717
+ mrb_callinfo *ci;
718
+ int n = mrb->c->ci->nregs;
719
+ mrb_value val;
720
+
721
+ if (mrb_nil_p(b)) {
722
+ mrb_raise(mrb, E_ARGUMENT_ERROR, "no block given");
723
+ }
724
+ if (mrb->c->ci - mrb->c->cibase > MRB_FUNCALL_DEPTH_MAX) {
725
+ mrb_exc_raise(mrb, mrb_obj_value(mrb->stack_err));
726
+ }
727
+ p = mrb_proc_ptr(b);
728
+ ci = cipush(mrb);
729
+ ci->mid = mid;
730
+ ci->proc = p;
731
+ ci->stackent = mrb->c->stack;
732
+ ci->argc = (int)argc;
733
+ ci->target_class = c;
734
+ ci->acc = CI_ACC_SKIP;
735
+ mrb->c->stack = mrb->c->stack + n;
736
+ ci->nregs = MRB_PROC_CFUNC_P(p) ? (int)(argc+2) : p->body.irep->nregs;
737
+ stack_extend(mrb, ci->nregs);
738
+
739
+ mrb->c->stack[0] = self;
740
+ if (argc > 0) {
741
+ stack_copy(mrb->c->stack+1, argv, argc);
742
+ }
743
+ mrb->c->stack[argc+1] = mrb_nil_value();
744
+
745
+ if (MRB_PROC_CFUNC_P(p)) {
746
+ val = MRB_PROC_CFUNC(p)(mrb, self);
747
+ mrb->c->stack = mrb->c->ci->stackent;
748
+ cipop(mrb);
749
+ }
750
+ else {
751
+ val = mrb_run(mrb, p, self);
752
+ }
753
+ return val;
754
+ }
755
+
756
+ MRB_API mrb_value
757
+ mrb_yield_argv(mrb_state *mrb, mrb_value b, mrb_int argc, const mrb_value *argv)
758
+ {
759
+ struct RProc *p = mrb_proc_ptr(b);
760
+
761
+ return mrb_yield_with_class(mrb, b, argc, argv, MRB_PROC_ENV(p)->stack[0], MRB_PROC_TARGET_CLASS(p));
762
+ }
763
+
764
+ MRB_API mrb_value
765
+ mrb_yield(mrb_state *mrb, mrb_value b, mrb_value arg)
766
+ {
767
+ struct RProc *p = mrb_proc_ptr(b);
768
+
769
+ return mrb_yield_with_class(mrb, b, 1, &arg, MRB_PROC_ENV(p)->stack[0], MRB_PROC_TARGET_CLASS(p));
770
+ }
771
+
772
+ mrb_value
773
+ mrb_yield_cont(mrb_state *mrb, mrb_value b, mrb_value self, mrb_int argc, const mrb_value *argv)
774
+ {
775
+ struct RProc *p;
776
+ mrb_callinfo *ci;
777
+
778
+ if (mrb_nil_p(b)) {
779
+ mrb_raise(mrb, E_ARGUMENT_ERROR, "no block given");
780
+ }
781
+ if (mrb_type(b) != MRB_TT_PROC) {
782
+ mrb_raise(mrb, E_TYPE_ERROR, "not a block");
783
+ }
784
+
785
+ p = mrb_proc_ptr(b);
786
+ ci = mrb->c->ci;
787
+
788
+ stack_extend(mrb, 3);
789
+ mrb->c->stack[1] = mrb_ary_new_from_values(mrb, argc, argv);
790
+ mrb->c->stack[2] = mrb_nil_value();
791
+ ci->argc = -1;
792
+ return mrb_exec_irep(mrb, self, p);
793
+ }
794
+
795
+ mrb_value
796
+ mrb_mod_s_nesting(mrb_state *mrb, mrb_value mod)
797
+ {
798
+ struct RProc *proc;
799
+ mrb_value ary;
800
+ struct RClass *c = NULL;
801
+
802
+ mrb_get_args(mrb, "");
803
+ ary = mrb_ary_new(mrb);
804
+ proc = mrb->c->ci[-1].proc; /* callee proc */
805
+ mrb_assert(!MRB_PROC_CFUNC_P(proc));
806
+ while (proc) {
807
+ if (MRB_PROC_SCOPE_P(proc)) {
808
+ struct RClass *c2 = MRB_PROC_TARGET_CLASS(proc);
809
+
810
+ if (c2 != c) {
811
+ c = c2;
812
+ mrb_ary_push(mrb, ary, mrb_obj_value(c));
813
+ }
814
+ }
815
+ proc = proc->upper;
816
+ }
817
+ return ary;
818
+ }
819
+
820
+ static struct RBreak*
821
+ break_new(mrb_state *mrb, struct RProc *p, mrb_value val)
822
+ {
823
+ struct RBreak *brk;
824
+
825
+ brk = (struct RBreak*)mrb_obj_alloc(mrb, MRB_TT_BREAK, NULL);
826
+ brk->proc = p;
827
+ brk->val = val;
828
+
829
+ return brk;
830
+ }
831
+
832
+ typedef enum {
833
+ LOCALJUMP_ERROR_RETURN = 0,
834
+ LOCALJUMP_ERROR_BREAK = 1,
835
+ LOCALJUMP_ERROR_YIELD = 2
836
+ } localjump_error_kind;
837
+
838
+ static void
839
+ localjump_error(mrb_state *mrb, localjump_error_kind kind)
840
+ {
841
+ char kind_str[3][7] = { "return", "break", "yield" };
842
+ char kind_str_len[] = { 6, 5, 5 };
843
+ static const char lead[] = "unexpected ";
844
+ mrb_value msg;
845
+ mrb_value exc;
846
+
847
+ msg = mrb_str_new_capa(mrb, sizeof(lead) + 7);
848
+ mrb_str_cat(mrb, msg, lead, sizeof(lead) - 1);
849
+ mrb_str_cat(mrb, msg, kind_str[kind], kind_str_len[kind]);
850
+ exc = mrb_exc_new_str(mrb, E_LOCALJUMP_ERROR, msg);
851
+ mrb_exc_set(mrb, exc);
852
+ }
853
+
854
+ static void
855
+ argnum_error(mrb_state *mrb, mrb_int num)
856
+ {
857
+ mrb_value exc;
858
+ mrb_value str;
859
+ mrb_int argc = mrb->c->ci->argc;
860
+
861
+ if (argc < 0) {
862
+ mrb_value args = mrb->c->stack[1];
863
+ if (mrb_array_p(args)) {
864
+ argc = RARRAY_LEN(args);
865
+ }
866
+ }
867
+ if (mrb->c->ci->mid) {
868
+ str = mrb_format(mrb, "'%S': wrong number of arguments (%S for %S)",
869
+ mrb_sym2str(mrb, mrb->c->ci->mid),
870
+ mrb_fixnum_value(argc), mrb_fixnum_value(num));
871
+ }
872
+ else {
873
+ str = mrb_format(mrb, "wrong number of arguments (%S for %S)",
874
+ mrb_fixnum_value(argc), mrb_fixnum_value(num));
875
+ }
876
+ exc = mrb_exc_new_str(mrb, E_ARGUMENT_ERROR, str);
877
+ mrb_exc_set(mrb, exc);
878
+ }
879
+
880
+ #define ERR_PC_SET(mrb, pc) mrb->c->ci->err = pc;
881
+ #define ERR_PC_CLR(mrb) mrb->c->ci->err = 0;
882
+ #ifdef MRB_ENABLE_DEBUG_HOOK
883
+ #define CODE_FETCH_HOOK(mrb, irep, pc, regs) if ((mrb)->code_fetch_hook) (mrb)->code_fetch_hook((mrb), (irep), (pc), (regs));
884
+ #else
885
+ #define CODE_FETCH_HOOK(mrb, irep, pc, regs)
886
+ #endif
887
+
888
+ #ifdef MRB_BYTECODE_DECODE_OPTION
889
+ #define BYTECODE_DECODER(x) ((mrb)->bytecode_decoder)?(mrb)->bytecode_decoder((mrb), (x)):(x)
890
+ #else
891
+ #define BYTECODE_DECODER(x) (x)
892
+ #endif
893
+
894
+
895
+ #if defined __GNUC__ || defined __clang__ || defined __INTEL_COMPILER
896
+ #define DIRECT_THREADED
897
+ #endif
898
+
899
+ #ifndef DIRECT_THREADED
900
+
901
+ #define INIT_DISPATCH for (;;) { i = BYTECODE_DECODER(*pc); CODE_FETCH_HOOK(mrb, irep, pc, regs); switch (GET_OPCODE(i)) {
902
+ #define CASE(op) case op:
903
+ #define NEXT pc++; break
904
+ #define JUMP break
905
+ #define END_DISPATCH }}
906
+
907
+ #else
908
+
909
+ #define INIT_DISPATCH JUMP; return mrb_nil_value();
910
+ #define CASE(op) L_ ## op:
911
+ #define NEXT i=BYTECODE_DECODER(*++pc); CODE_FETCH_HOOK(mrb, irep, pc, regs); goto *optable[GET_OPCODE(i)]
912
+ #define JUMP i=BYTECODE_DECODER(*pc); CODE_FETCH_HOOK(mrb, irep, pc, regs); goto *optable[GET_OPCODE(i)]
913
+
914
+ #define END_DISPATCH
915
+
916
+ #endif
917
+
918
+ MRB_API mrb_value
919
+ mrb_vm_run(mrb_state *mrb, struct RProc *proc, mrb_value self, unsigned int stack_keep)
920
+ {
921
+ mrb_irep *irep = proc->body.irep;
922
+ mrb_value result;
923
+ struct mrb_context *c = mrb->c;
924
+ ptrdiff_t cioff = c->ci - c->cibase;
925
+ unsigned int nregs = irep->nregs;
926
+
927
+ if (!c->stack) {
928
+ stack_init(mrb);
929
+ }
930
+ if (stack_keep > nregs)
931
+ nregs = stack_keep;
932
+ stack_extend(mrb, nregs);
933
+ stack_clear(c->stack + stack_keep, nregs - stack_keep);
934
+ c->stack[0] = self;
935
+ result = mrb_vm_exec(mrb, proc, irep->iseq);
936
+ if (c->ci - c->cibase > cioff) {
937
+ c->ci = c->cibase + cioff;
938
+ }
939
+ if (mrb->c != c) {
940
+ if (mrb->c->fib) {
941
+ mrb_write_barrier(mrb, (struct RBasic*)mrb->c->fib);
942
+ }
943
+ mrb->c = c;
944
+ }
945
+ return result;
946
+ }
947
+
948
+ MRB_API mrb_value
949
+ mrb_vm_exec(mrb_state *mrb, struct RProc *proc, mrb_code *pc)
950
+ {
951
+ /* mrb_assert(mrb_proc_cfunc_p(proc)) */
952
+ mrb_irep *irep = proc->body.irep;
953
+ mrb_value *pool = irep->pool;
954
+ mrb_sym *syms = irep->syms;
955
+ mrb_code i;
956
+ int ai = mrb_gc_arena_save(mrb);
957
+ struct mrb_jmpbuf *prev_jmp = mrb->jmp;
958
+ struct mrb_jmpbuf c_jmp;
959
+
960
+ #ifdef DIRECT_THREADED
961
+ static void *optable[] = {
962
+ &&L_OP_NOP, &&L_OP_MOVE,
963
+ &&L_OP_LOADL, &&L_OP_LOADI, &&L_OP_LOADSYM, &&L_OP_LOADNIL,
964
+ &&L_OP_LOADSELF, &&L_OP_LOADT, &&L_OP_LOADF,
965
+ &&L_OP_GETGLOBAL, &&L_OP_SETGLOBAL, &&L_OP_GETSPECIAL, &&L_OP_SETSPECIAL,
966
+ &&L_OP_GETIV, &&L_OP_SETIV, &&L_OP_GETCV, &&L_OP_SETCV,
967
+ &&L_OP_GETCONST, &&L_OP_SETCONST, &&L_OP_GETMCNST, &&L_OP_SETMCNST,
968
+ &&L_OP_GETUPVAR, &&L_OP_SETUPVAR,
969
+ &&L_OP_JMP, &&L_OP_JMPIF, &&L_OP_JMPNOT,
970
+ &&L_OP_ONERR, &&L_OP_RESCUE, &&L_OP_POPERR, &&L_OP_RAISE, &&L_OP_EPUSH, &&L_OP_EPOP,
971
+ &&L_OP_SEND, &&L_OP_SENDB, &&L_OP_FSEND,
972
+ &&L_OP_CALL, &&L_OP_SUPER, &&L_OP_ARGARY, &&L_OP_ENTER,
973
+ &&L_OP_KARG, &&L_OP_KDICT, &&L_OP_RETURN, &&L_OP_TAILCALL, &&L_OP_BLKPUSH,
974
+ &&L_OP_ADD, &&L_OP_ADDI, &&L_OP_SUB, &&L_OP_SUBI, &&L_OP_MUL, &&L_OP_DIV,
975
+ &&L_OP_EQ, &&L_OP_LT, &&L_OP_LE, &&L_OP_GT, &&L_OP_GE,
976
+ &&L_OP_ARRAY, &&L_OP_ARYCAT, &&L_OP_ARYPUSH, &&L_OP_AREF, &&L_OP_ASET, &&L_OP_APOST,
977
+ &&L_OP_STRING, &&L_OP_STRCAT, &&L_OP_HASH,
978
+ &&L_OP_LAMBDA, &&L_OP_RANGE, &&L_OP_OCLASS,
979
+ &&L_OP_CLASS, &&L_OP_MODULE, &&L_OP_EXEC,
980
+ &&L_OP_METHOD, &&L_OP_SCLASS, &&L_OP_TCLASS,
981
+ &&L_OP_DEBUG, &&L_OP_STOP, &&L_OP_ERR,
982
+ };
983
+ #endif
984
+
985
+ mrb_bool exc_catched = FALSE;
986
+ RETRY_TRY_BLOCK:
987
+
988
+ MRB_TRY(&c_jmp) {
989
+
990
+ if (exc_catched) {
991
+ exc_catched = FALSE;
992
+ if (mrb->exc && mrb->exc->tt == MRB_TT_BREAK)
993
+ goto L_BREAK;
994
+ goto L_RAISE;
995
+ }
996
+ mrb->jmp = &c_jmp;
997
+ mrb->c->ci->proc = proc;
998
+ mrb->c->ci->nregs = irep->nregs;
999
+
1000
+ #define regs (mrb->c->stack)
1001
+ INIT_DISPATCH {
1002
+ CASE(OP_NOP) {
1003
+ /* do nothing */
1004
+ NEXT;
1005
+ }
1006
+
1007
+ CASE(OP_MOVE) {
1008
+ /* A B R(A) := R(B) */
1009
+ int a = GETARG_A(i);
1010
+ int b = GETARG_B(i);
1011
+ regs[a] = regs[b];
1012
+ NEXT;
1013
+ }
1014
+
1015
+ CASE(OP_LOADL) {
1016
+ /* A Bx R(A) := Pool(Bx) */
1017
+ int a = GETARG_A(i);
1018
+ int bx = GETARG_Bx(i);
1019
+ #ifdef MRB_WORD_BOXING
1020
+ mrb_value val = pool[bx];
1021
+ #ifndef MRB_WITHOUT_FLOAT
1022
+ if (mrb_float_p(val)) {
1023
+ val = mrb_float_value(mrb, mrb_float(val));
1024
+ }
1025
+ #endif
1026
+ regs[a] = val;
1027
+ #else
1028
+ regs[a] = pool[bx];
1029
+ #endif
1030
+ NEXT;
1031
+ }
1032
+
1033
+ CASE(OP_LOADI) {
1034
+ /* A sBx R(A) := sBx */
1035
+ int a = GETARG_A(i);
1036
+ mrb_int bx = GETARG_sBx(i);
1037
+ SET_INT_VALUE(regs[a], bx);
1038
+ NEXT;
1039
+ }
1040
+
1041
+ CASE(OP_LOADSYM) {
1042
+ /* A Bx R(A) := Syms(Bx) */
1043
+ int a = GETARG_A(i);
1044
+ int bx = GETARG_Bx(i);
1045
+ SET_SYM_VALUE(regs[a], syms[bx]);
1046
+ NEXT;
1047
+ }
1048
+
1049
+ CASE(OP_LOADSELF) {
1050
+ /* A R(A) := self */
1051
+ int a = GETARG_A(i);
1052
+ regs[a] = regs[0];
1053
+ NEXT;
1054
+ }
1055
+
1056
+ CASE(OP_LOADT) {
1057
+ /* A R(A) := true */
1058
+ int a = GETARG_A(i);
1059
+ SET_TRUE_VALUE(regs[a]);
1060
+ NEXT;
1061
+ }
1062
+
1063
+ CASE(OP_LOADF) {
1064
+ /* A R(A) := false */
1065
+ int a = GETARG_A(i);
1066
+ SET_FALSE_VALUE(regs[a]);
1067
+ NEXT;
1068
+ }
1069
+
1070
+ CASE(OP_GETGLOBAL) {
1071
+ /* A Bx R(A) := getglobal(Syms(Bx)) */
1072
+ int a = GETARG_A(i);
1073
+ int bx = GETARG_Bx(i);
1074
+ mrb_value val = mrb_gv_get(mrb, syms[bx]);
1075
+ regs[a] = val;
1076
+ NEXT;
1077
+ }
1078
+
1079
+ CASE(OP_SETGLOBAL) {
1080
+ /* A Bx setglobal(Syms(Bx), R(A)) */
1081
+ int a = GETARG_A(i);
1082
+ int bx = GETARG_Bx(i);
1083
+ mrb_gv_set(mrb, syms[bx], regs[a]);
1084
+ NEXT;
1085
+ }
1086
+
1087
+ CASE(OP_GETSPECIAL) {
1088
+ /* A Bx R(A) := Special[Bx] */
1089
+ int a = GETARG_A(i);
1090
+ int bx = GETARG_Bx(i);
1091
+ mrb_value val = mrb_vm_special_get(mrb, bx);
1092
+ regs[a] = val;
1093
+ NEXT;
1094
+ }
1095
+
1096
+ CASE(OP_SETSPECIAL) {
1097
+ /* A Bx Special[Bx] := R(A) */
1098
+ int a = GETARG_A(i);
1099
+ int bx = GETARG_Bx(i);
1100
+ mrb_vm_special_set(mrb, bx, regs[a]);
1101
+ NEXT;
1102
+ }
1103
+
1104
+ CASE(OP_GETIV) {
1105
+ /* A Bx R(A) := ivget(Bx) */
1106
+ int a = GETARG_A(i);
1107
+ int bx = GETARG_Bx(i);
1108
+ mrb_value val = mrb_vm_iv_get(mrb, syms[bx]);
1109
+ regs[a] = val;
1110
+ NEXT;
1111
+ }
1112
+
1113
+ CASE(OP_SETIV) {
1114
+ /* A Bx ivset(Syms(Bx),R(A)) */
1115
+ int a = GETARG_A(i);
1116
+ int bx = GETARG_Bx(i);
1117
+ mrb_vm_iv_set(mrb, syms[bx], regs[a]);
1118
+ NEXT;
1119
+ }
1120
+
1121
+ CASE(OP_GETCV) {
1122
+ /* A Bx R(A) := cvget(Syms(Bx)) */
1123
+ int a = GETARG_A(i);
1124
+ int bx = GETARG_Bx(i);
1125
+ mrb_value val;
1126
+ ERR_PC_SET(mrb, pc);
1127
+ val = mrb_vm_cv_get(mrb, syms[bx]);
1128
+ ERR_PC_CLR(mrb);
1129
+ regs[a] = val;
1130
+ NEXT;
1131
+ }
1132
+
1133
+ CASE(OP_SETCV) {
1134
+ /* A Bx cvset(Syms(Bx),R(A)) */
1135
+ int a = GETARG_A(i);
1136
+ int bx = GETARG_Bx(i);
1137
+ mrb_vm_cv_set(mrb, syms[bx], regs[a]);
1138
+ NEXT;
1139
+ }
1140
+
1141
+ CASE(OP_GETCONST) {
1142
+ /* A Bx R(A) := constget(Syms(Bx)) */
1143
+ mrb_value val;
1144
+ int a = GETARG_A(i);
1145
+ int bx = GETARG_Bx(i);
1146
+ mrb_sym sym = syms[bx];
1147
+
1148
+ ERR_PC_SET(mrb, pc);
1149
+ val = mrb_vm_const_get(mrb, sym);
1150
+ ERR_PC_CLR(mrb);
1151
+ regs[a] = val;
1152
+ NEXT;
1153
+ }
1154
+
1155
+ CASE(OP_SETCONST) {
1156
+ /* A Bx constset(Syms(Bx),R(A)) */
1157
+ int a = GETARG_A(i);
1158
+ int bx = GETARG_Bx(i);
1159
+ mrb_vm_const_set(mrb, syms[bx], regs[a]);
1160
+ NEXT;
1161
+ }
1162
+
1163
+ CASE(OP_GETMCNST) {
1164
+ /* A Bx R(A) := R(A)::Syms(Bx) */
1165
+ mrb_value val;
1166
+ int a = GETARG_A(i);
1167
+ int bx = GETARG_Bx(i);
1168
+
1169
+ ERR_PC_SET(mrb, pc);
1170
+ val = mrb_const_get(mrb, regs[a], syms[bx]);
1171
+ ERR_PC_CLR(mrb);
1172
+ regs[a] = val;
1173
+ NEXT;
1174
+ }
1175
+
1176
+ CASE(OP_SETMCNST) {
1177
+ /* A Bx R(A+1)::Syms(Bx) := R(A) */
1178
+ int a = GETARG_A(i);
1179
+ int bx = GETARG_Bx(i);
1180
+ mrb_const_set(mrb, regs[a+1], syms[bx], regs[a]);
1181
+ NEXT;
1182
+ }
1183
+
1184
+ CASE(OP_GETUPVAR) {
1185
+ /* A B C R(A) := uvget(B,C) */
1186
+ int a = GETARG_A(i);
1187
+ int b = GETARG_B(i);
1188
+ int c = GETARG_C(i);
1189
+ mrb_value *regs_a = regs + a;
1190
+ struct REnv *e = uvenv(mrb, c);
1191
+
1192
+ if (!e) {
1193
+ *regs_a = mrb_nil_value();
1194
+ }
1195
+ else {
1196
+ *regs_a = e->stack[b];
1197
+ }
1198
+ NEXT;
1199
+ }
1200
+
1201
+ CASE(OP_SETUPVAR) {
1202
+ /* A B C uvset(B,C,R(A)) */
1203
+ int a = GETARG_A(i);
1204
+ int b = GETARG_B(i);
1205
+ int c = GETARG_C(i);
1206
+
1207
+ struct REnv *e = uvenv(mrb, c);
1208
+
1209
+ if (e) {
1210
+ mrb_value *regs_a = regs + a;
1211
+
1212
+ if (b < MRB_ENV_STACK_LEN(e)) {
1213
+ e->stack[b] = *regs_a;
1214
+ mrb_write_barrier(mrb, (struct RBasic*)e);
1215
+ }
1216
+ }
1217
+ NEXT;
1218
+ }
1219
+
1220
+ CASE(OP_JMP) {
1221
+ /* sBx pc+=sBx */
1222
+ int sbx = GETARG_sBx(i);
1223
+ pc += sbx;
1224
+ JUMP;
1225
+ }
1226
+
1227
+ CASE(OP_JMPIF) {
1228
+ /* A sBx if R(A) pc+=sBx */
1229
+ int a = GETARG_A(i);
1230
+ int sbx = GETARG_sBx(i);
1231
+ if (mrb_test(regs[a])) {
1232
+ pc += sbx;
1233
+ JUMP;
1234
+ }
1235
+ NEXT;
1236
+ }
1237
+
1238
+ CASE(OP_JMPNOT) {
1239
+ /* A sBx if !R(A) pc+=sBx */
1240
+ int a = GETARG_A(i);
1241
+ int sbx = GETARG_sBx(i);
1242
+ if (!mrb_test(regs[a])) {
1243
+ pc += sbx;
1244
+ JUMP;
1245
+ }
1246
+ NEXT;
1247
+ }
1248
+
1249
+ CASE(OP_ONERR) {
1250
+ /* sBx pc+=sBx on exception */
1251
+ int sbx = GETARG_sBx(i);
1252
+ if (mrb->c->rsize <= mrb->c->ci->ridx) {
1253
+ if (mrb->c->rsize == 0) mrb->c->rsize = RESCUE_STACK_INIT_SIZE;
1254
+ else mrb->c->rsize *= 2;
1255
+ mrb->c->rescue = (mrb_code **)mrb_realloc(mrb, mrb->c->rescue, sizeof(mrb_code*) * mrb->c->rsize);
1256
+ }
1257
+ mrb->c->rescue[mrb->c->ci->ridx++] = pc + sbx;
1258
+ NEXT;
1259
+ }
1260
+
1261
+ CASE(OP_RESCUE) {
1262
+ /* A B R(A) := exc; clear(exc); R(B) := matched (bool) */
1263
+ int a = GETARG_A(i);
1264
+ int b = GETARG_B(i);
1265
+ int c = GETARG_C(i);
1266
+ mrb_value exc;
1267
+
1268
+ if (c == 0) {
1269
+ exc = mrb_obj_value(mrb->exc);
1270
+ mrb->exc = 0;
1271
+ }
1272
+ else { /* continued; exc taken from R(A) */
1273
+ exc = regs[a];
1274
+ }
1275
+ if (b != 0) {
1276
+ mrb_value e = regs[b];
1277
+ struct RClass *ec;
1278
+
1279
+ switch (mrb_type(e)) {
1280
+ case MRB_TT_CLASS:
1281
+ case MRB_TT_MODULE:
1282
+ break;
1283
+ default:
1284
+ {
1285
+ mrb_value exc;
1286
+
1287
+ exc = mrb_exc_new_str_lit(mrb, E_TYPE_ERROR,
1288
+ "class or module required for rescue clause");
1289
+ mrb_exc_set(mrb, exc);
1290
+ goto L_RAISE;
1291
+ }
1292
+ }
1293
+ ec = mrb_class_ptr(e);
1294
+ regs[b] = mrb_bool_value(mrb_obj_is_kind_of(mrb, exc, ec));
1295
+ }
1296
+ if (a != 0 && c == 0) {
1297
+ regs[a] = exc;
1298
+ }
1299
+ NEXT;
1300
+ }
1301
+
1302
+ CASE(OP_POPERR) {
1303
+ /* A A.times{rescue_pop()} */
1304
+ int a = GETARG_A(i);
1305
+
1306
+ mrb->c->ci->ridx -= a;
1307
+ NEXT;
1308
+ }
1309
+
1310
+ CASE(OP_RAISE) {
1311
+ /* A raise(R(A)) */
1312
+ int a = GETARG_A(i);
1313
+
1314
+ mrb_exc_set(mrb, regs[a]);
1315
+ goto L_RAISE;
1316
+ }
1317
+
1318
+ CASE(OP_EPUSH) {
1319
+ /* Bx ensure_push(SEQ[Bx]) */
1320
+ int bx = GETARG_Bx(i);
1321
+ struct RProc *p;
1322
+
1323
+ p = mrb_closure_new(mrb, irep->reps[bx]);
1324
+ /* push ensure_stack */
1325
+ if (mrb->c->esize <= mrb->c->eidx+1) {
1326
+ if (mrb->c->esize == 0) mrb->c->esize = ENSURE_STACK_INIT_SIZE;
1327
+ else mrb->c->esize *= 2;
1328
+ mrb->c->ensure = (struct RProc **)mrb_realloc(mrb, mrb->c->ensure, sizeof(struct RProc*) * mrb->c->esize);
1329
+ }
1330
+ mrb->c->ensure[mrb->c->eidx++] = p;
1331
+ mrb->c->ensure[mrb->c->eidx] = NULL;
1332
+ mrb_gc_arena_restore(mrb, ai);
1333
+ NEXT;
1334
+ }
1335
+
1336
+ CASE(OP_EPOP) {
1337
+ /* A A.times{ensure_pop().call} */
1338
+ int a = GETARG_A(i);
1339
+ mrb_callinfo *ci = mrb->c->ci;
1340
+ int n, epos = ci->epos;
1341
+ mrb_value self = regs[0];
1342
+ struct RClass *target_class = ci->target_class;
1343
+
1344
+ if (mrb->c->eidx <= epos) {
1345
+ NEXT;
1346
+ }
1347
+
1348
+ if (a > mrb->c->eidx - epos)
1349
+ a = mrb->c->eidx - epos;
1350
+ pc = pc + 1;
1351
+ for (n=0; n<a; n++) {
1352
+ proc = mrb->c->ensure[epos+n];
1353
+ mrb->c->ensure[epos+n] = NULL;
1354
+ irep = proc->body.irep;
1355
+ ci = cipush(mrb);
1356
+ ci->mid = ci[-1].mid;
1357
+ ci->argc = 0;
1358
+ ci->proc = proc;
1359
+ ci->stackent = mrb->c->stack;
1360
+ ci->nregs = irep->nregs;
1361
+ ci->target_class = target_class;
1362
+ ci->pc = pc;
1363
+ ci->acc = ci[-1].nregs;
1364
+ mrb->c->stack += ci->acc;
1365
+ stack_extend(mrb, ci->nregs);
1366
+ regs[0] = self;
1367
+ pc = irep->iseq;
1368
+ }
1369
+ pool = irep->pool;
1370
+ syms = irep->syms;
1371
+ mrb->c->eidx = epos;
1372
+ JUMP;
1373
+ }
1374
+
1375
+ CASE(OP_LOADNIL) {
1376
+ /* A R(A) := nil */
1377
+ int a = GETARG_A(i);
1378
+
1379
+ SET_NIL_VALUE(regs[a]);
1380
+ NEXT;
1381
+ }
1382
+
1383
+ CASE(OP_SENDB) {
1384
+ /* A B C R(A) := call(R(A),Syms(B),R(A+1),...,R(A+C),&R(A+C+1))*/
1385
+ /* fall through */
1386
+ };
1387
+
1388
+ L_SEND:
1389
+ CASE(OP_SEND) {
1390
+ /* A B C R(A) := call(R(A),Syms(B),R(A+1),...,R(A+C)) */
1391
+ int a = GETARG_A(i);
1392
+ int n = GETARG_C(i);
1393
+ int argc = (n == CALL_MAXARGS) ? -1 : n;
1394
+ int bidx = (argc < 0) ? a+2 : a+n+1;
1395
+ mrb_method_t m;
1396
+ struct RClass *c;
1397
+ mrb_callinfo *ci = mrb->c->ci;
1398
+ mrb_value recv, blk;
1399
+ mrb_sym mid = syms[GETARG_B(i)];
1400
+
1401
+ mrb_assert(bidx < ci->nregs);
1402
+
1403
+ recv = regs[a];
1404
+ if (GET_OPCODE(i) != OP_SENDB) {
1405
+ SET_NIL_VALUE(regs[bidx]);
1406
+ blk = regs[bidx];
1407
+ }
1408
+ else {
1409
+ blk = regs[bidx];
1410
+ if (!mrb_nil_p(blk) && mrb_type(blk) != MRB_TT_PROC) {
1411
+ blk = mrb_convert_type(mrb, blk, MRB_TT_PROC, "Proc", "to_proc");
1412
+ /* The stack might have been reallocated during mrb_convert_type(),
1413
+ see #3622 */
1414
+ regs[bidx] = blk;
1415
+ }
1416
+ }
1417
+ c = mrb_class(mrb, recv);
1418
+ m = mrb_method_search_vm(mrb, &c, mid);
1419
+ if (MRB_METHOD_UNDEF_P(m)) {
1420
+ mrb_sym missing = mrb_intern_lit(mrb, "method_missing");
1421
+ m = mrb_method_search_vm(mrb, &c, missing);
1422
+ if (MRB_METHOD_UNDEF_P(m) || (missing == mrb->c->ci->mid && mrb_obj_eq(mrb, regs[0], recv))) {
1423
+ mrb_value args = (argc < 0) ? regs[a+1] : mrb_ary_new_from_values(mrb, n, regs+a+1);
1424
+ ERR_PC_SET(mrb, pc);
1425
+ mrb_method_missing(mrb, mid, recv, args);
1426
+ }
1427
+ if (argc >= 0) {
1428
+ if (a+2 >= irep->nregs) {
1429
+ stack_extend(mrb, a+3);
1430
+ }
1431
+ regs[a+1] = mrb_ary_new_from_values(mrb, n, regs+a+1);
1432
+ regs[a+2] = blk;
1433
+ argc = -1;
1434
+ }
1435
+ mrb_ary_unshift(mrb, regs[a+1], mrb_symbol_value(mid));
1436
+ mid = missing;
1437
+ }
1438
+
1439
+ /* push callinfo */
1440
+ ci = cipush(mrb);
1441
+ ci->mid = mid;
1442
+ ci->stackent = mrb->c->stack;
1443
+ ci->target_class = c;
1444
+ ci->argc = argc;
1445
+
1446
+ ci->pc = pc + 1;
1447
+ ci->acc = a;
1448
+
1449
+ /* prepare stack */
1450
+ mrb->c->stack += a;
1451
+
1452
+ if (MRB_METHOD_CFUNC_P(m)) {
1453
+ ci->nregs = (argc < 0) ? 3 : n+2;
1454
+ if (MRB_METHOD_PROC_P(m)) {
1455
+ struct RProc *p = MRB_METHOD_PROC(m);
1456
+
1457
+ ci->proc = p;
1458
+ recv = p->body.func(mrb, recv);
1459
+ }
1460
+ else {
1461
+ recv = MRB_METHOD_FUNC(m)(mrb, recv);
1462
+ }
1463
+ mrb_gc_arena_restore(mrb, ai);
1464
+ mrb_gc_arena_shrink(mrb, ai);
1465
+ if (mrb->exc) goto L_RAISE;
1466
+ ci = mrb->c->ci;
1467
+ if (GET_OPCODE(i) == OP_SENDB) {
1468
+ if (mrb_type(blk) == MRB_TT_PROC) {
1469
+ struct RProc *p = mrb_proc_ptr(blk);
1470
+ if (p && !MRB_PROC_STRICT_P(p) && MRB_PROC_ENV(p) == ci[-1].env) {
1471
+ p->flags |= MRB_PROC_ORPHAN;
1472
+ }
1473
+ }
1474
+ }
1475
+ if (!ci->target_class) { /* return from context modifying method (resume/yield) */
1476
+ if (ci->acc == CI_ACC_RESUMED) {
1477
+ mrb->jmp = prev_jmp;
1478
+ return recv;
1479
+ }
1480
+ else {
1481
+ mrb_assert(!MRB_PROC_CFUNC_P(ci[-1].proc));
1482
+ proc = ci[-1].proc;
1483
+ irep = proc->body.irep;
1484
+ pool = irep->pool;
1485
+ syms = irep->syms;
1486
+ }
1487
+ }
1488
+ mrb->c->stack[0] = recv;
1489
+ /* pop stackpos */
1490
+ mrb->c->stack = ci->stackent;
1491
+ pc = ci->pc;
1492
+ cipop(mrb);
1493
+ JUMP;
1494
+ }
1495
+ else {
1496
+ /* setup environment for calling method */
1497
+ proc = ci->proc = MRB_METHOD_PROC(m);
1498
+ irep = proc->body.irep;
1499
+ pool = irep->pool;
1500
+ syms = irep->syms;
1501
+ ci->nregs = irep->nregs;
1502
+ stack_extend(mrb, (argc < 0 && ci->nregs < 3) ? 3 : ci->nregs);
1503
+ pc = irep->iseq;
1504
+ JUMP;
1505
+ }
1506
+ }
1507
+
1508
+ CASE(OP_FSEND) {
1509
+ /* A B C R(A) := fcall(R(A),Syms(B),R(A+1),... ,R(A+C-1)) */
1510
+ /* not implemented yet */
1511
+ NEXT;
1512
+ }
1513
+
1514
+ CASE(OP_CALL) {
1515
+ /* A R(A) := self.call(frame.argc, frame.argv) */
1516
+ mrb_callinfo *ci;
1517
+ mrb_value recv = mrb->c->stack[0];
1518
+ struct RProc *m = mrb_proc_ptr(recv);
1519
+
1520
+ /* replace callinfo */
1521
+ ci = mrb->c->ci;
1522
+ ci->target_class = MRB_PROC_TARGET_CLASS(m);
1523
+ ci->proc = m;
1524
+ if (MRB_PROC_ENV_P(m)) {
1525
+ mrb_sym mid;
1526
+ struct REnv *e = MRB_PROC_ENV(m);
1527
+
1528
+ mid = e->mid;
1529
+ if (mid) ci->mid = mid;
1530
+ if (!e->stack) {
1531
+ e->stack = mrb->c->stack;
1532
+ }
1533
+ }
1534
+
1535
+ /* prepare stack */
1536
+ if (MRB_PROC_CFUNC_P(m)) {
1537
+ recv = MRB_PROC_CFUNC(m)(mrb, recv);
1538
+ mrb_gc_arena_restore(mrb, ai);
1539
+ mrb_gc_arena_shrink(mrb, ai);
1540
+ if (mrb->exc) goto L_RAISE;
1541
+ /* pop stackpos */
1542
+ ci = mrb->c->ci;
1543
+ mrb->c->stack = ci->stackent;
1544
+ regs[ci->acc] = recv;
1545
+ pc = ci->pc;
1546
+ cipop(mrb);
1547
+ irep = mrb->c->ci->proc->body.irep;
1548
+ pool = irep->pool;
1549
+ syms = irep->syms;
1550
+ JUMP;
1551
+ }
1552
+ else {
1553
+ /* setup environment for calling method */
1554
+ proc = m;
1555
+ irep = m->body.irep;
1556
+ if (!irep) {
1557
+ mrb->c->stack[0] = mrb_nil_value();
1558
+ goto L_RETURN;
1559
+ }
1560
+ pool = irep->pool;
1561
+ syms = irep->syms;
1562
+ ci->nregs = irep->nregs;
1563
+ stack_extend(mrb, ci->nregs);
1564
+ if (ci->argc < 0) {
1565
+ if (irep->nregs > 3) {
1566
+ stack_clear(regs+3, irep->nregs-3);
1567
+ }
1568
+ }
1569
+ else if (ci->argc+2 < irep->nregs) {
1570
+ stack_clear(regs+ci->argc+2, irep->nregs-ci->argc-2);
1571
+ }
1572
+ if (MRB_PROC_ENV_P(m)) {
1573
+ regs[0] = MRB_PROC_ENV(m)->stack[0];
1574
+ }
1575
+ pc = irep->iseq;
1576
+ JUMP;
1577
+ }
1578
+ }
1579
+
1580
+ CASE(OP_SUPER) {
1581
+ /* A C R(A) := super(R(A+1),... ,R(A+C+1)) */
1582
+ int a = GETARG_A(i);
1583
+ int n = GETARG_C(i);
1584
+ int argc = (n == CALL_MAXARGS) ? -1 : n;
1585
+ int bidx = (argc < 0) ? a+2 : a+n+1;
1586
+ mrb_method_t m;
1587
+ struct RClass *c;
1588
+ mrb_callinfo *ci = mrb->c->ci;
1589
+ mrb_value recv, blk;
1590
+ mrb_sym mid = ci->mid;
1591
+ struct RClass* target_class = MRB_PROC_TARGET_CLASS(ci->proc);
1592
+
1593
+ mrb_assert(bidx < ci->nregs);
1594
+
1595
+ if (mid == 0 || !target_class) {
1596
+ mrb_value exc = mrb_exc_new_str_lit(mrb, E_NOMETHOD_ERROR, "super called outside of method");
1597
+ mrb_exc_set(mrb, exc);
1598
+ goto L_RAISE;
1599
+ }
1600
+ if (target_class->tt == MRB_TT_MODULE) {
1601
+ target_class = ci->target_class;
1602
+ if (target_class->tt != MRB_TT_ICLASS) {
1603
+ mrb_value exc = mrb_exc_new_str_lit(mrb, E_RUNTIME_ERROR, "superclass info lost [mruby limitations]");
1604
+ mrb_exc_set(mrb, exc);
1605
+ goto L_RAISE;
1606
+ }
1607
+ }
1608
+ recv = regs[0];
1609
+ if (!mrb_obj_is_kind_of(mrb, recv, target_class)) {
1610
+ mrb_value exc = mrb_exc_new_str_lit(mrb, E_TYPE_ERROR,
1611
+ "self has wrong type to call super in this context");
1612
+ mrb_exc_set(mrb, exc);
1613
+ goto L_RAISE;
1614
+ }
1615
+ blk = regs[bidx];
1616
+ if (!mrb_nil_p(blk) && mrb_type(blk) != MRB_TT_PROC) {
1617
+ blk = mrb_convert_type(mrb, blk, MRB_TT_PROC, "Proc", "to_proc");
1618
+ /* The stack or ci stack might have been reallocated during
1619
+ mrb_convert_type(), see #3622 and #3784 */
1620
+ regs[bidx] = blk;
1621
+ ci = mrb->c->ci;
1622
+ }
1623
+ c = target_class->super;
1624
+ m = mrb_method_search_vm(mrb, &c, mid);
1625
+ if (MRB_METHOD_UNDEF_P(m)) {
1626
+ mrb_sym missing = mrb_intern_lit(mrb, "method_missing");
1627
+
1628
+ if (mid != missing) {
1629
+ c = mrb_class(mrb, recv);
1630
+ }
1631
+ m = mrb_method_search_vm(mrb, &c, missing);
1632
+ if (MRB_METHOD_UNDEF_P(m)) {
1633
+ mrb_value args = (argc < 0) ? regs[a+1] : mrb_ary_new_from_values(mrb, n, regs+a+1);
1634
+ ERR_PC_SET(mrb, pc);
1635
+ mrb_method_missing(mrb, mid, recv, args);
1636
+ }
1637
+ mid = missing;
1638
+ if (argc >= 0) {
1639
+ if (a+2 >= ci->nregs) {
1640
+ stack_extend(mrb, a+3);
1641
+ }
1642
+ regs[a+1] = mrb_ary_new_from_values(mrb, n, regs+a+1);
1643
+ regs[a+2] = blk;
1644
+ argc = -1;
1645
+ }
1646
+ mrb_ary_unshift(mrb, regs[a+1], mrb_symbol_value(ci->mid));
1647
+ }
1648
+
1649
+ /* push callinfo */
1650
+ ci = cipush(mrb);
1651
+ ci->mid = mid;
1652
+ ci->stackent = mrb->c->stack;
1653
+ ci->target_class = c;
1654
+ ci->pc = pc + 1;
1655
+ ci->argc = argc;
1656
+
1657
+ /* prepare stack */
1658
+ mrb->c->stack += a;
1659
+ mrb->c->stack[0] = recv;
1660
+
1661
+ if (MRB_METHOD_CFUNC_P(m)) {
1662
+ mrb_value v;
1663
+ ci->nregs = (argc < 0) ? 3 : n+2;
1664
+ v = MRB_METHOD_CFUNC(m)(mrb, recv);
1665
+ mrb_gc_arena_restore(mrb, ai);
1666
+ if (mrb->exc) goto L_RAISE;
1667
+ ci = mrb->c->ci;
1668
+ if (!ci->target_class) { /* return from context modifying method (resume/yield) */
1669
+ if (ci->acc == CI_ACC_RESUMED) {
1670
+ mrb->jmp = prev_jmp;
1671
+ return v;
1672
+ }
1673
+ else {
1674
+ mrb_assert(!MRB_PROC_CFUNC_P(ci[-1].proc));
1675
+ proc = ci[-1].proc;
1676
+ irep = proc->body.irep;
1677
+ pool = irep->pool;
1678
+ syms = irep->syms;
1679
+ }
1680
+ }
1681
+ mrb->c->stack[0] = v;
1682
+ /* pop stackpos */
1683
+ mrb->c->stack = ci->stackent;
1684
+ pc = ci->pc;
1685
+ cipop(mrb);
1686
+ JUMP;
1687
+ }
1688
+ else {
1689
+ /* fill callinfo */
1690
+ ci->acc = a;
1691
+
1692
+ /* setup environment for calling method */
1693
+ proc = ci->proc = MRB_METHOD_PROC(m);
1694
+ irep = proc->body.irep;
1695
+ pool = irep->pool;
1696
+ syms = irep->syms;
1697
+ ci->nregs = irep->nregs;
1698
+ stack_extend(mrb, (argc < 0 && ci->nregs < 3) ? 3 : ci->nregs);
1699
+ pc = irep->iseq;
1700
+ JUMP;
1701
+ }
1702
+ }
1703
+
1704
+ CASE(OP_ARGARY) {
1705
+ /* A Bx R(A) := argument array (16=6:1:5:4) */
1706
+ int a = GETARG_A(i);
1707
+ int bx = GETARG_Bx(i);
1708
+ int m1 = (bx>>10)&0x3f;
1709
+ int r = (bx>>9)&0x1;
1710
+ int m2 = (bx>>4)&0x1f;
1711
+ int lv = (bx>>0)&0xf;
1712
+ mrb_value *stack;
1713
+
1714
+ if (mrb->c->ci->mid == 0 || mrb->c->ci->target_class == NULL) {
1715
+ mrb_value exc;
1716
+
1717
+ L_NOSUPER:
1718
+ exc = mrb_exc_new_str_lit(mrb, E_NOMETHOD_ERROR, "super called outside of method");
1719
+ mrb_exc_set(mrb, exc);
1720
+ goto L_RAISE;
1721
+ }
1722
+ if (lv == 0) stack = regs + 1;
1723
+ else {
1724
+ struct REnv *e = uvenv(mrb, lv-1);
1725
+ if (!e) goto L_NOSUPER;
1726
+ if (MRB_ENV_STACK_LEN(e) <= m1+r+m2+1)
1727
+ goto L_NOSUPER;
1728
+ stack = e->stack + 1;
1729
+ }
1730
+ if (r == 0) {
1731
+ regs[a] = mrb_ary_new_from_values(mrb, m1+m2, stack);
1732
+ }
1733
+ else {
1734
+ mrb_value *pp = NULL;
1735
+ struct RArray *rest;
1736
+ int len = 0;
1737
+
1738
+ if (mrb_array_p(stack[m1])) {
1739
+ struct RArray *ary = mrb_ary_ptr(stack[m1]);
1740
+
1741
+ pp = ARY_PTR(ary);
1742
+ len = (int)ARY_LEN(ary);
1743
+ }
1744
+ regs[a] = mrb_ary_new_capa(mrb, m1+len+m2);
1745
+ rest = mrb_ary_ptr(regs[a]);
1746
+ if (m1 > 0) {
1747
+ stack_copy(ARY_PTR(rest), stack, m1);
1748
+ }
1749
+ if (len > 0) {
1750
+ stack_copy(ARY_PTR(rest)+m1, pp, len);
1751
+ }
1752
+ if (m2 > 0) {
1753
+ stack_copy(ARY_PTR(rest)+m1+len, stack+m1+1, m2);
1754
+ }
1755
+ ARY_SET_LEN(rest, m1+len+m2);
1756
+ }
1757
+ regs[a+1] = stack[m1+r+m2];
1758
+ mrb_gc_arena_restore(mrb, ai);
1759
+ NEXT;
1760
+ }
1761
+
1762
+ CASE(OP_ENTER) {
1763
+ /* Ax arg setup according to flags (23=5:5:1:5:5:1:1) */
1764
+ /* number of optional arguments times OP_JMP should follow */
1765
+ mrb_aspec ax = GETARG_Ax(i);
1766
+ int m1 = MRB_ASPEC_REQ(ax);
1767
+ int o = MRB_ASPEC_OPT(ax);
1768
+ int r = MRB_ASPEC_REST(ax);
1769
+ int m2 = MRB_ASPEC_POST(ax);
1770
+ /* unused
1771
+ int k = MRB_ASPEC_KEY(ax);
1772
+ int kd = MRB_ASPEC_KDICT(ax);
1773
+ int b = MRB_ASPEC_BLOCK(ax);
1774
+ */
1775
+ int argc = mrb->c->ci->argc;
1776
+ mrb_value *argv = regs+1;
1777
+ mrb_value *argv0 = argv;
1778
+ int len = m1 + o + r + m2;
1779
+ mrb_value *blk = &argv[argc < 0 ? 1 : argc];
1780
+
1781
+ if (argc < 0) {
1782
+ struct RArray *ary = mrb_ary_ptr(regs[1]);
1783
+ argv = ARY_PTR(ary);
1784
+ argc = (int)ARY_LEN(ary);
1785
+ mrb_gc_protect(mrb, regs[1]);
1786
+ }
1787
+ if (mrb->c->ci->proc && MRB_PROC_STRICT_P(mrb->c->ci->proc)) {
1788
+ if (argc >= 0) {
1789
+ if (argc < m1 + m2 || (r == 0 && argc > len)) {
1790
+ argnum_error(mrb, m1+m2);
1791
+ goto L_RAISE;
1792
+ }
1793
+ }
1794
+ }
1795
+ else if (len > 1 && argc == 1 && mrb_array_p(argv[0])) {
1796
+ mrb_gc_protect(mrb, argv[0]);
1797
+ argc = (int)RARRAY_LEN(argv[0]);
1798
+ argv = RARRAY_PTR(argv[0]);
1799
+ }
1800
+ if (argc < len) {
1801
+ int mlen = m2;
1802
+ if (argc < m1+m2) {
1803
+ if (m1 < argc)
1804
+ mlen = argc - m1;
1805
+ else
1806
+ mlen = 0;
1807
+ }
1808
+ regs[len+1] = *blk; /* move block */
1809
+ SET_NIL_VALUE(regs[argc+1]);
1810
+ if (argv0 != argv) {
1811
+ value_move(&regs[1], argv, argc-mlen); /* m1 + o */
1812
+ }
1813
+ if (argc < m1) {
1814
+ stack_clear(&regs[argc+1], m1-argc);
1815
+ }
1816
+ if (mlen) {
1817
+ value_move(&regs[len-m2+1], &argv[argc-mlen], mlen);
1818
+ }
1819
+ if (mlen < m2) {
1820
+ stack_clear(&regs[len-m2+mlen+1], m2-mlen);
1821
+ }
1822
+ if (r) {
1823
+ regs[m1+o+1] = mrb_ary_new_capa(mrb, 0);
1824
+ }
1825
+ if (o == 0 || argc < m1+m2) pc++;
1826
+ else
1827
+ pc += argc - m1 - m2 + 1;
1828
+ }
1829
+ else {
1830
+ int rnum = 0;
1831
+ if (argv0 != argv) {
1832
+ regs[len+1] = *blk; /* move block */
1833
+ value_move(&regs[1], argv, m1+o);
1834
+ }
1835
+ if (r) {
1836
+ rnum = argc-m1-o-m2;
1837
+ regs[m1+o+1] = mrb_ary_new_from_values(mrb, rnum, argv+m1+o);
1838
+ }
1839
+ if (m2) {
1840
+ if (argc-m2 > m1) {
1841
+ value_move(&regs[m1+o+r+1], &argv[m1+o+rnum], m2);
1842
+ }
1843
+ }
1844
+ if (argv0 == argv) {
1845
+ regs[len+1] = *blk; /* move block */
1846
+ }
1847
+ pc += o + 1;
1848
+ }
1849
+ mrb->c->ci->argc = len;
1850
+ /* clear local (but non-argument) variables */
1851
+ if (irep->nlocals-len-2 > 0) {
1852
+ stack_clear(&regs[len+2], irep->nlocals-len-2);
1853
+ }
1854
+ JUMP;
1855
+ }
1856
+
1857
+ CASE(OP_KARG) {
1858
+ /* A B C R(A) := kdict[Syms(B)]; if C kdict.rm(Syms(B)) */
1859
+ /* if C == 2; raise unless kdict.empty? */
1860
+ /* OP_JMP should follow to skip init code */
1861
+ NEXT;
1862
+ }
1863
+
1864
+ CASE(OP_KDICT) {
1865
+ /* A C R(A) := kdict */
1866
+ NEXT;
1867
+ }
1868
+
1869
+ L_RETURN:
1870
+ i = MKOP_AB(OP_RETURN, GETARG_A(i), OP_R_NORMAL);
1871
+ /* fall through */
1872
+ CASE(OP_RETURN) {
1873
+ /* A B return R(A) (B=normal,in-block return/break) */
1874
+ mrb_callinfo *ci;
1875
+
1876
+ #define ecall_adjust() do {\
1877
+ ptrdiff_t cioff = ci - mrb->c->cibase;\
1878
+ ecall(mrb);\
1879
+ ci = mrb->c->cibase + cioff;\
1880
+ } while (0)
1881
+
1882
+ ci = mrb->c->ci;
1883
+ if (ci->mid) {
1884
+ mrb_value blk;
1885
+
1886
+ if (ci->argc < 0) {
1887
+ blk = regs[2];
1888
+ }
1889
+ else {
1890
+ blk = regs[ci->argc+1];
1891
+ }
1892
+ if (mrb_type(blk) == MRB_TT_PROC) {
1893
+ struct RProc *p = mrb_proc_ptr(blk);
1894
+
1895
+ if (!MRB_PROC_STRICT_P(p) &&
1896
+ ci > mrb->c->cibase && MRB_PROC_ENV(p) == ci[-1].env) {
1897
+ p->flags |= MRB_PROC_ORPHAN;
1898
+ }
1899
+ }
1900
+ }
1901
+
1902
+ if (mrb->exc) {
1903
+ mrb_callinfo *ci0;
1904
+
1905
+ L_RAISE:
1906
+ ci0 = ci = mrb->c->ci;
1907
+ if (ci == mrb->c->cibase) {
1908
+ if (ci->ridx == 0) goto L_FTOP;
1909
+ goto L_RESCUE;
1910
+ }
1911
+ while (ci[0].ridx == ci[-1].ridx) {
1912
+ cipop(mrb);
1913
+ mrb->c->stack = ci->stackent;
1914
+ if (ci->acc == CI_ACC_SKIP && prev_jmp) {
1915
+ mrb->jmp = prev_jmp;
1916
+ MRB_THROW(prev_jmp);
1917
+ }
1918
+ ci = mrb->c->ci;
1919
+ if (ci == mrb->c->cibase) {
1920
+ if (ci->ridx == 0) {
1921
+ L_FTOP: /* fiber top */
1922
+ if (mrb->c == mrb->root_c) {
1923
+ mrb->c->stack = mrb->c->stbase;
1924
+ goto L_STOP;
1925
+ }
1926
+ else {
1927
+ struct mrb_context *c = mrb->c;
1928
+
1929
+ while (c->eidx > ci->epos) {
1930
+ ecall_adjust();
1931
+ }
1932
+ if (c->fib) {
1933
+ mrb_write_barrier(mrb, (struct RBasic*)c->fib);
1934
+ }
1935
+ mrb->c->status = MRB_FIBER_TERMINATED;
1936
+ mrb->c = c->prev;
1937
+ c->prev = NULL;
1938
+ goto L_RAISE;
1939
+ }
1940
+ }
1941
+ break;
1942
+ }
1943
+ /* call ensure only when we skip this callinfo */
1944
+ if (ci[0].ridx == ci[-1].ridx) {
1945
+ while (mrb->c->eidx > ci->epos) {
1946
+ ecall_adjust();
1947
+ }
1948
+ }
1949
+ }
1950
+ L_RESCUE:
1951
+ if (ci->ridx == 0) goto L_STOP;
1952
+ proc = ci->proc;
1953
+ irep = proc->body.irep;
1954
+ pool = irep->pool;
1955
+ syms = irep->syms;
1956
+ if (ci < ci0) {
1957
+ mrb->c->stack = ci[1].stackent;
1958
+ }
1959
+ stack_extend(mrb, irep->nregs);
1960
+ pc = mrb->c->rescue[--ci->ridx];
1961
+ }
1962
+ else {
1963
+ int acc;
1964
+ mrb_value v;
1965
+ struct RProc *dst;
1966
+
1967
+ ci = mrb->c->ci;
1968
+ v = regs[GETARG_A(i)];
1969
+ mrb_gc_protect(mrb, v);
1970
+ switch (GETARG_B(i)) {
1971
+ case OP_R_RETURN:
1972
+ /* Fall through to OP_R_NORMAL otherwise */
1973
+ if (ci->acc >=0 && MRB_PROC_ENV_P(proc) && !MRB_PROC_STRICT_P(proc)) {
1974
+ mrb_callinfo *cibase = mrb->c->cibase;
1975
+ dst = top_proc(mrb, proc);
1976
+
1977
+ if (MRB_PROC_ENV_P(dst)) {
1978
+ struct REnv *e = MRB_PROC_ENV(dst);
1979
+
1980
+ if (!MRB_ENV_STACK_SHARED_P(e) || e->cxt != mrb->c) {
1981
+ localjump_error(mrb, LOCALJUMP_ERROR_RETURN);
1982
+ goto L_RAISE;
1983
+ }
1984
+ }
1985
+ while (cibase <= ci && ci->proc != dst) {
1986
+ if (ci->acc < 0) {
1987
+ localjump_error(mrb, LOCALJUMP_ERROR_RETURN);
1988
+ goto L_RAISE;
1989
+ }
1990
+ ci--;
1991
+ }
1992
+ if (ci <= cibase) {
1993
+ localjump_error(mrb, LOCALJUMP_ERROR_RETURN);
1994
+ goto L_RAISE;
1995
+ }
1996
+ break;
1997
+ }
1998
+ case OP_R_NORMAL:
1999
+ NORMAL_RETURN:
2000
+ if (ci == mrb->c->cibase) {
2001
+ struct mrb_context *c;
2002
+
2003
+ if (!mrb->c->prev) { /* toplevel return */
2004
+ localjump_error(mrb, LOCALJUMP_ERROR_RETURN);
2005
+ goto L_RAISE;
2006
+ }
2007
+ if (mrb->c->prev->ci == mrb->c->prev->cibase) {
2008
+ mrb_value exc = mrb_exc_new_str_lit(mrb, E_FIBER_ERROR, "double resume");
2009
+ mrb_exc_set(mrb, exc);
2010
+ goto L_RAISE;
2011
+ }
2012
+ while (mrb->c->eidx > 0) {
2013
+ ecall(mrb);
2014
+ }
2015
+ /* automatic yield at the end */
2016
+ c = mrb->c;
2017
+ c->status = MRB_FIBER_TERMINATED;
2018
+ mrb->c = c->prev;
2019
+ c->prev = NULL;
2020
+ mrb->c->status = MRB_FIBER_RUNNING;
2021
+ ci = mrb->c->ci;
2022
+ }
2023
+ break;
2024
+ case OP_R_BREAK:
2025
+ if (MRB_PROC_STRICT_P(proc)) goto NORMAL_RETURN;
2026
+ if (MRB_PROC_ORPHAN_P(proc)) {
2027
+ mrb_value exc;
2028
+
2029
+ L_BREAK_ERROR:
2030
+ exc = mrb_exc_new_str_lit(mrb, E_LOCALJUMP_ERROR,
2031
+ "break from proc-closure");
2032
+ mrb_exc_set(mrb, exc);
2033
+ goto L_RAISE;
2034
+ }
2035
+ if (!MRB_PROC_ENV_P(proc) || !MRB_ENV_STACK_SHARED_P(MRB_PROC_ENV(proc))) {
2036
+ goto L_BREAK_ERROR;
2037
+ }
2038
+ else {
2039
+ struct REnv *e = MRB_PROC_ENV(proc);
2040
+
2041
+ if (e == mrb->c->cibase->env && proc != mrb->c->cibase->proc) {
2042
+ goto L_BREAK_ERROR;
2043
+ }
2044
+ if (e->cxt != mrb->c) {
2045
+ goto L_BREAK_ERROR;
2046
+ }
2047
+ }
2048
+ while (mrb->c->eidx > mrb->c->ci->epos) {
2049
+ ecall_adjust();
2050
+ }
2051
+ /* break from fiber block */
2052
+ if (ci == mrb->c->cibase && ci->pc) {
2053
+ struct mrb_context *c = mrb->c;
2054
+
2055
+ mrb->c = c->prev;
2056
+ c->prev = NULL;
2057
+ ci = mrb->c->ci;
2058
+ }
2059
+ if (ci->acc < 0) {
2060
+ mrb_gc_arena_restore(mrb, ai);
2061
+ mrb->c->vmexec = FALSE;
2062
+ mrb->exc = (struct RObject*)break_new(mrb, proc, v);
2063
+ mrb->jmp = prev_jmp;
2064
+ MRB_THROW(prev_jmp);
2065
+ }
2066
+ if (FALSE) {
2067
+ L_BREAK:
2068
+ v = ((struct RBreak*)mrb->exc)->val;
2069
+ proc = ((struct RBreak*)mrb->exc)->proc;
2070
+ mrb->exc = NULL;
2071
+ ci = mrb->c->ci;
2072
+ }
2073
+ mrb->c->stack = ci->stackent;
2074
+ proc = proc->upper;
2075
+ while (mrb->c->cibase < ci && ci[-1].proc != proc) {
2076
+ if (ci[-1].acc == CI_ACC_SKIP) {
2077
+ while (ci < mrb->c->ci) {
2078
+ cipop(mrb);
2079
+ }
2080
+ goto L_BREAK_ERROR;
2081
+ }
2082
+ ci--;
2083
+ }
2084
+ if (ci == mrb->c->cibase) {
2085
+ goto L_BREAK_ERROR;
2086
+ }
2087
+ break;
2088
+ default:
2089
+ /* cannot happen */
2090
+ break;
2091
+ }
2092
+ while (ci < mrb->c->ci) {
2093
+ cipop(mrb);
2094
+ }
2095
+ ci[0].ridx = ci[-1].ridx;
2096
+ while (mrb->c->eidx > ci->epos) {
2097
+ ecall_adjust();
2098
+ }
2099
+ if (mrb->c->vmexec && !ci->target_class) {
2100
+ mrb_gc_arena_restore(mrb, ai);
2101
+ mrb->c->vmexec = FALSE;
2102
+ mrb->jmp = prev_jmp;
2103
+ return v;
2104
+ }
2105
+ acc = ci->acc;
2106
+ mrb->c->stack = ci->stackent;
2107
+ cipop(mrb);
2108
+ if (acc == CI_ACC_SKIP || acc == CI_ACC_DIRECT) {
2109
+ mrb_gc_arena_restore(mrb, ai);
2110
+ mrb->jmp = prev_jmp;
2111
+ return v;
2112
+ }
2113
+ pc = ci->pc;
2114
+ ci = mrb->c->ci;
2115
+ DEBUG(fprintf(stderr, "from :%s\n", mrb_sym2name(mrb, ci->mid)));
2116
+ proc = mrb->c->ci->proc;
2117
+ irep = proc->body.irep;
2118
+ pool = irep->pool;
2119
+ syms = irep->syms;
2120
+
2121
+ regs[acc] = v;
2122
+ mrb_gc_arena_restore(mrb, ai);
2123
+ }
2124
+ JUMP;
2125
+ }
2126
+
2127
+ CASE(OP_TAILCALL) {
2128
+ /* A B C return call(R(A),Syms(B),R(A+1),... ,R(A+C+1)) */
2129
+ int a = GETARG_A(i);
2130
+ int b = GETARG_B(i);
2131
+ int n = GETARG_C(i);
2132
+ mrb_method_t m;
2133
+ struct RClass *c;
2134
+ mrb_callinfo *ci;
2135
+ mrb_value recv;
2136
+ mrb_sym mid = syms[b];
2137
+
2138
+ recv = regs[a];
2139
+ c = mrb_class(mrb, recv);
2140
+ m = mrb_method_search_vm(mrb, &c, mid);
2141
+ if (MRB_METHOD_UNDEF_P(m)) {
2142
+ mrb_value sym = mrb_symbol_value(mid);
2143
+ mrb_sym missing = mrb_intern_lit(mrb, "method_missing");
2144
+ m = mrb_method_search_vm(mrb, &c, missing);
2145
+ if (MRB_METHOD_UNDEF_P(m)) {
2146
+ mrb_value args;
2147
+
2148
+ if (n == CALL_MAXARGS) {
2149
+ args = regs[a+1];
2150
+ }
2151
+ else {
2152
+ args = mrb_ary_new_from_values(mrb, n, regs+a+1);
2153
+ }
2154
+ ERR_PC_SET(mrb, pc);
2155
+ mrb_method_missing(mrb, mid, recv, args);
2156
+ }
2157
+ mid = missing;
2158
+ if (n == CALL_MAXARGS) {
2159
+ mrb_ary_unshift(mrb, regs[a+1], sym);
2160
+ }
2161
+ else {
2162
+ value_move(regs+a+2, regs+a+1, ++n);
2163
+ regs[a+1] = sym;
2164
+ }
2165
+ }
2166
+
2167
+ /* replace callinfo */
2168
+ ci = mrb->c->ci;
2169
+ ci->mid = mid;
2170
+ ci->target_class = c;
2171
+ if (n == CALL_MAXARGS) {
2172
+ ci->argc = -1;
2173
+ }
2174
+ else {
2175
+ ci->argc = n;
2176
+ }
2177
+
2178
+ /* move stack */
2179
+ value_move(mrb->c->stack, &regs[a], ci->argc+1);
2180
+
2181
+ if (MRB_METHOD_CFUNC_P(m)) {
2182
+ mrb_value v = MRB_METHOD_CFUNC(m)(mrb, recv);
2183
+ mrb->c->stack[0] = v;
2184
+ mrb_gc_arena_restore(mrb, ai);
2185
+ goto L_RETURN;
2186
+ }
2187
+ else {
2188
+ /* setup environment for calling method */
2189
+ struct RProc *p = MRB_METHOD_PROC(m);
2190
+ irep = p->body.irep;
2191
+ pool = irep->pool;
2192
+ syms = irep->syms;
2193
+ if (ci->argc < 0) {
2194
+ stack_extend(mrb, (irep->nregs < 3) ? 3 : irep->nregs);
2195
+ }
2196
+ else {
2197
+ stack_extend(mrb, irep->nregs);
2198
+ }
2199
+ pc = irep->iseq;
2200
+ }
2201
+ JUMP;
2202
+ }
2203
+
2204
+ CASE(OP_BLKPUSH) {
2205
+ /* A Bx R(A) := block (16=6:1:5:4) */
2206
+ int a = GETARG_A(i);
2207
+ int bx = GETARG_Bx(i);
2208
+ int m1 = (bx>>10)&0x3f;
2209
+ int r = (bx>>9)&0x1;
2210
+ int m2 = (bx>>4)&0x1f;
2211
+ int lv = (bx>>0)&0xf;
2212
+ mrb_value *stack;
2213
+
2214
+ if (lv == 0) stack = regs + 1;
2215
+ else {
2216
+ struct REnv *e = uvenv(mrb, lv-1);
2217
+ if (!e || (!MRB_ENV_STACK_SHARED_P(e) && e->mid == 0) ||
2218
+ MRB_ENV_STACK_LEN(e) <= m1+r+m2+1) {
2219
+ localjump_error(mrb, LOCALJUMP_ERROR_YIELD);
2220
+ goto L_RAISE;
2221
+ }
2222
+ stack = e->stack + 1;
2223
+ }
2224
+ if (mrb_nil_p(stack[m1+r+m2])) {
2225
+ localjump_error(mrb, LOCALJUMP_ERROR_YIELD);
2226
+ goto L_RAISE;
2227
+ }
2228
+ regs[a] = stack[m1+r+m2];
2229
+ NEXT;
2230
+ }
2231
+
2232
+ #define TYPES2(a,b) ((((uint16_t)(a))<<8)|(((uint16_t)(b))&0xff))
2233
+ #define OP_MATH_BODY(op,v1,v2) do {\
2234
+ v1(regs[a]) = v1(regs[a]) op v2(regs[a+1]);\
2235
+ } while(0)
2236
+
2237
+ CASE(OP_ADD) {
2238
+ /* A B C R(A) := R(A)+R(A+1) (Syms[B]=:+,C=1)*/
2239
+ int a = GETARG_A(i);
2240
+
2241
+ /* need to check if op is overridden */
2242
+ switch (TYPES2(mrb_type(regs[a]),mrb_type(regs[a+1]))) {
2243
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FIXNUM):
2244
+ {
2245
+ mrb_int x, y, z;
2246
+ mrb_value *regs_a = regs + a;
2247
+
2248
+ x = mrb_fixnum(regs_a[0]);
2249
+ y = mrb_fixnum(regs_a[1]);
2250
+ if (mrb_int_add_overflow(x, y, &z)) {
2251
+ #ifndef MRB_WITHOUT_FLOAT
2252
+ SET_FLOAT_VALUE(mrb, regs_a[0], (mrb_float)x + (mrb_float)y);
2253
+ break;
2254
+ #endif
2255
+ }
2256
+ SET_INT_VALUE(regs[a], z);
2257
+ }
2258
+ break;
2259
+ #ifndef MRB_WITHOUT_FLOAT
2260
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FLOAT):
2261
+ {
2262
+ mrb_int x = mrb_fixnum(regs[a]);
2263
+ mrb_float y = mrb_float(regs[a+1]);
2264
+ SET_FLOAT_VALUE(mrb, regs[a], (mrb_float)x + y);
2265
+ }
2266
+ break;
2267
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FIXNUM):
2268
+ #ifdef MRB_WORD_BOXING
2269
+ {
2270
+ mrb_float x = mrb_float(regs[a]);
2271
+ mrb_int y = mrb_fixnum(regs[a+1]);
2272
+ SET_FLOAT_VALUE(mrb, regs[a], x + y);
2273
+ }
2274
+ #else
2275
+ OP_MATH_BODY(+,mrb_float,mrb_fixnum);
2276
+ #endif
2277
+ break;
2278
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FLOAT):
2279
+ #ifdef MRB_WORD_BOXING
2280
+ {
2281
+ mrb_float x = mrb_float(regs[a]);
2282
+ mrb_float y = mrb_float(regs[a+1]);
2283
+ SET_FLOAT_VALUE(mrb, regs[a], x + y);
2284
+ }
2285
+ #else
2286
+ OP_MATH_BODY(+,mrb_float,mrb_float);
2287
+ #endif
2288
+ break;
2289
+ #endif
2290
+ case TYPES2(MRB_TT_STRING,MRB_TT_STRING):
2291
+ regs[a] = mrb_str_plus(mrb, regs[a], regs[a+1]);
2292
+ break;
2293
+ default:
2294
+ goto L_SEND;
2295
+ }
2296
+ mrb_gc_arena_restore(mrb, ai);
2297
+ NEXT;
2298
+ }
2299
+
2300
+ CASE(OP_SUB) {
2301
+ /* A B C R(A) := R(A)-R(A+1) (Syms[B]=:-,C=1)*/
2302
+ int a = GETARG_A(i);
2303
+
2304
+ /* need to check if op is overridden */
2305
+ switch (TYPES2(mrb_type(regs[a]),mrb_type(regs[a+1]))) {
2306
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FIXNUM):
2307
+ {
2308
+ mrb_int x, y, z;
2309
+
2310
+ x = mrb_fixnum(regs[a]);
2311
+ y = mrb_fixnum(regs[a+1]);
2312
+ if (mrb_int_sub_overflow(x, y, &z)) {
2313
+ #ifndef MRB_WITHOUT_FLOAT
2314
+ SET_FLOAT_VALUE(mrb, regs[a], (mrb_float)x - (mrb_float)y);
2315
+ break;
2316
+ #endif
2317
+ }
2318
+ SET_INT_VALUE(regs[a], z);
2319
+ }
2320
+ break;
2321
+ #ifndef MRB_WITHOUT_FLOAT
2322
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FLOAT):
2323
+ {
2324
+ mrb_int x = mrb_fixnum(regs[a]);
2325
+ mrb_float y = mrb_float(regs[a+1]);
2326
+ SET_FLOAT_VALUE(mrb, regs[a], (mrb_float)x - y);
2327
+ }
2328
+ break;
2329
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FIXNUM):
2330
+ #ifdef MRB_WORD_BOXING
2331
+ {
2332
+ mrb_float x = mrb_float(regs[a]);
2333
+ mrb_int y = mrb_fixnum(regs[a+1]);
2334
+ SET_FLOAT_VALUE(mrb, regs[a], x - y);
2335
+ }
2336
+ #else
2337
+ OP_MATH_BODY(-,mrb_float,mrb_fixnum);
2338
+ #endif
2339
+ break;
2340
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FLOAT):
2341
+ #ifdef MRB_WORD_BOXING
2342
+ {
2343
+ mrb_float x = mrb_float(regs[a]);
2344
+ mrb_float y = mrb_float(regs[a+1]);
2345
+ SET_FLOAT_VALUE(mrb, regs[a], x - y);
2346
+ }
2347
+ #else
2348
+ OP_MATH_BODY(-,mrb_float,mrb_float);
2349
+ #endif
2350
+ break;
2351
+ #endif
2352
+ default:
2353
+ goto L_SEND;
2354
+ }
2355
+ NEXT;
2356
+ }
2357
+
2358
+ CASE(OP_MUL) {
2359
+ /* A B C R(A) := R(A)*R(A+1) (Syms[B]=:*,C=1)*/
2360
+ int a = GETARG_A(i);
2361
+
2362
+ /* need to check if op is overridden */
2363
+ switch (TYPES2(mrb_type(regs[a]),mrb_type(regs[a+1]))) {
2364
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FIXNUM):
2365
+ {
2366
+ mrb_int x, y, z;
2367
+
2368
+ x = mrb_fixnum(regs[a]);
2369
+ y = mrb_fixnum(regs[a+1]);
2370
+ if (mrb_int_mul_overflow(x, y, &z)) {
2371
+ #ifndef MRB_WITHOUT_FLOAT
2372
+ SET_FLOAT_VALUE(mrb, regs[a], (mrb_float)x * (mrb_float)y);
2373
+ break;
2374
+ #endif
2375
+ }
2376
+ SET_INT_VALUE(regs[a], z);
2377
+ }
2378
+ break;
2379
+ #ifndef MRB_WITHOUT_FLOAT
2380
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FLOAT):
2381
+ {
2382
+ mrb_int x = mrb_fixnum(regs[a]);
2383
+ mrb_float y = mrb_float(regs[a+1]);
2384
+ SET_FLOAT_VALUE(mrb, regs[a], (mrb_float)x * y);
2385
+ }
2386
+ break;
2387
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FIXNUM):
2388
+ #ifdef MRB_WORD_BOXING
2389
+ {
2390
+ mrb_float x = mrb_float(regs[a]);
2391
+ mrb_int y = mrb_fixnum(regs[a+1]);
2392
+ SET_FLOAT_VALUE(mrb, regs[a], x * y);
2393
+ }
2394
+ #else
2395
+ OP_MATH_BODY(*,mrb_float,mrb_fixnum);
2396
+ #endif
2397
+ break;
2398
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FLOAT):
2399
+ #ifdef MRB_WORD_BOXING
2400
+ {
2401
+ mrb_float x = mrb_float(regs[a]);
2402
+ mrb_float y = mrb_float(regs[a+1]);
2403
+ SET_FLOAT_VALUE(mrb, regs[a], x * y);
2404
+ }
2405
+ #else
2406
+ OP_MATH_BODY(*,mrb_float,mrb_float);
2407
+ #endif
2408
+ break;
2409
+ #endif
2410
+ default:
2411
+ goto L_SEND;
2412
+ }
2413
+ NEXT;
2414
+ }
2415
+
2416
+ CASE(OP_DIV) {
2417
+ /* A B C R(A) := R(A)/R(A+1) (Syms[B]=:/,C=1)*/
2418
+ int a = GETARG_A(i);
2419
+ #ifndef MRB_WITHOUT_FLOAT
2420
+ double x, y, f;
2421
+ #endif
2422
+
2423
+ /* need to check if op is overridden */
2424
+ switch (TYPES2(mrb_type(regs[a]),mrb_type(regs[a+1]))) {
2425
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FIXNUM):
2426
+ #ifdef MRB_WITHOUT_FLOAT
2427
+ {
2428
+ mrb_int x = mrb_fixnum(regs[a]);
2429
+ mrb_int y = mrb_fixnum(regs[a+1]);
2430
+ SET_INT_VALUE(regs[a], y ? x / y : 0);
2431
+ }
2432
+ break;
2433
+ #else
2434
+ x = (mrb_float)mrb_fixnum(regs[a]);
2435
+ y = (mrb_float)mrb_fixnum(regs[a+1]);
2436
+ break;
2437
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FLOAT):
2438
+ x = (mrb_float)mrb_fixnum(regs[a]);
2439
+ y = mrb_float(regs[a+1]);
2440
+ break;
2441
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FIXNUM):
2442
+ x = mrb_float(regs[a]);
2443
+ y = (mrb_float)mrb_fixnum(regs[a+1]);
2444
+ break;
2445
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FLOAT):
2446
+ x = mrb_float(regs[a]);
2447
+ y = mrb_float(regs[a+1]);
2448
+ break;
2449
+ #endif
2450
+ default:
2451
+ goto L_SEND;
2452
+ }
2453
+
2454
+ #ifndef MRB_WITHOUT_FLOAT
2455
+ if (y == 0) {
2456
+ if (x > 0) f = INFINITY;
2457
+ else if (x < 0) f = -INFINITY;
2458
+ else /* if (x == 0) */ f = NAN;
2459
+ }
2460
+ else {
2461
+ f = x / y;
2462
+ }
2463
+ SET_FLOAT_VALUE(mrb, regs[a], f);
2464
+ #endif
2465
+ NEXT;
2466
+ }
2467
+
2468
+ CASE(OP_ADDI) {
2469
+ /* A B C R(A) := R(A)+C (Syms[B]=:+)*/
2470
+ int a = GETARG_A(i);
2471
+
2472
+ /* need to check if + is overridden */
2473
+ switch (mrb_type(regs[a])) {
2474
+ case MRB_TT_FIXNUM:
2475
+ {
2476
+ mrb_int x = mrb_fixnum(regs[a]);
2477
+ mrb_int y = GETARG_C(i);
2478
+ mrb_int z;
2479
+
2480
+ if (mrb_int_add_overflow(x, y, &z)) {
2481
+ #ifndef MRB_WITHOUT_FLOAT
2482
+ SET_FLOAT_VALUE(mrb, regs[a], (mrb_float)x + (mrb_float)y);
2483
+ break;
2484
+ #endif
2485
+ }
2486
+ SET_INT_VALUE(regs[a], z);
2487
+ }
2488
+ break;
2489
+ #ifndef MRB_WITHOUT_FLOAT
2490
+ case MRB_TT_FLOAT:
2491
+ #ifdef MRB_WORD_BOXING
2492
+ {
2493
+ mrb_float x = mrb_float(regs[a]);
2494
+ SET_FLOAT_VALUE(mrb, regs[a], x + GETARG_C(i));
2495
+ }
2496
+ #else
2497
+ mrb_float(regs[a]) += GETARG_C(i);
2498
+ #endif
2499
+ break;
2500
+ #endif
2501
+ default:
2502
+ SET_INT_VALUE(regs[a+1], GETARG_C(i));
2503
+ i = MKOP_ABC(OP_SEND, a, GETARG_B(i), 1);
2504
+ goto L_SEND;
2505
+ }
2506
+ NEXT;
2507
+ }
2508
+
2509
+ CASE(OP_SUBI) {
2510
+ /* A B C R(A) := R(A)-C (Syms[B]=:-)*/
2511
+ int a = GETARG_A(i);
2512
+ mrb_value *regs_a = regs + a;
2513
+
2514
+ /* need to check if + is overridden */
2515
+ switch (mrb_type(regs_a[0])) {
2516
+ case MRB_TT_FIXNUM:
2517
+ {
2518
+ mrb_int x = mrb_fixnum(regs_a[0]);
2519
+ mrb_int y = GETARG_C(i);
2520
+ mrb_int z;
2521
+
2522
+ if (mrb_int_sub_overflow(x, y, &z)) {
2523
+ #ifndef MRB_WITHOUT_FLOAT
2524
+ SET_FLOAT_VALUE(mrb, regs_a[0], (mrb_float)x - (mrb_float)y);
2525
+ break;
2526
+ #endif
2527
+ }
2528
+ SET_INT_VALUE(regs_a[0], z);
2529
+ }
2530
+ break;
2531
+ #ifndef MRB_WITHOUT_FLOAT
2532
+ case MRB_TT_FLOAT:
2533
+ #ifdef MRB_WORD_BOXING
2534
+ {
2535
+ mrb_float x = mrb_float(regs[a]);
2536
+ SET_FLOAT_VALUE(mrb, regs[a], x - GETARG_C(i));
2537
+ }
2538
+ #else
2539
+ mrb_float(regs_a[0]) -= GETARG_C(i);
2540
+ #endif
2541
+ break;
2542
+ #endif
2543
+ default:
2544
+ SET_INT_VALUE(regs_a[1], GETARG_C(i));
2545
+ i = MKOP_ABC(OP_SEND, a, GETARG_B(i), 1);
2546
+ goto L_SEND;
2547
+ }
2548
+ NEXT;
2549
+ }
2550
+
2551
+ #define OP_CMP_BODY(op,v1,v2) (v1(regs[a]) op v2(regs[a+1]))
2552
+
2553
+ #ifdef MRB_WITHOUT_FLOAT
2554
+ #define OP_CMP(op) do {\
2555
+ int result;\
2556
+ /* need to check if - is overridden */\
2557
+ switch (TYPES2(mrb_type(regs[a]),mrb_type(regs[a+1]))) {\
2558
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FIXNUM):\
2559
+ result = OP_CMP_BODY(op,mrb_fixnum,mrb_fixnum);\
2560
+ break;\
2561
+ default:\
2562
+ goto L_SEND;\
2563
+ }\
2564
+ if (result) {\
2565
+ SET_TRUE_VALUE(regs[a]);\
2566
+ }\
2567
+ else {\
2568
+ SET_FALSE_VALUE(regs[a]);\
2569
+ }\
2570
+ } while(0)
2571
+ #else
2572
+ #define OP_CMP(op) do {\
2573
+ int result;\
2574
+ /* need to check if - is overridden */\
2575
+ switch (TYPES2(mrb_type(regs[a]),mrb_type(regs[a+1]))) {\
2576
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FIXNUM):\
2577
+ result = OP_CMP_BODY(op,mrb_fixnum,mrb_fixnum);\
2578
+ break;\
2579
+ case TYPES2(MRB_TT_FIXNUM,MRB_TT_FLOAT):\
2580
+ result = OP_CMP_BODY(op,mrb_fixnum,mrb_float);\
2581
+ break;\
2582
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FIXNUM):\
2583
+ result = OP_CMP_BODY(op,mrb_float,mrb_fixnum);\
2584
+ break;\
2585
+ case TYPES2(MRB_TT_FLOAT,MRB_TT_FLOAT):\
2586
+ result = OP_CMP_BODY(op,mrb_float,mrb_float);\
2587
+ break;\
2588
+ default:\
2589
+ goto L_SEND;\
2590
+ }\
2591
+ if (result) {\
2592
+ SET_TRUE_VALUE(regs[a]);\
2593
+ }\
2594
+ else {\
2595
+ SET_FALSE_VALUE(regs[a]);\
2596
+ }\
2597
+ } while(0)
2598
+ #endif
2599
+
2600
+ CASE(OP_EQ) {
2601
+ /* A B C R(A) := R(A)==R(A+1) (Syms[B]=:==,C=1)*/
2602
+ int a = GETARG_A(i);
2603
+ if (mrb_obj_eq(mrb, regs[a], regs[a+1])) {
2604
+ SET_TRUE_VALUE(regs[a]);
2605
+ }
2606
+ else {
2607
+ OP_CMP(==);
2608
+ }
2609
+ NEXT;
2610
+ }
2611
+
2612
+ CASE(OP_LT) {
2613
+ /* A B C R(A) := R(A)<R(A+1) (Syms[B]=:<,C=1)*/
2614
+ int a = GETARG_A(i);
2615
+ OP_CMP(<);
2616
+ NEXT;
2617
+ }
2618
+
2619
+ CASE(OP_LE) {
2620
+ /* A B C R(A) := R(A)<=R(A+1) (Syms[B]=:<=,C=1)*/
2621
+ int a = GETARG_A(i);
2622
+ OP_CMP(<=);
2623
+ NEXT;
2624
+ }
2625
+
2626
+ CASE(OP_GT) {
2627
+ /* A B C R(A) := R(A)>R(A+1) (Syms[B]=:>,C=1)*/
2628
+ int a = GETARG_A(i);
2629
+ OP_CMP(>);
2630
+ NEXT;
2631
+ }
2632
+
2633
+ CASE(OP_GE) {
2634
+ /* A B C R(A) := R(A)>=R(A+1) (Syms[B]=:>=,C=1)*/
2635
+ int a = GETARG_A(i);
2636
+ OP_CMP(>=);
2637
+ NEXT;
2638
+ }
2639
+
2640
+ CASE(OP_ARRAY) {
2641
+ /* A B C R(A) := ary_new(R(B),R(B+1)..R(B+C)) */
2642
+ int a = GETARG_A(i);
2643
+ int b = GETARG_B(i);
2644
+ int c = GETARG_C(i);
2645
+ mrb_value v = mrb_ary_new_from_values(mrb, c, &regs[b]);
2646
+ regs[a] = v;
2647
+ mrb_gc_arena_restore(mrb, ai);
2648
+ NEXT;
2649
+ }
2650
+
2651
+ CASE(OP_ARYCAT) {
2652
+ /* A B mrb_ary_concat(R(A),R(B)) */
2653
+ int a = GETARG_A(i);
2654
+ int b = GETARG_B(i);
2655
+ mrb_value splat = mrb_ary_splat(mrb, regs[b]);
2656
+ mrb_ary_concat(mrb, regs[a], splat);
2657
+ mrb_gc_arena_restore(mrb, ai);
2658
+ NEXT;
2659
+ }
2660
+
2661
+ CASE(OP_ARYPUSH) {
2662
+ /* A B R(A).push(R(B)) */
2663
+ int a = GETARG_A(i);
2664
+ int b = GETARG_B(i);
2665
+ mrb_ary_push(mrb, regs[a], regs[b]);
2666
+ NEXT;
2667
+ }
2668
+
2669
+ CASE(OP_AREF) {
2670
+ /* A B C R(A) := R(B)[C] */
2671
+ int a = GETARG_A(i);
2672
+ int b = GETARG_B(i);
2673
+ int c = GETARG_C(i);
2674
+ mrb_value v = regs[b];
2675
+
2676
+ if (!mrb_array_p(v)) {
2677
+ if (c == 0) {
2678
+ regs[a] = v;
2679
+ }
2680
+ else {
2681
+ SET_NIL_VALUE(regs[a]);
2682
+ }
2683
+ }
2684
+ else {
2685
+ v = mrb_ary_ref(mrb, v, c);
2686
+ regs[a] = v;
2687
+ }
2688
+ NEXT;
2689
+ }
2690
+
2691
+ CASE(OP_ASET) {
2692
+ /* A B C R(B)[C] := R(A) */
2693
+ int a = GETARG_A(i);
2694
+ int b = GETARG_B(i);
2695
+ int c = GETARG_C(i);
2696
+ mrb_ary_set(mrb, regs[b], c, regs[a]);
2697
+ NEXT;
2698
+ }
2699
+
2700
+ CASE(OP_APOST) {
2701
+ /* A B C *R(A),R(A+1)..R(A+C) := R(A) */
2702
+ int a = GETARG_A(i);
2703
+ mrb_value v = regs[a];
2704
+ int pre = GETARG_B(i);
2705
+ int post = GETARG_C(i);
2706
+ struct RArray *ary;
2707
+ int len, idx;
2708
+
2709
+ if (!mrb_array_p(v)) {
2710
+ v = mrb_ary_new_from_values(mrb, 1, &regs[a]);
2711
+ }
2712
+ ary = mrb_ary_ptr(v);
2713
+ len = (int)ARY_LEN(ary);
2714
+ if (len > pre + post) {
2715
+ v = mrb_ary_new_from_values(mrb, len - pre - post, ARY_PTR(ary)+pre);
2716
+ regs[a++] = v;
2717
+ while (post--) {
2718
+ regs[a++] = ARY_PTR(ary)[len-post-1];
2719
+ }
2720
+ }
2721
+ else {
2722
+ v = mrb_ary_new_capa(mrb, 0);
2723
+ regs[a++] = v;
2724
+ for (idx=0; idx+pre<len; idx++) {
2725
+ regs[a+idx] = ARY_PTR(ary)[pre+idx];
2726
+ }
2727
+ while (idx < post) {
2728
+ SET_NIL_VALUE(regs[a+idx]);
2729
+ idx++;
2730
+ }
2731
+ }
2732
+ mrb_gc_arena_restore(mrb, ai);
2733
+ NEXT;
2734
+ }
2735
+
2736
+ CASE(OP_STRING) {
2737
+ /* A Bx R(A) := str_new(Lit(Bx)) */
2738
+ mrb_int a = GETARG_A(i);
2739
+ mrb_int bx = GETARG_Bx(i);
2740
+ mrb_value str = mrb_str_dup(mrb, pool[bx]);
2741
+
2742
+ regs[a] = str;
2743
+ mrb_gc_arena_restore(mrb, ai);
2744
+ NEXT;
2745
+ }
2746
+
2747
+ CASE(OP_STRCAT) {
2748
+ /* A B R(A).concat(R(B)) */
2749
+ mrb_int a = GETARG_A(i);
2750
+ mrb_int b = GETARG_B(i);
2751
+
2752
+ mrb_str_concat(mrb, regs[a], regs[b]);
2753
+ NEXT;
2754
+ }
2755
+
2756
+ CASE(OP_HASH) {
2757
+ /* A B C R(A) := hash_new(R(B),R(B+1)..R(B+C)) */
2758
+ int b = GETARG_B(i);
2759
+ int c = GETARG_C(i);
2760
+ int lim = b+c*2;
2761
+ mrb_value hash = mrb_hash_new_capa(mrb, c);
2762
+
2763
+ while (b < lim) {
2764
+ mrb_hash_set(mrb, hash, regs[b], regs[b+1]);
2765
+ b+=2;
2766
+ }
2767
+ regs[GETARG_A(i)] = hash;
2768
+ mrb_gc_arena_restore(mrb, ai);
2769
+ NEXT;
2770
+ }
2771
+
2772
+ CASE(OP_LAMBDA) {
2773
+ /* A b c R(A) := lambda(SEQ[b],c) (b:c = 14:2) */
2774
+ struct RProc *p;
2775
+ int a = GETARG_A(i);
2776
+ int b = GETARG_b(i);
2777
+ int c = GETARG_c(i);
2778
+ mrb_irep *nirep = irep->reps[b];
2779
+
2780
+ if (c & OP_L_CAPTURE) {
2781
+ p = mrb_closure_new(mrb, nirep);
2782
+ }
2783
+ else {
2784
+ p = mrb_proc_new(mrb, nirep);
2785
+ p->flags |= MRB_PROC_SCOPE;
2786
+ }
2787
+ if (c & OP_L_STRICT) p->flags |= MRB_PROC_STRICT;
2788
+ regs[a] = mrb_obj_value(p);
2789
+ mrb_gc_arena_restore(mrb, ai);
2790
+ NEXT;
2791
+ }
2792
+
2793
+ CASE(OP_OCLASS) {
2794
+ /* A R(A) := ::Object */
2795
+ regs[GETARG_A(i)] = mrb_obj_value(mrb->object_class);
2796
+ NEXT;
2797
+ }
2798
+
2799
+ CASE(OP_CLASS) {
2800
+ /* A B R(A) := newclass(R(A),Syms(B),R(A+1)) */
2801
+ struct RClass *c = 0, *baseclass;
2802
+ int a = GETARG_A(i);
2803
+ mrb_value base, super;
2804
+ mrb_sym id = syms[GETARG_B(i)];
2805
+
2806
+ base = regs[a];
2807
+ super = regs[a+1];
2808
+ if (mrb_nil_p(base)) {
2809
+ baseclass = MRB_PROC_TARGET_CLASS(mrb->c->ci->proc);
2810
+ base = mrb_obj_value(baseclass);
2811
+ }
2812
+ c = mrb_vm_define_class(mrb, base, super, id);
2813
+ regs[a] = mrb_obj_value(c);
2814
+ mrb_gc_arena_restore(mrb, ai);
2815
+ NEXT;
2816
+ }
2817
+
2818
+ CASE(OP_MODULE) {
2819
+ /* A B R(A) := newmodule(R(A),Syms(B)) */
2820
+ struct RClass *c = 0, *baseclass;
2821
+ int a = GETARG_A(i);
2822
+ mrb_value base;
2823
+ mrb_sym id = syms[GETARG_B(i)];
2824
+
2825
+ base = regs[a];
2826
+ if (mrb_nil_p(base)) {
2827
+ baseclass = MRB_PROC_TARGET_CLASS(mrb->c->ci->proc);
2828
+ base = mrb_obj_value(baseclass);
2829
+ }
2830
+ c = mrb_vm_define_module(mrb, base, id);
2831
+ regs[a] = mrb_obj_value(c);
2832
+ mrb_gc_arena_restore(mrb, ai);
2833
+ NEXT;
2834
+ }
2835
+
2836
+ CASE(OP_EXEC) {
2837
+ /* A Bx R(A) := blockexec(R(A),SEQ[Bx]) */
2838
+ int a = GETARG_A(i);
2839
+ int bx = GETARG_Bx(i);
2840
+ mrb_callinfo *ci;
2841
+ mrb_value recv = regs[a];
2842
+ struct RProc *p;
2843
+ mrb_irep *nirep = irep->reps[bx];
2844
+
2845
+ /* prepare closure */
2846
+ p = mrb_proc_new(mrb, nirep);
2847
+ p->c = NULL;
2848
+ mrb_field_write_barrier(mrb, (struct RBasic*)p, (struct RBasic*)proc);
2849
+ MRB_PROC_SET_TARGET_CLASS(p, mrb_class_ptr(recv));
2850
+ p->flags |= MRB_PROC_SCOPE;
2851
+
2852
+ /* prepare call stack */
2853
+ ci = cipush(mrb);
2854
+ ci->pc = pc + 1;
2855
+ ci->acc = a;
2856
+ ci->mid = 0;
2857
+ ci->stackent = mrb->c->stack;
2858
+ ci->argc = 0;
2859
+ ci->target_class = mrb_class_ptr(recv);
2860
+
2861
+ /* prepare stack */
2862
+ mrb->c->stack += a;
2863
+
2864
+ /* setup block to call */
2865
+ ci->proc = p;
2866
+
2867
+ irep = p->body.irep;
2868
+ pool = irep->pool;
2869
+ syms = irep->syms;
2870
+ ci->nregs = irep->nregs;
2871
+ stack_extend(mrb, ci->nregs);
2872
+ stack_clear(regs+1, ci->nregs-1);
2873
+ pc = irep->iseq;
2874
+ JUMP;
2875
+ }
2876
+
2877
+ CASE(OP_METHOD) {
2878
+ /* A B R(A).newmethod(Syms(B),R(A+1)) */
2879
+ int a = GETARG_A(i);
2880
+ struct RClass *c = mrb_class_ptr(regs[a]);
2881
+ struct RProc *p = mrb_proc_ptr(regs[a+1]);
2882
+ mrb_method_t m;
2883
+
2884
+ MRB_METHOD_FROM_PROC(m, p);
2885
+ mrb_define_method_raw(mrb, c, syms[GETARG_B(i)], m);
2886
+ mrb_gc_arena_restore(mrb, ai);
2887
+ NEXT;
2888
+ }
2889
+
2890
+ CASE(OP_SCLASS) {
2891
+ /* A B R(A) := R(B).singleton_class */
2892
+ int a = GETARG_A(i);
2893
+ int b = GETARG_B(i);
2894
+
2895
+ regs[a] = mrb_singleton_class(mrb, regs[b]);
2896
+ mrb_gc_arena_restore(mrb, ai);
2897
+ NEXT;
2898
+ }
2899
+
2900
+ CASE(OP_TCLASS) {
2901
+ /* A R(A) := target_class */
2902
+ if (!mrb->c->ci->target_class) {
2903
+ mrb_value exc = mrb_exc_new_str_lit(mrb, E_TYPE_ERROR, "no target class or module");
2904
+ mrb_exc_set(mrb, exc);
2905
+ goto L_RAISE;
2906
+ }
2907
+ regs[GETARG_A(i)] = mrb_obj_value(mrb->c->ci->target_class);
2908
+ NEXT;
2909
+ }
2910
+
2911
+ CASE(OP_RANGE) {
2912
+ /* A B C R(A) := range_new(R(B),R(B+1),C) */
2913
+ int b = GETARG_B(i);
2914
+ mrb_value val = mrb_range_new(mrb, regs[b], regs[b+1], GETARG_C(i));
2915
+ regs[GETARG_A(i)] = val;
2916
+ mrb_gc_arena_restore(mrb, ai);
2917
+ NEXT;
2918
+ }
2919
+
2920
+ CASE(OP_DEBUG) {
2921
+ /* A B C debug print R(A),R(B),R(C) */
2922
+ #ifdef MRB_ENABLE_DEBUG_HOOK
2923
+ mrb->debug_op_hook(mrb, irep, pc, regs);
2924
+ #else
2925
+ #ifndef MRB_DISABLE_STDIO
2926
+ printf("OP_DEBUG %d %d %d\n", GETARG_A(i), GETARG_B(i), GETARG_C(i));
2927
+ #else
2928
+ abort();
2929
+ #endif
2930
+ #endif
2931
+ NEXT;
2932
+ }
2933
+
2934
+ CASE(OP_STOP) {
2935
+ /* stop VM */
2936
+ L_STOP:
2937
+ while (mrb->c->ci > mrb->c->cibase) {
2938
+ cipop(mrb);
2939
+ }
2940
+ while (mrb->c->eidx > 0) {
2941
+ ecall(mrb);
2942
+ }
2943
+ ERR_PC_CLR(mrb);
2944
+ mrb->jmp = prev_jmp;
2945
+ if (mrb->exc) {
2946
+ return mrb_obj_value(mrb->exc);
2947
+ }
2948
+ return regs[irep->nlocals];
2949
+ }
2950
+
2951
+ CASE(OP_ERR) {
2952
+ /* Bx raise RuntimeError with message Lit(Bx) */
2953
+ mrb_value msg = mrb_str_dup(mrb, pool[GETARG_Bx(i)]);
2954
+ mrb_value exc;
2955
+
2956
+ if (GETARG_A(i) == 0) {
2957
+ exc = mrb_exc_new_str(mrb, E_RUNTIME_ERROR, msg);
2958
+ }
2959
+ else {
2960
+ exc = mrb_exc_new_str(mrb, E_LOCALJUMP_ERROR, msg);
2961
+ }
2962
+ ERR_PC_SET(mrb, pc);
2963
+ mrb_exc_set(mrb, exc);
2964
+ goto L_RAISE;
2965
+ }
2966
+ }
2967
+ END_DISPATCH;
2968
+ #undef regs
2969
+
2970
+ }
2971
+ MRB_CATCH(&c_jmp) {
2972
+ exc_catched = TRUE;
2973
+ goto RETRY_TRY_BLOCK;
2974
+ }
2975
+ MRB_END_EXC(&c_jmp);
2976
+ }
2977
+
2978
+ MRB_API mrb_value
2979
+ mrb_run(mrb_state *mrb, struct RProc *proc, mrb_value self)
2980
+ {
2981
+ if (mrb->c->ci->argc < 0) {
2982
+ return mrb_vm_run(mrb, proc, self, 3); /* receiver, args and block) */
2983
+ }
2984
+ else {
2985
+ return mrb_vm_run(mrb, proc, self, mrb->c->ci->argc + 2); /* argc + 2 (receiver and block) */
2986
+ }
2987
+ }
2988
+
2989
+ MRB_API mrb_value
2990
+ mrb_top_run(mrb_state *mrb, struct RProc *proc, mrb_value self, unsigned int stack_keep)
2991
+ {
2992
+ mrb_callinfo *ci;
2993
+ mrb_value v;
2994
+
2995
+ if (!mrb->c->cibase) {
2996
+ return mrb_vm_run(mrb, proc, self, stack_keep);
2997
+ }
2998
+ if (mrb->c->ci == mrb->c->cibase) {
2999
+ return mrb_vm_run(mrb, proc, self, stack_keep);
3000
+ }
3001
+ ci = cipush(mrb);
3002
+ ci->mid = 0;
3003
+ ci->nregs = 1; /* protect the receiver */
3004
+ ci->acc = CI_ACC_SKIP;
3005
+ ci->target_class = mrb->object_class;
3006
+ v = mrb_vm_run(mrb, proc, self, stack_keep);
3007
+ cipop(mrb);
3008
+
3009
+ return v;
3010
+ }
3011
+
3012
+ #if defined(MRB_ENABLE_CXX_EXCEPTION) && defined(__cplusplus)
3013
+ # if !defined(MRB_ENABLE_CXX_ABI)
3014
+ } /* end of extern "C" */
3015
+ # endif
3016
+ mrb_int mrb_jmpbuf::jmpbuf_id = 0;
3017
+ # if !defined(MRB_ENABLE_CXX_ABI)
3018
+ extern "C" {
3019
+ # endif
3020
+ #endif