return { "nvim-treesitter/nvim-treesitter", dependencies = { "nvim-treesitter/nvim-treesitter-context", "nvim-treesitter/nvim-treesitter-textobjects", "nvim-treesitter/playground", }, build = ":TSUpdate", config = function() require("nvim-treesitter.install").update({ with_sync = true }) require("nvim-treesitter.configs").setup { ensure_installed = "all", highlight = { enable = true, }, textobjects = { select = { enable = true, lookahead = true, keymaps = { ["af"] = "@function.outer", ["if"] = "@function.inner", ["ac"] = "@comment.outer", ["ic"] = { query = "@class.inner", desc = "Select inner part of a class region" }, ["as"] = { query = "@scope", query_group = "locals", desc = "Select language scope" }, ["is"] = { query = "@scope", query_group = "locals", desc = "Select language scope" }, ['al'] = '@loop.outer', ['il'] = '@loop.inner', ['aa'] = '@parameter.outer', ['ia'] = '@parameter.inner', }, selection_modes = { ['@parameter.outer'] = 'v', -- charwise ['@function.outer'] = 'V', -- linewise ['@class.outer'] = '', -- blockwise }, include_surrounding_whitespace = true, }, swap = { enable = true, swap_next = { ["a"] = "@parameter.inner", }, swap_previous = { ["A"] = "@parameter.inner", }, }, lsp_interop = { enable = true, border = 'none', floating_preview_opts = {}, peek_definition_code = { ["gf"] = "@function.outer", ["gc"] = "@class.outer", }, }, move = { enable = true, set_jumps = true, -- whether to set jumps in the jumplist goto_next_start = { ["]m"] = "@function.outer", ["]]"] = { query = "@class.outer", desc = "Next class start" }, -- -- You can use regex matching (i.e. lua pattern) and/or pass a list in a "query" key to group multiple queires. ["]o"] = "@loop.*", -- ["]o"] = { query = { "@loop.inner", "@loop.outer" } } -- -- You can pass a query group to use query from `queries//.scm file in your runtime path. -- Below example nvim-treesitter's `locals.scm` and `folds.scm`. They also provide highlights.scm and indent.scm. ["]s"] = { query = "@scope", query_group = "locals", desc = "Next scope" }, ["]z"] = { query = "@fold", query_group = "folds", desc = "Next fold" }, }, goto_next_end = { ["]M"] = "@function.outer", ["]["] = "@class.outer", }, goto_previous_start = { ["[m"] = "@function.outer", ["[["] = "@class.outer", }, goto_previous_end = { ["[M"] = "@function.outer", ["[]"] = "@class.outer", }, -- Below will go to either the start or the end, whichever is closer. -- Use if you want more granular movements -- Make it even more gradual by adding multiple queries and regex. goto_next = { ["]i"] = "@conditional.outer", }, goto_previous = { ["[i"] = "@conditional.outer", } }, }, } local ts_repeat_move = require "nvim-treesitter.textobjects.repeatable_move" -- Repeat movement with ; and , -- ensure ; goes forward and , goes backward regardless of the last direction vim.keymap.set({ "n", "x", "o" }, ";", ts_repeat_move.repeat_last_move_next) vim.keymap.set({ "n", "x", "o" }, ",", ts_repeat_move.repeat_last_move_previous) -- vim way: ; goes to the direction you were moving. -- vim.keymap.set({ "n", "x", "o" }, ";", ts_repeat_move.repeat_last_move) -- vim.keymap.set({ "n", "x", "o" }, ",", ts_repeat_move.repeat_last_move_opposite) -- Optionally, make builtin f, F, t, T also repeatable with ; and , vim.keymap.set({ "n", "x", "o" }, "f", ts_repeat_move.builtin_f) vim.keymap.set({ "n", "x", "o" }, "F", ts_repeat_move.builtin_F) vim.keymap.set({ "n", "x", "o" }, "t", ts_repeat_move.builtin_t) vim.keymap.set({ "n", "x", "o" }, "T", ts_repeat_move.builtin_T) end, }