Marty Oehme
ece30350c2
Options were previously set ad-hoc in the initialize function, but re-set and overwritten at various places. Options now live in one central module (options.lua), where they directly access the neovim options set, and re-access them on any run. That means options can be changed while the plugin is running and it will use their newer versions, without requiring any re-initialization.
45 lines
1.4 KiB
Lua
45 lines
1.4 KiB
Lua
local ls = {}
|
|
|
|
local function isDirectory(ftype)
|
|
if ftype == 'directory' then return true end
|
|
return false
|
|
end
|
|
|
|
-- TODO transform paths:
|
|
-- * to absolute value (e.g. ~ to home, scandir needs absolute)
|
|
-- * to ensure / at the end (or no /) gets taken into account
|
|
function ls.get_anchors_and_paths(path, recursive, options)
|
|
options = options or {}
|
|
-- TODO check for duplicates and warn user
|
|
local zettel = {}
|
|
local anchorreg = '^.*/?([%d][%d][%d][%d][%d][%d][%d][%d][%d][%d])[^/]*%' ..
|
|
(options.zettel_extension or '.md') .. '$'
|
|
|
|
local handle = vim.loop.fs_scandir(path)
|
|
while handle do
|
|
local name, ftype = vim.loop.fs_scandir_next(handle)
|
|
if not name then break end
|
|
|
|
if isDirectory(ftype) and recursive then
|
|
local subdir = ls.get_anchors_and_paths(path .. "/" .. name, true)
|
|
for k, v in pairs(subdir) do zettel[tostring(k)] = v end
|
|
end
|
|
|
|
local anchor = string.match(name, anchorreg)
|
|
if anchor then zettel[tostring(anchor)] = name end
|
|
end
|
|
return zettel
|
|
end
|
|
|
|
-- Returns the path to the zettel defined by the anchor argument.
|
|
-- Take a list of zettel as an optional variable, without which
|
|
-- it will use the (recursive) results of the zettel_root directory.
|
|
function ls.get_zettel(anchor, all)
|
|
if not all then all = ls.get_anchors_and_paths('somepath') end
|
|
|
|
return all[anchor]
|
|
end
|
|
|
|
function ls.open_zettel(anchor, all) end
|
|
|
|
return ls
|