5 if /i "%1"=="help" goto help
6 if /i "%1"=="--help" goto help
7 if /i "%1"=="-help" goto help
8 if /i "%1"=="/help" goto help
9 if /i "%1"=="?" goto help
10 if /i "%1"=="-?" goto help
11 if /i "%1"=="--?" goto help
12 if /i "%1"=="/?" goto help
14 @rem Process arguments.
35 set noperfctr_msi_arg=
42 if "%1"=="" goto args-done
43 if /i "%1"=="debug" set config=Debug&goto arg-ok
44 if /i "%1"=="release" set config=Release&goto arg-ok
45 if /i "%1"=="clean" set target=Clean&goto arg-ok
46 if /i "%1"=="ia32" set target_arch=x86&goto arg-ok
47 if /i "%1"=="x86" set target_arch=x86&goto arg-ok
48 if /i "%1"=="x64" set target_arch=x64&goto arg-ok
49 if /i "%1"=="noprojgen" set noprojgen=1&goto arg-ok
50 if /i "%1"=="nobuild" set nobuild=1&goto arg-ok
51 if /i "%1"=="nosign" set nosign=1&goto arg-ok
52 if /i "%1"=="nosnapshot" set nosnapshot=1&goto arg-ok
53 if /i "%1"=="noetw" set noetw=1&goto arg-ok
54 if /i "%1"=="noperfctr" set noperfctr=1&goto arg-ok
55 if /i "%1"=="licensertf" set licensertf=1&goto arg-ok
56 if /i "%1"=="test" set test_args=%test_args% sequential parallel message -J&set jslint=1&goto arg-ok
57 if /i "%1"=="test-ci" set test_args=%test_args% %test_ci_args% -p tap --logfile test.tap message sequential parallel&goto arg-ok
58 if /i "%1"=="test-simple" set test_args=%test_args% sequential parallel -J&goto arg-ok
59 if /i "%1"=="test-message" set test_args=%test_args% message&goto arg-ok
60 if /i "%1"=="test-gc" set test_args=%test_args% gc&set buildnodeweak=1&goto arg-ok
61 if /i "%1"=="test-internet" set test_args=%test_args% internet&goto arg-ok
62 if /i "%1"=="test-pummel" set test_args=%test_args% pummel&goto arg-ok
63 if /i "%1"=="test-all" set test_args=%test_args% sequential parallel message gc internet pummel&set buildnodeweak=1&set jslint=1&goto arg-ok
64 if /i "%1"=="jslint" set jslint=1&goto arg-ok
65 @rem Include small-icu support with MSI installer
66 if /i "%1"=="msi" set msi=1&set licensertf=1&set download_arg="--download=all"&set i18n_arg=small-icu&goto arg-ok
67 if /i "%1"=="build-release" set build_release=1&goto arg-ok
68 if /i "%1"=="upload" set upload=1&goto arg-ok
69 if /i "%1"=="small-icu" set i18n_arg=%1&goto arg-ok
70 if /i "%1"=="full-icu" set i18n_arg=%1&goto arg-ok
71 if /i "%1"=="intl-none" set i18n_arg=%1&goto arg-ok
72 if /i "%1"=="download-all" set download_arg="--download=all"&goto arg-ok
73 if /i "%1"=="ignore-flaky" set test_args=%test_args% --flaky-tests=dontcare&goto arg-ok
75 echo Warning: ignoring invalid command line option `%1`.
84 if defined build_release (
88 set download_arg="--download=all"
89 set i18n_arg=small-icu
92 if "%config%"=="Debug" set debug_arg=--debug
93 if defined nosnapshot set snapshot_arg=--without-snapshot
94 if defined noetw set noetw_arg=--without-etw& set noetw_msi_arg=/p:NoETW=1
95 if defined noperfctr set noperfctr_arg=--without-perfctr& set noperfctr_msi_arg=/p:NoPerfCtr=1
96 if defined RELEASE_URLBASE set release_urlbase_arg=--release-urlbase=%RELEASE_URLBASE%
98 if "%i18n_arg%"=="full-icu" set i18n_arg=--with-intl=full-icu
99 if "%i18n_arg%"=="small-icu" set i18n_arg=--with-intl=small-icu
100 if "%i18n_arg%"=="intl-none" set i18n_arg=--with-intl=none
102 if not exist "%~dp0deps\icu" goto no-depsicu
103 if "%target%"=="Clean" echo deleting %~dp0deps\icu
104 if "%target%"=="Clean" rmdir /S /Q %~dp0deps\icu
107 call :getnodeversion || exit /b 1
109 @rem Set environment for msbuild
111 @rem Look for Visual Studio 2015
112 echo Looking for Visual Studio 2015
113 if not defined VS140COMNTOOLS goto vc-set-2013
114 if not exist "%VS140COMNTOOLS%\..\..\vc\vcvarsall.bat" goto vc-set-2013
115 echo Found Visual Studio 2015
117 echo Looking for WiX installation for Visual Studio 2015...
118 if not exist "%WIX%\SDK\VS2015" (
119 echo Failed to find WiX install for Visual Studio 2015
120 echo VS2015 support for WiX is only present starting at version 3.10
124 if "%VCVARS_VER%" NEQ "140" (
125 call "%VS140COMNTOOLS%\..\..\vc\vcvarsall.bat"
128 if not defined VCINSTALLDIR goto vc-set-2013
129 set GYP_MSVS_VERSION=2015
130 set PLATFORM_TOOLSET=v140
134 @rem Look for Visual Studio 2013
135 echo Looking for Visual Studio 2013
136 if not defined VS120COMNTOOLS goto msbuild-not-found
137 if not exist "%VS120COMNTOOLS%\..\..\vc\vcvarsall.bat" goto msbuild-not-found
138 echo Found Visual Studio 2013
140 echo Looking for WiX installation for Visual Studio 2013...
141 if not exist "%WIX%\SDK\VS2013" (
142 echo Failed to find WiX install for Visual Studio 2013
143 echo VS2013 support for WiX is only present starting at version 3.8
147 if "%VCVARS_VER%" NEQ "120" (
148 call "%VS120COMNTOOLS%\..\..\vc\vcvarsall.bat"
151 if not defined VCINSTALLDIR goto msbuild-not-found
152 set GYP_MSVS_VERSION=2013
153 set PLATFORM_TOOLSET=v120
157 echo Failed to find Visual Studio installation.
161 echo Build skipped. To generate installer, you need to install Wix.
167 @rem Skip project generation if requested.
168 if defined noprojgen goto msbuild
170 @rem Generate the VS project.
171 python configure %download_arg% %i18n_arg% %debug_arg% %snapshot_arg% %noetw_arg% %noperfctr_arg% --dest-cpu=%target_arch% --tag=%TAG%
172 if errorlevel 1 goto create-msvs-files-failed
173 if not exist node.sln goto create-msvs-files-failed
174 echo Project files generated.
177 @rem Skip build if requested.
178 if defined nobuild goto sign
180 @rem Build the sln with msbuild.
181 msbuild node.sln /m /t:%target% /p:Configuration=%config% /clp:NoSummary;NoItemAndPropertyList;Verbosity=minimal /nologo
182 if errorlevel 1 goto exit
183 if "%target%" == "Clean" goto exit
186 @rem Skip signing if the `nosign` option was specified.
187 if defined nosign goto licensertf
189 signtool sign /a /d "Node.js" /du "https://nodejs.org" /t http://timestamp.globalsign.com/scripts/timestamp.dll Release\node.exe
190 if errorlevel 1 echo Failed to sign exe&goto exit
193 @rem Skip license.rtf generation if not requested.
194 if not defined licensertf goto msi
196 %config%\node tools\license2rtf.js < LICENSE > %config%\license.rtf
197 if errorlevel 1 echo Failed to generate license.rtf&goto exit
200 @rem Skip msi generation if not requested
201 if not defined msi goto run
204 echo Building node-v%FULLVERSION%-%target_arch%.msi
205 msbuild "%~dp0tools\msvs\msi\nodemsi.sln" /m /t:Clean,Build /p:PlatformToolset=%PLATFORM_TOOLSET% /p:GypMsvsVersion=%GYP_MSVS_VERSION% /p:Configuration=%config% /p:Platform=%target_arch% /p:NodeVersion=%NODE_VERSION% /p:FullVersion=%FULLVERSION% /p:DistTypeDir=%DISTTYPEDIR% %noetw_msi_arg% %noperfctr_msi_arg% /clp:NoSummary;NoItemAndPropertyList;Verbosity=minimal /nologo
206 if errorlevel 1 goto exit
208 if defined nosign goto upload
209 signtool sign /a /d "Node.js" /du "https://nodejs.org" /t http://timestamp.globalsign.com/scripts/timestamp.dll node-v%FULLVERSION%-%target_arch%.msi
210 if errorlevel 1 echo Failed to sign msi&goto exit
213 @rem Skip upload if not requested
214 if not defined upload goto run
216 if not defined SSHCONFIG (
217 echo SSHCONFIG is not set for upload
220 if not defined STAGINGSERVER set STAGINGSERVER=node-www
221 ssh -F %SSHCONFIG% %STAGINGSERVER% "mkdir -p nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%"
222 scp -F %SSHCONFIG% Release\node.exe %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node.exe
223 scp -F %SSHCONFIG% Release\node.lib %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node.lib
224 scp -F %SSHCONFIG% node-v%FULLVERSION%-%target_arch%.msi %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/
225 ssh -F %SSHCONFIG% %STAGINGSERVER% "touch nodejs/%DISTTYPEDIR%/v%FULLVERSION%/node-v%FULLVERSION%-%target_arch%.msi.done nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%.done && chmod -R ug=rw-x+X,o=r+X nodejs/%DISTTYPEDIR%/v%FULLVERSION%/node-v%FULLVERSION%-%target_arch%.msi* nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%*"
228 @rem Run tests if requested.
231 @rem Build node-weak if required
232 if "%buildnodeweak%"=="" goto run-tests
233 "%config%\node" deps\npm\node_modules\node-gyp\bin\node-gyp rebuild --directory="%~dp0test\gc\node_modules\weak" --nodedir="%~dp0."
234 if errorlevel 1 goto build-node-weak-failed
237 :build-node-weak-failed
238 echo Failed to build node-weak.
242 if "%test_args%"=="" goto jslint
243 if "%config%"=="Debug" set test_args=--mode=debug %test_args%
244 if "%config%"=="Release" set test_args=--mode=release %test_args%
245 echo running 'cctest'
247 echo running 'python tools\test.py %test_args%'
248 python tools\test.py %test_args%
252 if not defined jslint goto exit
254 %config%\node tools\eslint\bin\eslint.js src lib test tools\eslint-rules --rulesdir tools\eslint-rules --reset --quiet
257 :create-msvs-files-failed
258 echo Failed to create vc project files.
262 echo vcbuild.bat [debug/release] [msi] [test-all/test-uv/test-internet/test-pummel/test-simple/test-message] [clean] [noprojgen] [small-icu/full-icu/intl-none] [nobuild] [nosign] [x86/x64] [download-all]
264 echo vcbuild.bat : builds release build
265 echo vcbuild.bat debug : builds debug build
266 echo vcbuild.bat release msi : builds release build and MSI installer package
267 echo vcbuild.bat test : builds debug build and runs tests
268 echo vcbuild.bat build-release : builds the release distribution as used by nodejs.org
283 for /F "usebackq tokens=*" %%i in (`python "%~dp0tools\getnodeversion.py"`) do set NODE_VERSION=%%i
284 if not defined NODE_VERSION (
285 echo Cannot determine current version of Node.js
289 if not defined DISTTYPE set DISTTYPE=release
290 if "%DISTTYPE%"=="release" (
291 set FULLVERSION=%NODE_VERSION%
294 if "%DISTTYPE%"=="custom" (
295 if not defined CUSTOMTAG (
296 echo "CUSTOMTAG is not set for DISTTYPE=custom"
301 if not "%DISTTYPE%"=="custom" (
302 if not defined DATESTRING (
303 echo "DATESTRING is not set for nightly"
306 if not defined COMMIT (
307 echo "COMMIT is not set for nightly"
310 if not "%DISTTYPE%"=="nightly" (
311 if not "%DISTTYPE%"=="next-nightly" (
312 echo "DISTTYPE is not release, custom, nightly or next-nightly"
316 set TAG=%DISTTYPE%%DATESTRING%%COMMIT%
318 set FULLVERSION=%NODE_VERSION%-%TAG%
321 if not defined DISTTYPEDIR set DISTTYPEDIR=%DISTTYPE%