diff options
author | Matthew Wild <mwild1@gmail.com> | 2009-02-13 14:38:17 +0000 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2009-02-13 14:38:17 +0000 |
commit | d5a03594832f7050536d88c38be4009a64de207b (patch) | |
tree | 0d7df5037b68b7acfa0ac1804b608f53c0140ae7 /core/configmanager.lua | |
parent | 13fd316d82218961b88a4a3d96fa25f0ab41cc3d (diff) | |
download | prosody-d5a03594832f7050536d88c38be4009a64de207b.tar.gz prosody-d5a03594832f7050536d88c38be4009a64de207b.zip |
Add Include command to include extra configuration files from the main one
Diffstat (limited to 'core/configmanager.lua')
-rw-r--r-- | core/configmanager.lua | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/core/configmanager.lua b/core/configmanager.lua index d0e70670..63a9cf89 100644 --- a/core/configmanager.lua +++ b/core/configmanager.lua @@ -9,8 +9,8 @@ local _G = _G; -local setmetatable, loadfile, pcall, rawget, rawset, io = - setmetatable, loadfile, pcall, rawget, rawset, io; +local setmetatable, loadfile, pcall, rawget, rawset, io, error = + setmetatable, loadfile, pcall, rawget, rawset, io, error; module "configmanager" @@ -97,7 +97,8 @@ do function parsers.lua.load(data) local env; -- The ' = true' are needed so as not to set off __newindex when we assign the functions below - env = setmetatable({ Host = true; host = true; Component = true, component = true }, { __index = function (t, k) + env = setmetatable({ Host = true; host = true; Component = true, component = true, + Include = true, include = true }, { __index = function (t, k) return rawget(_G, k) or function (settings_table) config[__currenthost or "*"][k] = settings_table; @@ -124,6 +125,18 @@ do end env.component = env.Component; + function env.Include(file) + local f, err = io.open(file); + if f then + local data = f:read("*a"); + local ok, err = parsers.lua.load(data); + if not ok then error(err:gsub("%[string.-%]", file), 0); end + end + if not f then error("Error loading included "..file..": "..err, 0); end + return f, err; + end + env.include = env.Include; + local chunk, err = loadstring(data); if not chunk then |