mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Some Lunatic cleanup.
git-svn-id: https://svn.eduke32.com/eduke32@3246 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
4d40ca6159
commit
16c596b31b
3 changed files with 43 additions and 39 deletions
|
@ -21,7 +21,8 @@ MAXSOUNDS = 4096
|
||||||
|
|
||||||
|
|
||||||
-- KEEPINSYNC with gamedef.c:C_AddDefaultDefinitions() and the respective
|
-- KEEPINSYNC with gamedef.c:C_AddDefaultDefinitions() and the respective
|
||||||
-- defines
|
-- defines. These are exported to the ffi.C namespace and as literal defines
|
||||||
|
-- in lunacon.lua.
|
||||||
labels =
|
labels =
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
|
|
|
@ -319,7 +319,7 @@ end
|
||||||
|
|
||||||
function getbunch(sectnum, cf)
|
function getbunch(sectnum, cf)
|
||||||
if (sectnum < 0 or sectnum >= ffiC.numsectors) then
|
if (sectnum < 0 or sectnum >= ffiC.numsectors) then
|
||||||
error('passed out-of-bounds sector number '..sectnum, 2)
|
error("passed out-of-bounds sector number "..sectnum, 2)
|
||||||
end
|
end
|
||||||
if (cf ~= 0 and cf ~= 1) then
|
if (cf ~= 0 and cf ~= 1) then
|
||||||
error("passed invalid 'cf' to getbunch, must be 0 or 1", 2)
|
error("passed invalid 'cf' to getbunch, must be 0 or 1", 2)
|
||||||
|
@ -334,8 +334,8 @@ end
|
||||||
-- TODO: make v[xyz] be passed as one aggregate, too?
|
-- TODO: make v[xyz] be passed as one aggregate, too?
|
||||||
-- Additionally, permit different coordinates? (ang&horiz, ...)
|
-- Additionally, permit different coordinates? (ang&horiz, ...)
|
||||||
function hitscan(pos, sectnum, vx,vy,vz, cliptype)
|
function hitscan(pos, sectnum, vx,vy,vz, cliptype)
|
||||||
if (sectnum < 0 or sectnum >= ffiC.numsectors) then
|
if (sectnum >= ffiC.numsectors+0ULL) then
|
||||||
error('passed out-of-bounds sector number '..sectnum, 2)
|
error("passed out-of-bounds sector number "..sectnum, 2)
|
||||||
end
|
end
|
||||||
|
|
||||||
local vec = vec3_ct(pos.x, pos.y, pos.z)
|
local vec = vec3_ct(pos.x, pos.y, pos.z)
|
||||||
|
|
|
@ -20,7 +20,7 @@ local Pat, Set, Range, Var = lpeg.P, lpeg.S, lpeg.R, lpeg.V
|
||||||
local POS = lpeg.Cp
|
local POS = lpeg.Cp
|
||||||
|
|
||||||
---- All keywords pattern -- needed for CON syntax
|
---- All keywords pattern -- needed for CON syntax
|
||||||
local con = require("con_lang")
|
local conl = require("con_lang")
|
||||||
|
|
||||||
|
|
||||||
local function match_until(matchsp, untilsp) -- (!untilsp matchsp)* in PEG
|
local function match_until(matchsp, untilsp) -- (!untilsp matchsp)* in PEG
|
||||||
|
@ -28,8 +28,10 @@ local function match_until(matchsp, untilsp) -- (!untilsp matchsp)* in PEG
|
||||||
return (matchsp - Pat(untilsp))^0
|
return (matchsp - Pat(untilsp))^0
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local format = string.format
|
||||||
|
|
||||||
local function printf(fmt, ...)
|
local function printf(fmt, ...)
|
||||||
print(string.format(fmt, ...))
|
print(format(fmt, ...))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -71,11 +73,12 @@ local function reset_codegen()
|
||||||
end
|
end
|
||||||
|
|
||||||
local function addcode(x)
|
local function addcode(x)
|
||||||
|
assert(type(x)=="string" or type(x)=="table")
|
||||||
g_curcode[#g_curcode+1] = x
|
g_curcode[#g_curcode+1] = x
|
||||||
end
|
end
|
||||||
|
|
||||||
local function addcodef(fmt, ...)
|
local function addcodef(fmt, ...)
|
||||||
addcode(string.format(fmt, ...))
|
addcode(format(fmt, ...))
|
||||||
end
|
end
|
||||||
|
|
||||||
local function on_actor_end(usertype, tsamm, codetab)
|
local function on_actor_end(usertype, tsamm, codetab)
|
||||||
|
@ -84,6 +87,7 @@ local function on_actor_end(usertype, tsamm, codetab)
|
||||||
|
|
||||||
-- usertype is non-nil only for 'useractor'
|
-- usertype is non-nil only for 'useractor'
|
||||||
addcodef("gameactor(%d, function(_aci, _pli, _dist)", tilenum)
|
addcodef("gameactor(%d, function(_aci, _pli, _dist)", tilenum)
|
||||||
|
assert(type(codetab)=="table")
|
||||||
g_actor_code[tilenum] = codetab
|
g_actor_code[tilenum] = codetab
|
||||||
|
|
||||||
addcode(codetab)
|
addcode(codetab)
|
||||||
|
@ -94,7 +98,7 @@ end
|
||||||
|
|
||||||
local function linecolstr(pos)
|
local function linecolstr(pos)
|
||||||
local line, col = getlinecol(pos)
|
local line, col = getlinecol(pos)
|
||||||
return string.format("%d:%d", line, col)
|
return format("%d:%d", line, col)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function perrprintf(pos, fmt, ...)
|
local function perrprintf(pos, fmt, ...)
|
||||||
|
@ -158,8 +162,8 @@ local function reset_labels()
|
||||||
g_labeltype = { NO=LABEL.NUMBER }
|
g_labeltype = { NO=LABEL.NUMBER }
|
||||||
|
|
||||||
-- Initialize default defines.
|
-- Initialize default defines.
|
||||||
for i=1,#con.labels do
|
for i=1,#conl.labels do
|
||||||
for label, val in pairs(con.labels[i]) do
|
for label, val in pairs(conl.labels[i]) do
|
||||||
g_labeldef[label] = val
|
g_labeldef[label] = val
|
||||||
g_labeltype[label] = LABEL.NUMBER
|
g_labeltype[label] = LABEL.NUMBER
|
||||||
end
|
end
|
||||||
|
@ -193,8 +197,8 @@ local function do_define_label(identifier, num)
|
||||||
errprintf("refusing to overwrite `%s' label \"%s\" with a `define'd number",
|
errprintf("refusing to overwrite `%s' label \"%s\" with a `define'd number",
|
||||||
LABEL[oldtype], identifier)
|
LABEL[oldtype], identifier)
|
||||||
else
|
else
|
||||||
-- con.labels[...]: don't warn for wrong PROJ_ redefinitions
|
-- conl.labels[...]: don't warn for wrong PROJ_ redefinitions
|
||||||
if (oldval ~= num and con.labels[2][identifier]==nil) then
|
if (oldval ~= num and conl.labels[2][identifier]==nil) then
|
||||||
warnprintf("label \"%s\" not redefined with new value %d (old: %d)",
|
warnprintf("label \"%s\" not redefined with new value %d (old: %d)",
|
||||||
identifier, num, oldval)
|
identifier, num, oldval)
|
||||||
end
|
end
|
||||||
|
@ -234,7 +238,7 @@ local function lookup_composite(labeltype, pos, identifier)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Generate a quoted identifier name.
|
-- Generate a quoted identifier name.
|
||||||
val = string.format("%q", identifier)
|
val = format("%q", identifier)
|
||||||
|
|
||||||
if (TEMP_numlookups[identifier]) then
|
if (TEMP_numlookups[identifier]) then
|
||||||
TEMP_numlookups[identifier] = TEMP_numlookups[identifier]+1
|
TEMP_numlookups[identifier] = TEMP_numlookups[identifier]+1
|
||||||
|
@ -282,10 +286,10 @@ local function do_define_composite(labeltype, identifier, ...)
|
||||||
|
|
||||||
-- Make a string out of that.
|
-- Make a string out of that.
|
||||||
for i=1+(isai and 2 or 0),#args do
|
for i=1+(isai and 2 or 0),#args do
|
||||||
args[i] = string.format("%d", args[i])
|
args[i] = format("%d", args[i])
|
||||||
end
|
end
|
||||||
|
|
||||||
addcodef("_con.%s(%q,%s)\n", LABEL_FUNCNAME[labeltype], identifier, table.concat(args, ","))
|
addcodef("_con.%s(%q,%s)", LABEL_FUNCNAME[labeltype], identifier, table.concat(args, ","))
|
||||||
|
|
||||||
g_labeldef[identifier] = ""
|
g_labeldef[identifier] = ""
|
||||||
g_labeltype[identifier] = labeltype
|
g_labeltype[identifier] = labeltype
|
||||||
|
@ -350,7 +354,7 @@ end
|
||||||
|
|
||||||
--- Per-module game data
|
--- Per-module game data
|
||||||
local g_data = {}
|
local g_data = {}
|
||||||
local EPMUL = con.MAXLEVELS
|
local EPMUL = conl.MAXLEVELS
|
||||||
|
|
||||||
local function reset_gamedata()
|
local function reset_gamedata()
|
||||||
g_data = {}
|
g_data = {}
|
||||||
|
@ -372,12 +376,12 @@ local function reset_gamedata()
|
||||||
end
|
end
|
||||||
|
|
||||||
local function cmd_definelevelname(vol, lev, fn, ptstr, dtstr, levname)
|
local function cmd_definelevelname(vol, lev, fn, ptstr, dtstr, levname)
|
||||||
if (vol < 0 or vol >= con.MAXVOLUMES) then
|
if (vol < 0 or vol >= conl.MAXVOLUMES) then
|
||||||
errprintf("volume number exceeds maximum volume count.")
|
errprintf("volume number exceeds maximum volume count.")
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
if (lev < 0 or lev >= con.MAXLEVELS) then
|
if (lev < 0 or lev >= conl.MAXLEVELS) then
|
||||||
errprintf("level number exceeds maximum number of levels per episode.")
|
errprintf("level number exceeds maximum number of levels per episode.")
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
@ -396,7 +400,7 @@ local function cmd_definelevelname(vol, lev, fn, ptstr, dtstr, levname)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function cmd_defineskillname(skillnum, name)
|
local function cmd_defineskillname(skillnum, name)
|
||||||
if (skillnum < 0 or skillnum >= con.MAXSKILLS) then
|
if (skillnum < 0 or skillnum >= conl.MAXSKILLS) then
|
||||||
errprintf("volume number is negative or exceeds maximum skill count.")
|
errprintf("volume number is negative or exceeds maximum skill count.")
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
@ -405,7 +409,7 @@ local function cmd_defineskillname(skillnum, name)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function cmd_definevolumename(vol, name)
|
local function cmd_definevolumename(vol, name)
|
||||||
if (vol < 0 or vol >= con.MAXVOLUMES) then
|
if (vol < 0 or vol >= conl.MAXVOLUMES) then
|
||||||
errprintf("volume number is negative or exceeds maximum volume count.")
|
errprintf("volume number is negative or exceeds maximum volume count.")
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
@ -436,8 +440,8 @@ local function cmd_gamestartup(...)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function cmd_definesound(sndnum, fn, ...)
|
local function cmd_definesound(sndnum, fn, ...)
|
||||||
if (sndnum < 0 or sndnum >= con.MAXSOUNDS) then
|
if (sndnum < 0 or sndnum >= conl.MAXSOUNDS) then
|
||||||
errprintf("sound number is or exceeds sound limit of %d", con.MAXSOUNDS)
|
errprintf("sound number is or exceeds sound limit of %d", conl.MAXSOUNDS)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -447,16 +451,16 @@ local function cmd_definesound(sndnum, fn, ...)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function cmd_music(volnum, ...)
|
local function cmd_music(volnum, ...)
|
||||||
if (volnum < 0 or volnum >= con.MAXVOLUMES+1) then
|
if (volnum < 0 or volnum >= conl.MAXVOLUMES+1) then
|
||||||
errprintf("volume number is negative or exceeds maximum volume count+1")
|
errprintf("volume number is negative or exceeds maximum volume count+1")
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local filenames = {...}
|
local filenames = {...}
|
||||||
|
|
||||||
if (#filenames > con.MAXLEVELS) then
|
if (#filenames > conl.MAXLEVELS) then
|
||||||
warnprintf("ignoring extraneous %d music file names", #filenames-con.MAXLEVELS)
|
warnprintf("ignoring extraneous %d music file names", #filenames-conl.MAXLEVELS)
|
||||||
for i=con.MAXLEVELS+1,#filenames do
|
for i=conl.MAXLEVELS+1,#filenames do
|
||||||
filenames[i] = nil
|
filenames[i] = nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -588,7 +592,7 @@ local Co = {
|
||||||
definesound = sp1 * t_define * sp1 * maybe_quoted_filename * n_defines(5) / cmd_definesound,
|
definesound = sp1 * t_define * sp1 * maybe_quoted_filename * n_defines(5) / cmd_definesound,
|
||||||
|
|
||||||
-- NOTE: gamevar.ogg and the like is OK, too
|
-- NOTE: gamevar.ogg and the like is OK, too
|
||||||
music = sp1 * t_define * match_until(sp1 * t_filename, sp1 * con.keyword * sp1) / cmd_music,
|
music = sp1 * t_define * match_until(sp1 * t_filename, sp1 * conl.keyword * sp1) / cmd_music,
|
||||||
|
|
||||||
--- 3. Game Settings
|
--- 3. Game Settings
|
||||||
-- gamestartup has 25/29 fixed defines, depending on 1.3D/1.5 version:
|
-- gamestartup has 25/29 fixed defines, depending on 1.3D/1.5 version:
|
||||||
|
@ -669,12 +673,12 @@ local setperxvarcmd = -- set<actor/player>var[<idx>].<member> <var>
|
||||||
|
|
||||||
local Ci = {
|
local Ci = {
|
||||||
-- these can appear anywhere in the script
|
-- these can appear anywhere in the script
|
||||||
["break"] = cmd() /
|
["break"] = cmd()
|
||||||
"do return end", -- TODO: more exact semantics
|
/ "do return end", -- TODO: more exact semantics
|
||||||
["return"] = cmd(),
|
["return"] = cmd(),
|
||||||
|
|
||||||
state = cmd(I) /
|
state = cmd(I)
|
||||||
"%1()", -- TODO: mangle names
|
/ "%1()", -- TODO: mangle names
|
||||||
|
|
||||||
--- 1. get*, set*
|
--- 1. get*, set*
|
||||||
getactor = getstructcmd,
|
getactor = getstructcmd,
|
||||||
|
@ -841,8 +845,8 @@ local Ci = {
|
||||||
flash = cmd(),
|
flash = cmd(),
|
||||||
getlastpal = cmd(),
|
getlastpal = cmd(),
|
||||||
insertspriteq = cmd(),
|
insertspriteq = cmd(),
|
||||||
killit = cmd() /
|
killit = cmd()
|
||||||
"do return 2 end", -- exec SPECIAL HANDLING!
|
/ "do return 2 end", -- exec SPECIAL HANDLING!
|
||||||
mikesnd = cmd(),
|
mikesnd = cmd(),
|
||||||
nullop = cmd(),
|
nullop = cmd(),
|
||||||
pkick = cmd(),
|
pkick = cmd(),
|
||||||
|
@ -1208,7 +1212,6 @@ local function all_alt_pattern(...)
|
||||||
for cmdname,_ in pairs(pattab) do
|
for cmdname,_ in pairs(pattab) do
|
||||||
cmds[#cmds+1] = cmdname
|
cmds[#cmds+1] = cmdname
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- ...and then sort them in ascending lexicographical order
|
-- ...and then sort them in ascending lexicographical order
|
||||||
|
@ -1272,7 +1275,7 @@ attachnames(Cb)
|
||||||
local t_good_identifier = Range("AZ", "az", "__") * Range("AZ", "az", "__", "09")^0
|
local t_good_identifier = Range("AZ", "az", "__") * Range("AZ", "az", "__", "09")^0
|
||||||
|
|
||||||
-- CON isaltok also has chars in "{}.", but these could potentially
|
-- CON isaltok also has chars in "{}.", but these could potentially
|
||||||
-- interfere with *CON* syntax. The "]" is so that the number in array[80]
|
-- interfere with *CON* syntax. The "]" is so that the number in e.g. array[80]
|
||||||
-- isn't considered a broken identifier.
|
-- isn't considered a broken identifier.
|
||||||
-- "-" is somewhat problematic, but we allow it only as 2nd and up character, so
|
-- "-" is somewhat problematic, but we allow it only as 2nd and up character, so
|
||||||
-- there's no ambiguity with unary minus. (Commands must be separated by spaces
|
-- there's no ambiguity with unary minus. (Commands must be separated by spaces
|
||||||
|
@ -1317,7 +1320,7 @@ local Grammar = Pat{
|
||||||
whitespace = Set(" \t\r\26") + newline + Set("(),;") + comment + linecomment,
|
whitespace = Set(" \t\r\26") + newline + Set("(),;") + comment + linecomment,
|
||||||
|
|
||||||
t_identifier_all = t_broken_identifier + t_good_identifier,
|
t_identifier_all = t_broken_identifier + t_good_identifier,
|
||||||
-- NOTE: -con.keyword alone would be wrong, e.g. "state breakobject":
|
-- NOTE: -conl.keyword alone would be wrong, e.g. "state breakobject":
|
||||||
-- NOTE 2: The + "[" is so that stuff like
|
-- NOTE 2: The + "[" is so that stuff like
|
||||||
-- getactor[THISACTOR].x x
|
-- getactor[THISACTOR].x x
|
||||||
-- getactor[THISACTOR].y y
|
-- getactor[THISACTOR].y y
|
||||||
|
@ -1325,7 +1328,7 @@ local Grammar = Pat{
|
||||||
-- getactor[THISACTOR].x x
|
-- getactor[THISACTOR].x x
|
||||||
-- getactor [THISACTOR].y y
|
-- getactor [THISACTOR].y y
|
||||||
-- This is in need of cleanup!
|
-- This is in need of cleanup!
|
||||||
t_identifier = -NotKeyw(con.keyword * (sp1 + "[")) * lpeg.C(t_identifier_all),
|
t_identifier = -NotKeyw(conl.keyword * (sp1 + "[")) * lpeg.C(t_identifier_all),
|
||||||
t_define = (POS() * lpeg.C(t_maybe_minus) * t_identifier / lookup_defined_label) + t_number,
|
t_define = (POS() * lpeg.C(t_maybe_minus) * t_identifier / lookup_defined_label) + t_number,
|
||||||
|
|
||||||
t_move =
|
t_move =
|
||||||
|
@ -1402,7 +1405,7 @@ local function do_flatten_codetab(code, intotab)
|
||||||
local elt = code[i]
|
local elt = code[i]
|
||||||
|
|
||||||
if (type(elt)=="string") then
|
if (type(elt)=="string") then
|
||||||
intotab[#intotab+1] = code[i]
|
intotab[#intotab+1] = elt
|
||||||
elseif (type(elt)=="table") then
|
elseif (type(elt)=="table") then
|
||||||
do_flatten_codetab(elt, intotab)
|
do_flatten_codetab(elt, intotab)
|
||||||
else
|
else
|
||||||
|
@ -1531,7 +1534,7 @@ if (not _EDUKE32_LUNATIC) then
|
||||||
--[[
|
--[[
|
||||||
local file = io.stdout
|
local file = io.stdout
|
||||||
for filename,codetab in pairs(g_file_code) do
|
for filename,codetab in pairs(g_file_code) do
|
||||||
file:write(string.format("-- GENERATED CODE (%s):\n", filename))
|
file:write(format("-- GENERATED CODE for \"%s\":\n", filename))
|
||||||
file:write(table.concat(flatten_codetab(codetab), "\n"))
|
file:write(table.concat(flatten_codetab(codetab), "\n"))
|
||||||
file:write("\n")
|
file:write("\n")
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue