-
Notifications
You must be signed in to change notification settings - Fork 76
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
Add option for formatting with spaces between function names and arguments #839
Add option for formatting with spaces between function names and arguments #839
Conversation
94ba46a
to
530aa62
Compare
530aa62
to
cb823a1
Compare
I'm using this in production including setting the config option it introduces all over the place. The results are what I want to see. If the implementation here isn't the best way to do it or needs adjusting to be included I'm happy to adapt, but it would be nice if this could get upstreamed so I don't have to push by fork of StyLua on anybody contributing to my Lua projects ;-) |
I think I'm going to get some movement on #854 this weekend (which I want to merge before next release) so I also hope to review this too. Sorry for the wait! |
Sure fair enough. From an implementation standpoint there are probably better ways to do this (I was quite unfamiliar with the code base) even with the current parser, and improved full-moon interfaces may open up even better ways. From the perspective of the end user feature introduction the two important parts are the name of the new config option key and values paired with their respective expected test outputs. Everything in between is implementation details that could be refactored at any time. Personally I'm only interested in the |
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.
Implementation itself looks good to me, thank you!
the name of the new config option key and values paired with their respective expected test outputs
I'm trying to think if the key name is complete descriptive of what is actually happening here for someone with no context. The space isn't really after the function, so maybe it should be space_in_functions
or space_in_functions_before_parentheses
. Not sure though, naming is always hard.
@@ -1158,7 +1165,8 @@ pub fn format_function_declaration( | |||
shape | |||
) | |||
.update_leading_trivia(FormatTriviaType::Append(leading_trivia)); | |||
let formatted_function_name = format_function_name(ctx, function_declaration.name(), shape); | |||
let formatted_function_name = format_function_name(ctx, function_declaration.name(), shape) | |||
.update_trailing_trivia(FormatTriviaType::Append(function_definition_trivia)); | |||
|
|||
let shape = shape + (9 + strip_trivia(&formatted_function_name).to_string().len()); // 9 = "function " |
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.
A point worth mentioning is that our "shape" calculation here (and potentially elsewhere) will not take into account the fact that a space was added after the function name (since we explicitly strip the trivia afterwards). Shape is used to store the amount of line budget used so far and how many characters we have left on a line. This opens up a very small edge case where the definition line now hits column_width + 1
characters because of the space, but shape only sees column_width
and therefore we don't reformat correctly. It's quite a minor edge case though, unsure if it is worth rectifying until someone brings it up
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'd be happy to fix the edge case if I had any idea where/how, but I wasn't actually that clear on the internals of how that was being done or where extra info should be passed to get it back. Given what you say here I'm guessing the same edge case might exist for some other scenarios unrelated to this PR, no?
cb823a1
to
1cb1676
Compare
Yes naming is hard. I'm happy to refactor this to another name if you think it best, but I'm not convinced there are better options. Actually instead of I don't like |
The lint error seems to be unrelated to this PR and more related to a new Rust version. In fact it might even be a false positive for the new lint, I know there was some talk of false positives in new docstring lints. I haven't looked into whether this is one of them, but it seems that should be in a separate PR anywhere. |
1cb1676
to
6cef63c
Compare
The force-push just now was to add a missed bit to override the configs if CLI arguments were present. The option was working from config (or editor config) and accepted from the CLI but silently ignored. |
Beep beep, gentle ping. I keep wanting to contribute style overhauls and CI jobs for projects using this, but it's kind of limiting to have it stuck in a PR. Many of the projects I hope to see adopt this already use this style (for example Pandoc) and it would be unreasonable churn to expect them to change. |
I am so so sorry for this delay, I haven't had the chance to work on this project for a while. I renamed the option to Thank you for taking the time to contribute this, sorry it took almost a year to get it in. I'm going to try get the full-moon update PR ready soon to get this out into a release |
Closes #832
So far just some CLI options and tests. Work on implementation pending feedback in issue.All options implemented and tested.