mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
Lunatic: fix current incarnation of gamevar saving/restoration.
git-svn-id: https://svn.eduke32.com/eduke32@3857 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
a0f00e28c3
commit
34138cdc96
5 changed files with 84 additions and 32 deletions
|
@ -1413,7 +1413,7 @@ local function our_require(modname, ...)
|
||||||
local gvnames = {}
|
local gvnames = {}
|
||||||
|
|
||||||
for name in pairs(getfenv(2)) do
|
for name in pairs(getfenv(2)) do
|
||||||
gvnames[#gvnames] = name
|
gvnames[#gvnames+1] = name
|
||||||
if (ffiC._DEBUG_LUNATIC ~= 0) then
|
if (ffiC._DEBUG_LUNATIC ~= 0) then
|
||||||
printf("MODULE %s GAMEVAR %s", thismodname, name)
|
printf("MODULE %s GAMEVAR %s", thismodname, name)
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
local string = require("string")
|
local string = require("string")
|
||||||
local table = require("table")
|
local table = require("table")
|
||||||
|
|
||||||
|
local assert = assert
|
||||||
local getmetatable = getmetatable
|
local getmetatable = getmetatable
|
||||||
local pairs = pairs
|
local pairs = pairs
|
||||||
local setmetatable = setmetatable
|
local setmetatable = setmetatable
|
||||||
|
@ -16,6 +17,9 @@ module(...)
|
||||||
|
|
||||||
---=== Serialization, based on the idea from PiL ===---
|
---=== Serialization, based on the idea from PiL ===---
|
||||||
|
|
||||||
|
assert(tostring(0/0)=="nan")
|
||||||
|
assert(tostring(1/0)=="inf")
|
||||||
|
|
||||||
-- Serialize a 'primitive' Lua value.
|
-- Serialize a 'primitive' Lua value.
|
||||||
local function basicSerialize(o)
|
local function basicSerialize(o)
|
||||||
-- Compare with sb_get_initial_strbuf() below.
|
-- Compare with sb_get_initial_strbuf() below.
|
||||||
|
|
|
@ -39,12 +39,21 @@ ourvar = { ourvar2; 1, 2, 3, "qwe"; [true]=0, [false]=1 }
|
||||||
ourvar[#ourvar+1] = ourvar;
|
ourvar[#ourvar+1] = ourvar;
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
print('tweaking sector pals')
|
local vol, lev = gv.currentEpisode()+1, gv.currentLevel()+1
|
||||||
print('numsectors: ' .. gv.numsectors .. ' of ' .. gv.MAXSECTORS)
|
printf('volume=%d, level=%d', vol, lev)
|
||||||
|
|
||||||
---[[
|
---[[
|
||||||
local SF = sector.STAT
|
if (vol ~= 4) then
|
||||||
for i = 0, gv.numsectors/2 do
|
-- Tweak some sector pals.
|
||||||
|
-- NOTE: you're not really supposed to modify game state from Lua file
|
||||||
|
-- scope! This is for testing only! E.g. it will fail if a savegame is
|
||||||
|
-- loaded from the menu when no other level is loaded.
|
||||||
|
|
||||||
|
print('tweaking sector pals')
|
||||||
|
print('numsectors: ' .. gv.numsectors .. ' of ' .. gv.MAXSECTORS)
|
||||||
|
|
||||||
|
local SF = sector.STAT
|
||||||
|
for i = 0, gv.numsectors/2 do
|
||||||
local sec = sector[i]
|
local sec = sector[i]
|
||||||
sec.floorpal = 1;
|
sec.floorpal = 1;
|
||||||
sector[i].floor.shade = sec.floor.shade + 4
|
sector[i].floor.shade = sec.floor.shade + 4
|
||||||
|
@ -53,11 +62,9 @@ for i = 0, gv.numsectors/2 do
|
||||||
ceil.shade = sector[i].ceiling.shade + 8
|
ceil.shade = sector[i].ceiling.shade + 8
|
||||||
ceil.statx:flip(SF.SMOOSH)
|
ceil.statx:flip(SF.SMOOSH)
|
||||||
sec.floorstatx:flip(SF.SWAPXY)
|
sec.floorstatx:flip(SF.SWAPXY)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local vol, lev = gv.currentEpisode()+1, gv.currentLevel()+1
|
|
||||||
printf('volume=%d, level=%d', vol, lev)
|
|
||||||
|
|
||||||
if (vol==1 and lev==1) then -- E1L1
|
if (vol==1 and lev==1) then -- E1L1
|
||||||
print('tweaking some sprites 2')
|
print('tweaking some sprites 2')
|
||||||
local i = 562
|
local i = 562
|
||||||
|
@ -215,7 +222,7 @@ gameevent("PROCESSINPUT",
|
||||||
gameevent("JUMP", actor.FLAGS.chain_beg,
|
gameevent("JUMP", actor.FLAGS.chain_beg,
|
||||||
function(actori, playeri, dist)
|
function(actori, playeri, dist)
|
||||||
local ps = player[playeri]
|
local ps = player[playeri]
|
||||||
print("I'm first!")
|
print("\n--- I'm first!")
|
||||||
-- DBG_.oom()
|
-- DBG_.oom()
|
||||||
ps.weapon.PISTOL.shoots = 2605 -- RPG
|
ps.weapon.PISTOL.shoots = 2605 -- RPG
|
||||||
ps.weapon[gv.PISTOL_WEAPON].firesound = 351 -- thunder
|
ps.weapon[gv.PISTOL_WEAPON].firesound = 351 -- thunder
|
||||||
|
|
|
@ -1,24 +1,53 @@
|
||||||
|
|
||||||
|
local require = require
|
||||||
local con = require "con"
|
local con = require "con"
|
||||||
|
|
||||||
|
local gv = gv
|
||||||
|
local sprite = sprite
|
||||||
|
local actor = actor
|
||||||
|
local player = player
|
||||||
|
|
||||||
|
local assert = assert
|
||||||
|
|
||||||
|
local printf = printf
|
||||||
|
local gameevent = gameevent
|
||||||
local spritesofstat = spritesofstat
|
local spritesofstat = spritesofstat
|
||||||
|
|
||||||
local Inf = 0/1
|
local Inf = 0/1
|
||||||
|
|
||||||
-- Insert MUSICANDSFX? (Delete it otherwise.)
|
|
||||||
-- XXX: should be a per-player gamevar, but this is testing code.
|
|
||||||
local insp = false
|
|
||||||
local hitag, lotag = 0, 0
|
|
||||||
|
|
||||||
gameevent("JUMP",
|
module(...)
|
||||||
|
|
||||||
|
|
||||||
|
-- Insert MUSICANDSFX? (Delete it otherwise.)
|
||||||
|
insp = false
|
||||||
|
|
||||||
|
-- Hitag and lotag of last deleted MUSICANDSFX sprite.
|
||||||
|
tag = {}
|
||||||
|
tag.hi, tag.lo = 0, 0
|
||||||
|
|
||||||
|
-- Preliminary dummy of a local gamevar.
|
||||||
|
local ournumjumps = 0
|
||||||
|
|
||||||
|
require "end_gamevars"
|
||||||
|
|
||||||
|
-- We may cache globals defined in the gamevar section afterwards, but not
|
||||||
|
-- refer to locals defined prior to the gamevar section in it.
|
||||||
|
local tag = tag
|
||||||
|
|
||||||
|
|
||||||
|
gameevent("JUMP", actor.FLAGS.chain_beg,
|
||||||
function(aci, pli)
|
function(aci, pli)
|
||||||
local ps = player[pli]
|
local ps = player[pli]
|
||||||
|
|
||||||
|
ournumjumps = ournumjumps+1
|
||||||
|
|
||||||
if (insp) then
|
if (insp) then
|
||||||
-- Insert MUSICANDSFX sprite with same lo-/hitag as last deleted one.
|
-- Insert MUSICANDSFX sprite with same lo-/hitag as last deleted one.
|
||||||
|
printf("delmusicsfx: jump count=%d, inserting", ournumjumps)
|
||||||
|
|
||||||
local spr = sprite[con.spawn(aci, 5)]
|
local spr = sprite[con.spawn(aci, 5)]
|
||||||
spr.lotag, spr.hitag = lotag, hitag
|
spr.lotag, spr.hitag = tag.lo, tag.hi
|
||||||
else
|
else
|
||||||
-- Delete nearest MUSICANDSFX sprite.
|
-- Delete nearest MUSICANDSFX sprite.
|
||||||
|
|
||||||
|
@ -27,7 +56,8 @@ function(aci, pli)
|
||||||
|
|
||||||
for i in spritesofstat(gv.STAT_FX) do
|
for i in spritesofstat(gv.STAT_FX) do
|
||||||
local dst = (sprite[i]-ps.pos):len2()
|
local dst = (sprite[i]-ps.pos):len2()
|
||||||
if (nearesti == -1 or dst < nearestdst) then
|
if (nearesti == -1 or (dst < nearestdst and dst < sprite[i].hitag)) then
|
||||||
|
printf("MSFX %d dist %d", i, dst)
|
||||||
nearesti = i
|
nearesti = i
|
||||||
nearestdst = dst
|
nearestdst = dst
|
||||||
end
|
end
|
||||||
|
@ -35,9 +65,12 @@ function(aci, pli)
|
||||||
|
|
||||||
if (nearesti >= 0) then
|
if (nearesti >= 0) then
|
||||||
local spr = sprite[nearesti]
|
local spr = sprite[nearesti]
|
||||||
lotag, hitag = spr.lotag, spr.hitag
|
tag.lo, tag.hi = spr.lotag, spr.hitag
|
||||||
actor.delete(nearesti)
|
actor.delete(nearesti)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
assert(nearesti < 0 or sprite[nearesti].picnum==5)
|
||||||
|
printf("delmusicsfx: jump count=%d, deleting sprite %d", ournumjumps, nearesti)
|
||||||
end
|
end
|
||||||
|
|
||||||
insp = not insp
|
insp = not insp
|
||||||
|
|
|
@ -848,6 +848,15 @@ static void sv_calcbitptrsize();
|
||||||
static void sv_prescriptsave_once();
|
static void sv_prescriptsave_once();
|
||||||
static void sv_prescriptload_once();
|
static void sv_prescriptload_once();
|
||||||
static void sv_postscript_once();
|
static void sv_postscript_once();
|
||||||
|
#else
|
||||||
|
// Recreate Lua state.
|
||||||
|
// XXX: It may matter a great deal when this is run from if the Lua code refers
|
||||||
|
// to C-side data at file scope. Such usage is strongly discouraged though.
|
||||||
|
static void sv_create_lua_state(void)
|
||||||
|
{
|
||||||
|
El_CreateGameState();
|
||||||
|
G_PostCreateGameState();
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
static void sv_preactordatasave();
|
static void sv_preactordatasave();
|
||||||
static void sv_postactordata();
|
static void sv_postactordata();
|
||||||
|
@ -867,7 +876,9 @@ static void sv_restload();
|
||||||
((sizeof(g_player[0].user_name)+sizeof(g_player[0].pcolor)+sizeof(g_player[0].pteam) \
|
((sizeof(g_player[0].user_name)+sizeof(g_player[0].pcolor)+sizeof(g_player[0].pteam) \
|
||||||
+sizeof(g_player[0].frags)+sizeof(DukePlayer_t))*MAXPLAYERS)
|
+sizeof(g_player[0].frags)+sizeof(DukePlayer_t))*MAXPLAYERS)
|
||||||
|
|
||||||
|
#if !defined LUNATIC
|
||||||
static uint32_t savegame_bitptrsize;
|
static uint32_t savegame_bitptrsize;
|
||||||
|
#endif
|
||||||
static uint8_t savegame_quotedef[MAXQUOTES>>3];
|
static uint8_t savegame_quotedef[MAXQUOTES>>3];
|
||||||
static char(*savegame_quotes)[MAXQUOTELEN];
|
static char(*savegame_quotes)[MAXQUOTELEN];
|
||||||
static char(*savegame_quoteredefs)[MAXQUOTELEN];
|
static char(*savegame_quoteredefs)[MAXQUOTELEN];
|
||||||
|
@ -983,7 +994,9 @@ static const dataspec_t svgm_script[] =
|
||||||
{ DS_SAVEFN, (void *)&sv_preactordatasave, 0, 1 },
|
{ DS_SAVEFN, (void *)&sv_preactordatasave, 0, 1 },
|
||||||
{ 0, &actor[0], sizeof(actor_t), MAXSPRITES },
|
{ 0, &actor[0], sizeof(actor_t), MAXSPRITES },
|
||||||
{ DS_SAVEFN|DS_LOADFN, (void *)&sv_postactordata, 0, 1 },
|
{ DS_SAVEFN|DS_LOADFN, (void *)&sv_postactordata, 0, 1 },
|
||||||
|
#if defined LUNATIC
|
||||||
|
{ DS_LOADFN|DS_NOCHK, (void *)&sv_create_lua_state, 0, 1 },
|
||||||
|
#endif
|
||||||
{ DS_END, 0, 0, 0 }
|
{ DS_END, 0, 0, 0 }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1334,11 +1347,6 @@ int32_t sv_loadsnapshot(int32_t fil, int32_t spot, savehead_t *h)
|
||||||
|
|
||||||
savegame_comprthres = h->comprthres;
|
savegame_comprthres = h->comprthres;
|
||||||
|
|
||||||
#ifdef LUNATIC
|
|
||||||
El_CreateGameState();
|
|
||||||
G_PostCreateGameState();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (spot >= 0)
|
if (spot >= 0)
|
||||||
{
|
{
|
||||||
// savegame
|
// savegame
|
||||||
|
|
Loading…
Reference in a new issue