ruff/CHANGELOG.md
Dhruv Manilawala 8184dae287
Include changelog reference for other major versions (#18745)
Add references to changelog files for other major versions in the main
CHANGELOG.md file.


[Rendered](https://github.com/astral-sh/ruff/blob/dhruv/other-changelog/CHANGELOG.md)
2025-06-18 07:05:43 +00:00

10 KiB

Changelog

0.12.0

Check out the blog post for a migration guide and overview of the changes!

Breaking changes

  • Detection of more syntax errors

    Ruff now detects version-related syntax errors, such as the use of the match statement on Python versions before 3.10, and syntax errors emitted by CPython's compiler, such as irrefutable match patterns before the final case arm.

  • New default Python version handling for syntax errors

    Ruff will default to the latest supported Python version (3.13) when checking for the version-related syntax errors mentioned above to prevent false positives in projects without a Python version configured. The default in all other cases, like applying lint rules, is unchanged and remains at the minimum supported Python version (3.9).

  • Updated f-string formatting

    Ruff now formats multi-line f-strings with format specifiers to avoid adding a line break after the format specifier. This addresses a change to the Python grammar in version 3.13.4 that made such a line break a syntax error.

  • rust-toolchain.toml is no longer included in source distributions

    The rust-toolchain.toml is used to specify a higher Rust version than Ruff's minimum supported Rust version (MSRV) for development and building release artifacts. However, when present in source distributions, it would also cause downstream package maintainers to pull in the same Rust toolchain, even if their available toolchain was MSRV-compatible.

Removed Rules

The following rules have been removed:

Deprecated Rules

The following rules have been deprecated:

Stabilization

The following rules have been stabilized and are no longer in preview:

The following behaviors have been stabilized:

Preview features

  • [ruff] Check for non-context-manager use of pytest.raises, pytest.warns, and pytest.deprecated_call (RUF061) (#17368)
  • [syntax-errors] Raise unsupported syntax error for template strings prior to Python 3.14 (#18664)

Bug fixes

  • Add syntax error when conversion flag does not immediately follow exclamation mark (#18706)
  • Add trailing space around readlines (#18542)
  • Fix \r and \r\n handling in t- and f-string debug texts (#18673)
  • Hug closing } when f-string expression has a format specifier (#18704)
  • [flake8-pyi] Avoid syntax error in the case of starred and keyword arguments (PYI059) (#18611)
  • [flake8-return] Fix RET504 autofix generating a syntax error (#18428)
  • [pep8-naming] Suppress fix for N804 and N805 if the recommended name is already used (#18472)
  • [pycodestyle] Avoid causing a syntax error in expressions spanning multiple lines (E731) (#18479)
  • [pyupgrade] Suppress UP008 if super is shadowed (#18688)
  • [refurb] Parenthesize lambda and ternary expressions (FURB122, FURB142) (#18592)
  • [ruff] Handle extra arguments to deque (RUF037) (#18614)
  • [ruff] Preserve parentheses around deque in fix for unnecessary-empty-iterable-within-deque-call (RUF037) (#18598)
  • [ruff] Validate arguments before offering a fix (RUF056) (#18631)
  • [ruff] Skip fix for RUF059 if dummy name is already bound (#18509)
  • [pylint] Fix PLW0128 to check assignment targets in square brackets and after asterisks (#18665)

Rule changes

  • Fix false positive on mutations in return statements (B909) (#18408)
  • Treat ty: comments as pragma comments (#18532)
  • [flake8-pyi] Apply custom-typevar-for-self to string annotations (PYI019) (#18311)
  • [pyupgrade] Don't offer a fix for Optional[None] (UP007, UP045) (#18545)
  • [pyupgrade] Fix super(__class__, self) detection (UP008) (#18478)
  • [refurb] Make the fix for FURB163 unsafe for log2, log10, *args, and deleted comments (#18645)

Server

  • Support cancellation requests (#18627)

Documentation

  • Drop confusing second * from glob pattern example for per-file-target-version (#18709)
  • Update Neovim configuration examples (#18491)
  • [pylint] De-emphasize __hash__ = Parent.__hash__ (PLW1641) (#18613)
  • [refurb] Add a note about float literal handling (FURB157) (#18615)

0.11.x

See changelogs/0.11.x

0.10.x

See changelogs/0.10.x

0.9.x

See changelogs/0.9.x

0.8.x

See changelogs/0.8.x

0.7.x

See changelogs/0.7.x

0.6.x

See changelogs/0.6.x

0.5.x

See changelogs/0.5.x

0.4.x

See changelogs/0.4.x

0.3.x

See changelogs/0.3.x

0.2.x

See changelogs/0.2.x

0.1.x

See changelogs/0.1.x