aboutsummaryrefslogtreecommitdiffstats
path: root/util/pluginloader.lua
diff options
context:
space:
mode:
Diffstat (limited to 'util/pluginloader.lua')
-rw-r--r--util/pluginloader.lua65
1 files changed, 48 insertions, 17 deletions
diff --git a/util/pluginloader.lua b/util/pluginloader.lua
index 9ab8f245..f2ccb4cb 100644
--- a/util/pluginloader.lua
+++ b/util/pluginloader.lua
@@ -8,18 +8,23 @@
-- luacheck: ignore 113/CFG_PLUGINDIR
local dir_sep, path_sep = package.config:match("^(%S+)%s(%S+)");
+local lua_version = _VERSION:match(" (.+)$");
local plugin_dir = {};
for path in (CFG_PLUGINDIR or "./plugins/"):gsub("[/\\]", dir_sep):gmatch("[^"..path_sep.."]+") do
path = path..dir_sep; -- add path separator to path end
- path = path:gsub(dir_sep..dir_sep.."+", dir_sep); -- coalesce multiple separaters
+ path = path:gsub(dir_sep..dir_sep.."+", dir_sep); -- coalesce multiple separators
plugin_dir[#plugin_dir + 1] = path;
end
local io_open = io.open;
local envload = require "util.envload".envload;
-local function load_file(names)
+local pluginloader_methods = {};
+local pluginloader_mt = { __index = pluginloader_methods };
+
+function pluginloader_methods:load_file(names)
local file, err, path;
+ local load_filter_cb = self._options.load_filter_cb;
for i=1,#plugin_dir do
for j=1,#names do
path = plugin_dir[i]..names[j];
@@ -27,39 +32,49 @@ local function load_file(names)
if file then
local content = file:read("*a");
file:close();
- return content, path;
+ local metadata;
+ if load_filter_cb then
+ path, content, metadata = load_filter_cb(path, content);
+ end
+ if content and path then
+ return content, path, metadata;
+ end
end
end
end
return file, err;
end
-local function load_resource(plugin, resource)
+function pluginloader_methods:load_resource(plugin, resource)
resource = resource or "mod_"..plugin..".lua";
-
local names = {
"mod_"..plugin..dir_sep..plugin..dir_sep..resource; -- mod_hello/hello/mod_hello.lua
"mod_"..plugin..dir_sep..resource; -- mod_hello/mod_hello.lua
plugin..dir_sep..resource; -- hello/mod_hello.lua
resource; -- mod_hello.lua
+ "share"..dir_sep.."lua"..dir_sep..lua_version..dir_sep..resource;
+ "share"..dir_sep.."lua"..dir_sep..lua_version..dir_sep.."mod_"..plugin..dir_sep..resource;
};
- return load_file(names);
+ return self:load_file(names);
end
-local function load_code(plugin, resource, env)
- local content, err = load_resource(plugin, resource);
+function pluginloader_methods:load_code(plugin, resource, env)
+ local content, err, metadata = self:load_resource(plugin, resource);
if not content then return content, err; end
local path = err;
local f, err = envload(content, "@"..path, env);
if not f then return f, err; end
- return f, path;
+ return f, path, metadata;
end
-local function load_code_ext(plugin, resource, extension, env)
- local content, err = load_resource(plugin, resource.."."..extension);
+function pluginloader_methods:load_code_ext(plugin, resource, extension, env)
+ local content, err, metadata = self:load_resource(plugin, resource.."."..extension);
+ if not content and extension == "lib.lua" then
+ content, err, metadata = self:load_resource(plugin, resource..".lua");
+ end
if not content then
- content, err = load_resource(resource, resource.."."..extension);
+ content, err, metadata = self:load_resource(resource, resource.."."..extension);
if not content then
return content, err;
end
@@ -67,12 +82,28 @@ local function load_code_ext(plugin, resource, extension, env)
local path = err;
local f, err = envload(content, "@"..path, env);
if not f then return f, err; end
- return f, path;
+ return f, path, metadata;
+end
+
+local function init(options)
+ return setmetatable({
+ _options = options or {};
+ }, pluginloader_mt);
end
+local function bind(self, method)
+ return function (...)
+ return method(self, ...);
+ end;
+end
+
+local default_loader = init();
+
return {
- load_file = load_file;
- load_resource = load_resource;
- load_code = load_code;
- load_code_ext = load_code_ext;
+ load_file = bind(default_loader, default_loader.load_file);
+ load_resource = bind(default_loader, default_loader.load_resource);
+ load_code = bind(default_loader, default_loader.load_code);
+ load_code_ext = bind(default_loader, default_loader.load_code_ext);
+
+ init = init;
};