mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 11:10:39 +00:00
Lunatic: provide CON-defined labels in read-only table require("CON.DEFS").
git-svn-id: https://svn.eduke32.com/eduke32@3870 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
d25dcbff17
commit
2f29a89368
5 changed files with 41 additions and 52 deletions
|
@ -71,41 +71,6 @@ PROJ = {
|
||||||
PROJ_USERDATA = 29,
|
PROJ_USERDATA = 29,
|
||||||
}
|
}
|
||||||
|
|
||||||
-- PROJ_* define -> projectile_t member name
|
|
||||||
--[[
|
|
||||||
PROJ_MEMBNAME = {
|
|
||||||
[PROJ.PROJ_WORKSLIKE] = "workslike",
|
|
||||||
[PROJ.PROJ_SPAWNS] = "spawns",
|
|
||||||
[PROJ.PROJ_SXREPEAT] = "sxrepeat",
|
|
||||||
[PROJ.PROJ_SYREPEAT] = "syrepeat",
|
|
||||||
[PROJ.PROJ_SOUND] = "sound",
|
|
||||||
[PROJ.PROJ_ISOUND] = "isound",
|
|
||||||
[PROJ.PROJ_VEL] = "vel",
|
|
||||||
[PROJ.PROJ_EXTRA] = "extra",
|
|
||||||
[PROJ.PROJ_DECAL] = "decal",
|
|
||||||
[PROJ.PROJ_TRAIL] = "trail",
|
|
||||||
[PROJ.PROJ_TXREPEAT] = "txrepeat",
|
|
||||||
[PROJ.PROJ_TYREPEAT] = "tyrepeat",
|
|
||||||
[PROJ.PROJ_TOFFSET] = "toffset",
|
|
||||||
[PROJ.PROJ_TNUM] = "tnum",
|
|
||||||
[PROJ.PROJ_DROP] = "drop",
|
|
||||||
[PROJ.PROJ_CSTAT] = "cstat",
|
|
||||||
[PROJ.PROJ_CLIPDIST] = "clipdist",
|
|
||||||
[PROJ.PROJ_SHADE] = "shade",
|
|
||||||
[PROJ.PROJ_XREPEAT] = "xrepeat",
|
|
||||||
[PROJ.PROJ_YREPEAT] = "yrepeat",
|
|
||||||
[PROJ.PROJ_PAL] = "pal",
|
|
||||||
[PROJ.PROJ_EXTRA_RAND] = "extra_rand",
|
|
||||||
[PROJ.PROJ_HITRADIUS] = "hitradius",
|
|
||||||
[PROJ.PROJ_VEL_MULT] = "movecnt", -- NAME
|
|
||||||
[PROJ.PROJ_OFFSET] = "offset",
|
|
||||||
[PROJ.PROJ_BOUNCES] = "bounces",
|
|
||||||
[PROJ.PROJ_BSOUND] = "bsound",
|
|
||||||
[PROJ.PROJ_RANGE] = "range",
|
|
||||||
[PROJ.PROJ_FLASH_COLOR] = "flashcolor", -- NAME
|
|
||||||
}
|
|
||||||
--]]
|
|
||||||
|
|
||||||
-- TODO: EVENT_INIT currently can't run since we init Lunatic state only afterwards
|
-- TODO: EVENT_INIT currently can't run since we init Lunatic state only afterwards
|
||||||
EVENT = {
|
EVENT = {
|
||||||
EVENT_INIT = 0,
|
EVENT_INIT = 0,
|
||||||
|
@ -802,7 +767,7 @@ local ProjectileLabels = {
|
||||||
userdata = PROJ".userdata",
|
userdata = PROJ".userdata",
|
||||||
}
|
}
|
||||||
|
|
||||||
-- XXX: kind of CODEDUP form above
|
-- XXX: kind of CODEDUP form spr2tspr
|
||||||
local function proj2thisproj(code)
|
local function proj2thisproj(code)
|
||||||
if (code and code:find(PROJ"", 1, true)==1) then
|
if (code and code:find(PROJ"", 1, true)==1) then
|
||||||
return THISPROJ(code:sub(#PROJ"" + 1))
|
return THISPROJ(code:sub(#PROJ"" + 1))
|
||||||
|
|
|
@ -1351,19 +1351,17 @@ local allowed_modules = {
|
||||||
}
|
}
|
||||||
|
|
||||||
-- Protect base modules.
|
-- Protect base modules.
|
||||||
do
|
local function basemodule_newindex()
|
||||||
local function basemodule_newindex()
|
error("modifying base module table forbidden", 2)
|
||||||
error("modifying base module table forbidden", 2)
|
end
|
||||||
end
|
|
||||||
|
|
||||||
for modname, themodule in pairs(allowed_modules) do
|
for modname, themodule in pairs(allowed_modules) do
|
||||||
local mt = {
|
local mt = {
|
||||||
__index = themodule,
|
__index = themodule,
|
||||||
__newindex = basemodule_newindex,
|
__newindex = basemodule_newindex,
|
||||||
}
|
}
|
||||||
|
|
||||||
allowed_modules[modname] = setmtonce({}, mt)
|
allowed_modules[modname] = setmtonce({}, mt)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -2037,8 +2035,14 @@ if (concode) then
|
||||||
error("Failure loading translated CON code: "..conerrmsg, 0)
|
error("Failure loading translated CON code: "..conerrmsg, 0)
|
||||||
end
|
end
|
||||||
|
|
||||||
package_loaded[CON_MODULE_NAME] = confunc()
|
local conmodule, conlabels = confunc()
|
||||||
|
|
||||||
|
package_loaded[CON_MODULE_NAME] = conmodule
|
||||||
module_gamevars[CON_MODULE_NAME] = { "A", "V" } -- See CON_GAMEVARS is lunacon.lua.
|
module_gamevars[CON_MODULE_NAME] = { "A", "V" } -- See CON_GAMEVARS is lunacon.lua.
|
||||||
|
|
||||||
|
-- Set up CON.DEFS module, providing access to labels defined in CON from Lua.
|
||||||
|
local mt = { __index = conlabels, __newindex = basemodule_newindex }
|
||||||
|
allowed_modules["CON.DEFS"] = setmtonce({}, mt)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- When starting a map, load Lua modules given on the command line.
|
-- When starting a map, load Lua modules given on the command line.
|
||||||
|
|
|
@ -120,9 +120,8 @@ time.
|
||||||
|
|
||||||
==== The function `require(modname, ...)`
|
==== The function `require(modname, ...)`
|
||||||
|
|
||||||
Attempts to find a Lua or Lunatic module named `modname`, which should not
|
Attempts to find a Lua or Lunatic module named `modname`. The name can refer to
|
||||||
contain directory separators. The name can refer to a _built-in_ module, of
|
a _built-in_ module, of which the following ones are allowed:
|
||||||
which the following ones are allowed:
|
|
||||||
|
|
||||||
* The http://bitop.luajit.org/[`bit`] module for bitwise operations
|
* The http://bitop.luajit.org/[`bit`] module for bitwise operations
|
||||||
* `math`, `string` and `table`, base modules from Lua
|
* `math`, `string` and `table`, base modules from Lua
|
||||||
|
@ -621,7 +620,10 @@ If this sprite is _view-aligned_, controls the distance at which another moving
|
||||||
object is considered to be in collision with this *stationary* sprite. (It does
|
object is considered to be in collision with this *stationary* sprite. (It does
|
||||||
not control the inverse case.) More precisely, it designates half the
|
not control the inverse case.) More precisely, it designates half the
|
||||||
side-length of the bounding square divided by 4. Thus, a value of `255` keeps
|
side-length of the bounding square divided by 4. Thus, a value of `255` keeps
|
||||||
moving objects away from this one at a Manhattan distance of at least 1020
|
moving objects away from this one at a max-norm distance
|
||||||
|
footnote:[The max-norm distance between points _p_~1~=(x~1~, y~1~) and
|
||||||
|
_p_~2~=(x~2~, y~2~) is defined as max(abs(x~2~ -- x~1~), abs(y~2~ -- y~1~)).]
|
||||||
|
of at least 1020
|
||||||
BUILD x/y units.
|
BUILD x/y units.
|
||||||
|
|
||||||
_`u8`_ `xrepeat`, `yrepeat`::
|
_`u8`_ `xrepeat`, `yrepeat`::
|
||||||
|
|
|
@ -602,6 +602,7 @@ local LABEL_FUNCNAME = { [2]="move", [3]="ai", [5]="action" }
|
||||||
|
|
||||||
local g_labeldef = {} -- Lua numbers for numbers, strings for composites
|
local g_labeldef = {} -- Lua numbers for numbers, strings for composites
|
||||||
local g_labeltype = {}
|
local g_labeltype = {}
|
||||||
|
local g_labelspecial = {} -- [<label>] = true
|
||||||
|
|
||||||
local function reset_labels()
|
local function reset_labels()
|
||||||
g_badids = {}
|
g_badids = {}
|
||||||
|
@ -622,6 +623,7 @@ local function reset_labels()
|
||||||
|
|
||||||
for varname,_ in pairs(g_labeldef) do
|
for varname,_ in pairs(g_labeldef) do
|
||||||
g_labeltype[varname] = LABEL.NUMBER
|
g_labeltype[varname] = LABEL.NUMBER
|
||||||
|
g_labelspecial[varname] = true
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Initialize default defines.
|
-- Initialize default defines.
|
||||||
|
@ -3319,6 +3321,17 @@ local function get_code_string(codetab, lineinfop)
|
||||||
-- Finalize translated code: return table containing gamevar and gamearray
|
-- Finalize translated code: return table containing gamevar and gamearray
|
||||||
-- tables. CON_GAMEVARS.
|
-- tables. CON_GAMEVARS.
|
||||||
codetab[#codetab+1] = "return { V=_V, A=_A }"
|
codetab[#codetab+1] = "return { V=_V, A=_A }"
|
||||||
|
|
||||||
|
-- Return defined labels in a table...
|
||||||
|
codetab[#codetab+1] = ",{"
|
||||||
|
for label, val in pairs(g_labeldef) do
|
||||||
|
-- ... skipping 'NO' and those that are gamevars in C-CON.
|
||||||
|
if (g_labeltype[label]==LABEL.NUMBER and not g_labelspecial[label]) then
|
||||||
|
codetab[#codetab+1] = format("[%q]=%d,", label, val)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
codetab[#codetab+1] = "}"
|
||||||
|
|
||||||
local flatcode = flatten_codetab(codetab)
|
local flatcode = flatten_codetab(codetab)
|
||||||
local lineinfo = lineinfop and get_lineinfo(flatcode)
|
local lineinfo = lineinfop and get_lineinfo(flatcode)
|
||||||
return table.concat(flatcode, "\n"), lineinfo
|
return table.concat(flatcode, "\n"), lineinfo
|
||||||
|
|
|
@ -538,3 +538,8 @@ spritesofsect(0)
|
||||||
-- This will complain about wrong usage of 'error'. In particular,
|
-- This will complain about wrong usage of 'error'. In particular,
|
||||||
-- the nil must not propagate to C!
|
-- the nil must not propagate to C!
|
||||||
checkfail('error(nil)', "error using 'error': error message must be a string")
|
checkfail('error(nil)', "error using 'error': error message must be a string")
|
||||||
|
|
||||||
|
local D = require("CON.DEFS")
|
||||||
|
checkfail('require("CON.DEFS").APLAYER=123', "modifying base module table forbidden")
|
||||||
|
-- Test with lunatic/test/rotfixed_actor.con.
|
||||||
|
print("DUKECAR="..tostring(D.DUKECAR))
|
||||||
|
|
Loading…
Reference in a new issue