mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 11:10:39 +00:00
LunaCON: very primitive gamevar handling logic for {save,load}mapstate.
git-svn-id: https://svn.eduke32.com/eduke32@4119 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
6c88824792
commit
25edec9c0a
9 changed files with 63 additions and 13 deletions
|
@ -5465,7 +5465,8 @@ void A_Execute(int32_t iActor,int32_t iPlayer,int32_t lDist)
|
||||||
|
|
||||||
void G_SaveMapState(void)
|
void G_SaveMapState(void)
|
||||||
{
|
{
|
||||||
map_t *mapinfo = &MapInfo[ud.volume_number*MAXLEVELS+ud.level_number];
|
int32_t levelnum = ud.volume_number*MAXLEVELS+ud.level_number;
|
||||||
|
map_t *mapinfo = &MapInfo[levelnum];
|
||||||
mapstate_t *save;
|
mapstate_t *save;
|
||||||
|
|
||||||
if (mapinfo->savedstate == NULL)
|
if (mapinfo->savedstate == NULL)
|
||||||
|
@ -5558,7 +5559,23 @@ void G_SaveMapState(void)
|
||||||
else save->vars[i] = (intptr_t *)aGameVars[i].val.lValue;
|
else save->vars[i] = (intptr_t *)aGameVars[i].val.lValue;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
// TODO! (Not easy.)
|
{
|
||||||
|
int32_t slen;
|
||||||
|
const char *svcode = El_SerializeGamevars(&slen, levelnum);
|
||||||
|
|
||||||
|
if (slen < 0)
|
||||||
|
{
|
||||||
|
El_OnError("ERROR: savemapstate: serialization failed!");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
char *savecode = Bstrdup(svcode);
|
||||||
|
if (savecode == NULL)
|
||||||
|
G_GameExit("OUT OF MEMORY in G_SaveMapState!");
|
||||||
|
Bfree(save->savecode);
|
||||||
|
save->savecode = savecode;
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
ototalclock = totalclock;
|
ototalclock = totalclock;
|
||||||
}
|
}
|
||||||
|
@ -5566,7 +5583,8 @@ void G_SaveMapState(void)
|
||||||
|
|
||||||
void G_RestoreMapState(void)
|
void G_RestoreMapState(void)
|
||||||
{
|
{
|
||||||
mapstate_t *save = MapInfo[ud.volume_number*MAXLEVELS+ud.level_number].savedstate;
|
int32_t levelnum = ud.volume_number*MAXLEVELS+ud.level_number;
|
||||||
|
mapstate_t *save = MapInfo[levelnum].savedstate;
|
||||||
|
|
||||||
if (save != NULL)
|
if (save != NULL)
|
||||||
{
|
{
|
||||||
|
@ -5664,7 +5682,10 @@ void G_RestoreMapState(void)
|
||||||
|
|
||||||
Gv_RefreshPointers();
|
Gv_RefreshPointers();
|
||||||
#else
|
#else
|
||||||
// TODO! (Not easy.)
|
if (save->savecode)
|
||||||
|
{
|
||||||
|
El_RestoreGamevars(save->savecode);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
// Update g_player[].ps->i (sprite indices of players) to be consistent
|
// Update g_player[].ps->i (sprite indices of players) to be consistent
|
||||||
// with just loaded sprites.
|
// with just loaded sprites.
|
||||||
|
|
|
@ -1834,7 +1834,7 @@ end
|
||||||
function _savemapstate()
|
function _savemapstate()
|
||||||
ffiC.G_SaveMapState()
|
ffiC.G_SaveMapState()
|
||||||
local errmsg = debug.traceback(
|
local errmsg = debug.traceback(
|
||||||
"warning: savemapstate: gamevar saving not yet implemented", 2)
|
"warning: savemapstate: gamevar saving not fully implemented", 2)
|
||||||
ffiC.El_OnError(errmsg)
|
ffiC.El_OnError(errmsg)
|
||||||
print(errmsg)
|
print(errmsg)
|
||||||
end
|
end
|
||||||
|
@ -1842,7 +1842,7 @@ end
|
||||||
function _loadmapstate()
|
function _loadmapstate()
|
||||||
ffiC.G_RestoreMapState()
|
ffiC.G_RestoreMapState()
|
||||||
local errmsg = debug.traceback(
|
local errmsg = debug.traceback(
|
||||||
"warning: loadmapstate: gamevar saving not yet implemented", 2)
|
"warning: loadmapstate: gamevar saving not fully implemented", 2)
|
||||||
ffiC.El_OnError(errmsg)
|
ffiC.El_OnError(errmsg)
|
||||||
print(errmsg)
|
print(errmsg)
|
||||||
end
|
end
|
||||||
|
|
|
@ -597,7 +597,8 @@ void El_OnError(const char *str);
|
||||||
|
|
||||||
char *g_elSavecode;
|
char *g_elSavecode;
|
||||||
void El_FreeSaveCode(void);
|
void El_FreeSaveCode(void);
|
||||||
const char *(*El_SerializeGamevars)(int32_t *slenptr);
|
const char *(*El_SerializeGamevars)(int32_t *slenptr, int32_t levelnum);
|
||||||
|
int32_t (*El_RestoreGamevars)(const char *savecode);
|
||||||
|
|
||||||
const char *s_buildRev;
|
const char *s_buildRev;
|
||||||
const char *g_sizes_of_what[];
|
const char *g_sizes_of_what[];
|
||||||
|
@ -2244,8 +2245,8 @@ local CON_MODULE_NAME = "_CON\0"
|
||||||
do
|
do
|
||||||
local savegame = require("savegame")
|
local savegame = require("savegame")
|
||||||
|
|
||||||
-- Callback for: const char *(int32_t *slenptr);
|
-- Callback for: const char *(int32_t *slenptr, int32_t levelnum);
|
||||||
ffiC.El_SerializeGamevars = function(slenptr)
|
ffiC.El_SerializeGamevars = function(slenptr, levelnum)
|
||||||
local sb = savegame.savebuffer()
|
local sb = savegame.savebuffer()
|
||||||
|
|
||||||
-- Module name, module table, restore_local. See SAVEFUNC_ARGS.
|
-- Module name, module table, restore_local. See SAVEFUNC_ARGS.
|
||||||
|
@ -2305,6 +2306,10 @@ do
|
||||||
local fn = os.getenv("LUNATIC_SAVECODE_FN")
|
local fn = os.getenv("LUNATIC_SAVECODE_FN")
|
||||||
|
|
||||||
if (fn ~= nil) then
|
if (fn ~= nil) then
|
||||||
|
if (levelnum >= 0) then
|
||||||
|
fn = fn .. levelnum
|
||||||
|
end
|
||||||
|
|
||||||
local io = require("io")
|
local io = require("io")
|
||||||
local f = io.open(fn, "w")
|
local f = io.open(fn, "w")
|
||||||
|
|
||||||
|
@ -2471,6 +2476,17 @@ do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Restore CON gamevars from loadmapstate.
|
||||||
|
-- TODO: non-user-defined gamevars.
|
||||||
|
-- TODO: savegames.
|
||||||
|
-- int32_t El_RestoreGamevars(const char *)
|
||||||
|
ffiC.El_RestoreGamevars = function(savecode)
|
||||||
|
savecode = ffi.string(savecode)
|
||||||
|
local restorefunc = assert(loadstring(savecode))
|
||||||
|
restorefunc(CON_MODULE_NAME, package_loaded[CON_MODULE_NAME], nil)
|
||||||
|
return 0
|
||||||
|
end
|
||||||
|
|
||||||
-- Run the CON code translated into Lua.
|
-- Run the CON code translated into Lua.
|
||||||
if (concode) then
|
if (concode) then
|
||||||
local confunc, conerrmsg = loadstring(concode, "CON")
|
local confunc, conerrmsg = loadstring(concode, "CON")
|
||||||
|
|
|
@ -315,7 +315,8 @@ local function new_initial_codetab()
|
||||||
"_V,_A={},{}",
|
"_V,_A={},{}",
|
||||||
"-- NOTE to the reader: This require's result is Lunatic-private API! DO NOT USE!",
|
"-- NOTE to the reader: This require's result is Lunatic-private API! DO NOT USE!",
|
||||||
"local _dummy,_S=require'end_gamevars'",
|
"local _dummy,_S=require'end_gamevars'",
|
||||||
"local _V,_A=_V,_A",
|
-- XXX: Currently commented out because of gamevar restoration from loadmapstate.
|
||||||
|
-- "local _V,_A=_V,_A",
|
||||||
"local _C,_M,_I={},{},{}", -- actions, moves, ais
|
"local _C,_M,_I={},{},{}", -- actions, moves, ais
|
||||||
|
|
||||||
-- Static ivec3s so that no allocations need to be made.
|
-- Static ivec3s so that no allocations need to be made.
|
||||||
|
|
|
@ -437,6 +437,8 @@ static void El_PushCFunctions(lua_State *L)
|
||||||
|
|
||||||
//////
|
//////
|
||||||
|
|
||||||
|
LUNATIC_CB int32_t (*El_RestoreGamevars)(const char *savecode);
|
||||||
|
|
||||||
static void El_StateSetup(lua_State *L)
|
static void El_StateSetup(lua_State *L)
|
||||||
{
|
{
|
||||||
luaopen_lpeg(L);
|
luaopen_lpeg(L);
|
||||||
|
|
|
@ -39,6 +39,10 @@ void El_DestroyState(L_State *estate);
|
||||||
int32_t El_CallEvent(L_State *estate, int32_t eventidx, int32_t iActor, int32_t iPlayer, int32_t lDist, int32_t *iReturn);
|
int32_t El_CallEvent(L_State *estate, int32_t eventidx, int32_t iActor, int32_t iPlayer, int32_t lDist, int32_t *iReturn);
|
||||||
int32_t El_CallActor(L_State *estate, int32_t actortile, int32_t iActor, int32_t iPlayer, int32_t lDist);
|
int32_t El_CallActor(L_State *estate, int32_t actortile, int32_t iActor, int32_t iPlayer, int32_t lDist);
|
||||||
|
|
||||||
|
void El_OnError(const char *str);
|
||||||
|
|
||||||
|
int32_t (*El_RestoreGamevars)(const char *savecode);
|
||||||
|
|
||||||
static inline int32_t El_HaveEvent(int32_t eventidx) { return g_elEvents[eventidx]!=0; }
|
static inline int32_t El_HaveEvent(int32_t eventidx) { return g_elEvents[eventidx]!=0; }
|
||||||
static inline int32_t El_HaveActor(int32_t actortile) { return g_elActors[actortile].haveit!=0; }
|
static inline int32_t El_HaveActor(int32_t actortile) { return g_elActors[actortile].haveit!=0; }
|
||||||
|
|
||||||
|
|
|
@ -1083,8 +1083,8 @@ static inline void prelevel(char g)
|
||||||
// NOTE: must be safe loop because callbacks could delete sprites.
|
// NOTE: must be safe loop because callbacks could delete sprites.
|
||||||
for (SPRITES_OF_STAT_SAFE(STAT_DEFAULT, i, nexti))
|
for (SPRITES_OF_STAT_SAFE(STAT_DEFAULT, i, nexti))
|
||||||
{
|
{
|
||||||
#if !defined LUNATIC
|
|
||||||
A_ResetVars(i);
|
A_ResetVars(i);
|
||||||
|
#if !defined LUNATIC
|
||||||
A_LoadActor(i);
|
A_LoadActor(i);
|
||||||
#endif
|
#endif
|
||||||
VM_OnEvent(EVENT_LOADACTOR, i, -1, -1, 0);
|
VM_OnEvent(EVENT_LOADACTOR, i, -1, -1, 0);
|
||||||
|
|
|
@ -1692,7 +1692,9 @@ static void sv_restload()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef LUNATIC
|
#ifdef LUNATIC
|
||||||
LUNATIC_CB const char *(*El_SerializeGamevars)(int32_t *slenptr);
|
// <levelnum>: if we're not serializing for a mapstate, -1
|
||||||
|
// otherwise, the linearized level number
|
||||||
|
LUNATIC_CB const char *(*El_SerializeGamevars)(int32_t *slenptr, int32_t levelnum);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static uint8_t *dosaveplayer2(FILE *fil, uint8_t *mem)
|
static uint8_t *dosaveplayer2(FILE *fil, uint8_t *mem)
|
||||||
|
@ -1711,7 +1713,7 @@ static uint8_t *dosaveplayer2(FILE *fil, uint8_t *mem)
|
||||||
// be present before Lua state creation in svgm_script, so save it
|
// be present before Lua state creation in svgm_script, so save it
|
||||||
// right before, too.
|
// right before, too.
|
||||||
int32_t slen, slen_ext;
|
int32_t slen, slen_ext;
|
||||||
const char *svcode = El_SerializeGamevars(&slen);
|
const char *svcode = El_SerializeGamevars(&slen, -1);
|
||||||
|
|
||||||
if (slen < 0)
|
if (slen < 0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -92,4 +92,8 @@ enum
|
||||||
void G_Util_PtrToIdx(void *ptr, int32_t count, const void *base, int32_t mode);
|
void G_Util_PtrToIdx(void *ptr, int32_t count, const void *base, int32_t mode);
|
||||||
void G_Util_PtrToIdx2(void *ptr, int32_t count, size_t stride, const void *base, int32_t mode);
|
void G_Util_PtrToIdx2(void *ptr, int32_t count, size_t stride, const void *base, int32_t mode);
|
||||||
|
|
||||||
|
#ifdef LUNATIC
|
||||||
|
const char *(*El_SerializeGamevars)(int32_t *slenptr, int32_t levelnum);
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue