-
-
Notifications
You must be signed in to change notification settings - Fork 39
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
treewide: refactor neovim-flake #225
Conversation
0ae497b
to
6762516
Compare
909f853
to
7c66ea2
Compare
no objections, I feel like inputs would be good for stability if we only had a small set of well tested plugins, but we're way past that point now |
I'd like to get rid of the input system that we have now, but I also would like to avoid having to pin/overlay plugins to get their latest versions. Nixpkgs usually lags back a month or two, and an individual override for each plugin that's behind master would be annoying. Perhaps we should reconsider inputs (but automate adding plugin inputs to the list to reduce a development step) or consider something like npins? |
utility/telescope: provide configurable vimgrep options
Why cannot we just use nixpkgs and have the user deal with what version of the packages? It would make the inputs only nixpkgs, the flake specific stuff, and anything that shouldn't be in nixpkgs. There would be some difficulties with transitioning to it, like people on nixpkgs stable won't get the new packages for a while, but I think that may be the simplest way to do it. |
Leaving the responsibility of dealing with the packages is annoying for the user. There can be a new configuration option, or a configuration option removed outside user's knowledge that would cause neovim to spit a whole bunch of errors, potentially confusing the user. As much as I dislike having a whole bunch of inputs (that's an understatement tbh), it allows us to pin package versions for our convenience. If the user wants to override (e.g. go back, or upgrade before us), it's easy as overriding an input because the plugins are built from their inputs. |
1d449ff
to
afa3c90
Compare
@horriblename could you rebase #228, #229 and #230 around this PR? It's creating a lot of merge conflicts and I think it's better to deal with them now than to wait for me to finish refactoring and then deal with the consequences altogether. |
Being continued in #231 |
Okay this has been long overdue, and I am finally pissed enough to spend what's left of my free time (and energy) on aggressively refactoring neovim-flake to have a sane and easy to grasp structure for contributors and maintainers alike.
This PR is that.
DONE
lib/modules/default.nix
->flake/modules/hm-module.nix
modules/
modules/plugins/
Basic
andCore
have been isolated asöodules/core
andmodules/neovim
(previously basic)`core
will contain wrapper and build related filesneovim
will contain the most basic vim/neovim options that are passed to base configurations.In Progress
inherit (lib) concatStringsSep
, we useinherit (lib.strings) concatStringsSep
to ensure clarity. This slightly clutters the beginning of each file, but it's more understandable where exactly the function comes from (especially when working with the extended lib)TODO/TBD
Things I want to do:
Things I might want to do:
package
options, or a packages list that gets passed to Neovim wrapper.