mirror of
				https://github.com/python-pillow/Pillow.git
				synced 2025-10-25 13:11:24 +03:00 
			
		
		
		
	Switch linting to ruff
Co-authored-by: Andrew Murray <3112309+radarhere@users.noreply.github.com> Co-authored-by: Hugo van Kemenade <hugovk@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									80406a7c9b
								
							
						
					
					
						commit
						de6c4b09d7
					
				|  | @ -1,9 +1,9 @@ | ||||||
| repos: | repos: | ||||||
|   - repo: https://github.com/asottile/pyupgrade |   - repo: https://github.com/astral-sh/ruff-pre-commit | ||||||
|     rev: v3.13.0 |     rev: v0.1.4 | ||||||
|     hooks: |     hooks: | ||||||
|       - id: pyupgrade |       - id: ruff | ||||||
|         args: [--py38-plus] |         args: [--fix, --exit-non-zero-on-fix] | ||||||
| 
 | 
 | ||||||
|   - repo: https://github.com/psf/black-pre-commit-mirror |   - repo: https://github.com/psf/black-pre-commit-mirror | ||||||
|     rev: 23.9.1 |     rev: 23.9.1 | ||||||
|  | @ -11,11 +11,6 @@ repos: | ||||||
|       - id: black |       - id: black | ||||||
|         args: [--target-version=py38] |         args: [--target-version=py38] | ||||||
| 
 | 
 | ||||||
|   - repo: https://github.com/PyCQA/isort |  | ||||||
|     rev: 5.12.0 |  | ||||||
|     hooks: |  | ||||||
|       - id: isort |  | ||||||
| 
 |  | ||||||
|   - repo: https://github.com/PyCQA/bandit |   - repo: https://github.com/PyCQA/bandit | ||||||
|     rev: 1.7.5 |     rev: 1.7.5 | ||||||
|     hooks: |     hooks: | ||||||
|  | @ -23,28 +18,15 @@ repos: | ||||||
|       args: [--severity-level=high] |       args: [--severity-level=high] | ||||||
|       files: ^src/ |       files: ^src/ | ||||||
| 
 | 
 | ||||||
|   - repo: https://github.com/asottile/yesqa |  | ||||||
|     rev: v1.5.0 |  | ||||||
|     hooks: |  | ||||||
|       - id: yesqa |  | ||||||
| 
 |  | ||||||
|   - repo: https://github.com/Lucas-C/pre-commit-hooks |   - repo: https://github.com/Lucas-C/pre-commit-hooks | ||||||
|     rev: v1.5.4 |     rev: v1.5.4 | ||||||
|     hooks: |     hooks: | ||||||
|       - id: remove-tabs |       - id: remove-tabs | ||||||
|         exclude: (Makefile$|\.bat$|\.cmake$|\.eps$|\.fits$|\.gd$|\.opt$) |         exclude: (Makefile$|\.bat$|\.cmake$|\.eps$|\.fits$|\.gd$|\.opt$) | ||||||
| 
 | 
 | ||||||
|   - repo: https://github.com/PyCQA/flake8 |  | ||||||
|     rev: 6.1.0 |  | ||||||
|     hooks: |  | ||||||
|       - id: flake8 |  | ||||||
|         additional_dependencies: |  | ||||||
|           [flake8-2020, flake8-errmsg, flake8-implicit-str-concat, flake8-logging] |  | ||||||
| 
 |  | ||||||
|   - repo: https://github.com/pre-commit/pygrep-hooks |   - repo: https://github.com/pre-commit/pygrep-hooks | ||||||
|     rev: v1.10.0 |     rev: v1.10.0 | ||||||
|     hooks: |     hooks: | ||||||
|       - id: python-check-blanket-noqa |  | ||||||
|       - id: rst-backticks |       - id: rst-backticks | ||||||
| 
 | 
 | ||||||
