diff options
author | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2009-08-28 10:51:57 -0300 |
---|---|---|
committer | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2009-08-28 10:51:57 -0300 |
commit | 5b6be84106f41752624b9ee66dbd9d21eda7e0ce (patch) | |
tree | 2508e6a296582e1358cb8a94ec0470e13ab01f63 | |
parent | b2bb2f7f592c0dfaa3a2aa523a97597d49c2252c (diff) | |
download | lua-5b6be84106f41752624b9ee66dbd9d21eda7e0ce.tar.gz lua-5b6be84106f41752624b9ee66dbd9d21eda7e0ce.tar.bz2 lua-5b6be84106f41752624b9ee66dbd9d21eda7e0ce.zip |
ensures that argument 'mode' to 'io.open' matches "[rwa]%+?b?", to
avoid passing invalid modes to 'fopen'.
-rw-r--r-- | liolib.c | 13 |
1 files changed, 11 insertions, 2 deletions
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: liolib.c,v 2.79 2008/02/12 17:05:36 roberto Exp roberto $ | 2 | ** $Id: liolib.c,v 2.80 2009/02/20 13:50:27 roberto Exp roberto $ |
3 | ** Standard I/O (and system) library | 3 | ** Standard I/O (and system) library |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -165,7 +165,16 @@ static int io_tostring (lua_State *L) { | |||
165 | static int io_open (lua_State *L) { | 165 | static int io_open (lua_State *L) { |
166 | const char *filename = luaL_checkstring(L, 1); | 166 | const char *filename = luaL_checkstring(L, 1); |
167 | const char *mode = luaL_optstring(L, 2, "r"); | 167 | const char *mode = luaL_optstring(L, 2, "r"); |
168 | FILE **pf = newfile(L); | 168 | FILE **pf; |
169 | int i = 0; | ||
170 | /* check whether 'mode' matches '[rwa]%+?b?' */ | ||
171 | if (!(mode[i] != '\0' && strchr("rwa", mode[i++]) != NULL && | ||
172 | (mode[i] != '+' || ++i) && /* skip if char is '+' */ | ||
173 | (mode[i] != 'b' || ++i) && /* skip if char is 'b' */ | ||
174 | (mode[i] == '\0'))) | ||
175 | luaL_error(L, "invalid mode " LUA_QL("%s") | ||
176 | " (should match " LUA_QL("[rwa]%%+?b?") ")", mode); | ||
177 | pf = newfile(L); | ||
169 | *pf = fopen(filename, mode); | 178 | *pf = fopen(filename, mode); |
170 | return (*pf == NULL) ? pushresult(L, 0, filename) : 1; | 179 | return (*pf == NULL) ? pushresult(L, 0, filename) : 1; |
171 | } | 180 | } |