From 75b6eede2fd96de61144fee91c8e300da1cc5dbf Mon Sep 17 00:00:00 2001 From: adollar <71227493+abp1994@users.noreply.github.com> Date: Sun, 29 Jun 2025 21:31:28 +0100 Subject: [PATCH] added md renderer --- README.md | 65 +++++++++++++++++++-------------- init.lua | 1 + lazy-lock.json | 1 + lua/plugins/render-markdown.lua | 9 +++++ 4 files changed, 48 insertions(+), 28 deletions(-) create mode 100644 lua/plugins/render-markdown.lua diff --git a/README.md b/README.md index 41139505..eefbb899 100644 --- a/README.md +++ b/README.md @@ -4,9 +4,9 @@ A starting point for Neovim that is: -* Small -* Single-file -* Completely Documented +- Small +- Single-file +- Completely Documented **NOT** a Neovim distribution, but instead a starting point for your configuration. @@ -14,7 +14,7 @@ A starting point for Neovim that is: ### Install Neovim -Kickstart.nvim targets *only* the latest +Kickstart.nvim targets _only_ the latest ['stable'](https://github.com/neovim/neovim/releases/tag/stable) and latest ['nightly'](https://github.com/neovim/neovim/releases/tag/nightly) of Neovim. If you are experiencing issues, please make sure you have the latest versions. @@ -22,6 +22,7 @@ If you are experiencing issues, please make sure you have the latest versions. ### Install External Dependencies External Requirements: + - Basic utils: `git`, `make`, `unzip`, C Compiler (`gcc`) - [ripgrep](https://github.com/BurntSushi/ripgrep#installation), [fd-find](https://github.com/sharkdp/fd#installation) @@ -45,11 +46,11 @@ External Requirements: Neovim's configurations are located under the following paths, depending on your OS: -| OS | PATH | -| :- | :--- | -| Linux, MacOS | `$XDG_CONFIG_HOME/nvim`, `~/.config/nvim` | -| Windows (cmd)| `%localappdata%\nvim\` | -| Windows (powershell)| `$env:LOCALAPPDATA\nvim\` | +| OS | PATH | +| :------------------- | :---------------------------------------- | +| Linux, MacOS | `$XDG_CONFIG_HOME/nvim`, `~/.config/nvim` | +| Windows (cmd) | `%localappdata%\nvim\` | +| Windows (powershell) | `$env:LOCALAPPDATA\nvim\` | #### Recommended Step @@ -115,19 +116,18 @@ examples of adding popularly requested plugins. > [!NOTE] > For more information about a particular plugin check its repository's documentation. - -### Getting Started +### Getting Startedplugins out there, however most rely on a browser window to get the preview. This is definitely the correct thing to do to get all the features out of Markdown but I wanted something to [The Only Video You Need to Get Started with Neovim](https://youtu.be/m8C0Cq9Uv9o) ### FAQ -* What should I do if I already have a pre-existing Neovim configuration? - * You should back it up and then delete all associated files. - * This includes your existing init.lua and the Neovim files in `~/.local` +- What should I do if I already have a pre-existing Neovim configuration? + - You should back it up and then delete all associated files. + - This includes your existing init.lua and the Neovim files in `~/.local` which can be deleted with `rm -rf ~/.local/share/nvim/` -* Can I keep my existing configuration in parallel to kickstart? - * Yes! You can use [NVIM_APPNAME](https://neovim.io/doc/user/starting.html#%24NVIM_APPNAME)`=nvim-NAME` +- Can I keep my existing configuration in parallel to kickstart? + - Yes! You can use [NVIM_APPNAME](https://neovim.io/doc/user/starting.html#%24NVIM_APPNAME)`=nvim-NAME` to maintain multiple configurations. For example, you can install the kickstart configuration in `~/.config/nvim-kickstart` and create an alias: ``` @@ -137,18 +137,18 @@ examples of adding popularly requested plugins. config directory and the matching local directory `~/.local/share/nvim-kickstart`. You can apply this approach to any Neovim distribution that you would like to try out. -* What if I want to "uninstall" this configuration: - * See [lazy.nvim uninstall](https://lazy.folke.io/usage#-uninstalling) information -* Why is the kickstart `init.lua` a single file? Wouldn't it make sense to split it into multiple files? - * The main purpose of kickstart is to serve as a teaching tool and a reference +- What if I want to "uninstall" this configuration: + - See [lazy.nvim uninstall](https://lazy.folke.io/usage#-uninstalling) information +- Why is the kickstart `init.lua` a single file? Wouldn't it make sense to split it into multiple files? + - The main purpose of kickstart is to serve as a teaching tool and a reference configuration that someone can easily use to `git clone` as a basis for their own. As you progress in learning Neovim and Lua, you might consider splitting `init.lua` into smaller parts. A fork of kickstart that does this while maintaining the same functionality is available here: - * [kickstart-modular.nvim](https://github.com/dam9000/kickstart-modular.nvim) - * Discussions on this topic can be found here: - * [Restructure the configuration](https://github.com/nvim-lua/kickstart.nvim/issues/218) - * [Reorganize init.lua into a multi-file setup](https://github.com/nvim-lua/kickstart.nvim/pull/473) + - [kickstart-modular.nvim](https://github.com/dam9000/kickstart-modular.nvim) + - Discussions on this topic can be found here: + - [Restructure the configuration](https://github.com/nvim-lua/kickstart.nvim/issues/218) + - [Reorganize init.lua into a multi-file setup](https://github.com/nvim-lua/kickstart.nvim/pull/473) ### Install Recipes @@ -170,23 +170,27 @@ This requires: ```lua {'nvim-telescope/telescope-fzf-native.nvim', build = 'cmake -S. -Bbuild -DCMAKE_BUILD_TYPE=Release && cmake --build build --config Release && cmake --install build --prefix build' } ``` +
Windows with gcc/make using chocolatey Alternatively, one can install gcc and make which don't require changing the config, the easiest way is to use choco: 1. install [chocolatey](https://chocolatey.org/install) -either follow the instructions on the page or use winget, -run in cmd as **admin**: + either follow the instructions on the page or use winget, + run in cmd as **admin**: + ``` winget install --accept-source-agreements chocolatey.chocolatey ``` 2. install all requirements using choco, exit the previous cmd and -open a new one so that choco path is set, and run in cmd as **admin**: + open a new one so that choco path is set, and run in cmd as **admin**: + ``` choco install -y neovim git ripgrep wget fd unzip gzip mingw make ``` +
WSL (Windows Subsystem for Linux) @@ -197,9 +201,11 @@ sudo add-apt-repository ppa:neovim-ppa/unstable -y sudo apt update sudo apt install make gcc ripgrep unzip git xclip neovim ``` +
#### Linux Install +
Ubuntu Install Steps ``` @@ -207,6 +213,7 @@ sudo add-apt-repository ppa:neovim-ppa/unstable -y sudo apt update sudo apt install make gcc ripgrep unzip git xclip neovim ``` +
Debian Install Steps @@ -224,12 +231,14 @@ sudo tar -C /opt -xzf nvim-linux-x86_64.tar.gz # make it available in /usr/local/bin, distro installs to /usr/bin sudo ln -sf /opt/nvim-linux-x86_64/bin/nvim /usr/local/bin/ ``` +
Fedora Install Steps ``` sudo dnf install -y gcc make git ripgrep fd-find unzip neovim ``` +
Arch Install Steps @@ -237,5 +246,5 @@ sudo dnf install -y gcc make git ripgrep fd-find unzip neovim ``` sudo pacman -S --noconfirm --needed gcc make git ripgrep fd unzip neovim ``` -
+ diff --git a/init.lua b/init.lua index e31de904..1e06ed27 100644 --- a/init.lua +++ b/init.lua @@ -33,6 +33,7 @@ require('lazy').setup({ require 'plugins.lsp', require 'plugins.conform', require 'plugins.nvim-lint', + require 'plugins.render-markdown', -- NOTE: Plugins can also be configured to run Lua code when they are loaded. -- -- This is often very useful to both group configuration, as well as handle diff --git a/lazy-lock.json b/lazy-lock.json index ea57d765..c0f20f2d 100644 --- a/lazy-lock.json +++ b/lazy-lock.json @@ -24,6 +24,7 @@ "nvim-ts-autotag": { "branch": "main", "commit": "a1d526af391f6aebb25a8795cbc05351ed3620b5" }, "nvim-web-devicons": { "branch": "master", "commit": "19d6211c78169e78bab372b585b6fb17ad974e82" }, "plenary.nvim": { "branch": "master", "commit": "857c5ac632080dba10aae49dba902ce3abf91b35" }, + "render-markdown.nvim": { "branch": "main", "commit": "c809fc129f842a7055c672593d24be6346bcc673" }, "telescope-fzf-native.nvim": { "branch": "main", "commit": "1f08ed60cafc8f6168b72b80be2b2ea149813e55" }, "telescope-ui-select.nvim": { "branch": "master", "commit": "6e51d7da30bd139a6950adf2a47fda6df9fa06d2" }, "telescope.nvim": { "branch": "master", "commit": "b4da76be54691e854d3e0e02c36b0245f945c2c7" }, diff --git a/lua/plugins/render-markdown.lua b/lua/plugins/render-markdown.lua new file mode 100644 index 00000000..76aed403 --- /dev/null +++ b/lua/plugins/render-markdown.lua @@ -0,0 +1,9 @@ +return { + 'MeanderingProgrammer/render-markdown.nvim', + dependencies = { 'nvim-treesitter/nvim-treesitter', 'echasnovski/mini.nvim' }, -- if you use the mini.nvim suite + -- dependencies = { 'nvim-treesitter/nvim-treesitter', 'echasnovski/mini.icons' }, -- if you use standalone mini plugins + -- dependencies = { 'nvim-treesitter/nvim-treesitter', 'nvim-tree/nvim-web-devicons' }, -- if you prefer nvim-web-devicons + ---@module 'render-markdown' + ---@type render.md.UserConfig + opts = {}, +}