-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpyproject.toml
More file actions
160 lines (134 loc) · 6.12 KB
/
pyproject.toml
File metadata and controls
160 lines (134 loc) · 6.12 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
# ============================================================
# pyproject.toml (Python project configuration)
# ============================================================
# Updated: 2026-04-15
# REQ.PYTHON: Python projects MUST include pyproject.toml as the single source of truth.
# WHY: Centralizes project configuration.
# CUSTOM: Update identity and build tool src folders.
# ============================================================
# SECTION 1: PROJECT IDENTITY (name, version, CUSTOM dependencies)
# ============================================================
[project]
name = "se-constitution" # Package distribution name (lowercase and dashes).
readme = "README.md"
requires-python = ">=3.15"
dynamic = ["version"] # WHY: Version is computed from git tags at build time (see [tool.hatch.version] below).
dependencies = []
[project.optional-dependencies]
# WHY: Optional dependency groups keep the core install clean and focused.
dev = [
# REQ.DEV.DEPS: External packages used for linting, testing, type checking, etc.
"build", # WHY: build tool required for packaging and publishing.
"pre-commit",
"pyright",
"pytest",
"pytest-cov",
"ruff",
]
docs = [
# REQ.DOCS.DEPS: External packages used to generate project documentation.
"zensical",
]
# ============================================================
# SECTION 2: TOOL CONFIGURATION (Professional basics)
# ============================================================
# === PYRIGHT (TYPE CHECKING HELPS FIND COMMON ERRORS BEFORE THE CODE RUNS) ===
[tool.pyright]
# CUSTOM: Pyright configuration for static type checking.
# WHY: Strict type checking helps catch bugs early.
include = ["src", "tests"] # WHY: Include both source and test code for comprehensive type checking.
extraPaths = ["src"] # WHY: Ensure imports are resolved relative to src/ for consistent behavior across environments.
exclude = [ "**/node_modules", "**/.*", ".venv","**/__pycache__","dist","build"]
pythonVersion = "3.15"
reportMissingTypeStubs = "none" # WHY: Avoid warnings from third-party libraries without type stubs.
reportMissingImports = "warning" # WHY: Warn about missing imports to catch potential issues, but allow flexibility in notebooks and dynamic code.
reportPrivateUsage = "none" # WHY: Allow usage of private members (e.g., _version.py) without warnings, as this is common in Python projects.
typeCheckingMode = "strict" # strict | basic | off
useLibraryCodeForTypes = false # WHY: Avoid type checking third-party library code to reduce noise and improve performance.
# === PYTEST (VERIFY LOGIC) ===
[tool.pytest.ini_options]
# WHY: Consistent test discovery and coverage visibility.
minversion = "7.0"
testpaths = ["tests"]
addopts = " --cov=se_constitution --cov-report=term-missing"
# === RUFF (PYTHON FORMATTING AND LINTING) ===
[tool.ruff]
# WHY: Fast linting and formatting in one tool.
exclude = [
".eggs",
"*.egg-info",
".ruff_cache",
".venv",
"__pycache__",
"build",
"dist",
"site",
]
line-length = 88 # WHY: PEP 8 standard, wrap when possible.
preview = false # WHY: Stable features only; avoid preview features.
target-version = "py313" # WHY: 3.14 not available yet; match latest supported Python version.
unsafe-fixes = false # WHY: Avoid potentially unsafe automatic fixes.
[tool.ruff.format]
# WHY: Formatter choices should be stable to keep diffs small and predictable.
indent-style = "space" # See also .gitattributes for indent style.
line-ending = "auto" # Match existing files and let .gitattributes handle it.
quote-style = "preserve" # Preserve existing quote styles to minimize churn.
[tool.ruff.lint]
# WHY: Baseline + stricter categories:
select = [
"E", # Basic syntax and structural correctness
"F", # Undefined names and unused imports
"W", # Warnings that catch easy issues early
"I", # Deterministic import ordering
"UP", # Modern Python constructs
"B", # Common bug patterns
"PTH", # Prefer pathlib patterns
"C4", # Comprehension correctness and clarity
"SIM", # Simplify obvious complexity
"RET", # Return practices
"D", # Docstring standards (see convention below)
"S", # Security checks (with deliberate exceptions)
]
ignore = [
"E501", # line length handled by formatter
"D203", # conflicts with D211
"D213", # conflicts with D212 (Google standard summary placement)
"S101", # allow assert (tests + internal invariants)
]
[tool.ruff.lint.isort]
# WHY: Ordering imports helps keep code diffs (differences) readable.
force-sort-within-sections = true
# === PER-FILE IGNORES (DEPENDS ON DOCSTRING POLICY) ===
[tool.ruff.lint.per-file-ignores]
# WHY: Some files must not be auto-modified.
"src/**/__init__.py" = ["F401"] # Allow re-export patterns
"src/**/_version.py" = ["ALL"] # Auto-generated file (do not lint)
"tests/**/*.py" = ["D", "B018", "B011", "S101"]
"src/**/py.typed" = ["ALL"]
# === CHOOSE PROJECT DOC STYLE ===
[tool.ruff.lint.pydocstyle]
# REQ: Google style is the project-wide docstring convention.
convention = "google" # ALT: "numpy" choose one, never mix.
# ============================================================
# SECTION 3: BUILD SYSTEM (boilerplate; CUSTOM src/ agreement)
# ============================================================
#
# REQ.PROJECT: A build system MUST be declared for package discovery and publishing.
# REQ.STRUCTURE: All importable code MUST live under src/.
# WHY src/ layout: Prevents accidental imports from the repo root;
# ensures consistent behavior across IDEs, tests, CI, and PyPI.
[build-system]
build-backend = "hatchling.build"
requires = ["hatchling", "hatch-vcs"]
[tool.hatch.build.hooks.vcs]
# WHY: Writes computed version into src/*/_version.py at build time.
# CUSTOM: Must match src/ folders.
version-file = "src/se_constitution/_version.py"
[tool.hatch.build.targets.wheel]
# CUSTOM: Must match src/ folders.
packages = ["src/se_constitution"] # REQ.PACKAGES: Discovery rooted at src/.
[tool.hatch.version]
# WHY: Version derived from git tags at build time
source = "vcs"
fallback-version = "0.1.0" # Used when no git tags present (fresh clone, CI).
tag-pattern = "^(?:v)?(?P<version>\\d+\\.\\d+\\.\\d+)$"