-
Notifications
You must be signed in to change notification settings - Fork 1
/
pyproject.toml
125 lines (113 loc) · 3.31 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
[build-system]
requires = ["setuptools>=42", "wheel"]
build-backend = "setuptools.build_meta"
[project]
name = "mochada_kit"
version = "0.2.0"
description = "Python code for generating MODA (MOdelling DAta) and CHADA (CHAracterisation DAta) workflow diagrams and tables using plantuml, with machine-readable, enhanced design based on bespoke themes."
authors = [{ name = "Thomas G. Woodcock" }]
maintainers = [{ name = "Thomas G. Woodcock" }]
license = { file = "LICENSE" }
classifiers = [
'Programming Language :: Python',
'Programming Language :: Python :: 3',
'Development Status :: 3 - Alpha',
'Environment :: X11 Applications :: Qt',
'Intended Audience :: End Users/Desktop',
'Intended Audience :: Science/Research',
'License :: OSI Approved :: MIT License',
'Operating System :: POSIX',
'Operating System :: Microsoft :: Windows',
'Topic :: Scientific/Engineering',
'Topic :: Scientific/Engineering :: Visualization',
]
keywords = [
"research",
"data",
"management",
"visualization",
"plantuml",
"uml",
"CHADA",
"MODA",
]
requires-python = ">=3.6"
dependencies = ["h5py", "pyyaml"]
[project.optional-dependencies]
doc = [
"matplotlib",
"nbsphinx >= 0.7",
"numpydoc",
"pydata-sphinx-theme",
"sphinx >= 3.0.2",
"sphinx-codeautolink[ipython] < 0.14",
"sphinx-copybutton >= 0.2.5",
"sphinx-design",
]
tests = [
"numpydoc",
"pytest >= 5.4",
"pytest-benchmark",
"pytest-rerunfailures",
"pytest-xdist",
]
coverage = [
"coverage >= 5.0",
"pytest-cov >= 2.8.1",
]
dev = [
"ruff",
"pre-commit >= 1.16",
"mochada_kit[doc,tests,coverage]",
]
[tool.ruff]
exclude = [
"examples/python_scripts/*.py",
"docs/examples/python_scripts/*.py",
"docs/conf.py",
]
[tool.ruff.lint]
select = [
"B", # flake8-bugbear
"D", # pydocstyle
"E", # pycodestyle
"F", # Pyflakes
"I", # isort
"SIM", # flake8-simplify
"UP", # pyupgrade
]
ignore = [
# conflict with other rules
"D203", # one-blank-line-before-class (conflicts with D204)
"D212", # multi-line-summary-first-line (conflicts with D213)
# conflict with formatter
"D206", # indent-with-spaces
"D300", # triple-single-quotes
"E111", # indentation-with-invalid-multiple
"E114", # indentation-with-invalid-multiple-comment
"E117", # over-indented
# conflict with Python 3.6 compatibility
"UP022", # replace-stdout-stderr
# personal preference
"SIM108", # turnary operator instead of if else block
"D205", # one-blank-line-required-between-summary-line-and-description
]
[tool.ruff.lint.isort]
known-local-folder = ["src"]
[tool.ruff.lint.per-file-ignores]
"*.ipynb" = [
"B018", # "Found useless expression. Either assign it to a variable or remove it."; false positives when using implicit __repr__ in the notebook
"E501", # line too long
"F811", # 'redefined-while-unused'; many false positives in notebooks because ipywidgets decorated functions are not recognised
]
[tool.ruff.lint.pydocstyle]
convention = "numpy"
[tool.ruff.format]
docstring-code-format = true
[project.readme]
'file' = "README.md"
'content-type' = "text/markdown"
[project.scripts]
mochada_kit = "mochada_kit.cli:cli"
[tool.setuptools.packages.find]
where = ["src"]