-
Notifications
You must be signed in to change notification settings - Fork 4
/
pyproject.toml
117 lines (109 loc) · 3.36 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
[project]
name = "lmdiag"
version = "0.4.1"
description = "Diagnostic Plots for Lineare Regression Models. Similar to plot.lm in R."
keywords = [
"lm",
"lineare",
"regression",
"diagnostics",
"plot",
"chart",
"linearmodels",
"statsmodels",
"scikit-learn",
]
readme = "README.md"
authors = [{ name = "dynobo", email = "dynobo@mailbox.org" }]
classifiers = [
"Development Status :: 4 - Beta",
"License :: OSI Approved :: MIT License",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
"Programming Language :: Python :: 3.12",
"Programming Language :: Python :: 3.9",
"Topic :: Scientific/Engineering :: Information Analysis",
]
dependencies = ["matplotlib", "numpy", "scipy", "statsmodels"]
optional-dependencies = { dev = [
"build",
"linearmodels",
"mypy",
"notebook",
"pre-commit",
"pytest",
"ruff",
"scikit-learn",
] }
license = { text = "MIT" }
requires-python = ">=3.9"
[project.urls]
Homepage = "http://github.com/dynobo/lmdiag"
Repository = "https://github.com/dynobo/lmdiag.git"
Issues = "https://github.com/dynobo/lmdiag/issues"
Changelog = "https://github.com/dynobo/lmdiag/blob/main/CHANGELOG"
[build-system]
build-backend = "setuptools.build_meta"
requires = ["setuptools >= 61.0"]
[tool.mypy]
files = ["lmdiag/**/*.py", "tests/**/*.py"]
exclude = ["build/"]
follow_imports = "skip"
ignore_missing_imports = true
# ONHOLD: Remove cache_dir once https://github.com/python/mypy/issues/17396 is fixed
cache_dir = "/dev/null"
[tool.ruff]
target-version = "py39"
line-length = 88
exclude = [".venv", "build"]
[tool.ruff.lint]
select = [
"F", # Pyflakes
"E", # pycodestyle
"I", # Isort
"D", # pydocstyle
"W", # warning
"UP", # pyupgrad
"N", # pep8-naming
"C90", # mccabe
"TRY", # tryceratops (exception handling)
"ANN", # flake8-annotations
"S", # flake8-bandits
"C4", # flake8-comprehensions
"B", # flake8-bugbear
"A", # flake8-builtins
"ISC", # flake8-implicit-str-concat
"ICN", # flake8-import-conventions
"T20", # flake8-print
"PYI", # flake8-pyi
"PT", # flake8-pytest-style
"Q", # flake8-quotes
"RET", # flake8-return
"SIM", # flake8-simplify
"PTH", # flake8-use-pathlib
"G", # flake8-logging-format
"PL", # pylint
"RUF", # meta rules (unused noqa)
"PL", # meta rules (unused noqa)
"PERF", # perflint
]
ignore = [
"D100", # Missing docstring in public module
"D101", # Missing docstring in public class
"D102", # Missing docstring in public method
"D103", # Missing docstring in public function
"D104", # Missing docstring in public package
"D107", # Missing docstring in __init__
"D203", # One black line before class
"D213", # Multi line summary second line
"ANN101", # Missing type annotation for `self` in method
"ANN401", # Dynamically typed expression Any
"TRY003", # Avoid specifying long messages outside the exception class
"ISC001", # Rule conflicts with ruff's formatter
"RET504", # Unnecessary assignment before return statement
"S101", # Use of assert detected
"N806", # Variable in function should be lowercase
"PLR0913", # Too many arguments in function definition
]
[tool.ruff.lint.pydocstyle]
convention = "google"