forked from github/server
try loading config.lua and custom.lua files, if they exist.
This commit is contained in:
parent
2c38883362
commit
9e9cd6ae79
2 changed files with 46 additions and 23 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue