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

FR: Integrate organizeImport, fixAll into formatting #335

Open
chrisgrieser opened this issue Dec 7, 2023 · 8 comments
Open

FR: Integrate organizeImport, fixAll into formatting #335

chrisgrieser opened this issue Dec 7, 2023 · 8 comments

Comments

@chrisgrieser
Copy link

chrisgrieser commented Dec 7, 2023

Right now, ruff format / textDocument/formatting apply formatting, while organizeImports and fixAll are available independently, e.g. as code actions.

I think it would make sense to have the option to run all three (organizeImports, fixAll, formatting) with one command by integrating the former two into the formatting capabilities. Combining import-sorting and formatting is not uncommon, a few formatters like for example stylua already do that.

Currently, doing that in ruff requires a bunch of workarounds (see e.g., #119 or #95), which have some minor hiccups as LSP code actions cannot be run async (#95). Implementing this would thus make ruff more accessible to newcomers who just need to set one toggle instead of finding a workaround in the GitHub issues.

@charliermarsh
Copy link
Member

Thanks! Are you imaging a dedicated code action for this, or a setting to make the format action do "everything"?

@chrisgrieser
Copy link
Author

because of the drawbacks of code actions (e.g. no async), I think adding as an opt-in setting to formatting would be preferable?

@MichaReiser
Copy link
Member

I can see how it makes sense to run organizeImport as part of formatting. In fact, we consider integrating organising imports into formatting into the CLI. Although VS Code identionally has a dedicated action for it. So it's a bit unclear if we want to keep the separation in IDEs or not.

I don't recommend integrating fix all into formatting. Fixing can create semantic changes. I would rather push for the opposite, considering to integrate format into fixAll. Again, this may be unexpected considering that many editors intentionally offer different actions for this. But we could expose different ruff.fixAll variations.

@chrisgrieser
Copy link
Author

So it's a bit unclear if we want to keep the separation in IDEs or not.

I mean, making it an opt-in setting, leaving it to the user to decide cannot really hurt?

I don't recommend integrating fix all into formatting. Fixing can create semantic changes.

In my personal opinion, if something can introduce semantic changes, it should not have a fix code action to begin with, as it can easily mislead less experienced users?

I would rather push for the opposite, considering to integrate format into fixAll

In theory it does not make a difference which way to go, but using a code action instead of formatting has some disadvantages, such not being able to run async (see #93 for the problems this can entail).

@naddeoa
Copy link

naddeoa commented Dec 11, 2023

I'm interested in a solution here as well. My current workflow has me using a nice keybind for running LspZeroFormat, which calls vim.lsp.buf.format() under the hood (usually after deleting a bunch of stuff) only to find a bunch of diagnostics I can't fix about unused imports, which I execute ruff check --fix to clean up.

I don't want to speak for what I think would be best for a certain type of user, but I know I'd love it if it all happened in a single command as someone who just compulsively spans format while refactoring.

@zanieb
Copy link
Member

zanieb commented Dec 11, 2023

astral-sh/ruff#8232 is relevant here.

@nervenes
Copy link

any update on this?

@alfonsomhc
Copy link

Please implement this :)

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

No branches or pull requests

7 participants