Lunatic translator standalone: option specifying a directory for gen'd code.

The option is -fgendir=<directory>.

git-svn-id: https://svn.eduke32.com/eduke32@3540 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2013-03-03 16:06:32 +00:00
parent aeeec9d2aa
commit 596b3e6d6a

View file

@ -98,8 +98,8 @@ local g_defaultDir = nil
local g_warn = { ["not-redefined"]=true, ["bad-identifier"]=true, local g_warn = { ["not-redefined"]=true, ["bad-identifier"]=true,
["number-conversion"]=true, ["system-gamevar"]=true, } ["number-conversion"]=true, ["system-gamevar"]=true, }
-- Code generation options. -- Code generation and output options.
local g_cgopt = { ["no"]=false, ["debug-lineinfo"]=false, } local g_cgopt = { ["no"]=false, ["debug-lineinfo"]=false, ["gendir"]=nil, }
-- How many 'if' statements are following immediately each other, -- How many 'if' statements are following immediately each other,
-- needed to cope with CONs dangling-else resolution -- needed to cope with CONs dangling-else resolution
@ -3031,6 +3031,11 @@ local function handle_cmdline_arg(str)
g_cgopt["no"] = true g_cgopt["no"] = true
ok = true ok = true
end end
elseif (str:sub(2,8)=="fgendir") then
if (#str >= 10 and str:sub(9,9)=="=") then
g_cgopt["gendir"] = str:sub(10)
ok = true
end
elseif (str:sub(2)=="fdebug-lineinfo") then elseif (str:sub(2)=="fdebug-lineinfo") then
g_cgopt["debug-lineinfo"] = true g_cgopt["debug-lineinfo"] = true
ok = true ok = true
@ -3079,7 +3084,17 @@ if (string.dump) then
local function compile(filename) local function compile(filename)
reset_all() reset_all()
g_directory = filename:match("(.*/)") or "" -- Construct file name for the output code: (...)/xxx/qwe.con -->
-- xxx_qwe.con, so that common root CON file names like EDUKE.CON will
-- result in distinct file names for different mods. From that name,
-- strip the extension.
local codedir = g_cgopt["gendir"]
local codefn = codedir and
codedir.."/"..filename:match("[^/]+/[^/]+$"):gsub('/','_')..".lua"
-- Get the directory part...
g_directory = filename:match(".*/") or ""
-- ...and the file name alone.
filename = filename:sub(#g_directory+1, -1) filename = filename:sub(#g_directory+1, -1)
-- NOTE: xpcall isn't useful here since the traceback won't give us -- NOTE: xpcall isn't useful here since the traceback won't give us
@ -3094,23 +3109,27 @@ if (string.dump) then
if (not (g_cgopt["no"]==true)) then if (not (g_cgopt["no"]==true)) then
local onlycheck = (g_cgopt["no"] == "onlycheck") local onlycheck = (g_cgopt["no"] == "onlycheck")
local file = onlycheck and io.stdout or io.stderr -- The file for the output messages:
local msgfile = onlycheck and io.stdout or io.stderr
local code, lineinfo = get_code_string(g_curcode, g_cgopt["debug-lineinfo"]) local code, lineinfo = get_code_string(g_curcode, g_cgopt["debug-lineinfo"])
local func, errmsg = loadstring(code, "CON") local func, errmsg = loadstring(code, "CON")
-- file:write(format("-- GENERATED CODE for \"%s\":\n", filename)) -- msgfile:write(format("-- GENERATED CODE for \"%s\":\n", filename))
if (func == nil) then if (func == nil) then
file:write(format("-- INVALID Lua CODE: %s\n", errmsg)) msgfile:write(format("-- INVALID Lua CODE: %s\n", errmsg))
end end
if (lineinfo) then if (lineinfo) then
for i=1,#lineinfo.llines do for i=1,#lineinfo.llines do
file:write(format("%d -> %s:%d\n", i, lineinfo:getfline(i))) msgfile:write(format("%d -> %s:%d\n", i, lineinfo:getfline(i)))
end end
elseif (not onlycheck) then elseif (not onlycheck) then
file:write(code) -- The file for the generated code:
file:write("\n") local codefile = codefn and assert(io.open(codefn, "w+")) or msgfile
codefile:write(code)
codefile:write("\n")
end end
end end
end end