-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathlaunchbot.bat
More file actions
178 lines (145 loc) · 4.4 KB
/
launchbot.bat
File metadata and controls
178 lines (145 loc) · 4.4 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
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
@echo off
setlocal EnableExtensions
chcp 65001 >nul
title Launch TTS + NachoBot
set "FINAL_RC=0"
set "ROOT=%~dp0"
echo ===== Start TTS Component =====
call :START_TTS
if errorlevel 1 (
set "FINAL_RC=1"
echo [FATAL] TTS component failed to start.
goto :EXIT
)
echo.
echo ===== Start Main Bot Component =====
call :START_MAIN
set "FINAL_RC=%ERRORLEVEL%"
goto :EXIT
:START_TTS
setlocal EnableDelayedExpansion
title TTS Launch
chcp 65001 >nul
set "TTS_RC=0"
set "BASE_DIR=%ROOT%"
set "ADAPTER_DIR=%BASE_DIR%NachoBot-TTS-Adapter"
set "NAPCAT_DIR=%BASE_DIR%NachoBot-Napcat-Adapter"
set "NAPCAT_SRC=%NAPCAT_DIR%\src"
set "SOVITS_DIR=C:\Users\BigSh0t\GPT-SoVITS\GPT-SoVITS-v2pro-20250604"
set "PORT_SOVITS=9880"
set "PORT_ADAPTER=8070"
set "PORT_CONTROL=9872"
set "PY_GPT=%SOVITS_DIR%\runtime\python.exe"
set "PY_ADAPTER=%ADAPTER_DIR%\.venv\Scripts\python.exe"
set "PYTHONNOUSERSITE=1"
set "HTTP_PROXY="
set "HTTPS_PROXY="
set "ALL_PROXY="
set "NO_PROXY=127.0.0.1,localhost"
set "LOG_DIR=%ADAPTER_DIR%\logs"
if not exist "%LOG_DIR%" mkdir "%LOG_DIR%"
set "SETUP_LOG=%LOG_DIR%\boot_setup.log"
echo ==== RUN %date% %time% ==== >> "%SETUP_LOG%"
set "PY_BOOT="
where py >nul 2>&1
if not errorlevel 1 (
py -3.11 -V >nul 2>&1
if not errorlevel 1 set "PY_BOOT=py -3.11"
)
if not defined PY_BOOT (
where python >nul 2>&1
if not errorlevel 1 set "PY_BOOT=python"
)
if not defined PY_BOOT (
echo [FATAL] No available Python found. >> "%SETUP_LOG%"
echo [FATAL] No available Python found.
set "TTS_RC=1"
goto :TTS_FAIL
)
where uv >nul 2>&1
if errorlevel 1 (
echo [INFO] uv not detected, installing... >> "%SETUP_LOG%"
powershell -NoProfile -ExecutionPolicy ByPass -Command "irm https://astral.sh/uv/install.ps1 | iex"
set "PATH=%USERPROFILE%\.local\bin;%USERPROFILE%\.cargo\bin;%PATH%"
)
echo [INFO] Syncing dependencies... >> "%SETUP_LOG%"
cd /d "%ADAPTER_DIR%"
uv sync >> "%SETUP_LOG%" 2>&1
set "API_FILE=%SOVITS_DIR%\api_v2.py"
if not exist "%API_FILE%" set "API_FILE=%SOVITS_DIR%\api.py"
echo.
echo ========== Start SoVITS / Adapter / Control ==========
echo.
start "SoVITS API (%PORT_SOVITS%)" cmd /k "chcp 65001>nul && set PYTHONPATH=%SOVITS_DIR%;%SOVITS_DIR%\GPT_SoVITS && cd /d %SOVITS_DIR% && %PY_GPT% -s %API_FILE% --port %PORT_SOVITS%"
set "READY="
for /l %%I in (1,1,60) do (
netstat -ano | findstr /r /c:":%PORT_SOVITS% " | findstr /i LISTENING >nul
if not errorlevel 1 (
set "READY=1"
goto :TTS_SOVITS_READY
)
timeout /t 1 /nobreak >nul
)
echo [ERROR] SoVITS timeout.
set "TTS_RC=1"
goto :TTS_FAIL
:TTS_SOVITS_READY
echo [OK] SoVITS ready.
start "TTS Adapter (%PORT_ADAPTER%)" cmd /k "chcp 65001>nul && set PYTHONPATH=%ADAPTER_DIR%;%ADAPTER_DIR%\tts_src;%NAPCAT_SRC%;%NAPCAT_DIR% && cd /d %ADAPTER_DIR% && uv run python main.py"
echo [OK] Starting Control...
start "Control API (%PORT_CONTROL%)" cmd /k "chcp 65001>nul && set PYTHONPATH=%ADAPTER_DIR%;%ADAPTER_DIR%\tts_src;%NAPCAT_SRC%;%NAPCAT_DIR% && cd /d %ADAPTER_DIR% && uv run python -m tts_src.plugins.GPT_Sovits.api_server"
echo.
echo All modules started.
echo.
goto :TTS_END
:TTS_FAIL
echo Error during initialization.
pause
set "TTS_RC=1"
:TTS_END
endlocal & exit /b %TTS_RC%
:START_MAIN
setlocal EnableExtensions
title Launch Process
chcp 65001 >nul
set "NACHOBOT_DIR=%ROOT%NachoBot"
set "NACHOBOT_MAIN=bot.py"
set "NACHOBOT_PORT=8000"
set "ADAPTER_DIR=%ROOT%NachoBot-Napcat-Adapter"
set "ADAPTER_MAIN=main.py"
set "ADAPTER_PORT=8095"
set "NAPCAT_SHELL_DIR=%ROOT%NapCat.Shell"
set "NAPCAT_SHELL_BAT=launcher-user.bat"
set "PYTHON_CMD=uv run python"
set "MAX_WAIT=60"
echo --- Syncing NachoBot...
cd /d "%NACHOBOT_DIR%"
uv sync
echo --- Syncing Adapter...
cd /d "%ADAPTER_DIR%"
uv sync
if exist "%NACHOBOT_DIR%\%NACHOBOT_MAIN%" (
echo --- Start NachoBot...
start "NachoBot" /D "%NACHOBOT_DIR%" cmd /k "set HOST=127.0.0.1 && set PORT=%NACHOBOT_PORT% && %PYTHON_CMD% %NACHOBOT_MAIN%"
timeout /t 5 /nobreak >nul
)
if exist "%ADAPTER_DIR%\%ADAPTER_MAIN%" (
echo --- Start Adapter...
start "NachoBot-Napcat" /D "%ADAPTER_DIR%" cmd /k "set HOST=0.0.0.0 && set PORT=%ADAPTER_PORT% && %PYTHON_CMD% %ADAPTER_MAIN%"
timeout /t 5 /nobreak >nul
)
if exist "%NAPCAT_SHELL_DIR%\%NAPCAT_SHELL_BAT%" (
echo --- Start NapCat Shell...
start "NapCatShell" /D "%NAPCAT_SHELL_DIR%" cmd /k "%NAPCAT_SHELL_BAT%"
)
echo.
echo Startup complete.
endlocal & exit /b 0
:EXIT
if %FINAL_RC% NEQ 0 (
echo Error occurred.
pause
) else (
echo All done.
)
endlocal & exit /b %FINAL_RC%