ruff/crates
Charlie Marsh 55d6fd53cd
Treat comments on open parentheses in return annotations as dangling (#6413)
## Summary

Given:

```python
def double(a: int) -> ( # Hello
    int
):
    return 2*a
```

We currently treat `# Hello` as a trailing comment on the parameters
(`(a: int)`). This PR adds a placement method to instead treat it as a
dangling comment on the function definition itself, so that it gets
formatted at the end of the definition, like:

```python
def double(a: int) -> int:  # Hello
    return 2*a
```

The formatting in this case is unchanged, but it's incorrect IMO for
that to be a trailing comment on the parameters, and that placement
leads to an instability after changing the grouping in #6410.

Fixing this led to a _different_ instability related to tuple return
type annotations, like:

```python
def zrevrangebylex(self, name: _Key, max: _Value, min: _Value, start: int | None = None, num: int | None = None) -> (  # type: ignore[override]
):
    ...
```

(This is a real example.)

To fix, I had to special-case tuples in that spot, though I'm not
certain that's correct.
2023-08-08 16:48:38 -04:00
..
flake8_to_ruff Bump version number to 0.0.283 (#6407) 2023-08-08 12:31:30 -05:00
ruff Improve documentation for `PLE1300` (#6430) 2023-08-08 20:16:36 +00:00
ruff_benchmark Use `Jupyter` mode while parsing Notebook files (#5552) 2023-08-05 00:32:07 +00:00
ruff_cache Only use a single cache file per Python package (#5117) 2023-06-19 17:46:13 +02:00
ruff_cli Bump version number to 0.0.283 (#6407) 2023-08-08 12:31:30 -05:00
ruff_dev Use `Jupyter` mode while parsing Notebook files (#5552) 2023-08-05 00:32:07 +00:00
ruff_diagnostics Skip partial duplicates when applying multi-edit fixes (#6144) 2023-07-29 12:11:57 +00:00
ruff_formatter Formatter comment handling nits (#6339) 2023-08-04 13:22:16 +00:00
ruff_index Add unreachable code rule (#5384) 2023-07-04 14:27:23 +00:00
ruff_macros Remove parser dependency from ruff-python-ast (#6096) 2023-07-26 17:47:22 +02:00
ruff_python_ast Rename `JoinedStr` to `FString` in the AST (#6379) 2023-08-07 17:33:17 +00:00
ruff_python_codegen Rename `JoinedStr` to `FString` in the AST (#6379) 2023-08-07 17:33:17 +00:00
ruff_python_formatter Treat comments on open parentheses in return annotations as dangling (#6413) 2023-08-08 16:48:38 -04:00
ruff_python_index Avoid detecting continuations at non-start-of-line (#6219) 2023-08-01 00:20:29 -04:00
ruff_python_literal [`pylint`] Implement Pylint `bad-format-character` (`E1300`) (#6171) 2023-08-02 21:32:43 +00:00
ruff_python_parser Rename `JoinedStr` to `FString` in the AST (#6379) 2023-08-07 17:33:17 +00:00
ruff_python_resolver Replace `.map_or(false, $closure)` with `.is_some_and(closure)` (#6244) 2023-08-01 19:29:42 +02:00
ruff_python_semantic Change `model: &SemanticModel` to `semantic: &SemanticModel` (#6406) 2023-08-07 16:32:55 -04:00
ruff_python_stdlib Replace `.map_or(false, $closure)` with `.is_some_and(closure)` (#6244) 2023-08-01 19:29:42 +02:00
ruff_python_trivia Refactor and rename `skip_trailing_trivia` (#6312) 2023-08-04 13:30:53 +00:00
ruff_shrinking Use `Jupyter` mode while parsing Notebook files (#5552) 2023-08-05 00:32:07 +00:00
ruff_source_file Skip BOM when determining Locator's line starts (#6159) 2023-07-29 11:47:13 +00:00
ruff_text_size Pull in RustPython parser (#6099) 2023-07-27 09:29:11 +00:00
ruff_wasm Use `Jupyter` mode while parsing Notebook files (#5552) 2023-08-05 00:32:07 +00:00