|   - repo: https://github.com/pre-commit/pre-commit-hooks |   - repo: https://github.com/pre-commit/pre-commit-hooks | ||||||
|  |  | ||||||
|  | @ -5,6 +5,7 @@ include *.md | ||||||
| include *.py | include *.py | ||||||
| include *.rst | include *.rst | ||||||
| include *.sh | include *.sh | ||||||
|  | include *.toml | ||||||
| include *.txt | include *.txt | ||||||
| include *.yaml | include *.yaml | ||||||
| include .flake8 | include .flake8 | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								Makefile
									
									
									
									
									
								
							|  | @ -49,7 +49,7 @@ help: | ||||||
| 	@echo "  install            make and install" | 	@echo "  install            make and install" | ||||||
| 	@echo "  install-coverage   make and install with C coverage" | 	@echo "  install-coverage   make and install with C coverage" | ||||||
| 	@echo "  lint               run the lint checks" | 	@echo "  lint               run the lint checks" | ||||||
| 	@echo "  lint-fix           run Black and isort to (mostly) fix lint issues" | 	@echo "  lint-fix           run Ruff to (mostly) fix lint issues" | ||||||
| 	@echo "  release-test       run code and package tests before release" | 	@echo "  release-test       run code and package tests before release" | ||||||
| 	@echo "  test               run tests on installed Pillow" | 	@echo "  test               run tests on installed Pillow" | ||||||
| 
 | 
 | ||||||
|  | @ -118,6 +118,6 @@ lint: | ||||||
| .PHONY: lint-fix | .PHONY: lint-fix | ||||||
| lint-fix: | lint-fix: | ||||||
| 	python3 -c "import black" > /dev/null 2>&1 || python3 -m pip install black | 	python3 -c "import black" > /dev/null 2>&1 || python3 -m pip install black | ||||||
| 	python3 -c "import isort" > /dev/null 2>&1 || python3 -m pip install isort |  | ||||||
| 	python3 -m black --target-version py38 . | 	python3 -m black --target-version py38 . | ||||||
| 	python3 -m isort . | 	python3 -c "import ruff" > /dev/null 2>&1 || python3 -m pip install ruff | ||||||
|  | 	python3 -m ruff --fix . | ||||||
|  |  | ||||||
|  | @ -77,8 +77,34 @@ package-dir = {"" = "src"} | ||||||
| [tool.setuptools.dynamic] | [tool.setuptools.dynamic] | ||||||
| version = {attr = "PIL.__version__"} | version = {attr = "PIL.__version__"} | ||||||
| 
 | 
 | ||||||
| [tool.isort] | [tool.ruff] | ||||||
| profile = "black" | target-version = "py38" | ||||||
|  | line-length = 88 | ||||||
|  | select = [ | ||||||
|  |   "E", # pycodestyle errors | ||||||
|  |   "EM", # flake8-errmsg | ||||||
|  |   "F", # pyflakes errors | ||||||
|  |   "I", # isort | ||||||
|  |   "ISC", # flake8-implicit-str-concat | ||||||
|  |   "PGH", # pygrep-hooks | ||||||
|  |   "RUF100", # unused noqa (yesqa) | ||||||
|  |   "UP", # pyupgrade | ||||||
|  |   "W", # pycodestyle warnings | ||||||
|  |   "YTT", # flake8-2020 | ||||||
|  |   # "LOG", # TODO: enable flake8-logging when it's not in preview anymore | ||||||
|  | ] | ||||||
|  | extend-ignore = [ | ||||||
|  |   "E203", # Whitespace before ':' | ||||||
|  |   "E221", # Multiple spaces before operator | ||||||
|  |   "E226", # Missing whitespace around arithmetic operator | ||||||
|  |   "E241", # Multiple spaces after ',' | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [tool.ruff.per-file-ignores] | ||||||
|  | "Tests/*.py" = ["I001"] | ||||||
|  | 
 | ||||||
|  | [tool.ruff.isort] | ||||||
|  | known-first-party = ["PIL"] | ||||||
| 
 | 
 | ||||||
| [tool.pytest.ini_options] | [tool.pytest.ini_options] | ||||||
| addopts = "-ra --color=yes" | addopts = "-ra --color=yes" | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user