1
0
Fork 0
mirror of https://github.com/NotAShelf/neovim-flake.git synced 2024-12-26 04:29:49 +01:00
neovim-flake/.github/README.md

244 lines
9.6 KiB
Markdown
Raw Normal View History

2023-07-16 12:15:32 +02:00
<div align="center">
2024-04-27 19:39:28 +02:00
<img src="assets/nvf-logo-work.svg" alt="nvf Logo" width="200">
2024-05-03 11:56:57 +02:00
<br/>
<h1>nvf</h1>
2023-07-16 12:15:32 +02:00
</div>
2024-04-28 20:00:57 +02:00
2023-02-16 20:27:57 +01:00
<div align="center">
2024-04-28 20:00:57 +02:00
<p>
<a href="https://github.com/NotAShelf/nvf/releases/latest">
<img alt="Latest release" src="https://img.shields.io/github/v/release/NotAShelf/nvf?style=for-the-badge&logo=nixos&color=C9CBFF&logoColor=D9E0EE&labelColor=302D41" />
2023-02-06 03:27:15 +01:00
</a>
<a href="https://github.com/NotAShelf/nvf/pulse">
<img alt="Last commit" src="https://img.shields.io/github/last-commit/NotAShelf/nvf?style=for-the-badge&logo=starship&color=8bd5ca&logoColor=D9E0EE&labelColor=302D41"/>
2023-02-06 06:14:28 +01:00
</a>
<a href="https://github.com/NotAShelf/nvf/blob/main/LICENSE">
<img alt="License" src="https://img.shields.io/github/license/NotAShelf/nvf?style=for-the-badge&logo=nixos&color=ee999f&logoColor=D9E0EE&labelColor=302D41" />
2023-02-06 03:27:15 +01:00
</a>
<a href="https://github.com/NotAShelf/nvf/stargazers">
<img alt="Stars" src="https://img.shields.io/github/stars/NotAShelf/nvf?style=for-the-badge&logo=nixos&color=c69ff5&logoColor=D9E0EE&labelColor=302D41" />
2023-02-06 03:27:15 +01:00
</a>
<a href="https://github.com/NotAShelf/nvf/issues">
<img alt="Issues" src="https://img.shields.io/github/issues/NotAShelf/nvf?style=for-the-badge&logo=bilibili&color=F5E0DC&logoColor=D9E0EE&labelColor=302D41" />
2023-02-06 03:27:15 +01:00
</a>
<a href="https://github.com/NotAShelf/nvf">
<img alt="Repo Size" src="https://img.shields.io/github/repo-size/NotAShelf/nvf?color=%23DDB6F2&label=SIZE&logo=codesandbox&style=for-the-badge&logoColor=D9E0EE&labelColor=302D41" />
2023-02-06 03:27:15 +01:00
</a>
2024-04-28 20:00:57 +02:00
</p>
</div>
2023-10-01 15:09:01 +02:00
<p align="center">
<img src="https://stars.medv.io/NotAShelf/nvf.svg", title="stars"/>
2023-10-01 15:09:01 +02:00
</p>
<div align="center">
<a>
nvf is a highly modular, configurable, extensible and easy to use Neovim configuration
in Nix. Designed for flexibility and ease of use, nvf allows you to easily configure
your fully featured Neovim instance with a few lines of Nix.
</a>
</div>
2023-02-06 03:27:15 +01:00
---
2023-02-06 03:44:55 +01:00
<div align="center"><p>
[Features]: #features
2024-04-28 20:00:57 +02:00
[Get Started]: #get-started
[Documentation]: #documentation
[Help]: #help
[Contribute]: #contributing
[FAQ]: #faq
[Credits]: #credits
**[<kbd><br>Features <br></kbd>][Features]**
**[<kbd><br>Get Started<br></kbd>][Get Started]**
**[<kbd><br>Documentation<br></kbd>][Documentation]**
**[<kbd><br>Help<br></kbd>][Help]**
**[<kbd><br>Contribute<br></kbd>][Contribute]**
**[<kbd><br>FAQ<br></kbd>][Faq]** **[<kbd><br>Credits<br></kbd>][Credits]**
2023-02-06 03:27:15 +01:00
2023-02-06 03:44:55 +01:00
</p></div>
2023-02-06 03:27:15 +01:00
---
## Features
2024-09-28 22:43:15 +02:00
- **Reproducible**: Your configuration will behave the same _anywhere_. No
surprises, promise!
- **Portable**: nvf depends _solely_ on your Nix store, and nothing else. No
more global binaries! Works on all platforms, without hassle.
- **Customizable**: There are _almost no defaults_ to annoy you. nvf is fully
customizable through the Nix module system.
2024-09-28 22:43:15 +02:00
- **Well-documented**: Documentation is priority. You will _never_ face
undocumented, obscure behaviour.
2024-09-28 22:43:15 +02:00
- **Idiomatic**: nvf does things ✨ _the right way_ ✨ - the codebase is, and
will, remain maintainable for myself and any contributors.
2023-02-06 03:27:15 +01:00
## Get Started
2023-02-06 03:27:15 +01:00
2024-09-28 22:43:15 +02:00
[nvf manual]: https://notashelf.github.io/nvf/
[issue tracker]: https://github.com/NotAShelf/nvf/issues
If you are not sold on the concepts of **nvf**, and would like to try out the
default configuration before even _thinking about_ installing it, you may run
the following in order to take **nvf** out for a spin.
2023-02-06 03:27:15 +01:00
```bash
2024-09-28 22:43:15 +02:00
# Run the default package
nix run github:notashelf/nvf
2023-02-06 03:27:15 +01:00
```
2023-02-06 03:32:13 +01:00
This will get you a feel for the base configuration and UI design. Though, none
of the configuration options are final as **nvf** is designed to be modular and
configurable.
2023-02-06 03:27:15 +01:00
> [!TIP]
> The flake exposes `#nix` as the default package, providing minimal language
> support and various utilities. You may also use the `#nix` or `#maximal`
> packages provided by the this flake to get try out different configurations.
2023-02-06 03:27:15 +01:00
It is as simple as changing the target output to get a different configuration.
For example, to get a configuration with large language coverage, run:
```bash
2024-09-28 22:43:15 +02:00
# Run the maximal package
nix run github:notashelf/nvf#maximal
2023-02-06 03:27:15 +01:00
```
2024-03-09 03:41:50 +01:00
Similar instructions will apply for `nix profile install`. However, you are
recommended to instead use the module system as described in the manual.
2023-02-06 03:27:15 +01:00
> [!NOTE]
2024-09-28 22:43:15 +02:00
> The `maximal` configuration is quite large, and might take a while to build.
> To get a feel for the configuration, use the default `nix` configuration.
> Should you choose to try out the `maximal` configuration, using the binary
> cache as described in the manual is _strongly_ recommended.
If you are convinced, proceed to the next section to view the installation
instructions.
## Documentation
The _recommended_ way of installing **nvf** is using either the NixOS or the
Home-Manager module, though it is completely possible and no less supported to
install **nvf** as a standalone package, or a flake output.
See the rendered [nvf manual] for detailed and up-to-date installation guides,
configurations, available options, release notes and more. Tips for installing
userspace plugins is also contained in the documentation.
> [!TIP]
> While using NixOS or Home-Manager modules,
> `programs.nvf.enableManpages = true;` will allow you to view option
> documentation from the comfort of your terminal via `man 5 nvf`. The more you
> know.
Please create an issue on the [issue tracker] if you find the documentation
lacking or confusing. Any improvements to the documentation through pull
requests are also welcome, and appreciated.
2023-02-04 02:16:26 +01:00
2023-02-03 22:35:00 +01:00
## Help
You can create an issue on the [issue tracker] to ask questions or report bugs.
I am not yet on spaces like matrix or IRC, so please use the issue tracker for
now.
2023-02-15 16:22:59 +01:00
## Contributing
2024-03-09 03:41:50 +01:00
I am always looking for new ways to help improve this flake. If you would like
to contribute, please read the [contributing guide](CONTRIBUTING.md) before
submitting a pull request. You can also create an issue on the [issue tracker]
before submitting a pull request if you would like to discuss a feature or bug
fix.
2023-02-15 16:22:59 +01:00
2023-02-06 03:27:15 +01:00
## FAQ
[appropriate issue template]: https://github.com/NotAShelf/nvf/issues/new/choose
2024-09-28 22:43:15 +02:00
[list of branches]: https://github.com/NotAShelf/nvf/branches
[list of open pull requests]: https://github.com/NotAShelf/nvf/pulls
**Q**: What platforms are supported?
<br/> **A**: nvf actively supports Linux and Darwin platforms using standalone
Nix, NixOS or Home-Manager. Please take a look at the
**Q**: Can you add _X_?
<br/> **A**: Maybe! It is not one of our goals to support each and every Neovim
plugin, however, I am always open to new modules and plugin setup additions to
**nvf**. Use the [appropriate issue template] and I will consider a module
addition. As mentioned before, PRs adding new features are also welcome.
2023-02-06 03:27:15 +01:00
**Q**: A plugin I need is not available in **nvf**. What to do?
<br/> **A**: **nvf** exposes several APIs for you to be able to add your own
plugin configurations! Please see the documentation on how you may do this.
2023-02-15 15:41:46 +01:00
2024-04-28 19:41:54 +02:00
**Q**: Main branch is awfully silent, is the project dead?
2024-09-28 22:43:15 +02:00
<br/> **A**: No! Sometimes we branch out (e.g. `v0.6`) to avoid breaking
userspace and work in a separate branch until we make sure the new additions are
implemented in the most comfortable way possible for the end user. If you have
not noticed any activity on the main branch, consider taking a look at the
2024-09-28 22:43:15 +02:00
[list of branches] or the [list of open pull requests]. You may also consider
_testing_ those release branches to get access to new features ahead of time and
better prepare to breaking changes.
2024-04-28 19:41:54 +02:00
2023-02-15 16:22:59 +01:00
## Credits
### Contributors
Special, heart-felt thanks to
2023-04-15 10:33:14 +02:00
2023-02-15 16:22:59 +01:00
- [@fufexan](https://github.com/fufexan) - For the transition to flake-parts
- [@FlafyDev](https://github.com/FlafyDev) - For getting the home-manager to
work
- [@n3oney](https://github.com/n3oney) - For making custom keybinds finally
possible
- [@horriblename](https://github.com/horriblename) - For actively implementing
planned features and quality of life updates
- [@Yavko](https://github.com/Yavko) - For the amazing **nvf** logo
- [@FrothyMarrow](https://github.com/FrothyMarrow) - For seeing mistakes that I
could not
- [@Diniamo](https://github.com/Diniamo) - For actively submitting PRs, pull
requests and overall assistence
- [@Gerg-l](https://github.com/gerg-l) - For the modern Neovim wrapper, mnw and
occasional code improvements
2023-02-15 16:22:59 +01:00
2023-04-15 10:33:14 +02:00
and everyone who has submitted issues or pull requests!
2023-02-15 16:22:59 +01:00
### Inspiration
2024-03-09 03:41:50 +01:00
This configuration borrows from and is based on a few other configurations,
including:
2023-02-15 16:22:59 +01:00
- [@jordanisaacs's](https://github.com/jordanisaacs)
[neovim-flake](https://github.com/jordanisaacs/neovim-flake) that this flake
is originally based on.
- [@sioodmy's](https://github.com/sioodmy)
[dotfiles](https://github.com/sioodmy/dotfiles) that inspired the design
choices.
- [@wiltaylor's](https://github.com/wiltaylor)
[neovim-flake](https://github.com/wiltaylor/neovim-flake) for plugin and
design ideas.
- [@gvolpe's](https://github.com/gvolpe)
[neovim-flake](https://github.com/gvolpe/neovim-flake) for plugin, design and
nix concepts.
2023-02-15 16:22:59 +01:00
2024-03-09 03:41:50 +01:00
I am grateful for their previous work and inspiration, and I wholeheartedly
recommend checking their work out.
2023-02-15 15:47:40 +01:00
<br/>
## License
Following the license of the
[original neovim-flake](https://github.com/jordanisaacs/neovim-flake), **nvf**
has been made available under the [**MIT License**](LICENSE). However, all
assets and documentation are published under the
2024-05-01 20:51:50 +02:00
[**CC BY License**](https://github.com/NotAShelf/nvf/blob/main/.github/assets/LICENSE).
2024-09-28 22:43:15 +02:00
<h6 align="center">Yes, this includes the logo work too. Stop taking artwork that is not yours!</h6>
2023-02-06 03:27:15 +01:00
---
<div align="right">
<a href="#readme">Back to the Top</a>
</div>