-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpyproject.toml
141 lines (128 loc) · 3.55 KB
/
pyproject.toml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
[build-system]
requires = ["poetry-core>=1.0.0"]
build-backend = "poetry.core.masonry.api"
[tool.poetry]
name = "powerchord"
version = "0.1.4"
description = "Concurrent CLI task runner"
authors = ["Huib Piguillet <[email protected]>"]
maintainers = ["Huib Piguillet"]
license = "MIT"
readme = "README.md"
packages = [{ include = "powerchord", from = "src" }]
include = [{ path = "tests", format = "sdist" }]
repository = "https://github.com/githuib/powerchord"
keywords = ["task runner", "cli utility", "concurrency"]
classifiers = ["Topic :: Utilities"]
[tool.poetry.scripts]
powerchord = "powerchord.cli:main"
[tool.poetry.dependencies]
python = ">=3.11,<4.0"
chili = "*"
gaffe = "*"
[tool.poetry.group.qa.dependencies]
mypy = "*"
pytest = "*"
pytest-asyncio = "*"
ruff = "*"
[tool.powerchord]
tasks = ["ruff check .", "pytest", "mypy"]
#[tool.powerchord.tasks]
#linting = "poetry run ruff check ."
#tests = "poetry run pytest"
#type-checking = "poetry run mypy"
[tool.powerchord.log_levels]
#all = "info"
#success = ""
#fail = "error"
[tool.mypy]
files = ["src", "tests"]
implicit_optional = true
warn_redundant_casts = true
warn_unused_ignores = true
plugins = "gaffe.mypy:plugin"
[tool.pytest.ini_options]
addopts = "-ra -q --doctest-modules"
asyncio_mode = "auto"
[tool.ruff]
indent-width = 4
line-length = 100
target-version = "py311"
[tool.ruff.lint.flake8-quotes]
inline-quotes = "single"
[tool.ruff.lint]
# Enable Pyflakes (`F`) and a subset of the pycodestyle (`E`) codes by default.
# Unlike Flake8, Ruff doesn't enable pycodestyle warnings (`W`) or
# McCabe complexity (`C901`) by default.
select = [
"F", # Pyflakes
"E", # pycodestyle
"E", # pycodestyle
"C90", # mccabe
"I", # isort
"N", # pep8-naming
# "D", # pydocstyle
"UP", # pyupgrade
"YTT", # flake8-2020
# "ANN", # flake8-annotations
"ASYNC", # flake8-async
# "TRIO", # flake8-trio
"S", # flake8-bandit
"BLE", # flake8-blind-except
# "FBT", # flake8-boolean-trap
"B", # flake8-bugbear
"A", # flake8-builtins
"COM", # flake8-commas
# "CPY", # flake8-copyright
"C4", # flake8-comprehensions
"DTZ", # flake8-datetimez
"T10", # flake8-debugger
"DJ", # flake8-django
"EM", # flake8-errmsg
"EXE", # flake8-executable
"FA", # flake8-future-annotations
"ISC", # flake8-implicit-str-concat
"ICN", # flake8-import-conventions
"G", # flake8-logging-format
"INP", # flake8-no-pep420
"PIE", # flake8-pie
"T20", # flake8-print
"PYI", # flake8-pyi
"PT", # flake8-pytest-style
"Q", # flake8-quotes
"RSE", # flake8-raise
"RET", # flake8-return
"SLF", # flake8-self
"SLOT", # flake8-slots
"SIM", # flake8-simplify
"TID", # flake8-tidy-imports
"TCH", # flake8-type-checking
"INT", # flake8-gettext
"ARG", # flake8-unused-arguments
"PTH", # flake8-use-pathlib
# "TD", # flake8-todos
# "FIX", # flake8-fixme
# "ERA", # eradicate
"PD", # pandas-vet
"PGH", # pygrep-hooks
"PL", # Pylint
"TRY", # tryceratops
"FLY", # flynt
"NPY", # NumPy-specific rules
"AIR", # Airflow
"PERF", # Perflint
# "FURB", # refurb
"LOG", # flake8-logging
"RUF", # Ruff-specific rules
]
ignore = [
"RUF013", # PEP 484 prohibits implicit `Optional`
"G004", # Logging statement uses f-string
"TRY003", # Avoid specifying long messages outside the exception class
"EM101", "EM102", # Exception must not use a string literal, assign to variable first
]
[tool.ruff.lint.per-file-ignores]
"tests/**/*" = [
# "ANN", # flake8-annotations
"S", # flake8-bandit
]