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,21 +1168,21 @@ lua_State *lua_init(const dictionary *inifile) {
return L; return L;
} }
int eressea_run(lua_State *L, const char *luafile) static int run_script(lua_State *L, const char *luafile) {
{ int err;
int err = 0; FILE *F;
global.vm_state = L; F = fopen(luafile, "r");
/* run the main script */ if (!F) {
if (luafile) { log_debug("dofile('%s'): %s", luafile, strerror(errno));
log_debug("executing script %s\n", luafile); return errno;
}
fclose(F);
lua_getglobal(L, "debug"); log_debug("executing script %s", luafile);
lua_getfield(L, -1, "traceback");
lua_remove(L, -2);
lua_getglobal(L, "dofile"); lua_getglobal(L, "dofile");
lua_pushstring(L, luafile); lua_pushstring(L, luafile);
err = lua_pcall(L, 1, 1, -3); err = lua_pcall(L, 1, 1, -3); /* error handler (debug.traceback) is now at stack -3 */
if (err != 0) { if (err != 0) {
log_lua_error(L); log_lua_error(L);
assert(!"Lua syntax error? check log."); assert(!"Lua syntax error? check log.");
@ -1194,6 +1194,30 @@ int eressea_run(lua_State *L, const char *luafile)
lua_pop(L, 1); lua_pop(L, 1);
} }
return err; return err;
} }
return lua_console(L);
int eressea_run(lua_State *L, const char *luafile)
{
int err;
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 */
if (luafile) {
err = run_script(L, luafile);
}
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);