zettelkasten.nvim/lua/zettelkasten/list.lua

53 lines
1.6 KiB
Lua
Raw Normal View History

local ls = {}
local o = require 'zettelkasten.options'
local function isDirectory(ftype)
2020-10-29 18:00:23 +00:00
if ftype == 'directory' then return true end
return false
end
2020-11-06 16:28:05 +00:00
local function cleanPath(path)
if path:match("^~") then path = os.getenv("HOME") .. path:sub(2) end
return path
end
2020-10-29 18:00:23 +00:00
-- 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)
2020-10-29 18:00:23 +00:00
-- TODO check for duplicates and warn user
local zettel = {}
local anchorreg = '^.*/?(' .. o.anchor().regex .. ')[^/]*%' ..
o.zettel().extension .. '$'
2020-11-06 16:28:05 +00:00
path = cleanPath(path)
2020-10-29 18:00:23 +00:00
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
2020-10-29 18:00:23 +00:00
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
2020-10-29 18:00:23 +00:00
local anchor = string.match(name, anchorreg)
2020-11-06 16:28:05 +00:00
if anchor then zettel[tostring(anchor)] = path .. "/" .. name end
end
2020-10-29 18:00:23 +00:00
return zettel
end
2020-10-30 12:48:17 +00:00
-- 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)
all = all or ls.get_anchors_and_paths(o.zettel().rootdir, true)
if not all then return end
2020-10-30 12:48:17 +00:00
return all[anchor]
end
return ls