-
Notifications
You must be signed in to change notification settings - Fork 31
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
Automatic code formatting for notebooks #1255
Comments
I think this is a great idea. +1 on black. |
https://github.com/charliermarsh/ruff is just a linter, but I believe they are working on adding an autoformatter. The list of projects using it is very impressive, so I can imagine it might replace black in the near future. |
Big fan of anything written in rust! Looks like a neat project, I'll definitely keep an eye on it.
So, it looks like the devs of ruff like black too; my guess is if they eventually get a Ruff formatter, it will have a black-compatible mode. I think black is still our best bet today. |
Black is probably the best choice today, but yeah that could change in the future astral-sh/ruff#1904 We use prettier for our stuff, so them combining black plus some basic config options like prettier allows would be great. |
https://github.com/jpadilla/black-playground could be useful starting point? |
It could be useful to use bidirection plugins to support this use case. |
Ruff has a wasm package (have to build it from src) that can be used to format and lint completely client-side |
Not something I will currently continue working on (I have other priorities), but I made a quick POC using ruff as wasm. https://github.com/mattrunyon/web-client-ui/tree/ruff-wasm I built the wasm from source and just included it as part of the branch. Looked at https://github.com/astral-sh/ruff/blob/main/playground/src/Editor/SourceEditor.tsx for how to call the linter/formatter and map the linter results to actions and markers. I roughly implemented
Would still need to cleanup the code and add
Some issues on my branch
|
Potentially related would be catching syntax errors on the web UI; I don't know if the code formatting tools considered would expose the appropriate syntax error hints, but that would also be a great addition. |
Two questions we should decide an answer on:
|
@jnumainville for investigating any additional default rules sets that are commonly enabled |
https://docs.astral.sh/ruff/settings/#lintflake8-implicit-str-concat I think we should add this rule by default t = t.update([
"X=X+1" # missing comma at the end not flagged by other rulesets
"Y=Y+1"
]) |
We should probably default to no style specific rules and focus only on rules that can show actual problems with the code (like inconsistent tabs/spaces). Or if they are style related, they should be to prevent easy to miss mistakes like the implicit string concatenation. That rule is technically style because it's valid Python. Another style rule we should consider is warning for unused imports/variables. Users would be able to add the other rules if they wanted to enforce something like mandatory pep8 naming conventions. We shouldn't enforce those on everyone by default unless we feel that strongly about it. |
I've been looking at the ruff rules https://docs.astral.sh/ruff/rules I think we should enable
Maybe enable, but might not be very useful. I need a Python person to provide more insight
Probably should not enable, but individual users might want to use these
|
Formatter settings we should leave as default I think with the following exceptions
|
The default is |
Many of the E rules outside 1xx/2xx/9xx are more stylistic to me. If @jnumainville wants to chime in I'd like his thoughts on the other E rules. Also, the default is |
To address some specific points - More broadly though, the |
Are we planning to provide an easy way to turn off formatting and turn off linting (likely, two different settings)? |
I think @jmao-denver and @chipkent should take a look specifically. I'm hoping that the settings we choose to use for web UI can be adopted by deephaven-core python development, ala deephaven/deephaven-core#3638 |
Yes they will be toggles either in the notebook settings (like mini-map) or the user settings (like shortcuts). Linting config will be user customizable. Formatting has a few options as well, but I think it's only indent size and single/double quotes for strings. For aligning w/ deephaven-core Python development, the web UI might be a subset of the rules you want there. There are some rules that are more preference/style that we might want in deephaven-core, but not necessarily applied to all users of DH |
DM me if you want me to dig in beyond the list you have. |
@chipkent just to clarify the rules list I proposed was for the web UI to show to users in notebooks/terminal. I think most of what you added would probably not be annoying to users, but We can also set some rules to warning (yellow squiggly underline) and others to error (red squiggly underline). That would be up to us to determine the defaults as ruff does not assign any default levels to rules. If we're adding linting rules to deephaven-core then we can definitely be as opinionated as we want and should add things like The required imports rule is something you can customize. I think by default it does nothing when on because you have to configure a list of required imports. https://docs.astral.sh/ruff/settings/#lint_isort_required-imports |
I see. My bad. Let me reasses the list with that in mind.
DM me if you want me to dig in beyond the list you have. |
|
I am in agreement with @chipkent's preference. During my discussion with @mattrunyon , I raised the issue of Python version compliance/compatibility check, it seems that that's currently not available with Ruff and the rulesets. But one can argue that it is more important to DH than to the users. |
Will add to a feature branch first, starting with this PR #2043 |
@rbasralian would like to make sure there is an option to disable/enable auto format on save. |
Fixes #1255 I need to test this doesn't crash if using groovy. Not sure if the ruff version is available without initializing ruff first or what happens if it's unavailable. - Added global setting for minimap, format on save, formatter, and formatting settings - Added format on save option and format button to notebook overflow menu - Format on save triggers on both shortcut and pressing the save button - Config editor has JSON schema included - Config editor cannot be closed by clicking outside the modal, but can be closed w/ escape key Something we should add maybe as part of this PR or a final follow-up to this feature branch is disabling certain/all linting/formatting for the console. One way we might do this is by registering the console w/ a specific URI or URI scheme so we can check it when checking if we should lint. Or include it as a prop to the `MonacoProviders` component. This would require some changes to the current setup of setting/using the config on `MonacoProviders` static members/methods (This might not actually be breaking, it's more just notes for implementing in DHE) BREAKING CHANGE: The app should call `MonacoUtils.init` with a `getWorker` function that uses the JSON worker in addition to the general fallback worker when adding support for configuring ruff.
Fixes #1255 (This might not actually be breaking, it's more just notes for implementing in DHE) BREAKING CHANGE: The app should call `MonacoUtils.init` with a `getWorker` function that uses the JSON worker in addition to the general fallback worker when adding support for configuring ruff.
As a user, I want automatic code formatting in my notebooks so that my code looks pretty.
I would like to have formatting applied by something like black: https://github.com/psf/black.
Ruff wasm Python formatter and linter:
(https://github.com/dprint/dprint-plugin-ruff has automation to self update and publish new versions, so maybe use that one?)
The text was updated successfully, but these errors were encountered: