diff --git a/polymer/eduke32/source/lunatic/control.lua b/polymer/eduke32/source/lunatic/control.lua index 95750e060..2aee7d799 100644 --- a/polymer/eduke32/source/lunatic/control.lua +++ b/polymer/eduke32/source/lunatic/control.lua @@ -266,22 +266,20 @@ end -- the engine "insertsprite". -- -- Forms: --- 1. table-call: insertsprite{tilenum, pos, sectnum [, owner [, statnum]] [, key=val...]} +-- 1. table-call: insertsprite{tilenum, pos, sectnum [, statnum [, owner]] [, key=val...]} -- valid keys are: owner, statnum, shade, xrepeat, yrepeat, xvel, zvel --- 2. position-call: insertsprite(tilenum, pos, sectnum [, owner [, statnum]]) +-- 2. position-call: insertsprite(tilenum, pos, sectnum [, statnum [, owner]]) function insertsprite(tab_or_tilenum, ...) local tilenum, pos, sectnum -- mandatory -- optional with defaults: - -- TODO: swap order of owner and statnum? - -- XXX: owner -1 valid??? local owner, statnum local shade, xrepeat, yrepeat, ang, xvel, zvel = 0, 48, 48, 0, 0, 0 if (type(tab_or_tilenum)=="table") then local tab = tab_or_tilenum tilenum, pos, sectnum = unpack(tab, 1, 3) - owner = tab[4] or tab.owner or -1 - statnum = tab[5] or tab.statnum or 0 + statnum = tab[4] or tab.statnum or 0 + owner = tab[5] or tab.owner or -1 shade = tab.shade or shade xrepeat = tab.xrepeat or xrepeat yrepeat = tab.yrepeat or yrepeat @@ -292,8 +290,8 @@ function insertsprite(tab_or_tilenum, ...) tilenum = tab_or_tilenum local args = {...} pos, sectnum = unpack(args, 1, 2) - owner = args[3] or -1 - statnum = args[4] or 0 + statnum = args[3] or 0 + owner = args[4] or -1 end if (type(sectnum)~="number" or type(tilenum) ~= "number") then @@ -303,6 +301,9 @@ function insertsprite(tab_or_tilenum, ...) check_tile_idx(tilenum) check_sector_idx(sectnum) check_allnumbers(shade, xrepeat, yrepeat, ang, xvel, zvel, owner) + if (owner ~= -1) then + check_sprite_idx(owner) + end if (not (statnum >= 0 and statnum < ffiC.MAXSTATUS)) then error("invalid 'statnum' argument to insertsprite: must be a status number [0 .. MAXSTATUS-1]", 2) @@ -310,9 +311,13 @@ function insertsprite(tab_or_tilenum, ...) A_ResetVarsNextIns() - return CF.A_InsertSprite(sectnum, pos.x, pos.y, pos.z, tilenum, - shade, xrepeat, yrepeat, ang, xvel, zvel, - owner, statnum) + local i = CF.A_InsertSprite(sectnum, pos.x, pos.y, pos.z, tilenum, + shade, xrepeat, yrepeat, ang, xvel, zvel, + owner, statnum) + if (owner == -1) then + ffiC.sprite[i]:_set_owner(i) + end + return i end -- INTERNAL USE ONLY. @@ -353,7 +358,7 @@ function _spawnmany(ow, label, n) local spr = sprite[ow] for i=n,1, -1 do - local j = insertsprite{ tilenum, spr^(ffiC.krand()%(47*256)), spr.sectnum, ow, 5, + local j = insertsprite{ tilenum, spr^(ffiC.krand()%(47*256)), spr.sectnum, 5, ow, shade=-32, xrepeat=8, yrepeat=8, ang=krandand(2047) } _spawnexisting(j) sprite[j].cstat = krandand(8+4) @@ -1025,7 +1030,7 @@ function _A_DoGuts(i, gutstile, n) for i=n,1, -1 do local pos = vec3(spr.x+krandand(255)-128, spr.y+krandand(255)-128, z-krandand(8191)) - local j = insertsprite{ gutstile, pos, spr.sectnum, i, 5, shade=-32, xrepeat=xsz, yrepeat=ysz, + local j = insertsprite{ gutstile, pos, spr.sectnum, 5, i, shade=-32, xrepeat=xsz, yrepeat=ysz, ang=krandand(2047), xvel=48+krandand(31), zvel=-512-krandand(2047) } local newspr = sprite[j] if (ispic(newspr.picnum, "JIBS2")) then @@ -1048,7 +1053,7 @@ function _debris(i, dtile, n) local isblimpscrap = (ispic(spr.picnum, "BLIMP") and ispic(dtile, "SCRAP1")) local picofs = isblimpscrap and 0 or krandand(3) local pos = spr + vec3(krandand(255)-128, krandand(255)-128, -(8*256)-krandand(8191)) - local jj = insertsprite{ dtile+picofs, pos, spr.sectnum, i, 5, + local jj = insertsprite{ dtile+picofs, pos, spr.sectnum, 5, i, shade=spr.shade, xrepeat=32+krandand(15), yrepeat=32+krandand(15), ang=krandand(2047), xvel=32+krandand(127), zvel=-krandand(2047) } -- NOTE: BlimpSpawnSprites[14] (its array size is 15) will never be chosen @@ -1062,7 +1067,7 @@ function _A_SpawnGlass(i, n) local spr = sprite[i] for j=n,1, -1 do - local k = insertsprite{ D.GLASSPIECES+n%3, spr^(256*krandand(16)), spr.sectnum, i, 5, + local k = insertsprite{ D.GLASSPIECES+n%3, spr^(256*krandand(16)), spr.sectnum, 5, i, shade=krandand(15), xrepeat=36, yrepeat=36, ang=krandand(2047), xvel=32+krandand(63), zvel=-512-krandand(2047) } sprite[k].pal = spr.pal diff --git a/polymer/eduke32/source/lunatic/doc/lunatic.txt b/polymer/eduke32/source/lunatic/doc/lunatic.txt index 92070e123..0e85211c7 100644 --- a/polymer/eduke32/source/lunatic/doc/lunatic.txt +++ b/polymer/eduke32/source/lunatic/doc/lunatic.txt @@ -1946,7 +1946,7 @@ In Lunatic, there are two functions that insert a sprite into the game world. They mainly differ in how they are used, and to which extent they imply ``hard-coded'' behavior. -===== The function `con.insertsprite{tilenum, pos, sectnum [, owner [, statnum]] [key=val...]}` +===== The function `con.insertsprite{tilenum, pos, sectnum [, statnum [, owner]] [key=val...]}` Inserts a new sprite into the game with the properties given as input arguments. If the world already contains the maximum number of sprites @@ -1957,11 +1957,26 @@ cleared. No additional ``hard-wired'' C code is run. Returns the index of the inserted sprite. -The function `con.insertsprite` is called with a single table whose values are -taken as the actual arguments. The first three, `tilenum`, `pos` and `sectnum`, -are passed positionally. All other input arguments are passed as key-value -pairs, but `owner` and `statnum` may be provided in both forms (but only one -form in one call). +The function `con.insertsprite` can be used in one of two forms: + +* In the `table-call` form specified above, a single table is passed whose +values are taken as the actual arguments. The first three, `tilenum`, `pos` and +`sectnum`, are passed positionally. All other input arguments are passed as +key-value pairs, but `owner` and `statnum` may be provided either positionally +or as key/value pair. + +* Passing only the three to five positional arguments is also directly + possible. For example, all of the following calls are equivalent: ++ +[source] +---------- +local i = con.insertsprite(tile, pos, sect, stat, ow) -- direct-call +local i = con.insertsprite{tile, pos, sect, stat, ow} -- table-call +local i = con.insertsprite{tile, pos, sect, statnum=stat, owner=ow} -- table-call with 2 k/v args +local i = con.insertsprite{tile, pos, sect, stat, owner=ow} -- table-call with one k/v arg +---------- + +The five main arguments are as follows: `[1]` (`tilenum`):: The tile number of the sprite to insert. @@ -1972,18 +1987,18 @@ The position at which to insert the sprite (anything indexable with `x`, `y` and `[3]` (`sectnum`):: The index of the sector in which to insert the sprite. -`[4] owner` (default: --1):: -The index of the sprite that is in some sense the ``parent'' of the newly -created one. - -`[5] statnum` (default: `actor.STAT.DEFAULT`):: +`[4] statnum` (default: `actor.STAT.DEFAULT`):: The initial status number of the inserted sprite. -The following additional keys are permissible as input arguments, corresponding -to the same-named <> members: -`shade`, `xrepeat` (default: 48), `yrepeat` (default: 48), `ang`, `xvel`, -`zvel`. All optional arguments passed this way except for `xrepeat` and -`yrepeat` default to 0. +`[5] owner` (default: see below):: +The index of the sprite that is in some sense the ``parent'' of the newly +created one. If omitted, it is set to the index of the newly spawned sprite. + +These keys are permissible as optional input arguments in the table-call form, +corresponding to the same-named <> members: + +* `shade`, `ang`, `xvel`, `zvel` (default: 0) +* `xrepeat` and `yrepeat` (default: 48) ===== The function `con.spawn(tilenum, parentspritenum)` diff --git a/polymer/eduke32/source/lunatic/test.lua b/polymer/eduke32/source/lunatic/test.lua index 9ccca9bb9..6bd0b6db1 100644 --- a/polymer/eduke32/source/lunatic/test.lua +++ b/polymer/eduke32/source/lunatic/test.lua @@ -92,10 +92,16 @@ gameevent end ---[[ if (vol==1 and lev==8) then - print('tweaking bunch 1'); - -- trueror1.map - for i, what in sectorsofbunch(1, gv.BOTH_CF) do - sector[i][what].z = sector[i][what].z - 3*1024; + local havebunch = false + for i=0,gv.numsectors-1 do + havebunch = havebunch or (sector[i].ceilingbunch >= 0) + end + if (havebunch) then + print('tweaking bunch 1'); + -- trueror1.map + for i, what in sectorsofbunch(1, gv.BOTH_CF) do + sector[i][what].z = sector[i][what].z - 3*1024; + end end end --]] diff --git a/polymer/eduke32/source/lunatic/test/damagehplane.lua b/polymer/eduke32/source/lunatic/test/damagehplane.lua index 3bae93bdf..c81a618d0 100644 --- a/polymer/eduke32/source/lunatic/test/damagehplane.lua +++ b/polymer/eduke32/source/lunatic/test/damagehplane.lua @@ -94,7 +94,7 @@ gameevent if (cf.bunch >= 0 and (cf.picnum==198 or cf.picnum==D.GLASS2) and cf.statbits:test(sector.STAT.HITSCAN)) then - local bi = con.insertsprite(TROR_GLASSBREAKER, wall[sec.wallptr], sectnum, aci, actor.STAT.ACTOR) + local bi = con.insertsprite(TROR_GLASSBREAKER, wall[sec.wallptr], sectnum, actor.STAT.ACTOR) local breaker = sprite[bi] breaker.cstat = sprite.CSTAT.INVISIBLE diff --git a/polymer/eduke32/source/lunatic/test/helixspawner.lua b/polymer/eduke32/source/lunatic/test/helixspawner.lua index 9c6bbaa3b..63f4d6b7a 100644 --- a/polymer/eduke32/source/lunatic/test/helixspawner.lua +++ b/polymer/eduke32/source/lunatic/test/helixspawner.lua @@ -130,7 +130,7 @@ gameactor local circvec = xmath.vec3(0, v.x, 16*v.y):rotate(spr.ang) local pos = spr^(zofs + radius) + 256*bangvec(spr.ang) + circvec - con.insertsprite{D.TRANSPORTERSTAR+4, pos, spr.sectnum, aci, actor.STAT.ACTOR, + con.insertsprite{D.TRANSPORTERSTAR+4, pos, spr.sectnum, actor.STAT.ACTOR, aci, xrepeat=3, yrepeat=3, ang=spr.ang} end end