immunio 0.15.4 → 0.16.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 (454) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE +0 -27
  3. data/ext/immunio/Rakefile +9 -0
  4. data/lib/immunio/plugins/active_record.rb +1 -1
  5. data/lib/immunio/plugins/active_record_relation.rb +1 -1
  6. data/lib/immunio/plugins/environment_reporter.rb +20 -0
  7. data/lib/immunio/rufus_lua_ext/ref.rb +1 -3
  8. data/lib/immunio/version.rb +1 -1
  9. data/lib/immunio/vm.rb +1 -2
  10. data/lua-hooks/Makefile +97 -0
  11. data/lua-hooks/ext/all.c +41 -52
  12. data/lua-hooks/ext/all.o +0 -0
  13. data/lua-hooks/ext/libinjection/libinjection_html5.o +0 -0
  14. data/lua-hooks/ext/libinjection/libinjection_sqli.o +0 -0
  15. data/lua-hooks/ext/libinjection/libinjection_xss.o +0 -0
  16. data/lua-hooks/ext/libinjection/lualib.c +2 -2
  17. data/lua-hooks/ext/lpeg/lpcap.c +2 -2
  18. data/lua-hooks/ext/lpeg/lpcap.o +0 -0
  19. data/lua-hooks/ext/lpeg/lpcode.c +2 -2
  20. data/lua-hooks/ext/lpeg/lpcode.h +1 -1
  21. data/lua-hooks/ext/lpeg/lpcode.o +0 -0
  22. data/lua-hooks/ext/lpeg/lpprint.o +0 -0
  23. data/lua-hooks/ext/lpeg/lptree.c +2 -2
  24. data/lua-hooks/ext/lpeg/lptypes.h +1 -1
  25. data/lua-hooks/ext/lpeg/lpvm.c +2 -2
  26. data/lua-hooks/ext/lpeg/lpvm.o +0 -0
  27. data/lua-hooks/ext/lua-cmsgpack/lua_cmsgpack.c +16 -3
  28. data/lua-hooks/ext/lua-snapshot/snapshot.c +14 -7
  29. data/lua-hooks/ext/luajit/COPYRIGHT +56 -0
  30. data/lua-hooks/ext/luajit/Makefile +159 -0
  31. data/lua-hooks/ext/luajit/README +16 -0
  32. data/lua-hooks/ext/luajit/doc/bluequad-print.css +166 -0
  33. data/lua-hooks/ext/luajit/doc/bluequad.css +325 -0
  34. data/lua-hooks/ext/luajit/doc/changes.html +804 -0
  35. data/lua-hooks/ext/luajit/doc/contact.html +104 -0
  36. data/lua-hooks/ext/luajit/doc/ext_c_api.html +189 -0
  37. data/lua-hooks/ext/luajit/doc/ext_ffi.html +332 -0
  38. data/lua-hooks/ext/luajit/doc/ext_ffi_api.html +570 -0
  39. data/lua-hooks/ext/luajit/doc/ext_ffi_semantics.html +1261 -0
  40. data/lua-hooks/ext/luajit/doc/ext_ffi_tutorial.html +603 -0
  41. data/lua-hooks/ext/luajit/doc/ext_jit.html +201 -0
  42. data/lua-hooks/ext/luajit/doc/ext_profiler.html +365 -0
  43. data/lua-hooks/ext/luajit/doc/extensions.html +448 -0
  44. data/lua-hooks/ext/luajit/doc/faq.html +186 -0
  45. data/lua-hooks/ext/luajit/doc/img/contact.png +0 -0
  46. data/lua-hooks/ext/luajit/doc/install.html +659 -0
  47. data/lua-hooks/ext/luajit/doc/luajit.html +236 -0
  48. data/lua-hooks/ext/luajit/doc/running.html +309 -0
  49. data/lua-hooks/ext/luajit/doc/status.html +118 -0
  50. data/lua-hooks/ext/luajit/dynasm/dasm_arm.h +456 -0
  51. data/lua-hooks/ext/luajit/dynasm/dasm_arm.lua +1125 -0
  52. data/lua-hooks/ext/luajit/dynasm/dasm_arm64.h +518 -0
  53. data/lua-hooks/ext/luajit/dynasm/dasm_arm64.lua +1166 -0
  54. data/lua-hooks/ext/luajit/dynasm/dasm_mips.h +416 -0
  55. data/lua-hooks/ext/luajit/dynasm/dasm_mips.lua +953 -0
  56. data/lua-hooks/ext/luajit/dynasm/dasm_ppc.h +419 -0
  57. data/lua-hooks/ext/luajit/dynasm/dasm_ppc.lua +1919 -0
  58. data/lua-hooks/ext/luajit/dynasm/dasm_proto.h +83 -0
  59. data/lua-hooks/ext/luajit/dynasm/dasm_x64.lua +12 -0
  60. data/lua-hooks/ext/luajit/dynasm/dasm_x86.h +471 -0
  61. data/lua-hooks/ext/luajit/dynasm/dasm_x86.lua +1945 -0
  62. data/lua-hooks/ext/luajit/dynasm/dynasm.lua +1094 -0
  63. data/lua-hooks/ext/luajit/etc/luajit.1 +88 -0
  64. data/lua-hooks/ext/luajit/etc/luajit.pc +25 -0
  65. data/lua-hooks/ext/luajit/src/Makefile +697 -0
  66. data/lua-hooks/ext/luajit/src/Makefile.dep +244 -0
  67. data/lua-hooks/ext/luajit/src/host/README +4 -0
  68. data/lua-hooks/ext/luajit/src/host/buildvm +0 -0
  69. data/lua-hooks/ext/luajit/src/host/buildvm.c +518 -0
  70. data/lua-hooks/ext/luajit/src/host/buildvm.h +105 -0
  71. data/lua-hooks/ext/luajit/src/host/buildvm.o +0 -0
  72. data/lua-hooks/ext/luajit/src/host/buildvm_arch.h +7449 -0
  73. data/lua-hooks/ext/luajit/src/host/buildvm_asm.c +345 -0
  74. data/lua-hooks/ext/luajit/src/host/buildvm_asm.o +0 -0
  75. data/lua-hooks/ext/luajit/src/host/buildvm_fold.c +229 -0
  76. data/lua-hooks/ext/luajit/src/host/buildvm_fold.o +0 -0
  77. data/lua-hooks/ext/luajit/src/host/buildvm_lib.c +457 -0
  78. data/lua-hooks/ext/luajit/src/host/buildvm_lib.o +0 -0
  79. data/lua-hooks/ext/luajit/src/host/buildvm_libbc.h +45 -0
  80. data/lua-hooks/ext/luajit/src/host/buildvm_peobj.c +368 -0
  81. data/lua-hooks/ext/luajit/src/host/buildvm_peobj.o +0 -0
  82. data/lua-hooks/ext/luajit/src/host/genlibbc.lua +197 -0
  83. data/lua-hooks/ext/luajit/src/host/genminilua.lua +428 -0
  84. data/lua-hooks/ext/luajit/src/host/minilua +0 -0
  85. data/lua-hooks/ext/luajit/src/host/minilua.c +7770 -0
  86. data/lua-hooks/ext/luajit/src/host/minilua.o +0 -0
  87. data/lua-hooks/ext/luajit/src/jit/bc.lua +190 -0
  88. data/lua-hooks/ext/luajit/src/jit/bcsave.lua +661 -0
  89. data/lua-hooks/ext/luajit/src/jit/dis_arm.lua +689 -0
  90. data/lua-hooks/ext/luajit/src/jit/dis_mips.lua +428 -0
  91. data/lua-hooks/ext/luajit/src/jit/dis_mipsel.lua +17 -0
  92. data/lua-hooks/ext/luajit/src/jit/dis_ppc.lua +591 -0
  93. data/lua-hooks/ext/luajit/src/jit/dis_x64.lua +17 -0
  94. data/lua-hooks/ext/luajit/src/jit/dis_x86.lua +838 -0
  95. data/lua-hooks/ext/luajit/src/jit/dump.lua +706 -0
  96. data/lua-hooks/ext/luajit/src/jit/p.lua +310 -0
  97. data/lua-hooks/ext/luajit/src/jit/v.lua +170 -0
  98. data/lua-hooks/ext/luajit/src/jit/vmdef.lua +362 -0
  99. data/lua-hooks/ext/luajit/src/jit/zone.lua +45 -0
  100. data/lua-hooks/ext/{lua → luajit/src}/lauxlib.h +10 -17
  101. data/lua-hooks/ext/luajit/src/lib_aux.c +356 -0
  102. data/lua-hooks/ext/luajit/src/lib_aux.o +0 -0
  103. data/lua-hooks/ext/luajit/src/lib_aux_dyn.o +0 -0
  104. data/lua-hooks/ext/luajit/src/lib_base.c +664 -0
  105. data/lua-hooks/ext/luajit/src/lib_base.o +0 -0
  106. data/lua-hooks/ext/luajit/src/lib_base_dyn.o +0 -0
  107. data/lua-hooks/ext/luajit/src/lib_bit.c +180 -0
  108. data/lua-hooks/ext/luajit/src/lib_bit.o +0 -0
  109. data/lua-hooks/ext/luajit/src/lib_bit_dyn.o +0 -0
  110. data/lua-hooks/ext/luajit/src/lib_debug.c +405 -0
  111. data/lua-hooks/ext/luajit/src/lib_debug.o +0 -0
  112. data/lua-hooks/ext/luajit/src/lib_debug_dyn.o +0 -0
  113. data/lua-hooks/ext/luajit/src/lib_ffi.c +872 -0
  114. data/lua-hooks/ext/luajit/src/lib_ffi.o +0 -0
  115. data/lua-hooks/ext/luajit/src/lib_ffi_dyn.o +0 -0
  116. data/lua-hooks/ext/luajit/src/lib_init.c +55 -0
  117. data/lua-hooks/ext/luajit/src/lib_init.o +0 -0
  118. data/lua-hooks/ext/luajit/src/lib_init_dyn.o +0 -0
  119. data/lua-hooks/ext/luajit/src/lib_io.c +541 -0
  120. data/lua-hooks/ext/luajit/src/lib_io.o +0 -0
  121. data/lua-hooks/ext/luajit/src/lib_io_dyn.o +0 -0
  122. data/lua-hooks/ext/luajit/src/lib_jit.c +767 -0
  123. data/lua-hooks/ext/luajit/src/lib_jit.o +0 -0
  124. data/lua-hooks/ext/luajit/src/lib_jit_dyn.o +0 -0
  125. data/lua-hooks/ext/luajit/src/lib_math.c +230 -0
  126. data/lua-hooks/ext/luajit/src/lib_math.o +0 -0
  127. data/lua-hooks/ext/luajit/src/lib_math_dyn.o +0 -0
  128. data/lua-hooks/ext/luajit/src/lib_os.c +292 -0
  129. data/lua-hooks/ext/luajit/src/lib_os.o +0 -0
  130. data/lua-hooks/ext/luajit/src/lib_os_dyn.o +0 -0
  131. data/lua-hooks/ext/luajit/src/lib_package.c +610 -0
  132. data/lua-hooks/ext/luajit/src/lib_package.o +0 -0
  133. data/lua-hooks/ext/luajit/src/lib_package_dyn.o +0 -0
  134. data/lua-hooks/ext/luajit/src/lib_string.c +752 -0
  135. data/lua-hooks/ext/luajit/src/lib_string.o +0 -0
  136. data/lua-hooks/ext/luajit/src/lib_string_dyn.o +0 -0
  137. data/lua-hooks/ext/luajit/src/lib_table.c +307 -0
  138. data/lua-hooks/ext/luajit/src/lib_table.o +0 -0
  139. data/lua-hooks/ext/luajit/src/lib_table_dyn.o +0 -0
  140. data/lua-hooks/ext/luajit/src/libluajit.a +0 -0
  141. data/lua-hooks/ext/luajit/src/libluajit.so +0 -0
  142. data/lua-hooks/ext/luajit/src/lj.supp +26 -0
  143. data/lua-hooks/ext/luajit/src/lj_alloc.c +1398 -0
  144. data/lua-hooks/ext/luajit/src/lj_alloc.h +17 -0
  145. data/lua-hooks/ext/luajit/src/lj_alloc.o +0 -0
  146. data/lua-hooks/ext/luajit/src/lj_alloc_dyn.o +0 -0
  147. data/lua-hooks/ext/luajit/src/lj_api.c +1210 -0
  148. data/lua-hooks/ext/luajit/src/lj_api.o +0 -0
  149. data/lua-hooks/ext/luajit/src/lj_api_dyn.o +0 -0
  150. data/lua-hooks/ext/luajit/src/lj_arch.h +509 -0
  151. data/lua-hooks/ext/luajit/src/lj_asm.c +2278 -0
  152. data/lua-hooks/ext/luajit/src/lj_asm.h +17 -0
  153. data/lua-hooks/ext/luajit/src/lj_asm.o +0 -0
  154. data/lua-hooks/ext/luajit/src/lj_asm_arm.h +2217 -0
  155. data/lua-hooks/ext/luajit/src/lj_asm_dyn.o +0 -0
  156. data/lua-hooks/ext/luajit/src/lj_asm_mips.h +1833 -0
  157. data/lua-hooks/ext/luajit/src/lj_asm_ppc.h +2015 -0
  158. data/lua-hooks/ext/luajit/src/lj_asm_x86.h +2634 -0
  159. data/lua-hooks/ext/luajit/src/lj_bc.c +14 -0
  160. data/lua-hooks/ext/luajit/src/lj_bc.h +265 -0
  161. data/lua-hooks/ext/luajit/src/lj_bc.o +0 -0
  162. data/lua-hooks/ext/luajit/src/lj_bc_dyn.o +0 -0
  163. data/lua-hooks/ext/luajit/src/lj_bcdef.h +220 -0
  164. data/lua-hooks/ext/luajit/src/lj_bcdump.h +68 -0
  165. data/lua-hooks/ext/luajit/src/lj_bcread.c +457 -0
  166. data/lua-hooks/ext/luajit/src/lj_bcread.o +0 -0
  167. data/lua-hooks/ext/luajit/src/lj_bcread_dyn.o +0 -0
  168. data/lua-hooks/ext/luajit/src/lj_bcwrite.c +361 -0
  169. data/lua-hooks/ext/luajit/src/lj_bcwrite.o +0 -0
  170. data/lua-hooks/ext/luajit/src/lj_bcwrite_dyn.o +0 -0
  171. data/lua-hooks/ext/luajit/src/lj_buf.c +234 -0
  172. data/lua-hooks/ext/luajit/src/lj_buf.h +105 -0
  173. data/lua-hooks/ext/luajit/src/lj_buf.o +0 -0
  174. data/lua-hooks/ext/luajit/src/lj_buf_dyn.o +0 -0
  175. data/lua-hooks/ext/luajit/src/lj_carith.c +429 -0
  176. data/lua-hooks/ext/luajit/src/lj_carith.h +37 -0
  177. data/lua-hooks/ext/luajit/src/lj_carith.o +0 -0
  178. data/lua-hooks/ext/luajit/src/lj_carith_dyn.o +0 -0
  179. data/lua-hooks/ext/luajit/src/lj_ccall.c +984 -0
  180. data/lua-hooks/ext/luajit/src/lj_ccall.h +178 -0
  181. data/lua-hooks/ext/luajit/src/lj_ccall.o +0 -0
  182. data/lua-hooks/ext/luajit/src/lj_ccall_dyn.o +0 -0
  183. data/lua-hooks/ext/luajit/src/lj_ccallback.c +712 -0
  184. data/lua-hooks/ext/luajit/src/lj_ccallback.h +25 -0
  185. data/lua-hooks/ext/luajit/src/lj_ccallback.o +0 -0
  186. data/lua-hooks/ext/luajit/src/lj_ccallback_dyn.o +0 -0
  187. data/lua-hooks/ext/luajit/src/lj_cconv.c +752 -0
  188. data/lua-hooks/ext/luajit/src/lj_cconv.h +70 -0
  189. data/lua-hooks/ext/luajit/src/lj_cconv.o +0 -0
  190. data/lua-hooks/ext/luajit/src/lj_cconv_dyn.o +0 -0
  191. data/lua-hooks/ext/luajit/src/lj_cdata.c +288 -0
  192. data/lua-hooks/ext/luajit/src/lj_cdata.h +76 -0
  193. data/lua-hooks/ext/luajit/src/lj_cdata.o +0 -0
  194. data/lua-hooks/ext/luajit/src/lj_cdata_dyn.o +0 -0
  195. data/lua-hooks/ext/luajit/src/lj_char.c +43 -0
  196. data/lua-hooks/ext/luajit/src/lj_char.h +42 -0
  197. data/lua-hooks/ext/luajit/src/lj_char.o +0 -0
  198. data/lua-hooks/ext/luajit/src/lj_char_dyn.o +0 -0
  199. data/lua-hooks/ext/luajit/src/lj_clib.c +418 -0
  200. data/lua-hooks/ext/luajit/src/lj_clib.h +29 -0
  201. data/lua-hooks/ext/luajit/src/lj_clib.o +0 -0
  202. data/lua-hooks/ext/luajit/src/lj_clib_dyn.o +0 -0
  203. data/lua-hooks/ext/luajit/src/lj_cparse.c +1862 -0
  204. data/lua-hooks/ext/luajit/src/lj_cparse.h +65 -0
  205. data/lua-hooks/ext/luajit/src/lj_cparse.o +0 -0
  206. data/lua-hooks/ext/luajit/src/lj_cparse_dyn.o +0 -0
  207. data/lua-hooks/ext/luajit/src/lj_crecord.c +1834 -0
  208. data/lua-hooks/ext/luajit/src/lj_crecord.h +38 -0
  209. data/lua-hooks/ext/luajit/src/lj_crecord.o +0 -0
  210. data/lua-hooks/ext/luajit/src/lj_crecord_dyn.o +0 -0
  211. data/lua-hooks/ext/luajit/src/lj_ctype.c +635 -0
  212. data/lua-hooks/ext/luajit/src/lj_ctype.h +461 -0
  213. data/lua-hooks/ext/luajit/src/lj_ctype.o +0 -0
  214. data/lua-hooks/ext/luajit/src/lj_ctype_dyn.o +0 -0
  215. data/lua-hooks/ext/luajit/src/lj_debug.c +699 -0
  216. data/lua-hooks/ext/luajit/src/lj_debug.h +65 -0
  217. data/lua-hooks/ext/luajit/src/lj_debug.o +0 -0
  218. data/lua-hooks/ext/luajit/src/lj_debug_dyn.o +0 -0
  219. data/lua-hooks/ext/luajit/src/lj_def.h +365 -0
  220. data/lua-hooks/ext/luajit/src/lj_dispatch.c +557 -0
  221. data/lua-hooks/ext/luajit/src/lj_dispatch.h +138 -0
  222. data/lua-hooks/ext/luajit/src/lj_dispatch.o +0 -0
  223. data/lua-hooks/ext/luajit/src/lj_dispatch_dyn.o +0 -0
  224. data/lua-hooks/ext/luajit/src/lj_emit_arm.h +356 -0
  225. data/lua-hooks/ext/luajit/src/lj_emit_mips.h +211 -0
  226. data/lua-hooks/ext/luajit/src/lj_emit_ppc.h +238 -0
  227. data/lua-hooks/ext/luajit/src/lj_emit_x86.h +462 -0
  228. data/lua-hooks/ext/luajit/src/lj_err.c +794 -0
  229. data/lua-hooks/ext/luajit/src/lj_err.h +41 -0
  230. data/lua-hooks/ext/luajit/src/lj_err.o +0 -0
  231. data/lua-hooks/ext/luajit/src/lj_err_dyn.o +0 -0
  232. data/lua-hooks/ext/luajit/src/lj_errmsg.h +190 -0
  233. data/lua-hooks/ext/luajit/src/lj_ff.h +18 -0
  234. data/lua-hooks/ext/luajit/src/lj_ffdef.h +209 -0
  235. data/lua-hooks/ext/luajit/src/lj_ffrecord.c +1247 -0
  236. data/lua-hooks/ext/luajit/src/lj_ffrecord.h +24 -0
  237. data/lua-hooks/ext/luajit/src/lj_ffrecord.o +0 -0
  238. data/lua-hooks/ext/luajit/src/lj_ffrecord_dyn.o +0 -0
  239. data/lua-hooks/ext/luajit/src/lj_folddef.h +1138 -0
  240. data/lua-hooks/ext/luajit/src/lj_frame.h +259 -0
  241. data/lua-hooks/ext/luajit/src/lj_func.c +185 -0
  242. data/lua-hooks/ext/luajit/src/lj_func.h +24 -0
  243. data/lua-hooks/ext/luajit/src/lj_func.o +0 -0
  244. data/lua-hooks/ext/luajit/src/lj_func_dyn.o +0 -0
  245. data/lua-hooks/ext/luajit/src/lj_gc.c +845 -0
  246. data/lua-hooks/ext/luajit/src/lj_gc.h +134 -0
  247. data/lua-hooks/ext/luajit/src/lj_gc.o +0 -0
  248. data/lua-hooks/ext/luajit/src/lj_gc_dyn.o +0 -0
  249. data/lua-hooks/ext/luajit/src/lj_gdbjit.c +787 -0
  250. data/lua-hooks/ext/luajit/src/lj_gdbjit.h +22 -0
  251. data/lua-hooks/ext/luajit/src/lj_gdbjit.o +0 -0
  252. data/lua-hooks/ext/luajit/src/lj_gdbjit_dyn.o +0 -0
  253. data/lua-hooks/ext/luajit/src/lj_ir.c +505 -0
  254. data/lua-hooks/ext/luajit/src/lj_ir.h +577 -0
  255. data/lua-hooks/ext/luajit/src/lj_ir.o +0 -0
  256. data/lua-hooks/ext/luajit/src/lj_ir_dyn.o +0 -0
  257. data/lua-hooks/ext/luajit/src/lj_ircall.h +321 -0
  258. data/lua-hooks/ext/luajit/src/lj_iropt.h +161 -0
  259. data/lua-hooks/ext/luajit/src/lj_jit.h +440 -0
  260. data/lua-hooks/ext/luajit/src/lj_lex.c +482 -0
  261. data/lua-hooks/ext/luajit/src/lj_lex.h +86 -0
  262. data/lua-hooks/ext/luajit/src/lj_lex.o +0 -0
  263. data/lua-hooks/ext/luajit/src/lj_lex_dyn.o +0 -0
  264. data/lua-hooks/ext/luajit/src/lj_lib.c +303 -0
  265. data/lua-hooks/ext/luajit/src/lj_lib.h +115 -0
  266. data/lua-hooks/ext/luajit/src/lj_lib.o +0 -0
  267. data/lua-hooks/ext/luajit/src/lj_lib_dyn.o +0 -0
  268. data/lua-hooks/ext/luajit/src/lj_libdef.h +414 -0
  269. data/lua-hooks/ext/luajit/src/lj_load.c +168 -0
  270. data/lua-hooks/ext/luajit/src/lj_load.o +0 -0
  271. data/lua-hooks/ext/luajit/src/lj_load_dyn.o +0 -0
  272. data/lua-hooks/ext/luajit/src/lj_mcode.c +386 -0
  273. data/lua-hooks/ext/luajit/src/lj_mcode.h +30 -0
  274. data/lua-hooks/ext/luajit/src/lj_mcode.o +0 -0
  275. data/lua-hooks/ext/luajit/src/lj_mcode_dyn.o +0 -0
  276. data/lua-hooks/ext/luajit/src/lj_meta.c +477 -0
  277. data/lua-hooks/ext/luajit/src/lj_meta.h +38 -0
  278. data/lua-hooks/ext/luajit/src/lj_meta.o +0 -0
  279. data/lua-hooks/ext/luajit/src/lj_meta_dyn.o +0 -0
  280. data/lua-hooks/ext/luajit/src/lj_obj.c +50 -0
  281. data/lua-hooks/ext/luajit/src/lj_obj.h +976 -0
  282. data/lua-hooks/ext/luajit/src/lj_obj.o +0 -0
  283. data/lua-hooks/ext/luajit/src/lj_obj_dyn.o +0 -0
  284. data/lua-hooks/ext/luajit/src/lj_opt_dce.c +78 -0
  285. data/lua-hooks/ext/luajit/src/lj_opt_dce.o +0 -0
  286. data/lua-hooks/ext/luajit/src/lj_opt_dce_dyn.o +0 -0
  287. data/lua-hooks/ext/luajit/src/lj_opt_fold.c +2488 -0
  288. data/lua-hooks/ext/luajit/src/lj_opt_fold.o +0 -0
  289. data/lua-hooks/ext/luajit/src/lj_opt_fold_dyn.o +0 -0
  290. data/lua-hooks/ext/luajit/src/lj_opt_loop.c +449 -0
  291. data/lua-hooks/ext/luajit/src/lj_opt_loop.o +0 -0
  292. data/lua-hooks/ext/luajit/src/lj_opt_loop_dyn.o +0 -0
  293. data/lua-hooks/ext/luajit/src/lj_opt_mem.c +935 -0
  294. data/lua-hooks/ext/luajit/src/lj_opt_mem.o +0 -0
  295. data/lua-hooks/ext/luajit/src/lj_opt_mem_dyn.o +0 -0
  296. data/lua-hooks/ext/luajit/src/lj_opt_narrow.c +652 -0
  297. data/lua-hooks/ext/luajit/src/lj_opt_narrow.o +0 -0
  298. data/lua-hooks/ext/luajit/src/lj_opt_narrow_dyn.o +0 -0
  299. data/lua-hooks/ext/luajit/src/lj_opt_sink.c +245 -0
  300. data/lua-hooks/ext/luajit/src/lj_opt_sink.o +0 -0
  301. data/lua-hooks/ext/luajit/src/lj_opt_sink_dyn.o +0 -0
  302. data/lua-hooks/ext/luajit/src/lj_opt_split.c +856 -0
  303. data/lua-hooks/ext/luajit/src/lj_opt_split.o +0 -0
  304. data/lua-hooks/ext/luajit/src/lj_opt_split_dyn.o +0 -0
  305. data/lua-hooks/ext/luajit/src/lj_parse.c +2725 -0
  306. data/lua-hooks/ext/luajit/src/lj_parse.h +18 -0
  307. data/lua-hooks/ext/luajit/src/lj_parse.o +0 -0
  308. data/lua-hooks/ext/luajit/src/lj_parse_dyn.o +0 -0
  309. data/lua-hooks/ext/luajit/src/lj_profile.c +368 -0
  310. data/lua-hooks/ext/luajit/src/lj_profile.h +21 -0
  311. data/lua-hooks/ext/luajit/src/lj_profile.o +0 -0
  312. data/lua-hooks/ext/luajit/src/lj_profile_dyn.o +0 -0
  313. data/lua-hooks/ext/luajit/src/lj_recdef.h +270 -0
  314. data/lua-hooks/ext/luajit/src/lj_record.c +2554 -0
  315. data/lua-hooks/ext/luajit/src/lj_record.h +45 -0
  316. data/lua-hooks/ext/luajit/src/lj_record.o +0 -0
  317. data/lua-hooks/ext/luajit/src/lj_record_dyn.o +0 -0
  318. data/lua-hooks/ext/luajit/src/lj_snap.c +870 -0
  319. data/lua-hooks/ext/luajit/src/lj_snap.h +34 -0
  320. data/lua-hooks/ext/luajit/src/lj_snap.o +0 -0
  321. data/lua-hooks/ext/luajit/src/lj_snap_dyn.o +0 -0
  322. data/lua-hooks/ext/luajit/src/lj_state.c +300 -0
  323. data/lua-hooks/ext/luajit/src/lj_state.h +35 -0
  324. data/lua-hooks/ext/luajit/src/lj_state.o +0 -0
  325. data/lua-hooks/ext/luajit/src/lj_state_dyn.o +0 -0
  326. data/lua-hooks/ext/luajit/src/lj_str.c +197 -0
  327. data/lua-hooks/ext/luajit/src/lj_str.h +27 -0
  328. data/lua-hooks/ext/luajit/src/lj_str.o +0 -0
  329. data/lua-hooks/ext/luajit/src/lj_str_dyn.o +0 -0
  330. data/lua-hooks/ext/luajit/src/lj_strfmt.c +554 -0
  331. data/lua-hooks/ext/luajit/src/lj_strfmt.h +125 -0
  332. data/lua-hooks/ext/luajit/src/lj_strfmt.o +0 -0
  333. data/lua-hooks/ext/luajit/src/lj_strfmt_dyn.o +0 -0
  334. data/lua-hooks/ext/luajit/src/lj_strscan.c +547 -0
  335. data/lua-hooks/ext/luajit/src/lj_strscan.h +39 -0
  336. data/lua-hooks/ext/luajit/src/lj_strscan.o +0 -0
  337. data/lua-hooks/ext/luajit/src/lj_strscan_dyn.o +0 -0
  338. data/lua-hooks/ext/luajit/src/lj_tab.c +666 -0
  339. data/lua-hooks/ext/luajit/src/lj_tab.h +73 -0
  340. data/lua-hooks/ext/luajit/src/lj_tab.o +0 -0
  341. data/lua-hooks/ext/luajit/src/lj_tab_dyn.o +0 -0
  342. data/lua-hooks/ext/luajit/src/lj_target.h +164 -0
  343. data/lua-hooks/ext/luajit/src/lj_target_arm.h +270 -0
  344. data/lua-hooks/ext/luajit/src/lj_target_arm64.h +97 -0
  345. data/lua-hooks/ext/luajit/src/lj_target_mips.h +260 -0
  346. data/lua-hooks/ext/luajit/src/lj_target_ppc.h +280 -0
  347. data/lua-hooks/ext/luajit/src/lj_target_x86.h +345 -0
  348. data/lua-hooks/ext/luajit/src/lj_trace.c +859 -0
  349. data/lua-hooks/ext/luajit/src/lj_trace.h +54 -0
  350. data/lua-hooks/ext/luajit/src/lj_trace.o +0 -0
  351. data/lua-hooks/ext/luajit/src/lj_trace_dyn.o +0 -0
  352. data/lua-hooks/ext/luajit/src/lj_traceerr.h +63 -0
  353. data/lua-hooks/ext/luajit/src/lj_udata.c +34 -0
  354. data/lua-hooks/ext/luajit/src/lj_udata.h +14 -0
  355. data/lua-hooks/ext/luajit/src/lj_udata.o +0 -0
  356. data/lua-hooks/ext/luajit/src/lj_udata_dyn.o +0 -0
  357. data/lua-hooks/ext/luajit/src/lj_vm.S +2730 -0
  358. data/lua-hooks/ext/luajit/src/lj_vm.h +114 -0
  359. data/lua-hooks/ext/luajit/src/lj_vm.o +0 -0
  360. data/lua-hooks/ext/luajit/src/lj_vm_dyn.o +0 -0
  361. data/lua-hooks/ext/luajit/src/lj_vmevent.c +58 -0
  362. data/lua-hooks/ext/luajit/src/lj_vmevent.h +59 -0
  363. data/lua-hooks/ext/luajit/src/lj_vmevent.o +0 -0
  364. data/lua-hooks/ext/luajit/src/lj_vmevent_dyn.o +0 -0
  365. data/lua-hooks/ext/luajit/src/lj_vmmath.c +152 -0
  366. data/lua-hooks/ext/luajit/src/lj_vmmath.o +0 -0
  367. data/lua-hooks/ext/luajit/src/lj_vmmath_dyn.o +0 -0
  368. data/lua-hooks/ext/luajit/src/ljamalg.c +96 -0
  369. data/lua-hooks/ext/{lua → luajit/src}/lua.h +12 -7
  370. data/lua-hooks/ext/luajit/src/lua.hpp +9 -0
  371. data/lua-hooks/ext/luajit/src/luaconf.h +156 -0
  372. data/lua-hooks/ext/luajit/src/luajit +0 -0
  373. data/lua-hooks/ext/luajit/src/luajit.c +570 -0
  374. data/lua-hooks/ext/luajit/src/luajit.h +79 -0
  375. data/lua-hooks/ext/luajit/src/luajit.o +0 -0
  376. data/lua-hooks/ext/luajit/src/lualib.h +43 -0
  377. data/lua-hooks/ext/luajit/src/msvcbuild.bat +114 -0
  378. data/lua-hooks/ext/luajit/src/ps4build.bat +103 -0
  379. data/lua-hooks/ext/luajit/src/psvitabuild.bat +93 -0
  380. data/lua-hooks/ext/luajit/src/vm_arm.dasc +4585 -0
  381. data/lua-hooks/ext/luajit/src/vm_arm64.dasc +3764 -0
  382. data/lua-hooks/ext/luajit/src/vm_mips.dasc +4355 -0
  383. data/lua-hooks/ext/luajit/src/vm_ppc.dasc +5252 -0
  384. data/lua-hooks/ext/luajit/src/vm_x64.dasc +4902 -0
  385. data/lua-hooks/ext/luajit/src/vm_x86.dasc +5710 -0
  386. data/lua-hooks/ext/luajit/src/xb1build.bat +101 -0
  387. data/lua-hooks/ext/luajit/src/xedkbuild.bat +92 -0
  388. data/lua-hooks/ext/luautf8/lutf8lib.c +3 -3
  389. data/lua-hooks/lib/boot.lua +37 -2
  390. metadata +372 -69
  391. data/lua-hooks/ext/bitop/README +0 -22
  392. data/lua-hooks/ext/bitop/bit.c +0 -189
  393. data/lua-hooks/ext/extconf.rb +0 -38
  394. data/lua-hooks/ext/lua/COPYRIGHT +0 -34
  395. data/lua-hooks/ext/lua/lapi.c +0 -1087
  396. data/lua-hooks/ext/lua/lapi.h +0 -16
  397. data/lua-hooks/ext/lua/lauxlib.c +0 -652
  398. data/lua-hooks/ext/lua/lbaselib.c +0 -659
  399. data/lua-hooks/ext/lua/lcode.c +0 -831
  400. data/lua-hooks/ext/lua/lcode.h +0 -76
  401. data/lua-hooks/ext/lua/ldblib.c +0 -398
  402. data/lua-hooks/ext/lua/ldebug.c +0 -638
  403. data/lua-hooks/ext/lua/ldebug.h +0 -33
  404. data/lua-hooks/ext/lua/ldo.c +0 -519
  405. data/lua-hooks/ext/lua/ldo.h +0 -57
  406. data/lua-hooks/ext/lua/ldump.c +0 -164
  407. data/lua-hooks/ext/lua/lfunc.c +0 -174
  408. data/lua-hooks/ext/lua/lfunc.h +0 -34
  409. data/lua-hooks/ext/lua/lgc.c +0 -710
  410. data/lua-hooks/ext/lua/lgc.h +0 -110
  411. data/lua-hooks/ext/lua/linit.c +0 -38
  412. data/lua-hooks/ext/lua/liolib.c +0 -556
  413. data/lua-hooks/ext/lua/llex.c +0 -463
  414. data/lua-hooks/ext/lua/llex.h +0 -81
  415. data/lua-hooks/ext/lua/llimits.h +0 -128
  416. data/lua-hooks/ext/lua/lmathlib.c +0 -263
  417. data/lua-hooks/ext/lua/lmem.c +0 -86
  418. data/lua-hooks/ext/lua/lmem.h +0 -49
  419. data/lua-hooks/ext/lua/loadlib.c +0 -705
  420. data/lua-hooks/ext/lua/loadlib_rel.c +0 -760
  421. data/lua-hooks/ext/lua/lobject.c +0 -214
  422. data/lua-hooks/ext/lua/lobject.h +0 -381
  423. data/lua-hooks/ext/lua/lopcodes.c +0 -102
  424. data/lua-hooks/ext/lua/lopcodes.h +0 -268
  425. data/lua-hooks/ext/lua/loslib.c +0 -243
  426. data/lua-hooks/ext/lua/lparser.c +0 -1339
  427. data/lua-hooks/ext/lua/lparser.h +0 -82
  428. data/lua-hooks/ext/lua/lstate.c +0 -214
  429. data/lua-hooks/ext/lua/lstate.h +0 -169
  430. data/lua-hooks/ext/lua/lstring.c +0 -111
  431. data/lua-hooks/ext/lua/lstring.h +0 -31
  432. data/lua-hooks/ext/lua/lstrlib.c +0 -871
  433. data/lua-hooks/ext/lua/ltable.c +0 -588
  434. data/lua-hooks/ext/lua/ltable.h +0 -40
  435. data/lua-hooks/ext/lua/ltablib.c +0 -287
  436. data/lua-hooks/ext/lua/ltm.c +0 -75
  437. data/lua-hooks/ext/lua/ltm.h +0 -54
  438. data/lua-hooks/ext/lua/lua.c +0 -392
  439. data/lua-hooks/ext/lua/lua.def +0 -131
  440. data/lua-hooks/ext/lua/lua.rc +0 -28
  441. data/lua-hooks/ext/lua/lua_dll.rc +0 -26
  442. data/lua-hooks/ext/lua/luac.c +0 -200
  443. data/lua-hooks/ext/lua/luac.rc +0 -1
  444. data/lua-hooks/ext/lua/luaconf.h +0 -763
  445. data/lua-hooks/ext/lua/luaconf.h.in +0 -724
  446. data/lua-hooks/ext/lua/luaconf.h.orig +0 -763
  447. data/lua-hooks/ext/lua/lualib.h +0 -53
  448. data/lua-hooks/ext/lua/lundump.c +0 -227
  449. data/lua-hooks/ext/lua/lundump.h +0 -36
  450. data/lua-hooks/ext/lua/lvm.c +0 -767
  451. data/lua-hooks/ext/lua/lvm.h +0 -36
  452. data/lua-hooks/ext/lua/lzio.c +0 -82
  453. data/lua-hooks/ext/lua/lzio.h +0 -67
  454. data/lua-hooks/ext/lua/print.c +0 -227
