mirror of
https://github.com/Reuh/candran.git
synced 2025-10-27 09:59:29 +00:00
Fix #set changing global state
This commit is contained in:
parent
b32d4d5600
commit
56f1901f9b
2 changed files with 251 additions and 245 deletions
10
candran.can
10
candran.can
|
|
@ -53,7 +53,7 @@ end
|
||||||
-- @treturn[1] macros registered macros
|
-- @treturn[1] macros registered macros
|
||||||
-- @treturn[2] nil nil if error
|
-- @treturn[2] nil nil if error
|
||||||
-- @treturn[2] error string error message
|
-- @treturn[2] error string error message
|
||||||
function candran.preprocess(input, options={})
|
function candran.preprocess(input, options={}, _env)
|
||||||
options = util.merge(candran.default, options)
|
options = util.merge(candran.default, options)
|
||||||
local macros = {
|
local macros = {
|
||||||
functions = {},
|
functions = {},
|
||||||
|
|
@ -98,6 +98,7 @@ function candran.preprocess(input, options={})
|
||||||
preprocessor ..= "return output"
|
preprocessor ..= "return output"
|
||||||
|
|
||||||
-- make preprocessor environement
|
-- make preprocessor environement
|
||||||
|
local exportenv = {}
|
||||||
local env = util.merge(_G, options.preprocessorEnv)
|
local env = util.merge(_G, options.preprocessorEnv)
|
||||||
--- Candran library table
|
--- Candran library table
|
||||||
env.candran = candran
|
env.candran = candran
|
||||||
|
|
@ -118,8 +119,9 @@ function candran.preprocess(input, options={})
|
||||||
|
|
||||||
margs = util.merge(options, { chunkname = filepath, loadLocal = true, loadPackage = true }, margs)
|
margs = util.merge(options, { chunkname = filepath, loadLocal = true, loadPackage = true }, margs)
|
||||||
margs.import = {} -- no need for recursive import
|
margs.import = {} -- no need for recursive import
|
||||||
local modcontent, modmacros = assert(candran.preprocess(f:read("*a"), margs))
|
local modcontent, modmacros, modenv = assert(candran.preprocess(f:read("*a"), margs))
|
||||||
macros = util.recmerge(macros, modmacros)
|
macros = util.recmerge(macros, modmacros)
|
||||||
|
for k, v in pairs(modenv) do env[k] = v end
|
||||||
f:close()
|
f:close()
|
||||||
|
|
||||||
-- get module name (ex: module name of path.to.module is module)
|
-- get module name (ex: module name of path.to.module is module)
|
||||||
|
|
@ -185,7 +187,7 @@ function candran.preprocess(input, options={})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
env.set = function(identifier, value)
|
env.set = function(identifier, value)
|
||||||
options.preprocessorEnv[identifier] = value
|
exportenv[identifier] = value
|
||||||
env[identifier] = value
|
env[identifier] = value
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
@ -215,7 +217,7 @@ function candran.preprocess(input, options={})
|
||||||
return nil, "in preprocessor: "..output
|
return nil, "in preprocessor: "..output
|
||||||
end
|
end
|
||||||
|
|
||||||
return output, macros
|
return output, macros, exportenv
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Run the compiler
|
--- Run the compiler
|
||||||
|
|
|
||||||
486
candran.lua
486
candran.lua
|
|
@ -7038,7 +7038,7 @@ candran["default"]["target"] = "lua52" -- candran.can:44
|
||||||
elseif _VERSION == "Lua 5.3" then -- candran.can:45
|
elseif _VERSION == "Lua 5.3" then -- candran.can:45
|
||||||
candran["default"]["target"] = "lua53" -- candran.can:46
|
candran["default"]["target"] = "lua53" -- candran.can:46
|
||||||
end -- candran.can:46
|
end -- candran.can:46
|
||||||
candran["preprocess"] = function(input, options) -- candran.can:56
|
candran["preprocess"] = function(input, options, _env) -- candran.can:56
|
||||||
if options == nil then options = {} end -- candran.can:56
|
if options == nil then options = {} end -- candran.can:56
|
||||||
options = util["merge"](candran["default"], options) -- candran.can:57
|
options = util["merge"](candran["default"], options) -- candran.can:57
|
||||||
local macros = { -- candran.can:58
|
local macros = { -- candran.can:58
|
||||||
|
|
@ -7082,262 +7082,266 @@ end -- candran.can:94
|
||||||
end -- candran.can:94
|
end -- candran.can:94
|
||||||
end -- candran.can:94
|
end -- candran.can:94
|
||||||
preprocessor = preprocessor .. ("return output") -- candran.can:98
|
preprocessor = preprocessor .. ("return output") -- candran.can:98
|
||||||
local env = util["merge"](_G, options["preprocessorEnv"]) -- candran.can:101
|
local exportenv = {} -- candran.can:101
|
||||||
env["candran"] = candran -- candran.can:103
|
local env = util["merge"](_G, options["preprocessorEnv"]) -- candran.can:102
|
||||||
env["output"] = "" -- candran.can:105
|
env["candran"] = candran -- candran.can:104
|
||||||
env["import"] = function(modpath, margs) -- candran.can:112
|
env["output"] = "" -- candran.can:106
|
||||||
if margs == nil then margs = {} end -- candran.can:112
|
env["import"] = function(modpath, margs) -- candran.can:113
|
||||||
local filepath = assert(util["search"](modpath, { -- candran.can:113
|
if margs == nil then margs = {} end -- candran.can:113
|
||||||
"can", -- candran.can:113
|
local filepath = assert(util["search"](modpath, { -- candran.can:114
|
||||||
"lua" -- candran.can:113
|
"can", -- candran.can:114
|
||||||
}), "No module named \"" .. modpath .. "\"") -- candran.can:113
|
"lua" -- candran.can:114
|
||||||
local f = io["open"](filepath) -- candran.can:116
|
}), "No module named \"" .. modpath .. "\"") -- candran.can:114
|
||||||
if not f then -- candran.can:117
|
local f = io["open"](filepath) -- candran.can:117
|
||||||
error("can't open the module file to import") -- candran.can:117
|
if not f then -- candran.can:118
|
||||||
end -- candran.can:117
|
error("can't open the module file to import") -- candran.can:118
|
||||||
margs = util["merge"](options, { -- candran.can:119
|
end -- candran.can:118
|
||||||
["chunkname"] = filepath, -- candran.can:119
|
margs = util["merge"](options, { -- candran.can:120
|
||||||
["loadLocal"] = true, -- candran.can:119
|
["chunkname"] = filepath, -- candran.can:120
|
||||||
["loadPackage"] = true -- candran.can:119
|
["loadLocal"] = true, -- candran.can:120
|
||||||
}, margs) -- candran.can:119
|
["loadPackage"] = true -- candran.can:120
|
||||||
margs["import"] = {} -- candran.can:120
|
}, margs) -- candran.can:120
|
||||||
local modcontent, modmacros = assert(candran["preprocess"](f:read("*a"), margs)) -- candran.can:121
|
margs["import"] = {} -- candran.can:121
|
||||||
macros = util["recmerge"](macros, modmacros) -- candran.can:122
|
local modcontent, modmacros, modenv = assert(candran["preprocess"](f:read("*a"), margs)) -- candran.can:122
|
||||||
f:close() -- candran.can:123
|
macros = util["recmerge"](macros, modmacros) -- candran.can:123
|
||||||
local modname = modpath:match("[^%.]+$") -- candran.can:126
|
for k, v in pairs(modenv) do -- candran.can:124
|
||||||
|
env[k] = v -- candran.can:124
|
||||||
|
end -- candran.can:124
|
||||||
|
f:close() -- candran.can:125
|
||||||
|
local modname = modpath:match("[^%.]+$") -- candran.can:128
|
||||||
env["write"]("-- MODULE " .. modpath .. " --\
|
env["write"]("-- MODULE " .. modpath .. " --\
|
||||||
" .. "local function _()\
|
" .. "local function _()\
|
||||||
" .. modcontent .. "\
|
" .. modcontent .. "\
|
||||||
" .. "end\
|
" .. "end\
|
||||||
" .. (margs["loadLocal"] and ("local %s = _() or %s\
|
" .. (margs["loadLocal"] and ("local %s = _() or %s\
|
||||||
"):format(modname, modname) or "") .. (margs["loadPackage"] and ("package.loaded[%q] = %s or true\
|
"):format(modname, modname) or "") .. (margs["loadPackage"] and ("package.loaded[%q] = %s or true\
|
||||||
"):format(modpath, margs["loadLocal"] and modname or "_()") or "") .. "-- END OF MODULE " .. modpath .. " --") -- candran.can:135
|
"):format(modpath, margs["loadLocal"] and modname or "_()") or "") .. "-- END OF MODULE " .. modpath .. " --") -- candran.can:137
|
||||||
end -- candran.can:135
|
end -- candran.can:137
|
||||||
env["include"] = function(file) -- candran.can:140
|
env["include"] = function(file) -- candran.can:142
|
||||||
local f = io["open"](file) -- candran.can:141
|
local f = io["open"](file) -- candran.can:143
|
||||||
if not f then -- candran.can:142
|
if not f then -- candran.can:144
|
||||||
error("can't open the file " .. file .. " to include") -- candran.can:142
|
error("can't open the file " .. file .. " to include") -- candran.can:144
|
||||||
end -- candran.can:142
|
|
||||||
env["write"](f:read("*a")) -- candran.can:143
|
|
||||||
f:close() -- candran.can:144
|
|
||||||
end -- candran.can:144
|
end -- candran.can:144
|
||||||
env["write"] = function(...) -- candran.can:148
|
env["write"](f:read("*a")) -- candran.can:145
|
||||||
|
f:close() -- candran.can:146
|
||||||
|
end -- candran.can:146
|
||||||
|
env["write"] = function(...) -- candran.can:150
|
||||||
env["output"] = env["output"] .. (table["concat"]({ ... }, "\9") .. "\
|
env["output"] = env["output"] .. (table["concat"]({ ... }, "\9") .. "\
|
||||||
") -- candran.can:149
|
") -- candran.can:151
|
||||||
end -- candran.can:149
|
end -- candran.can:151
|
||||||
env["placeholder"] = function(name) -- candran.can:153
|
env["placeholder"] = function(name) -- candran.can:155
|
||||||
if env[name] then -- candran.can:154
|
if env[name] then -- candran.can:156
|
||||||
env["write"](env[name]) -- candran.can:155
|
env["write"](env[name]) -- candran.can:157
|
||||||
end -- candran.can:155
|
end -- candran.can:157
|
||||||
end -- candran.can:155
|
end -- candran.can:157
|
||||||
env["define"] = function(identifier, replacement) -- candran.can:158
|
env["define"] = function(identifier, replacement) -- candran.can:160
|
||||||
local iast, ierr = parser["parsemacroidentifier"](identifier, options["chunkname"]) -- candran.can:160
|
local iast, ierr = parser["parsemacroidentifier"](identifier, options["chunkname"]) -- candran.can:162
|
||||||
if not iast then -- candran.can:161
|
if not iast then -- candran.can:163
|
||||||
return error(("in macro identifier: %s"):format(tostring(ierr))) -- candran.can:162
|
return error(("in macro identifier: %s"):format(tostring(ierr))) -- candran.can:164
|
||||||
end -- candran.can:162
|
end -- candran.can:164
|
||||||
if type(replacement) == "string" then -- candran.can:165
|
if type(replacement) == "string" then -- candran.can:167
|
||||||
local rast, rerr = parser["parse"](replacement, options["chunkname"]) -- candran.can:166
|
local rast, rerr = parser["parse"](replacement, options["chunkname"]) -- candran.can:168
|
||||||
if not rast then -- candran.can:167
|
if not rast then -- candran.can:169
|
||||||
return error(("in macro replacement: %s"):format(tostring(rerr))) -- candran.can:168
|
return error(("in macro replacement: %s"):format(tostring(rerr))) -- candran.can:170
|
||||||
end -- candran.can:168
|
end -- candran.can:170
|
||||||
if # rast == 1 and rast[1]["tag"] == "Push" and rast[1]["implicit"] then -- candran.can:171
|
if # rast == 1 and rast[1]["tag"] == "Push" and rast[1]["implicit"] then -- candran.can:173
|
||||||
rast = rast[1][1] -- candran.can:172
|
rast = rast[1][1] -- candran.can:174
|
||||||
end -- candran.can:172
|
end -- candran.can:174
|
||||||
replacement = rast -- candran.can:174
|
replacement = rast -- candran.can:176
|
||||||
elseif type(replacement) ~= "function" then -- candran.can:175
|
elseif type(replacement) ~= "function" then -- candran.can:177
|
||||||
error("bad argument #2 to 'define' (string or function expected)") -- candran.can:176
|
error("bad argument #2 to 'define' (string or function expected)") -- candran.can:178
|
||||||
end -- candran.can:176
|
end -- candran.can:178
|
||||||
if iast["tag"] == "MacroFunction" then -- candran.can:179
|
if iast["tag"] == "MacroFunction" then -- candran.can:181
|
||||||
macros["functions"][iast[1][1]] = { -- candran.can:180
|
macros["functions"][iast[1][1]] = { -- candran.can:182
|
||||||
["args"] = iast[2], -- candran.can:180
|
["args"] = iast[2], -- candran.can:182
|
||||||
["replacement"] = replacement -- candran.can:180
|
["replacement"] = replacement -- candran.can:182
|
||||||
} -- candran.can:180
|
} -- candran.can:182
|
||||||
elseif iast["tag"] == "Id" then -- candran.can:181
|
elseif iast["tag"] == "Id" then -- candran.can:183
|
||||||
macros["variables"][iast[1]] = replacement -- candran.can:182
|
macros["variables"][iast[1]] = replacement -- candran.can:184
|
||||||
else -- candran.can:182
|
else -- candran.can:184
|
||||||
error(("invalid macro type %s"):format(tostring(iast["tag"]))) -- candran.can:184
|
error(("invalid macro type %s"):format(tostring(iast["tag"]))) -- candran.can:186
|
||||||
end -- candran.can:184
|
end -- candran.can:186
|
||||||
end -- candran.can:184
|
end -- candran.can:186
|
||||||
env["set"] = function(identifier, value) -- candran.can:187
|
env["set"] = function(identifier, value) -- candran.can:189
|
||||||
options["preprocessorEnv"][identifier] = value -- candran.can:188
|
exportenv[identifier] = value -- candran.can:190
|
||||||
env[identifier] = value -- candran.can:189
|
env[identifier] = value -- candran.can:191
|
||||||
end -- candran.can:189
|
end -- candran.can:191
|
||||||
if options["builtInMacros"] then -- candran.can:193
|
if options["builtInMacros"] then -- candran.can:195
|
||||||
env["define"]("__STR__(x)", function(x) -- candran.can:194
|
env["define"]("__STR__(x)", function(x) -- candran.can:196
|
||||||
return ("%q"):format(x) -- candran.can:194
|
return ("%q"):format(x) -- candran.can:196
|
||||||
end) -- candran.can:194
|
end) -- candran.can:196
|
||||||
local s = require("candran.serpent") -- candran.can:195
|
local s = require("candran.serpent") -- candran.can:197
|
||||||
env["define"]("__CONSTEXPR__(expr)", function(expr) -- candran.can:196
|
env["define"]("__CONSTEXPR__(expr)", function(expr) -- candran.can:198
|
||||||
return s["block"](assert(candran["load"](expr))(), { ["fatal"] = true }) -- candran.can:197
|
return s["block"](assert(candran["load"](expr))(), { ["fatal"] = true }) -- candran.can:199
|
||||||
end) -- candran.can:197
|
end) -- candran.can:199
|
||||||
end -- candran.can:197
|
end -- candran.can:199
|
||||||
local preprocess, err = candran["compile"](preprocessor, options) -- candran.can:202
|
local preprocess, err = candran["compile"](preprocessor, options) -- candran.can:204
|
||||||
if not preprocess then -- candran.can:203
|
if not preprocess then -- candran.can:205
|
||||||
return nil, "in preprocessor: " .. err -- candran.can:204
|
return nil, "in preprocessor: " .. err -- candran.can:206
|
||||||
end -- candran.can:204
|
end -- candran.can:206
|
||||||
preprocess, err = util["load"](preprocessor, "candran preprocessor", env) -- candran.can:207
|
preprocess, err = util["load"](preprocessor, "candran preprocessor", env) -- candran.can:209
|
||||||
if not preprocess then -- candran.can:208
|
if not preprocess then -- candran.can:210
|
||||||
return nil, "in preprocessor: " .. err -- candran.can:209
|
return nil, "in preprocessor: " .. err -- candran.can:211
|
||||||
end -- candran.can:209
|
end -- candran.can:211
|
||||||
local success, output = pcall(preprocess) -- candran.can:213
|
local success, output = pcall(preprocess) -- candran.can:215
|
||||||
if not success then -- candran.can:214
|
if not success then -- candran.can:216
|
||||||
return nil, "in preprocessor: " .. output -- candran.can:215
|
return nil, "in preprocessor: " .. output -- candran.can:217
|
||||||
end -- candran.can:215
|
end -- candran.can:217
|
||||||
return output, macros -- candran.can:218
|
return output, macros, exportenv -- candran.can:220
|
||||||
end -- candran.can:218
|
end -- candran.can:220
|
||||||
candran["compile"] = function(input, options, macros) -- candran.can:228
|
candran["compile"] = function(input, options, macros) -- candran.can:230
|
||||||
if options == nil then options = {} end -- candran.can:228
|
if options == nil then options = {} end -- candran.can:230
|
||||||
options = util["merge"](candran["default"], options) -- candran.can:229
|
options = util["merge"](candran["default"], options) -- candran.can:231
|
||||||
local ast, errmsg = parser["parse"](input, options["chunkname"]) -- candran.can:231
|
local ast, errmsg = parser["parse"](input, options["chunkname"]) -- candran.can:233
|
||||||
if not ast then -- candran.can:233
|
if not ast then -- candran.can:235
|
||||||
return nil, errmsg -- candran.can:234
|
return nil, errmsg -- candran.can:236
|
||||||
end -- candran.can:234
|
end -- candran.can:236
|
||||||
return require("compiler." .. options["target"])(input, ast, options, macros) -- candran.can:237
|
return require("compiler." .. options["target"])(input, ast, options, macros) -- candran.can:239
|
||||||
end -- candran.can:237
|
end -- candran.can:239
|
||||||
candran["make"] = function(code, options) -- candran.can:246
|
candran["make"] = function(code, options) -- candran.can:248
|
||||||
local r, err = candran["preprocess"](code, options) -- candran.can:247
|
local r, err = candran["preprocess"](code, options) -- candran.can:249
|
||||||
if r then -- candran.can:248
|
|
||||||
r, err = candran["compile"](r, options, err) -- candran.can:249
|
|
||||||
if r then -- candran.can:250
|
if r then -- candran.can:250
|
||||||
return r -- candran.can:251
|
r, err = candran["compile"](r, options, err) -- candran.can:251
|
||||||
end -- candran.can:251
|
if r then -- candran.can:252
|
||||||
end -- candran.can:251
|
return r -- candran.can:253
|
||||||
return r, err -- candran.can:254
|
end -- candran.can:253
|
||||||
end -- candran.can:254
|
end -- candran.can:253
|
||||||
local errorRewritingActive = false -- candran.can:257
|
return r, err -- candran.can:256
|
||||||
local codeCache = {} -- candran.can:258
|
end -- candran.can:256
|
||||||
candran["loadfile"] = function(filepath, env, options) -- candran.can:261
|
local errorRewritingActive = false -- candran.can:259
|
||||||
local f, err = io["open"](filepath) -- candran.can:262
|
local codeCache = {} -- candran.can:260
|
||||||
if not f then -- candran.can:263
|
candran["loadfile"] = function(filepath, env, options) -- candran.can:263
|
||||||
return nil, ("cannot open %s"):format(tostring(err)) -- candran.can:264
|
local f, err = io["open"](filepath) -- candran.can:264
|
||||||
end -- candran.can:264
|
if not f then -- candran.can:265
|
||||||
local content = f:read("*a") -- candran.can:266
|
return nil, ("cannot open %s"):format(tostring(err)) -- candran.can:266
|
||||||
f:close() -- candran.can:267
|
end -- candran.can:266
|
||||||
return candran["load"](content, filepath, env, options) -- candran.can:269
|
local content = f:read("*a") -- candran.can:268
|
||||||
end -- candran.can:269
|
f:close() -- candran.can:269
|
||||||
candran["load"] = function(chunk, chunkname, env, options) -- candran.can:274
|
return candran["load"](content, filepath, env, options) -- candran.can:271
|
||||||
if options == nil then options = {} end -- candran.can:274
|
end -- candran.can:271
|
||||||
options = util["merge"]({ ["chunkname"] = tostring(chunkname or chunk) }, options) -- candran.can:275
|
candran["load"] = function(chunk, chunkname, env, options) -- candran.can:276
|
||||||
local code, err = candran["make"](chunk, options) -- candran.can:277
|
if options == nil then options = {} end -- candran.can:276
|
||||||
if not code then -- candran.can:278
|
options = util["merge"]({ ["chunkname"] = tostring(chunkname or chunk) }, options) -- candran.can:277
|
||||||
return code, err -- candran.can:279
|
local code, err = candran["make"](chunk, options) -- candran.can:279
|
||||||
end -- candran.can:279
|
if not code then -- candran.can:280
|
||||||
codeCache[options["chunkname"]] = code -- candran.can:282
|
return code, err -- candran.can:281
|
||||||
local f -- candran.can:283
|
end -- candran.can:281
|
||||||
f, err = util["load"](code, ("=%s(%s)"):format(options["chunkname"], "compiled candran"), env) -- candran.can:284
|
codeCache[options["chunkname"]] = code -- candran.can:284
|
||||||
if f == nil then -- candran.can:289
|
local f -- candran.can:285
|
||||||
return f, "candran unexpectedly generated invalid code: " .. err -- candran.can:290
|
f, err = util["load"](code, ("=%s(%s)"):format(options["chunkname"], "compiled candran"), env) -- candran.can:286
|
||||||
end -- candran.can:290
|
if f == nil then -- candran.can:291
|
||||||
if options["rewriteErrors"] == false then -- candran.can:293
|
return f, "candran unexpectedly generated invalid code: " .. err -- candran.can:292
|
||||||
return f -- candran.can:294
|
end -- candran.can:292
|
||||||
else -- candran.can:294
|
if options["rewriteErrors"] == false then -- candran.can:295
|
||||||
return function(...) -- candran.can:296
|
return f -- candran.can:296
|
||||||
if not errorRewritingActive then -- candran.can:297
|
else -- candran.can:296
|
||||||
errorRewritingActive = true -- candran.can:298
|
return function(...) -- candran.can:298
|
||||||
local t = { xpcall(f, candran["messageHandler"], ...) } -- candran.can:299
|
if not errorRewritingActive then -- candran.can:299
|
||||||
errorRewritingActive = false -- candran.can:300
|
errorRewritingActive = true -- candran.can:300
|
||||||
if t[1] == false then -- candran.can:301
|
local t = { xpcall(f, candran["messageHandler"], ...) } -- candran.can:301
|
||||||
error(t[2], 0) -- candran.can:302
|
errorRewritingActive = false -- candran.can:302
|
||||||
end -- candran.can:302
|
if t[1] == false then -- candran.can:303
|
||||||
return unpack(t, 2) -- candran.can:304
|
error(t[2], 0) -- candran.can:304
|
||||||
else -- candran.can:304
|
end -- candran.can:304
|
||||||
return f(...) -- candran.can:306
|
return unpack(t, 2) -- candran.can:306
|
||||||
end -- candran.can:306
|
else -- candran.can:306
|
||||||
end -- candran.can:306
|
return f(...) -- candran.can:308
|
||||||
end -- candran.can:306
|
end -- candran.can:308
|
||||||
end -- candran.can:306
|
end -- candran.can:308
|
||||||
candran["dofile"] = function(filename, options) -- candran.can:314
|
end -- candran.can:308
|
||||||
local f, err = candran["loadfile"](filename, nil, options) -- candran.can:315
|
end -- candran.can:308
|
||||||
if f == nil then -- candran.can:317
|
candran["dofile"] = function(filename, options) -- candran.can:316
|
||||||
error(err) -- candran.can:318
|
local f, err = candran["loadfile"](filename, nil, options) -- candran.can:317
|
||||||
else -- candran.can:318
|
if f == nil then -- candran.can:319
|
||||||
return f() -- candran.can:320
|
error(err) -- candran.can:320
|
||||||
end -- candran.can:320
|
else -- candran.can:320
|
||||||
end -- candran.can:320
|
return f() -- candran.can:322
|
||||||
candran["messageHandler"] = function(message, noTraceback) -- candran.can:326
|
end -- candran.can:322
|
||||||
message = tostring(message) -- candran.can:327
|
end -- candran.can:322
|
||||||
|
candran["messageHandler"] = function(message, noTraceback) -- candran.can:328
|
||||||
|
message = tostring(message) -- candran.can:329
|
||||||
if not noTraceback and not message:match("\
|
if not noTraceback and not message:match("\
|
||||||
stack traceback:\
|
stack traceback:\
|
||||||
") then -- candran.can:328
|
") then -- candran.can:330
|
||||||
message = debug["traceback"](message, 2) -- candran.can:329
|
message = debug["traceback"](message, 2) -- candran.can:331
|
||||||
end -- candran.can:329
|
end -- candran.can:331
|
||||||
return message:gsub("(\
|
return message:gsub("(\
|
||||||
?%s*)([^\
|
?%s*)([^\
|
||||||
]-)%:(%d+)%:", function(indentation, source, line) -- candran.can:331
|
]-)%:(%d+)%:", function(indentation, source, line) -- candran.can:333
|
||||||
line = tonumber(line) -- candran.can:332
|
line = tonumber(line) -- candran.can:334
|
||||||
local originalFile -- candran.can:334
|
local originalFile -- candran.can:336
|
||||||
local strName = source:match("^(.-)%(compiled candran%)$") -- candran.can:335
|
local strName = source:match("^(.-)%(compiled candran%)$") -- candran.can:337
|
||||||
if strName then -- candran.can:336
|
if strName then -- candran.can:338
|
||||||
if codeCache[strName] then -- candran.can:337
|
if codeCache[strName] then -- candran.can:339
|
||||||
originalFile = codeCache[strName] -- candran.can:338
|
originalFile = codeCache[strName] -- candran.can:340
|
||||||
source = strName -- candran.can:339
|
source = strName -- candran.can:341
|
||||||
end -- candran.can:339
|
end -- candran.can:341
|
||||||
else -- candran.can:339
|
else -- candran.can:341
|
||||||
do -- candran.can:342
|
do -- candran.can:344
|
||||||
local fi -- candran.can:342
|
local fi -- candran.can:344
|
||||||
fi = io["open"](source, "r") -- candran.can:342
|
fi = io["open"](source, "r") -- candran.can:344
|
||||||
if fi then -- candran.can:342
|
if fi then -- candran.can:344
|
||||||
originalFile = fi:read("*a") -- candran.can:343
|
originalFile = fi:read("*a") -- candran.can:345
|
||||||
fi:close() -- candran.can:344
|
fi:close() -- candran.can:346
|
||||||
end -- candran.can:344
|
end -- candran.can:346
|
||||||
end -- candran.can:344
|
end -- candran.can:346
|
||||||
end -- candran.can:344
|
end -- candran.can:346
|
||||||
if originalFile then -- candran.can:348
|
if originalFile then -- candran.can:350
|
||||||
local i = 0 -- candran.can:349
|
local i = 0 -- candran.can:351
|
||||||
for l in (originalFile .. "\
|
for l in (originalFile .. "\
|
||||||
"):gmatch("([^\
|
"):gmatch("([^\
|
||||||
]*)\
|
]*)\
|
||||||
") do -- candran.can:350
|
") do -- candran.can:352
|
||||||
i = i + 1 -- candran.can:351
|
i = i + 1 -- candran.can:353
|
||||||
if i == line then -- candran.can:352
|
if i == line then -- candran.can:354
|
||||||
local extSource, lineMap = l:match(".*%-%- (.-)%:(%d+)$") -- candran.can:353
|
local extSource, lineMap = l:match(".*%-%- (.-)%:(%d+)$") -- candran.can:355
|
||||||
if lineMap then -- candran.can:354
|
if lineMap then -- candran.can:356
|
||||||
if extSource ~= source then -- candran.can:355
|
if extSource ~= source then -- candran.can:357
|
||||||
return indentation .. extSource .. ":" .. lineMap .. "(" .. extSource .. ":" .. line .. "):" -- candran.can:356
|
return indentation .. extSource .. ":" .. lineMap .. "(" .. extSource .. ":" .. line .. "):" -- candran.can:358
|
||||||
else -- candran.can:356
|
else -- candran.can:358
|
||||||
return indentation .. extSource .. ":" .. lineMap .. "(" .. line .. "):" -- candran.can:358
|
return indentation .. extSource .. ":" .. lineMap .. "(" .. line .. "):" -- candran.can:360
|
||||||
end -- candran.can:358
|
end -- candran.can:360
|
||||||
end -- candran.can:358
|
end -- candran.can:360
|
||||||
break -- candran.can:361
|
break -- candran.can:363
|
||||||
end -- candran.can:361
|
end -- candran.can:363
|
||||||
end -- candran.can:361
|
end -- candran.can:363
|
||||||
end -- candran.can:361
|
end -- candran.can:363
|
||||||
end) -- candran.can:361
|
end) -- candran.can:363
|
||||||
end -- candran.can:361
|
end -- candran.can:363
|
||||||
candran["searcher"] = function(modpath) -- candran.can:369
|
candran["searcher"] = function(modpath) -- candran.can:371
|
||||||
local filepath = util["search"](modpath, { "can" }) -- candran.can:370
|
local filepath = util["search"](modpath, { "can" }) -- candran.can:372
|
||||||
if not filepath then -- candran.can:371
|
if not filepath then -- candran.can:373
|
||||||
if _VERSION == "Lua 5.4" then -- candran.can:372
|
if _VERSION == "Lua 5.4" then -- candran.can:374
|
||||||
return "no candran file in package.path" -- candran.can:373
|
return "no candran file in package.path" -- candran.can:375
|
||||||
else -- candran.can:373
|
else -- candran.can:375
|
||||||
return "\
|
return "\
|
||||||
\9no candran file in package.path" -- candran.can:375
|
\9no candran file in package.path" -- candran.can:377
|
||||||
end -- candran.can:375
|
end -- candran.can:377
|
||||||
end -- candran.can:375
|
end -- candran.can:377
|
||||||
return function(modpath) -- candran.can:378
|
return function(modpath) -- candran.can:380
|
||||||
local r, s = candran["loadfile"](filepath) -- candran.can:379
|
local r, s = candran["loadfile"](filepath) -- candran.can:381
|
||||||
if r then -- candran.can:380
|
if r then -- candran.can:382
|
||||||
return r(modpath, filepath) -- candran.can:381
|
return r(modpath, filepath) -- candran.can:383
|
||||||
else -- candran.can:381
|
else -- candran.can:383
|
||||||
error(("error loading candran module '%s' from file '%s':\
|
error(("error loading candran module '%s' from file '%s':\
|
||||||
\9%s"):format(modpath, filepath, tostring(s)), 0) -- candran.can:383
|
\9%s"):format(modpath, filepath, tostring(s)), 0) -- candran.can:385
|
||||||
end -- candran.can:383
|
|
||||||
end, filepath -- candran.can:385
|
|
||||||
end -- candran.can:385
|
end -- candran.can:385
|
||||||
candran["setup"] = function() -- candran.can:389
|
end, filepath -- candran.can:387
|
||||||
local searchers = (function() -- candran.can:390
|
end -- candran.can:387
|
||||||
if _VERSION == "Lua 5.1" then -- candran.can:390
|
candran["setup"] = function() -- candran.can:391
|
||||||
return package["loaders"] -- candran.can:391
|
local searchers = (function() -- candran.can:392
|
||||||
else -- candran.can:391
|
if _VERSION == "Lua 5.1" then -- candran.can:392
|
||||||
return package["searchers"] -- candran.can:393
|
return package["loaders"] -- candran.can:393
|
||||||
end -- candran.can:393
|
else -- candran.can:393
|
||||||
end)() -- candran.can:393
|
return package["searchers"] -- candran.can:395
|
||||||
for _, s in ipairs(searchers) do -- candran.can:396
|
end -- candran.can:395
|
||||||
if s == candran["searcher"] then -- candran.can:397
|
end)() -- candran.can:395
|
||||||
return candran -- candran.can:398
|
for _, s in ipairs(searchers) do -- candran.can:398
|
||||||
end -- candran.can:398
|
if s == candran["searcher"] then -- candran.can:399
|
||||||
end -- candran.can:398
|
return candran -- candran.can:400
|
||||||
table["insert"](searchers, 1, candran["searcher"]) -- candran.can:402
|
end -- candran.can:400
|
||||||
return candran -- candran.can:403
|
end -- candran.can:400
|
||||||
end -- candran.can:403
|
table["insert"](searchers, 1, candran["searcher"]) -- candran.can:404
|
||||||
return candran -- candran.can:406
|
return candran -- candran.can:405
|
||||||
|
end -- candran.can:405
|
||||||
|
return candran -- candran.can:408
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue