mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 11:10:39 +00:00
Lunatic: use bcarray types to guard accesses to arrays inside structs.
git-svn-id: https://svn.eduke32.com/eduke32@3435 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
ddc2104065
commit
ba8c6e487d
4 changed files with 39 additions and 39 deletions
|
@ -155,7 +155,8 @@ ifneq (0,$(LUNATIC))
|
||||||
$(OBJ)/luaJIT_BC_randgen.$o \
|
$(OBJ)/luaJIT_BC_randgen.$o \
|
||||||
$(OBJ)/luaJIT_BC_stat.$o \
|
$(OBJ)/luaJIT_BC_stat.$o \
|
||||||
$(OBJ)/luaJIT_BC_bitar.$o \
|
$(OBJ)/luaJIT_BC_bitar.$o \
|
||||||
$(OBJ)/luaJIT_BC_control.$o
|
$(OBJ)/luaJIT_BC_control.$o \
|
||||||
|
$(OBJ)/luaJIT_BC_bcarray.$o
|
||||||
|
|
||||||
# now, take care of having the necessary symbols (sector, wall, etc.) in the
|
# now, take care of having the necessary symbols (sector, wall, etc.) in the
|
||||||
# executable no matter what the debugging level
|
# executable no matter what the debugging level
|
||||||
|
|
|
@ -441,8 +441,8 @@ local PlayerLabels = {
|
||||||
last_extra = PL".last_extra",
|
last_extra = PL".last_extra",
|
||||||
subweapon = PL".subweapon",
|
subweapon = PL".subweapon",
|
||||||
|
|
||||||
max_ammo_amount = { PL":get_max_ammo_amount(%s)" },
|
max_ammo_amount = PL".max_ammo_amount[%s]" ,
|
||||||
ammo_amount = { PL":get_ammo_amount(%s)" },
|
ammo_amount = PL".ammo_amount[%s]" ,
|
||||||
-- NOTE: no direct access for .inv_amount (but see end)
|
-- NOTE: no direct access for .inv_amount (but see end)
|
||||||
|
|
||||||
wackedbyactor = PL".wackedbyactor",
|
wackedbyactor = PL".wackedbyactor",
|
||||||
|
@ -487,7 +487,7 @@ local PlayerLabels = {
|
||||||
|
|
||||||
last_pissed_time = PL".last_pissed_time",
|
last_pissed_time = PL".last_pissed_time",
|
||||||
|
|
||||||
weaprecs = { PL".weaprecs" },
|
weaprecs = PL".weaprecs[%s]" ,
|
||||||
|
|
||||||
weapon_sway = PL".weapon_sway",
|
weapon_sway = PL".weapon_sway",
|
||||||
crack_time = PL".crack_time",
|
crack_time = PL".crack_time",
|
||||||
|
@ -584,17 +584,17 @@ local PlayerLabels = {
|
||||||
name = {},
|
name = {},
|
||||||
|
|
||||||
-- Access to .inv_amount
|
-- Access to .inv_amount
|
||||||
steroids_amount = { PL":get_inv_amount(0)", },
|
steroids_amount = PL".inv_amount[0]",
|
||||||
shield_amount = { PL":get_inv_amount(1)", },
|
shield_amount = PL".inv_amount[1]",
|
||||||
scuba_amount = { PL":get_inv_amount(2)", },
|
scuba_amount = PL".inv_amount[2]",
|
||||||
holoduke_amount = { PL":get_inv_amount(3)", },
|
holoduke_amount = PL".inv_amount[3]",
|
||||||
jetpack_amount = { PL":get_inv_amount(4)", },
|
jetpack_amount = PL".inv_amount[4]",
|
||||||
-- 5: dummy
|
-- 5: dummy
|
||||||
-- 6: no "access_amount"
|
-- 6: no "access_amount"
|
||||||
heat_amount = { PL":get_inv_amount(7)" },
|
heat_amount = PL".inv_amount[7]",
|
||||||
-- 8: dummy
|
-- 8: dummy
|
||||||
firstaid_amount = { PL":get_inv_amount(9)" },
|
firstaid_amount = PL".inv_amount[9]",
|
||||||
boot_amount = { PL":get_inv_amount(10)" },
|
boot_amount = PL".inv_amount[10]",
|
||||||
}
|
}
|
||||||
|
|
||||||
local SEC = function(memb) return "sector[%s]"..memb end
|
local SEC = function(memb) return "sector[%s]"..memb end
|
||||||
|
|
|
@ -152,6 +152,13 @@ local ACTOR_STRUCT = [[
|
||||||
}
|
}
|
||||||
]]
|
]]
|
||||||
|
|
||||||
|
local bcarray = require("bcarray")
|
||||||
|
|
||||||
|
-- TODO: randomize member names
|
||||||
|
bcarray.new("int16_t", 64, "loogie", "int16_x_64")
|
||||||
|
bcarray.new("int16_t", ffiC.MAX_WEAPONS, "weapon", "int16_x_MAX_WEAPONS")
|
||||||
|
bcarray.new("int16_t", ffiC.GET_MAX, "inventory", "int16_x_GET_MAX")
|
||||||
|
|
||||||
local DUKEPLAYER_STRUCT = [[
|
local DUKEPLAYER_STRUCT = [[
|
||||||
{
|
{
|
||||||
vec3_t pos, opos, vel, npos;
|
vec3_t pos, opos, vel, npos;
|
||||||
|
@ -172,16 +179,16 @@ local DUKEPLAYER_STRUCT = [[
|
||||||
uint16_t max_actors_killed, actors_killed;
|
uint16_t max_actors_killed, actors_killed;
|
||||||
uint16_t gotweapon, zoom;
|
uint16_t gotweapon, zoom;
|
||||||
|
|
||||||
const int16_t loogiex[64];
|
int16_x_64 loogiex;
|
||||||
const int16_t loogiey[64];
|
int16_x_64 loogiey;
|
||||||
int16_t sbs, sound_pitch;
|
int16_t sbs, sound_pitch;
|
||||||
|
|
||||||
int16_t ang, oang, angvel;
|
int16_t ang, oang, angvel;
|
||||||
const int16_t cursectnum;
|
const int16_t cursectnum;
|
||||||
int16_t look_ang, last_extra, subweapon;
|
int16_t look_ang, last_extra, subweapon;
|
||||||
const int16_t max_ammo_amount[MAX_WEAPONS];
|
int16_x_MAX_WEAPONS max_ammo_amount;
|
||||||
const int16_t ammo_amount[MAX_WEAPONS];
|
int16_x_MAX_WEAPONS ammo_amount;
|
||||||
const int16_t inv_amount[GET_MAX];
|
int16_x_GET_MAX inv_amount;
|
||||||
int16_t wackedbyactor, pyoff, opyoff;
|
int16_t wackedbyactor, pyoff, opyoff;
|
||||||
|
|
||||||
int16_t horiz, horizoff, ohoriz, ohorizoff;
|
int16_t horiz, horizoff, ohoriz, ohorizoff;
|
||||||
|
@ -199,7 +206,7 @@ local DUKEPLAYER_STRUCT = [[
|
||||||
const int16_t customexitsound;
|
const int16_t customexitsound;
|
||||||
int16_t last_pissed_time;
|
int16_t last_pissed_time;
|
||||||
|
|
||||||
const int16_t weaprecs[MAX_WEAPONS];
|
int16_x_MAX_WEAPONS weaprecs;
|
||||||
int16_t weapon_sway, crack_time, bobcounter;
|
int16_t weapon_sway, crack_time, bobcounter;
|
||||||
|
|
||||||
int16_t orotscrnang, rotscrnang, dead_flag; // JBF 20031220: added orotscrnang
|
int16_t orotscrnang, rotscrnang, dead_flag; // JBF 20031220: added orotscrnang
|
||||||
|
@ -257,10 +264,9 @@ local function ma_replace_array(typestr, neltstr)
|
||||||
local strtab = { "const ", typestr.." " }
|
local strtab = { "const ", typestr.." " }
|
||||||
for i=1,nelts do
|
for i=1,nelts do
|
||||||
local ch1 = 97 + (ma_rand:getu32() % 25) -- 'a'..'z'
|
local ch1 = 97 + (ma_rand:getu32() % 25) -- 'a'..'z'
|
||||||
strtab[i+2] = string.format("_%c%x%s", ch1, ma_count, (i<nelts) and "," or "")
|
strtab[i+2] = string.format("_%c%x%s", ch1, ma_count, (i<nelts) and "," or ";")
|
||||||
ma_count = ma_count+1
|
ma_count = ma_count+1
|
||||||
end
|
end
|
||||||
strtab[#strtab+1] = ";"
|
|
||||||
|
|
||||||
return table.concat(strtab)
|
return table.concat(strtab)
|
||||||
end
|
end
|
||||||
|
@ -818,38 +824,31 @@ local player_mt = {
|
||||||
__index = {
|
__index = {
|
||||||
--- Getters/setters
|
--- Getters/setters
|
||||||
get_ammo_amount = function(p, weap)
|
get_ammo_amount = function(p, weap)
|
||||||
check_weapon_idx(weap)
|
return p.ammo_amount[weap]
|
||||||
return ffi.cast(player_ptr_ct, p).ammo_amount[weap]
|
|
||||||
end,
|
end,
|
||||||
|
|
||||||
set_ammo_amount = function(p, weap, amount)
|
set_ammo_amount = function(p, weap, amount)
|
||||||
check_weapon_idx(weap)
|
p.ammo_amount[weap] = amount
|
||||||
ffi.cast(player_ptr_ct, p).ammo_amount[weap] = amount
|
|
||||||
end,
|
end,
|
||||||
|
|
||||||
get_max_ammo_amount = function(p, weap)
|
get_max_ammo_amount = function(p, weap)
|
||||||
check_weapon_idx(weap)
|
return p.max_ammo_amount[weap]
|
||||||
return ffi.cast(player_ptr_ct, p).max_ammo_amount[weap]
|
|
||||||
end,
|
end,
|
||||||
|
|
||||||
set_max_ammo_amount = function(p, weap, amount)
|
set_max_ammo_amount = function(p, weap, amount)
|
||||||
check_weapon_idx(weap)
|
p.max_ammo_amount[weap] = amount
|
||||||
ffi.cast(player_ptr_ct, p).max_ammo_amount[weap] = amount
|
|
||||||
end,
|
end,
|
||||||
|
|
||||||
set_curr_weapon = function(p, weap)
|
set_curr_weapon = function(p, weap)
|
||||||
check_weapon_idx(weap)
|
p.curr_weapon = weap
|
||||||
ffi.cast(player_ptr_ct, p).curr_weapon = weap
|
|
||||||
end,
|
end,
|
||||||
|
|
||||||
get_inv_amount = function(p, inv)
|
get_inv_amount = function(p, inv)
|
||||||
check_inventory_idx(inv)
|
return p.inv_amount[inv]
|
||||||
return ffi.cast(player_ptr_ct, p).inv_amount[inv]
|
|
||||||
end,
|
end,
|
||||||
|
|
||||||
set_inv_amount = function(p, inv, amount)
|
set_inv_amount = function(p, inv, amount)
|
||||||
check_inventory_idx(inv)
|
p.inv_amount[inv] = amount
|
||||||
ffi.cast(player_ptr_ct, p).inv_amount[inv] = amount
|
|
||||||
end,
|
end,
|
||||||
|
|
||||||
set_customexitsound = function(p, soundnum)
|
set_customexitsound = function(p, soundnum)
|
||||||
|
@ -902,10 +901,9 @@ local camera_mt = {
|
||||||
end
|
end
|
||||||
ffiC.g_camera[key] = val
|
ffiC.g_camera[key] = val
|
||||||
end,
|
end,
|
||||||
__metatable = true
|
|
||||||
}
|
}
|
||||||
|
|
||||||
gv_access.cam = setmetatable({}, camera_mt)
|
gv_access.cam = setmtonce({}, camera_mt)
|
||||||
|
|
||||||
function gv_access._currentFramerate()
|
function gv_access._currentFramerate()
|
||||||
return ffiC.g_currentFrameRate
|
return ffiC.g_currentFrameRate
|
||||||
|
@ -964,11 +962,10 @@ for modname, themodule in pairs(allowed_modules) do
|
||||||
__newindex = function(tab,idx,val)
|
__newindex = function(tab,idx,val)
|
||||||
error("modifying base module table forbidden", 2)
|
error("modifying base module table forbidden", 2)
|
||||||
end,
|
end,
|
||||||
__metatable = true,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
-- Comment out to make base modules not protected:
|
-- Comment out to make base modules not protected:
|
||||||
allowed_modules[modname] = setmetatable({}, mt)
|
allowed_modules[modname] = setmtonce({}, mt)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function check_valid_modname(modname, errlev)
|
local function check_valid_modname(modname, errlev)
|
||||||
|
@ -1165,7 +1162,7 @@ local function our_gameactor(tilenum, ...)
|
||||||
if (#args == 0) then
|
if (#args == 0) then
|
||||||
error("invalid call to gameactor: must have at least two arguments (tilenum, func)", 2)
|
error("invalid call to gameactor: must have at least two arguments (tilenum, func)", 2)
|
||||||
end
|
end
|
||||||
if (#args > 6) then
|
if (#args > 5) then
|
||||||
error("invalid call to gameactor: must have at most six arguments", 2)
|
error("invalid call to gameactor: must have at most six arguments", 2)
|
||||||
end
|
end
|
||||||
if (type(args[#args]) ~= "function") then
|
if (type(args[#args]) ~= "function") then
|
||||||
|
|
|
@ -250,6 +250,8 @@ gameevent(gv.EVENT_ENTERLEVEL,
|
||||||
printf("sqrt(0xffffffff) = %f(ksqrt) %f(math.sqrt)",
|
printf("sqrt(0xffffffff) = %f(ksqrt) %f(math.sqrt)",
|
||||||
gv.ksqrt(0xffffffff), math.sqrt(0xffffffff))
|
gv.ksqrt(0xffffffff), math.sqrt(0xffffffff))
|
||||||
|
|
||||||
|
player[0].max_ammo_amount[gv.RPG_WEAPON] = 17
|
||||||
|
|
||||||
checkfail("gameevent('GAME', function() print('qwe') end)",
|
checkfail("gameevent('GAME', function() print('qwe') end)",
|
||||||
"must be called from top level")
|
"must be called from top level")
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue