aboutsummaryrefslogtreecommitdiffstats
path: root/core/configmanager.lua
diff options
context:
space:
mode:
authorMatthew Wild <mwild1@gmail.com>2009-02-13 14:38:17 +0000
committerMatthew Wild <mwild1@gmail.com>2009-02-13 14:38:17 +0000
commitd5a03594832f7050536d88c38be4009a64de207b (patch)
tree0d7df5037b68b7acfa0ac1804b608f53c0140ae7 /core/configmanager.lua
parent13fd316d82218961b88a4a3d96fa25f0ab41cc3d (diff)
downloadprosody-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.lua19
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