diff --git a/.github/workflows/python.yml b/.github/workflows/python.yml index da18f78..4debf78 100644 --- a/.github/workflows/python.yml +++ b/.github/workflows/python.yml @@ -11,6 +11,7 @@ on: - '.github/workflows/python.yml' - '**.py' - '**.pyi' + - 'Makefile' pull_request: branches: - '**' @@ -18,6 +19,7 @@ on: - '.github/workflows/python.yml' - '**.py' - '**.pyi' + - 'Makefile' jobs: job_lint: @@ -30,20 +32,21 @@ jobs: python-version: ['3.8'] steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 with: submodules: recursive - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@v2 + uses: actions/setup-python@v4 with: python-version: ${{ matrix.python-version }} - name: Install dependencies run: | - python -m pip install --upgrade pip wheel - pip install -r requirements.txt + python -m pip install -U uv - name: Do linting run: | + python -m uv v && . .venv/Scripts/activate + uv pip install -r requirements.txt make ci-check diff --git a/Makefile b/Makefile index 2449cbd..1a3e24a 100644 --- a/Makefile +++ b/Makefile @@ -2,17 +2,25 @@ all: .PHONY: install -install: - python -m pip install -U pip -r requirements.txt +install: pip-compile + python -m uv pip install -r requirements.txt + +.PHONY: pip-compile +pip-compile: + python -m uv pip compile requirements.in -o requirements.txt .PHONY: ci-check ci-check: + @echo "========== check: mypy ==========" mypy -p plugin - ruff check --diff --preview . - black --diff --preview --check . + @echo "========== check: ruff (lint) ==========" + ruff check --diff . + @echo "========== check: ruff (format) ==========" + ruff format --diff . .PHONY: ci-fix ci-fix: - ruff check --preview --fix . - # ruff format --preview . - black --preview . + @echo "========== fix: ruff (lint) ==========" + ruff check --fix . + @echo "========== fix: ruff (format) ==========" + ruff format . diff --git a/pyproject.toml b/pyproject.toml index 8f26a2a..fe7b0f7 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -9,33 +9,15 @@ module = ["plugin.libs.*"] ignore_errors = true ignore_missing_imports = true -[tool.black] -preview = true -line-length = 120 -target-version = ['py38'] -exclude = ''' -/( - \.git - | \.?venv - | \.mypy_cache - | br-.* - | branch-.* - | libs - | stubs - | tests/files - | typings -)/ -''' - [tool.pyright] include = ['./'] exclude = [ - '**/__pycache__/', - '**/node_modules/', - # git-related - '**/.git/', - '**/br-*/', - '**/branch-*/', + '**/__pycache__/', + '**/node_modules/', + # git-related + '**/.git/', + '**/br-*/', + '**/branch-*/', ] ignore = ['**/.venv', '**/libs'] stubPath = 'typings' @@ -43,25 +25,26 @@ pythonVersion = '3.8' [tool.ruff] preview = true -select = ["E", "F", "W", "I", "UP"] -ignore = ["E203"] line-length = 120 target-version = 'py38' exclude = [ - ".git", - ".mypy_cache", - ".venv", - ".venv-*", - "branch-*", - "libs", - "plugin/libs", - "stubs", - "tests/files", - "typings", - "vendor", - "venv", - "venv-*", + "*/libs/*", + ".git", + ".mypy_cache", + ".venv", + ".venv-*", + "branch-*", + "stubs", + "tests/files", + "typings", + "vendor", + "venv", + "venv-*", ] -[tool.ruff.per-file-ignores] +[tool.ruff.lint] +select = ["E", "F", "W", "I", "UP"] +ignore = ["E203"] + +[tool.ruff.lint.per-file-ignores] "boot.py" = ["E402"] diff --git a/requirements.in b/requirements.in new file mode 100644 index 0000000..870367d --- /dev/null +++ b/requirements.in @@ -0,0 +1,2 @@ +mypy +ruff>=0.2 diff --git a/requirements.txt b/requirements.txt index 350988b..0e70c10 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,6 +1,8 @@ -# This is an implicit value, here for clarity ---index https://pypi.python.org/simple/ - -black -mypy -ruff +# This file was autogenerated by uv v0.1.2 via the following command: +# uv pip compile requirements.in -o requirements.txt +mypy==1.8.0 +mypy-extensions==1.0.0 + # via mypy +ruff==0.2.1 +typing-extensions==4.9.0 + # via mypy