-
Notifications
You must be signed in to change notification settings - Fork 379
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 YAML formatter #2004
Comments
Hey @adamjstewart I can take care of this. I assume that formatting should be run on all files, not just some specific folder ? Also to clarify, this job should be implemented in style.yaml CI ? |
Yes, all Yes, It would be preferable to use something available on PyPI so we can explicitly list it as a dependency and install it with pip. Maybe you can review the options and propose which tool is best and why before actually making any code changes? |
Yes that will be most convenient. I will review then available packages and will let you know which ones I would suggest. |
From what I have searched Google (unofficial) yamlfmt if well recommended but it's written in In this case I would decide on yamlfix. It's available on PyPI, have good and clear documentation can be simply configured in |
yamlfmt's dependency on go and prettier's dependency on npm are unideal. yamlfix appears to be somewhat dead: lyz-code/yamlfix#272 What about pretty-yaml? Are there any other alternatives we can consider? |
True, sorry I haven't noticed that. Pretty-yaml is very simple and seams to not support going thru all the directories in search for I will be keep on searching and will let you know as soon as I find something. |
In YAML, I personally prefer |
Yes I noticed that here in code is used I did search since last comment and I could not find anything that could be used. Packages either do not support CLI, or are dead projects that haven't been touched for at lest a year or more. Then I think in this case we could use yamlfix even tho at the moment maintainer since 5 months is too busy, he says that eventually will comeback to project. It supports going through files recursively, can be easily configured, have quite few options and well written documentation. I can test if it wont throw any unsolved errors while running on torchgeo code. There is also yamllint but this is only a linter, it would only prompt user where the errors are but it wont fix them on it self. |
Let me think about this. It might not be horrible to use a go/npm package since it's only used by developers, not users. I'm also curious how many files would be changed if we used something like prettier. We do need something for JSON files too for .ipynb files... |
When it's a part of CI it don't make much of a difference to us, it's just matter of using It's possible that initially it could slightly change all the files since it's very opinionated, as it's devs say "Prettier is not a kitchen-sink code formatter that attempts to print your code in any way you wish. It is opinionated.". But still it have some options that can be always adjusted. If JSON files also would had to be handled then Prettier is a best choice. |
I'm fine with opinionated, that's the whole point of a formatter/linter. |
What is the final decision on that matter ? Will we use Prettier ? |
I think prettier is probably best. Can you open a PR that uses prettier to see what the changes look like? |
This is how it looks like while it was run without any additional options with just |
Have you seen changes in PR #2018 ? |
Seen yes, but haven't had time to review in detail yet. Apologies for the wait... |
Summary
We should add a YAML formatter to CI
Rationale
Indentation is inconsistent, and I frequently have to remind people to add EOL chars before EOF chars.
Implementation
Bunch of options:
Alternatives
No response
Additional information
No response
The text was updated successfully, but these errors were encountered: