Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kkoomen/vim-doge
(Do)cumentation (Ge)nerator for nearly 20 languages 📚 Generate proper code documentation with a single keypress. ⚡️🔥
https://github.com/kkoomen/vim-doge
boilerplate docblock documentation doge fast generator instant languages multilingual neovim polyglot skeleton vim
Last synced: 2 days ago
JSON representation
(Do)cumentation (Ge)nerator for nearly 20 languages 📚 Generate proper code documentation with a single keypress. ⚡️🔥
- Host: GitHub
- URL: https://github.com/kkoomen/vim-doge
- Owner: kkoomen
- License: gpl-3.0
- Created: 2019-04-28T20:23:34.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-12-06T23:38:50.000Z (about 2 months ago)
- Last Synced: 2025-01-13T05:00:19.483Z (10 days ago)
- Topics: boilerplate, docblock, documentation, doge, fast, generator, instant, languages, multilingual, neovim, polyglot, skeleton, vim
- Language: Rust
- Homepage:
- Size: 4.15 MB
- Stars: 1,010
- Watchers: 9
- Forks: 51
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-list - vim-doge
README
> Any fool can write code that a computer can understand. Good programmers write
> code that humans can understand. -- Martin Fowler, 1999We all love documentation because it makes our codebases easier to understand,
yet no one has time to write it in a good and proper way.Vim-doge is a (Do)cumentation (Ge)nerator which will generate a proper documentation
skeleton based on certain expressions (mainly functions). Simply put your cursor
on a function, press `d`, jump quickly through `TODO` items using
`` and `` to quickly add descriptions and go on coding!# Table of Contents
- [Table of Contents](#table-of-contents)
- [Supported languages and doc standards](#supported-languages-and-doc-standards)
- [Getting started](#getting-started)
- [Configuration](#configuration)
* [Choosing a different doc standard](#choosing-a-different-doc-standard)
* [Options](#options)
+ [`g:doge_install_path`](#gdoge_install_path)
+ [`g:doge_enable_mappings`](#gdoge_enable_mappings)
+ [`g:doge_mapping`](#gdoge_mapping)
+ [`g:doge_filetype_aliases`](#gdoge_filetype_aliases)
+ [`g:doge_buffer_mappings`](#gdoge_buffer_mappings)
+ [`g:doge_mapping_comment_jump_forward`](#gdoge_mapping_comment_jump_forward)
+ [`g:doge_mapping_comment_jump_backward`](#gdoge_mapping_comment_jump_backward)
+ [`g:doge_comment_interactive`](#gdoge_comment_interactive)
+ [`g:doge_comment_jump_wrap`](#gdoge_comment_jump_wrap)
+ [`g:doge_comment_jump_modes`](#gdoge_comment_jump_modes)
- [Commands](#commands)
+ [`:DogeGenerate {doc_standard}`](#dogegenerate-doc_standard)
- [Language-specific configuration](#language-specific-configuration)
+ [JavaScript](#javascript)
+ [PHP](#php)
+ [Python](#python)
+ [Doxygen](#doxygen)
- [Headless mode](#headless-mode)
- [Help](#help)
- [Contributing](#contributing)
* [Tree sitter](#tree-sitter)
- [Development](#development)
+ [Environment setup](#environment-setup)
+ [Helper](#helper)
+ [Testing locally](#testing-locally)
- [Motivation](#motivation)
- [Supporting vim-doge](#supporting-vim-doge)
- [Alternative projects](#alternative-projects)
- [License](#license)# Supported languages and doc standards
Every language that has a documentation standard should be supported by vim-doge.
Is your favorite language not supported?
[Suggest a new language][suggest-language] :tada:
Is your favorite doc standard not supported?
[Suggest a new doc standard][suggest-doc-standard] :tada:| | Language | Doc standards |
| :----------------- | :----------------------------------------------------- | :----------------------------------------------------------------------------------------------- |
| :white_check_mark: | Python | [reST][py-rest], [Numpy][py-numpy], [Google][py-google], [Sphinx][py-sphinx], [Doxygen][doxygen] |
| :white_check_mark: | PHP | [phpdoc][phpdoc] |
| :white_check_mark: | JavaScript (Vanilla, ES6, FlowJS, NodeJS, Svelte, Vue) | [JSDoc][jsdoc] |
| :white_check_mark: | TypeScript | [JSDoc][jsdoc] |
| :white_check_mark: | HTML (through inline `` tags) | [JSDoc][jsdoc] |
| :white_check_mark: | Lua | [LDoc][ldoc] |
| :white_check_mark: | Java | [JavaDoc][javadoc] |
| :white_check_mark: | Groovy | [JavaDoc][javadoc] |
| :white_check_mark: | Ruby | [YARD][yard] |
| :white_check_mark: | C++ | [Doxygen][doxygen] |
| :white_check_mark: | C | [Doxygen][doxygen], [KernelDoc][kerneldoc] |
| :white_check_mark: | C# | [XMLDoc][xmldoc] |
| :white_check_mark: | Bash | [Google][sh-google] |
| :white_check_mark: | Rust | [RustDoc][rustdoc] |
| :white_check_mark: | R | [Roxygen2][roxygen2] |
| :white_check_mark: | Scala | [ScalaDoc][scaladoc] |# Getting started
Using plug:
- `Plug 'kkoomen/vim-doge', { 'do': { -> doge#install() } }`
Using vim-pack:
- `git clone --recursive --depth 1 https://github.com/kkoomen/vim-doge ~/.vim/pack/*/start/vim-doge`
- Open Vim and run `:call doge#install()`Using Pathogen:
- `git clone --recursive --depth 1 https://github.com/kkoomen/vim-doge ~/.vim/bundle/vim-doge`
- Open Vim and run `:call doge#install()`Using Vundle:
- `Plugin 'kkoomen/vim-doge'`
- Open Vim and run `:call doge#install()`Using [packer.nvim](https://github.com/wbthomason/packer.nvim):
```lua
use {
'kkoomen/vim-doge',
run = ':call doge#install()'
}
```Using `LazyVim`:
- Add plugin config to lua plugins folder:
```
{
"kkoomen/vim-doge",
}
```
- Open nvim and run `:call doge#install()`# Configuration
Run `:help doge` to get the full help page.
## Choosing a different doc standard
Vim-doge supports multiple doc standard and you can overwrite them per filetype
in your vimrc. Is your favorite doc standard not supported?
[Suggest a new doc standard][suggest-doc-standard] :tada:Example:
```vim
let g:doge_doc_standard_python = 'numpy'
```If you want to change the doc standard specifically for a buffer, then you can do:
```vim
" Inside test.py
:let b:doge_doc_standard = 'numpy'
```If you want to generate a docblock using a different doc standard just for a
specific expression, then you can use the `DogeGenerate` command:```vim
" Inside test.py, cursor is at a function expression (cursor = `|`):
" |def foo(p1, p2):
" pass
:DogeGenerate numpy
```Here is the full list of available doc standards per filetype:
:warning: For C and C++, see [C Family Doc Standard Examples](./doc/c-family-doc-standard-examples.md).
| Variable | Default | Supported |
| :------------------------------- | :------------------ | :----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `g:doge_doc_standard_python` | `'reST'` | `'reST'`, `'numpy'`, `'google'`, `'sphinx'`, `'doxygen'` |
| `g:doge_doc_standard_php` | `'phpdoc'` | `'phpdoc'` |
| `g:doge_doc_standard_javascript` | `'jsdoc'` | `'jsdoc'` |
| `g:doge_doc_standard_html` | `'jsdoc'` | `'jsdoc'` |
| `g:doge_doc_standard_lua` | `'ldoc'` | `'ldoc'` |
| `g:doge_doc_standard_java` | `'javadoc'` | `'javadoc'` |
| `g:doge_doc_standard_groovy` | `'javadoc'` | `'javadoc'` |
| `g:doge_doc_standard_ruby` | `'YARD'` | `'YARD'` |
| `g:doge_doc_standard_cpp` | `'doxygen_javadoc'` | `'doxygen_javadoc'`, `'doxygen_javadoc_no_asterisk'`, `'doxygen_javadoc_banner'`, `'doxygen_qt'`, `'doxygen_qt_no_asterisk'`, `'doxygen_cpp_comment_slash'`, `'doxygen_cpp_comment_exclamation'`, `'doxygen_cpp_comment_slash_banner'` |
| `g:doge_doc_standard_c` | `'doxygen_javadoc'` | `'kernel_doc'`, `'doxygen_javadoc'`, `'doxygen_javadoc_no_asterisk'`, `'doxygen_javadoc_banner'`, `'doxygen_qt'`, `'doxygen_qt_no_asterisk'`, `'doxygen_cpp_comment_slash'`, `'doxygen_cpp_comment_exclamation'`, `'doxygen_cpp_comment_slash_banner'` |
| `g:doge_doc_standard_sh` | `'google'` | `'google'` |
| `g:doge_doc_standard_rs` | `'rustdoc'` | `'rustdoc'` |
| `g:doge_doc_standard_cs` | `'xmldoc'` | `'xmldoc'` |
| `g:doge_doc_standard_r` | `'roxygen2'` | `'roxygen2'` |
| `g:doge_doc_standard_scala` | `'scaladoc'` | `'scaladoc'` |## Options
### `g:doge_install_path`
Default: `/path/to/vim-doge`
The path where the bin/ directory will be installed and loaded from. Can be
useful if your system is read-only or uses immutable datastructures.### `g:doge_enable_mappings`
Default: `1`
Whether to enable built-in mappings. If you decide to disable this, then you can
copy the mappings below and change them to your needs:```vim
" Generate comment for current line.
nmap <silent> <Leader>d <Plug>(doge-generate)" Interactive mode comment todo-jumping.
nmap <silent> <TAB> <Plug>(doge-comment-jump-forward)
nmap <silent> <S-TAB> <Plug>(doge-comment-jump-backward)
imap <silent> <TAB> <Plug>(doge-comment-jump-forward)
imap <silent> <S-TAB> <Plug>(doge-comment-jump-backward)
smap <silent> <TAB> <Plug>(doge-comment-jump-forward)
smap <silent> <S-TAB> <Plug>(doge-comment-jump-backward)
```Or with Lua for Neovim:
```lua
-- Generate comment for current line
vim.keymap.set('n', '<Leader>d', '<Plug>(doge-generate)')-- Interactive mode comment todo-jumping
vim.keymap.set('n', '<TAB>', '<Plug>(doge-comment-jump-forward)')
vim.keymap.set('n', '<S-TAB>', '<Plug>(doge-comment-jump-backward)')
vim.keymap.set('i', '<TAB>', '<Plug>(doge-comment-jump-forward)')
vim.keymap.set('i', '<S-TAB>', '<Plug>(doge-comment-jump-backward)')
vim.keymap.set('x', '<TAB>', '<Plug>(doge-comment-jump-forward)')
vim.keymap.set('x', '<S-TAB>', '<Plug>(doge-comment-jump-backward)')
```### `g:doge_mapping`
Default: `'<Leader>d'`
The mapping to trigger vim-doge. The mapping accepts a count, to select a
specific doc standard, if more than one is defined.### `g:doge_filetype_aliases`
Default:
```
{
'javascript': [
'javascript.jsx',
'javascriptreact',
'javascript.tsx',
'typescriptreact',
'typescript',
'typescript.tsx',
],
'html': ['svelte', 'vue'],
'java': ['groovy'],
}
```Set filetypes as an alias for other filetypes. The key should be the filetype
that is defined in `ftplugin/<filetype>.vim`. The value must be a list of 1 or
more filetypes that will be aliases.Example:
```vim
let g:doge_filetype_aliases = {
\ 'javascript': ['typescript']
\}
```If you use the above settings and you open `myfile.ts` then it will behave like
you're opening a JavaScript filetype.### `g:doge_buffer_mappings`
Default: `1`
Mappings to jump forward/backward are applied as buffer mappings when
interactive mode starts and removed when it ends.### `g:doge_mapping_comment_jump_forward`
Default: `'<Tab>'`
The mapping to jump forward to the next `TODO` item in a comment. Requires
`g:doge_comment_interactive` to be enabled.### `g:doge_mapping_comment_jump_backward`
Default: `'<S-Tab>'`
The mapping to jump backward to the previous `TODO` item in a comment. Requires
`g:doge_comment_interactive` to be enabled.### `g:doge_comment_interactive`
Default: `1`
Jumps interactively through all `TODO` items in the generated comment.
### `g:doge_comment_jump_wrap`
Default: `1`
Continue to cycle among placeholders when reaching the start or end.
### `g:doge_comment_jump_modes`
Default: `['n', 'i', 's']`
Defines the modes in which doge will jump forward and backward when interactive
mode is active. For example: removing `i` would allow you to use `<Tab>` for
autocompletion in insert mode.# Commands
### `:DogeGenerate {doc_standard}`
Command to generate documentation. The `{doc_standard}` accepts a count or a
string as argument, and it can complete the available doc standards for the
current buffer.The numeric value should point to an index key from the
`b:doge_supported_doc_standards` variable.The string value should point to a doc standard name listed in the
`b:doge_supported_doc_standards` variable.# Language-specific configuration
Below is a list of language-specific configuration and their default values.
### JavaScript
JavaScript settings automatically apply for all the default filetypes that are
being aliased, see [`g:doge_filetype_aliases`](#gdoge_filetype_aliases).```vim
let g:doge_javascript_settings = {
\ 'destructuring_props': 1,
\ 'omit_redundant_param_types': 0,
\}
```- `destructuring_props`: Whether to generate `@param` tags for the destructured
properties in a function expression.- `omit_redundant_param_types`: Whether to omit the `{type}` part of
parameters and return types when the type is known (i.e. typescript).### PHP
```vim
let g:doge_php_settings = {
\ 'resolve_fqn': 1
\}
```- `resolve_fqn`: Whether to resolve the FQN based on the `use` statements in the
current buffer. The FQN will be resolved for type hints in parameters and the
return type.### Python
```vim
let g:doge_python_settings = {
\ 'single_quotes': 0,
\ 'omit_redundant_param_types': 1
\}
```- `single_quotes`: Whether to use single quotes for the multiline comments delimiters.
- `omit_redundant_param_types`: Whether to omit the `{type}` part of parameters
and return types when the type is specified in the function itself.### Doxygen
```vim
let g:doge_doxygen_settings = {
\ 'char': '@'
\}
```- `char`: Character to use for docblock tags. Use `'@'` for `@param` or `'\'` for `\param`.
# Headless mode
If you're running your vim commands inside a docker, CI or similar environments
with commands such as `vim +PlugInstall +qall > /dev/null` then you probably
want to use headless mode. This will not spawn any terminals or progress bars
and will simply run any process by vim-doge in the background.This feature can be enabled by passing in `{ 'headless': 1 }` into the
`doge#install()` like so: `doge#install({ 'headless': 1 })`.Example using vim-plug:
```vim
Plug 'kkoomen/vim-doge', {'do': { -> doge#install({ 'headless': 1 }) }}
```# Help
To open all the help pages, run `:help doge`.
# Contributing
Help or feedback is always appreciated. If you find any bugs, feel free to
[submit a bug report][bug-report]. If you think vim-doge can be improved, feel
free to submit a [feature request][feature-request] or a pull request if you
have time to help out.Read the [Contribution Guidelines][contrib-guide] and [Code of Conduct][coc]
when doing contributions.## Tree sitter
If you want a new language to be supported but tree-sitter doesn't support it
yet, then feel free to create a custom tree-sitter language parser for that
language and then we'll integrate it into vim-doge.- [Creating parsers][create-tree-sitter-parser]
# Development
### Environment setup
Make sure you [install Rust and Cargo][rust-cargo-install] and you're good to go.
### Helper
Vim-doge uses a custom command-line interface called
[vim-doge-helper](./helper/), all made in Rust, that is responsible for parsing
code and generating docblocks. Go have a look at the `helper` directory if you
want to contribute to the parsers.### Testing locally
If you want to run the tests locally, you should install [vader][vader] at the
same directory level that vim-doge is, so your structure should look like this
(using vim-plug example):```
~/.vim/plugged/
├── vader.vim
└── vim-doge
```After that, you can do the following:
- `cd /path/to/vim-doge`
- `vim -u test/vimrc`
- Inside vim you can now run: `Vader test/**/**/*.vader` to run all tests:bulb: If you're working on specific tests, you can run that specific test only:
`Vader test/filetypes/<filetype>/functions.<ext>`.For more information, see [Contribution Guidelines][contrib-guide].
# Motivation
I created vim-doge mainly because I couldn't find a plugin that could generate
proper comments for a big collection of languages that I would use on a daily
basis in a quick and easy way.Rather than scraping off the internet to find all sorts of vim plugins for every
language I was coding in, I was more or less looking for a single plugin that
supports every language I was working in.Another big motivation for me is that I've noticed people tend to skip the
documentation part because writing _just the skeleton_ of the comment takes
already too much time and I am one of those people. Having the skeleton
generated and an interactive mode to quickly add descriptions is a big
time saver.# Supporting vim-doge
Do you enjoy using vim-doge? Give it a star on GitHub and submit your vote on
[vim.org][vim-script].# Alternative projects
Vim-doge generates docblocks, but perhaps you want to take it a step further and
generate it into HTML. [Dooku.nvim](https://github.com/Zeioth/dooku.nvim) is
another plugin that can suit these needs.# License
Vim-doge is licensed under the GPL-3.0 license.
[py-rest]: http://daouzli.com/blog/docstring.html#restructuredtext
[py-numpy]: http://daouzli.com/blog/docstring.html#numpydoc
[py-google]: https://github.com/google/styleguide/blob/gh-pages/pyguide.md#38-comments-and-docstrings
[py-sphinx]: https://sphinx-rtd-tutorial.readthedocs.io/en/latest/docstrings.html#the-sphinx-docstring-format
[phpdoc]: https://www.phpdoc.org
[jsdoc]: https://jsdoc.app
[ldoc]: https://github.com/stevedonovan/LDoc
[javadoc]: https://www.oracle.com/technetwork/articles/javase/index-137868.html
[yard]: https://www.rubydoc.info/gems/yard/file/docs/Tags.md
[doxygen]: http://www.doxygen.nl
[rustdoc]: https://doc.rust-lang.org/rust-by-example/meta/doc.html
[kerneldoc]: https://www.kernel.org/doc/html/latest/doc-guide/kernel-doc.html
[sh-google]: https://google.github.io/styleguide/shell.xml#Function_Comments
[xmldoc]: https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/xmldoc/
[roxygen2]: https://github.com/klutometis/roxygen
[scaladoc]: https://docs.scala-lang.org/style/scaladoc.html[demo-readme]: https://github.com/kkoomen/vim-doge/blob/master/doc/demos
[suggest-language]: https://github.com/kkoomen/vim-doge/issues/new?labels=enhancement&template=feature_request.md&title=Add+support+for+<language>
[suggest-doc-standard]: https://github.com/kkoomen/vim-doge/issues/new?labels=enhancement&template=doc_standard.md
[bug-report]: https://github.com/kkoomen/vim-doge/issues/new?labels=bug&template=bug_report.md
[feature-request]: https://github.com/kkoomen/vim-doge/issues/new?labels=enhancement&template=feature_request.md
[contrib-guide]: https://github.com/kkoomen/vim-doge/blob/master/CONTRIBUTING.md
[coc]: https://github.com/kkoomen/vim-doge/blob/master/CODE_OF_CONDUCT.md
[vim-script]: https://www.vim.org/scripts/script.php?script_id=5801
[vader]: https://github.com/junegunn/vader.vim
[rust-cargo-install]: https://doc.rust-lang.org/cargo/getting-started/installation.html
[create-tree-sitter-parser]: https://tree-sitter.github.io/tree-sitter/creating-parsers