AP_Scripting: Reenable file IO

This commit is contained in:
Michael du Breuil 2019-04-23 23:26:59 -07:00 committed by Andrew Tridgell
parent a4d9853f1d
commit 17e258d347
3 changed files with 13 additions and 12 deletions

View File

@ -44,7 +44,7 @@ static const luaL_Reg loadedlibs[] = {
// {LUA_LOADLIBNAME, luaopen_package}, // {LUA_LOADLIBNAME, luaopen_package},
// {LUA_COLIBNAME, luaopen_coroutine}, // {LUA_COLIBNAME, luaopen_coroutine},
{LUA_TABLIBNAME, luaopen_table}, {LUA_TABLIBNAME, luaopen_table},
// {LUA_IOLIBNAME, luaopen_io}, {LUA_IOLIBNAME, luaopen_io},
// {LUA_OSLIBNAME, luaopen_os}, // {LUA_OSLIBNAME, luaopen_os},
{LUA_STRLIBNAME, luaopen_string}, {LUA_STRLIBNAME, luaopen_string},
{LUA_MATHLIBNAME, luaopen_math}, {LUA_MATHLIBNAME, luaopen_math},

View File

@ -1,4 +1,3 @@
#if 0
/* /*
** $Id: liolib.c,v 2.151.1.1 2017/04/19 17:29:57 roberto Exp $ ** $Id: liolib.c,v 2.151.1.1 2017/04/19 17:29:57 roberto Exp $
** Standard I/O (and system) library ** Standard I/O (and system) library
@ -207,7 +206,7 @@ static int aux_close (lua_State *L) {
} }
static int f_close (lua_State *L) { static int lf_close (lua_State *L) {
tofile(L); /* make sure argument is an open stream */ tofile(L); /* make sure argument is an open stream */
return aux_close(L); return aux_close(L);
} }
@ -216,7 +215,7 @@ static int f_close (lua_State *L) {
static int io_close (lua_State *L) { static int io_close (lua_State *L) {
if (lua_isnone(L, 1)) /* no argument? */ if (lua_isnone(L, 1)) /* no argument? */
lua_getfield(L, LUA_REGISTRYINDEX, IO_OUTPUT); /* use standard output */ lua_getfield(L, LUA_REGISTRYINDEX, IO_OUTPUT); /* use standard output */
return f_close(L); return lf_close(L);
} }
@ -582,7 +581,7 @@ static int io_read (lua_State *L) {
} }
static int f_read (lua_State *L) { static int lf_read (lua_State *L) {
return g_read(L, tofile(L), 2); return g_read(L, tofile(L), 2);
} }
@ -647,7 +646,7 @@ static int io_write (lua_State *L) {
} }
static int f_write (lua_State *L) { static int lf_write (lua_State *L) {
FILE *f = tofile(L); FILE *f = tofile(L);
lua_pushvalue(L, 1); /* push file at the stack top (to be returned) */ lua_pushvalue(L, 1); /* push file at the stack top (to be returned) */
return g_write(L, f, 2); return g_write(L, f, 2);
@ -673,6 +672,7 @@ static int f_seek (lua_State *L) {
} }
#if 0
static int f_setvbuf (lua_State *L) { static int f_setvbuf (lua_State *L) {
static const int mode[] = {_IONBF, _IOFBF, _IOLBF}; static const int mode[] = {_IONBF, _IOFBF, _IOLBF};
static const char *const modenames[] = {"no", "full", "line", NULL}; static const char *const modenames[] = {"no", "full", "line", NULL};
@ -682,7 +682,7 @@ static int f_setvbuf (lua_State *L) {
int res = setvbuf(f, NULL, mode[op], (size_t)sz); int res = setvbuf(f, NULL, mode[op], (size_t)sz);
return luaL_fileresult(L, res == 0, NULL); return luaL_fileresult(L, res == 0, NULL);
} }
#endif
static int io_flush (lua_State *L) { static int io_flush (lua_State *L) {
@ -718,13 +718,13 @@ static const luaL_Reg iolib[] = {
** methods for file handles ** methods for file handles
*/ */
static const luaL_Reg flib[] = { static const luaL_Reg flib[] = {
{"close", f_close}, {"close", lf_close},
{"flush", f_flush}, {"flush", f_flush},
{"lines", f_lines}, {"lines", f_lines},
{"read", f_read}, {"read", lf_read},
{"seek", f_seek}, {"seek", f_seek},
{"setvbuf", f_setvbuf}, // {"setvbuf", f_setvbuf},
{"write", f_write}, {"write", lf_write},
{"__gc", f_gc}, {"__gc", f_gc},
{"__tostring", f_tostring}, {"__tostring", f_tostring},
{NULL, NULL} {NULL, NULL}
@ -775,4 +775,3 @@ LUAMOD_API int luaopen_io (lua_State *L) {
return 1; return 1;
} }
#endif

View File

@ -9,6 +9,8 @@ function get_sandbox_env ()
tostring = tostring, tostring = tostring,
type = type, type = type,
unpack = unpack, unpack = unpack,
io = { close = io.close, flush = io.flush, input = io.input, open = io.open, output = io.output,
popen = io.popen, read = io.read, type = io.type, write = io.write},
string = { byte = string.byte, char = string.char, find = string.find, string = { byte = string.byte, char = string.char, find = string.find,
format = string.format, gmatch = string.gmatch, gsub = string.gsub, format = string.format, gmatch = string.gmatch, gsub = string.gsub,
len = string.len, lower = string.lower, match = string.match, len = string.len, lower = string.lower, match = string.match,