diff --git a/lua/luau-lsp/init.lua b/lua/luau-lsp/init.lua index 342f136..521d7ab 100644 --- a/lua/luau-lsp/init.lua +++ b/lua/luau-lsp/init.lua @@ -27,18 +27,16 @@ function M.aliases(paths) return end - local success, contents = pcall(json.decode, luaurc:read "a") - if not success then + local ok, contents = pcall(json.decode, luaurc:read "a") + if not ok then log.error("Failed to read '.luaurc': %s", contents) return end local aliases = vim.empty_dict() - for alias, value in pairs(contents.aliases or {}) do aliases["@" .. alias] = value end - return aliases end diff --git a/lua/luau-lsp/util.lua b/lua/luau-lsp/util.lua index 0e6d6f4..87e063d 100644 --- a/lua/luau-lsp/util.lua +++ b/lua/luau-lsp/util.lua @@ -25,7 +25,7 @@ end function M.storage_file(key) local path = M.joinpath(vim.fn.stdpath "data", "luau-lsp") if not M.is_dir(path) then - vim.uv.fs_mkdir(path, 448) + vim.fn.mkdir(path, "p") end return M.joinpath(path, key) end diff --git a/spec/json_spec.lua b/spec/json_spec.lua index d24fa5a..168167e 100644 --- a/spec/json_spec.lua +++ b/spec/json_spec.lua @@ -2,7 +2,7 @@ local json = require "luau-lsp.json" describe("json5 decoder", function() it("should decode with comments", function() - local success, contents = pcall( + local ok, contents = pcall( json.decode, [[ // .luaurc @@ -14,7 +14,7 @@ describe("json5 decoder", function() ]] ) - assert.is_true(success) + assert.is_true(ok) assert.same({ foo = "foo", bar = "bar", @@ -22,7 +22,7 @@ describe("json5 decoder", function() end) it("should decode with trailing commas", function() - local success, contents = pcall( + local ok, contents = pcall( json.decode, [[ { @@ -32,10 +32,31 @@ describe("json5 decoder", function() ]] ) - assert.is_true(success) + assert.is_true(ok) assert.same({ foo = "foo", bar = "bar", }, contents) end) + + it("should decode nesting fields", function() + local ok, contents = pcall( + json.decode, + [[ + { + // nested + "foo": { + "bar": "baz", + }, + } + ]] + ) + + assert.is_true(ok) + assert.same({ + foo = { + bar = "baz", + }, + }, contents) + end) end) diff --git a/spec/server_spec.lua b/spec/server_spec.lua index f6c7cb6..e4f7544 100644 --- a/spec/server_spec.lua +++ b/spec/server_spec.lua @@ -28,9 +28,6 @@ local function wait_for_client() end describe("luau-lsp server", function() - ---@diagnostic disable-next-line: duplicate-set-field - vim.notify = function() end - after_each(function() local client = wait_for_client() client.stop(true)