Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

https://github.com/folke/ts-comments.nvim

Tiny plugin to enhance Neovim's native comments
https://github.com/folke/ts-comments.nvim

neovim neovim-plugin nvim nvim-plugin

Last synced: 26 days ago
JSON representation

Tiny plugin to enhance Neovim's native comments

Lists

README

        

# 🚀 `ts-comments.nvim`

Tiny plugin to enhance Neovim's native comments:

- Easily override the comment string for a given **treesitter** language
- Supports different comment strings for different **treesitter** node types
- Relaxed rules for uncommenting
- Add proper whitespace when needed
- Supports multiple commentstrings for the same language.
The first one is used for adding comments.
All are used for uncommenting.

## ⚡️ Requirements

- Neovim >= 0.10.0

## 📦 Installation

Using [lazy.nvim](https://github.com/folke/lazy.nvim):

```lua
{
"folke/ts-comments.nvim",
opts = {},
event = "VeryLazy",
enabled = vim.fn.has("nvim-0.10.0") == 1,
}
```

## ⚙️ Configuration

**ts-comments.nvim** uses the default Neovim `commentstring` as a fallback,
so there's no need to configure every language.

Default configuration:

```lua
{
lang = {
astro = "",
axaml = "",
blueprint = "// %s",
c = "// %s",
c_sharp = "// %s",
clojure = { ";; %s", "; %s" },
cpp = "// %s",
cs_project = "",
cue = "// %s",
fsharp = "// %s",
fsharp_project = "",
gleam = "// %s",
glimmer = "{{! %s }}",
handlebars = "{{! %s }}",
hcl = "# %s",
html = "",
ini = "; %s",
javascript = {
"// %s", -- default commentstring when no treesitter node matches
"/* %s */",
call_expression = "// %s", -- specific commentstring for call_expression
jsx_attribute = "// %s",
jsx_element = "{/* %s */}",
jsx_fragment = "{/* %s */}",
spread_element = "// %s",
statement_block = "// %s",
},
php = "// %s",
rego = "# %s",
rescript = "// %s",
rust = { "// %s", "/* %s */", "/// %s" },
svelte = "",
terraform = "# %s",
tsx = {
"// %s", -- default commentstring when no treesitter node matches
"/* %s */",
call_expression = "// %s", -- specific commentstring for call_expression
jsx_attribute = "// %s",
jsx_element = "{/* %s */}",
jsx_fragment = "{/* %s */}",
spread_element = "// %s",
statement_block = "// %s",
},
twig = "{# %s #}",
typescript = { "// %s", "/* %s */" }, -- langs can have multiple commentstrings
vue = "",
xaml = "",
},
}
```

## 🔗 Related

- [nvim-ts-context-commentstring](https://github.com/JoosepAlviste/nvim-ts-context-commentstring)