summaryrefslogtreecommitdiff
path: root/lua/nvim-treesitter
diff options
context:
space:
mode:
authorThomas Vigouroux <39092278+vigoux@users.noreply.github.com>2020-05-15 15:01:06 +0200
committerGitHub <noreply@github.com>2020-05-15 15:01:06 +0200
commit9c3211119141dd751b7a045f37fb742c19b75cb2 (patch)
treed4000f95f0f472478036a89b19a2f55aadbb5fff /lua/nvim-treesitter
parent5a66c38b9ff49f0f0b45afa95816c77e18cc9886 (diff)
parent8be2dc64a2e0a94a429d66c411eb7d500566508f (diff)
Merge pull request #54 from kyazdani42/feat/expose-api
Expose internal api.
Diffstat (limited to 'lua/nvim-treesitter')
-rw-r--r--lua/nvim-treesitter/configs.lua13
-rw-r--r--lua/nvim-treesitter/node_movement.lua72
-rw-r--r--lua/nvim-treesitter/state.lua8
3 files changed, 8 insertions, 85 deletions
diff --git a/lua/nvim-treesitter/configs.lua b/lua/nvim-treesitter/configs.lua
index 31f01a72..f79fed00 100644
--- a/lua/nvim-treesitter/configs.lua
+++ b/lua/nvim-treesitter/configs.lua
@@ -228,19 +228,6 @@ local config = {
is_supported = function(ft)
return queries.get_query(ft, 'locals')
end
- },
- node_movement = {
- enable = false,
- disable = {},
- is_supported = function(ft)
- return queries.get_query(ft, 'locals')
- end,
- keymaps = {
- parent_scope = "<a-k>",
- child_scope = "<a-j>",
- next_scope = "<a-l>",
- previous_scope = "<a-h>",
- },
}
},
ensure_installed = nil
diff --git a/lua/nvim-treesitter/node_movement.lua b/lua/nvim-treesitter/node_movement.lua
deleted file mode 100644
index f6f15fce..00000000
--- a/lua/nvim-treesitter/node_movement.lua
+++ /dev/null
@@ -1,72 +0,0 @@
-local api = vim.api
-
-local configs = require'nvim-treesitter.configs'
-local state = require'nvim-treesitter.state'
-local ts_utils = require'nvim-treesitter.ts_utils'
-
-local M = {}
-
-local NodeMovementKind = {
- parent_scope = 'parent',
- child_scope = 'child',
- next_scope = 'next',
- previous_scope = 'previous',
-}
-
-local get_node_fn = {
- [NodeMovementKind.parent_scope] = function(node, curpos)
- return ts_utils.parent_scope(node, curpos)
- end,
- [NodeMovementKind.child_scope] = function(node, curpos)
- return ts_utils.nested_scope(node, curpos)
- end,
- [NodeMovementKind.next_scope] = function(node)
- return ts_utils.next_scope(node)
- end,
- [NodeMovementKind.previous_scope] = function(node)
- return ts_utils.previous_scope(node)
- end,
-}
-
-M.do_node_movement = function(kind)
- local buf = api.nvim_get_current_buf()
-
- local buf_state = state.get_buf_state(buf)
- if not buf_state then return end
-
- local current_node = buf_state.current_node
- if not current_node then return end
-
- local destination_node = get_node_fn[kind](current_node, buf_state.cursor_pos)
-
- if destination_node then
- local row, col = destination_node:start()
- vim.fn.setpos(".", { buf, row+1, col+1, 0 })
- end
-end
-
-function M.parent_scope() M.do_node_movement(NodeMovementKind.parent_scope) end
-function M.child_scope() M.do_node_movement(NodeMovementKind.child_scope) end
-function M.next_scope() M.do_node_movement(NodeMovementKind.next_scope) end
-function M.previous_scope() M.do_node_movement(NodeMovementKind.previous_scope) end
-
-function M.attach(bufnr)
- local bufnr = bufnr or api.nvim_get_current_buf()
-
- local config = configs.get_module('node_movement')
- for funcname, mapping in pairs(config.keymaps) do
- local cmd = string.format(":lua require'nvim-treesitter.node_movement'.%s()<CR>", funcname)
- api.nvim_buf_set_keymap(bufnr, 'n', mapping, cmd, { silent = true })
- end
-end
-
-function M.detach(bufnr)
- local buf = bufnr or api.nvim_get_current_buf()
-
- local config = configs.get_module('node_movement')
- for _, mapping in pairs(config.keymaps) do
- api.nvim_buf_del_keymap(buf, 'n', mapping)
- end
-end
-
-return M
diff --git a/lua/nvim-treesitter/state.lua b/lua/nvim-treesitter/state.lua
index 9da07ae1..d682bd28 100644
--- a/lua/nvim-treesitter/state.lua
+++ b/lua/nvim-treesitter/state.lua
@@ -111,4 +111,12 @@ function M.get_buf_state(bufnr)
return buffers[bufnr]
end
+function M.exposed_state(bufnr)
+ local buf_state = buffers[bufnr]
+ return {
+ cursor_pos = buf_state.cursor_pos,
+ current_node = buf_state.current_node
+ }
+end
+
return M