diff options
author | daurnimator <quae@daurnimator.com> | 2018-04-20 21:16:24 +1000 |
---|---|---|
committer | daurnimator <quae@daurnimator.com> | 2018-04-20 21:16:24 +1000 |
commit | a260f381d30e036b39078fee0295e539067c10a3 (patch) | |
tree | 4f3b2ecb264ec8dd29cac74d23223d15d297eb8e /test/tests.js | |
parent | fe9b43374c2e8dc28df0ce460aefaf50b933aaa7 (diff) | |
parent | 9f5d4d35de0b88334bba7c11a9e960a19ee0740b (diff) | |
download | fengari-a260f381d30e036b39078fee0295e539067c10a3.tar.gz fengari-a260f381d30e036b39078fee0295e539067c10a3.tar.bz2 fengari-a260f381d30e036b39078fee0295e539067c10a3.zip |
Merge branch 'test-with-jest'
Diffstat (limited to 'test/tests.js')
-rw-r--r-- | test/tests.js | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/test/tests.js b/test/tests.js new file mode 100644 index 0000000..631594b --- /dev/null +++ b/test/tests.js @@ -0,0 +1,23 @@ +"use strict"; + +const lua = require("../src/lua.js"); +const lauxlib = require("../src/lauxlib.js"); +const {to_luastring} = require("../src/fengaricore.js"); + +const toByteCode = function(luaCode) { + let L = lauxlib.luaL_newstate(); + if (!L) throw Error("failed to create lua state"); + + if (lauxlib.luaL_loadstring(L, to_luastring(luaCode)) !== lua.LUA_OK) + throw Error(lua.lua_tojsstring(L, -1)); + + let b = []; + if (lua.lua_dump(L, function(L, b, size, B) { + B.push(...b.slice(0, size)); + return 0; + }, b, false) !== 0) + throw Error("unable to dump given function"); + return Uint8Array.from(b); +}; + +module.exports.toByteCode = toByteCode; |