Marksman - code assistant¶
Marksman is a useful tool when drafting your document for Rocky Linux. It allows the easy entry of symbols needed to define the markdown language tags. This allows you to write faster and reduces the possibility of errors.
NvChad/Neovim already includes text widgets that aid writing, such as the repetition of often-used words indexed by frequency of entry. The new options included by this language server will enrich these widgets.
Marksman integrates with your editor to help you write and maintain your Markdown documents with the LSP protocol, thereby providing features such as completion, go-to definition, reference searching, name refactoring, diagnostics, and more.
Objectives¶
- increase the productivity of NvChad in writing Markdown code
- produce documents that conform to the rules of the Markdown language
- refine your knowledge regarding the language
Requirements and skills¶
- A basic knowledge of the Markdown language, recommended reading the Markdown Guide
- NvChad on the machine in use with the Template Chadr properly installed
Difficulty level
Reading time: 20 minutes
Installation of Marksman¶
Installation of the language server does not involve any particular problems since it is natively available in Mason. Install it directly from the statusline with the command:
:MasonInstall marksman
The command will open the Mason interface and directly install the required language server. Once binary installation completes, you can close the Mason screen with the q key.
Its installation, however, does not yet involve its integration into the editor. Enable this by editing the custom/configs/lspconfig.lua
file of the Chadrc Template.
Integration into the editor¶
LSP in NvChad
The nvim-lspconfig plugin integrates the language servers into NvChad. This plugin greatly simplifies their inclusion in the NvChad configuration.
If during the editor installation you also chose to install the Template Chadrc, this creates the lspoconfig.lua file in your custom/configs
folder.
This file takes care of entering the calls needed to use the language servers and also allows you to specify the ones you have installed. To integrate marksman into the editor's language server configuration you will need to edit the local servers string by adding your new LSP.
Open your NvChad on the file with the command:
nvim ~/.config/nvim/lua/custom/configs/lspconfig.lua
And edit the local servers string, which will look as follows when completed:
local servers = { "html", "cssls", "tsserver", "clangd", "marksman" }
Save the file and close the editor with the :wq
command.
To check if the language server is properly activated, open a markdown file in your NvChad and use the command :LspInfo
to view the language servers applied to that file. Within the summary there should be something like:
Client: marksman (id: 2, bufnr: [11, 156])
filetypes: markdown
autostart: true
root directory: /home/your_user/your_path/your_directory
cmd: /home/your_user/.local/share/nvim/mason/bin/marksman server
Configured servers list: cssls, tsserver, clangd, html, yamlls, lua_ls, marksman
This indicates the activation of the marksman server for the open file, and that it started automatically (autostart: true
) since it recognizes it as a markdown file filetypes: markdown
. The other information indicates the path to the executable used for the code check cmd:
, that it uses marksman server
mode, and that it uses the root directory your_directory
for the checks.
Root folder
The concept of a "root folder" is important in using a language server in that to perform controls on the document, such as links to other files or images, it must have a "global view" of the project. We can say that "root folders" equates with the "Projects" found in graphics IDEs.
The root directory, also called the "working directory", used by the editor for the open file, is viewable with the :pwd
command. It is changeable with the :lcd
command if it does not match the desired one. This command reassigns the working directory only to that buffer, without changing any settings of the other buffers open in the editor.
Use of marksman¶
Once you have completed all the steps to enter it, activation of the language server occurs whenever opening a markdown file in the editor. By entering INSERT
mode, when typing certain characters you will have new options in the widgets that will help you in writing the document. In the screenshot below you can see some of the markdown snippets available in these widgets.
Main keys¶
The language server provides many shortcuts that activate writing assistance. This includes quick insertion of Markdown tags, creation of links, and insertion of images into the document. A non-exhaustive list of characters that activate the various snippets is below.
These snippets are displayed within widgets that also contain other shortcuts. Use the Tab key for navigation of the widget to select those provided by marksman.
Key | Snippets |
---|---|
h | Allows for quick entry of title headings (h1 to h6), for example, entering h4 and pressing enter will insert four hash marks and a space and the cursor will already be in place to enter your title |
b | Typing this character activates the ability to use the shortcut for entering bold text by inserting four asterisks and placing the cursor in the middle making writing the bold part much faster |
i | As with the previous character, it allows you to select quick insertion of italic text by entering two asterisks and placing the cursor in between. |
bi | This key inserts six asterisks by placing the cursor in the middle for writing text in bold and italics |
img | This key inserts the markdown structure for inserting an image into the document in the format ![alt text](path) . Note that writing the path can be done using the autocomplete provided by the server. |
link | This key creates the markdown tag structure for a [text](url) link. Again, if the link refers to a file in the working directory you will be able to use autocomplete and the server will check the correctness of the reference. |
list | Typing this key allows the entry of a list of three items to begin the creation of a numbered or unordered list |
q | This character allows the insertion of the tag for a citation > followed by a space and positions the cursor for writing the citation |
s | This character activates numerous possibilities including inserting four tildes and placing the cursor in the middle for writing text ~~strikethrough~~ |
sup | The key inserts the superscript tag. TrademarkTM |
sub | The key inserts the subscript tag. Notes1 |
table | This key enables quick creation of a table structure and allows you to choose from many starting structures |
code | Inserts a block of code inline by placing two backticks at the position where the cursor is located by placing it in the center of the two backticks. |
codeblock | Inserts three lines, two with triple backticks and one blank where you insert your code blocks. Note that it also inserts the string language which is to be compiled with the language you used in the block. |
Code block statement
Markdown code rules recommend always declaring the code used in the block, even without highlighting features for proper interpretation. If the code within it is too generic, using "text" for its declaration is recommended.
The activation keys for Markdown tagging shortcuts also include other combinations that you can discover as you use the language server.
Conclusion¶
Although not strictly necessary, this language server can over time become a great companion in your documentation writing for Rocky Linux.
By using it and consequently memorizing the main keys for inserting Markdown code symbols it will enable effectively faster writing by allowing you to focus your attention on the content.
Author: Franco Colussi
Contributors: Steven Spencer, Ganna Zhyrnova