mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-27 09:20:51 +00:00
Lunatic savegames: store g_playerWeapon[][], fix 'require' with submodules.
git-svn-id: https://svn.eduke32.com/eduke32@3883 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
4a49da94c1
commit
d43cfe6232
4 changed files with 26 additions and 7 deletions
|
@ -1,6 +1,7 @@
|
||||||
-- Bound-checking functions for engine and game "things".
|
-- Bound-checking functions for engine and game "things".
|
||||||
|
|
||||||
local ffiC = require("ffi").C
|
local ffiC = require("ffi").C
|
||||||
|
local type = type
|
||||||
local error = error
|
local error = error
|
||||||
|
|
||||||
local con_lang = require("con_lang")
|
local con_lang = require("con_lang")
|
||||||
|
@ -97,5 +98,10 @@ function bcheck.top_level(funcname)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function bcheck.number(val)
|
||||||
|
if (type(val)~="number") then
|
||||||
|
error("invalid argument: must be a number", 3)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
return bcheck
|
return bcheck
|
||||||
|
|
|
@ -178,6 +178,7 @@ local check_sector_idx, check_tile_idx = bcheck.sector_idx, bcheck.tile_idx
|
||||||
local check_sprite_idx = bcheck.sprite_idx
|
local check_sprite_idx = bcheck.sprite_idx
|
||||||
local check_weapon_idx, check_inventory_idx = bcheck.weapon_idx, bcheck.inventory_idx
|
local check_weapon_idx, check_inventory_idx = bcheck.weapon_idx, bcheck.inventory_idx
|
||||||
local check_sound_idx = bcheck.sound_idx
|
local check_sound_idx = bcheck.sound_idx
|
||||||
|
local check_number = bcheck.number
|
||||||
|
|
||||||
bcarray.new("int16_t", 64, "loogie", "int16_x_64") -- TODO: randomize member names
|
bcarray.new("int16_t", 64, "loogie", "int16_x_64") -- TODO: randomize member names
|
||||||
bcarray.new("int16_t", ffiC.MAX_WEAPONS, "weapon", "int16_x_MAX_WEAPONS", WEAPON_NAMES)
|
bcarray.new("int16_t", ffiC.MAX_WEAPONS, "weapon", "int16_x_MAX_WEAPONS", WEAPON_NAMES)
|
||||||
|
@ -1082,6 +1083,8 @@ local weapondata_mt = {
|
||||||
-- Set to 'true' if we set a tile or sound member.
|
-- Set to 'true' if we set a tile or sound member.
|
||||||
local didit = false
|
local didit = false
|
||||||
|
|
||||||
|
check_number(val)
|
||||||
|
|
||||||
if (string.match(member, "sound")) then
|
if (string.match(member, "sound")) then
|
||||||
if (val < 0) then
|
if (val < 0) then
|
||||||
val = 0 -- Set to 0 if oob (e.g. CrackDown).
|
val = 0 -- Set to 0 if oob (e.g. CrackDown).
|
||||||
|
@ -1896,7 +1899,8 @@ do
|
||||||
|
|
||||||
-- XXX: System gamevars?
|
-- XXX: System gamevars?
|
||||||
for modname, modvars in pairs(module_gamevars) do
|
for modname, modvars in pairs(module_gamevars) do
|
||||||
sb:addrawf("M=require%q", modname)
|
-- NOTE: when emitting 'require' code, reverse '.' -> '/' substitution.
|
||||||
|
sb:addrawf("M=require%q", modname:gsub("/","."))
|
||||||
for i=1,#modvars do
|
for i=1,#modvars do
|
||||||
local varname = modvars[i]
|
local varname = modvars[i]
|
||||||
-- Serialize gamevar named 'varname' from module named 'modname'.
|
-- Serialize gamevar named 'varname' from module named 'modname'.
|
||||||
|
|
|
@ -221,6 +221,8 @@ gameevent
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local D = require("CON.DEFS")
|
||||||
|
|
||||||
-- test event chaining
|
-- test event chaining
|
||||||
gameevent
|
gameevent
|
||||||
{
|
{
|
||||||
|
@ -232,8 +234,13 @@ gameevent
|
||||||
local ps = player[playeri]
|
local ps = player[playeri]
|
||||||
print("\n--- I'm first!")
|
print("\n--- I'm first!")
|
||||||
-- DBG_.oom()
|
-- DBG_.oom()
|
||||||
ps.weapon.PISTOL.shoots = 2605 -- RPG
|
local pistol = ps.weapon.PISTOL
|
||||||
ps.weapon[gv.PISTOL_WEAPON].firesound = 351 -- thunder
|
if (pistol.shoots ~= D.RPG) then
|
||||||
|
pistol.shoots = D.RPG
|
||||||
|
else
|
||||||
|
pistol.shoots = D.SHOTSPARK1
|
||||||
|
end
|
||||||
|
ps.weapon[gv.PISTOL_WEAPON].firesound = D.LIGHTNING_SLAP
|
||||||
|
|
||||||
-- XXX: provide either named constants or methods?
|
-- XXX: provide either named constants or methods?
|
||||||
ps.pipebombControl = 2
|
ps.pipebombControl = 2
|
||||||
|
@ -307,7 +314,7 @@ gameevent
|
||||||
player[0].weapon.SHOTGUN.shoots = 1653
|
player[0].weapon.SHOTGUN.shoots = 1653
|
||||||
local proj = projectile[1653]
|
local proj = projectile[1653]
|
||||||
proj.drop = 0
|
proj.drop = 0
|
||||||
proj:set_trail(2329) -- SMALLSMOKE
|
proj:set_trail(D.SMALLSMOKE)
|
||||||
|
|
||||||
t = gv.gethitickms()
|
t = gv.gethitickms()
|
||||||
local N=1
|
local N=1
|
||||||
|
@ -333,6 +340,7 @@ gameevent
|
||||||
-- N=100: about 160 us * 100 = about 16 ms
|
-- N=100: about 160 us * 100 = about 16 ms
|
||||||
|
|
||||||
-- Make the DUKECAR in E1L1 into a zombie actor (temporarily)
|
-- Make the DUKECAR in E1L1 into a zombie actor (temporarily)
|
||||||
|
-- NOTE: Use static value (not the one from 'D').
|
||||||
if (sprite[24].picnum==2491) then
|
if (sprite[24].picnum==2491) then
|
||||||
sprite.changestat(24, actor.STAT.ZOMBIEACTOR)
|
sprite.changestat(24, actor.STAT.ZOMBIEACTOR)
|
||||||
end
|
end
|
||||||
|
@ -392,7 +400,6 @@ con.ai("AITEMP", "TROOPFLINTCH", "SHRUNKVELS", 0)
|
||||||
|
|
||||||
local TROOPSTRENGTH = 30
|
local TROOPSTRENGTH = 30
|
||||||
|
|
||||||
local D = require("CON.DEFS")
|
|
||||||
local AF = actor.FLAGS
|
local AF = actor.FLAGS
|
||||||
local CS = sprite.CSTAT
|
local CS = sprite.CSTAT
|
||||||
|
|
||||||
|
@ -505,7 +512,7 @@ gameevent
|
||||||
|
|
||||||
function(aci)
|
function(aci)
|
||||||
local tspr = atsprite[aci]
|
local tspr = atsprite[aci]
|
||||||
if (tspr:getspr().picnum==1680) then
|
if (tspr:getspr().picnum==D.LIZTROOP) then
|
||||||
local tspr2 = tspr:dup()
|
local tspr2 = tspr:dup()
|
||||||
if (tspr2) then
|
if (tspr2) then
|
||||||
tspr2.x = tspr2.x + 512*math.cos(gv.totalclock/60)
|
tspr2.x = tspr2.x + 512*math.cos(gv.totalclock/60)
|
||||||
|
|
|
@ -1038,7 +1038,9 @@ static const dataspec_t svgm_anmisc[] =
|
||||||
{ DS_NOCHK|DS_DYNAMIC|DS_CNT(g_numQuoteRedefinitions), &savegame_quoteredefs, MAXQUOTELEN, (intptr_t)&g_numQuoteRedefinitions },
|
{ DS_NOCHK|DS_DYNAMIC|DS_CNT(g_numQuoteRedefinitions), &savegame_quoteredefs, MAXQUOTELEN, (intptr_t)&g_numQuoteRedefinitions },
|
||||||
{ DS_NOCHK|DS_LOADFN, (void *)&sv_quoteredefload, 0, 1 },
|
{ DS_NOCHK|DS_LOADFN, (void *)&sv_quoteredefload, 0, 1 },
|
||||||
{ DS_NOCHK|DS_SAVEFN|DS_LOADFN, (void *)&sv_postquoteredef, 0, 1 },
|
{ DS_NOCHK|DS_SAVEFN|DS_LOADFN, (void *)&sv_postquoteredef, 0, 1 },
|
||||||
|
#ifdef LUNATIC
|
||||||
|
{ 0, g_playerWeapon, sizeof(weapondata_t), MAXPLAYERS*MAX_WEAPONS },
|
||||||
|
#endif
|
||||||
{ DS_SAVEFN, (void *)&sv_restsave, 0, 1 },
|
{ DS_SAVEFN, (void *)&sv_restsave, 0, 1 },
|
||||||
{ 0, savegame_restdata, 1, sizeof(savegame_restdata) }, // sz/cnt swapped for kdfread
|
{ 0, savegame_restdata, 1, sizeof(savegame_restdata) }, // sz/cnt swapped for kdfread
|
||||||
{ DS_LOADFN, (void *)&sv_restload, 0, 1 },
|
{ DS_LOADFN, (void *)&sv_restload, 0, 1 },
|
||||||
|
|
Loading…
Reference in a new issue