mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Lunatic: rotatesprite+test, player access, misc.
git-svn-id: https://svn.eduke32.com/eduke32@2923 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
df591aba1c
commit
e9095c8470
11 changed files with 131 additions and 24 deletions
|
@ -2768,7 +2768,10 @@ void G_DisplayRest(int32_t smoothratio)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef LUNATIC
|
||||||
|
// TODO: get rid of the other outer apScriptGameEvent checks, too
|
||||||
if (apScriptGameEvent[EVENT_DISPLAYREST])
|
if (apScriptGameEvent[EVENT_DISPLAYREST])
|
||||||
|
#endif
|
||||||
VM_OnEvent(EVENT_DISPLAYREST, g_player[screenpeek].ps->i, screenpeek, -1, 0);
|
VM_OnEvent(EVENT_DISPLAYREST, g_player[screenpeek].ps->i, screenpeek, -1, 0);
|
||||||
|
|
||||||
if (g_player[myconnectindex].ps->newowner == -1 && ud.overhead_on == 0 && ud.crosshair && ud.camerasprite == -1)
|
if (g_player[myconnectindex].ps->newowner == -1 && ud.overhead_on == 0 && ud.crosshair && ud.camerasprite == -1)
|
||||||
|
|
|
@ -102,9 +102,7 @@ int32_t VM_OnEvent(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t lD
|
||||||
if (El_IsInitialized(&g_ElState) && El_HaveEvent(iEventID))
|
if (El_IsInitialized(&g_ElState) && El_HaveEvent(iEventID))
|
||||||
El_CallEvent(&g_ElState, iEventID, iActor, iPlayer, lDist);
|
El_CallEvent(&g_ElState, iEventID, iActor, iPlayer, lDist);
|
||||||
#endif
|
#endif
|
||||||
if (!apScriptGameEvent[iEventID])
|
if (apScriptGameEvent[iEventID])
|
||||||
return iReturn;
|
|
||||||
|
|
||||||
{
|
{
|
||||||
intptr_t *oinsptr=insptr;
|
intptr_t *oinsptr=insptr;
|
||||||
vmstate_t vm_backup;
|
vmstate_t vm_backup;
|
||||||
|
@ -141,13 +139,13 @@ int32_t VM_OnEvent(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t lD
|
||||||
g_currentEventExec = backupEventExec;
|
g_currentEventExec = backupEventExec;
|
||||||
iReturn = aGameVars[g_iReturnVarID].val.lValue;
|
iReturn = aGameVars[g_iReturnVarID].val.lValue;
|
||||||
aGameVars[g_iReturnVarID].val.lValue = backupReturnVar;
|
aGameVars[g_iReturnVarID].val.lValue = backupReturnVar;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef LUNATIC
|
#ifdef LUNATIC
|
||||||
g_eventTotalMs[iEventID] += gethitickms()-t;
|
g_eventTotalMs[iEventID] += gethitickms()-t;
|
||||||
g_eventCalls[iEventID]++;
|
g_eventCalls[iEventID]++;
|
||||||
#endif
|
#endif
|
||||||
return iReturn;
|
return iReturn;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int32_t VM_CheckSquished(void)
|
static inline int32_t VM_CheckSquished(void)
|
||||||
|
|
|
@ -1,6 +1,9 @@
|
||||||
-- Game control module for Lunatic.
|
-- Game control module for Lunatic.
|
||||||
|
|
||||||
local ffi = require("ffi")
|
local ffi = require("ffi")
|
||||||
|
local ffiC = ffi.C
|
||||||
|
|
||||||
|
local bit = require("bit")
|
||||||
|
|
||||||
local setmetatable = setmetatable
|
local setmetatable = setmetatable
|
||||||
|
|
||||||
|
@ -98,3 +101,16 @@ function ai(name, action, move, flags)
|
||||||
|
|
||||||
def.ai[name] = ffi.new("const con_ai_t", lastid.ai, act, mov, flags)
|
def.ai[name] = ffi.new("const con_ai_t", lastid.ai, act, mov, flags)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--== RUNTIME CON FUNCTIONS ==--
|
||||||
|
|
||||||
|
function rotatesprite(x, y, zoom, ang, tilenum, shade, pal, orientation,
|
||||||
|
cx1, cy1, cx2, cy2)
|
||||||
|
if (type(tilenum) ~= "number" or not (tilenum >= 0 and tilenum < ffiC.MAXTILES)) then
|
||||||
|
error("bad argument #5 to rotatesprite: must be number in [0.."..ffiC.MAXTILES.."]")
|
||||||
|
end
|
||||||
|
|
||||||
|
ffiC.rotatesprite(65536*x, 65536*y, zoom, ang, tilenum, shade, pal, bit.bor(2,orientation),
|
||||||
|
cx1, cy1, cx2, cy2)
|
||||||
|
end
|
||||||
|
|
|
@ -149,6 +149,7 @@ end
|
||||||
ffi.cdef[[
|
ffi.cdef[[
|
||||||
enum {
|
enum {
|
||||||
MAXSTATUS = 1024,
|
MAXSTATUS = 1024,
|
||||||
|
MAXTILES = 30720,
|
||||||
|
|
||||||
MAXBUNCHES = 256,
|
MAXBUNCHES = 256,
|
||||||
CEILING = 0,
|
CEILING = 0,
|
||||||
|
@ -162,6 +163,8 @@ enum {
|
||||||
ffi.cdef[[
|
ffi.cdef[[
|
||||||
const int16_t numsectors, numwalls;
|
const int16_t numsectors, numwalls;
|
||||||
const int32_t numyaxbunches;
|
const int32_t numyaxbunches;
|
||||||
|
const int32_t totalclock;
|
||||||
|
const int32_t xdim, ydim;
|
||||||
]]
|
]]
|
||||||
|
|
||||||
decl[[
|
decl[[
|
||||||
|
@ -175,6 +178,10 @@ int16_t yax_getbunch(int16_t i, int16_t cf);
|
||||||
|
|
||||||
int32_t hitscan(const vec3_t *sv, int16_t sectnum, int32_t vx, int32_t vy, int32_t vz,
|
int32_t hitscan(const vec3_t *sv, int16_t sectnum, int32_t vx, int32_t vy, int32_t vz,
|
||||||
hitdata_t *hitinfo, uint32_t cliptype);
|
hitdata_t *hitinfo, uint32_t cliptype);
|
||||||
|
|
||||||
|
void rotatesprite(int32_t sx, int32_t sy, int32_t z, int16_t a, int16_t picnum,
|
||||||
|
int8_t dashade, char dapalnum, int32_t dastat,
|
||||||
|
int32_t cx1, int32_t cy1, int32_t cx2, int32_t cy2);
|
||||||
]]
|
]]
|
||||||
|
|
||||||
-- array -> element flattening inside structs,
|
-- array -> element flattening inside structs,
|
||||||
|
@ -515,6 +522,8 @@ int32_t g_sizes_of[];
|
||||||
actor_t actor[MAXSPRITES];
|
actor_t actor[MAXSPRITES];
|
||||||
user_defs ud;
|
user_defs ud;
|
||||||
playerdata_t g_player[MAXPLAYERS];
|
playerdata_t g_player[MAXPLAYERS];
|
||||||
|
|
||||||
|
const int32_t playerswhenstarted;
|
||||||
]]
|
]]
|
||||||
|
|
||||||
-- functions
|
-- functions
|
||||||
|
@ -582,9 +591,9 @@ local con = require("control")
|
||||||
-- All-zero action and move
|
-- All-zero action and move
|
||||||
local nullac, nullmv = ffi.new("const struct action"), ffi.new("const struct move")
|
local nullac, nullmv = ffi.new("const struct action"), ffi.new("const struct move")
|
||||||
|
|
||||||
local function check_literal_am(am)
|
local function check_literal_am(am, typename)
|
||||||
if (type(am) ~= "number") then
|
if (type(am) ~= "number") then
|
||||||
error("bad argument: expected number", 3)
|
error("bad argument: expected number or "..typename, 3)
|
||||||
end
|
end
|
||||||
|
|
||||||
if (not (am >= 0 and am <= 32767)) then
|
if (not (am >= 0 and am <= 32767)) then
|
||||||
|
@ -606,7 +615,7 @@ local actor_mt = {
|
||||||
a.t_data[4] = act.id
|
a.t_data[4] = act.id
|
||||||
a.ac = act.ac
|
a.ac = act.ac
|
||||||
else
|
else
|
||||||
check_literal_am(act)
|
check_literal_am(act, "action")
|
||||||
a.t_data[4] = act
|
a.t_data[4] = act
|
||||||
a.ac = nullac
|
a.ac = nullac
|
||||||
end
|
end
|
||||||
|
@ -620,7 +629,7 @@ local actor_mt = {
|
||||||
if (ffi.istype(con_action_ct, act)) then
|
if (ffi.istype(con_action_ct, act)) then
|
||||||
return (a.t_data[4]==act.id)
|
return (a.t_data[4]==act.id)
|
||||||
else
|
else
|
||||||
check_literal_am(act)
|
check_literal_am(act, "action")
|
||||||
return (a.t_data[4]==act)
|
return (a.t_data[4]==act)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
@ -650,7 +659,7 @@ local actor_mt = {
|
||||||
a.t_data[1] = mov.id
|
a.t_data[1] = mov.id
|
||||||
a.mv = mov.mv
|
a.mv = mov.mv
|
||||||
else
|
else
|
||||||
check_literal_am(mov)
|
check_literal_am(mov, "move")
|
||||||
a.t_data[1] = mov
|
a.t_data[1] = mov
|
||||||
a.mv = nullmv
|
a.mv = nullmv
|
||||||
end
|
end
|
||||||
|
@ -667,7 +676,7 @@ local actor_mt = {
|
||||||
if (ffi.istype(con_move_ct, mov)) then
|
if (ffi.istype(con_move_ct, mov)) then
|
||||||
return (a.t_data[1]==mov.id)
|
return (a.t_data[1]==mov.id)
|
||||||
else
|
else
|
||||||
check_literal_am(mov)
|
check_literal_am(mov, "move")
|
||||||
return (a.t_data[1]==mov)
|
return (a.t_data[1]==mov)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
@ -678,7 +687,9 @@ local actor_mt = {
|
||||||
a = ffi.cast(actor_ptr_ct, a)
|
a = ffi.cast(actor_ptr_ct, a)
|
||||||
|
|
||||||
-- TODO: literal number AIs?
|
-- TODO: literal number AIs?
|
||||||
assert(ffi.istype(con_ai_ct, ai))
|
if (not ffi.istype(con_ai_ct, ai)) then
|
||||||
|
error("bad argument: expected ai", 2)
|
||||||
|
end
|
||||||
|
|
||||||
-- NOTE: compare with gameexec.c
|
-- NOTE: compare with gameexec.c
|
||||||
a.t_data[5] = ai.id
|
a.t_data[5] = ai.id
|
||||||
|
@ -695,7 +706,7 @@ local actor_mt = {
|
||||||
if (ffi.istype(con_ai_ct, ai)) then
|
if (ffi.istype(con_ai_ct, ai)) then
|
||||||
return (a.t_data[5]==ai.id)
|
return (a.t_data[5]==ai.id)
|
||||||
else
|
else
|
||||||
check_literal_am(ai)
|
check_literal_am(ai, "ai")
|
||||||
return (a.t_data[5]==ai)
|
return (a.t_data[5]==ai)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
@ -996,6 +1007,18 @@ local tmpmt = {
|
||||||
}
|
}
|
||||||
wall = setmtonce({}, tmpmt)
|
wall = setmtonce({}, tmpmt)
|
||||||
|
|
||||||
|
local tmpmt = {
|
||||||
|
__index = function(tab, key)
|
||||||
|
if (key >= 0 and key < ffiC.playerswhenstarted) then
|
||||||
|
return ffiC.g_player[key].ps[0]
|
||||||
|
end
|
||||||
|
error('out-of-bounds player[] read access', 2)
|
||||||
|
end,
|
||||||
|
|
||||||
|
__newindex = function(tab, key, val) error('cannot write directly to player[] struct', 2) end,
|
||||||
|
}
|
||||||
|
player = setmtonce({}, tmpmt)
|
||||||
|
|
||||||
-- create a safe indirection for an ffi.C array
|
-- create a safe indirection for an ffi.C array
|
||||||
local function creategtab(ctab, maxidx, name)
|
local function creategtab(ctab, maxidx, name)
|
||||||
local tab = {}
|
local tab = {}
|
||||||
|
|
|
@ -14,6 +14,10 @@ numsectors;
|
||||||
numwalls;
|
numwalls;
|
||||||
numyaxbunches;
|
numyaxbunches;
|
||||||
|
|
||||||
|
totalclock;
|
||||||
|
xdim;
|
||||||
|
ydim;
|
||||||
|
|
||||||
yax_getbunch;
|
yax_getbunch;
|
||||||
|
|
||||||
headspritesect;
|
headspritesect;
|
||||||
|
@ -33,11 +37,14 @@ kread;
|
||||||
|
|
||||||
ksqrt;
|
ksqrt;
|
||||||
hitscan;
|
hitscan;
|
||||||
|
rotatesprite;
|
||||||
|
|
||||||
actor;
|
actor;
|
||||||
ud;
|
ud;
|
||||||
g_player;
|
g_player;
|
||||||
|
|
||||||
|
playerswhenstarted;
|
||||||
|
|
||||||
luaJIT_BC_lunacon;
|
luaJIT_BC_lunacon;
|
||||||
luaJIT_BC_con_lang;
|
luaJIT_BC_con_lang;
|
||||||
luaJIT_BC_geom;
|
luaJIT_BC_geom;
|
||||||
|
|
|
@ -33,11 +33,14 @@ local mt = {
|
||||||
assert(type(b)=="number")
|
assert(type(b)=="number")
|
||||||
return vec2_(a.x/b, a.y/b)
|
return vec2_(a.x/b, a.y/b)
|
||||||
end,
|
end,
|
||||||
|
--[[
|
||||||
|
-- NOTE: metamethods from metatype() are invoken on *any mix of types*
|
||||||
|
-- This means that we can't check a "maybe-vec2" variable like "v ~= nil".
|
||||||
|
|
||||||
__eq = function(a,b)
|
__eq = function(a,b)
|
||||||
return (a.x==b.x and a.y==b.y)
|
return (a.x==b.x and a.y==b.y)
|
||||||
end,
|
end,
|
||||||
|
--]]
|
||||||
__len = function(a) return math.sqrt(a.x*a.x + a.y*a.y) end,
|
__len = function(a) return math.sqrt(a.x*a.x + a.y*a.y) end,
|
||||||
|
|
||||||
__tostring = function(a) return "vec2("..a.x..", "..a.y..")" end,
|
__tostring = function(a) return "vec2("..a.x..", "..a.y..")" end,
|
||||||
|
|
|
@ -55,7 +55,8 @@ local jkiss = ffi.metatype("rng_jkiss_t", mt)
|
||||||
function new(x,y,z,c)
|
function new(x,y,z,c)
|
||||||
local s
|
local s
|
||||||
if (x == nil or type(x)=="boolean") then
|
if (x == nil or type(x)=="boolean") then
|
||||||
s = jkiss(0,0,0,0) -- invalid state, must be initialized first
|
-- initialize with arbitrary but fixed state
|
||||||
|
s = jkiss(123456789, 987654321, 43219876, 6543217)
|
||||||
if (x) then
|
if (x) then
|
||||||
s:init_time_md4()
|
s:init_time_md4()
|
||||||
end
|
end
|
||||||
|
|
|
@ -12,6 +12,7 @@ module(...)
|
||||||
ffi.cdef[[
|
ffi.cdef[[
|
||||||
typedef struct {
|
typedef struct {
|
||||||
double n;
|
double n;
|
||||||
|
// vvv internal vvv
|
||||||
double m, s;
|
double m, s;
|
||||||
double min, max;
|
double min, max;
|
||||||
} runningstat_t;
|
} runningstat_t;
|
||||||
|
@ -24,6 +25,8 @@ typedef struct {
|
||||||
]]
|
]]
|
||||||
|
|
||||||
|
|
||||||
|
local NaN = 0/0
|
||||||
|
|
||||||
local res_mt = {
|
local res_mt = {
|
||||||
__tostring = function(s)
|
__tostring = function(s)
|
||||||
return
|
return
|
||||||
|
@ -68,9 +71,14 @@ local mt = {
|
||||||
end,
|
end,
|
||||||
|
|
||||||
getstats = function(s)
|
getstats = function(s)
|
||||||
local var = s.n > 1 and s.s/(s.n-1) or 0/0
|
local var = s.n > 1 and s.s/(s.n-1) or NaN
|
||||||
return rstatres(s.n, s.m, var, math.sqrt(var), s.min, s.max)
|
return rstatres(s.n, s.m, var, math.sqrt(var), s.min, s.max)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
|
reset = function(s)
|
||||||
|
s.n, s.m = 0, 0
|
||||||
|
s.s, s.min, s.max = NaN, NaN, NaN
|
||||||
|
end,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
local rstat = ffi.metatype("runningstat_t", mt)
|
local rstat = ffi.metatype("runningstat_t", mt)
|
||||||
|
@ -78,7 +86,7 @@ local rstat = ffi.metatype("runningstat_t", mt)
|
||||||
function new(n,m,s, min,max)
|
function new(n,m,s, min,max)
|
||||||
if (n == nil) then
|
if (n == nil) then
|
||||||
-- initialization containing no elements
|
-- initialization containing no elements
|
||||||
return rstat(0, 0, 0/0, 0/0, 0/0)
|
return rstat(0, 0, NaN, NaN, NaN)
|
||||||
elseif (m == nil) then
|
elseif (m == nil) then
|
||||||
-- same as initialization with N==0 above (one element)
|
-- same as initialization with N==0 above (one element)
|
||||||
return rstat(1, n, 0, n, n)
|
return rstat(1, n, 0, n, n)
|
||||||
|
|
|
@ -174,13 +174,13 @@ checkfail('gv.gethitickms = nil', "cannot create new or write into existing fiel
|
||||||
checkfail('local i = actor[0].t_data[15]', "has no member named 't_data'")
|
checkfail('local i = actor[0].t_data[15]', "has no member named 't_data'")
|
||||||
|
|
||||||
-- no pointer arithmetic!
|
-- no pointer arithmetic!
|
||||||
checkfail('local spr = sprite[0]; local x=spr+1',
|
checkfail('local spr = sprite[0]; local x=spr+1', "attempt to perform arithmetic on")
|
||||||
"attempt to perform arithmetic on")
|
|
||||||
|
|
||||||
checkfail('gameactor(1680, 0)', "bad argument #3 to 'gameactor' (function expected, got number)")
|
checkfail('gameactor(1680, 0)', "bad argument #3 to 'gameactor' (function expected, got number)")
|
||||||
|
|
||||||
checkfail("do local bt=require'bittest'; bt.QWE=1; end", "modifying module table forbidden")
|
checkfail("do local bt=require'bittest'; bt.QWE=1; end", "modifying module table forbidden")
|
||||||
|
-- the cdata returned by player[] is not a pointer!
|
||||||
|
checkfail("do local pl=player[0]; i=pl[1]")
|
||||||
|
|
||||||
printf('ceilingbunch of sector 0: %d', getbunch(0, gv.CEILING))
|
printf('ceilingbunch of sector 0: %d', getbunch(0, gv.CEILING))
|
||||||
|
|
||||||
|
@ -253,7 +253,7 @@ gameactor(1680, -- LIZTROOP
|
||||||
|
|
||||||
if (hs.n == 300) then
|
if (hs.n == 300) then
|
||||||
printf("hitscan: %s", tostring(hs:getstats()))
|
printf("hitscan: %s", tostring(hs:getstats()))
|
||||||
hs = stat.new()
|
hs:reset()
|
||||||
end
|
end
|
||||||
|
|
||||||
if (dist < 4096) then
|
if (dist < 4096) then
|
||||||
|
@ -270,6 +270,7 @@ local bittest = require "bittest"
|
||||||
bittest.sieve()
|
bittest.sieve()
|
||||||
|
|
||||||
require("test/test_geom")
|
require("test/test_geom")
|
||||||
|
require("test/test_rotspr")
|
||||||
|
|
||||||
print('---=== END TEST SCRIPT ===---')
|
print('---=== END TEST SCRIPT ===---')
|
||||||
|
|
||||||
|
|
|
@ -56,7 +56,10 @@ local t3 = os.clock()
|
||||||
|
|
||||||
local v = geom.vec2(0, 0)
|
local v = geom.vec2(0, 0)
|
||||||
for i=1,N do
|
for i=1,N do
|
||||||
v = v + geom.intersect(A[i],V[i], B[i],W[i], true)
|
local intersp = geom.intersect(A[i],V[i], B[i],W[i], true)
|
||||||
|
if (intersp ~= nil) then
|
||||||
|
v = v + intersp
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local t4 = os.clock()
|
local t4 = os.clock()
|
||||||
|
|
44
polymer/eduke32/source/lunatic/test/test_rotspr.lua
Normal file
44
polymer/eduke32/source/lunatic/test/test_rotspr.lua
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
|
||||||
|
local con = require("con")
|
||||||
|
local bit = require("bit")
|
||||||
|
local math = require("math")
|
||||||
|
|
||||||
|
local rs = con.rotatesprite
|
||||||
|
|
||||||
|
local DOT1x5 = 3135
|
||||||
|
local BAR1x5 = 3163
|
||||||
|
|
||||||
|
local function draw_hline_dotted(x1, x2, y, pal,stat)
|
||||||
|
for x=x1,x2,2 do
|
||||||
|
local tile = (x==x1 or x==x2) and BAR1x5 or DOT1x5
|
||||||
|
if (player[0].curr_weapon==2) then
|
||||||
|
x = x + 16*math.sin(2*math.pi*gv.totalclock/120)
|
||||||
|
end
|
||||||
|
rs(x,y, 65536, 0, tile, 0,pal,stat, 0,0,gv.xdim-1,gv.ydim-1)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function draw_two_hlines(y, stat)
|
||||||
|
if (player[0].curr_weapon ~= 3) then
|
||||||
|
stat = bit.bor(stat, 8)
|
||||||
|
end
|
||||||
|
draw_hline_dotted(0,160, y, 0, stat)
|
||||||
|
-- XXX: rotatesprite(*, 320, ...) with stat 1024 and classic draws out of
|
||||||
|
-- bounds (wraps to lower left corner). (Or is it the left one? In any case,
|
||||||
|
-- weird stuff happens.)
|
||||||
|
draw_hline_dotted(162,318, y, 2, stat)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
local function rotatesprite_test()
|
||||||
|
local stats = { [0]=0, 256, 512, 1024 }
|
||||||
|
for i=0,3 do
|
||||||
|
local stat = stats[i]
|
||||||
|
draw_two_hlines(50+25*i, stats[i])
|
||||||
|
end
|
||||||
|
|
||||||
|
-- NUKEBUTTON
|
||||||
|
rs(30,170, 32768, 2047*((gv.totalclock/240)%1), 142, 0,0,8+1024, 0,0,gv.xdim-1,gv.ydim-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
gameevent(gv.EVENT_DISPLAYREST, rotatesprite_test)
|
Loading…
Reference in a new issue