feat: Update help file
This commit is contained in:
101
docs/DOCS.md
101
docs/DOCS.md
@@ -2,26 +2,113 @@
|
|||||||
|
|
||||||
Neogen is an extensible and extremely configurable annotation generator for your favorite languages
|
Neogen is an extensible and extremely configurable annotation generator for your favorite languages
|
||||||
|
|
||||||
|
Want to know what the supported languages are ?
|
||||||
|
Check out the up-to-date readme section: https://github.com/danymat/neogen#supported-languages
|
||||||
|
|
||||||
# Concept
|
# Concept
|
||||||
|
|
||||||
TODO: update doc
|
- Create annotations with one keybind, and jump your cursor in the inserted annotation
|
||||||
|
- Defaults for multiple languages and annotation conventions
|
||||||
|
- Extremely customizable and extensible
|
||||||
|
- Written in lua (and uses Tree-sitter)
|
||||||
|
|
||||||
# Usage
|
# Usage
|
||||||
|
|
||||||
TODO: update doc
|
Neogen will use tree-sitter parsing to properly generate annotations.
|
||||||
|
|
||||||
# Lua API
|
The basic idea is that Neogen will generate annotation to the type you're in.
|
||||||
|
For example, if you have a csharp function like (note the cursor position):
|
||||||
|
|
||||||
TODO: update doc
|
```cs
|
||||||
|
public class HelloWorld
|
||||||
|
{
|
||||||
|
public static void Main(string[] args)
|
||||||
|
{
|
||||||
|
# CURSOR HERE
|
||||||
|
Console.WriteLine("Hello world!");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
# Config
|
public int someMethod(string str, ref int nm, void* ptr) { return 1; }
|
||||||
|
|
||||||
TODO: update doc
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
and you call `:Neogen class`, it will generate the annotation for the upper class:
|
||||||
|
|
||||||
|
```cs
|
||||||
|
/// <summary>
|
||||||
|
/// ...
|
||||||
|
/// </summary>
|
||||||
|
public class HelloWorld
|
||||||
|
{
|
||||||
|
```
|
||||||
|
|
||||||
|
Currently supported types are `func`, `class`, `type`, `file`.
|
||||||
|
Check out the up-to-date readme section: https://github.com/danymat/neogen#supported-languages
|
||||||
|
To know the supported types for a certain language
|
||||||
|
|
||||||
|
NOTE: calling `:Neogen` without any type is the same as `:Neogen func`
|
||||||
|
|
||||||
|
# Basic configurations
|
||||||
|
|
||||||
|
Every configuration here is to put inside your `require('neogen').setup {...}` table.
|
||||||
|
|
||||||
|
- `enabled` (defaults: `false`)
|
||||||
|
Enable Neogen.
|
||||||
|
|
||||||
|
- `input_after_comment` (defaults: `true`)
|
||||||
|
Go to annotation after insertion, and change to insert mode
|
||||||
|
|
||||||
|
# Advanced configurations
|
||||||
|
|
||||||
|
To customize a language, you can provide a custom table like this:
|
||||||
|
The defaults are provided here: https://github.com/danymat/neogen/tree/main/lua/neogen/configurations
|
||||||
|
|
||||||
|
```lua
|
||||||
|
require('neogen').setup {
|
||||||
|
languages = {
|
||||||
|
csharp = {
|
||||||
|
-- Configuration here
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
- `template.annotation_convention` (default: check the language default configurations)
|
||||||
|
Change the annotation convention to use with the language.
|
||||||
|
- `template.use_default_comment` (default: `true`)
|
||||||
|
Prepend any template line with the default comment for the filetype
|
||||||
|
- `template.append`
|
||||||
|
If you want to customize the position of the annotation
|
||||||
|
- `template.append.child_name`
|
||||||
|
What child node to use for appending the annotation
|
||||||
|
- `template.append.position` (`before/after`)
|
||||||
|
Relative positioning with `child_name`
|
||||||
|
- `template.<convention_name>` (replace `<convention_name>` with an annotation convention)
|
||||||
|
Template for an annotation convention.
|
||||||
|
To know more about how to create your own template, go here:
|
||||||
|
https://github.com/danymat/neogen/blob/main/docs/adding-languages.md#default-generator
|
||||||
|
|
||||||
# Develop
|
# Develop
|
||||||
|
|
||||||
|
- Want to add a new language?
|
||||||
|
|
||||||
|
1. Using the defaults to generate a new language support:
|
||||||
|
https://github.com/danymat/neogen/blob/main/docs/adding-languages.md
|
||||||
|
2. (advanced) Only if the defaults aren't enough, please see here:
|
||||||
|
https://github.com/danymat/neogen/blob/main/docs/advanced-integration.md
|
||||||
|
|
||||||
|
- Want to contribute to an existing language?
|
||||||
|
I guess you can still read the previous links, as they have some valuable knowledge inside.
|
||||||
|
You can go and directly open/edit the configuration file relative to the language you want to contribute to.
|
||||||
|
|
||||||
|
Feel free to submit a PR, I will be happy to help you !
|
||||||
|
|
||||||
|
## Developer API
|
||||||
|
|
||||||
TODO: update doc
|
TODO: update doc
|
||||||
|
|
||||||
# FAQ
|
# FAQ
|
||||||
|
|
||||||
TODO: update doc
|
Seems too calm here...
|
||||||
|
|||||||
Reference in New Issue
Block a user