-
Notifications
You must be signed in to change notification settings - Fork 187
Expand file tree
/
Copy pathpyproject.toml
More file actions
98 lines (89 loc) · 4.04 KB
/
Copy pathpyproject.toml
File metadata and controls
98 lines (89 loc) · 4.04 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
[project]
name = "stemdeck"
# Version is derived from the git tag by hatch-vcs (see [tool.hatch.version]),
# so it is never hand-edited — `git tag vX.Y.Z` is the single source of truth.
# Builds between tags report a dev version (e.g. 0.7.0a5.dev3+g<sha>). (#169)
dynamic = ["version"]
description = "Paste a YouTube URL, get audio stems split into a DAW-style player."
requires-python = ">=3.10,<3.14"
dependencies = [
"fastapi>=0.115,!=0.136.3",
"uvicorn[standard]>=0.30",
"yt-dlp>=2024.12.0",
"demucs>=4.0.1",
# Pin torch/torchaudio to 2.6.x where available — torchaudio 2.7+ removed its built-in
# audio writer and now requires the separate `torchcodec` package, which
# has ABI issues with torch 2.11. Demucs 4.0.1 calls torchaudio.save() to
# write stems, so it breaks on 2.7+.
"torch>=2.6,<2.7; sys_platform != 'darwin' or platform_machine != 'x86_64'",
"torchaudio>=2.6,<2.7; sys_platform != 'darwin' or platform_machine != 'x86_64'",
# PyTorch does not publish macOS x86_64 wheels for 2.6.x. Keep Intel macOS
# on the last compatible line so the x64 runtime pack can still be built.
"torch>=2.2,<2.3; sys_platform == 'darwin' and platform_machine == 'x86_64'",
"torchaudio>=2.2,<2.3; sys_platform == 'darwin' and platform_machine == 'x86_64'",
# torchaudio 2.6 dispatches WAV writes through libsndfile via soundfile.
# Without this, demucs crashes on save with "Couldn't find appropriate
# backend to handle uri ... drums.wav".
"soundfile>=0.12",
# BPM + key analysis on the downloaded source. Pulls numpy/scipy/numba.
"librosa>=0.10",
# Current llvmlite releases no longer publish macOS x86_64 wheels, which
# makes Intel runtime builds require a full LLVM/CMake toolchain. Keep Intel
# macOS on a wheel-backed Numba line.
"numba>=0.61,<0.62; sys_platform == 'darwin' and platform_machine == 'x86_64'",
# Torch 2.2's Intel macOS wheel was built against NumPy 1.x.
"numpy<2; sys_platform == 'darwin' and platform_machine == 'x86_64'",
# ITU-R BS.1770 integrated-loudness (LUFS) measurement for the
# post-analysis loudness card. Pure Python, depends on scipy which
# librosa already pulls in.
"pyloudnorm>=0.1.1",
# FastAPI multipart/form-data (file uploads) unconditionally require
# python-multipart — it is not an optional extra.
"python-multipart>=0.0.9",
# CVE-2026-44431 / CVE-2026-44432: sensitive header forwarding and
# decompression-bomb bypass fixed in 2.7.0. urllib3 is a transitive
# dep via requests; pin floor to pull in the fix.
"urllib3>=2.7.0",
# Pure-Python QR code generator used by the /api/qr endpoint (server
# access QR codes in the desktop settings panel).
"segno>=1.6",
]
[project.optional-dependencies]
dev = [
"ruff>=0.6",
"pytest>=8",
"pytest-asyncio>=0.24",
"httpx>=0.27",
]
[build-system]
requires = ["hatchling", "hatch-vcs"]
build-backend = "hatchling.build"
# Derive the version from git tags. Writes app/_version.py at build time as a
# runtime fallback for environments without installed package metadata.
[tool.hatch.version]
source = "vcs"
# Used when the tag can't be reached (e.g. CI's shallow/tagless clone) so the
# build never hard-fails. Real builds derive from the tag or the pinned
# SETUPTOOLS_SCM_PRETEND_VERSION. (#169)
fallback-version = "0.0.0"
[tool.hatch.build.hooks.vcs]
version-file = "app/_version.py"
[tool.hatch.build.targets.wheel]
packages = ["app"]
[tool.ruff]
target-version = "py310"
line-length = 100
# app/_version.py is generated by hatch-vcs at build/sync time — don't lint it.
exclude = ["jobs", ".run", "static/vendor", "app/_version.py"]
[tool.ruff.lint]
select = ["E", "F", "W", "I", "UP", "B", "SIM"]
ignore = [
"E501", # line too long -- format-check is the gate, not lint
"B008", # FastAPI uses Depends(...) in defaults
"SIM105", # try/except/pass is fine; contextlib.suppress is heavier for one-shot warm-up imports
]
[tool.ruff.lint.isort]
split-on-trailing-comma = false
[tool.pytest.ini_options]
testpaths = ["tests"]
asyncio_mode = "auto"