mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
Lunatic translator: codegen fixes, setgamepalette, -fno=onlycheck option.
git-svn-id: https://svn.eduke32.com/eduke32@3523 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
0354e38843
commit
b92c487c6f
4 changed files with 53 additions and 25 deletions
|
@ -1291,7 +1291,7 @@ function _getlastpal(spritenum)
|
|||
end
|
||||
|
||||
-- G_GetAngleDelta(a1, a2)
|
||||
function _angdiffabs(a1, a2)
|
||||
function _angdiff(a1, a2)
|
||||
a1 = bit.band(a1, 2047)
|
||||
a2 = bit.band(a2, 2047)
|
||||
-- a1 and a2 are in [0, 2047]
|
||||
|
@ -1557,6 +1557,10 @@ function _setaspect(viewingrange, yxaspect)
|
|||
ffiC.setaspect(viewingrange, yxaspect)
|
||||
end
|
||||
|
||||
function _setgamepalette(pli, basepal)
|
||||
ffiC.P_SetGamePalette(player[pli], basepal)
|
||||
end
|
||||
|
||||
|
||||
--- Game arrays ---
|
||||
|
||||
|
@ -1762,7 +1766,7 @@ local peractorvar_mt = {
|
|||
-- * All values equal to the default one are cleared.
|
||||
__call = function(acv)
|
||||
for i=0,ffiC.MAXSPRITES-1 do
|
||||
if (ffiC.sprite[i].statnum == ffiC.MAXSTATUS or acv[i]==acv._defval) then
|
||||
if (ffiC.sprite[i].statnum == ffiC.MAXSTATUS or rawget(acv, i)==acv._defval) then
|
||||
rawset(acv, i, nil)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -144,7 +144,8 @@ __attribute__((packed)) struct {
|
|||
const int16_t owner;
|
||||
int16_t movflag,tempang,timetosleep; //6b
|
||||
|
||||
const int16_t lightId, lightcount, lightmaxrange, cgg; //8b
|
||||
const int16_t lightId, lightcount, lightmaxrange;
|
||||
int16_t cgg;
|
||||
int16_t actorstayput;
|
||||
const int16_t dispicnum;
|
||||
int16_t shootzvel;
|
||||
|
@ -528,6 +529,7 @@ int32_t G_CheckActivatorMotion(int32_t lotag);
|
|||
int32_t A_Dodge(spritetype *s);
|
||||
int32_t A_MoveSprite(int32_t spritenum, const vec3_t *change, uint32_t cliptype);
|
||||
void P_DoQuote(int32_t q, DukePlayer_t *p);
|
||||
void P_SetGamePalette(DukePlayer_t *player, uint8_t palid, int32_t set);
|
||||
void G_AddUserQuote(const char *daquote);
|
||||
void G_ClearCameraView(DukePlayer_t *ps);
|
||||
void G_DrawTileGeneric(int32_t x, int32_t y, int32_t zoom, int32_t tilenum,
|
||||
|
|
|
@ -137,6 +137,7 @@ G_CheckActivatorMotion;
|
|||
A_Dodge;
|
||||
A_MoveSprite;
|
||||
P_DoQuote;
|
||||
P_SetGamePalette;
|
||||
G_AddUserQuote;
|
||||
G_ClearCameraView;
|
||||
G_DrawTileGeneric;
|
||||
|
|
|
@ -14,6 +14,7 @@ local arg = arg
|
|||
|
||||
local assert = assert
|
||||
local ipairs = ipairs
|
||||
local loadstring = loadstring
|
||||
local pairs = pairs
|
||||
local pcall = pcall
|
||||
local print = print
|
||||
|
@ -93,7 +94,7 @@ local g_warn = { ["not-redefined"]=true, ["bad-identifier"]=true,
|
|||
["number-conversion"]=true, ["system-gamevar"]=true, }
|
||||
|
||||
-- Code generation options.
|
||||
local g_cgopt = { ["no"]=false, ["_incomplete"]=false, }
|
||||
local g_cgopt = { ["no"]=false, }
|
||||
|
||||
-- How many 'if' statements are following immediately each other,
|
||||
-- needed to cope with CONs dangling-else resolution
|
||||
|
@ -1271,7 +1272,7 @@ local varop = cmd(W,D)
|
|||
local varvarop = cmd(W,R)
|
||||
|
||||
local function varopf(op)
|
||||
if (#op == 1) then
|
||||
if (#op <= 2) then
|
||||
return varop / ("%1=%1"..op.."%2")
|
||||
else
|
||||
return varop / ("%1="..op.."(%1,%2)")
|
||||
|
@ -1279,7 +1280,7 @@ local function varopf(op)
|
|||
end
|
||||
|
||||
local function varvaropf(op)
|
||||
if (#op == 1) then
|
||||
if (#op <= 2) then
|
||||
return varvarop / ("%1=%1"..op.."%2")
|
||||
else
|
||||
return varvarop / ("%1="..op.."(%1,%2)")
|
||||
|
@ -1504,6 +1505,7 @@ local handle =
|
|||
{
|
||||
NYI = function()
|
||||
errprintf("command `%s' not yet implemented", g_lastkw)
|
||||
return ""
|
||||
end,
|
||||
|
||||
dynNYI = function()
|
||||
|
@ -1554,7 +1556,8 @@ local handle =
|
|||
|
||||
qsprintf = function(qdst, qsrc, ...)
|
||||
local codes = {...}
|
||||
return format("_con._qsprintf(%d,%d,%s)", qdst, qsrc, table.concat(codes, ','))
|
||||
return format("_con._qsprintf(%d,%d%s%s)", qdst, qsrc,
|
||||
#codes>0 and "," or "", table.concat(codes, ','))
|
||||
end,
|
||||
|
||||
move = function(mv, ...)
|
||||
|
@ -1641,7 +1644,9 @@ local Cinner = {
|
|||
|
||||
setvarvar = varvarop / "%1=%2",
|
||||
addvarvar = varvaropf "+",
|
||||
subvarvar = varvaropf "-",
|
||||
-- NOTE the space after the minus sign so that e.g. "subvar x -1" won't get
|
||||
-- translated to "x=x--1" (-- being the Lua line comment start).
|
||||
subvarvar = varvaropf "- ",
|
||||
mulvarvar = varvaropf "*",
|
||||
divvarvar = varvaropf "_con._div",
|
||||
modvarvar = varvaropf "_con._mod",
|
||||
|
@ -1652,7 +1657,7 @@ local Cinner = {
|
|||
|
||||
setvar = varop / "%1=%2",
|
||||
addvar = varopf "+",
|
||||
subvar = varopf "-",
|
||||
subvar = varopf "- ",
|
||||
mulvar = varopf "*",
|
||||
divvar = varopf "_con._div",
|
||||
modvar = varopf "_con._mod",
|
||||
|
@ -1746,7 +1751,8 @@ local Cinner = {
|
|||
/ "_con._echo(%1)",
|
||||
activatecheat = cmd(R)
|
||||
/ handle.NYI,
|
||||
setgamepalette = cmd(R),
|
||||
setgamepalette = cmd(R)
|
||||
/ "_con._setgamepalette(_pli,%1)",
|
||||
|
||||
-- Sound commands
|
||||
sound = cmd(D)
|
||||
|
@ -1951,7 +1957,7 @@ local Cinner = {
|
|||
/ handle.dynNYI,
|
||||
savegamevar = cmd(R)
|
||||
/ handle.dynNYI,
|
||||
readgamevar = cmd(R)
|
||||
readgamevar = cmd(W)
|
||||
/ handle.dynNYI,
|
||||
savenn = cmd(D)
|
||||
/ handle.dynNYI,
|
||||
|
@ -2096,8 +2102,10 @@ local Cinner = {
|
|||
|
||||
setaspect = cmd(R,R)
|
||||
/ "_con._setaspect(%1,%2)",
|
||||
showview = cmd(R,R,R,R,R,R,R,R,R,R), -- 10R
|
||||
showviewunbiased = cmd(R,R,R,R,R,R,R,R,R,R), -- 10R
|
||||
showview = cmd(R,R,R,R,R,R,R,R,R,R) -- 10R
|
||||
/ "", -- TODO
|
||||
showviewunbiased = cmd(R,R,R,R,R,R,R,R,R,R) -- 10R
|
||||
/ "", -- TODO
|
||||
smaxammo = cmd(R,R)
|
||||
/ PLS":set_max_ammo_amount(%1,%2)",
|
||||
gmaxammo = cmd(R,W)
|
||||
|
@ -2386,7 +2394,7 @@ local function after_if_cmd_Cmt(subj, pos, ...)
|
|||
return nil
|
||||
end
|
||||
|
||||
if (not g_cgopt["_incomplete"] and capts[1] ~= nil) then
|
||||
if (capts[1] ~= nil) then
|
||||
assert(#capts <= 3)
|
||||
for i=1,#capts do
|
||||
assert(type(capts[i]=="string"))
|
||||
|
@ -2870,14 +2878,15 @@ local function handle_cmdline_arg(str)
|
|||
g_warn[warnstr] = val
|
||||
ok = true
|
||||
end
|
||||
elseif (str:sub(2)=="fno") then
|
||||
elseif (str:sub(2,4)=="fno") then
|
||||
-- Disable printing code.
|
||||
g_cgopt["no"] = true
|
||||
ok = true
|
||||
elseif (str:sub(2)=="f_incomplete") then
|
||||
-- TEMP
|
||||
g_cgopt["_incomplete"] = true
|
||||
ok = true
|
||||
if (#str >= 5 and str:sub(5)=="=onlycheck") then
|
||||
g_cgopt["no"] = "onlycheck"
|
||||
ok = true
|
||||
else
|
||||
g_cgopt["no"] = true
|
||||
ok = true
|
||||
end
|
||||
elseif (kind=="I" and #str >= 3) then
|
||||
-- default directory (only ONCE, not search path)
|
||||
g_defaultDir = str:sub(3)
|
||||
|
@ -2936,11 +2945,23 @@ if (string.dump) then
|
|||
print_on_failure(msg)
|
||||
end
|
||||
|
||||
if (not g_cgopt["no"]) then
|
||||
local file = require("io").stderr
|
||||
if (not (g_cgopt["no"]==true)) then
|
||||
local onlycheck = (g_cgopt["no"] == "onlycheck")
|
||||
local io = require("io")
|
||||
local file = onlycheck and io.stdout or io.stderr
|
||||
|
||||
local code = get_code_string(g_curcode)
|
||||
local func, errmsg = loadstring(code, "CON")
|
||||
|
||||
file:write(format("-- GENERATED CODE for \"%s\":\n", filename))
|
||||
file:write(get_code_string(g_curcode))
|
||||
file:write("\n")
|
||||
if (func == nil) then
|
||||
file:write(format("-- (invalid Lua code: %s)\n", errmsg))
|
||||
end
|
||||
|
||||
if (not onlycheck) then
|
||||
file:write(code)
|
||||
file:write("\n")
|
||||
end
|
||||
end
|
||||
end
|
||||
else
|
||||
|
|
Loading…
Reference in a new issue