1
0
Fork 0
mirror of https://github.com/Reuh/candran.git synced 2025-10-27 17:59:30 +00:00

Fix #set changing global state

This commit is contained in:
Étienne Fildadut 2021-06-18 15:26:33 +02:00
parent b32d4d5600
commit 56f1901f9b
2 changed files with 251 additions and 245 deletions

View file

@ -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

View file

@ -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