diff options
author | Matthew Wild <mwild1@gmail.com> | 2012-04-21 20:09:03 +0100 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2012-04-21 20:09:03 +0100 |
commit | 1c88e91a1990b795c0d358f5b6d38c3d28288ea5 (patch) | |
tree | 8635d2724e1715ce919859072cab050f5b9ee49d | |
parent | 800fd50ce0934689db0afaf6966ec6ba78f06eec (diff) | |
download | prosody-1c88e91a1990b795c0d358f5b6d38c3d28288ea5.tar.gz prosody-1c88e91a1990b795c0d358f5b6d38c3d28288ea5.zip |
modulemanager: Support for shared modules - function module.add_host(host_module) in a global module
-rw-r--r-- | core/modulemanager.lua | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/core/modulemanager.lua b/core/modulemanager.lua index 769041f9..e76f2624 100644 --- a/core/modulemanager.lua +++ b/core/modulemanager.lua @@ -132,6 +132,21 @@ local function do_load_module(host, module_name) log("warn", "%s is already loaded for %s, so not loading again", module_name, host); return nil, "module-already-loaded"; elseif modulemap["*"][module_name] then + local mod = modulemap["*"][module_name]; + if module_has_method(mod, "add_host") then + local _log = logger.init(host..":"..module_name); + local host_module_api = setmetatable({ + host = host, event_handlers = {}, items = {}; + _log = _log, log = function (self, ...) return _log(...); end; + },{ + __index = modulemap["*"][module_name].module; + }); + local ok, result, module_err = call_module_method(mod, "add_host", host_module_api); + if not ok or result == false then return nil, ok and module_err or result; end + local host_module = setmetatable({ module = host_module_api }, { __index = mod }); + modulemap[host][module_name] = host_module; + return host_module; + end return nil, "global-module-already-loaded"; end |