Reformat lua code with lua-format
This commit is contained in:
parent
a365cef6c7
commit
e5afcb5e15
4 changed files with 236 additions and 203 deletions
|
@ -5,9 +5,12 @@ local ls = require'zettelkasten.list'
|
|||
function ZK.init(vimapi)
|
||||
vim = vimapi or vim
|
||||
ZK.options = {
|
||||
anchor_separator = vim.g["zettel_anchor_separator"] or vim.b["zettel_anchor_separator"] or "_",
|
||||
zettel_extension = vim.g["zettel_extension"] or vim.b["zettel_extension"] or ".md",
|
||||
zettel_root = vim.g["zettel_root"] or vim.b["zettel_root"] or "~/documents/notes",
|
||||
anchor_separator = vim.g["zettel_anchor_separator"] or
|
||||
vim.b["zettel_anchor_separator"] or "_",
|
||||
zettel_extension = vim.g["zettel_extension"] or
|
||||
vim.b["zettel_extension"] or ".md"
|
||||
-- zettel_root = vim.g["zettel_root"] or vim.b["zettel_root"] or "~/documents/notes",
|
||||
-- TODO zettel_anchor_pattern = regex? -> needs custom creation function in `create_anchor`
|
||||
}
|
||||
end
|
||||
|
||||
|
@ -44,12 +47,12 @@ function ZK.create_link(text, date)
|
|||
text = "" .. ZK.create_anchor(date)
|
||||
else
|
||||
text = text:lower():gsub(" ", "-")
|
||||
text = "" .. ZK.create_anchor(date) .. o.anchor_separator .. text
|
||||
text = "" .. ZK.create_anchor(date) .. (o.anchor_separator or "_") ..
|
||||
text
|
||||
end
|
||||
return text .. (o.zettel_extension or ".md")
|
||||
end
|
||||
|
||||
|
||||
-- Returns all zettel in path as a
|
||||
-- { "anchor" = "path/to/zettel/anchor filename.md" }
|
||||
-- table.
|
||||
|
@ -63,5 +66,5 @@ return {
|
|||
zettel_link_create = ZK.zettel_link_create,
|
||||
create_anchor = ZK.create_anchor,
|
||||
create_link = ZK.create_link,
|
||||
get_zettel_list = ZK.get_zettel_list,
|
||||
get_zettel_list = ZK.get_zettel_list
|
||||
}
|
||||
|
|
|
@ -2,16 +2,16 @@ ZK = require'zettelkasten.init'
|
|||
Test_date = {year = 2019, month = 10, day = 29, hour = 16, min = 45}
|
||||
|
||||
describe("Zettelkasten", function()
|
||||
before_each(function()
|
||||
ZK.init({ g={}, b={} })
|
||||
end)
|
||||
before_each(function() ZK.init({g = {}, b = {}}) end)
|
||||
|
||||
describe("anchor creation", function()
|
||||
it("should return zettel anchor from time passed in", function()
|
||||
assert.same("1910291645", ZK.create_anchor(Test_date))
|
||||
end)
|
||||
|
||||
it("should return zettel anchor from current moment if no argument passed in", function()
|
||||
it(
|
||||
"should return zettel anchor from current moment if no argument passed in",
|
||||
function()
|
||||
assert.same(os.date('%y%m%d%H%M'), ZK.create_anchor())
|
||||
end)
|
||||
|
||||
|
@ -21,32 +21,41 @@ describe("Zettelkasten", function()
|
|||
end)
|
||||
|
||||
describe("link creation", function()
|
||||
it("should return a markdown link with only zettel anchor on no text passed in", function()
|
||||
it(
|
||||
"should return a markdown link with only zettel anchor on no text passed in",
|
||||
function()
|
||||
assert.same("1910291645.md", ZK.create_link(nil, Test_date))
|
||||
end)
|
||||
|
||||
it("should text to link", function()
|
||||
assert.same("1910291645_isappended.md", ZK.create_link("isappended", Test_date))
|
||||
assert.same("1910291645_isappended.md",
|
||||
ZK.create_link("isappended", Test_date))
|
||||
end)
|
||||
|
||||
it("should return lowercased link text", function()
|
||||
assert.same("1910291645_yesiamshouting.md", ZK.create_link("YESIAMSHOUTING", Test_date))
|
||||
assert.same("1910291645_yesiamshouting.md",
|
||||
ZK.create_link("YESIAMSHOUTING", Test_date))
|
||||
end)
|
||||
|
||||
it("should return spaces in text replaced with dashes", function()
|
||||
assert.same("1910291645_yes-indeed-a-space.md", ZK.create_link("yes indeed a space", Test_date))
|
||||
assert.same("1910291645_yes-indeed-a-space.md",
|
||||
ZK.create_link("yes indeed a space", Test_date))
|
||||
end)
|
||||
|
||||
it("should place the contents of g:zettel_anchor_separator variable in link", function()
|
||||
it(
|
||||
"should place the contents of g:zettel_anchor_separator variable in link",
|
||||
function()
|
||||
vim = {g = {zettel_anchor_separator = "SEP"}, b = {}}
|
||||
ZK.init(vim)
|
||||
assert.same("1910291645SEParated.md", ZK.create_link("arated", Test_date))
|
||||
assert.same("1910291645SEParated.md",
|
||||
ZK.create_link("arated", Test_date))
|
||||
end)
|
||||
|
||||
it("should append the filetype set in g:zettel_extension", function()
|
||||
vim = {g = {zettel_extension = ".something"}, b = {}}
|
||||
ZK.init(vim)
|
||||
assert.same("1910291645_theworld.something", ZK.create_link("theworld", Test_date))
|
||||
assert.same("1910291645_theworld.something",
|
||||
ZK.create_link("theworld", Test_date))
|
||||
end)
|
||||
end)
|
||||
|
||||
|
|
|
@ -20,15 +20,11 @@ function ls.get_anchors_and_paths(path, recursive)
|
|||
|
||||
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
|
||||
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
|
||||
if anchor then zettel[tostring(anchor)] = name end
|
||||
end
|
||||
return zettel
|
||||
end
|
||||
|
|
|
@ -15,42 +15,44 @@ describe("zettel listing", function()
|
|||
return true
|
||||
end
|
||||
end,
|
||||
fs_scandir_next = function() return table.remove(files) end
|
||||
fs_scandir_next = function()
|
||||
return table.remove(files)
|
||||
end
|
||||
}
|
||||
}
|
||||
end
|
||||
end)
|
||||
|
||||
it("should return anchor-keyed table pointing to filename of zettel", function()
|
||||
it("should return anchor-keyed table pointing to filename of zettel",
|
||||
function()
|
||||
local file_list = {"1910291645 this-is-a-testfile.md"}
|
||||
ZK.init(get_api_mock(file_list))
|
||||
|
||||
local expected = { ["1910291645"] = "1910291645 this-is-a-testfile.md", }
|
||||
local expected = {["1910291645"] = "1910291645 this-is-a-testfile.md"}
|
||||
assert.same(expected, ZK.get_zettel_list("someDir"))
|
||||
end)
|
||||
|
||||
it("should ignore any malformed files", function()
|
||||
local file_list = {
|
||||
"2010261208 this-should-be-picked-up.md",
|
||||
"1910291645 this-is-a-testfile.md",
|
||||
"this-is-not-a-testfile.md",
|
||||
"1910271456 this-is-wrong-extension.txt",
|
||||
"1812 this-is-ignored.md",
|
||||
"1910291645 this-is-a-testfile.md", "this-is-not-a-testfile.md",
|
||||
"1910271456 this-is-wrong-extension.txt", "1812 this-is-ignored.md"
|
||||
}
|
||||
ZK.init(get_api_mock(file_list))
|
||||
|
||||
local expected = {
|
||||
["1910291645"] = "1910291645 this-is-a-testfile.md",
|
||||
["2010261208"] = "2010261208 this-should-be-picked-up.md",
|
||||
["2010261208"] = "2010261208 this-should-be-picked-up.md"
|
||||
}
|
||||
assert.same(expected, ZK.get_zettel_list("someDir"))
|
||||
end)
|
||||
|
||||
it("should recurse into directories if recursive argument passed in ", function()
|
||||
it("should recurse into directories if recursive argument passed in ",
|
||||
function()
|
||||
local files = {
|
||||
{"1910271456 testfile.md", "file"},
|
||||
{"more-notes-here", "directory"},
|
||||
{ "2010261208 another-testfile.md", "file" },
|
||||
{"2010261208 another-testfile.md", "file"}
|
||||
}
|
||||
local vim_api_mock = {
|
||||
g = {},
|
||||
|
@ -75,12 +77,19 @@ describe("zettel listing", function()
|
|||
ZK.get_zettel_list("path/to/startingdir", true)
|
||||
|
||||
assert.spy(vim_api_mock.loop.fs_scandir).was_called(2)
|
||||
assert.spy(vim_api_mock.loop.fs_scandir).was_called_with("path/to/startingdir/more-notes-here")
|
||||
assert.spy(vim_api_mock.loop.fs_scandir).was_called_with(
|
||||
"path/to/startingdir/more-notes-here")
|
||||
end)
|
||||
|
||||
it("should append all notes found in subdirectories when recursing", function()
|
||||
local outer_files = { "subdir", "1234567890 myfile.md", "2345678901 another.md", }
|
||||
local inner_files = { "2222222222 should-be-present.md", "3333333333 should-also-be-present.md" }
|
||||
it("should append all notes found in subdirectories when recursing",
|
||||
function()
|
||||
local outer_files = {
|
||||
"subdir", "1234567890 myfile.md", "2345678901 another.md"
|
||||
}
|
||||
local inner_files = {
|
||||
"2222222222 should-be-present.md",
|
||||
"3333333333 should-also-be-present.md"
|
||||
}
|
||||
local files = outer_files
|
||||
-- assert.is_true("not implemented")
|
||||
local vim_api_mock = {
|
||||
|
@ -100,15 +109,31 @@ describe("zettel listing", function()
|
|||
end
|
||||
return fname, ftype
|
||||
end
|
||||
}}
|
||||
}
|
||||
}
|
||||
ZK.init(vim_api_mock)
|
||||
local expected = {
|
||||
["1234567890"] = "1234567890 myfile.md",
|
||||
["2345678901"] = "2345678901 another.md",
|
||||
["2222222222"] = "2222222222 should-be-present.md",
|
||||
["3333333333"] = "3333333333 should-also-be-present.md",
|
||||
["3333333333"] = "3333333333 should-also-be-present.md"
|
||||
}
|
||||
assert.same(expected, ZK.get_zettel_list('mydirectory', true))
|
||||
end)
|
||||
|
||||
it("should adhere to the zettel extension defined in options", function()
|
||||
local file_list = {"1910291645 myfile.wiki", "2345678901 another.wiki"}
|
||||
local vim = get_api_mock(file_list)
|
||||
vim.g['zettel_extension'] = '.wiki'
|
||||
ZK.init(vim)
|
||||
|
||||
local expected = {
|
||||
["1910291645"] = "1910291645 myfile.wiki",
|
||||
["2345678901"] = "2345678901 another.wiki"
|
||||
}
|
||||
|
||||
assert.same(expected, ZK.get_zettel_list('mydirectory'))
|
||||
|
||||
end)
|
||||
|
||||
end)
|
||||
|
|
Loading…
Reference in a new issue