Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alejandrosuero/freeze-code.nvim
Take a code screenshot using freeze by https://charm.sh/
https://github.com/alejandrosuero/freeze-code.nvim
charm charmbracelet code freeze golang neovim neovim-plugin nvim open-source plenary plugin
Last synced: 17 days ago
JSON representation
Take a code screenshot using freeze by https://charm.sh/
- Host: GitHub
- URL: https://github.com/alejandrosuero/freeze-code.nvim
- Owner: AlejandroSuero
- License: mit
- Created: 2024-05-12T03:09:23.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-09-27T12:03:30.000Z (about 1 month ago)
- Last Synced: 2024-10-03T08:07:22.518Z (about 1 month ago)
- Topics: charm, charmbracelet, code, freeze, golang, neovim, neovim-plugin, nvim, open-source, plenary, plugin
- Language: Lua
- Homepage: https://luarocks.org/modules/AlejandroSuero/freeze-code.nvim
- Size: 158 KB
- Stars: 21
- Watchers: 1
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
[![Stargazers][stars-shield]][stars-url]
[![Issues][issues-shield]][issues-url]# Freeze Neovim Plugin
Take a "screenshot" of your code by turning it into an image, thanks to
[freeze](https://github.com/charmbracelet/freeze) by [charm](https://charm.sh/).[Report an issue](https://github.com/AlejandroSuero/freeze-code.nvim/issues/new?assignees=&labels=bug&projects=&template=bug_report.yml&title=%5BBug%5D%3A+)
· [Suggest a feature](https://github.com/AlejandroSuero/freeze-code.nvim/issues/new?assignees=&labels=enhancement&projects=&template=feature_request.md&title=%5BFeat%5D%3A+)**Remember to always follow the [code of conduct](https://github.com/AlejandroSuero/freeze-code.nvim/blob/main/CODE_OF_CONDUCT.md#contributor-covenant-code-of-conduct)**
> [!warning]
>
> This plugin requires Neovim v0.9.0 or higher## Installation
Using your plugin manager at your disposal, in the example
[lazy](https://github.com/folke/lazy.nvim) is going to be used.> [!note]
>
> If you don't have [freeze](https://github.com/charmbracelet/freeze) installed,
> and if you have [golang](https://go.dev) installed, it will
> `go install github.com/charmbracelet/freeze@latest` for you 🫡.
>
> In the case that you don't have neither of those, don't you worry 😉, we got you
> cover. It will install `freeze` using `cURL` to the
> [freeze's releases page](https://github.com/charmbracelet/freeze/releases).- Default installation:
```lua
return {
"AlejandroSuero/freeze-code.nvim",
config = function()
require("freeze-code").setup()
end,
}
```> [!note]
>
> You can also install it using [Rocks.nvim](https://github.com/nvim-neorocks/rocks.nvim)
>
> `:Rocks install freeze-code.nvim`
>
> Also as `luarocks install freeze-code.nvim`- Customizable installation:
```lua
return {
"AlejandroSuero/freeze-code.nvim",
config = function()
require("freeze-code.nvim").setup({
-- your configuration goes here
})
end,
}
```> [!note]
>
> See default configuration below.```lua
local opts = {
freeze_path = vim.fn.exepath("freeze"), -- where is freeze installed
copy_cmd = "", -- the default copy command is native to your OS (see below)
copy = false, -- copy after screenshot option
open = false, -- open after screenshot option
dir = vim.env.PWD, -- where is the image going to be saved "." as default
freeze_config = { -- configuration options for `freeze` command
output = "freeze.png",
config = "base",
theme = "default",
},
}
```> [!note]
>
> The commands to copy, as defaults per OS will be, for example, for Windows:
> `Add-Type -AssemblyName System.Windows.Forms; [System.Windows.Forms.Clipboard]::SetImage(...)`,
> for Linux: `xclip -selection clipboard -t image/png ...` if is an `X11` session,
> `wl-copy < ...` if is a `Wayland` session, and for MacOS:
> `osascript -e 'to set the clipboard to (read (POSIX file "...") as «class PNGf»)'`.If you specify a `copy_cmd` in the configuration, it will be used instead of the
default one. To use the custom command, you need to specify `"filename"` in the
command, where the image will be saved.Once you have it installed, you can use `:checkhealt freeze-code` to see if there
are any problems with the installation or you need to install additional tools.## Usage
To use this plugin, simply call `:Freeze` and it will take a screenshot of the
current buffer and save it in the `dir` path you have configured.If you want to take a screenshot of a specific line, you can use the `:Freeze` in
visual mode, and it will take a screenshot of the selected lines.### Keymaps
```lua
local fz_api = require("freeze-code.utils.api")
vim.keymap.set("n", "fz", fz_api.freeze)
vim.keymap.set("v", "fz", function()
fz_api.freeze(vim.fn.line("'<"), vim.fn.line("'>"))
end)
-- or using `Freeze`
vim.keymap.set("n", "fl", fz.freeze_line)
-- or using `FreezeLine`
```## Contributing
Thank you to everyone that is contributing and to those who want to contribute.
Any contribution is welcomed!**Quick guide**:
1. [Fork](https://github.com/AlejandroSuero/freeze-code.nvim/fork) this
project.
2. Clone your fork (`git clone `).
3. Add main repo as remote (`git remote add upstream `).
4. Create a branch for your changes (`git switch -c feature/your-feature` or
`git switch -c fix/your-fix`).
5. Commit your changes (`git commit -m "feat(...): ..."`).
6. Push to your fork (`git push origin `).
7. Open a [PR](https://github.com/AlejandroSuero/freeze-code.nvim/pulls).For more information, check
[CONTRIBUTING.md](https://github.com/AlejandroSuero/freeze-code.nvim/blob/main/CONTRIBUTING.md).### Contributors
Thanks goes to these wonderful people that have contributed to this project:
[![contributors][contributors-img]][contributors-url]
[stars-shield]: https://img.shields.io/github/stars/AlejandroSuero/freeze-code.nvim.svg?style=for-the-badge
[stars-url]: https://github.com/AlejandroSuero/freeze-code.nvim/stargazers
[issues-shield]: https://img.shields.io/github/issues/AlejandroSuero/freeze-code.nvim.svg?style=for-the-badge
[issues-url]: https://github.com/AlejandroSuero/freeze-code.nvim/issues
[contributors-url]: https://github.com/AlejandroSuero/freeze-code.nvim/graphs/contributors
[contributors-img]: https://contrib.rocks/image?repo=AlejandroSuero/freeze-code.nvim