mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 19:20:38 +00:00
Lunatic: make g_playerWeapon an array of a corresponding bcarray type.
git-svn-id: https://svn.eduke32.com/eduke32@3931 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
4c4cf5eecc
commit
baebd63bac
1 changed files with 11 additions and 9 deletions
|
@ -576,6 +576,8 @@ typedef struct {
|
||||||
} map_t;
|
} map_t;
|
||||||
]])
|
]])
|
||||||
|
|
||||||
|
bcarray.new("weapondata_t", ffiC.MAX_WEAPONS, "weapon", "weapondata_x_MAX_WEAPONS", WEAPON_NAMES)
|
||||||
|
|
||||||
-- EXTERNALLY EXPOSED GAME VARIABLES
|
-- EXTERNALLY EXPOSED GAME VARIABLES
|
||||||
ffi.cdef[[
|
ffi.cdef[[
|
||||||
const int32_t screenpeek;
|
const int32_t screenpeek;
|
||||||
|
@ -610,7 +612,7 @@ camera_t g_camera;
|
||||||
user_defs ud;
|
user_defs ud;
|
||||||
playerdata_t g_player[MAXPLAYERS];
|
playerdata_t g_player[MAXPLAYERS];
|
||||||
DukePlayer_t *g_player_ps[MAXPLAYERS];
|
DukePlayer_t *g_player_ps[MAXPLAYERS];
|
||||||
weapondata_t g_playerWeapon[MAXPLAYERS][MAX_WEAPONS];
|
weapondata_x_MAX_WEAPONS g_playerWeapon[MAXPLAYERS];
|
||||||
weapondata_t g_weaponOverridden[MAX_WEAPONS];
|
weapondata_t g_weaponOverridden[MAX_WEAPONS];
|
||||||
tiledata_t g_tile[MAXTILES];
|
tiledata_t g_tile[MAXTILES];
|
||||||
projectile_t ProjectileData[MAXTILES];
|
projectile_t ProjectileData[MAXTILES];
|
||||||
|
@ -1113,7 +1115,6 @@ local actor_mt = {
|
||||||
end,
|
end,
|
||||||
|
|
||||||
-- Getters/setters.
|
-- Getters/setters.
|
||||||
-- TODO: make a bcarray instead.
|
|
||||||
_get_t_data = function(a, idx)
|
_get_t_data = function(a, idx)
|
||||||
if (idx >= 10ULL) then
|
if (idx >= 10ULL) then
|
||||||
error("invalid t_data index "..idx, 2)
|
error("invalid t_data index "..idx, 2)
|
||||||
|
@ -1224,7 +1225,8 @@ local weapondata_mt = {
|
||||||
-- Signal that we overrode this member at CON translation time.
|
-- Signal that we overrode this member at CON translation time.
|
||||||
|
|
||||||
-- Get weapon index as pointer difference first. PLAYER_0.
|
-- Get weapon index as pointer difference first. PLAYER_0.
|
||||||
local wi = ffi.cast(weapondata_ptr_ct, wd)-ffi.cast(weapondata_ptr_ct, ffiC.g_playerWeapon[0][0])
|
local wi = ffi.cast(weapondata_ptr_ct, wd)
|
||||||
|
- ffi.cast(weapondata_ptr_ct, ffiC.g_playerWeapon)
|
||||||
assert(not (wi >= ffiC.MAX_WEAPONS+0ULL))
|
assert(not (wi >= ffiC.MAX_WEAPONS+0ULL))
|
||||||
|
|
||||||
-- Set g_weaponOverridden[wi][member], but without invoking
|
-- Set g_weaponOverridden[wi][member], but without invoking
|
||||||
|
@ -1236,15 +1238,15 @@ local weapondata_mt = {
|
||||||
ffi.metatype("weapondata_t", weapondata_mt)
|
ffi.metatype("weapondata_t", weapondata_mt)
|
||||||
|
|
||||||
local weaponaccess_mt = {
|
local weaponaccess_mt = {
|
||||||
-- Make syntax like "player[0].weapon.KNEE.shoots" possible
|
-- Syntax like "player[0].weapon.KNEE.shoots" possible because
|
||||||
|
-- g_playerWeapon[] is declared as an array of corresponding bcarray types
|
||||||
|
-- for us.
|
||||||
__index = function(wa, key)
|
__index = function(wa, key)
|
||||||
if (type(key)=="number") then
|
if (type(key)~="number" and type(key)~="string") then
|
||||||
check_weapon_idx(key)
|
error("must access weapon either by number or by name")
|
||||||
return ffiC.g_playerWeapon[wa._p][key]
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- TODO: use bcarray?
|
return ffiC.g_playerWeapon[wa._p][key]
|
||||||
return ffiC.g_playerWeapon[wa._p][ffiC[key.."_WEAPON"]]
|
|
||||||
end,
|
end,
|
||||||
}
|
}
|
||||||
ffi.metatype("weaponaccess_t", weaponaccess_mt)
|
ffi.metatype("weaponaccess_t", weaponaccess_mt)
|
||||||
|
|
Loading…
Reference in a new issue