Skip to content
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 a canonical rustfmt config #86

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open

Add a canonical rustfmt config #86

wants to merge 1 commit into from

Conversation

PoignardAzur
Copy link
Contributor

No description provided.

Comment on lines +34 to +35
# Forces let else blocks to always be their own line(s)
single_line_let_else_max_width = 0
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we do decide to set this, I'd expect it to have the same value as single_line_if_else_max_width, I think.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Indeed, they seem very similar and have identical default values.

use_field_init_shorthand = true

# Forces let else blocks to always be their own line(s)
single_line_let_else_max_width = 0
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Obviously this isn't used at all in Linebender yet. This is a reasonable value, but I'd lean more towards keeping the default without very good reason, for consistency with the rest of the ecosystem.

This is certainly more taste based than the other two options here.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For what it's worth I copy-pasted it from the xilem repo.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm. Fair. I don't care that much either way.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah we approved it in xilem#305. What I said back then still applies for me: it's quite minor and so I don't personally care much either way.

I believe this was originally added by you @PoignardAzur. So if you still think it's worth having, then I'm fine with it and don't want to bikeshed it. However, if you're not arguing for its benefit, then I don't think we have anyone doing that and we should omit it by default as Daniel mentioned.

Copy link
Member

@xStrom xStrom left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Properly standardizing this across repos has been a long time coming, thanks for getting the ball actually rolling.


# Forces let else blocks to always be their own line(s)
single_line_let_else_max_width = 0
# END LINEBENDER RUSTFMT CONFIG
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we should keep the import ordering settings as part of the standard. These have been discussed at various times before and are present in the commented out form in various repos. It would be nice to skip bikeshedding them again later.

The chosen options also match what were chosen by the Rust compiler team for their own code.

The specific suggestion here is copy-pasted from Xilem.

Suggested change
# END LINEBENDER RUSTFMT CONFIG
# Subjectively, this combo improves readability on imports. The full prefix is always
# visible right after `use`, and different types of imports are grouped together in
# a predictable way (first std, then other crates, then local imports).
# (These options are still unstable and thus commented out)
# imports_granularity = "Module"
# group_imports = "StdExternalCrate"
# END LINEBENDER RUSTFMT CONFIG

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One of the reasons I didn't include them, besides them being unstable and commented out, is that we don't actually apply them even if the repositories where they're included.

There's a bunch of cases where strictly following these settings actually makes the import code harder to read, because it doesn't take into account things like cfg attributes which may make you want to import something separately.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not actually applying them yet is true, but also I think that is a bit of a chicken and egg problem. Having it be part of this standard config would help us propagate it to all the repos that would make actually occasionally applying it much easier. I can volunteer to do a pass of all the repos to apply it once the config has been propagated.

Now not taking into account things like cfg attributes would definitely be a blocker. However I'm not aware of any cases where this actually happens. I just did a test run of this on the Xilem repo and the only file where I saw cfg attribute guarded imports is masonry/src/render_root.rs. In that file it behaved correctly, it moved both the import and its guard together.

#[cfg(not(target_arch = "wasm32"))]
use std::time::Instant;

Do you have an example of where rustfmt fails with cfg attributes?

For what it's worth I also think that the Rust compiler team adopting these settings is a strong enough signal that the remaining bugs aren't very severe.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I didn't say there was a bug. Just, there are some cases where I want the cfg-guarded imports to be in a separate block.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In my mind, the reason to want these settings is to reduce merge conflicts, not to have ideal formatting in all cases (as is the case with all auto-formatting...).

I do agree that having cfg-d imports not intermingled would be better, but given that there's supposedly only one case of this in the entire Xilem repository, I agree with Kaur that we should aspire to enabling this.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's merge linebender/xilem#838, then I'll create a PR showing the remaining differences, so we have a concrete example.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants