Lunatic: in con.action and con.move, allow mixed number/string key tables.

E.g. con.action{0, 4, delay=20}; for convenience, viewtype and incval are
initialized to 1 (not 0) here.

git-svn-id: https://svn.eduke32.com/eduke32@3923 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2013-06-30 20:38:54 +00:00
parent cad7d49bd1
commit cb2edcf45e
3 changed files with 44 additions and 13 deletions

View file

@ -67,7 +67,10 @@ local literal_act = { [0]=con_action_ct(0), [1]=con_action_ct(1) }
local literal_mov = { [0]=con_move_ct(0), [1]=con_move_ct(1) } local literal_mov = { [0]=con_move_ct(0), [1]=con_move_ct(1) }
local literal_am = { action=literal_act, move=literal_mov } local literal_am = { action=literal_act, move=literal_mov }
local am_ctype = { action=con_action_ct, move=con_move_ct } -- Const-qualified 'full' action and move (with ID):
local am_ctype_full_const = { action=con_action_ct, move=con_move_ct }
-- Non-const-qualified 'bare' action and move (without ID):
local am_ctype_bare = { action=ffi.typeof("struct action"), move=ffi.typeof("struct move") }
local function def_action_or_move(what, tab) local function def_action_or_move(what, tab)
if (lastid[what] <= -(2^31)) then if (lastid[what] <= -(2^31)) then
@ -76,18 +79,44 @@ local function def_action_or_move(what, tab)
bcheck.top_level(what, 4) bcheck.top_level(what, 4)
if (type(tab) ~= "table") then -- NOTE: tab[0]~=nil check for "Special default values" below.
if (type(tab) ~= "table" or tab[0]~=nil) then
error("invalid argument to con."..what..": must be a table", 3) error("invalid argument to con."..what..": must be a table", 3)
end end
-- Pass args table to ffi.new, which can take either: a table with numeric
-- indices, or a table with key-value pairs, *but not in combination*.
-- See http://luajit.org/ext_ffi_semantics.html#init_table
local am = am_ctype_bare[what](tab)
-- Now, set all string keys as they have been ignored if tab[1] was
-- non-nil.
for key, val in pairs(tab) do
if (type(key)=="string") then
am[key] = val
end
end
if (what=="action") then
-- Special default values
if (tab[2]==nil and tab.numframes==nil) then
am.numframes = 1
end
if (tab[3]==nil and tab.viewtype==nil) then
am.viewtype = 1
end
if (tab[4]==nil and tab.incval==nil) then
am.incval = 1
end
end
-- Named actions or moves have negative ids so that non-negative ones -- Named actions or moves have negative ids so that non-negative ones
-- can be used as (different) placeholders for all-zero ones. -- can be used as (different) placeholders for all-zero ones.
lastid[what] = lastid[what]-1 lastid[what] = lastid[what]-1
-- Pass args table to ffi.new, which can take either: a table with numeric return am_ctype_full_const[what](lastid[what], am)
-- indices, or a table with key-value pairs, *but not in combination*.
-- See http://luajit.org/ext_ffi_semantics.html#init_table
return am_ctype[what](lastid[what], tab)
end end
---=== ACTION/MOVE/AI FUNCTIONS ===--- ---=== ACTION/MOVE/AI FUNCTIONS ===---
@ -104,7 +133,7 @@ end
local function get_action_or_move(what, val, argi) local function get_action_or_move(what, val, argi)
if (val == nil) then if (val == nil) then
return literal_am[what][0] return literal_am[what][0]
elseif (ffi.istype(am_ctype[what], val)) then elseif (ffi.istype(am_ctype_full_const[what], val)) then
return val return val
elseif (type(val)=="number") then elseif (type(val)=="number") then
if (val==0 or val==1) then if (val==0 or val==1) then
@ -1266,6 +1295,7 @@ local function cossinb(bang)
return xmath.cosb(bang), xmath.sinb(bang) return xmath.cosb(bang), xmath.sinb(bang)
end end
-- TODO: xmath.vec3 'mhlen2' method?
local function manhatdist(v1, v2) local function manhatdist(v1, v2)
return abs(v1.x-v2.x) + abs(v1.y-v2.y) return abs(v1.x-v2.x) + abs(v1.y-v2.y)
end end

View file

@ -218,9 +218,11 @@ typedef struct {
uint8_t xpanning, ypanning; uint8_t xpanning, ypanning;
const uint8_t filler; const uint8_t filler;
float alpha; float alpha;
union { // NOTE: const aggregate fixed with LuaJIT git fe9934feea0a8d580de1
const intptr_t _tspr; // ("FFI: Fix handling of qualified transparent structs/unions.")
struct { const int32_t _dummy0, _dummy1; }; const union {
intptr_t _tspr;
struct { int32_t _dummy0, _dummy1; };
}; };
} spriteext_t; } spriteext_t;

View file

@ -466,9 +466,8 @@ gameactor
{ {
1275, -- newspaper, E4L6 sprite #513 1275, -- newspaper, E4L6 sprite #513
-- XXX: I want to write "{0, 4, delay=20}" action = con.action{0, 4, delay=20}, -- Same as {0, 4, 1, 1, 20}
action = con.action{0, 4, 1, 1, 20}, move = 1, -- so that the ID is nonzero and it will move
move = con.move{}, -- so that the ID is nonzero and it will move
func = function(aci) func = function(aci)
local a = actor[aci] local a = actor[aci]