mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-15 22:21:26 +00:00
Fix and clean up io_open after MI broke it horribly
strcpy(NULL, filename); congrats
This commit is contained in:
parent
14dcd2404b
commit
9c299e5ad4
1 changed files with 23 additions and 23 deletions
|
@ -166,16 +166,18 @@ static int StartsWith(const char *a, const char *b) // this is wolfs being lazy
|
||||||
|
|
||||||
|
|
||||||
static int io_open (lua_State *L) {
|
static int io_open (lua_State *L) {
|
||||||
const char *filename = luaL_checkstring(L, 1);
|
|
||||||
int pass = 0; size_t i;
|
|
||||||
int length = strlen(filename) - 1;
|
|
||||||
char *splitter, *splitter2;
|
|
||||||
char *destFilename = NULL;
|
|
||||||
const char *mode = luaL_optstring(L, 2, "r");
|
|
||||||
FILE **pf;
|
FILE **pf;
|
||||||
|
const char *filename = luaL_checkstring(L, 1);
|
||||||
|
int pass = 0;
|
||||||
|
size_t i;
|
||||||
|
int length = strlen(filename);
|
||||||
|
char *splitter, *forward, *backward;
|
||||||
|
char *destFilename;
|
||||||
|
const char *mode = luaL_optstring(L, 2, "r");
|
||||||
|
|
||||||
for (i = 0; i < (sizeof (whitelist) / sizeof(const char *)); i++)
|
for (i = 0; i < (sizeof (whitelist) / sizeof(const char *)); i++)
|
||||||
{
|
{
|
||||||
if (!stricmp(&filename[length - (strlen(whitelist[i]) - 1)], whitelist[i]))
|
if (!stricmp(&filename[length - strlen(whitelist[i])], whitelist[i]))
|
||||||
{
|
{
|
||||||
pass = 1;
|
pass = 1;
|
||||||
break;
|
break;
|
||||||
|
@ -187,29 +189,27 @@ static int io_open (lua_State *L) {
|
||||||
luaL_error(L,"access denied to %s", filename);
|
luaL_error(L,"access denied to %s", filename);
|
||||||
return pushresult(L,0,filename);
|
return pushresult(L,0,filename);
|
||||||
}
|
}
|
||||||
I_mkdir("luafiles", 0755);
|
|
||||||
|
destFilename = va("luafiles"PATHSEP"%s", filename);
|
||||||
strcpy(destFilename, filename); // copy file name to temp string
|
|
||||||
|
// Make directories as needed
|
||||||
splitter = destFilename;
|
splitter = destFilename;
|
||||||
while ((splitter = strchr(splitter, '/')))
|
|
||||||
|
forward = strchr(splitter, '/');
|
||||||
|
backward = strchr(splitter, '\\');
|
||||||
|
while ((splitter = (forward && backward) ? min(forward, backward) : (forward ?: backward)))
|
||||||
{
|
{
|
||||||
*splitter = 0;
|
*splitter = 0;
|
||||||
I_mkdir(va("luafiles"PATHSEP"%s", destFilename), 0755);
|
I_mkdir(destFilename, 0755);
|
||||||
*splitter = '/';
|
*splitter = '/';
|
||||||
splitter++;
|
splitter++;
|
||||||
|
|
||||||
|
forward = strchr(splitter, '/');
|
||||||
|
backward = strchr(splitter, '\\');
|
||||||
}
|
}
|
||||||
splitter2 = destFilename;
|
|
||||||
while ((splitter2 = strchr(splitter2, '\\')))
|
|
||||||
{
|
|
||||||
*splitter2 = 0;
|
|
||||||
I_mkdir(va("luafiles"PATHSEP"%s", destFilename), 0755);
|
|
||||||
*splitter2 = '\\';
|
|
||||||
splitter2++;
|
|
||||||
}
|
|
||||||
destFilename = va("luafiles"PATHSEP"%s", destFilename);
|
|
||||||
filename = destFilename;
|
|
||||||
pf = newfile(L);
|
pf = newfile(L);
|
||||||
*pf = fopen(filename, mode);
|
*pf = fopen(destFilename, mode);
|
||||||
return (*pf == NULL) ? pushresult(L, 0, filename) : 1;
|
return (*pf == NULL) ? pushresult(L, 0, filename) : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue