From c5bb3643ab28d5309971f1960dd5222b9c81fd3a Mon Sep 17 00:00:00 2001 From: Roberto Ierusalimschy <roberto@inf.puc-rio.br> Date: Thu, 6 Mar 2014 14:12:02 -0300 Subject: simpler code to read a line from a file (using 'getc' or, if present, 'getc_unlocked') --- liolib.c | 41 ++++++++++++++++++++++++----------------- 1 file changed, 24 insertions(+), 17 deletions(-) (limited to 'liolib.c') diff --git a/liolib.c b/liolib.c index 88be99ec..adb72ef3 100644 --- a/liolib.c +++ b/liolib.c @@ -1,5 +1,5 @@ /* -** $Id: liolib.c,v 2.116 2014/02/21 14:39:50 roberto Exp roberto $ +** $Id: liolib.c,v 2.117 2014/02/26 15:27:56 roberto Exp roberto $ ** Standard I/O (and system) library ** See Copyright Notice in lua.h */ @@ -79,6 +79,21 @@ /* }====================================================== */ +#if !defined(lua_getc) /* { */ + +#if defined(LUA_USE_POSIX) +#define lua_getc(f) getc_unlocked(f) +#define lua_lockfile(f) flockfile(f) +#define lua_unlockfile(f) funlockfile(f) +#else +#define lua_getc(f) getc(f) +#define lua_lockfile(f) ((void)0) +#define lua_unlockfile(f) ((void)0) +#endif + +#endif /* } */ + + /* ** {====================================================== ** lua_fseek: configuration for longer offsets @@ -384,23 +399,15 @@ static int test_eof (lua_State *L, FILE *f) { static int read_line (lua_State *L, FILE *f, int chop) { luaL_Buffer b; + int c; luaL_buffinit(L, &b); - for (;;) { - size_t l; - char *p = luaL_prepbuffer(&b); - if (fgets(p, LUAL_BUFFERSIZE, f) == NULL) { /* eof? */ - luaL_pushresult(&b); /* close buffer */ - return (lua_rawlen(L, -1) > 0); /* check whether read something */ - } - l = strlen(p); - if (l == 0 || p[l-1] != '\n') - luaL_addsize(&b, l); - else { - luaL_addsize(&b, l - chop); /* chop 'eol' if needed */ - luaL_pushresult(&b); /* close buffer */ - return 1; /* read at least an `eol' */ - } - } + lua_lockfile(f); + while ((c = lua_getc(f)) != EOF && c != '\n') + luaL_addchar(&b, c); + lua_unlockfile(f); + if (!chop && c == '\n') luaL_addchar(&b, c); + luaL_pushresult(&b); /* close buffer */ + return (c == '\n' || lua_rawlen(L, -1) > 0); } -- cgit v1.2.3-55-g6feb