Comparison

core/configmanager.lua @ 3012:6d86e26f0923

Merge configmanager->trunk
author Matthew Wild <mwild1@gmail.com>
date Wed, 05 May 2010 19:01:14 +0100
parent 2985:fde53d82fde0
parent 3011:1189a29cd846
child 3384:b7600dd7cd42
comparison
equal deleted inserted replaced
3010:52146b82f295 3012:6d86e26f0923
112 parsers.lua = {}; 112 parsers.lua = {};
113 function parsers.lua.load(data, filename) 113 function parsers.lua.load(data, filename)
114 local env; 114 local env;
115 -- The ' = true' are needed so as not to set off __newindex when we assign the functions below 115 -- The ' = true' are needed so as not to set off __newindex when we assign the functions below
116 env = setmetatable({ 116 env = setmetatable({
117 Host = true; host = true; Component = true, component = true, 117 Host = true, host = true, VirtualHost = true,
118 Component = true, component = true,
118 Include = true, include = true, RunScript = dofile }, { 119 Include = true, include = true, RunScript = dofile }, {
119 __index = function (t, k) 120 __index = function (t, k)
120 return rawget(_G, k) or 121 return rawget(_G, k) or
121 function (settings_table) 122 function (settings_table)
122 config[__currenthost or "*"][k] = settings_table; 123 config[__currenthost or "*"][k] = settings_table;
126 set(env.__currenthost or "*", "core", k, v); 127 set(env.__currenthost or "*", "core", k, v);
127 end 128 end
128 }); 129 });
129 130
130 rawset(env, "__currenthost", "*") -- Default is global 131 rawset(env, "__currenthost", "*") -- Default is global
131 function env.Host(name) 132 function env.VirtualHost(name)
132 if rawget(config, name) and rawget(config[name].core, "component_module") then 133 if rawget(config, name) and rawget(config[name].core, "component_module") then
133 error(format("Host %q clashes with previously defined %s Component %q, for services use a sub-domain like conference.%s", 134 error(format("Host %q clashes with previously defined %s Component %q, for services use a sub-domain like conference.%s",
134 name, config[name].core.component_module:gsub("^%a+$", { component = "external", muc = "MUC"}), name, name), 0); 135 name, config[name].core.component_module:gsub("^%a+$", { component = "external", muc = "MUC"}), name, name), 0);
135 end 136 end
136 rawset(env, "__currenthost", name); 137 rawset(env, "__currenthost", name);
137 -- Needs at least one setting to logically exist :) 138 -- Needs at least one setting to logically exist :)
138 set(name or "*", "core", "defined", true); 139 set(name or "*", "core", "defined", true);
139 end 140 end
140 env.host = env.Host; 141 env.Host, env.host = env.VirtualHost, env.VirtualHost;
141 142
142 function env.Component(name) 143 function env.Component(name)
143 if rawget(config, name) and rawget(config[name].core, "defined") and not rawget(config[name].core, "component_module") then 144 if rawget(config, name) and rawget(config[name].core, "defined") and not rawget(config[name].core, "component_module") then
144 error(format("Component %q clashes with previously defined Host %q, for services use a sub-domain like conference.%s", 145 error(format("Component %q clashes with previously defined Host %q, for services use a sub-domain like conference.%s",
145 name, name, name), 0); 146 name, name, name), 0);