forked from stride3d/stride
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcompile.bat
221 lines (175 loc) · 6.55 KB
/
compile.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
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
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
@echo off
setlocal
set STARTTIME=%TIME%
set __SkipTestBuild=true
set __BuildType=Debug
set __BuildVerbosity=m
set __BuildDoc=0
set __ContinueOnError=false
:Arg_Loop
rem This does not check for duplicate arguments, the last one will take precedence
if "%1" == "" goto ArgsDone
if /i "%1" == "/?" goto Usage
if /i "%1" == "debug" (set __BuildType=Debug && shift && goto Arg_loop)
if /i "%1" == "release" (set __BuildType=Release && shift && goto Arg_loop)
if /i "%1" == "tests" (set __SkipTestBuild=false && shift && goto Arg_loop)
if /i "%1" == "continueonerror" (set __ContinueOnError=true && shift && goto Arg_loop)
if /i "%1" == "verbosity:q" (set __BuildVerbosity=q && shift && goto Arg_loop)
if /i "%1" == "verbosity:m" (set __BuildVerbosity=m && shift && goto Arg_loop)
if /i "%1" == "verbosity:n" (set __BuildVerbosity=n && shift && goto Arg_loop)
if /i "%1" == "verbosity:d" (set __BuildVerbosity=d && shift && goto Arg_loop)
if /i "%1" == "doc" (set __BuildDoc=1 && shift && goto Arg_loop)
rem No space after %2 as it would add a space at the end of __SelectedProject
if /i "%1" == "project" (if "%2" == "" (goto Usage) else (set __SelectedProject=%2&& shift && shift && goto Arg_loop))
echo.
echo Invalid command line argument: %1
echo.
goto Usage
:Usage
echo compile.bat [/? ^| debug ^| release ^| tests ^| verbosity:[q^|m^|n^|d] ^| project Project.sln
echo.
echo debug : Build debug version
echo release : Build release version
echo tests : Build tests
echo verbosity : Verbosity level [q]uiet, [m]inimal, [n]ormal or [d]iagnostic. Default is [m]inimal
echo project : Chosen project
echo.
goto exit
:ArgsDone
rem Let's check we have msbuild in our path
msbuild /nologo /version > nul 2>&1
if %ERRORLEVEL% NEQ 0 (
echo Cannot find msbuild.
goto exit
)
rem Check that msbuild is version 15 or greater
for /f "tokens=1 delims=." %%i in ('msbuild /nologo /version') do set __BuildVersion=%%i
if %__BuildVersion% LSS 15 (
echo MSbuild version 15 or greater is required
goto exit
)
set XXMSBUILD=msbuild.exe
set _platform_target=Mixed Platforms
rem Compiling the various solutions
set Project=Xenko.sln
rem We always compile tests for the main solution
set __OldSkipTestBuild=%__SkipTestBuild%
set __SkipTestBuild=false
call :compile
set __SkipTestBuild=%__OldSkipTestBuild%
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Direct3D.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Direct3D.SDL.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Direct3D.CoreCLR.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Direct3D12.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Null.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Vulkan.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Vulkan.SDL.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.OpenGL.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.OpenGL.CoreCLR.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Linux.sln
set _platform_target=Linux
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Linux.Vulkan.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Linux.CoreCLR.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Linux.Vulkan.CoreCLR.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.macOS.sln
set _platform_target=macOS
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.macOS.CoreCLR.sln
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.Android.sln
set _platform_target=Android
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.iOS.sln
set _platform_target=iPhone
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
set Project=Xenko.UWP.sln
set _platform_target=UWP
call :compile
if %ERRORLEVEL% NEQ 0 if "%__ContinueOnError%" == "false" goto exit
goto exit
rem Compile our solution. The following variables needs to be set:
rem "Project" is the solution name
rem "_platform_target" is the platform being targeted
:compile
set _option=/nologo /nr:false /m /verbosity:%__BuildVerbosity% /p:Configuration=%__BuildType% /p:Platform="%_platform_target%" /p:XenkoSkipUnitTests=%__SkipTestBuild% %Project%
if "%__BuildDoc%" == "1" set _option=%_option% /p:XenkoGenerateDoc=true
rem Skip Compilation if __SelectedProject was set and does not match what was requested
if "%__SelectedProject%" NEQ "" (
if "%__SelectedProject%" NEQ "%Project%" (
goto :eof
)
)
echo Compiling using command line %XXMSBUILD% %_option%
echo.
rem Launch the build and checkling for an error
%XXMSBUILD% %_option%
if %ERRORLEVEL% NEQ 0 (
echo Error while compiling project: %Project%
echo Command line was: %XXMSBUILD% %_option%
exit /b 1
) else (
echo Done compiling project: %Project%
)
echo.
goto :eof
:exit
set ENDTIME=%TIME%
echo.
echo Starting time was: %STARTTIME%
echo Ending time is : %ENDTIME%
rem convert STARTTIME and ENDTIME to miliseconds
rem The format of %TIME% is HH:MM:SS,CS for example 23:59:59,99
set /A STARTTIME=(1%STARTTIME:~0,2%-100)*3600000 + (1%STARTTIME:~3,2%-100)*60000 + (1%STARTTIME:~6,2%-100)*1000 + (1%STARTTIME:~9,2%-100)*10
set /A ENDTIME=(1%ENDTIME:~0,2%-100)*3600000 + (1%ENDTIME:~3,2%-100)*60000 + (1%ENDTIME:~6,2%-100)*1000 + (1%ENDTIME:~9,2%-100)*10
rem calculating the duration is easy
set /A DURATION=%ENDTIME%-%STARTTIME%
rem we might have measured the time inbetween days
if %ENDTIME% LSS %STARTTIME% set set /A DURATION=%STARTTIME%-%ENDTIME%
set /A DURATION=%DURATION%/1000
if %DURATION% GEQ 60 (
set /A MINUTES=%DURATION% / 60
rem Get rid of the part after the .
for /f "tokens=1,2 delims=." %%a in ("%MINUTES%") do set MINUTES=%%a
set /A DURATION=%DURATION%%%60
) else (
set /A MINUTES=0
)
rem outputing
if %MINUTES% NEQ 0 (
echo Duration is : %MINUTES% minutes and %DURATION% seconds
) else (
echo Duration is : %DURATION% seconds
)
endlocal
@echo on