@@ -0,0 +1,356 @@
1
+ /*
2
+ ** Auxiliary library for the Lua/C API.
3
+ ** Copyright (C) 2005-2015 Mike Pall. See Copyright Notice in luajit.h
4
+ **
5
+ ** Major parts taken verbatim or adapted from the Lua interpreter.
6
+ ** Copyright (C) 1994-2008 Lua.org, PUC-Rio. See Copyright Notice in lua.h
7
+ */
8
+
9
+ #include <errno.h>
10
+ #include <stdarg.h>
11
+ #include <stdio.h>
12
+
13
+ #define lib_aux_c
14
+ #define LUA_LIB
15
+
16
+ #include "lua.h"
17
+ #include "lauxlib.h"
18
+
19
+ #include "lj_obj.h"
20
+ #include "lj_err.h"
21
+ #include "lj_state.h"
22
+ #include "lj_trace.h"
23
+ #include "lj_lib.h"
24
+
25
+ #if LJ_TARGET_POSIX
26
+ #include <sys/wait.h>
27
+ #endif
28
+
29
+ /* -- I/O error handling -------------------------------------------------- */
30
+
31
+ LUALIB_API int luaL_fileresult(lua_State *L, int stat, const char *fname)
32
+ {
33
+ if (stat) {
34
+ setboolV(L->top++, 1);
35
+ return 1;
36
+ } else {
37
+ int en = errno; /* Lua API calls may change this value. */
38
+ setnilV(L->top++);
39
+ if (fname)
40
+ lua_pushfstring(L, "%s: %s", fname, strerror(en));
41
+ else
42
+ lua_pushfstring(L, "%s", strerror(en));
43
+ setintV(L->top++, en);
44
+ lj_trace_abort(G(L));
45
+ return 3;
46
+ }
47
+ }
48
+
49
+ LUALIB_API int luaL_execresult(lua_State *L, int stat)
50
+ {
51
+ if (stat != -1) {
52
+ #if LJ_TARGET_POSIX
53
+ if (WIFSIGNALED(stat)) {
54
+ stat = WTERMSIG(stat);
55
+ setnilV(L->top++);
56
+ lua_pushliteral(L, "signal");
57
+ } else {
58
+ if (WIFEXITED(stat))
59
+ stat = WEXITSTATUS(stat);
60
+ if (stat == 0)
61
+ setboolV(L->top++, 1);
62
+ else
63
+ setnilV(L->top++);
64
+ lua_pushliteral(L, "exit");
65
+ }
66
+ #else
67
+ if (stat == 0)
68
+ setboolV(L->top++, 1);
69
+ else
70
+ setnilV(L->top++);
71
+ lua_pushliteral(L, "exit");
72
+ #endif
73
+ setintV(L->top++, stat);
74
+ return 3;
75
+ }
76
+ return luaL_fileresult(L, 0, NULL);
77
+ }
78
+
79
+ /* -- Module registration ------------------------------------------------- */
80
+
81
+ LUALIB_API const char *luaL_findtable(lua_State *L, int idx,
82
+ const char *fname, int szhint)
83
+ {
84
+ const char *e;
85
+ lua_pushvalue(L, idx);
86
+ do {
87
+ e = strchr(fname, '.');
88
+ if (e == NULL) e = fname + strlen(fname);
89
+ lua_pushlstring(L, fname, (size_t)(e - fname));
90
+ lua_rawget(L, -2);
91
+ if (lua_isnil(L, -1)) { /* no such field? */
92
+ lua_pop(L, 1); /* remove this nil */
93
+ lua_createtable(L, 0, (*e == '.' ? 1 : szhint)); /* new table for field */
94
+ lua_pushlstring(L, fname, (size_t)(e - fname));
95
+ lua_pushvalue(L, -2);
96
+ lua_settable(L, -4); /* set new table into field */
97
+ } else if (!lua_istable(L, -1)) { /* field has a non-table value? */
98
+ lua_pop(L, 2); /* remove table and value */
99
+ return fname; /* return problematic part of the name */
100
+ }
101
+ lua_remove(L, -2); /* remove previous table */
102
+ fname = e + 1;
103
+ } while (*e == '.');
104
+ return NULL;
105
+ }
106
+
107
+ static int libsize(const luaL_Reg *l)
108
+ {
109
+ int size = 0;
110
+ for (; l->name; l++) size++;
111
+ return size;
112
+ }
113
+
114
+ LUALIB_API void luaL_openlib(lua_State *L, const char *libname,
115
+ const luaL_Reg *l, int nup)
116
+ {
117
+ lj_lib_checkfpu(L);
118
+ if (libname) {
119
+ int size = libsize(l);
120
+ /* check whether lib already exists */
121
+ luaL_findtable(L, LUA_REGISTRYINDEX, "_LOADED", 16);
122
+ lua_getfield(L, -1, libname); /* get _LOADED[libname] */
123
+ if (!lua_istable(L, -1)) { /* not found? */
124
+ lua_pop(L, 1); /* remove previous result */
125
+ /* try global variable (and create one if it does not exist) */
126
+ if (luaL_findtable(L, LUA_GLOBALSINDEX, libname, size) != NULL)
127
+ lj_err_callerv(L, LJ_ERR_BADMODN, libname);
128
+ lua_pushvalue(L, -1);
129
+ lua_setfield(L, -3, libname); /* _LOADED[libname] = new table */
130
+ }
131
+ lua_remove(L, -2); /* remove _LOADED table */
132
+ lua_insert(L, -(nup+1)); /* move library table to below upvalues */
133
+ }
134
+ for (; l->name; l++) {
135
+ int i;
136
+ for (i = 0; i < nup; i++) /* copy upvalues to the top */
137
+ lua_pushvalue(L, -nup);
138
+ lua_pushcclosure(L, l->func, nup);
139
+ lua_setfield(L, -(nup+2), l->name);
140
+ }
141
+ lua_pop(L, nup); /* remove upvalues */
142
+ }
143
+
144
+ LUALIB_API void luaL_register(lua_State *L, const char *libname,
145
+ const luaL_Reg *l)
146
+ {
147
+ luaL_openlib(L, libname, l, 0);
148
+ }
149
+
150
+ LUALIB_API const char *luaL_gsub(lua_State *L, const char *s,
151
+ const char *p, const char *r)
152
+ {
153
+ const char *wild;
154
+ size_t l = strlen(p);
155
+ luaL_Buffer b;
156
+ luaL_buffinit(L, &b);
157
+ while ((wild = strstr(s, p)) != NULL) {
158
+ luaL_addlstring(&b, s, (size_t)(wild - s)); /* push prefix */
159
+ luaL_addstring(&b, r); /* push replacement in place of pattern */
160
+ s = wild + l; /* continue after `p' */
161
+ }
162
+ luaL_addstring(&b, s); /* push last suffix */
163
+ luaL_pushresult(&b);
164
+ return lua_tostring(L, -1);
165
+ }
166
+
167
+ /* -- Buffer handling ----------------------------------------------------- */
168
+
169
+ #define bufflen(B) ((size_t)((B)->p - (B)->buffer))
170
+ #define bufffree(B) ((size_t)(LUAL_BUFFERSIZE - bufflen(B)))
171
+
172
+ static int emptybuffer(luaL_Buffer *B)
173
+ {
174
+ size_t l = bufflen(B);
175
+ if (l == 0)
176
+ return 0; /* put nothing on stack */
177
+ lua_pushlstring(B->L, B->buffer, l);
178
+ B->p = B->buffer;
179
+ B->lvl++;
180
+ return 1;
181
+ }
182
+
183
+ static void adjuststack(luaL_Buffer *B)
184
+ {
185
+ if (B->lvl > 1) {
186
+ lua_State *L = B->L;
187
+ int toget = 1; /* number of levels to concat */
188
+ size_t toplen = lua_strlen(L, -1);
189
+ do {
190
+ size_t l = lua_strlen(L, -(toget+1));
191
+ if (!(B->lvl - toget + 1 >= LUA_MINSTACK/2 || toplen > l))
192
+ break;
193
+ toplen += l;
194
+ toget++;
195
+ } while (toget < B->lvl);
196
+ lua_concat(L, toget);
197
+ B->lvl = B->lvl - toget + 1;
198
+ }
199
+ }
200
+
201
+ LUALIB_API char *luaL_prepbuffer(luaL_Buffer *B)
202
+ {
203
+ if (emptybuffer(B))
204
+ adjuststack(B);
205
+ return B->buffer;
206
+ }
207
+
208
+ LUALIB_API void luaL_addlstring(luaL_Buffer *B, const char *s, size_t l)
209
+ {
210
+ while (l--)
211
+ luaL_addchar(B, *s++);
212
+ }
213
+
214
+ LUALIB_API void luaL_addstring(luaL_Buffer *B, const char *s)
215
+ {
216
+ luaL_addlstring(B, s, strlen(s));
217
+ }
218
+
219
+ LUALIB_API void luaL_pushresult(luaL_Buffer *B)
220
+ {
221
+ emptybuffer(B);
222
+ lua_concat(B->L, B->lvl);
223
+ B->lvl = 1;
224
+ }
225
+
226
+ LUALIB_API void luaL_addvalue(luaL_Buffer *B)
227
+ {
228
+ lua_State *L = B->L;
229
+ size_t vl;
230
+ const char *s = lua_tolstring(L, -1, &vl);
231
+ if (vl <= bufffree(B)) { /* fit into buffer? */
232
+ memcpy(B->p, s, vl); /* put it there */
233
+ B->p += vl;
234
+ lua_pop(L, 1); /* remove from stack */
235
+ } else {
236
+ if (emptybuffer(B))
237
+ lua_insert(L, -2); /* put buffer before new value */
238
+ B->lvl++; /* add new value into B stack */
239
+ adjuststack(B);
240
+ }
241
+ }
242
+
243
+ LUALIB_API void luaL_buffinit(lua_State *L, luaL_Buffer *B)
244
+ {
245
+ B->L = L;
246
+ B->p = B->buffer;
247
+ B->lvl = 0;
248
+ }
249
+
250
+ /* -- Reference management ------------------------------------------------ */
251
+
252
+ #define FREELIST_REF 0
253
+
254
+ /* Convert a stack index to an absolute index. */
255
+ #define abs_index(L, i) \
256
+ ((i) > 0 || (i) <= LUA_REGISTRYINDEX ? (i) : lua_gettop(L) + (i) + 1)
257
+
258
+ LUALIB_API int luaL_ref(lua_State *L, int t)
259
+ {
260
+ int ref;
261
+ t = abs_index(L, t);
262
+ if (lua_isnil(L, -1)) {
263
+ lua_pop(L, 1); /* remove from stack */
264
+ return LUA_REFNIL; /* `nil' has a unique fixed reference */
265
+ }
266
+ lua_rawgeti(L, t, FREELIST_REF); /* get first free element */
267
+ ref = (int)lua_tointeger(L, -1); /* ref = t[FREELIST_REF] */
268
+ lua_pop(L, 1); /* remove it from stack */
269
+ if (ref != 0) { /* any free element? */
270
+ lua_rawgeti(L, t, ref); /* remove it from list */
271
+ lua_rawseti(L, t, FREELIST_REF); /* (t[FREELIST_REF] = t[ref]) */
272
+ } else { /* no free elements */
273
+ ref = (int)lua_objlen(L, t);
274
+ ref++; /* create new reference */
275
+ }
276
+ lua_rawseti(L, t, ref);
277
+ return ref;
278
+ }
279
+
280
+ LUALIB_API void luaL_unref(lua_State *L, int t, int ref)
281
+ {
282
+ if (ref >= 0) {
283
+ t = abs_index(L, t);
284
+ lua_rawgeti(L, t, FREELIST_REF);
285
+ lua_rawseti(L, t, ref); /* t[ref] = t[FREELIST_REF] */
286
+ lua_pushinteger(L, ref);
287
+ lua_rawseti(L, t, FREELIST_REF); /* t[FREELIST_REF] = ref */
288
+ }
289
+ }
290
+
291
+ /* -- Default allocator and panic function -------------------------------- */
292
+
293
+ static int panic(lua_State *L)
294
+ {
295
+ const char *s = lua_tostring(L, -1);
296
+ fputs("PANIC: unprotected error in call to Lua API (", stderr);
297
+ fputs(s ? s : "?", stderr);
298
+ fputc(')', stderr); fputc('\n', stderr);
299
+ fflush(stderr);
300
+ return 0;
301
+ }
302
+
303
+ #ifdef LUAJIT_USE_SYSMALLOC
304
+
305
+ #if LJ_64 && !defined(LUAJIT_USE_VALGRIND)
306
+ #error "Must use builtin allocator for 64 bit target"
307
+ #endif
308
+
309
+ static void *mem_alloc(void *ud, void *ptr, size_t osize, size_t nsize)
310
+ {
311
+ (void)ud;
312
+ (void)osize;
313
+ if (nsize == 0) {
314
+ free(ptr);
315
+ return NULL;
316
+ } else {
317
+ return realloc(ptr, nsize);
318
+ }
319
+ }
320
+
321
+ LUALIB_API lua_State *luaL_newstate(void)
322
+ {
323
+ lua_State *L = lua_newstate(mem_alloc, NULL);
324
+ if (L) G(L)->panic = panic;
325
+ return L;
326
+ }
327
+
328
+ #else
329
+
330
+ #include "lj_alloc.h"
331
+
332
+ LUALIB_API lua_State *luaL_newstate(void)
333
+ {
334
+ lua_State *L;
335
+ void *ud = lj_alloc_create();
336
+ if (ud == NULL) return NULL;
337
+ #if LJ_64
338
+ L = lj_state_newstate(lj_alloc_f, ud);
339
+ #else
340
+ L = lua_newstate(lj_alloc_f, ud);
341
+ #endif
342
+ if (L) G(L)->panic = panic;
343
+ return L;
344
+ }
345
+
346
+ #if LJ_64
347
+ LUA_API lua_State *lua_newstate(lua_Alloc f, void *ud)
348
+ {
349
+ UNUSED(f); UNUSED(ud);
350
+ fputs("Must use luaL_newstate() for 64 bit target\n", stderr);
351
+ return NULL;
352
+ }
353
+ #endif
354
+
355
+ #endif
356
+
@@ -0,0 +1,664 @@
1
+ /*
2
+ ** Base and coroutine library.
3
+ ** Copyright (C) 2005-2015 Mike Pall. See Copyright Notice in luajit.h
4
+ **
5
+ ** Major portions taken verbatim or adapted from the Lua interpreter.
6
+ ** Copyright (C) 1994-2011 Lua.org, PUC-Rio. See Copyright Notice in lua.h
7
+ */
8
+
9
+ #include <stdio.h>
10
+
11
+ #define lib_base_c
12
+ #define LUA_LIB
13
+
14
+ #include "lua.h"
15
+ #include "lauxlib.h"
16
+ #include "lualib.h"
17
+
18
+ #include "lj_obj.h"
19
+ #include "lj_gc.h"
20
+ #include "lj_err.h"
21
+ #include "lj_debug.h"
22
+ #include "lj_str.h"
23
+ #include "lj_tab.h"
24
+ #include "lj_meta.h"
25
+ #include "lj_state.h"
26
+ #if LJ_HASFFI
27
+ #include "lj_ctype.h"
28
+ #include "lj_cconv.h"
29
+ #endif
30
+ #include "lj_bc.h"
31
+ #include "lj_ff.h"
32
+ #include "lj_dispatch.h"
33
+ #include "lj_char.h"
34
+ #include "lj_strscan.h"
35
+ #include "lj_strfmt.h"
36
+ #include "lj_lib.h"
37
+
38
+ /* -- Base library: checks ------------------------------------------------ */
39
+
40
+ #define LJLIB_MODULE_base
41
+
42
+ LJLIB_ASM(assert) LJLIB_REC(.)
43
+ {
44
+ GCstr *s;
45
+ lj_lib_checkany(L, 1);
46
+ s = lj_lib_optstr(L, 2);
47
+ if (s)
48
+ lj_err_callermsg(L, strdata(s));
49
+ else
50
+ lj_err_caller(L, LJ_ERR_ASSERT);
51
+ return FFH_UNREACHABLE;
52
+ }
53
+
54
+ /* ORDER LJ_T */
55
+ LJLIB_PUSH("nil")
56
+ LJLIB_PUSH("boolean")
57
+ LJLIB_PUSH(top-1) /* boolean */
58
+ LJLIB_PUSH("userdata")
59
+ LJLIB_PUSH("string")
60
+ LJLIB_PUSH("upval")
61
+ LJLIB_PUSH("thread")
62
+ LJLIB_PUSH("proto")
63
+ LJLIB_PUSH("function")
64
+ LJLIB_PUSH("trace")
65
+ LJLIB_PUSH("cdata")
66
+ LJLIB_PUSH("table")
67
+ LJLIB_PUSH(top-9) /* userdata */
68
+ LJLIB_PUSH("number")
69
+ LJLIB_ASM_(type) LJLIB_REC(.)
70
+ /* Recycle the lj_lib_checkany(L, 1) from assert. */
71
+
72
+ /* -- Base library: iterators --------------------------------------------- */
73
+
74
+ /* This solves a circular dependency problem -- change FF_next_N as needed. */
75
+ LJ_STATIC_ASSERT((int)FF_next == FF_next_N);
76
+
77
+ LJLIB_ASM(next)
78
+ {
79
+ lj_lib_checktab(L, 1);
80
+ return FFH_UNREACHABLE;
81
+ }
82
+
83
+ #if LJ_52 || LJ_HASFFI
84
+ static int ffh_pairs(lua_State *L, MMS mm)
85
+ {
86
+ TValue *o = lj_lib_checkany(L, 1);
87
+ cTValue *mo = lj_meta_lookup(L, o, mm);
88
+ if ((LJ_52 || tviscdata(o)) && !tvisnil(mo)) {
89
+ L->top = o+1; /* Only keep one argument. */
90
+ copyTV(L, L->base-1-LJ_FR2, mo); /* Replace callable. */
91
+ return FFH_TAILCALL;
92
+ } else {
93
+ if (!tvistab(o)) lj_err_argt(L, 1, LUA_TTABLE);
94
+ if (LJ_FR2) { copyTV(L, o-1, o); o--; }
95
+ setfuncV(L, o-1, funcV(lj_lib_upvalue(L, 1)));
96
+ if (mm == MM_pairs) setnilV(o+1); else setintV(o+1, 0);
97
+ return FFH_RES(3);
98
+ }
99
+ }
100
+ #else
101
+ #define ffh_pairs(L, mm) (lj_lib_checktab(L, 1), FFH_UNREACHABLE)
102
+ #endif
103
+
104
+ LJLIB_PUSH(lastcl)
105
+ LJLIB_ASM(pairs) LJLIB_REC(xpairs 0)
106
+ {
107
+ return ffh_pairs(L, MM_pairs);
108
+ }
109
+
110
+ LJLIB_NOREGUV LJLIB_ASM(ipairs_aux) LJLIB_REC(.)
111
+ {
112
+ lj_lib_checktab(L, 1);
113
+ lj_lib_checkint(L, 2);
114
+ return FFH_UNREACHABLE;
115
+ }
116
+
117
+ LJLIB_PUSH(lastcl)
118
+ LJLIB_ASM(ipairs) LJLIB_REC(xpairs 1)
119
+ {
120
+ return ffh_pairs(L, MM_ipairs);
121
+ }
122
+
123
+ /* -- Base library: getters and setters ----------------------------------- */
124
+
125
+ LJLIB_ASM_(getmetatable) LJLIB_REC(.)
126
+ /* Recycle the lj_lib_checkany(L, 1) from assert. */
127
+
128
+ LJLIB_ASM(setmetatable) LJLIB_REC(.)
129
+ {
130
+ GCtab *t = lj_lib_checktab(L, 1);
131
+ GCtab *mt = lj_lib_checktabornil(L, 2);
132
+ if (!tvisnil(lj_meta_lookup(L, L->base, MM_metatable)))
133
+ lj_err_caller(L, LJ_ERR_PROTMT);
134
+ setgcref(t->metatable, obj2gco(mt));
135
+ if (mt) { lj_gc_objbarriert(L, t, mt); }
136
+ settabV(L, L->base-1-LJ_FR2, t);
137
+ return FFH_RES(1);
138
+ }
139
+
140
+ LJLIB_CF(getfenv) LJLIB_REC(.)
141
+ {
142
+ GCfunc *fn;
143
+ cTValue *o = L->base;
144
+ if (!(o < L->top && tvisfunc(o))) {
145
+ int level = lj_lib_optint(L, 1, 1);
146
+ o = lj_debug_frame(L, level, &level);
147
+ if (o == NULL)
148
+ lj_err_arg(L, 1, LJ_ERR_INVLVL);
149
+ if (LJ_FR2) o--;
150
+ }
151
+ fn = &gcval(o)->fn;
152
+ settabV(L, L->top++, isluafunc(fn) ? tabref(fn->l.env) : tabref(L->env));
153
+ return 1;
154
+ }
155
+
156
+ LJLIB_CF(setfenv)
157
+ {
158
+ GCfunc *fn;
159
+ GCtab *t = lj_lib_checktab(L, 2);
160
+ cTValue *o = L->base;
161
+ if (!(o < L->top && tvisfunc(o))) {
162
+ int level = lj_lib_checkint(L, 1);
163
+ if (level == 0) {
164
+ /* NOBARRIER: A thread (i.e. L) is never black. */
165
+ setgcref(L->env, obj2gco(t));
166
+ return 0;
167
+ }
168
+ o = lj_debug_frame(L, level, &level);
169
+ if (o == NULL)
170
+ lj_err_arg(L, 1, LJ_ERR_INVLVL);
171
+ if (LJ_FR2) o--;
172
+ }
173
+ fn = &gcval(o)->fn;
174
+ if (!isluafunc(fn))
175
+ lj_err_caller(L, LJ_ERR_SETFENV);
176
+ setgcref(fn->l.env, obj2gco(t));
177
+ lj_gc_objbarrier(L, obj2gco(fn), t);
178
+ setfuncV(L, L->top++, fn);
179
+ return 1;
180
+ }
181
+
182
+ LJLIB_ASM(rawget) LJLIB_REC(.)
183
+ {
184
+ lj_lib_checktab(L, 1);
185
+ lj_lib_checkany(L, 2);
186
+ return FFH_UNREACHABLE;
187
+ }
188
+
189
+ LJLIB_CF(rawset) LJLIB_REC(.)
190
+ {
191
+ lj_lib_checktab(L, 1);
192
+ lj_lib_checkany(L, 2);
193
+ L->top = 1+lj_lib_checkany(L, 3);
194
+ lua_rawset(L, 1);
195
+ return 1;
196
+ }
197
+
198
+ LJLIB_CF(rawequal) LJLIB_REC(.)
199
+ {
200
+ cTValue *o1 = lj_lib_checkany(L, 1);
201
+ cTValue *o2 = lj_lib_checkany(L, 2);
202
+ setboolV(L->top-1, lj_obj_equal(o1, o2));
203
+ return 1;
204
+ }
205
+
206
+ #if LJ_52
207
+ LJLIB_CF(rawlen) LJLIB_REC(.)
208
+ {
209
+ cTValue *o = L->base;
210
+ int32_t len;
211
+ if (L->top > o && tvisstr(o))
212
+ len = (int32_t)strV(o)->len;
213
+ else
214
+ len = (int32_t)lj_tab_len(lj_lib_checktab(L, 1));
215
+ setintV(L->top-1, len);
216
+ return 1;
217
+ }
218
+ #endif
219
+
220
+ LJLIB_CF(unpack)
221
+ {
222
+ GCtab *t = lj_lib_checktab(L, 1);
223
+ int32_t n, i = lj_lib_optint(L, 2, 1);
224
+ int32_t e = (L->base+3-1 < L->top && !tvisnil(L->base+3-1)) ?
225
+ lj_lib_checkint(L, 3) : (int32_t)lj_tab_len(t);
226
+ if (i > e) return 0;
227
+ n = e - i + 1;
228
+ if (n <= 0 || !lua_checkstack(L, n))
229
+ lj_err_caller(L, LJ_ERR_UNPACK);
230
+ do {
231
+ cTValue *tv = lj_tab_getint(t, i);
232
+ if (tv) {
233
+ copyTV(L, L->top++, tv);
234
+ } else {
235
+ setnilV(L->top++);
236
+ }
237
+ } while (i++ < e);
238
+ return n;
239
+ }
240
+
241
+ LJLIB_CF(select) LJLIB_REC(.)
242
+ {
243
+ int32_t n = (int32_t)(L->top - L->base);
244
+ if (n >= 1 && tvisstr(L->base) && *strVdata(L->base) == '#') {
245
+ setintV(L->top-1, n-1);
246
+ return 1;
247
+ } else {
248
+ int32_t i = lj_lib_checkint(L, 1);
249
+ if (i < 0) i = n + i; else if (i > n) i = n;
250
+ if (i < 1)
251
+ lj_err_arg(L, 1, LJ_ERR_IDXRNG);
252
+ return n - i;
253
+ }
254
+ }
255
+
256
+ /* -- Base library: conversions ------------------------------------------- */
257
+
258
+ LJLIB_ASM(tonumber) LJLIB_REC(.)
259
+ {
260
+ int32_t base = lj_lib_optint(L, 2, 10);
261
+ if (base == 10) {
262
+ TValue *o = lj_lib_checkany(L, 1);
263
+ if (lj_strscan_numberobj(o)) {
264
+ copyTV(L, L->base-1-LJ_FR2, o);
265
+ return FFH_RES(1);
266
+ }
267
+ #if LJ_HASFFI
268
+ if (tviscdata(o)) {
269
+ CTState *cts = ctype_cts(L);
270
+ CType *ct = lj_ctype_rawref(cts, cdataV(o)->ctypeid);
271
+ if (ctype_isenum(ct->info)) ct = ctype_child(cts, ct);
272
+ if (ctype_isnum(ct->info) || ctype_iscomplex(ct->info)) {
273
+ if (LJ_DUALNUM && ctype_isinteger_or_bool(ct->info) &&
274
+ ct->size <= 4 && !(ct->size == 4 && (ct->info & CTF_UNSIGNED))) {
275
+ int32_t i;
276
+ lj_cconv_ct_tv(cts, ctype_get(cts, CTID_INT32), (uint8_t *)&i, o, 0);
277
+ setintV(L->base-1-LJ_FR2, i);
278
+ return FFH_RES(1);
279
+ }
280
+ lj_cconv_ct_tv(cts, ctype_get(cts, CTID_DOUBLE),
281
+ (uint8_t *)&(L->base-1-LJ_FR2)->n, o, 0);
282
+ return FFH_RES(1);
283
+ }
284
+ }
285
+ #endif
286
+ } else {
287
+ const char *p = strdata(lj_lib_checkstr(L, 1));
288
+ char *ep;
289
+ unsigned long ul;
290
+ if (base < 2 || base > 36)
291
+ lj_err_arg(L, 2, LJ_ERR_BASERNG);
292
+ ul = strtoul(p, &ep, base);
293
+ if (p != ep) {
294
+ while (lj_char_isspace((unsigned char)(*ep))) ep++;
295
+ if (*ep == '\0') {
296
+ if (LJ_DUALNUM && LJ_LIKELY(ul < 0x80000000u))
297
+ setintV(L->base-1-LJ_FR2, (int32_t)ul);
298
+ else
299
+ setnumV(L->base-1-LJ_FR2, (lua_Number)ul);
300
+ return FFH_RES(1);
301
+ }
302
+ }
303
+ }
304
+ setnilV(L->base-1-LJ_FR2);
305
+ return FFH_RES(1);
306
+ }
307
+
308
+ LJLIB_ASM(tostring) LJLIB_REC(.)
309
+ {
310
+ TValue *o = lj_lib_checkany(L, 1);
311
+ cTValue *mo;
312
+ L->top = o+1; /* Only keep one argument. */
313
+ if (!tvisnil(mo = lj_meta_lookup(L, o, MM_tostring))) {
314
+ copyTV(L, L->base-1-LJ_FR2, mo); /* Replace callable. */
315
+ return FFH_TAILCALL;
316
+ }
317
+ lj_gc_check(L);
318
+ setstrV(L, L->base-1-LJ_FR2, lj_strfmt_obj(L, L->base));
319
+ return FFH_RES(1);
320
+ }
321
+
322
+ /* -- Base library: throw and catch errors -------------------------------- */
323
+
324
+ LJLIB_CF(error)
325
+ {
326
+ int32_t level = lj_lib_optint(L, 2, 1);
327
+ lua_settop(L, 1);
328
+ if (lua_isstring(L, 1) && level > 0) {
329
+ luaL_where(L, level);
330
+ lua_pushvalue(L, 1);
331
+ lua_concat(L, 2);
332
+ }
333
+ return lua_error(L);
334
+ }
335
+
336
+ LJLIB_ASM(pcall) LJLIB_REC(.)
337
+ {
338
+ lj_lib_checkany(L, 1);
339
+ lj_lib_checkfunc(L, 2); /* For xpcall only. */
340
+ return FFH_UNREACHABLE;
341
+ }
342
+ LJLIB_ASM_(xpcall) LJLIB_REC(.)
343
+
344
+ /* -- Base library: load Lua code ----------------------------------------- */
345
+
346
+ static int load_aux(lua_State *L, int status, int envarg)
347
+ {
348
+ if (status == 0) {
349
+ if (tvistab(L->base+envarg-1)) {
350
+ GCfunc *fn = funcV(L->top-1);
351
+ GCtab *t = tabV(L->base+envarg-1);
352
+ setgcref(fn->c.env, obj2gco(t));
353
+ lj_gc_objbarrier(L, fn, t);
354
+ }
355
+ return 1;
356
+ } else {
357
+ setnilV(L->top-2);
358
+ return 2;
359
+ }
360
+ }
361
+
362
+ LJLIB_CF(loadfile)
363
+ {
364
+ GCstr *fname = lj_lib_optstr(L, 1);
365
+ GCstr *mode = lj_lib_optstr(L, 2);
366
+ int status;
367
+ lua_settop(L, 3); /* Ensure env arg exists. */
368
+ status = luaL_loadfilex(L, fname ? strdata(fname) : NULL,
369
+ mode ? strdata(mode) : NULL);
370
+ return load_aux(L, status, 3);
371
+ }
372
+
373
+ static const char *reader_func(lua_State *L, void *ud, size_t *size)
374
+ {
375
+ UNUSED(ud);
376
+ luaL_checkstack(L, 2, "too many nested functions");
377
+ copyTV(L, L->top++, L->base);
378
+ lua_call(L, 0, 1); /* Call user-supplied function. */
379
+ L->top--;
380
+ if (tvisnil(L->top)) {
381
+ *size = 0;
382
+ return NULL;
383
+ } else if (tvisstr(L->top) || tvisnumber(L->top)) {
384
+ copyTV(L, L->base+4, L->top); /* Anchor string in reserved stack slot. */
385
+ return lua_tolstring(L, 5, size);
386
+ } else {
387
+ lj_err_caller(L, LJ_ERR_RDRSTR);
388
+ return NULL;
389
+ }
390
+ }
391
+
392
+ LJLIB_CF(load)
393
+ {
394
+ GCstr *name = lj_lib_optstr(L, 2);
395
+ GCstr *mode = lj_lib_optstr(L, 3);
396
+ int status;
397
+ if (L->base < L->top && (tvisstr(L->base) || tvisnumber(L->base))) {
398
+ GCstr *s = lj_lib_checkstr(L, 1);
399
+ lua_settop(L, 4); /* Ensure env arg exists. */
400
+ status = luaL_loadbufferx(L, strdata(s), s->len, strdata(name ? name : s),
401
+ mode ? strdata(mode) : NULL);
402
+ } else {
403
+ lj_lib_checkfunc(L, 1);
404
+ lua_settop(L, 5); /* Reserve a slot for the string from the reader. */
405
+ status = lua_loadx(L, reader_func, NULL, name ? strdata(name) : "=(load)",
406
+ mode ? strdata(mode) : NULL);
407
+ }
408
+ return load_aux(L, status, 4);
409
+ }
410
+
411
+ LJLIB_CF(loadstring)
412
+ {
413
+ return lj_cf_load(L);
414
+ }
415
+
416
+ LJLIB_CF(dofile)
417
+ {
418
+ GCstr *fname = lj_lib_optstr(L, 1);
419
+ setnilV(L->top);
420
+ L->top = L->base+1;
421
+ if (luaL_loadfile(L, fname ? strdata(fname) : NULL) != 0)
422
+ lua_error(L);
423
+ lua_call(L, 0, LUA_MULTRET);
424
+ return (int)(L->top - L->base) - 1;
425
+ }
426
+
427
+ /* -- Base library: GC control -------------------------------------------- */
428
+
429
+ LJLIB_CF(gcinfo)
430
+ {
431
+ setintV(L->top++, (int32_t)(G(L)->gc.total >> 10));
432
+ return 1;
433
+ }
434
+
435
+ LJLIB_CF(collectgarbage)
436
+ {
437
+ int opt = lj_lib_checkopt(L, 1, LUA_GCCOLLECT, /* ORDER LUA_GC* */
438
+ "\4stop\7restart\7collect\5count\1\377\4step\10setpause\12setstepmul");
439
+ int32_t data = lj_lib_optint(L, 2, 0);
440
+ if (opt == LUA_GCCOUNT) {
441
+ setnumV(L->top, (lua_Number)G(L)->gc.total/1024.0);
442
+ } else {
443
+ int res = lua_gc(L, opt, data);
444
+ if (opt == LUA_GCSTEP)
445
+ setboolV(L->top, res);
446
+ else
447
+ setintV(L->top, res);
448
+ }
449
+ L->top++;
450
+ return 1;
451
+ }
452
+
453
+ /* -- Base library: miscellaneous functions ------------------------------- */
454
+
455
+ LJLIB_PUSH(top-2) /* Upvalue holds weak table. */
456
+ LJLIB_CF(newproxy)
457
+ {
458
+ lua_settop(L, 1);
459
+ lua_newuserdata(L, 0);
460
+ if (lua_toboolean(L, 1) == 0) { /* newproxy(): without metatable. */
461
+ return 1;
462
+ } else if (lua_isboolean(L, 1)) { /* newproxy(true): with metatable. */
463
+ lua_newtable(L);
464
+ lua_pushvalue(L, -1);
465
+ lua_pushboolean(L, 1);
466
+ lua_rawset(L, lua_upvalueindex(1)); /* Remember mt in weak table. */
467
+ } else { /* newproxy(proxy): inherit metatable. */
468
+ int validproxy = 0;
469
+ if (lua_getmetatable(L, 1)) {
470
+ lua_rawget(L, lua_upvalueindex(1));
471
+ validproxy = lua_toboolean(L, -1);
472
+ lua_pop(L, 1);
473
+ }
474
+ if (!validproxy)
475
+ lj_err_arg(L, 1, LJ_ERR_NOPROXY);
476
+ lua_getmetatable(L, 1);
477
+ }
478
+ lua_setmetatable(L, 2);
479
+ return 1;
480
+ }
481
+
482
+ LJLIB_PUSH("tostring")
483
+ LJLIB_CF(print)
484
+ {
485
+ ptrdiff_t i, nargs = L->top - L->base;
486
+ cTValue *tv = lj_tab_getstr(tabref(L->env), strV(lj_lib_upvalue(L, 1)));
487
+ int shortcut;
488
+ if (tv && !tvisnil(tv)) {
489
+ copyTV(L, L->top++, tv);
490
+ } else {
491
+ setstrV(L, L->top++, strV(lj_lib_upvalue(L, 1)));
492
+ lua_gettable(L, LUA_GLOBALSINDEX);
493
+ tv = L->top-1;
494
+ }
495
+ shortcut = (tvisfunc(tv) && funcV(tv)->c.ffid == FF_tostring);
496
+ for (i = 0; i < nargs; i++) {
497
+ cTValue *o = &L->base[i];
498
+ char buf[STRFMT_MAXBUF_NUM];
499
+ const char *str;
500
+ size_t size;
501
+ MSize len;
502
+ if (shortcut && (str = lj_strfmt_wstrnum(buf, o, &len)) != NULL) {
503
+ size = len;
504
+ } else {
505
+ copyTV(L, L->top+1, o);
506
+ copyTV(L, L->top, L->top-1);
507
+ L->top += 2;
508
+ lua_call(L, 1, 1);
509
+ str = lua_tolstring(L, -1, &size);
510
+ if (!str)
511
+ lj_err_caller(L, LJ_ERR_PRTOSTR);
512
+ L->top--;
513
+ }
514
+ if (i)
515
+ putchar('\t');
516
+ fwrite(str, 1, size, stdout);
517
+ }
518
+ putchar('\n');
519
+ return 0;
520
+ }
521
+
522
+ LJLIB_PUSH(top-3)
523
+ LJLIB_SET(_VERSION)
524
+
525
+ #include "lj_libdef.h"
526
+
527
+ /* -- Coroutine library --------------------------------------------------- */
528
+
529
+ #define LJLIB_MODULE_coroutine
530
+
531
+ LJLIB_CF(coroutine_status)
532
+ {
533
+ const char *s;
534
+ lua_State *co;
535
+ if (!(L->top > L->base && tvisthread(L->base)))
536
+ lj_err_arg(L, 1, LJ_ERR_NOCORO);
537
+ co = threadV(L->base);
538
+ if (co == L) s = "running";
539
+ else if (co->status == LUA_YIELD) s = "suspended";
540
+ else if (co->status != 0) s = "dead";
541
+ else if (co->base > tvref(co->stack)+1+LJ_FR2) s = "normal";
542
+ else if (co->top == co->base) s = "dead";
543
+ else s = "suspended";
544
+ lua_pushstring(L, s);
545
+ return 1;
546
+ }
547
+
548
+ LJLIB_CF(coroutine_running)
549
+ {
550
+ #if LJ_52
551
+ int ismain = lua_pushthread(L);
552
+ setboolV(L->top++, ismain);
553
+ return 2;
554
+ #else
555
+ if (lua_pushthread(L))
556
+ setnilV(L->top++);
557
+ return 1;
558
+ #endif
559
+ }
560
+
561
+ LJLIB_CF(coroutine_create)
562
+ {
563
+ lua_State *L1;
564
+ if (!(L->base < L->top && tvisfunc(L->base)))
565
+ lj_err_argt(L, 1, LUA_TFUNCTION);
566
+ L1 = lua_newthread(L);
567
+ setfuncV(L, L1->top++, funcV(L->base));
568
+ return 1;
569
+ }
570
+
571
+ LJLIB_ASM(coroutine_yield)
572
+ {
573
+ lj_err_caller(L, LJ_ERR_CYIELD);
574
+ return FFH_UNREACHABLE;
575
+ }
576
+
577
+ static int ffh_resume(lua_State *L, lua_State *co, int wrap)
578
+ {
579
+ if (co->cframe != NULL || co->status > LUA_YIELD ||
580
+ (co->status == 0 && co->top == co->base)) {
581
+ ErrMsg em = co->cframe ? LJ_ERR_CORUN : LJ_ERR_CODEAD;
582
+ if (wrap) lj_err_caller(L, em);
583
+ setboolV(L->base-1-LJ_FR2, 0);
584
+ setstrV(L, L->base-LJ_FR2, lj_err_str(L, em));
585
+ return FFH_RES(2);
586
+ }
587
+ lj_state_growstack(co, (MSize)(L->top - L->base));
588
+ return FFH_RETRY;
589
+ }
590
+
591
+ LJLIB_ASM(coroutine_resume)
592
+ {
593
+ if (!(L->top > L->base && tvisthread(L->base)))
594
+ lj_err_arg(L, 1, LJ_ERR_NOCORO);
595
+ return ffh_resume(L, threadV(L->base), 0);
596
+ }
597
+
598
+ LJLIB_NOREG LJLIB_ASM(coroutine_wrap_aux)
599
+ {
600
+ return ffh_resume(L, threadV(lj_lib_upvalue(L, 1)), 1);
601
+ }
602
+
603
+ /* Inline declarations. */
604
+ LJ_ASMF void lj_ff_coroutine_wrap_aux(void);
605
+ #if !(LJ_TARGET_MIPS && defined(ljamalg_c))
606
+ LJ_FUNCA_NORET void LJ_FASTCALL lj_ffh_coroutine_wrap_err(lua_State *L,
607
+ lua_State *co);
608
+ #endif
609
+
610
+ /* Error handler, called from assembler VM. */
611
+ void LJ_FASTCALL lj_ffh_coroutine_wrap_err(lua_State *L, lua_State *co)
612
+ {
613
+ co->top--; copyTV(L, L->top, co->top); L->top++;
614
+ if (tvisstr(L->top-1))
615
+ lj_err_callermsg(L, strVdata(L->top-1));
616
+ else
617
+ lj_err_run(L);
618
+ }
619
+
620
+ /* Forward declaration. */
621
+ static void setpc_wrap_aux(lua_State *L, GCfunc *fn);
622
+
623
+ LJLIB_CF(coroutine_wrap)
624
+ {
625
+ GCfunc *fn;
626
+ lj_cf_coroutine_create(L);
627
+ fn = lj_lib_pushcc(L, lj_ffh_coroutine_wrap_aux, FF_coroutine_wrap_aux, 1);
628
+ setpc_wrap_aux(L, fn);
629
+ return 1;
630
+ }
631
+
632
+ #include "lj_libdef.h"
633
+
634
+ /* Fix the PC of wrap_aux. Really ugly workaround. */
635
+ static void setpc_wrap_aux(lua_State *L, GCfunc *fn)
636
+ {
637
+ setmref(fn->c.pc, &L2GG(L)->bcff[lj_lib_init_coroutine[1]+2]);
638
+ }
639
+
640
+ /* ------------------------------------------------------------------------ */
641
+
642
+ static void newproxy_weaktable(lua_State *L)
643
+ {
644
+ /* NOBARRIER: The table is new (marked white). */
645
+ GCtab *t = lj_tab_new(L, 0, 1);
646
+ settabV(L, L->top++, t);
647
+ setgcref(t->metatable, obj2gco(t));
648
+ setstrV(L, lj_tab_setstr(L, t, lj_str_newlit(L, "__mode")),
649
+ lj_str_newlit(L, "kv"));
650
+ t->nomm = (uint8_t)(~(1u<<MM_mode));
651
+ }
652
+
653
+ LUALIB_API int luaopen_base(lua_State *L)
654
+ {
655
+ /* NOBARRIER: Table and value are the same. */
656
+ GCtab *env = tabref(L->env);
657
+ settabV(L, lj_tab_setstr(L, env, lj_str_newlit(L, "_G")), env);
658
+ lua_pushliteral(L, LUA_VERSION); /* top-3. */
659
+ newproxy_weaktable(L); /* top-2. */
660
+ LJ_LIB_REG(L, "_G", base);
661
+ LJ_LIB_REG(L, LUA_COLIBNAME, coroutine);
662
+ return 2;
663
+ }
664
+