-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathpyproject.toml
More file actions
192 lines (162 loc) · 7.28 KB
/
Copy pathpyproject.toml
File metadata and controls
192 lines (162 loc) · 7.28 KB
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
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
[project]
name = "wzcalc-fastapi"
version = "0.1.0"
authors = [{name = "Roman Balashov", email="rbalashou@yandex.ru"}]
description = "Simple calculator for ozon and wildberries marketplaces"
readme = "README.md"
requires-python = ">=3.13"
dependencies = [
"ptpython",
"ruff",
"black",
"pre-commit",
"fastapi[standard]>=0.116.1",
"pytest>=8.4.1",
]
# romz987 pytest
[tool.pytest.ini_options]
testpaths = ["tests"]
pythonpath = ["."]
# romz987 pyright + ruff + black config
[tool.pyright]
# Версия Python, используемая в проекте (влияет на парсер и проверки) и платформа
pythonVersion = "3.13"
pythonPlatform = "Linux"
# Список папок/файлов, которые Pyright будет анализировать (в данном случае только папка src)
# Если не указать, то pyright будет анализировать все файлы
# Установлено - анализировать все в текущем контексте (если вообще убрать include, pyright не будет ходить по директориям)
include = ["."]
# Стандартный список исключений — папки и файлы, которые Pyright не будет анализировать
exclude = [
".bzr",
".direnv",
".eggs",
".git",
".git-rewrite",
".hg",
".ipynb_checkpoints",
".mypy_cache",
".nox",
".pants.d",
".pyenv",
".pytest_cache",
".pytype",
".ruff_cache",
".svn",
".tox",
".venv",
".vscode",
"__pypackages__",
"_build",
"buck-out",
"build",
"dist",
"node_modules",
"site-packages",
"venv",
"**/node_modules",
"**/__pycache__",
]
# Игнорировать конкретную папку/файлы (например, старый код)
# ignore = ["oldcode"]
# Недостающие модули это ошибка
reportMissingImports = "error"
# Лишний импорт это ошибка
reportUnusedImport = "error"
# Неиспользумеая переменная это ошибка
reportUnusedVariable = "error"
# "Недостижимый код" (никогда не будет выполнен в процессе выполнения программы) это ошибка
reportUnreachable = "warning"
# Не выдавать предупреждения об отсутствующих типовых заглушках (.pyi)
reportMissingTypeStubs = false
# Определяем константу DEBUG в процессе анализа (Всегда будет true)
# defineConstant = { DEBUG = true }
# Путь к папке с stub-файлами (.pyi) — служебные типовые заглушки
# stubPath = "src/stubs"
[tool.ruff]
# Директории, файлы в которых ruff будет игнорировать
exclude = [
".bzr",
".direnv",
".eggs",
".git",
".git-rewrite",
".hg",
".ipynb_checkpoints",
".mypy_cache",
".nox",
".pants.d",
".pyenv",
".pytest_cache",
".pytype",
".ruff_cache",
".svn",
".tox",
".venv",
".vscode",
"__pypackages__",
"_build",
"buck-out",
"build",
"dist",
"node_modules",
"site-packages",
"venv",
]
# Длина строки и длина отступа
line-length = 79
indent-width = 4
# Какая версия python используется
# Если не указать то, ruff # Если не указать, будет пытаться угадать версию анализируя файлы.
# Может сделать неверные выводы о доступности синтаксиса, особенно в проектах, поддерживающих старые версии Python
target-version = "py312"
[tool.ruff.lint]
# Какие правила мы будем использовать или какие правила будем игнорировать
# После изменений neovim должен быть перезапущен
select = ["E", "F", "Q", "COM"]
ignore = []
# Разрешить автоматическое исправление всех включённых правил (при запуске с --fix)
fixable = ["ALL"]
unfixable = []
# Разрешить неиспользуемые переменные, начинающиеся с подчёркивания
# Если имя переменной соответствует этому шаблону, не ругайся, даже если переменная не используется.
# Это касается т.н. "мусорных переменных" в контексте PEP8
dummy-variable-rgx = "^(_+|(_+[a-zA-Z0-9_]*[a-zA-Z0-9]+?))$"
[tool.ruff.format]
# Одинарные или двойные кавычки (должен быть активен плагин Q)
quote-style = "double"
# Проверяет последнюю запятную в структурах (должен быть активен плагин COM)
skip-magic-trailing-comma = false
# Aвтоматическое форматирование кода внутри docstrings.
# Ruff попытается отформатировать код внутри таких комментариев, так же как он форматирует обычный код
docstring-code-format = false
# Управляет максимальной длиной строки кода внутри docstring
docstring-code-line-length = "dynamic"
# Like Black, automatically detect the appropriate line ending.
# Указывает инструменту автоматически определять и использовать подходящий тип окончания строки в файлах, которые он обрабатывает
# line-ending = "auto"
# Like Black, indent with spaces, rather than tabs.
# Указывает инструменту использовать пробелы для отступов вместо табуляции при форматировании кода.
# indent-style = "space"
# Enable auto-formatting of code examples in docstrings. Markdown,
# reStructuredText code/literal blocks and doctests are all supported.
[tool.black]
# Маскимально допустимая длинна строки
line-length = 79
# Какая версия python используется
# Некоторые правила форматирования зависят от синтаксиса, поддерживаемого только в новых версиях Python.
# Если не указать, будет использовать ту версию, из которой он запущен
target-version = ['py313']
# Включать только .py и .pyi файлы
# Если мы не пишем stub-файлы, то pyi не нужны:
# include = '\.pyi?$'
include = '\.py?$'
# Расширенное исключение файлов/папок (в дополнение к стандартным)
extend-exclude = '''
# A regex preceded with ^/ will apply only to files and directories
# in the root of the project.
(
^/foo.py # exclude a file named foo.py in the root of the project
| .*_pb2.py # exclude autogenerated Protocol Buffer files anywhere in the project
)
'''