immunio 0.15.4 → 0.16.0

Sign up to get free protection for your applications and to get access to all the features.
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,17 @@
1
+ /*
2
+ ** Bundled memory allocator.
3
+ ** Donated to the public domain.
4
+ */
5
+
6
+ #ifndef _LJ_ALLOC_H
7
+ #define _LJ_ALLOC_H
8
+
9
+ #include "lj_def.h"
10
+
11
+ #ifndef LUAJIT_USE_SYSMALLOC
12
+ LJ_FUNC void *lj_alloc_create(void);
13
+ LJ_FUNC void lj_alloc_destroy(void *msp);
14
+ LJ_FUNC void *lj_alloc_f(void *msp, void *ptr, size_t osize, size_t nsize);
15
+ #endif
16
+
17
+ #endif
@@ -0,0 +1,1210 @@
1
+ /*
2
+ ** Public Lua/C API.
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-2008 Lua.org, PUC-Rio. See Copyright Notice in lua.h
7
+ */
8
+
9
+ #define lj_api_c
10
+ #define LUA_CORE
11
+
12
+ #include "lj_obj.h"
13
+ #include "lj_gc.h"
14
+ #include "lj_err.h"
15
+ #include "lj_debug.h"
16
+ #include "lj_str.h"
17
+ #include "lj_tab.h"
18
+ #include "lj_func.h"
19
+ #include "lj_udata.h"
20
+ #include "lj_meta.h"
21
+ #include "lj_state.h"
22
+ #include "lj_bc.h"
23
+ #include "lj_frame.h"
24
+ #include "lj_trace.h"
25
+ #include "lj_vm.h"
26
+ #include "lj_strscan.h"
27
+ #include "lj_strfmt.h"
28
+
29
+ /* -- Common helper functions --------------------------------------------- */
30
+
31
+ #define api_checknelems(L, n) api_check(L, (n) <= (L->top - L->base))
32
+ #define api_checkvalidindex(L, i) api_check(L, (i) != niltv(L))
33
+
34
+ static TValue *index2adr(lua_State *L, int idx)
35
+ {
36
+ if (idx > 0) {
37
+ TValue *o = L->base + (idx - 1);
38
+ return o < L->top ? o : niltv(L);
39
+ } else if (idx > LUA_REGISTRYINDEX) {
40
+ api_check(L, idx != 0 && -idx <= L->top - L->base);
41
+ return L->top + idx;
42
+ } else if (idx == LUA_GLOBALSINDEX) {
43
+ TValue *o = &G(L)->tmptv;
44
+ settabV(L, o, tabref(L->env));
45
+ return o;
46
+ } else if (idx == LUA_REGISTRYINDEX) {
47
+ return registry(L);
48
+ } else {
49
+ GCfunc *fn = curr_func(L);
50
+ api_check(L, fn->c.gct == ~LJ_TFUNC && !isluafunc(fn));
51
+ if (idx == LUA_ENVIRONINDEX) {
52
+ TValue *o = &G(L)->tmptv;
53
+ settabV(L, o, tabref(fn->c.env));
54
+ return o;
55
+ } else {
56
+ idx = LUA_GLOBALSINDEX - idx;
57
+ return idx <= fn->c.nupvalues ? &fn->c.upvalue[idx-1] : niltv(L);
58
+ }
59
+ }
60
+ }
61
+
62
+ static TValue *stkindex2adr(lua_State *L, int idx)
63
+ {
64
+ if (idx > 0) {
65
+ TValue *o = L->base + (idx - 1);
66
+ return o < L->top ? o : niltv(L);
67
+ } else {
68
+ api_check(L, idx != 0 && -idx <= L->top - L->base);
69
+ return L->top + idx;
70
+ }
71
+ }
72
+
73
+ static GCtab *getcurrenv(lua_State *L)
74
+ {
75
+ GCfunc *fn = curr_func(L);
76
+ return fn->c.gct == ~LJ_TFUNC ? tabref(fn->c.env) : tabref(L->env);
77
+ }
78
+
79
+ /* -- Miscellaneous API functions ----------------------------------------- */
80
+
81
+ LUA_API int lua_status(lua_State *L)
82
+ {
83
+ return L->status;
84
+ }
85
+
86
+ LUA_API int lua_checkstack(lua_State *L, int size)
87
+ {
88
+ if (size > LUAI_MAXCSTACK || (L->top - L->base + size) > LUAI_MAXCSTACK) {
89
+ return 0; /* Stack overflow. */
90
+ } else if (size > 0) {
91
+ lj_state_checkstack(L, (MSize)size);
92
+ }
93
+ return 1;
94
+ }
95
+
96
+ LUALIB_API void luaL_checkstack(lua_State *L, int size, const char *msg)
97
+ {
98
+ if (!lua_checkstack(L, size))
99
+ lj_err_callerv(L, LJ_ERR_STKOVM, msg);
100
+ }
101
+
102
+ LUA_API void lua_xmove(lua_State *from, lua_State *to, int n)
103
+ {
104
+ TValue *f, *t;
105
+ if (from == to) return;
106
+ api_checknelems(from, n);
107
+ api_check(from, G(from) == G(to));
108
+ lj_state_checkstack(to, (MSize)n);
109
+ f = from->top;
110
+ t = to->top = to->top + n;
111
+ while (--n >= 0) copyTV(to, --t, --f);
112
+ from->top = f;
113
+ }
114
+
115
+ /* -- Stack manipulation -------------------------------------------------- */
116
+
117
+ LUA_API int lua_gettop(lua_State *L)
118
+ {
119
+ return (int)(L->top - L->base);
120
+ }
121
+
122
+ LUA_API void lua_settop(lua_State *L, int idx)
123
+ {
124
+ if (idx >= 0) {
125
+ api_check(L, idx <= tvref(L->maxstack) - L->base);
126
+ if (L->base + idx > L->top) {
127
+ if (L->base + idx >= tvref(L->maxstack))
128
+ lj_state_growstack(L, (MSize)idx - (MSize)(L->top - L->base));
129
+ do { setnilV(L->top++); } while (L->top < L->base + idx);
130
+ } else {
131
+ L->top = L->base + idx;
132
+ }
133
+ } else {
134
+ api_check(L, -(idx+1) <= (L->top - L->base));
135
+ L->top += idx+1; /* Shrinks top (idx < 0). */
136
+ }
137
+ }
138
+
139
+ LUA_API void lua_remove(lua_State *L, int idx)
140
+ {
141
+ TValue *p = stkindex2adr(L, idx);
142
+ api_checkvalidindex(L, p);
143
+ while (++p < L->top) copyTV(L, p-1, p);
144
+ L->top--;
145
+ }
146
+
147
+ LUA_API void lua_insert(lua_State *L, int idx)
148
+ {
149
+ TValue *q, *p = stkindex2adr(L, idx);
150
+ api_checkvalidindex(L, p);
151
+ for (q = L->top; q > p; q--) copyTV(L, q, q-1);
152
+ copyTV(L, p, L->top);
153
+ }
154
+
155
+ LUA_API void lua_replace(lua_State *L, int idx)
156
+ {
157
+ api_checknelems(L, 1);
158
+ if (idx == LUA_GLOBALSINDEX) {
159
+ api_check(L, tvistab(L->top-1));
160
+ /* NOBARRIER: A thread (i.e. L) is never black. */
161
+ setgcref(L->env, obj2gco(tabV(L->top-1)));
162
+ } else if (idx == LUA_ENVIRONINDEX) {
163
+ GCfunc *fn = curr_func(L);
164
+ if (fn->c.gct != ~LJ_TFUNC)
165
+ lj_err_msg(L, LJ_ERR_NOENV);
166
+ api_check(L, tvistab(L->top-1));
167
+ setgcref(fn->c.env, obj2gco(tabV(L->top-1)));
168
+ lj_gc_barrier(L, fn, L->top-1);
169
+ } else {
170
+ TValue *o = index2adr(L, idx);
171
+ api_checkvalidindex(L, o);
172
+ copyTV(L, o, L->top-1);
173
+ if (idx < LUA_GLOBALSINDEX) /* Need a barrier for upvalues. */
174
+ lj_gc_barrier(L, curr_func(L), L->top-1);
175
+ }
176
+ L->top--;
177
+ }
178
+
179
+ LUA_API void lua_pushvalue(lua_State *L, int idx)
180
+ {
181
+ copyTV(L, L->top, index2adr(L, idx));
182
+ incr_top(L);
183
+ }
184
+
185
+ /* -- Stack getters ------------------------------------------------------- */
186
+
187
+ LUA_API int lua_type(lua_State *L, int idx)
188
+ {
189
+ cTValue *o = index2adr(L, idx);
190
+ if (tvisnumber(o)) {
191
+ return LUA_TNUMBER;
192
+ #if LJ_64 && !LJ_GC64
193
+ } else if (tvislightud(o)) {
194
+ return LUA_TLIGHTUSERDATA;
195
+ #endif
196
+ } else if (o == niltv(L)) {
197
+ return LUA_TNONE;
198
+ } else { /* Magic internal/external tag conversion. ORDER LJ_T */
199
+ uint32_t t = ~itype(o);
200
+ #if LJ_64
201
+ int tt = (int)((U64x(75a06,98042110) >> 4*t) & 15u);
202
+ #else
203
+ int tt = (int)(((t < 8 ? 0x98042110u : 0x75a06u) >> 4*(t&7)) & 15u);
204
+ #endif
205
+ lua_assert(tt != LUA_TNIL || tvisnil(o));
206
+ return tt;
207
+ }
208
+ }
209
+
210
+ LUALIB_API void luaL_checktype(lua_State *L, int idx, int tt)
211
+ {
212
+ if (lua_type(L, idx) != tt)
213
+ lj_err_argt(L, idx, tt);
214
+ }
215
+
216
+ LUALIB_API void luaL_checkany(lua_State *L, int idx)
217
+ {
218
+ if (index2adr(L, idx) == niltv(L))
219
+ lj_err_arg(L, idx, LJ_ERR_NOVAL);
220
+ }
221
+
222
+ LUA_API const char *lua_typename(lua_State *L, int t)
223
+ {
224
+ UNUSED(L);
225
+ return lj_obj_typename[t+1];
226
+ }
227
+
228
+ LUA_API int lua_iscfunction(lua_State *L, int idx)
229
+ {
230
+ cTValue *o = index2adr(L, idx);
231
+ return tvisfunc(o) && !isluafunc(funcV(o));
232
+ }
233
+
234
+ LUA_API int lua_isnumber(lua_State *L, int idx)
235
+ {
236
+ cTValue *o = index2adr(L, idx);
237
+ TValue tmp;
238
+ return (tvisnumber(o) || (tvisstr(o) && lj_strscan_number(strV(o), &tmp)));
239
+ }
240
+
241
+ LUA_API int lua_isstring(lua_State *L, int idx)
242
+ {
243
+ cTValue *o = index2adr(L, idx);
244
+ return (tvisstr(o) || tvisnumber(o));
245
+ }
246
+
247
+ LUA_API int lua_isuserdata(lua_State *L, int idx)
248
+ {
249
+ cTValue *o = index2adr(L, idx);
250
+ return (tvisudata(o) || tvislightud(o));
251
+ }
252
+
253
+ LUA_API int lua_rawequal(lua_State *L, int idx1, int idx2)
254
+ {
255
+ cTValue *o1 = index2adr(L, idx1);
256
+ cTValue *o2 = index2adr(L, idx2);
257
+ return (o1 == niltv(L) || o2 == niltv(L)) ? 0 : lj_obj_equal(o1, o2);
258
+ }
259
+
260
+ LUA_API int lua_equal(lua_State *L, int idx1, int idx2)
261
+ {
262
+ cTValue *o1 = index2adr(L, idx1);
263
+ cTValue *o2 = index2adr(L, idx2);
264
+ if (tvisint(o1) && tvisint(o2)) {
265
+ return intV(o1) == intV(o2);
266
+ } else if (tvisnumber(o1) && tvisnumber(o2)) {
267
+ return numberVnum(o1) == numberVnum(o2);
268
+ } else if (itype(o1) != itype(o2)) {
269
+ return 0;
270
+ } else if (tvispri(o1)) {
271
+ return o1 != niltv(L) && o2 != niltv(L);
272
+ #if LJ_64 && !LJ_GC64
273
+ } else if (tvislightud(o1)) {
274
+ return o1->u64 == o2->u64;
275
+ #endif
276
+ } else if (gcrefeq(o1->gcr, o2->gcr)) {
277
+ return 1;
278
+ } else if (!tvistabud(o1)) {
279
+ return 0;
280
+ } else {
281
+ TValue *base = lj_meta_equal(L, gcV(o1), gcV(o2), 0);
282
+ if ((uintptr_t)base <= 1) {
283
+ return (int)(uintptr_t)base;
284
+ } else {
285
+ L->top = base+2;
286
+ lj_vm_call(L, base, 1+1);
287
+ L->top -= 2+LJ_FR2;
288
+ return tvistruecond(L->top+1+LJ_FR2);
289
+ }
290
+ }
291
+ }
292
+
293
+ LUA_API int lua_lessthan(lua_State *L, int idx1, int idx2)
294
+ {
295
+ cTValue *o1 = index2adr(L, idx1);
296
+ cTValue *o2 = index2adr(L, idx2);
297
+ if (o1 == niltv(L) || o2 == niltv(L)) {
298
+ return 0;
299
+ } else if (tvisint(o1) && tvisint(o2)) {
300
+ return intV(o1) < intV(o2);
301
+ } else if (tvisnumber(o1) && tvisnumber(o2)) {
302
+ return numberVnum(o1) < numberVnum(o2);
303
+ } else {
304
+ TValue *base = lj_meta_comp(L, o1, o2, 0);
305
+ if ((uintptr_t)base <= 1) {
306
+ return (int)(uintptr_t)base;
307
+ } else {
308
+ L->top = base+2;
309
+ lj_vm_call(L, base, 1+1);
310
+ L->top -= 2+LJ_FR2;
311
+ return tvistruecond(L->top+1+LJ_FR2);
312
+ }
313
+ }
314
+ }
315
+
316
+ LUA_API lua_Number lua_tonumber(lua_State *L, int idx)
317
+ {
318
+ cTValue *o = index2adr(L, idx);
319
+ TValue tmp;
320
+ if (LJ_LIKELY(tvisnumber(o)))
321
+ return numberVnum(o);
322
+ else if (tvisstr(o) && lj_strscan_num(strV(o), &tmp))
323
+ return numV(&tmp);
324
+ else
325
+ return 0;
326
+ }
327
+
328
+ LUALIB_API lua_Number luaL_checknumber(lua_State *L, int idx)
329
+ {
330
+ cTValue *o = index2adr(L, idx);
331
+ TValue tmp;
332
+ if (LJ_LIKELY(tvisnumber(o)))
333
+ return numberVnum(o);
334
+ else if (!(tvisstr(o) && lj_strscan_num(strV(o), &tmp)))
335
+ lj_err_argt(L, idx, LUA_TNUMBER);
336
+ return numV(&tmp);
337
+ }
338
+
339
+ LUALIB_API lua_Number luaL_optnumber(lua_State *L, int idx, lua_Number def)
340
+ {
341
+ cTValue *o = index2adr(L, idx);
342
+ TValue tmp;
343
+ if (LJ_LIKELY(tvisnumber(o)))
344
+ return numberVnum(o);
345
+ else if (tvisnil(o))
346
+ return def;
347
+ else if (!(tvisstr(o) && lj_strscan_num(strV(o), &tmp)))
348
+ lj_err_argt(L, idx, LUA_TNUMBER);
349
+ return numV(&tmp);
350
+ }
351
+
352
+ LUA_API lua_Integer lua_tointeger(lua_State *L, int idx)
353
+ {
354
+ cTValue *o = index2adr(L, idx);
355
+ TValue tmp;
356
+ lua_Number n;
357
+ if (LJ_LIKELY(tvisint(o))) {
358
+ return intV(o);
359
+ } else if (LJ_LIKELY(tvisnum(o))) {
360
+ n = numV(o);
361
+ } else {
362
+ if (!(tvisstr(o) && lj_strscan_number(strV(o), &tmp)))
363
+ return 0;
364
+ if (tvisint(&tmp))
365
+ return (lua_Integer)intV(&tmp);
366
+ n = numV(&tmp);
367
+ }
368
+ #if LJ_64
369
+ return (lua_Integer)n;
370
+ #else
371
+ return lj_num2int(n);
372
+ #endif
373
+ }
374
+
375
+ LUALIB_API lua_Integer luaL_checkinteger(lua_State *L, int idx)
376
+ {
377
+ cTValue *o = index2adr(L, idx);
378
+ TValue tmp;
379
+ lua_Number n;
380
+ if (LJ_LIKELY(tvisint(o))) {
381
+ return intV(o);
382
+ } else if (LJ_LIKELY(tvisnum(o))) {
383
+ n = numV(o);
384
+ } else {
385
+ if (!(tvisstr(o) && lj_strscan_number(strV(o), &tmp)))
386
+ lj_err_argt(L, idx, LUA_TNUMBER);
387
+ if (tvisint(&tmp))
388
+ return (lua_Integer)intV(&tmp);
389
+ n = numV(&tmp);
390
+ }
391
+ #if LJ_64
392
+ return (lua_Integer)n;
393
+ #else
394
+ return lj_num2int(n);
395
+ #endif
396
+ }
397
+
398
+ LUALIB_API lua_Integer luaL_optinteger(lua_State *L, int idx, lua_Integer def)
399
+ {
400
+ cTValue *o = index2adr(L, idx);
401
+ TValue tmp;
402
+ lua_Number n;
403
+ if (LJ_LIKELY(tvisint(o))) {
404
+ return intV(o);
405
+ } else if (LJ_LIKELY(tvisnum(o))) {
406
+ n = numV(o);
407
+ } else if (tvisnil(o)) {
408
+ return def;
409
+ } else {
410
+ if (!(tvisstr(o) && lj_strscan_number(strV(o), &tmp)))
411
+ lj_err_argt(L, idx, LUA_TNUMBER);
412
+ if (tvisint(&tmp))
413
+ return (lua_Integer)intV(&tmp);
414
+ n = numV(&tmp);
415
+ }
416
+ #if LJ_64
417
+ return (lua_Integer)n;
418
+ #else
419
+ return lj_num2int(n);
420
+ #endif
421
+ }
422
+
423
+ LUA_API int lua_toboolean(lua_State *L, int idx)
424
+ {
425
+ cTValue *o = index2adr(L, idx);
426
+ return tvistruecond(o);
427
+ }
428
+
429
+ LUA_API const char *lua_tolstring(lua_State *L, int idx, size_t *len)
430
+ {
431
+ TValue *o = index2adr(L, idx);
432
+ GCstr *s;
433
+ if (LJ_LIKELY(tvisstr(o))) {
434
+ s = strV(o);
435
+ } else if (tvisnumber(o)) {
436
+ lj_gc_check(L);
437
+ o = index2adr(L, idx); /* GC may move the stack. */
438
+ s = lj_strfmt_number(L, o);
439
+ setstrV(L, o, s);
440
+ } else {
441
+ if (len != NULL) *len = 0;
442
+ return NULL;
443
+ }
444
+ if (len != NULL) *len = s->len;
445
+ return strdata(s);
446
+ }
447
+
448
+ LUALIB_API const char *luaL_checklstring(lua_State *L, int idx, size_t *len)
449
+ {
450
+ TValue *o = index2adr(L, idx);
451
+ GCstr *s;
452
+ if (LJ_LIKELY(tvisstr(o))) {
453
+ s = strV(o);
454
+ } else if (tvisnumber(o)) {
455
+ lj_gc_check(L);
456
+ o = index2adr(L, idx); /* GC may move the stack. */
457
+ s = lj_strfmt_number(L, o);
458
+ setstrV(L, o, s);
459
+ } else {
460
+ lj_err_argt(L, idx, LUA_TSTRING);
461
+ }
462
+ if (len != NULL) *len = s->len;
463
+ return strdata(s);
464
+ }
465
+
466
+ LUALIB_API const char *luaL_optlstring(lua_State *L, int idx,
467
+ const char *def, size_t *len)
468
+ {
469
+ TValue *o = index2adr(L, idx);
470
+ GCstr *s;
471
+ if (LJ_LIKELY(tvisstr(o))) {
472
+ s = strV(o);
473
+ } else if (tvisnil(o)) {
474
+ if (len != NULL) *len = def ? strlen(def) : 0;
475
+ return def;
476
+ } else if (tvisnumber(o)) {
477
+ lj_gc_check(L);
478
+ o = index2adr(L, idx); /* GC may move the stack. */
479
+ s = lj_strfmt_number(L, o);
480
+ setstrV(L, o, s);
481
+ } else {
482
+ lj_err_argt(L, idx, LUA_TSTRING);
483
+ }
484
+ if (len != NULL) *len = s->len;
485
+ return strdata(s);
486
+ }
487
+
488
+ LUALIB_API int luaL_checkoption(lua_State *L, int idx, const char *def,
489
+ const char *const lst[])
490
+ {
491
+ ptrdiff_t i;
492
+ const char *s = lua_tolstring(L, idx, NULL);
493
+ if (s == NULL && (s = def) == NULL)
494
+ lj_err_argt(L, idx, LUA_TSTRING);
495
+ for (i = 0; lst[i]; i++)
496
+ if (strcmp(lst[i], s) == 0)
497
+ return (int)i;
498
+ lj_err_argv(L, idx, LJ_ERR_INVOPTM, s);
499
+ }
500
+
501
+ LUA_API size_t lua_objlen(lua_State *L, int idx)
502
+ {
503
+ TValue *o = index2adr(L, idx);
504
+ if (tvisstr(o)) {
505
+ return strV(o)->len;
506
+ } else if (tvistab(o)) {
507
+ return (size_t)lj_tab_len(tabV(o));
508
+ } else if (tvisudata(o)) {
509
+ return udataV(o)->len;
510
+ } else if (tvisnumber(o)) {
511
+ GCstr *s = lj_strfmt_number(L, o);
512
+ setstrV(L, o, s);
513
+ return s->len;
514
+ } else {
515
+ return 0;
516
+ }
517
+ }
518
+
519
+ LUA_API lua_CFunction lua_tocfunction(lua_State *L, int idx)
520
+ {
521
+ cTValue *o = index2adr(L, idx);
522
+ if (tvisfunc(o)) {
523
+ BCOp op = bc_op(*mref(funcV(o)->c.pc, BCIns));
524
+ if (op == BC_FUNCC || op == BC_FUNCCW)
525
+ return funcV(o)->c.f;
526
+ }
527
+ return NULL;
528
+ }
529
+
530
+ LUA_API void *lua_touserdata(lua_State *L, int idx)
531
+ {
532
+ cTValue *o = index2adr(L, idx);
533
+ if (tvisudata(o))
534
+ return uddata(udataV(o));
535
+ else if (tvislightud(o))
536
+ return lightudV(o);
537
+ else
538
+ return NULL;
539
+ }
540
+
541
+ LUA_API lua_State *lua_tothread(lua_State *L, int idx)
542
+ {
543
+ cTValue *o = index2adr(L, idx);
544
+ return (!tvisthread(o)) ? NULL : threadV(o);
545
+ }
546
+
547
+ LUA_API const void *lua_topointer(lua_State *L, int idx)
548
+ {
549
+ return lj_obj_ptr(index2adr(L, idx));
550
+ }
551
+
552
+ /* -- Stack setters (object creation) ------------------------------------- */
553
+
554
+ LUA_API void lua_pushnil(lua_State *L)
555
+ {
556
+ setnilV(L->top);
557
+ incr_top(L);
558
+ }
559
+
560
+ LUA_API void lua_pushnumber(lua_State *L, lua_Number n)
561
+ {
562
+ setnumV(L->top, n);
563
+ if (LJ_UNLIKELY(tvisnan(L->top)))
564
+ setnanV(L->top); /* Canonicalize injected NaNs. */
565
+ incr_top(L);
566
+ }
567
+
568
+ LUA_API void lua_pushinteger(lua_State *L, lua_Integer n)
569
+ {
570
+ setintptrV(L->top, n);
571
+ incr_top(L);
572
+ }
573
+
574
+ LUA_API void lua_pushlstring(lua_State *L, const char *str, size_t len)
575
+ {
576
+ GCstr *s;
577
+ lj_gc_check(L);
578
+ s = lj_str_new(L, str, len);
579
+ setstrV(L, L->top, s);
580
+ incr_top(L);
581
+ }
582
+
583
+ LUA_API void lua_pushstring(lua_State *L, const char *str)
584
+ {
585
+ if (str == NULL) {
586
+ setnilV(L->top);
587
+ } else {
588
+ GCstr *s;
589
+ lj_gc_check(L);
590
+ s = lj_str_newz(L, str);
591
+ setstrV(L, L->top, s);
592
+ }
593
+ incr_top(L);
594
+ }
595
+
596
+ LUA_API const char *lua_pushvfstring(lua_State *L, const char *fmt,
597
+ va_list argp)
598
+ {
599
+ lj_gc_check(L);
600
+ return lj_strfmt_pushvf(L, fmt, argp);
601
+ }
602
+
603
+ LUA_API const char *lua_pushfstring(lua_State *L, const char *fmt, ...)
604
+ {
605
+ const char *ret;
606
+ va_list argp;
607
+ lj_gc_check(L);
608
+ va_start(argp, fmt);
609
+ ret = lj_strfmt_pushvf(L, fmt, argp);
610
+ va_end(argp);
611
+ return ret;
612
+ }
613
+
614
+ LUA_API void lua_pushcclosure(lua_State *L, lua_CFunction f, int n)
615
+ {
616
+ GCfunc *fn;
617
+ lj_gc_check(L);
618
+ api_checknelems(L, n);
619
+ fn = lj_func_newC(L, (MSize)n, getcurrenv(L));
620
+ fn->c.f = f;
621
+ L->top -= n;
622
+ while (n--)
623
+ copyTV(L, &fn->c.upvalue[n], L->top+n);
624
+ setfuncV(L, L->top, fn);
625
+ lua_assert(iswhite(obj2gco(fn)));
626
+ incr_top(L);
627
+ }
628
+
629
+ LUA_API void lua_pushboolean(lua_State *L, int b)
630
+ {
631
+ setboolV(L->top, (b != 0));
632
+ incr_top(L);
633
+ }
634
+
635
+ LUA_API void lua_pushlightuserdata(lua_State *L, void *p)
636
+ {
637
+ setlightudV(L->top, checklightudptr(L, p));
638
+ incr_top(L);
639
+ }
640
+
641
+ LUA_API void lua_createtable(lua_State *L, int narray, int nrec)
642
+ {
643
+ lj_gc_check(L);
644
+ settabV(L, L->top, lj_tab_new_ah(L, narray, nrec));
645
+ incr_top(L);
646
+ }
647
+
648
+ LUALIB_API int luaL_newmetatable(lua_State *L, const char *tname)
649
+ {
650
+ GCtab *regt = tabV(registry(L));
651
+ TValue *tv = lj_tab_setstr(L, regt, lj_str_newz(L, tname));
652
+ if (tvisnil(tv)) {
653
+ GCtab *mt = lj_tab_new(L, 0, 1);
654
+ settabV(L, tv, mt);
655
+ settabV(L, L->top++, mt);
656
+ lj_gc_anybarriert(L, regt);
657
+ return 1;
658
+ } else {
659
+ copyTV(L, L->top++, tv);
660
+ return 0;
661
+ }
662
+ }
663
+
664
+ LUA_API int lua_pushthread(lua_State *L)
665
+ {
666
+ setthreadV(L, L->top, L);
667
+ incr_top(L);
668
+ return (mainthread(G(L)) == L);
669
+ }
670
+
671
+ LUA_API lua_State *lua_newthread(lua_State *L)
672
+ {
673
+ lua_State *L1;
674
+ lj_gc_check(L);
675
+ L1 = lj_state_new(L);
676
+ setthreadV(L, L->top, L1);
677
+ incr_top(L);
678
+ return L1;
679
+ }
680
+
681
+ LUA_API void *lua_newuserdata(lua_State *L, size_t size)
682
+ {
683
+ GCudata *ud;
684
+ lj_gc_check(L);
685
+ if (size > LJ_MAX_UDATA)
686
+ lj_err_msg(L, LJ_ERR_UDATAOV);
687
+ ud = lj_udata_new(L, (MSize)size, getcurrenv(L));
688
+ setudataV(L, L->top, ud);
689
+ incr_top(L);
690
+ return uddata(ud);
691
+ }
692
+
693
+ LUA_API void lua_concat(lua_State *L, int n)
694
+ {
695
+ api_checknelems(L, n);
696
+ if (n >= 2) {
697
+ n--;
698
+ do {
699
+ TValue *top = lj_meta_cat(L, L->top-1, -n);
700
+ if (top == NULL) {
701
+ L->top -= n;
702
+ break;
703
+ }
704
+ n -= (int)(L->top - top);
705
+ L->top = top+2;
706
+ lj_vm_call(L, top, 1+1);
707
+ L->top -= 1+LJ_FR2;
708
+ copyTV(L, L->top-1, L->top+LJ_FR2);
709
+ } while (--n > 0);
710
+ } else if (n == 0) { /* Push empty string. */
711
+ setstrV(L, L->top, &G(L)->strempty);
712
+ incr_top(L);
713
+ }
714
+ /* else n == 1: nothing to do. */
715
+ }
716
+
717
+ /* -- Object getters ------------------------------------------------------ */
718
+
719
+ LUA_API void lua_gettable(lua_State *L, int idx)
720
+ {
721
+ cTValue *v, *t = index2adr(L, idx);
722
+ api_checkvalidindex(L, t);
723
+ v = lj_meta_tget(L, t, L->top-1);
724
+ if (v == NULL) {
725
+ L->top += 2;
726
+ lj_vm_call(L, L->top-2, 1+1);
727
+ L->top -= 2+LJ_FR2;
728
+ v = L->top+1+LJ_FR2;
729
+ }
730
+ copyTV(L, L->top-1, v);
731
+ }
732
+
733
+ LUA_API void lua_getfield(lua_State *L, int idx, const char *k)
734
+ {
735
+ cTValue *v, *t = index2adr(L, idx);
736
+ TValue key;
737
+ api_checkvalidindex(L, t);
738
+ setstrV(L, &key, lj_str_newz(L, k));
739
+ v = lj_meta_tget(L, t, &key);
740
+ if (v == NULL) {
741
+ L->top += 2;
742
+ lj_vm_call(L, L->top-2, 1+1);
743
+ L->top -= 2+LJ_FR2;
744
+ v = L->top+1+LJ_FR2;
745
+ }
746
+ copyTV(L, L->top, v);
747
+ incr_top(L);
748
+ }
749
+
750
+ LUA_API void lua_rawget(lua_State *L, int idx)
751
+ {
752
+ cTValue *t = index2adr(L, idx);
753
+ api_check(L, tvistab(t));
754
+ copyTV(L, L->top-1, lj_tab_get(L, tabV(t), L->top-1));
755
+ }
756
+
757
+ LUA_API void lua_rawgeti(lua_State *L, int idx, int n)
758
+ {
759
+ cTValue *v, *t = index2adr(L, idx);
760
+ api_check(L, tvistab(t));
761
+ v = lj_tab_getint(tabV(t), n);
762
+ if (v) {
763
+ copyTV(L, L->top, v);
764
+ } else {
765
+ setnilV(L->top);
766
+ }
767
+ incr_top(L);
768
+ }
769
+
770
+ LUA_API int lua_getmetatable(lua_State *L, int idx)
771
+ {
772
+ cTValue *o = index2adr(L, idx);
773
+ GCtab *mt = NULL;
774
+ if (tvistab(o))
775
+ mt = tabref(tabV(o)->metatable);
776
+ else if (tvisudata(o))
777
+ mt = tabref(udataV(o)->metatable);
778
+ else
779
+ mt = tabref(basemt_obj(G(L), o));
780
+ if (mt == NULL)
781
+ return 0;
782
+ settabV(L, L->top, mt);
783
+ incr_top(L);
784
+ return 1;
785
+ }
786
+
787
+ LUALIB_API int luaL_getmetafield(lua_State *L, int idx, const char *field)
788
+ {
789
+ if (lua_getmetatable(L, idx)) {
790
+ cTValue *tv = lj_tab_getstr(tabV(L->top-1), lj_str_newz(L, field));
791
+ if (tv && !tvisnil(tv)) {
792
+ copyTV(L, L->top-1, tv);
793
+ return 1;
794
+ }
795
+ L->top--;
796
+ }
797
+ return 0;
798
+ }
799
+
800
+ LUA_API void lua_getfenv(lua_State *L, int idx)
801
+ {
802
+ cTValue *o = index2adr(L, idx);
803
+ api_checkvalidindex(L, o);
804
+ if (tvisfunc(o)) {
805
+ settabV(L, L->top, tabref(funcV(o)->c.env));
806
+ } else if (tvisudata(o)) {
807
+ settabV(L, L->top, tabref(udataV(o)->env));
808
+ } else if (tvisthread(o)) {
809
+ settabV(L, L->top, tabref(threadV(o)->env));
810
+ } else {
811
+ setnilV(L->top);
812
+ }
813
+ incr_top(L);
814
+ }
815
+
816
+ LUA_API int lua_next(lua_State *L, int idx)
817
+ {
818
+ cTValue *t = index2adr(L, idx);
819
+ int more;
820
+ api_check(L, tvistab(t));
821
+ more = lj_tab_next(L, tabV(t), L->top-1);
822
+ if (more) {
823
+ incr_top(L); /* Return new key and value slot. */
824
+ } else { /* End of traversal. */
825
+ L->top--; /* Remove key slot. */
826
+ }
827
+ return more;
828
+ }
829
+
830
+ LUA_API const char *lua_getupvalue(lua_State *L, int idx, int n)
831
+ {
832
+ TValue *val;
833
+ const char *name = lj_debug_uvnamev(index2adr(L, idx), (uint32_t)(n-1), &val);
834
+ if (name) {
835
+ copyTV(L, L->top, val);
836
+ incr_top(L);
837
+ }
838
+ return name;
839
+ }
840
+
841
+ LUA_API void *lua_upvalueid(lua_State *L, int idx, int n)
842
+ {
843
+ GCfunc *fn = funcV(index2adr(L, idx));
844
+ n--;
845
+ api_check(L, (uint32_t)n < fn->l.nupvalues);
846
+ return isluafunc(fn) ? (void *)gcref(fn->l.uvptr[n]) :
847
+ (void *)&fn->c.upvalue[n];
848
+ }
849
+
850
+ LUA_API void lua_upvaluejoin(lua_State *L, int idx1, int n1, int idx2, int n2)
851
+ {
852
+ GCfunc *fn1 = funcV(index2adr(L, idx1));
853
+ GCfunc *fn2 = funcV(index2adr(L, idx2));
854
+ n1--; n2--;
855
+ api_check(L, isluafunc(fn1) && (uint32_t)n1 < fn1->l.nupvalues);
856
+ api_check(L, isluafunc(fn2) && (uint32_t)n2 < fn2->l.nupvalues);
857
+ setgcrefr(fn1->l.uvptr[n1], fn2->l.uvptr[n2]);
858
+ lj_gc_objbarrier(L, fn1, gcref(fn1->l.uvptr[n1]));
859
+ }
860
+
861
+ LUALIB_API void *luaL_checkudata(lua_State *L, int idx, const char *tname)
862
+ {
863
+ cTValue *o = index2adr(L, idx);
864
+ if (tvisudata(o)) {
865
+ GCudata *ud = udataV(o);
866
+ cTValue *tv = lj_tab_getstr(tabV(registry(L)), lj_str_newz(L, tname));
867
+ if (tv && tvistab(tv) && tabV(tv) == tabref(ud->metatable))
868
+ return uddata(ud);
869
+ }
870
+ lj_err_argtype(L, idx, tname);
871
+ return NULL; /* unreachable */
872
+ }
873
+
874
+ /* -- Object setters ------------------------------------------------------ */
875
+
876
+ LUA_API void lua_settable(lua_State *L, int idx)
877
+ {
878
+ TValue *o;
879
+ cTValue *t = index2adr(L, idx);
880
+ api_checknelems(L, 2);
881
+ api_checkvalidindex(L, t);
882
+ o = lj_meta_tset(L, t, L->top-2);
883
+ if (o) {
884
+ /* NOBARRIER: lj_meta_tset ensures the table is not black. */
885
+ L->top -= 2;
886
+ copyTV(L, o, L->top+1);
887
+ } else {
888
+ TValue *base = L->top;
889
+ copyTV(L, base+2, base-3-2*LJ_FR2);
890
+ L->top = base+3;
891
+ lj_vm_call(L, base, 0+1);
892
+ L->top -= 3+LJ_FR2;
893
+ }
894
+ }
895
+
896
+ LUA_API void lua_setfield(lua_State *L, int idx, const char *k)
897
+ {
898
+ TValue *o;
899
+ TValue key;
900
+ cTValue *t = index2adr(L, idx);
901
+ api_checknelems(L, 1);
902
+ api_checkvalidindex(L, t);
903
+ setstrV(L, &key, lj_str_newz(L, k));
904
+ o = lj_meta_tset(L, t, &key);
905
+ if (o) {
906
+ /* NOBARRIER: lj_meta_tset ensures the table is not black. */
907
+ copyTV(L, o, --L->top);
908
+ } else {
909
+ TValue *base = L->top;
910
+ copyTV(L, base+2, base-3-2*LJ_FR2);
911
+ L->top = base+3;
912
+ lj_vm_call(L, base, 0+1);
913
+ L->top -= 2+LJ_FR2;
914
+ }
915
+ }
916
+
917
+ LUA_API void lua_rawset(lua_State *L, int idx)
918
+ {
919
+ GCtab *t = tabV(index2adr(L, idx));
920
+ TValue *dst, *key;
921
+ api_checknelems(L, 2);
922
+ key = L->top-2;
923
+ dst = lj_tab_set(L, t, key);
924
+ copyTV(L, dst, key+1);
925
+ lj_gc_anybarriert(L, t);
926
+ L->top = key;
927
+ }
928
+
929
+ LUA_API void lua_rawseti(lua_State *L, int idx, int n)
930
+ {
931
+ GCtab *t = tabV(index2adr(L, idx));
932
+ TValue *dst, *src;
933
+ api_checknelems(L, 1);
934
+ dst = lj_tab_setint(L, t, n);
935
+ src = L->top-1;
936
+ copyTV(L, dst, src);
937
+ lj_gc_barriert(L, t, dst);
938
+ L->top = src;
939
+ }
940
+
941
+ LUA_API int lua_setmetatable(lua_State *L, int idx)
942
+ {
943
+ global_State *g;
944
+ GCtab *mt;
945
+ cTValue *o = index2adr(L, idx);
946
+ api_checknelems(L, 1);
947
+ api_checkvalidindex(L, o);
948
+ if (tvisnil(L->top-1)) {
949
+ mt = NULL;
950
+ } else {
951
+ api_check(L, tvistab(L->top-1));
952
+ mt = tabV(L->top-1);
953
+ }
954
+ g = G(L);
955
+ if (tvistab(o)) {
956
+ setgcref(tabV(o)->metatable, obj2gco(mt));
957
+ if (mt)
958
+ lj_gc_objbarriert(L, tabV(o), mt);
959
+ } else if (tvisudata(o)) {
960
+ setgcref(udataV(o)->metatable, obj2gco(mt));
961
+ if (mt)
962
+ lj_gc_objbarrier(L, udataV(o), mt);
963
+ } else {
964
+ /* Flush cache, since traces specialize to basemt. But not during __gc. */
965
+ if (lj_trace_flushall(L))
966
+ lj_err_caller(L, LJ_ERR_NOGCMM);
967
+ if (tvisbool(o)) {
968
+ /* NOBARRIER: basemt is a GC root. */
969
+ setgcref(basemt_it(g, LJ_TTRUE), obj2gco(mt));
970
+ setgcref(basemt_it(g, LJ_TFALSE), obj2gco(mt));
971
+ } else {
972
+ /* NOBARRIER: basemt is a GC root. */
973
+ setgcref(basemt_obj(g, o), obj2gco(mt));
974
+ }
975
+ }
976
+ L->top--;
977
+ return 1;
978
+ }
979
+
980
+ LUA_API int lua_setfenv(lua_State *L, int idx)
981
+ {
982
+ cTValue *o = index2adr(L, idx);
983
+ GCtab *t;
984
+ api_checknelems(L, 1);
985
+ api_checkvalidindex(L, o);
986
+ api_check(L, tvistab(L->top-1));
987
+ t = tabV(L->top-1);
988
+ if (tvisfunc(o)) {
989
+ setgcref(funcV(o)->c.env, obj2gco(t));
990
+ } else if (tvisudata(o)) {
991
+ setgcref(udataV(o)->env, obj2gco(t));
992
+ } else if (tvisthread(o)) {
993
+ setgcref(threadV(o)->env, obj2gco(t));
994
+ } else {
995
+ L->top--;
996
+ return 0;
997
+ }
998
+ lj_gc_objbarrier(L, gcV(o), t);
999
+ L->top--;
1000
+ return 1;
1001
+ }
1002
+
1003
+ LUA_API const char *lua_setupvalue(lua_State *L, int idx, int n)
1004
+ {
1005
+ cTValue *f = index2adr(L, idx);
1006
+ TValue *val;
1007
+ const char *name;
1008
+ api_checknelems(L, 1);
1009
+ name = lj_debug_uvnamev(f, (uint32_t)(n-1), &val);
1010
+ if (name) {
1011
+ L->top--;
1012
+ copyTV(L, val, L->top);
1013
+ lj_gc_barrier(L, funcV(f), L->top);
1014
+ }
1015
+ return name;
1016
+ }
1017
+
1018
+ /* -- Calls --------------------------------------------------------------- */
1019
+
1020
+ #if LJ_FR2
1021
+ static TValue *api_call_base(lua_State *L, int nargs)
1022
+ {
1023
+ TValue *o = L->top, *base = o - nargs;
1024
+ L->top = o+1;
1025
+ for (; o > base; o--) copyTV(L, o, o-1);
1026
+ setnilV(o);
1027
+ return o+1;
1028
+ }
1029
+ #else
1030
+ #define api_call_base(L, nargs) (L->top - (nargs))
1031
+ #endif
1032
+
1033
+ LUA_API void lua_call(lua_State *L, int nargs, int nresults)
1034
+ {
1035
+ api_check(L, L->status == 0 || L->status == LUA_ERRERR);
1036
+ api_checknelems(L, nargs+1);
1037
+ lj_vm_call(L, api_call_base(L, nargs), nresults+1);
1038
+ }
1039
+
1040
+ LUA_API int lua_pcall(lua_State *L, int nargs, int nresults, int errfunc)
1041
+ {
1042
+ global_State *g = G(L);
1043
+ uint8_t oldh = hook_save(g);
1044
+ ptrdiff_t ef;
1045
+ int status;
1046
+ api_check(L, L->status == 0 || L->status == LUA_ERRERR);
1047
+ api_checknelems(L, nargs+1);
1048
+ if (errfunc == 0) {
1049
+ ef = 0;
1050
+ } else {
1051
+ cTValue *o = stkindex2adr(L, errfunc);
1052
+ api_checkvalidindex(L, o);
1053
+ ef = savestack(L, o);
1054
+ }
1055
+ status = lj_vm_pcall(L, api_call_base(L, nargs), nresults+1, ef);
1056
+ if (status) hook_restore(g, oldh);
1057
+ return status;
1058
+ }
1059
+
1060
+ static TValue *cpcall(lua_State *L, lua_CFunction func, void *ud)
1061
+ {
1062
+ GCfunc *fn = lj_func_newC(L, 0, getcurrenv(L));
1063
+ TValue *top = L->top;
1064
+ fn->c.f = func;
1065
+ setfuncV(L, top++, fn);
1066
+ if (LJ_FR2) setnilV(top++);
1067
+ setlightudV(top++, checklightudptr(L, ud));
1068
+ cframe_nres(L->cframe) = 1+0; /* Zero results. */
1069
+ L->top = top;
1070
+ return top-1; /* Now call the newly allocated C function. */
1071
+ }
1072
+
1073
+ LUA_API int lua_cpcall(lua_State *L, lua_CFunction func, void *ud)
1074
+ {
1075
+ global_State *g = G(L);
1076
+ uint8_t oldh = hook_save(g);
1077
+ int status;
1078
+ api_check(L, L->status == 0 || L->status == LUA_ERRERR);
1079
+ status = lj_vm_cpcall(L, func, ud, cpcall);
1080
+ if (status) hook_restore(g, oldh);
1081
+ return status;
1082
+ }
1083
+
1084
+ LUALIB_API int luaL_callmeta(lua_State *L, int idx, const char *field)
1085
+ {
1086
+ if (luaL_getmetafield(L, idx, field)) {
1087
+ TValue *top = L->top--;
1088
+ if (LJ_FR2) setnilV(top++);
1089
+ copyTV(L, top++, index2adr(L, idx));
1090
+ L->top = top;
1091
+ lj_vm_call(L, top-1, 1+1);
1092
+ return 1;
1093
+ }
1094
+ return 0;
1095
+ }
1096
+
1097
+ /* -- Coroutine yield and resume ------------------------------------------ */
1098
+
1099
+ LUA_API int lua_yield(lua_State *L, int nresults)
1100
+ {
1101
+ void *cf = L->cframe;
1102
+ global_State *g = G(L);
1103
+ if (cframe_canyield(cf)) {
1104
+ cf = cframe_raw(cf);
1105
+ if (!hook_active(g)) { /* Regular yield: move results down if needed. */
1106
+ cTValue *f = L->top - nresults;
1107
+ if (f > L->base) {
1108
+ TValue *t = L->base;
1109
+ while (--nresults >= 0) copyTV(L, t++, f++);
1110
+ L->top = t;
1111
+ }
1112
+ L->cframe = NULL;
1113
+ L->status = LUA_YIELD;
1114
+ return -1;
1115
+ } else { /* Yield from hook: add a pseudo-frame. */
1116
+ TValue *top = L->top;
1117
+ hook_leave(g);
1118
+ (top++)->u64 = cframe_multres(cf);
1119
+ setcont(top, lj_cont_hook);
1120
+ if (LJ_FR2) top++;
1121
+ setframe_pc(top, cframe_pc(cf)-1);
1122
+ if (LJ_FR2) top++;
1123
+ setframe_gc(top, obj2gco(L), LJ_TTHREAD);
1124
+ setframe_ftsz(top, ((char *)(top+1)-(char *)L->base)+FRAME_CONT);
1125
+ L->top = L->base = top+1;
1126
+ #if LJ_TARGET_X64
1127
+ lj_err_throw(L, LUA_YIELD);
1128
+ #else
1129
+ L->cframe = NULL;
1130
+ L->status = LUA_YIELD;
1131
+ lj_vm_unwind_c(cf, LUA_YIELD);
1132
+ #endif
1133
+ }
1134
+ }
1135
+ lj_err_msg(L, LJ_ERR_CYIELD);
1136
+ return 0; /* unreachable */
1137
+ }
1138
+
1139
+ LUA_API int lua_resume(lua_State *L, int nargs)
1140
+ {
1141
+ if (L->cframe == NULL && L->status <= LUA_YIELD)
1142
+ return lj_vm_resume(L,
1143
+ L->status == 0 ? api_call_base(L, nargs) : L->top - nargs,
1144
+ 0, 0);
1145
+ L->top = L->base;
1146
+ setstrV(L, L->top, lj_err_str(L, LJ_ERR_COSUSP));
1147
+ incr_top(L);
1148
+ return LUA_ERRRUN;
1149
+ }
1150
+
1151
+ /* -- GC and memory management -------------------------------------------- */
1152
+
1153
+ LUA_API int lua_gc(lua_State *L, int what, int data)
1154
+ {
1155
+ global_State *g = G(L);
1156
+ int res = 0;
1157
+ switch (what) {
1158
+ case LUA_GCSTOP:
1159
+ g->gc.threshold = LJ_MAX_MEM;
1160
+ break;
1161
+ case LUA_GCRESTART:
1162
+ g->gc.threshold = data == -1 ? (g->gc.total/100)*g->gc.pause : g->gc.total;
1163
+ break;
1164
+ case LUA_GCCOLLECT:
1165
+ lj_gc_fullgc(L);
1166
+ break;
1167
+ case LUA_GCCOUNT:
1168
+ res = (int)(g->gc.total >> 10);
1169
+ break;
1170
+ case LUA_GCCOUNTB:
1171
+ res = (int)(g->gc.total & 0x3ff);
1172
+ break;
1173
+ case LUA_GCSTEP: {
1174
+ GCSize a = (GCSize)data << 10;
1175
+ g->gc.threshold = (a <= g->gc.total) ? (g->gc.total - a) : 0;
1176
+ while (g->gc.total >= g->gc.threshold)
1177
+ if (lj_gc_step(L) > 0) {
1178
+ res = 1;
1179
+ break;
1180
+ }
1181
+ break;
1182
+ }
1183
+ case LUA_GCSETPAUSE:
1184
+ res = (int)(g->gc.pause);
1185
+ g->gc.pause = (MSize)data;
1186
+ break;
1187
+ case LUA_GCSETSTEPMUL:
1188
+ res = (int)(g->gc.stepmul);
1189
+ g->gc.stepmul = (MSize)data;
1190
+ break;
1191
+ default:
1192
+ res = -1; /* Invalid option. */
1193
+ }
1194
+ return res;
1195
+ }
1196
+
1197
+ LUA_API lua_Alloc lua_getallocf(lua_State *L, void **ud)
1198
+ {
1199
+ global_State *g = G(L);
1200
+ if (ud) *ud = g->allocd;
1201
+ return g->allocf;
1202
+ }
1203
+
1204
+ LUA_API void lua_setallocf(lua_State *L, lua_Alloc f, void *ud)
1205
+ {
1206
+ global_State *g = G(L);
1207
+ g->allocd = ud;
1208
+ g->allocf = f;
1209
+ }
1210
+