summaryrefslogtreecommitdiff
path: root/lib/gitano/plugins.lua
blob: bdc6d1e1cb7addc7078de1c02e0f2e05f34a0a05 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
-- gitano.plugins
--
-- Plugin loading support for Gitano
--
-- Copyright 2014 Daniel Silverstone <daniel.silverstone@codethink.co.uk>

local util = require "gitano.util"
local log = require "gitano.log"

local luxio = require "luxio"
local sio = require "luxio.simple"

local gfind = string.gfind

local plugin_name_pattern = "^(.+)%.lua$"

local function find_plugins(path)
   local ret = {}
   for _, entry in ipairs(path) do
      local dirp, err = sio.opendir(entry)
      if not dirp then
         log.warning(("Unable to scan plugin directory '%s': %s")
                     :format(entry, err))
      else
         for filename, fileinfo in dirp:iterate() do
            local plugin_name = filename:match(plugin_name_pattern)
            if plugin_name and fileinfo.d_type == luxio.DT_REG then
               if not ret[plugin_name] then
                  ret[plugin_name] = entry
                  ret[#ret + 1] = plugin_name
               end
            end
         end
      end
   end
   table.sort(ret)
   return ret
end

local function load_plugins(path)
   local to_load = find_plugins(path)
   for _, plugin_name in ipairs(to_load) do
      local filepath = util.path_join(to_load[plugin_name],
                                      plugin_name .. ".lua")
      local chunk, err = loadfile(filepath)
      if not chunk then
         log.warning(("Failure loading plugin '%s' from '%s': %s")
                     :format(plugin_name, to_load[plugin_name],
                             err))
      else
         local ok, err = pcall(chunk)
         if not ok then
            log.warning(("Failure running plugin '%s' from '%s': %s")
                        :format(plugin_name, to_load[plugin_name],
                                err))
         end
      end
   end
end

return {
   load_plugins = load_plugins,
}