mirror of
				https://github.com/astral-sh/ruff.git
				synced 2025-10-31 12:05:57 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			187 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			187 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Preview
 | |
| 
 | |
| Ruff includes an opt-in preview mode to provide an opportunity for community feedback and increase confidence that
 | |
| changes are a net-benefit before enabling them for everyone.
 | |
| 
 | |
| Preview mode enables a collection of unstable features such as new lint rules and fixes, formatter style changes, interface updates, and more. Warnings about deprecated features may turn into errors when using preview mode.
 | |
| 
 | |
| Enabling preview mode does not on its own enable all preview rules. See the [rules section](#using-rules-that-are-in-preview) for details on selecting preview rules.
 | |
| 
 | |
| ## Enabling preview mode
 | |
| 
 | |
| Preview mode can be enabled with the `--preview` flag on the CLI or by setting `preview = true` in your Ruff
 | |
| configuration file.
 | |
| 
 | |
| Preview mode can be configured separately for linting and formatting. To enable preview lint rules without preview style formatting:
 | |
| 
 | |
| === "pyproject.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [tool.ruff.lint]
 | |
|     preview = true
 | |
|     ```
 | |
| 
 | |
| === "ruff.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [lint]
 | |
|     preview = true
 | |
|     ```
 | |
| 
 | |
| === "CLI"
 | |
| 
 | |
|     ```console
 | |
|     ruff check --preview
 | |
|     ```
 | |
| 
 | |
| 
 | |
| To enable preview style formatting without enabling any preview lint rules:
 | |
| 
 | |
| === "pyproject.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [tool.ruff.format]
 | |
|     preview = true
 | |
|     ```
 | |
| 
 | |
| === "ruff.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [format]
 | |
|     preview = true
 | |
|     ```
 | |
| 
 | |
| === "CLI"
 | |
| 
 | |
|     ```console
 | |
|     ruff format --preview
 | |
|     ```
 | |
| 
 | |
| ## Using rules that are in preview
 | |
| 
 | |
| If a rule is marked as preview, it can only be selected if preview mode is enabled. For example, consider a
 | |
| hypothetical rule, `HYP001`. If `HYP001` were in preview, it would _not_ be enabled by adding it to the selected rule set.
 | |
| 
 | |
| === "pyproject.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [tool.ruff.lint]
 | |
|     extend-select = ["HYP001"]
 | |
|     ```
 | |
| 
 | |
| === "ruff.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [lint]
 | |
|     extend-select = ["HYP001"]
 | |
|     ```
 | |
| 
 | |
| === "CLI"
 | |
| 
 | |
|     ```console
 | |
|     ruff check --extend-select HYP001
 | |
|     ```
 | |
| 
 | |
| 
 | |
| It also would _not_ be enabled by selecting the `HYP` category, like so:
 | |
| 
 | |
| === "pyproject.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [tool.ruff.lint]
 | |
|     extend-select = ["HYP"]
 | |
|     ```
 | |
| 
 | |
| === "ruff.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [lint]
 | |
|     extend-select = ["HYP"]
 | |
|     ```
 | |
| 
 | |
| === "CLI"
 | |
| 
 | |
|     ```console
 | |
|     ruff check --extend-select HYP
 | |
|     ```
 | |
| 
 | |
| 
 | |
| Similarly, it would _not_ be enabled via the `ALL` selector:
 | |
| 
 | |
| === "pyproject.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [tool.ruff.lint]
 | |
|     select = ["ALL"]
 | |
|     ```
 | |
| 
 | |
| === "ruff.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [lint]
 | |
|     select = ["ALL"]
 | |
|     ```
 | |
| 
 | |
| === "CLI"
 | |
| 
 | |
|     ```console
 | |
|     ruff check --select ALL
 | |
|     ```
 | |
| 
 | |
| However, it _would_ be enabled in any of the above cases if you enabled preview mode:
 | |
| 
 | |
| === "pyproject.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [tool.ruff.lint]
 | |
|     extend-select = ["HYP"]
 | |
|     preview = true
 | |
|     ```
 | |
| 
 | |
| === "ruff.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [lint]
 | |
|     extend-select = ["HYP"]
 | |
|     preview = true
 | |
|     ```
 | |
| 
 | |
| === "CLI"
 | |
| 
 | |
|     ```console
 | |
|     ruff check --extend-select HYP --preview
 | |
|     ```
 | |
| 
 | |
| To see which rules are currently in preview, visit the [rules reference](rules.md).
 | |
| 
 | |
| ## Selecting single preview rules
 | |
| 
 | |
| When preview mode is enabled, selecting rule categories or prefixes will include all preview rules that match.
 | |
| If you'd prefer to opt in to each preview rule individually, you can toggle the `explicit-preview-rules`
 | |
| setting in your configuration file:
 | |
| 
 | |
| === "pyproject.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [tool.ruff.lint]
 | |
|     preview = true
 | |
|     explicit-preview-rules = true
 | |
|     ```
 | |
| 
 | |
| === "ruff.toml"
 | |
| 
 | |
|     ```toml
 | |
|     [lint]
 | |
|     preview = true
 | |
|     explicit-preview-rules = true
 | |
|     ```
 | |
| 
 | |
| In our previous example, `--select` with `ALL` `HYP`, `HYP0`, or `HYP00` would not enable `HYP001`. Each preview
 | |
| rule will need to be selected with its exact code: for example, `--select ALL,HYP001`.
 | |
| 
 | |
| If preview mode is not enabled, this setting has no effect.
 | |
| 
 | |
| ## Deprecated rules
 | |
| 
 | |
| When preview mode is enabled, deprecated rules will be disabled. If a deprecated rule is selected explicitly, an
 | |
| error will be raised. Deprecated rules will not be included if selected via a rule category or prefix.
 | 
