-
-
Notifications
You must be signed in to change notification settings - Fork 42
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
Leading commas are unhandy #95
Comments
What's Haskell ? 😉
Un-unhandied in: #98
Thank you for supporting your point with arguments, this is the way to go about style discussions
Alejandra is different |
Just for reference because this made me curious as to why people even consider leading commas; There are basically two arguments in favor of leading commas:
I don't really see the former point as particularly relevant, because a missing comma isn't that hard to spot, at least if you have tooling shouting at you that your code is broken before it is deployed. I can see the argument if the language implementation doesn't give you good error messages for missing tokens, or if checks for this are somehow entirely runtime-only, but I don't think that applies to nix, and I think error messages that bad are both uncommon in modern languages and significantly less problematic thanks to the in-line highlighting provided by virtually all editors/IDEs. Hell, GitHub's font-lock becomes very screwy if you mess up basic syntax. The latter argument doesn't seem to really apply to nix, and the formatting suggested by Alejandra lends itself to both single-line diff appending and prepending, so it seems poorly placed for the language and irrelevant in practice. There are also some dubious analyses of github projects that apparently show that projects with leading commas are more successful on average, but that is the definition of cargo culting and hence I just reject any argument based on that on principle. |
I don't think this is a good change. Leading commas are used all over Nixpkgs for arguments and it's basically the standard next to long line argument blobs. I take issue with the argument of not being able to edit the first one as easily as all the others in two ways:
I don't buy the inconsistency either, the last argument in the postfix comma style has no comma. That's even less consistent IMO. |
This is not true, Nix has had trailing commas for a while now. If Nix didn't have this, I'd agree with out that leading commas are the better choice, because as you said the first function argument usually stays the same. In fact, the style we currently use initially started as a workaround when there were no trailing commas. |
Again the
Good point. But this is a specific property of the nixpkgs repo and the way arguments are ordered there (non alphabetic ordering etc.). You cannot even be sure if it will always stay like that in nixpkgs in the future. Also there can be function args in many places other than at the top of package expressions where neither lib, nor pkgs, nor stdenv will usually be the first argument.
You can always fight issues with better tools and better skills. But wouldn't it be better if the design wouldn't require that in the first place?
Not sure how this statement demonstrates superiority of either leading or trailing commas.
Sounds not so convenient.
This is why trailing commas are allowed even for the last argument (see last example below) Examples:let..in lines all ending with
|
No, it doesn't. It's an argument for keeping the diff small (reducing formatting noise) and defaulting to what the majority is used to, minimising the need for mental adjustment when reading code.
To my knowledge, Nixpkgs is the largest repository of Nix expressions and de-facto upstream. "Downstream" users don't have to oblige by its rules by any means but if we have to chose a default, choosing what the most significant code source does is the only sensible choice.
No but it's a good assumption and, should opinions change later, it'd be a major community effort like an RFC and that would warrant a change in alejandra at that point.
Some, yes; a minority though I'd argue. And those probably don't need to change very often either.
It would but not if it comes at the cost of readability. Code needs to be read much, much more often than it needs to be written and altering the first argument (the only place this matters) is even rarer. The primary purpose of a code formatting making code better to read. Making it easier to edit is a nice side-effect of that at best.
It doesn't. It demonstrates that the supposed superiority of trailing commas doesn't matter when proper tools are used. I'd argue anyone that cares about something as insignificant as adjusting a few more characters should also be interested in using better tools to do their job more efficiently.
A comma implies a statement following it and the absence of which would confuse a reader. Again, readability comes first. I personally quite like enforcing optional following commas for keeping diffs tidy but readability of the code is more important than the readability of diffs.
Because that rule has already been broken by languages whose syntax almost everyone is used to. I'd like to see you try to find developers who haven't used C, Java and/or JavaScript (and many other languages with C-ish syntax) where commas are used for separating function arguments and commas without a following argument are either a syntax error or frowned upon. I don't think you'll find many. No, it's not consistent. The syntax for attrset arguments isn't consistent with anything either (commas instead of semicolons, no I think the formatter should keep as much about the original author's intent as possible, so I wouldn't be opposed to optionally allow following comma syntax if it's already present but I'd also prefer if we unified on one way of doing things because a formatter should also be a tool to combat bikeshedding. Converting a block with multiple following comma arguments per line to a stack of leading comma, one argument per line is also something you could want off a formatter; to enforce a unified style a repository has agreed upon. IMO any formatter preference should be configurable (a la editorconfig) and default to whatever the most significant part of the community most commonly does. |
I'd suggest trying to format using the web editor's random button for a while (or even just reading nixpkgs). The absolute majority of packages use a single line for their args. Even packages that use leading comma often have one line that has many args. Others used If you really care, it would be interesting to see actual numbers for this. How many pieces of the codebase actually use leading comma syntax consistently, and would be negatively affected? How many already use trailing comma?
The problem with that argument is that more changed characters means bigger diffs for the rest of eternity, and there simply is no alternative. I'm not sure I care much personally, but there is a distinct advantage here that no amount of tool reliance can circumvent. Trailing commas are objectively better for this detail, and this change is based on that detail. Anyway, we're talking about making one of these better tools right now, so I don't think this is the time for insulting people about their inferior tool usage.
Code readability is extremely subjective, and, as you say yourself in reference to tool usage, this is a very minor point that is unlikely to actually confuse anyone. I personally find trailing comma less surprising, and it probably will be for many developers and non-developers alike - after all, written natural languages frown upon leading commas, so you don't need to subscribe to C-isms to be exposed to this; just any language using a Roman alphabet. But this is subjective, and we will likely never agree on which is more readable. If you read around the nixpkgs repo today, you'll find a lof of inconsistency, including the style of function args, among which many formatting choices were made with not much prior thought (as is bound to happen over time without tools or a standard). Setting a new standard that improves on what is there currently should not be out of scope - so please, keep arguments as far from subjectivity as possible. |
I'm rather surprised to see this merged and so quickly. Personally, I'd tolerate whichever convention, as long as we have an actually "uncompromising formatter" (like black for python - I them, I use them). I'm not reading the whole thread now, but have we checked just which convention causes fewer changes in nixpkgs? |
No, but given that many parts of nixpkgs use leading comma at the moment I don't think there is much to check. However, this is besides the point. In my opinion, the important questions are:
|
I don't immediately know what units of measurements are fit for assessing which commas are superior, but I can see how to measure the diff size, and how the diff size could be relevant to mass adoption in nixpkgs :) |
Ask the following questions (in no particular order):
To be honest, I don't see a strong relationship there. I'd argue that it doesn't really matter whether the final formatting PR touches 80% or 85% of all the |
That is indeed to be expected, and why an RFC for adopting a general code formatter across the repository is currently open. The idea being that you can't easily use a formatter right now, because the repository is inconsistent, while formatters would be consistent, so if you modify someone else's code you're going to get irrelevant diffs at some point. Those cannot be accepted, because there isn't a standard, so the next person using a different formatter will just create the same irrelevant noise in their PR. The problem isn't really the format you're using as much as it is the fact that you're changing the existing format for no reason, and causing a diff that contains things irrelevant to your actual change, which is confusing and puts additional burden on a reviewer - they need to understand if your change actually does anything now. Please try to avoid doing that, in general, as a courtesy to reviewers. If a formatter for the nixpkgs repo is decided on, though, a big patch introducing the new format could be applied. It would be changing things for a very clear reason, i.e. freeing us all of manual code formatting chores. Alejandra specifically does its best to also change as few semantics as possible - ideally this would be none, but a small number can still be hand-reviewed, while the rest can be checked by asserting nix doesn't rebuild anything. It doesn't matter that much if such a patch would change 80% of the codebase or 85% of it - regardless of the actual choices made here it probably will change most of the repo, because the formatting currently is very inconsistent. So we might as well pick a format that has actual design decisions behind it, rather than organic adaptations of other language's rules that people were used to before writing nix. In the mean time, the pragmatic option is to apply alejandra only on your diffs somehow. You'll have to wait until that RFC is through and implemented to use a formatter for full files on nixpkgs, which is pending on any of the projects becoming mature and accepted enough for that to happen :) |
These were mine diffs, and I applying alejandra to them meets the resistance |
That being this change? I think that's an edge case; the problem is that you put burden on the reviewer there because they had already looked at your code before, and now you changed it completely, so they would need to review it again. If you had written that file with alejandra originally I believe you would not have had any resistance (because there are other modules that don't follow this style, or at the very least because different people seem to have different, but clearly valid, opinions on the matter of which style is preferable, so the outcome would depend on the reviewer). Anyway, we're way off topic here. We should pick this back up if the question of leading commas becomes contentious in the RFC, or if there are additional arguments for adopting leading commas. |
No, I don't think that is the case. From my previous interactions with them, they are very strict about "minor" things like this. This can be annoying at times but it's for good reason I believe. As one of the top Nixpgks reviewers, they read much, much more Nix than any of us do. We should ask them on their opinion on this matter. |
I have run into the same situation with the same person more than once. I am not okay with people unilaterally deciding on some code style and then enforcing it through mass code review. Note that this specific style question is not the only one: I remember bulk PRs changing This is the main reason why we are having this discussion right now. So that we finally decide on a style, and make these endless review comments that have nothing to do with the actual content of the changes stop. |
Almost all files in nixpkgs are formatted with the comma in the beginning of inputs. I didn't come up with that and there are only advantages to keep it like that and having a very similar style across all files. Changing that would be stupid and create a massive diff, would require to change a very big chunk of PRs and changing the default formatters everyone is using. If you want to do it different in your personal projects go ahead but introducing it to nixpkgs is something we shouldn't do. It should have been done different in the beginning but now we are stuck with that decision ages ago.
black is a very good example why uncompromising formatters are not great. It tries to create shorter lines by putting
No and it isn't temporary and also not short. It will take weeks or more likely months and a lot of time for people to adjust and change all things. Is that worth it for an opinionated change? No, especially because we have bigger issues where our time should be invested.
The problem with alexandria is that it changes significant more lines than nixpkgs-fmt and the default style and does not allow people to do opinionated formattings where it makes sense. So far we couldn't even agree on nixpkgs-fmt which changes much less and allows more freedom, so alexandria has a far higher burden. First agreeing on nixpkgs-fmt would be an entry to have an accepted formatter. If nixpkgs-fmt and alexandria would be compatible it would be ideal and I would happily accept both tools. If someone else later only formats the file with nixpkgs-fmt and isn't undoing half the changes both tools could coexist with each other and everyone could benefit.
Hey, at least I am consistent and I treat every contributor the same. :)
I told you that before and you are still ignoring it: I didn't decide on this. I didn't come up with this. It was the coding style I was introduced in the beginning and the one currently the most people use and most files are formatted in. It naturally only made sense to adopt that one to keep the friction with the majority of people the lowest.
Yes and I choose the path that has the least changes from the current situation while others try to redefine the style from the ground up which is far more work and way harder to get everyone to agree on. So, I am now continuing playing Assassin's Creed Valhalla and viking more. 🎮 Happy Sunday everyone! |
You can choose
❤️ |
|
I know that leading commas seem to be a standard in haskell and somehow everyone does it, but actually it's unhandy when editing code.
Explanation of why leading commas negatively impact editing experience is already given in the equivalent issue on nixpkgs-fmt: nix-community/nixpkgs-fmt#248 (comment)
To summarize what has already been said:
{
and subsiding ones with,
.In the other thread, there were a lot of opposing opinions to what I'm saying, but if we are having this discussion on a scientific basis, any opposing argument to this should either contain an explanation of why my statements are wrong or irrelevant, or explain disadvantages of trailing commas.
I am still waiting for such a response.
I think if we want to achieve the best possible result, we need to leave personal preferences out of this as well as statements like
but this is what everyone does
.The text was updated successfully, but these errors were encountered: