-
Notifications
You must be signed in to change notification settings - Fork 24
/
win_run_server_dev_seed.bat
109 lines (87 loc) · 3.79 KB
/
win_run_server_dev_seed.bat
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
@echo off
IF NOT EXIST .build\modules\TFN.mod (
echo .build\modules\TFN.mod does not exist. Please run win_nasher_install.bat first to install the module
pause
exit /b 1
)
python --version > nul 2>&1
IF %ERRORLEVEL% NEQ 0 (
echo Python is not installed. Please install Python to continue seeding the server.
pause
exit /b 1
)
docker --version > nul 2>&1
IF %ERRORLEVEL% NEQ 0 (
echo Docker is not installed. Please install Docker to run the server.
pause
exit /b 1
)
docker info > nul 2>&1
IF %ERRORLEVEL% NEQ 0 (
echo Docker error encountered or the Docker service isn't running! Please check and try again.
pause
exit /b 1
)
setlocal
:: Capture start time
for /F "tokens=1-3 delims=:." %%a in ("%TIME%") do (
set "START_HOUR=%%a"
set "START_MINUTE=%%b"
set "START_SECOND=%%c"
)
del /f .build\database\prettify.sqlite3
del /f .build\database\tmapsolutions.sqlite3
del /f .build\database\areadistances.sqlite3
md .build\database
:: Delete existing databases, because sqlite will attempt to load it into an existing database instead of overwriting
del /f .build\database\spawns.sqlite3
del /f .build\database\treasures.sqlite3
del /f .build\database\randspellbooks.sqlite3
del /f .build\database\prettify.sqlite3
del /f .build\database\tmapsolutions.sqlite3
del /f .build\database\areadistances.sqlite3
:: These databases rely on previous information (checks existing and may skip recalculating some things so it's faster)
"%CD%/tools/win/sqlite/sqlite3.exe" .build/database/treasures.sqlite3 < seeded_database/treasures.txt
"%CD%/tools/win/sqlite/sqlite3.exe" .build/database/tmapsolutions.sqlite3 < seeded_database/tmapsolutions.txt
"%CD%/tools/win/sqlite/sqlite3.exe" .build/database/randspellbooks.sqlite3 < seeded_database/randspellbooks.txt
"%CD%/tools/win/sqlite/sqlite3.exe" .build/database/prettify.sqlite3 < seeded_database/prettify.txt
"%CD%/tools/win/sqlite/sqlite3.exe" .build/database/areadistances.sqlite3 < seeded_database/areadistances.txt
cd .build
docker-compose -f docker-compose-dev-seed.yml down
docker-compose -f docker-compose-dev-seed.yml up --no-recreate
:: Delete existing database dumps, because we should always get the newly generated ones
del /f ..\seeded_database\spawns.txt
del /f ..\seeded_database\treasures.txt
del /f ..\seeded_database\randspellbooks.txt
del /f ..\seeded_database\prettify.txt
del /f ..\seeded_database\tmapsolutions.txt
del /f ..\seeded_database\areadistances.txt
"%CD%/../tools/win/sqlite/sqlite3.exe" database/treasures.sqlite3 .dump > ../seeded_database/treasures.txt
"%CD%/../tools/win/sqlite/sqlite3.exe" database/tmapsolutions.sqlite3 .dump > ../seeded_database/tmapsolutions.txt
"%CD%/../tools/win/sqlite/sqlite3.exe" database/spawns.sqlite3 .dump > ../seeded_database/spawns.txt
"%CD%/../tools/win/sqlite/sqlite3.exe" database/randspellbooks.sqlite3 .dump > ../seeded_database/randspellbooks.txt
"%CD%/../tools/win/sqlite/sqlite3.exe" database/prettify.sqlite3 .dump > ../seeded_database/prettify.txt
"%CD%/../tools/win/sqlite/sqlite3.exe" database/areadistances.sqlite3 .dump > ../seeded_database/areadistances.txt
python ../tools/replace_database_migration_numbers.py
for /F "tokens=1-3 delims=:." %%a in ("%TIME%") do (
set "END_HOUR=%%a"
set "END_MINUTE=%%b"
set "END_SECOND=%%c"
)
call :TimeDiff
PAUSE
exit /b
:TimeDiff
setlocal
set /A "START_TOTAL_SECONDS=START_HOUR*3600 + START_MINUTE*60 + START_SECOND"
set /A "END_TOTAL_SECONDS=END_HOUR*3600 + END_MINUTE*60 + END_SECOND"
set /A "DIFF=END_TOTAL_SECONDS-START_TOTAL_SECONDS"
if %DIFF% lss 0 (
set /A "DIFF+=86400" :: Adjust for negative difference (e.g., if crossing midnight)
)
set /A "HOURS=DIFF/3600"
set /A "MINUTES=(DIFF%%3600)/60"
set /A "SECONDS=DIFF%%60"
echo Total execution time: %HOURS% hours, %MINUTES% minutes, %SECONDS% seconds.
endlocal
exit /b