Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Feel-ix-343/markdown-oxide
PKM for the LSP
https://github.com/Feel-ix-343/markdown-oxide
language-server-protocol lsp lsp-server markdown obsidian obsidian-md rust rust-lang rust-language-server vscode-language-support vscode-languageserver
Last synced: 2 months ago
JSON representation
PKM for the LSP
- Host: GitHub
- URL: https://github.com/Feel-ix-343/markdown-oxide
- Owner: Feel-ix-343
- License: gpl-3.0
- Created: 2023-04-27T18:20:29.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-10-29T23:14:16.000Z (2 months ago)
- Last Synced: 2024-10-30T01:49:45.962Z (2 months ago)
- Topics: language-server-protocol, lsp, lsp-server, markdown, obsidian, obsidian-md, rust, rust-lang, rust-language-server, vscode-language-support, vscode-languageserver
- Language: Rust
- Homepage: https://oxide.md
- Size: 40.2 MB
- Stars: 981
- Watchers: 6
- Forks: 16
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - Feel-ix-343/markdown-oxide - PKM for the LSP (Rust)
- my-awesome-github-stars - Feel-ix-343/markdown-oxide - PKM for the LSP (Rust)
README
**markdown-oxide**: Robust, Minimalist, Unbundled PKM (Personal-Knowledge-Management System) for your favorite text-editor through the [Language-Server-Protocol](https://microsoft.github.io/language-server-protocol/).
**[Quick Start](#quick-start)**
# Docs
Here are some recommended links from our documentation website,
## Recommended Links
* [What is markdown-oxide?](https://oxide.md/v0/Articles/Markdown-Oxide+v0): An overview of our PKM features to help you determine if markdown-oxide is for you
* [Markdown-oxide getting-started guide](https://oxide.md/v0/Guides/Getting+started+with+Markdown+Oxide+Version+0): A guide to setting up your text editor, configuring the PKM, and using the features.
* [Features Reference](https://oxide.md/v0/references/v0+Features+Reference): An organized list of all features
* [Configuration Reference](https://oxide.md/v0/references/v0+Configuration+Reference): Configuration information to reference
+ [Default Config File](https://oxide.md/v0/References/v0+Configuration+Reference#Default+Config+File)# Quick Start
Get started with Markdown-oxide as fast as possible!
Set up the PKM for your text editor...
- [Neovim](#Neovim)
- [VSCode](#VSCode)
- [Zed](#Zed)
- [Helix](#Helix)## Neovim
1. Give Neovim access to the binary.
-
Cargo Install (from source)
```bash
cargo install --locked --git https://github.com/Feel-ix-343/markdown-oxide.git markdown-oxide
```
-
Cargo binstall (from hosted binary)
```bash
cargo binstall --git 'https://github.com/feel-ix-343/markdown-oxide' markdown-oxide
```
-
AUR (from source)
```bash
paru -S markdown-oxide-git
``````bash
yay -S markdown-oxide-git
```
- [Mason.nvim](https://github.com/williamboman/mason.nvim) (from hosted binary)
- Nix Unstable: `pkgs.markdown-oxide`
2. Modify your Neovim Configuration ^nvimconfigsetup
-
Modify LSP Config (making sure to adjust capabilities as follows)```lua
-- An example nvim-lspconfig capabilities setting
local capabilities = require("cmp_nvim_lsp").default_capabilities(vim.lsp.protocol.make_client_capabilities())
require("lspconfig").markdown_oxide.setup({
-- Ensure that dynamicRegistration is enabled! This allows the LS to take into account actions like the
-- Create Unresolved File code action, resolving completions for unindexed code blocks, ...
capabilities = vim.tbl_deep_extend(
'force',
capabilities,
{
workspace = {
didChangeWatchedFiles = {
dynamicRegistration = true,
},
},
}
),
on_attach = on_attach -- configure your on attach config
})
```
-
Modify your nvim-cmp configurationModify your nvim-cmp source settings for nvim-lsp (note: you must have nvim-lsp installed)
```lua
{
name = 'nvim_lsp',
option = {
markdown_oxide = {
keyword_pattern = [[\(\k\| \|\/\|#\)\+]]
}
}
},
```
-
(optional) Enable Code Lens (eg for UI reference count)Modify your lsp `on_attach` function.
```lua
local function check_codelens_support()
local clients = vim.lsp.get_active_clients({ bufnr = 0 })
for _, c in ipairs(clients) do
if c.server_capabilities.codeLensProvider then
return true
end
end
return false
endvim.api.nvim_create_autocmd({ 'TextChanged', 'InsertLeave', 'CursorHold', 'LspAttach', 'BufEnter' }, {
buffer = bufnr,
callback = function ()
if check_codelens_support() then
vim.lsp.codelens.refresh({bufnr = 0})
end
end
})
-- trigger codelens refresh
vim.api.nvim_exec_autocmds('User', { pattern = 'LspAttached' })
```
-
(optional) Enable opening daily notes with natural langaugeModify your lsp `on_attach` function to support opening daily notes with, for example, `:Daily two days ago` or `:Daily next monday`.
```lua
-- setup Markdown Oxide daily note commands
if client.name == "markdown_oxide" thenvim.api.nvim_create_user_command(
"Daily",
function(args)
local input = args.argsvim.lsp.buf.execute_command({command="jump", arguments={input}})
end,
{desc = 'Open daily note', nargs = "*"}
)
end
```
- Ensure relevant plugins are installed:
* [Nvim CMP](https://github.com/hrsh7th/nvim-cmp): UI for using LSP completions
* [Telescope](https://github.com/nvim-telescope/telescope.nvim): UI helpful for the LSP references implementation
- Allows you to view and fuzzy match backlinks to files, headings, and blocks.
* [Lspsaga](https://github.com/nvimdev/lspsaga.nvim): UI generally helpful for LSP commands
+ Allows you to edit linked markdown files in a popup window, for example.## VSCode
Install the [vscode extension](https://marketplace.visualstudio.com/items?itemName=FelixZeller.markdown-oxide) (called `Markdown Oxide`). As for how the extension uses the language server, there are two options
1. Recommended: the extension will download the server's binary and use that
2. The extension will use `markdown-oxide` from path. To install to your path, there are the following methods for VSCode:-
Cargo Install (from source)
```bash
cargo install --locked --git https://github.com/Feel-ix-343/markdown-oxide.git markdown-oxide
```
-
Cargo binstall[1] (from hosted binary)
```bash
cargo binstall --git 'https://github.com/feel-ix-343/markdown-oxide' markdown-oxide
```
-
AUR (from source)
```bash
paru -S markdown-oxide-git
``````bash
yay -S markdown-oxide-git
```
- Nix Unstable: `pkgs.markdown-oxide`## Zed
Markdown Oxide is available as an extension titled `Markdown Oxide`. Similarly to VSCode, there are two methods for this extension to access the language server
1. Recommended: the extension will download the server's binary and use that
2. The extension will use `markdown-oxide` from path. To install to your path, there are the following methods for Zed:-
Cargo Install (from source)
```bash
cargo install --locked --git https://github.com/Feel-ix-343/markdown-oxide.git markdown-oxide
```
-
Cargo binstall[1] (from hosted binary)
```bash
cargo binstall --git 'https://github.com/feel-ix-343/markdown-oxide' markdown-oxide
```
-
AUR (from source)
```bash
paru -S markdown-oxide-git
``````bash
yay -S markdown-oxide-git
```
- Nix Unstable: `pkgs.markdown-oxide`
## Helix
For Helix, all you must do is install the language server's binary to your path. The following installation methods are available:
-
Cargo Install (from source)```bash
cargo install --locked --git https://github.com/Feel-ix-343/markdown-oxide.git markdown-oxide
```-
Cargo binstall[1] (from hosted binary)
```bash
cargo binstall --git 'https://github.com/feel-ix-343/markdown-oxide' markdown-oxide
```
-
AUR (from source)```bash
paru -S markdown-oxide-git
``````bash
yay -S markdown-oxide-git
```- Nix Unstable: `pkgs.markdown-oxide`