-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpyinstaller.spec
More file actions
141 lines (128 loc) · 3.65 KB
/
pyinstaller.spec
File metadata and controls
141 lines (128 loc) · 3.65 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
# -*- mode: python ; coding: utf-8 -*-
"""
PyInstaller spec for DoctorFill Python backend sidecar.
Builds a single-file executable that Tauri will launch as a sidecar.
The output binary must be placed in src-tauri/binaries/ with the correct
target triple suffix for Tauri to find it.
Usage:
pyinstaller --noconfirm pyinstaller.spec
After build, copy:
dist/doctorfill-server -> src-tauri/binaries/doctorfill-server-<target-triple>
"""
import platform
import subprocess
from PyInstaller.utils.hooks import collect_all, collect_submodules
block_cipher = None
# ChromaDB uses dynamic imports heavily — collect everything
chromadb_datas, chromadb_binaries, chromadb_hiddenimports = collect_all("chromadb")
# Also collect all onnxruntime submodules (used by chromadb embeddings)
onnxruntime_hiddenimports = collect_submodules("onnxruntime")
# Determine the Rust target triple (Tauri sidecar naming convention)
def get_target_triple():
try:
out = subprocess.check_output(["rustc", "-vV"], text=True)
for line in out.splitlines():
if line.startswith("host:"):
return line.split(":")[1].strip()
except Exception:
pass
# Fallback
machine = platform.machine().lower()
system = platform.system().lower()
if system == "darwin":
arch = "aarch64" if machine == "arm64" else "x86_64"
return f"{arch}-apple-darwin"
elif system == "windows":
return "x86_64-pc-windows-msvc"
else:
return f"{machine}-unknown-linux-gnu"
TARGET_TRIPLE = get_target_triple()
a = Analysis(
["server.py"],
pathex=["."],
binaries=chromadb_binaries,
datas=[
("src/web/static", "src/web/static"),
("templates", "templates"),
("forms", "forms"),
(".env.example", "."),
] + chromadb_datas,
hiddenimports=[
# DoctorFill modules
"src",
"src.config",
"src.config.settings",
"src.config.user_config",
"src.config.form_registry",
"src.core",
"src.core.template_manager",
"src.core.type_converter",
"src.llm",
"src.llm.provider",
"src.llm.infomaniak",
"src.llm.local",
"src.llm.response_parser",
"src.pdf",
"src.pdf.xfa",
"src.pdf.xfa.extract",
"src.pdf.xfa.fill",
"src.pdf.xfa.inject",
"src.rag",
"src.rag.chunker",
"src.rag.processor",
"src.rag.context_builder",
"src.pipeline",
"src.pipeline.orchestrator",
"src.pipeline.report_merger",
"src.templates",
"src.templates.loader",
"src.web",
"src.web.app",
# Third-party
"flask",
"flask_cors",
"dotenv",
"tiktoken",
"tiktoken_ext",
"tiktoken_ext.openai_public",
"numpy",
"lxml",
"lxml.etree",
"pikepdf",
"pymupdf",
"fitz",
"json_repair",
"tqdm",
"requests",
] + chromadb_hiddenimports + onnxruntime_hiddenimports,
hookspath=[],
hooksconfig={},
runtime_hooks=[],
excludes=[],
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,
a.binaries,
a.zipfiles,
a.datas,
[],
name="doctorfill-server",
debug=False,
bootloader_ignore_signals=False,
strip=False,
upx=True,
upx_exclude=[],
runtime_tmpdir=None,
console=True,
disable_windowed_traceback=False,
argv_emulation=False,
target_arch=None,
codesign_identity=None,
entitlements_file=None,
)