diff options
| author | Markus Koller <markus-koller@gmx.ch> | 2020-09-10 14:18:15 +0200 |
|---|---|---|
| committer | Thomas Vigouroux <tomvig38@gmail.com> | 2020-09-10 15:11:04 +0200 |
| commit | fd6d09fd1f52d0c7d307c7f10b95509400d859c9 (patch) | |
| tree | 95796ab99302a280b405876a0a819dc454b16a33 /lua | |
| parent | 10848ca5bd2893664eab122c9b415860e5352e79 (diff) | |
Find package path based on the Lua source file
This is more robust compared to the previous method where we walked
up the tree and matched on the directory name, which also required
that the repository was cloned in a directory named `nvim-treesitter`.
Diffstat (limited to 'lua')
| -rw-r--r-- | lua/nvim-treesitter/install.lua | 10 | ||||
| -rw-r--r-- | lua/nvim-treesitter/utils.lua | 11 |
2 files changed, 6 insertions, 15 deletions
diff --git a/lua/nvim-treesitter/install.lua b/lua/nvim-treesitter/install.lua index 3b75362c..61b1a9f9 100644 --- a/lua/nvim-treesitter/install.lua +++ b/lua/nvim-treesitter/install.lua @@ -200,9 +200,7 @@ local function install(with_sync, ask_reinstall) return api.nvim_err_writeln('Git is required on your system to run this command') end - local package_path, err = utils.get_package_path() - if err then return api.nvim_err_writeln(err) end - + local package_path = utils.get_package_path() local cache_folder, err = utils.get_cache_dir() if err then return api.nvim_err_writeln(err) end @@ -267,11 +265,7 @@ function M.uninstall(lang) M.uninstall(lang) end elseif lang then - local package_path, err = utils.get_package_path() - if err then - print(err) - return - end + local package_path = utils.get_package_path() local parser_lib = package_path..path_sep.."parser"..path_sep..lang..".so" local command_list = { diff --git a/lua/nvim-treesitter/utils.lua b/lua/nvim-treesitter/utils.lua index c080c2a9..7a5fbe5e 100644 --- a/lua/nvim-treesitter/utils.lua +++ b/lua/nvim-treesitter/utils.lua @@ -18,14 +18,11 @@ function M.setup_commands(mod, commands) end function M.get_package_path() - for _, path in pairs(api.nvim_list_runtime_paths()) do - local last_segment = vim.fn.fnamemodify(path, ":p:h:t") - if last_segment == "nvim-treesitter" then - return path - end - end + -- Path to this source file, removing the leading '@' + local source = string.sub(debug.getinfo(1, 'S').source, 2) - return nil, 'Plugin runtime path not found.' + -- Path to the package root + return fn.fnamemodify(source, ":p:h:h:h") end function M.get_cache_dir() |
