try loading config.lua and custom.lua files, if they exist.

This commit is contained in:
Enno Rehling 2017-01-22 18:01:09 +01:00
parent 2c38883362
commit 9e9cd6ae79
2 changed files with 46 additions and 23 deletions

View file

@ -1168,32 +1168,56 @@ lua_State *lua_init(const dictionary *inifile) {
return L; return L;
} }
static int run_script(lua_State *L, const char *luafile) {
int err;
FILE *F;
F = fopen(luafile, "r");
if (!F) {
log_debug("dofile('%s'): %s", luafile, strerror(errno));
return errno;
}
fclose(F);
log_debug("executing script %s", luafile);
lua_getglobal(L, "dofile");
lua_pushstring(L, luafile);
err = lua_pcall(L, 1, 1, -3); /* error handler (debug.traceback) is now at stack -3 */
if (err != 0) {
log_lua_error(L);
assert(!"Lua syntax error? check log.");
}
else {
if (lua_isnumber(L, -1)) {
err = (int)lua_tonumber(L, -1);
}
lua_pop(L, 1);
}
return err;
}
int eressea_run(lua_State *L, const char *luafile) int eressea_run(lua_State *L, const char *luafile)
{ {
int err = 0; int err;
global.vm_state = L; global.vm_state = L;
/* push an error handling function on the stack: */
lua_getglobal(L, "debug");
lua_getfield(L, -1, "traceback");
lua_remove(L, -2);
/* try to run configuration scripts: */
err = run_script(L, "config.lua");
err = run_script(L, "custom.lua");
/* run the main script */ /* run the main script */
if (luafile) { if (luafile) {
log_debug("executing script %s\n", luafile); err = run_script(L, luafile);
lua_getglobal(L, "debug");
lua_getfield(L, -1, "traceback");
lua_remove(L, -2);
lua_getglobal(L, "dofile");
lua_pushstring(L, luafile);
err = lua_pcall(L, 1, 1, -3);
if (err != 0) {
log_lua_error(L);
assert(!"Lua syntax error? check log.");
}
else {
if (lua_isnumber(L, -1)) {
err = (int)lua_tonumber(L, -1);
}
lua_pop(L, 1);
}
return err;
} }
return lua_console(L); else {
err = lua_console(L);
}
/* pop error handler off the stack: */
lua_pop(L, 1);
return err;
} }

View file

@ -44,7 +44,6 @@ extern "C" {
extern int enc_gamedata; extern int enc_gamedata;
int readorders(const char *filename); int readorders(const char *filename);
int creategame(void);
int readgame(const char *filename); int readgame(const char *filename);
int writegame(const char *filename); int writegame(const char *filename);