-
Notifications
You must be signed in to change notification settings - Fork 2
/
pyproject.toml
86 lines (72 loc) · 2.9 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
[build-system]
requires = ["setuptools >= 61"]
build-backend = "setuptools.build_meta"
[project]
name = "archerycalculator"
version = "0.1.1"
description = "A flask web app to perform archery calculations"
authors = [
{ name="Jack Atkinson", email="jack.atkinson1000@gmail.com" },
]
readme = "README.md"
license = {file = "LICENSE"}
requires-python = ">=3.7"
classifiers = [
"Programming Language :: Python :: 3",
"License :: OSI Approved :: MIT License",
"Operating System :: OS Independent",
"Natural Language :: English",
"Development Status :: 3 - Alpha",
# "Topic :: Software Development :: Libraries :: Python Modules",
]
dependencies = [
"archeryutils @ git+https://github.com/jatkinson1000/archeryutils.git",
"black>=22.12.0",
"flake8>=6.0.0",
"Flask>=2.2.2",
"wtforms>=3.0.1"
]
[project.urls]
"Homepage" = "https://github.com/jatkinson1000/archerycalculator"
"Bug Tracker" = "https://github.com/jatkinson1000/archerycalculator/Issues"
[project.optional-dependencies]
TEST = ["pytest"]
[tool.setuptools]
# By default, include-package-data is true in pyproject.toml, so you do
# NOT have to specify this line.
include-package-data = true
[tool.setuptools.package-data]
mypkg = ["* = *.json",]
[tool.setuptools.packages]
find = {}
#[tool.setuptools.packages.find]
#where = ["archerycalculator"] # list of folders that contain the packages (["."] by default)
#include = ["archerycalculator*"] # package names should match these glob patterns (["*"] by default)
#exclude = ["archerycalculator.tests*"] # exclude packages matching these glob patterns (empty by default)
#namespaces = false # to disable scanning PEP 420 namespaces (true by default)
[tool.ruff]
# Run linting and formatting on notebooks
extend-include = ["*.ipynb"]
[tool.ruff.format]
docstring-code-format = true
[tool.ruff.lint]
# See https://docs.astral.sh/ruff/rules for full details of each ruleset.
# Enable: D: `pydocstyle`, PL: `pylint`, I: `isort`, W: `pycodestyle whitespace`
# NPY: `numpy`, FLY: `flynt`, RUF: `ruff`
# From flake8: "ARG", "SLF", "S", "BLE", "B", "A", "C4", "EM", "ICN",
# "PIE", "Q", "RSE", "SIM", "TID"
select = ["D", "PL", "I", "E", "W", "NPY", "FLY", "RUF",
"ARG", "SLF", "S", "BLE","B", "A", "C4", "EM", "ICN", "PIE", "Q", "RSE",
"SIM", "TID"]
# Enable D417 (Missing argument description) on top of the NumPy convention.
extend-select = ["D417"]
# Ignore SIM108 (use ternary instead of if-else) as I think it can obscure intent.
# Ignore RUF002 (ambiguous characters) as it does not allow apostrophes in strings.
ignore = ["SIM108", "RUF002"]
[tool.ruff.lint.pydocstyle]
# Use NumPy convention for checking docstrings
convention = "numpy"
[tool.ruff.lint.per-file-ignores]
# Ignore S101 (use of assert) in tests
# Ignore PLR2004 (magic values) in tests as we regularly want to compare to a numerical value
"**/tests/*" = ["S101", "PLR2004"]