diff options
author | Kim Alvefur <zash@zash.se> | 2017-03-01 16:42:02 +0100 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2017-03-01 16:42:02 +0100 |
commit | 70941b5f818b6e94cce03c9b3c83e3169fae5f68 (patch) | |
tree | 9da5479b278d4444bf80cf2720ebf0ba3688d197 | |
parent | 4de415d6700cd0f1ab4111cdf4c5f5cb7161c766 (diff) | |
download | prosody-70941b5f818b6e94cce03c9b3c83e3169fae5f68.tar.gz prosody-70941b5f818b6e94cce03c9b3c83e3169fae5f68.zip |
util.envload: Open file here instead of letting loadfile do it so that all return values from io.open can be collected
-rw-r--r-- | util/envload.lua | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/util/envload.lua b/util/envload.lua index 3c5190df..08adf35e 100644 --- a/util/envload.lua +++ b/util/envload.lua @@ -6,7 +6,8 @@ -- -- luacheck: ignore 113/setfenv -local load, loadstring, loadfile, setfenv = load, loadstring, loadfile, setfenv; +local load, loadstring, setfenv = load, loadstring, setfenv; +local io_open = io.open; local envload; local envloadfile; @@ -18,7 +19,9 @@ if setfenv then end function envloadfile(file, env) - local f, err = loadfile(file); + local fh, err, errno = io_open(file); + if not fh then return fh, err, errno; end + local f, err = load(function () return fh:read(2048); end, "@"..file); if f and env then setfenv(f, env); end return f, err; end @@ -28,7 +31,9 @@ else end function envloadfile(file, env) - return loadfile(file, nil, env); + local fh, err, errno = io_open(file); + if not fh then return fh, err, errno; end + return load(fh:lines(2048), "@"..file, nil, env); end end |