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 /tests/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 'tests/tests.js')
-rw-r--r-- | tests/tests.js | 30 |
1 files changed, 0 insertions, 30 deletions
diff --git a/tests/tests.js b/tests/tests.js deleted file mode 100644 index 778cbef..0000000 --- a/tests/tests.js +++ /dev/null @@ -1,30 +0,0 @@ -"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 = getState(luaCode); - 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); -}; - -const getState = function(luaCode) { - let L = lauxlib.luaL_newstate(); - if (!L) - throw Error("unable to create lua_State"); - - if (lauxlib.luaL_loadstring(L, to_luastring(luaCode)) !== lua.LUA_OK) - throw Error(lua.lua_tojsstring(L, -1)); - - return L; -}; - -module.exports.getState = getState; -module.exports.toByteCode = toByteCode; |