-
-
Notifications
You must be signed in to change notification settings - Fork 295
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: switch back to alejandra formatting #1629
Conversation
Remove explicit `formatter = config.treefmt.build.wrapper`, because treefmt's `flakeFormatter` option (default `true`) handles that for us.
Sorry nixfmt-rfc-style; it's not you, it's me.
Initially added to ignore large-scale reformatting commits when using `git blame`. See [GitHub's Documentation][1] and the [`git blame` manual][2]. [1]: https://docs.github.com/en/repositories/working-with-files/using-files/viewing-a-file#ignore-commits-in-the-blame-view [2]: https://www.git-scm.com/docs/git-blame#Documentation/git-blame.txt---ignore-revs-fileltfilegt
The changes look correct to me. The |
Of course, let's wait for @traxys's confirmation before merging such a change. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
After scrolling through a decent portion of the diff and observing formatting differences, I'm less convinced this is a change worth making.
I do think we should discuss it further, but many of the improvements we were expecting from switching back to Alejandra don't seem to have happened.
There are a few cases where the formatting is better, but just as many where it is worse.
perSystem = { | ||
pkgs, | ||
system, | ||
... | ||
}: { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
IMO nixfmt is better here:
perSystem = { | |
pkgs, | |
system, | |
... | |
}: { | |
perSystem = { pkgs, system, ... }: { |
{ | ||
imports = [ inputs.devshell.flakeModule ]; | ||
{inputs, ...}: { | ||
imports = [inputs.devshell.flakeModule]; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Personally, I prefer whitespace in lists:
imports = [inputs.devshell.flakeModule]; | |
imports = [ inputs.devshell.flakeModule ]; |
{ | ||
_module.args.getHelpers = | ||
pkgs: _nixvimTests: | ||
{getHelpers, ...}: { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Again, I prefer the nixfmt padding:
{getHelpers, ...}: { | |
{ getHelpers, ... }: { |
{lib, ...}: | ||
with lib; { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think I do prefer how alejandra indents this and keeps the opening bracket inline with the with
statement.
nixfmt's indentation is less clear.
# description = null or "<DESCRIPTION>"; | ||
# url = null or "<URL>"; | ||
# } | ||
merge = _: defs: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I like having function parameters inline with the attribute name, so this is an improvement.
mkStrLuaOr' = { | ||
default, | ||
description, | ||
... | ||
} @ args: | ||
mkNullOrStrLuaOr' (convertArgs args); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this is a downgrade.
mkEnum' = { | ||
values, | ||
default ? head values, | ||
... | ||
} @ args: | ||
# `values` is a list and `default` is one of the values (or null) | ||
assert isList values; | ||
assert default == null || elem default values; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The comment is indented poorly. IDK if alejandra allows manual intervention in this case, though.
logLevel = types.enum [ | ||
"off" | ||
"error" | ||
"warn" | ||
"info" | ||
"debug" | ||
"trace" | ||
]; | ||
logLevel = types.enum [ | ||
"off" | ||
"error" | ||
"warn" | ||
"info" | ||
"debug" | ||
"trace" | ||
]; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This kind of multi-line list was one of @GaetanLepage's biggest complaints with nixfmt, however alejandra doesn't appear to be any different 😖
@@ -11,69 +12,78 @@ with lib; | |||
"__empty" = null; | |||
}; | |||
|
|||
/** | |||
Turn all the keys of an attrs into raw lua. | |||
/* |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Alejandra doesn't support RFC145 docstrings!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is a patch for this issue, though we probably want to avoid compiling a rust program each time we format our code
helpers.defaultNullOpts.mkEnumFirstDefault | ||
[ | ||
"default" | ||
"tinted" | ||
"deuteranopia" | ||
"tritanopia" | ||
] | ||
'' | ||
Styles come in four variants: | ||
|
||
- `default` is the plugin's main style designed to cover a broad range of needs. | ||
- `tinted` tones down intensity and provides more color variety. | ||
- `deuteranopia` is optimized for users with red-green color deficiency. | ||
- `tritanopia` is optimized for users with blue-yellow color deficiency. | ||
''; | ||
[ | ||
"default" | ||
"tinted" | ||
"deuteranopia" | ||
"tritanopia" | ||
] | ||
'' | ||
Styles come in four variants: | ||
|
||
- `default` is the plugin's main style designed to cover a broad range of needs. | ||
- `tinted` tones down intensity and provides more color variety. | ||
- `deuteranopia` is optimized for users with red-green color deficiency. | ||
- `tritanopia` is optimized for users with blue-yellow color deficiency. | ||
''; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another example of relatively short lists being formatted essentially the same.
This might need a deeper look indeed. Alejandra is probably less strict than nixfmt, so we might have some margin to adapt code here and there. To be confirmed though. |
For me it's not a big deal, also. But all else being equal, I find the nixfmt style, with whitespace, to be more readable.
We can use the Alejandra playground and Nixfmt online demo to experiment, I guess. I'm not sure how I feel about attempting to make a few cases slightly better, if it still doesn't solve the overall issue. In general, I think we should avoid large sweeping changes (like this) unless they have a clear benefit.
I'd be surprised if that is the case, but for sure worth investigating: Alejandra was originally marketed as a fully AST-based (and therefore deterministic) formatter, but that may have changed I guess. To quote:
|
Specifically on lists, I stand corrected. If your input code has the list on a single line, alejandra will avoid splitting it up. So you could have two identical lists, formatted differently in alejandra. As an example, this is valid code formatted by alejandra: {
foo = ["default" "tinted" "deuteranopia" "tritanopia"];
bar = [
"default"
"tinted"
"deuteranopia"
"tritanopia"
];
} Whether or not this non-determinism is a good or a bad thing, I'm undecided. |
As for practical ways we could apply that formatting to 450 files, I'm at a loss. For files with no changes since 62f32bf, we could simply checkout a copy of the file from the parent commit For other files, we'd either have to review every list on a case-by-case basis or write a small single-purpose custom formatting tool that decides based on list length and/or resulting line-length whether to format a list on one line or not. If we do that, I think it should be done as part of the treewide reformat commit, so that it can be a single entry in the ignore-revs file. That said, I'm not 100% convinced it is worth the effort. This issue in particular is annoying, because it means we can't use RFC145 docstrings. |
That's one of the reasons I don't like alejandra much, it leaves a huge user choice in the mix, making it difficukt to enforce a style & having loads of PRs with only style reviews. |
For me the biggest use of a formatter is to avoid any style comments in PRs (or at least try to have almost none). I feel like with nixfmt we have had much less of those, and I'd like that to continue, so I guess the options I'd like are either we stay on nixfmt, or we go back to |
I agree on the fact that a "strict" formatter is preferable. However, in this case, the question was worth considering as I find the nixfmt style very less readable than alejandra. But not having to discuss style in PR reviews is a significant benefit of nixfmt... Not easy... |
I've marked this as draft since discussion is ongoing and any decisions would likely involve changes to the PR. I think we're all agreed that a strict formatter is preferable, however we sometimes find specific nixfmt choices less readable than manual formatting. Frankly, to some degree this is inevitable; the stricter a formatter is the more edge case you'll run into where it doesn't work well for that specific scenario. For short non-singleton lists, we may be able to patch nixfmt instead of resorting to an entirely different formatter... This would give us the "best of both worlds". I doubt such a patch would be accepted upstream (maybe behind an option though?) since it was likely already discussed in the RFC, but we could maintain it as a nixvim patch or a standalone flake repo. Are short non-singleton lists the only solid example where you prefer alejandra @GaetanLepage? FYI the nixfmt standard describes this in the Expansion of expressions section. It does have good justifications, but I agree it is on-the-whole less readable in our codebase:
|
I am willing to put my preferences aside considering the importance of strict formatting. This is indeed the most important feature of the formatter. |
I'll close this as I think we're all agreed we don't want to do this. Fingers crossed NixOS/nixfmt#206 is accepted upstream or we are able to maintain our own patch. |
This PR switches back to using Alejandra to format the project, as discussed on matrix.
A git blame ignore-revs-file is included using a filename recognised by GitHub.
To use this locally, you should configure your git config as described in
.git-blame-ignore-revs
's header comments. Or see this section of the git manual.In the future, it'd be nice to automatically add that config, e.g. via git-hooks and/or a devshell hook.
I kept the change in flake-modules and the actual treewide re-formatting in separate commits for ease of review, however they can be squashed if preferred.
Note to self: when squashing or rebasing, remember to update the sha in
.git-blame-ignore-revs
!!