aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--autoload/nvim_treesitter.vim8
-rw-r--r--doc/nvim-treesitter.txt12
-rw-r--r--lua/nvim-treesitter.lua31
3 files changed, 8 insertions, 43 deletions
diff --git a/autoload/nvim_treesitter.vim b/autoload/nvim_treesitter.vim
index 813cc3e50..a5f1f9782 100644
--- a/autoload/nvim_treesitter.vim
+++ b/autoload/nvim_treesitter.vim
@@ -1,9 +1,5 @@
-function! nvim_treesitter#statusline(len) abort
- return luaeval("require'nvim-treesitter'.statusline(_A)", a:len)
-endfunction
-
-function! nvim_treesitter#named_statusline(...) abort
- return luaeval("require'nvim-treesitter'.named_statusline(_A)", get(a:, 1, {}))
+function! nvim_treesitter#statusline(...) abort
+ return luaeval("require'nvim-treesitter'.statusline(_A)", get(a:, 1, {}))
endfunction
function! nvim_treesitter#foldexpr() abort
diff --git a/doc/nvim-treesitter.txt b/doc/nvim-treesitter.txt
index 86250736b..c6ea4ed30 100644
--- a/doc/nvim-treesitter.txt
+++ b/doc/nvim-treesitter.txt
@@ -415,16 +415,8 @@ to the jump list.
==============================================================================
FUNCTIONS *nvim-treesitter-functions*
- *nvim_treesitter#statusline()*
-nvim_treesitter#statusline(size)~
-
-Returns a string describing the current position in the syntax tree. This
-could be used as a statusline indicator.
-Note: The `size` argument is optional. When specified, the string will not be
- longer than `size`.
-
- *nvim_treesitter#named_statusline()*
-nvim_treesitter#named_statusline(opts)~
+ *nvim_treesitter#statusline()*
+nvim_treesitter#statusline(opts)~
Returns a string describing the current position in the file. This
could be used as a statusline indicator.
diff --git a/lua/nvim-treesitter.lua b/lua/nvim-treesitter.lua
index b61164268..1eb5276f2 100644
--- a/lua/nvim-treesitter.lua
+++ b/lua/nvim-treesitter.lua
@@ -27,32 +27,6 @@ function M.define_modules(...)
configs.define_modules(...)
end
-function M.statusline(indicator_size)
- if not parsers.has_parser() then return end
- local indicator_size = indicator_size or 100
-
- local current_node = ts_utils.get_node_at_cursor()
- if not current_node then return "" end
-
- local expr = current_node:parent()
- local prefix = ""
- if expr then
- prefix = "->"
- end
-
- local indicator = current_node:type()
- while expr and (#indicator + #(expr:type()) + 5) < indicator_size do
- indicator = expr:type() .. prefix .. indicator
- expr = expr:parent()
- end
-
- if expr then
- return "..." .. indicator
- else
- return indicator
- end
-end
-
local get_line_for_node = function(node, type_patterns, transform_fn)
local node_type = node:type()
local is_valid = false
@@ -74,9 +48,12 @@ local transform_line = function(line)
return line:gsub('[%[%(%{]*%s*$', '')
end
-function M.named_statusline(opts)
+function M.statusline(opts)
if not parsers.has_parser() then return end
local options = opts or {}
+ if type(opts) == 'number' then
+ options = {indicator_size = opts}
+ end
local indicator_size = options.indicator_size or 100
local type_patterns = options.type_patterns or {'class', 'function', 'method'}
local transform_fn = options.transform_fn or transform_line