Some checks failed
Build Sidecars / Bump sidecar version and tag (push) Successful in 3s
Release / Bump version and tag (push) Successful in 3s
Build Sidecars / Build Sidecar (macOS) (push) Successful in 3m58s
Release / Build App (macOS) (push) Successful in 1m20s
Release / Build App (Linux) (push) Has been cancelled
Release / Build App (Windows) (push) Has been cancelled
Build Sidecars / Build Sidecar (Linux) (push) Successful in 13m41s
Build Sidecars / Build Sidecar (Windows) (push) Successful in 34m33s
torchaudio 2.10 unconditionally delegates load() to torchcodec, ignoring the backend parameter. Since torchcodec is excluded from PyInstaller, this broke our pyannote Audio monkey-patch. Fix: replace torchaudio.load() with soundfile.read() + torch.from_numpy(). soundfile handles WAV natively (audio is pre-converted to WAV), has no torchcodec dependency, and is already a transitive dependency. Also added soundfile to PyInstaller hiddenimports. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
79 lines
2.2 KiB
Python
79 lines
2.2 KiB
Python
# -*- mode: python ; coding: utf-8 -*-
|
|
"""PyInstaller spec for the Voice to Notes sidecar binary."""
|
|
|
|
from PyInstaller.utils.hooks import collect_all
|
|
|
|
block_cipher = None
|
|
|
|
# Collect all files for packages that have shared libraries / data files
|
|
# PyInstaller often misses these for ML packages
|
|
ctranslate2_datas, ctranslate2_binaries, ctranslate2_hiddenimports = collect_all("ctranslate2")
|
|
faster_whisper_datas, faster_whisper_binaries, faster_whisper_hiddenimports = collect_all(
|
|
"faster_whisper"
|
|
)
|
|
pyannote_datas, pyannote_binaries, pyannote_hiddenimports = collect_all("pyannote")
|
|
|
|
a = Analysis(
|
|
["voice_to_notes/main.py"],
|
|
pathex=[],
|
|
binaries=ctranslate2_binaries + faster_whisper_binaries + pyannote_binaries,
|
|
datas=ctranslate2_datas + faster_whisper_datas + pyannote_datas,
|
|
hiddenimports=[
|
|
"torch",
|
|
"torchaudio",
|
|
"soundfile",
|
|
"huggingface_hub",
|
|
"pysubs2",
|
|
"openai",
|
|
"anthropic",
|
|
"litellm",
|
|
]
|
|
+ ctranslate2_hiddenimports
|
|
+ faster_whisper_hiddenimports
|
|
+ pyannote_hiddenimports,
|
|
hookspath=[],
|
|
hooksconfig={},
|
|
runtime_hooks=[],
|
|
excludes=[
|
|
"tkinter", "test", "pip", "setuptools",
|
|
# ctranslate2.converters imports torch at module level and causes
|
|
# circular import crashes under PyInstaller. These modules are only
|
|
# needed for model format conversion, never for inference.
|
|
"ctranslate2.converters",
|
|
# torchcodec is partially bundled by PyInstaller but non-functional
|
|
# (missing FFmpeg shared libs). Excluding it forces pyannote.audio
|
|
# to fall back to torchaudio for audio decoding.
|
|
"torchcodec",
|
|
],
|
|
win_no_prefer_redirects=False,
|
|
win_private_assemblies=False,
|
|
cipher=block_cipher,
|
|
noarchive=False,
|
|
)
|
|
|
|
pyz = PYZ(a.pure, a.zipped_data, cipher=block_cipher)
|
|
|
|
exe = EXE(
|
|
pyz,
|
|
a.scripts,
|
|
[],
|
|
exclude_binaries=True,
|
|
name="voice-to-notes-sidecar",
|
|
debug=False,
|
|
bootloader_ignore_signals=False,
|
|
strip=False,
|
|
upx=True,
|
|
console=True,
|
|
)
|
|
|
|
coll = COLLECT(
|
|
exe,
|
|
a.binaries,
|
|
a.zipfiles,
|
|
a.datas,
|
|
strip=False,
|
|
upx=True,
|
|
upx_exclude=[],
|
|
name="voice-to-notes-sidecar",
|
|
)
|