-
Notifications
You must be signed in to change notification settings - Fork 0
/
pyproject.toml
119 lines (109 loc) · 2.99 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
# Copyright 2020 by Jiuguang Wang (www.robo.guru)
# All rights reserved.
# This file is part of dte_calculator and is released under the MIT License.
# Please see the LICENSE file that should have been included as part of
# this package.
[build-system]
build-backend = "setuptools.build_meta"
requires = ["setuptools", "setuptools_scm"]
[project]
authors = [
{name = "Jiuguang Wang", email = "[email protected]"}
]
classifiers = [
"Programming Language :: Python :: 3",
"License :: OSI Approved :: MIT License",
"Operating System :: OS Independent"
]
dependencies = [
"tomli>=2.0.1",
"matplotlib>=3.8",
"pandas>=2.1.0",
"seaborn>=0.12.2",
"numpy>=1.25.2",
"chart_studio>=1.1.0",
"toml>=0.10.2"
]
description = "Python based utility to compare electric service plans based on past consumption data."
keywords = ["DTE", "electricity", "pandas", "matplotlib"]
license = {file = "LICENSE"}
name = "dte_calculator"
readme = "README.md"
requires-python = ">=3.10"
version = "0.1.0"
[project.optional-dependencies]
dev = [
"pre-commit>=3.5.0",
"pytest>=7.4.0",
"pytest-cov>=4.1.0",
"MonkeyType>=23.3.0"
]
[project.urls]
documentation = "https://github.com/jiuguangw/dte_calculator"
homepage = "https://github.com/jiuguangw/dte_calculator"
repository = "https://github.com/jiuguangw/dte_calculator"
[tool.black]
# `extend-exclude` is not honored when `black` is passed a file path explicitly,
# as is typical when `black` is invoked via `pre-commit`.
force-exclude = '''
/(
build/.*
)/
'''
include = '\.pyi?$'
line-length = 79
preview = true
target-version = ['py310']
[tool.mypy]
check_untyped_defs = true
disallow_untyped_defs = true
explicit_package_bases = true
ignore_missing_imports = true
no_implicit_optional = true
python_version = "3.10"
strict_equality = true
warn_redundant_casts = true
warn_unreachable = true
[tool.ruff]
# Allow unused variables when underscore-prefixed.
dummy-variable-rgx = "^(_+|(_+[a-zA-Z0-9_]*[a-zA-Z0-9]+?))$"
# Exclude a variety of commonly ignored directories.
exclude = [
".bzr",
".direnv",
".eggs",
".git",
".hg",
".mypy_cache",
".nox",
".pants.d",
".pytype",
".ruff_cache",
".svn",
".tox",
".venv",
"__pypackages__",
"_build",
"buck-out",
"build",
"dist",
"node_modules",
"venv"
]
# Allow autofix for all enabled rules (when `--fix`) is provided.
fixable = ["A", "B", "C", "D", "E", "F", "G", "I", "N", "Q", "S", "T", "W", "ANN", "ARG", "BLE", "COM", "DJ", "DTZ", "EM", "ERA", "EXE", "FBT", "ICN", "INP", "ISC", "NPY", "PD", "PGH", "PIE", "PL", "PT", "PTH", "PYI", "RET", "RSE", "RUF", "SIM", "SLF", "TCH", "TID", "TRY", "UP", "YTT"]
ignore = ["D", "PLR2004", "T201", "S101"]
# Same as Black.
line-length = 79
# Enable pycodestyle (`E`), Pyflakes (`F`), and import sorting (`I`)
select = ["ALL"]
# Assume Python 3.10.
target-version = "py310"
unfixable = []
[tool.ruff.mccabe]
# Unlike Flake8, default to a complexity level of 10.
max-complexity = 10
[tool.ruff.per-file-ignores]
"__init__.py" = ["F401"]
[tool.setuptools]
packages = ["dte", "data"]