diff options
author | Benoit Giannangeli <giann008@gmail.com> | 2017-05-17 07:51:27 +0200 |
---|---|---|
committer | Benoit Giannangeli <giann008@gmail.com> | 2017-05-17 07:51:27 +0200 |
commit | 238106fbfba60a23800c1038ec7b1a04e0682119 (patch) | |
tree | cb5045904cc16d091b61f993f3cbab50992a4128 /src/liolib.js | |
parent | 3a7f9d85b91530f7f151f536a0aab2455486262d (diff) | |
parent | 0422224def06db85f16d24a73b71b8d75e6f74a4 (diff) | |
download | fengari-238106fbfba60a23800c1038ec7b1a04e0682119.tar.gz fengari-238106fbfba60a23800c1038ec7b1a04e0682119.tar.bz2 fengari-238106fbfba60a23800c1038ec7b1a04e0682119.zip |
Merge remote-tracking branch 'daurnimator/iolib'
Diffstat (limited to 'src/liolib.js')
-rw-r--r-- | src/liolib.js | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/src/liolib.js b/src/liolib.js index 575b3ec..51e18ee 100644 --- a/src/liolib.js +++ b/src/liolib.js @@ -78,6 +78,23 @@ const getiofile = function(L, findex) { return p.f; }; +const g_iofile = function(L, f, mode) { + if (!lua.lua_isnoneornil(L, 1)) { + lauxlib.luaL_error(L, lua.to_luastring("opening files not yet implemented")); + } + /* return current value */ + lua.lua_getfield(L, lua.LUA_REGISTRYINDEX, f); + return 1; +}; + +const io_input = function(L) { + return g_iofile(L, IO_INPUT, "r"); +}; + +const io_output = function(L) { + return g_iofile(L, IO_OUTPUT, "w"); +}; + const g_write = function(L, f, arg) { let nargs = lua.lua_gettop(L) - arg; let status = true; @@ -105,14 +122,30 @@ const f_write = function(L) { return g_write(L, f, 2); }; +const io_flush = function (L) { + /* stub, as node doesn't have synchronized buffered IO */ + getiofile(L, IO_OUTPUT); + return lauxlib.luaL_fileresult(L, true, null, null); +}; + +const f_flush = function (L) { + /* stub, as node doesn't have synchronized buffered IO */ + tofile(L); + return lauxlib.luaL_fileresult(L, true, null, null); +}; + const iolib = { "close": io_close, + "flush": io_flush, + "input": io_input, + "output": io_output, "type": io_type, "write": io_write }; const flib = { "close": io_close, + "flush": f_flush, "write": f_write, "__tostring": f_tostring }; |