summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris <[email protected]>2021-07-10 10:51:47 -0400
committerChris <[email protected]>2021-07-10 10:51:47 -0400
commit9624905ad851925d6761059ee41d4f247e3cf430 (patch)
tree490577386e2ea4ef2277085af0f2467f255cb512
parent95c00903a8c1891bed4b9f4571d758684eaf1792 (diff)
refactor treesitter
-rw-r--r--lua/default-config.lua33
-rw-r--r--lua/lv-treesitter/config.lua90
-rw-r--r--lua/lv-treesitter/init.lua181
3 files changed, 153 insertions, 151 deletions
diff --git a/lua/default-config.lua b/lua/default-config.lua
index a23fb8a6..c2c582fa 100644
--- a/lua/default-config.lua
+++ b/lua/default-config.lua
@@ -58,37 +58,6 @@ O = {
auto_close_tree = 0,
nvim_tree_disable_netrw = 0,
- -- TODO refactor treesitter
- -- @usage pass a table with your desired languages
- treesitter = {
- ensure_installed = "all",
- ignore_install = { "haskell" },
- highlight = { enabled = true },
- -- The below are for treesitter-textobjects plugin
- textobj_prefixes = {
- goto_next = "]", -- Go to next
- goto_previous = "[", -- Go to previous
- inner = "i", -- Select inside
- outer = "a", -- Selct around
- swap = "<leader>a", -- Swap with next
- },
- textobj_suffixes = {
- -- Start and End respectively for the goto keys
- -- for other keys it only uses the first
- ["function"] = { "f", "F" },
- ["class"] = { "m", "M" },
- ["parameter"] = { "a", "A" },
- ["block"] = { "k", "K" },
- ["conditional"] = { "i", "I" },
- ["call"] = { "c", "C" },
- ["loop"] = { "l", "L" },
- ["statement"] = { "s", "S" },
- ["comment"] = { "/", "?" },
- },
- -- The below is for treesitter hint textobjects plugin
- hint_labels = { "h", "j", "f", "d", "n", "v", "s", "l", "a" },
- },
-
lsp = {
document_highlight = true,
popup_border = "single",
@@ -99,7 +68,6 @@ O = {
plugin = {
-- Builtins
diffview = { active = false },
- ts_context_commentstring = { active = false },
ts_hintobjects = { active = false },
ts_textobjects = { active = false },
ts_textsubjects = { active = false },
@@ -263,3 +231,4 @@ require "lv-gitsigns.config"
require "lv-telescope.config"
require "lv-dap.config"
require "lv-which-key.config"
+require "lv-treesitter.config"
diff --git a/lua/lv-treesitter/config.lua b/lua/lv-treesitter/config.lua
new file mode 100644
index 00000000..c22f7bcf
--- /dev/null
+++ b/lua/lv-treesitter/config.lua
@@ -0,0 +1,90 @@
+O.treesitter = {
+ ensure_installed = {}, -- one of "all", "maintained" (parsers with maintainers), or a list of languages
+ ignore_install = {},
+ matchup = {
+ enable = false, -- mandatory, false will disable the whole extension
+ -- disable = { "c", "ruby" }, -- optional, list of language that will be disabled
+ },
+ highlight = {
+ enable = true, -- false will disable the whole extension
+ additional_vim_regex_highlighting = true,
+ disable = { "latex" },
+ },
+ context_commentstring = {
+ enable = false,
+ config = { css = "// %s" },
+ },
+ -- indent = {enable = true, disable = {"python", "html", "javascript"}},
+ -- TODO seems to be broken
+ indent = { enable = { "javascriptreact" } },
+ autotag = { enable = false },
+ textobjects = {
+ swap = {
+ enable = false,
+ -- swap_next = textobj_swap_keymaps,
+ },
+ -- move = textobj_move_keymaps,
+ select = {
+ enable = false,
+ -- keymaps = textobj_sel_keymaps,
+ },
+ },
+ textsubjects = {
+ enable = false,
+ keymaps = { ["."] = "textsubjects-smart", [";"] = "textsubjects-big" },
+ },
+ playground = {
+ enable = false,
+ disable = {},
+ updatetime = 25, -- Debounced time for highlighting nodes in the playground from source code
+ persist_queries = false, -- Whether the query persists across vim sessions
+ keybindings = {
+ toggle_query_editor = "o",
+ toggle_hl_groups = "i",
+ toggle_injected_languages = "t",
+ toggle_anonymous_nodes = "a",
+ toggle_language_display = "I",
+ focus_language = "f",
+ unfocus_language = "F",
+ update = "R",
+ goto_node = "<cr>",
+ show_help = "?",
+ },
+ },
+ rainbow = {
+ enable = false,
+ extended_mode = true, -- Highlight also non-parentheses delimiters, boolean or table: lang -> boolean
+ max_file_lines = 1000, -- Do not enable for files with more than 1000 lines, int
+ },
+}
+
+-- -- TODO refactor treesitter
+-- -- @usage pass a table with your desired languages
+-- treesitter = {
+-- ensure_installed = "all",
+-- ignore_install = { "haskell" },
+-- highlight = { enabled = true },
+-- -- The below are for treesitter-textobjects plugin
+-- textobj_prefixes = {
+-- goto_next = "]", -- Go to next
+-- goto_previous = "[", -- Go to previous
+-- inner = "i", -- Select inside
+-- outer = "a", -- Selct around
+-- swap = "<leader>a", -- Swap with next
+-- },
+-- textobj_suffixes = {
+-- -- Start and End respectively for the goto keys
+-- -- for other keys it only uses the first
+-- ["function"] = { "f", "F" },
+-- ["class"] = { "m", "M" },
+-- ["parameter"] = { "a", "A" },
+-- ["block"] = { "k", "K" },
+-- ["conditional"] = { "i", "I" },
+-- ["call"] = { "c", "C" },
+-- ["loop"] = { "l", "L" },
+-- ["statement"] = { "s", "S" },
+-- ["comment"] = { "/", "?" },
+-- },
+-- -- The below is for treesitter hint textobjects plugin
+-- hint_labels = { "h", "j", "f", "d", "n", "v", "s", "l", "a" },
+-- },
diff --git a/lua/lv-treesitter/init.lua b/lua/lv-treesitter/init.lua
index ba7d57b4..36526d09 100644
--- a/lua/lv-treesitter/init.lua
+++ b/lua/lv-treesitter/init.lua
@@ -19,128 +19,71 @@
-- -- used_by = {"bar", "baz"} -- additional filetypes that use this parser
-- }
-- Custom text objects
-local textobj_prefixes = O.treesitter.textobj_prefixes
-local textobj_suffixes = O.treesitter.textobj_suffixes
-local textobj_sel_keymaps = {}
-local textobj_swap_keymaps = {}
-local textobj_move_keymaps = {
- enable = O.plugin.ts_textobjects,
- set_jumps = true, -- whether to set jumps in the jumplist
- goto_next_start = {},
- goto_next_end = {},
- goto_previous_start = {},
- goto_previous_end = {},
-}
-for obj, suffix in pairs(textobj_suffixes) do
- if textobj_prefixes["goto_next"] ~= nil then
- textobj_move_keymaps["goto_next_start"][textobj_prefixes["goto_next"] .. suffix[1]] = "@" .. obj .. ".outer"
- textobj_move_keymaps["goto_next_end"][textobj_prefixes["goto_next"] .. suffix[2]] = "@" .. obj .. ".outer"
- end
- if textobj_prefixes["goto_previous"] ~= nil then
- textobj_move_keymaps["goto_previous_start"][textobj_prefixes["goto_previous"] .. suffix[2]] = "@" .. obj .. ".outer"
- textobj_move_keymaps["goto_previous_end"][textobj_prefixes["goto_previous"] .. suffix[1]] = "@" .. obj .. ".outer"
- end
-
- if textobj_prefixes["inner"] ~= nil then
- textobj_sel_keymaps[textobj_prefixes["inner"] .. suffix[1]] = "@" .. obj .. ".inner"
- end
- if textobj_prefixes["outer"] ~= nil then
- textobj_sel_keymaps[textobj_prefixes["outer"] .. suffix[1]] = "@" .. obj .. ".outer"
- end
-
- if textobj_prefixes["swap"] ~= nil then
- textobj_swap_keymaps[textobj_prefixes["swap"] .. suffix[1]] = "@" .. obj .. ".outer"
- end
-end
-vim.g.ts_hint_textobject_keys = O.treesitter.hint_labels -- Requires https://github.com/mfussenegger/nvim-ts-hint-textobject/pull/2
+-- local textobj_prefixes = O.treesitter.textobj_prefixes
+-- local textobj_suffixes = O.treesitter.textobj_suffixes
+-- local textobj_sel_keymaps = {}
+-- local textobj_swap_keymaps = {}
+-- local textobj_move_keymaps = {
+-- enable = O.plugin.ts_textobjects,
+-- set_jumps = true, -- whether to set jumps in the jumplist
+-- goto_next_start = {},
+-- goto_next_end = {},
+-- goto_previous_start = {},
+-- goto_previous_end = {},
+-- }
+-- for obj, suffix in pairs(textobj_suffixes) do
+-- if textobj_prefixes["goto_next"] ~= nil then
+-- textobj_move_keymaps["goto_next_start"][textobj_prefixes["goto_next"] .. suffix[1]] = "@" .. obj .. ".outer"
+-- textobj_move_keymaps["goto_next_end"][textobj_prefixes["goto_next"] .. suffix[2]] = "@" .. obj .. ".outer"
+-- end
+-- if textobj_prefixes["goto_previous"] ~= nil then
+-- textobj_move_keymaps["goto_previous_start"][textobj_prefixes["goto_previous"] .. suffix[2]] = "@" .. obj .. ".outer"
+-- textobj_move_keymaps["goto_previous_end"][textobj_prefixes["goto_previous"] .. suffix[1]] = "@" .. obj .. ".outer"
+-- end
+--
+-- if textobj_prefixes["inner"] ~= nil then
+-- textobj_sel_keymaps[textobj_prefixes["inner"] .. suffix[1]] = "@" .. obj .. ".inner"
+-- end
+-- if textobj_prefixes["outer"] ~= nil then
+-- textobj_sel_keymaps[textobj_prefixes["outer"] .. suffix[1]] = "@" .. obj .. ".outer"
+-- end
+--
+-- if textobj_prefixes["swap"] ~= nil then
+-- textobj_swap_keymaps[textobj_prefixes["swap"] .. suffix[1]] = "@" .. obj .. ".outer"
+-- end
+-- end
+-- vim.g.ts_hint_textobject_keys = O.treesitter.hint_labels -- Requires https://github.com/mfussenegger/nvim-ts-hint-textobject/pull/2
+--
+-- -- Add which key menu entries
+-- local status, wk = pcall(require, "which-key")
+-- if status then
+-- local normal = {
+-- mode = "n", -- Normal mode
+-- }
+-- local operators = {
+-- mode = "o", -- Operator mode
+-- }
+-- wk.register(textobj_sel_keymaps, operators)
+-- wk.register({
+-- ["m"] = "Hint Objects",
+-- ["."] = "Textsubject",
+-- [";"] = "Textsubject-big",
+-- }, operators)
+-- wk.register(textobj_swap_keymaps, normal)
+-- wk.register({
+-- [textobj_prefixes["swap"]] = "Swap",
+-- -- [textobj_prefixes["goto_next"]] = "Jump [",
+-- -- [textobj_prefixes["goto_previous"]] = "Jump ]"
+-- }, normal)
+-- wk.register(textobj_move_keymaps["goto_next_start"], normal)
+-- wk.register(textobj_move_keymaps["goto_next_end"], normal)
+-- wk.register(textobj_move_keymaps["goto_previous_start"], normal)
+-- wk.register(textobj_move_keymaps["goto_previous_end"], normal)
+-- end
--- Add which key menu entries
-local status, wk = pcall(require, "which-key")
-if status then
- local normal = {
- mode = "n", -- Normal mode
- }
- local operators = {
- mode = "o", -- Operator mode
- }
- wk.register(textobj_sel_keymaps, operators)
- wk.register({
- ["m"] = "Hint Objects",
- ["."] = "Textsubject",
- [";"] = "Textsubject-big",
- }, operators)
- wk.register(textobj_swap_keymaps, normal)
- wk.register({
- [textobj_prefixes["swap"]] = "Swap",
- -- [textobj_prefixes["goto_next"]] = "Jump [",
- -- [textobj_prefixes["goto_previous"]] = "Jump ]"
- }, normal)
- wk.register(textobj_move_keymaps["goto_next_start"], normal)
- wk.register(textobj_move_keymaps["goto_next_end"], normal)
- wk.register(textobj_move_keymaps["goto_previous_start"], normal)
- wk.register(textobj_move_keymaps["goto_previous_end"], normal)
-end
local status_ok, treesitter_configs = pcall(require, "nvim-treesitter.configs")
if not status_ok then
return
end
-treesitter_configs.setup {
- ensure_installed = O.treesitter.ensure_installed, -- one of "all", "maintained" (parsers with maintainers), or a list of languages
- ignore_install = O.treesitter.ignore_install,
- matchup = {
- enable = true, -- mandatory, false will disable the whole extension
- -- disable = { "c", "ruby" }, -- optional, list of language that will be disabled
- },
- highlight = {
- enable = O.treesitter.highlight.enabled, -- false will disable the whole extension
- additional_vim_regex_highlighting = true,
- disable = { "latex" },
- },
- context_commentstring = {
- enable = O.plugin.ts_context_commentstring.active,
- config = { css = "// %s" },
- },
- -- indent = {enable = true, disable = {"python", "html", "javascript"}},
- -- TODO seems to be broken
- indent = { enable = { "javascriptreact" } },
- autotag = { enable = false },
- textobjects = {
- swap = {
- enable = O.plugin.ts_textobjects,
- swap_next = textobj_swap_keymaps,
- },
- move = textobj_move_keymaps,
- select = {
- enable = O.plugin.ts_textobjects,
- keymaps = textobj_sel_keymaps,
- },
- },
- textsubjects = {
- enable = O.plugin.ts_textsubjects,
- keymaps = { ["."] = "textsubjects-smart", [";"] = "textsubjects-big" },
- },
- playground = {
- enable = false,
- disable = {},
- updatetime = 25, -- Debounced time for highlighting nodes in the playground from source code
- persist_queries = false, -- Whether the query persists across vim sessions
- keybindings = {
- toggle_query_editor = "o",
- toggle_hl_groups = "i",
- toggle_injected_languages = "t",
- toggle_anonymous_nodes = "a",
- toggle_language_display = "I",
- focus_language = "f",
- unfocus_language = "F",
- update = "R",
- goto_node = "<cr>",
- show_help = "?",
- },
- },
- rainbow = {
- enable = false,
- extended_mode = true, -- Highlight also non-parentheses delimiters, boolean or table: lang -> boolean
- max_file_lines = 1000, -- Do not enable for files with more than 1000 lines, int
- },
-}
+treesitter_configs.setup(O.treesitter)