mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
Lunatic: fix weapondata_t read access, Lua->CON line mapping for if* commands.
git-svn-id: https://svn.eduke32.com/eduke32@3595 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
b7ea1cb205
commit
ea118fe436
3 changed files with 25 additions and 4 deletions
|
@ -1188,6 +1188,10 @@ function _cansee(aci, ps)
|
||||||
local spr = sprite[aci]
|
local spr = sprite[aci]
|
||||||
local s = sprite[ps.i]
|
local s = sprite[ps.i]
|
||||||
|
|
||||||
|
-- This is kind of redundant, but points the error messages to the CON code.
|
||||||
|
check_sector_idx(spr.sectnum)
|
||||||
|
check_sector_idx(s.sectnum)
|
||||||
|
|
||||||
if (ps.holoduke_on >= 0) then
|
if (ps.holoduke_on >= 0) then
|
||||||
-- If holoduke is on, let them target holoduke first.
|
-- If holoduke is on, let them target holoduke first.
|
||||||
local hs = sprite[ps.holoduke_on]
|
local hs = sprite[ps.holoduke_on]
|
||||||
|
|
|
@ -913,6 +913,11 @@ ffi.metatype("actor_t", actor_mt)
|
||||||
|
|
||||||
--- PER-PLAYER WEAPON SETTINGS
|
--- PER-PLAYER WEAPON SETTINGS
|
||||||
local weapondata_mt = {
|
local weapondata_mt = {
|
||||||
|
__index = function(wd, member)
|
||||||
|
-- Handle protected members that are renamed (e.g. shoots/_shoots).
|
||||||
|
return ffi.cast(weapondata_ptr_ct, wd)[member]
|
||||||
|
end,
|
||||||
|
|
||||||
__newindex = function(wd, member, val)
|
__newindex = function(wd, member, val)
|
||||||
if (string.match(member, "sound")) then
|
if (string.match(member, "sound")) then
|
||||||
if (val < 0) then
|
if (val < 0) then
|
||||||
|
|
|
@ -2567,11 +2567,15 @@ local function after_if_cmd_Cmt(subj, pos, ...)
|
||||||
local capts = {...}
|
local capts = {...}
|
||||||
assert(capts[1] ~= nil)
|
assert(capts[1] ~= nil)
|
||||||
assert(#capts <= 3)
|
assert(#capts <= 3)
|
||||||
for i=1,#capts do
|
|
||||||
assert(type(capts[i]=="string"))
|
for i=#capts,1, -1 do
|
||||||
|
assert(type(capts[i])=="string" or type(capts[i])=="table")
|
||||||
end
|
end
|
||||||
|
|
||||||
-- TODO: make if* commands have line numbers.
|
-- IF_LINE_NUMBERING
|
||||||
|
local firstistab = (type(capts[1])=="table")
|
||||||
|
attachlinenum(firstistab and capts[1] or capts, pos)
|
||||||
|
|
||||||
return true, unpack(capts)
|
return true, unpack(capts)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -2750,6 +2754,7 @@ function on.if_else_end(ifconds, ifstmt, elsestmt, ...)
|
||||||
-- and it's always idempotent (executing it multiple times has the same
|
-- and it's always idempotent (executing it multiple times has the same
|
||||||
-- effect as executing it once), so generate code for it only once, too.
|
-- effect as executing it once), so generate code for it only once, too.
|
||||||
local deferred = { nil, nil }
|
local deferred = { nil, nil }
|
||||||
|
local linenum = ""
|
||||||
|
|
||||||
local ifcondstr = {}
|
local ifcondstr = {}
|
||||||
for i=1,#ifconds do
|
for i=1,#ifconds do
|
||||||
|
@ -2759,6 +2764,13 @@ function on.if_else_end(ifconds, ifstmt, elsestmt, ...)
|
||||||
ifcondstr[i] = hasmore and cond[1] or cond
|
ifcondstr[i] = hasmore and cond[1] or cond
|
||||||
assert(type(ifcondstr[i])=="string")
|
assert(type(ifcondstr[i])=="string")
|
||||||
|
|
||||||
|
-- IF_LINE_NUMBERING
|
||||||
|
local tlinum = assert(ifcondstr[i]:match("^.*(%-%-[0-9]+)$"))
|
||||||
|
ifcondstr[i] = assert(ifcondstr[i]:match("^(.*)%-%-[0-9]+$"))
|
||||||
|
if (linenum == "") then
|
||||||
|
linenum = tlinum
|
||||||
|
end
|
||||||
|
|
||||||
if (hasmore) then
|
if (hasmore) then
|
||||||
for i=1,2 do
|
for i=1,2 do
|
||||||
if (deferred[i]==nil) then
|
if (deferred[i]==nil) then
|
||||||
|
@ -2772,7 +2784,7 @@ function on.if_else_end(ifconds, ifstmt, elsestmt, ...)
|
||||||
local conds = "(" .. table.concat(ifcondstr, ")and(") .. ")"
|
local conds = "(" .. table.concat(ifcondstr, ")and(") .. ")"
|
||||||
|
|
||||||
local code = {
|
local code = {
|
||||||
format("if %s then", conds),
|
format("if %s then%s", conds, linenum),
|
||||||
assert(ifstmt),
|
assert(ifstmt),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue