mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 10:59:27 +00:00
6dae965c2d
Enable all recommended JSDoc linting rules and disable the ones we don't (yet?) meet. They can be enabled one by one by removing the lines that turn them off. This requires adding --max-warnings to the ESLint invocations in Makefile and vcbuild.bat because the preset enables the recommended rules as warnings and not errors. PR-URL: https://github.com/nodejs/node/pull/41057 Reviewed-By: Michaël Zasso <targos@protonmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
817 lines
31 KiB
Batchfile
817 lines
31 KiB
Batchfile
@if not defined DEBUG_HELPER @ECHO OFF
|
|
|
|
:: Other scripts rely on the environment variables set in this script, so we
|
|
:: explicitly allow them to persist in the calling shell.
|
|
endlocal
|
|
|
|
if /i "%1"=="help" goto help
|
|
if /i "%1"=="--help" goto help
|
|
if /i "%1"=="-help" goto help
|
|
if /i "%1"=="/help" goto help
|
|
if /i "%1"=="?" goto help
|
|
if /i "%1"=="-?" goto help
|
|
if /i "%1"=="--?" goto help
|
|
if /i "%1"=="/?" goto help
|
|
|
|
cd %~dp0
|
|
|
|
set JS_SUITES=default
|
|
set NATIVE_SUITES=addons js-native-api node-api
|
|
@rem CI_* variables should be kept synchronized with the ones in Makefile
|
|
set "CI_NATIVE_SUITES=%NATIVE_SUITES% benchmark"
|
|
set "CI_JS_SUITES=%JS_SUITES% pummel"
|
|
set CI_DOC=doctool
|
|
@rem Same as the test-ci target in Makefile
|
|
set "common_test_suites=%JS_SUITES% %NATIVE_SUITES%&set build_addons=1&set build_js_native_api_tests=1&set build_node_api_tests=1"
|
|
|
|
@rem Process arguments.
|
|
set config=Release
|
|
set target=Build
|
|
set target_arch=x64
|
|
set ltcg=
|
|
set target_env=
|
|
set noprojgen=
|
|
set projgen=
|
|
set nobuild=
|
|
set sign=
|
|
set nosnapshot=
|
|
set cctest_args=
|
|
set test_args=
|
|
set stage_package=
|
|
set package=
|
|
set msi=
|
|
set upload=
|
|
set licensertf=
|
|
set lint_js=
|
|
set lint_cpp=
|
|
set lint_md=
|
|
set lint_md_build=
|
|
set noetw=
|
|
set noetw_msi_arg=
|
|
set i18n_arg=
|
|
set download_arg=
|
|
set build_release=
|
|
set configure_flags=
|
|
set build_addons=
|
|
set dll=
|
|
set enable_static=
|
|
set build_js_native_api_tests=
|
|
set build_node_api_tests=
|
|
set test_node_inspect=
|
|
set test_check_deopts=
|
|
set v8_test_options=
|
|
set v8_build_options=
|
|
set http2_debug=
|
|
set nghttp2_debug=
|
|
set link_module=
|
|
set no_cctest=
|
|
set cctest=
|
|
set openssl_no_asm=
|
|
set doc=
|
|
set extra_msbuild_args=
|
|
set exit_code=0
|
|
|
|
:next-arg
|
|
if "%1"=="" goto args-done
|
|
if /i "%1"=="debug" set config=Debug&goto arg-ok
|
|
if /i "%1"=="release" set config=Release&set ltcg=1&set cctest=1&goto arg-ok
|
|
if /i "%1"=="clean" set target=Clean&goto arg-ok
|
|
if /i "%1"=="testclean" set target=TestClean&goto arg-ok
|
|
if /i "%1"=="ia32" set target_arch=x86&goto arg-ok
|
|
if /i "%1"=="x86" set target_arch=x86&goto arg-ok
|
|
if /i "%1"=="x64" set target_arch=x64&goto arg-ok
|
|
if /i "%1"=="arm64" set target_arch=arm64&goto arg-ok
|
|
if /i "%1"=="vs2019" set target_env=vs2019&goto arg-ok
|
|
if /i "%1"=="vs2022" set target_env=vs2022&goto arg-ok
|
|
if /i "%1"=="noprojgen" set noprojgen=1&goto arg-ok
|
|
if /i "%1"=="projgen" set projgen=1&goto arg-ok
|
|
if /i "%1"=="nobuild" set nobuild=1&goto arg-ok
|
|
if /i "%1"=="nosign" set "sign="&echo Note: vcbuild no longer signs by default. "nosign" is redundant.&goto arg-ok
|
|
if /i "%1"=="sign" set sign=1&goto arg-ok
|
|
if /i "%1"=="nosnapshot" set nosnapshot=1&goto arg-ok
|
|
if /i "%1"=="noetw" set noetw=1&goto arg-ok
|
|
if /i "%1"=="ltcg" set ltcg=1&goto arg-ok
|
|
if /i "%1"=="licensertf" set licensertf=1&goto arg-ok
|
|
if /i "%1"=="test" set test_args=%test_args% %common_test_suites%&set lint_cpp=1&set lint_js=1&set lint_md=1&goto arg-ok
|
|
if /i "%1"=="test-ci-native" set test_args=%test_args% %test_ci_args% -p tap --logfile test.tap %CI_NATIVE_SUITES% %CI_DOC%&set build_addons=1&set build_js_native_api_tests=1&set build_node_api_tests=1&set cctest_args=%cctest_args% --gtest_output=xml:cctest.junit.xml&goto arg-ok
|
|
if /i "%1"=="test-ci-js" set test_args=%test_args% %test_ci_args% -p tap --logfile test.tap %CI_JS_SUITES%&set no_cctest=1&goto arg-ok
|
|
if /i "%1"=="build-addons" set build_addons=1&goto arg-ok
|
|
if /i "%1"=="build-js-native-api-tests" set build_js_native_api_tests=1&goto arg-ok
|
|
if /i "%1"=="build-node-api-tests" set build_node_api_tests=1&goto arg-ok
|
|
if /i "%1"=="test-addons" set test_args=%test_args% addons&set build_addons=1&goto arg-ok
|
|
if /i "%1"=="test-doc" set test_args=%test_args% %CI_DOC%&set doc=1&&set lint_js=1&set lint_md=1&goto arg-ok
|
|
if /i "%1"=="test-js-native-api" set test_args=%test_args% js-native-api&set build_js_native_api_tests=1&goto arg-ok
|
|
if /i "%1"=="test-node-api" set test_args=%test_args% node-api&set build_node_api_tests=1&goto arg-ok
|
|
if /i "%1"=="test-benchmark" set test_args=%test_args% benchmark&goto arg-ok
|
|
if /i "%1"=="test-simple" set test_args=%test_args% sequential parallel&goto arg-ok
|
|
if /i "%1"=="test-message" set test_args=%test_args% message&goto arg-ok
|
|
if /i "%1"=="test-tick-processor" set test_args=%test_args% tick-processor&goto arg-ok
|
|
if /i "%1"=="test-internet" set test_args=%test_args% internet&goto arg-ok
|
|
if /i "%1"=="test-pummel" set test_args=%test_args% pummel&goto arg-ok
|
|
if /i "%1"=="test-known-issues" set test_args=%test_args% known_issues&goto arg-ok
|
|
if /i "%1"=="test-async-hooks" set test_args=%test_args% async-hooks&goto arg-ok
|
|
if /i "%1"=="test-all" set test_args=%test_args% gc internet pummel %common_test_suites%&set lint_cpp=1&set lint_js=1&goto arg-ok
|
|
if /i "%1"=="test-node-inspect" set test_node_inspect=1&goto arg-ok
|
|
if /i "%1"=="test-check-deopts" set test_check_deopts=1&goto arg-ok
|
|
if /i "%1"=="test-npm" set test_npm=1&goto arg-ok
|
|
if /i "%1"=="test-v8" set test_v8=1&set custom_v8_test=1&goto arg-ok
|
|
if /i "%1"=="test-v8-intl" set test_v8_intl=1&set custom_v8_test=1&goto arg-ok
|
|
if /i "%1"=="test-v8-benchmarks" set test_v8_benchmarks=1&set custom_v8_test=1&goto arg-ok
|
|
if /i "%1"=="test-v8-all" set test_v8=1&set test_v8_intl=1&set test_v8_benchmarks=1&set custom_v8_test=1&goto arg-ok
|
|
if /i "%1"=="lint-cpp" set lint_cpp=1&goto arg-ok
|
|
if /i "%1"=="lint-js" set lint_js=1&goto arg-ok
|
|
if /i "%1"=="jslint" set lint_js=1&echo Please use lint-js instead of jslint&goto arg-ok
|
|
if /i "%1"=="lint-md" set lint_md=1&goto arg-ok
|
|
if /i "%1"=="lint-md-build" set lint_md_build=1&goto arg-ok
|
|
if /i "%1"=="lint" set lint_cpp=1&set lint_js=1&set lint_md=1&goto arg-ok
|
|
if /i "%1"=="lint-ci" set lint_cpp=1&set lint_js_ci=1&goto arg-ok
|
|
if /i "%1"=="package" set package=1&goto arg-ok
|
|
if /i "%1"=="msi" set msi=1&set licensertf=1&set download_arg="--download=all"&set i18n_arg=full-icu&goto arg-ok
|
|
if /i "%1"=="build-release" set build_release=1&set sign=1&goto arg-ok
|
|
if /i "%1"=="upload" set upload=1&goto arg-ok
|
|
if /i "%1"=="small-icu" set i18n_arg=%1&goto arg-ok
|
|
if /i "%1"=="full-icu" set i18n_arg=%1&goto arg-ok
|
|
if /i "%1"=="intl-none" set i18n_arg=none&goto arg-ok
|
|
if /i "%1"=="without-intl" set i18n_arg=none&goto arg-ok
|
|
if /i "%1"=="download-all" set download_arg="--download=all"&goto arg-ok
|
|
if /i "%1"=="ignore-flaky" set test_args=%test_args% --flaky-tests=dontcare&goto arg-ok
|
|
if /i "%1"=="dll" set dll=1&goto arg-ok
|
|
if /i "%1"=="static" set enable_static=1&goto arg-ok
|
|
if /i "%1"=="no-NODE-OPTIONS" set no_NODE_OPTIONS=1&goto arg-ok
|
|
if /i "%1"=="debug-nghttp2" set debug_nghttp2=1&goto arg-ok
|
|
if /i "%1"=="link-module" set "link_module= --link-module=%2%link_module%"&goto arg-ok-2
|
|
if /i "%1"=="no-cctest" set no_cctest=1&goto arg-ok
|
|
if /i "%1"=="cctest" set cctest=1&goto arg-ok
|
|
if /i "%1"=="openssl-no-asm" set openssl_no_asm=1&goto arg-ok
|
|
if /i "%1"=="doc" set doc=1&goto arg-ok
|
|
if /i "%1"=="binlog" set extra_msbuild_args=/binaryLogger:%config%\node.binlog&goto arg-ok
|
|
|
|
echo Error: invalid command line option `%1`.
|
|
exit /b 1
|
|
|
|
:arg-ok-2
|
|
shift
|
|
:arg-ok
|
|
shift
|
|
goto next-arg
|
|
|
|
:args-done
|
|
|
|
if defined build_release (
|
|
set config=Release
|
|
set package=1
|
|
set msi=1
|
|
set licensertf=1
|
|
set download_arg="--download=all"
|
|
set i18n_arg=full-icu
|
|
set projgen=1
|
|
set cctest=1
|
|
set ltcg=1
|
|
)
|
|
|
|
if defined msi set stage_package=1
|
|
if defined package set stage_package=1
|
|
|
|
:: assign path to node_exe
|
|
set "node_exe=%config%\node.exe"
|
|
set "node_gyp_exe="%node_exe%" deps\npm\node_modules\node-gyp\bin\node-gyp"
|
|
set "npm_exe="%~dp0%node_exe%" %~dp0deps\npm\bin\npm-cli.js"
|
|
if "%target_env%"=="vs2019" set "node_gyp_exe=%node_gyp_exe% --msvs_version=2019"
|
|
if "%target_env%"=="vs2022" set "node_gyp_exe=%node_gyp_exe% --msvs_version=2022"
|
|
|
|
:: skip building if the only argument received was lint
|
|
if "%*"=="lint" if exist "%node_exe%" goto lint-cpp
|
|
|
|
if "%config%"=="Debug" set configure_flags=%configure_flags% --debug
|
|
if defined nosnapshot set configure_flags=%configure_flags% --without-snapshot
|
|
if defined noetw set configure_flags=%configure_flags% --without-etw& set noetw_msi_arg=/p:NoETW=1
|
|
if defined ltcg set configure_flags=%configure_flags% --with-ltcg
|
|
if defined release_urlbase set configure_flags=%configure_flags% --release-urlbase=%release_urlbase%
|
|
if defined download_arg set configure_flags=%configure_flags% %download_arg%
|
|
if defined dll set configure_flags=%configure_flags% --shared
|
|
if defined enable_static set configure_flags=%configure_flags% --enable-static
|
|
if defined no_NODE_OPTIONS set configure_flags=%configure_flags% --without-node-options
|
|
if defined link_module set configure_flags=%configure_flags% %link_module%
|
|
if defined i18n_arg set configure_flags=%configure_flags% --with-intl=%i18n_arg%
|
|
if defined config_flags set configure_flags=%configure_flags% %config_flags%
|
|
if defined target_arch set configure_flags=%configure_flags% --dest-cpu=%target_arch%
|
|
if defined openssl_no_asm set configure_flags=%configure_flags% --openssl-no-asm
|
|
if defined DEBUG_HELPER set configure_flags=%configure_flags% --verbose
|
|
if "%target_arch%"=="x86" if "%PROCESSOR_ARCHITECTURE%"=="AMD64" set configure_flags=%configure_flags% --no-cross-compiling
|
|
if "%target_arch%"=="arm64" set configure_flags=%configure_flags% --cross-compiling
|
|
|
|
if not exist "%~dp0deps\icu" goto no-depsicu
|
|
if "%target%"=="Clean" echo deleting %~dp0deps\icu
|
|
if "%target%"=="Clean" rmdir /S /Q %~dp0deps\icu
|
|
:no-depsicu
|
|
|
|
if "%target%"=="TestClean" (
|
|
echo deleting test/.tmp*
|
|
if exist "test\.tmp*" for /f %%i in ('dir /a:d /s /b test\.tmp*') do rmdir /S /Q "%%i"
|
|
goto exit
|
|
)
|
|
|
|
|
|
call tools\msvs\find_python.cmd
|
|
if errorlevel 1 goto :exit
|
|
|
|
REM NASM is only needed on IA32 and x86_64.
|
|
if not defined openssl_no_asm if "%target_arch%" NEQ "arm64" call tools\msvs\find_nasm.cmd
|
|
if errorlevel 1 echo Could not find NASM, install it or build with openssl-no-asm. See BUILDING.md.
|
|
|
|
call :getnodeversion || exit /b 1
|
|
|
|
if defined TAG set configure_flags=%configure_flags% --tag=%TAG%
|
|
|
|
if not "%target%"=="Clean" goto skip-clean
|
|
rmdir /Q /S "%~dp0%config%\%TARGET_NAME%" > nul 2> nul
|
|
:skip-clean
|
|
|
|
if defined noprojgen if defined nobuild goto :after-build
|
|
|
|
@rem Set environment for msbuild
|
|
|
|
set msvs_host_arch=x86
|
|
if _%PROCESSOR_ARCHITECTURE%_==_AMD64_ set msvs_host_arch=amd64
|
|
if _%PROCESSOR_ARCHITEW6432%_==_AMD64_ set msvs_host_arch=amd64
|
|
@rem usually vcvarsall takes an argument: host + '_' + target
|
|
set vcvarsall_arg=%msvs_host_arch%_%target_arch%
|
|
@rem unless both host and target are x64
|
|
if %target_arch%==x64 if %msvs_host_arch%==amd64 set vcvarsall_arg=amd64
|
|
@rem also if both are x86
|
|
if %target_arch%==x86 if %msvs_host_arch%==x86 set vcvarsall_arg=x86
|
|
|
|
@rem Look for Visual Studio 2022
|
|
:vs-set-2022
|
|
if defined target_env if "%target_env%" NEQ "vs2022" goto vs-set-2019
|
|
echo Looking for Visual Studio 2022
|
|
@rem VCINSTALLDIR may be set if run from a VS Command Prompt and needs to be
|
|
@rem cleared first as vswhere_usability_wrapper.cmd doesn't when it fails to
|
|
@rem detect the version searched for
|
|
if not defined target_env set "VCINSTALLDIR="
|
|
call tools\msvs\vswhere_usability_wrapper.cmd "[17.0,18.0)" "prerelease"
|
|
if "_%VCINSTALLDIR%_" == "__" goto vs-set-2019
|
|
set "WIXSDKDIR=%WIX%\SDK\VS2017"
|
|
if defined msi (
|
|
echo Looking for WiX installation for Visual Studio 2022...
|
|
if not exist "%WIXSDKDIR%" (
|
|
echo Failed to find WiX install for Visual Studio 2022
|
|
echo VS2022 support for WiX is only present starting at version 3.XX
|
|
goto vs-set-2019
|
|
)
|
|
if not exist "%VCINSTALLDIR%\..\MSBuild\Microsoft\WiX" (
|
|
echo Failed to find the WiX Toolset Visual Studio 2022 Extension
|
|
goto vs-set-2019
|
|
)
|
|
)
|
|
@rem check if VS2022 is already setup, and for the requested arch
|
|
if "_%VisualStudioVersion%_" == "_17.0_" if "_%VSCMD_ARG_TGT_ARCH%_"=="_%target_arch%_" goto found_vs2022
|
|
@rem need to clear VSINSTALLDIR for vcvarsall to work as expected
|
|
set "VSINSTALLDIR="
|
|
@rem prevent VsDevCmd.bat from changing the current working directory
|
|
set "VSCMD_START_DIR=%CD%"
|
|
set vcvars_call="%VCINSTALLDIR%\Auxiliary\Build\vcvarsall.bat" %vcvarsall_arg%
|
|
echo calling: %vcvars_call%
|
|
call %vcvars_call%
|
|
if errorlevel 1 goto vs-set-2019
|
|
if defined DEBUG_HELPER @ECHO ON
|
|
:found_vs2022
|
|
echo Found MSVS version %VisualStudioVersion%
|
|
set GYP_MSVS_VERSION=2022
|
|
set PLATFORM_TOOLSET=v143
|
|
goto msbuild-found
|
|
|
|
@rem Look for Visual Studio 2019
|
|
:vs-set-2019
|
|
if defined target_env if "%target_env%" NEQ "vs2019" goto msbuild-not-found
|
|
echo Looking for Visual Studio 2019
|
|
@rem VCINSTALLDIR may be set if run from a VS Command Prompt and needs to be
|
|
@rem cleared first as vswhere_usability_wrapper.cmd doesn't when it fails to
|
|
@rem detect the version searched for
|
|
if not defined target_env set "VCINSTALLDIR="
|
|
call tools\msvs\vswhere_usability_wrapper.cmd "[16.0,17.0)" "prerelease"
|
|
if "_%VCINSTALLDIR%_" == "__" goto msbuild-not-found
|
|
set "WIXSDKDIR=%WIX%\SDK\VS2017"
|
|
if defined msi (
|
|
echo Looking for WiX installation for Visual Studio 2019...
|
|
if not exist "%WIXSDKDIR%" (
|
|
echo Failed to find WiX install for Visual Studio 2019
|
|
echo VS2019 support for WiX is only present starting at version 3.11
|
|
goto msbuild-not-found
|
|
)
|
|
if not exist "%VCINSTALLDIR%\..\MSBuild\Microsoft\WiX" (
|
|
echo Failed to find the WiX Toolset Visual Studio 2019 Extension
|
|
goto msbuild-not-found
|
|
)
|
|
)
|
|
@rem check if VS2019 is already setup, and for the requested arch
|
|
if "_%VisualStudioVersion%_" == "_16.0_" if "_%VSCMD_ARG_TGT_ARCH%_"=="_%target_arch%_" goto found_vs2019
|
|
@rem need to clear VSINSTALLDIR for vcvarsall to work as expected
|
|
set "VSINSTALLDIR="
|
|
@rem prevent VsDevCmd.bat from changing the current working directory
|
|
set "VSCMD_START_DIR=%CD%"
|
|
set vcvars_call="%VCINSTALLDIR%\Auxiliary\Build\vcvarsall.bat" %vcvarsall_arg%
|
|
echo calling: %vcvars_call%
|
|
call %vcvars_call%
|
|
if errorlevel 1 goto msbuild-not-found
|
|
if defined DEBUG_HELPER @ECHO ON
|
|
:found_vs2019
|
|
echo Found MSVS version %VisualStudioVersion%
|
|
set GYP_MSVS_VERSION=2019
|
|
set PLATFORM_TOOLSET=v142
|
|
goto msbuild-found
|
|
|
|
:msbuild-not-found
|
|
echo Failed to find a suitable Visual Studio installation.
|
|
echo Try to run in a "Developer Command Prompt" or consult
|
|
echo https://github.com/nodejs/node/blob/HEAD/BUILDING.md#windows
|
|
goto exit
|
|
|
|
:msbuild-found
|
|
|
|
set project_generated=
|
|
:project-gen
|
|
@rem Skip project generation if requested.
|
|
if defined noprojgen goto msbuild
|
|
if defined projgen goto run-configure
|
|
if not exist node.sln goto run-configure
|
|
if not exist .gyp_configure_stamp goto run-configure
|
|
echo %configure_flags% > .tmp_gyp_configure_stamp
|
|
where /R . /T *.gyp* >> .tmp_gyp_configure_stamp
|
|
fc .gyp_configure_stamp .tmp_gyp_configure_stamp >NUL 2>&1
|
|
if errorlevel 1 goto run-configure
|
|
|
|
:skip-configure
|
|
del .tmp_gyp_configure_stamp 2> NUL
|
|
echo Reusing solution generated with %configure_flags%
|
|
goto msbuild
|
|
|
|
:run-configure
|
|
del .tmp_gyp_configure_stamp 2> NUL
|
|
del .gyp_configure_stamp 2> NUL
|
|
@rem Generate the VS project.
|
|
echo configure %configure_flags%
|
|
echo %configure_flags%> .used_configure_flags
|
|
python configure %configure_flags%
|
|
if errorlevel 1 goto create-msvs-files-failed
|
|
if not exist node.sln goto create-msvs-files-failed
|
|
set project_generated=1
|
|
echo Project files generated.
|
|
echo %configure_flags% > .gyp_configure_stamp
|
|
where /R . /T *.gyp* >> .gyp_configure_stamp
|
|
|
|
:msbuild
|
|
@rem Skip build if requested.
|
|
if defined nobuild goto :after-build
|
|
|
|
@rem Build the sln with msbuild.
|
|
set "msbcpu=/m:2"
|
|
if "%NUMBER_OF_PROCESSORS%"=="1" set "msbcpu=/m:1"
|
|
set "msbplatform=Win32"
|
|
if "%target_arch%"=="x64" set "msbplatform=x64"
|
|
if "%target_arch%"=="arm64" set "msbplatform=ARM64"
|
|
if "%target%"=="Build" (
|
|
if defined no_cctest set target=node
|
|
if "%test_args%"=="" set target=node
|
|
if defined cctest set target="Build"
|
|
)
|
|
if "%target%"=="node" if exist "%config%\cctest.exe" del "%config%\cctest.exe"
|
|
if defined msbuild_args set "extra_msbuild_args=%extra_msbuild_args% %msbuild_args%"
|
|
@rem Setup env variables to use multiprocessor build
|
|
set UseMultiToolTask=True
|
|
set EnforceProcessCountAcrossBuilds=True
|
|
set MultiProcMaxCount=%NUMBER_OF_PROCESSORS%
|
|
msbuild node.sln %msbcpu% /t:%target% /p:Configuration=%config% /p:Platform=%msbplatform% /clp:NoItemAndPropertyList;Verbosity=minimal /nologo %extra_msbuild_args%
|
|
if errorlevel 1 (
|
|
if not defined project_generated echo Building Node with reused solution failed. To regenerate project files use "vcbuild projgen"
|
|
exit /B 1
|
|
)
|
|
if "%target%" == "Clean" goto exit
|
|
|
|
:after-build
|
|
rd %config%
|
|
if errorlevel 1 echo "Old build output exists at 'out\%config%'. Please remove." & exit /B
|
|
:: Use /J because /D (symlink) requires special permissions.
|
|
if EXIST out\%config% mklink /J %config% out\%config%
|
|
if errorlevel 1 echo "Could not create junction to 'out\%config%'." & exit /B
|
|
|
|
:sign
|
|
@rem Skip signing unless the `sign` option was specified.
|
|
if not defined sign goto licensertf
|
|
|
|
call tools\sign.bat Release\node.exe
|
|
if errorlevel 1 echo Failed to sign exe&goto exit
|
|
|
|
:licensertf
|
|
@rem Skip license.rtf generation if not requested.
|
|
if not defined licensertf goto stage_package
|
|
|
|
set "use_x64_node_exe=false"
|
|
if "%target_arch%"=="arm64" if "%PROCESSOR_ARCHITECTURE%"=="AMD64" set "use_x64_node_exe=true"
|
|
if "%use_x64_node_exe%"=="true" (
|
|
echo Cross-compilation to ARM64 detected. We'll use the x64 Node executable for license2rtf.
|
|
if not defined "%x64_node_exe%" set "x64_node_exe=temp-vcbuild\node-x64-cross-compiling.exe"
|
|
if not exist "%x64_node_exe%" (
|
|
echo Downloading x64 node.exe...
|
|
if not exist "temp-vcbuild" mkdir temp-vcbuild
|
|
powershell -c "Invoke-WebRequest -Uri 'https://nodejs.org/dist/latest/win-x64/node.exe' -OutFile 'temp-vcbuild\node-x64-cross-compiling.exe'"
|
|
)
|
|
if not exist "%x64_node_exe%" (
|
|
echo Could not find the Node executable at the given x64_node_exe path. Aborting.
|
|
set exit_code=1
|
|
goto exit
|
|
)
|
|
%x64_node_exe% tools\license2rtf.js < LICENSE > %config%\license.rtf
|
|
) else (
|
|
%node_exe% tools\license2rtf.js < LICENSE > %config%\license.rtf
|
|
)
|
|
|
|
if errorlevel 1 echo Failed to generate license.rtf&goto exit
|
|
|
|
:stage_package
|
|
if not defined stage_package goto install-doctools
|
|
|
|
echo Creating package...
|
|
cd Release
|
|
rmdir /S /Q %TARGET_NAME% > nul 2> nul
|
|
mkdir %TARGET_NAME% > nul 2> nul
|
|
mkdir %TARGET_NAME%\node_modules > nul 2>nul
|
|
|
|
copy /Y node.exe %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy node.exe && goto package_error
|
|
copy /Y ..\LICENSE %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy LICENSE && goto package_error
|
|
copy /Y ..\README.md %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy README.md && goto package_error
|
|
copy /Y ..\CHANGELOG.md %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy CHANGELOG.md && goto package_error
|
|
robocopy ..\deps\npm %TARGET_NAME%\node_modules\npm /e /xd test > nul
|
|
if errorlevel 8 echo Cannot copy npm package && goto package_error
|
|
robocopy ..\deps\corepack %TARGET_NAME%\node_modules\corepack /e /xd test > nul
|
|
if errorlevel 8 echo Cannot copy corepack package && goto package_error
|
|
copy /Y ..\deps\npm\bin\npm %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy npm && goto package_error
|
|
copy /Y ..\deps\npm\bin\npm.cmd %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy npm.cmd && goto package_error
|
|
copy /Y ..\deps\npm\bin\npx %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy npx && goto package_error
|
|
copy /Y ..\deps\npm\bin\npx.cmd %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy npx.cmd && goto package_error
|
|
copy /Y ..\deps\corepack\shims\nodewin\corepack %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy corepack && goto package_error
|
|
copy /Y ..\deps\corepack\shims\nodewin\corepack.cmd %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy corepack.cmd && goto package_error
|
|
copy /Y ..\tools\msvs\nodevars.bat %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy nodevars.bat && goto package_error
|
|
copy /Y ..\tools\msvs\install_tools\*.* %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy install_tools scripts && goto package_error
|
|
if not defined noetw (
|
|
copy /Y ..\src\res\node_etw_provider.man %TARGET_NAME%\ > nul
|
|
if errorlevel 1 echo Cannot copy node_etw_provider.man && goto package_error
|
|
)
|
|
cd ..
|
|
|
|
:package
|
|
if not defined package goto msi
|
|
cd Release
|
|
echo Creating %TARGET_NAME%.7z
|
|
del %TARGET_NAME%.7z > nul 2> nul
|
|
7z a -r -mx9 -t7z %TARGET_NAME%.7z %TARGET_NAME% > nul
|
|
if errorlevel 1 echo Cannot create %TARGET_NAME%.7z && goto package_error
|
|
|
|
echo Creating %TARGET_NAME%.zip
|
|
del %TARGET_NAME%.zip > nul 2> nul
|
|
7z a -r -mx9 -tzip %TARGET_NAME%.zip %TARGET_NAME% > nul
|
|
if errorlevel 1 echo Cannot create %TARGET_NAME%.zip && goto package_error
|
|
|
|
echo Creating node_pdb.7z
|
|
del node_pdb.7z > nul 2> nul
|
|
7z a -mx9 -t7z node_pdb.7z node.pdb > nul
|
|
|
|
echo Creating node_pdb.zip
|
|
del node_pdb.zip > nul 2> nul
|
|
7z a -mx9 -tzip node_pdb.zip node.pdb > nul
|
|
|
|
cd ..
|
|
echo Package created!
|
|
goto package_done
|
|
:package_error
|
|
cd ..
|
|
exit /b 1
|
|
:package_done
|
|
|
|
:msi
|
|
@rem Skip msi generation if not requested
|
|
if not defined msi goto install-doctools
|
|
|
|
:msibuild
|
|
echo Building node-v%FULLVERSION%-%target_arch%.msi
|
|
set "msbsdk="
|
|
if defined WindowsSDKVersion set "msbsdk=/p:WindowsTargetPlatformVersion=%WindowsSDKVersion:~0,-1%"
|
|
msbuild "%~dp0tools\msvs\msi\nodemsi.sln" /m /t:Clean,Build %msbsdk% /p:PlatformToolset=%PLATFORM_TOOLSET% /p:WixSdkDir="%WIXSDKDIR%" /p:Configuration=%config% /p:Platform=%target_arch% /p:NodeVersion=%NODE_VERSION% /p:FullVersion=%FULLVERSION% /p:DistTypeDir=%DISTTYPEDIR% %noetw_msi_arg% /clp:NoSummary;NoItemAndPropertyList;Verbosity=minimal /nologo
|
|
if errorlevel 1 goto exit
|
|
|
|
if not defined sign goto upload
|
|
call tools\sign.bat node-v%FULLVERSION%-%target_arch%.msi
|
|
if errorlevel 1 echo Failed to sign msi&goto exit
|
|
|
|
:upload
|
|
@rem Skip upload if not requested
|
|
if not defined upload goto install-doctools
|
|
|
|
if not defined SSHCONFIG (
|
|
echo SSHCONFIG is not set for upload
|
|
exit /b 1
|
|
)
|
|
|
|
if not defined STAGINGSERVER set STAGINGSERVER=node-www
|
|
ssh -F %SSHCONFIG% %STAGINGSERVER% "mkdir -p nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%"
|
|
if errorlevel 1 goto exit
|
|
scp -F %SSHCONFIG% Release\node.exe %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node.exe
|
|
if errorlevel 1 goto exit
|
|
scp -F %SSHCONFIG% Release\node.lib %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node.lib
|
|
if errorlevel 1 goto exit
|
|
scp -F %SSHCONFIG% Release\node_pdb.zip %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node_pdb.zip
|
|
if errorlevel 1 goto exit
|
|
scp -F %SSHCONFIG% Release\node_pdb.7z %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node_pdb.7z
|
|
if errorlevel 1 goto exit
|
|
scp -F %SSHCONFIG% Release\%TARGET_NAME%.7z %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/%TARGET_NAME%.7z
|
|
if errorlevel 1 goto exit
|
|
scp -F %SSHCONFIG% Release\%TARGET_NAME%.zip %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/%TARGET_NAME%.zip
|
|
if errorlevel 1 goto exit
|
|
scp -F %SSHCONFIG% node-v%FULLVERSION%-%target_arch%.msi %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/
|
|
if errorlevel 1 goto exit
|
|
ssh -F %SSHCONFIG% %STAGINGSERVER% "touch nodejs/%DISTTYPEDIR%/v%FULLVERSION%/node-v%FULLVERSION%-%target_arch%.msi.done nodejs/%DISTTYPEDIR%/v%FULLVERSION%/%TARGET_NAME%.zip.done nodejs/%DISTTYPEDIR%/v%FULLVERSION%/%TARGET_NAME%.7z.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%.* nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%*"
|
|
if errorlevel 1 goto exit
|
|
|
|
|
|
:install-doctools
|
|
REM only install if building doc OR testing doctool OR building addons
|
|
if not defined doc if not defined build_addons (
|
|
echo.%test_args% | findstr doctool 1>nul
|
|
if errorlevel 1 goto :skip-install-doctools
|
|
)
|
|
if exist "tools\doc\node_modules\unified\package.json" goto skip-install-doctools
|
|
SETLOCAL
|
|
cd tools\doc
|
|
%npm_exe% ci
|
|
cd ..\..
|
|
if errorlevel 1 goto exit
|
|
ENDLOCAL
|
|
:skip-install-doctools
|
|
@rem Clear errorlevel from echo.%test_args% | findstr doctool 1>nul
|
|
cd .
|
|
|
|
:build-doc
|
|
@rem Build documentation if requested
|
|
if not defined doc goto run
|
|
if not exist %node_exe% (
|
|
echo Failed to find node.exe
|
|
goto run
|
|
)
|
|
mkdir %config%\doc
|
|
robocopy /e doc\api %config%\doc\api
|
|
robocopy /e doc\api_assets %config%\doc\api\assets
|
|
|
|
for %%F in (%config%\doc\api\*.md) do (
|
|
%node_exe% tools\doc\generate.mjs --node-version=v%FULLVERSION% %%F --output-directory=%%~dF%%~pF
|
|
)
|
|
|
|
:run
|
|
@rem Run tests if requested.
|
|
|
|
if not defined build_addons goto build-js-native-api-tests
|
|
if not exist "%node_exe%" (
|
|
echo Failed to find node.exe
|
|
goto build-js-native-api-tests
|
|
)
|
|
echo Building addons
|
|
:: clear
|
|
for /d %%F in (test\addons\??_*) do (
|
|
rd /s /q %%F
|
|
)
|
|
:: generate
|
|
"%node_exe%" tools\doc\addon-verify.mjs
|
|
if %errorlevel% neq 0 exit /b %errorlevel%
|
|
:: building addons
|
|
setlocal
|
|
set npm_config_nodedir=%~dp0
|
|
"%node_exe%" "%~dp0tools\build-addons.js" "%~dp0deps\npm\node_modules\node-gyp\bin\node-gyp.js" "%~dp0test\addons"
|
|
if errorlevel 1 exit /b 1
|
|
endlocal
|
|
|
|
:build-js-native-api-tests
|
|
if not defined build_js_native_api_tests goto build-node-api-tests
|
|
if not exist "%node_exe%" (
|
|
echo Failed to find node.exe
|
|
goto build-node-api-tests
|
|
)
|
|
echo Building js-native-api
|
|
:: clear
|
|
for /d %%F in (test\js-native-api\??_*) do (
|
|
rd /s /q %%F
|
|
)
|
|
:: building js-native-api
|
|
setlocal
|
|
set npm_config_nodedir=%~dp0
|
|
"%node_exe%" "%~dp0tools\build-addons.js" "%~dp0deps\npm\node_modules\node-gyp\bin\node-gyp.js" "%~dp0test\js-native-api"
|
|
if errorlevel 1 exit /b 1
|
|
endlocal
|
|
goto build-node-api-tests
|
|
|
|
:build-node-api-tests
|
|
if not defined build_node_api_tests goto run-tests
|
|
if not exist "%node_exe%" (
|
|
echo Failed to find node.exe
|
|
goto run-tests
|
|
)
|
|
echo Building node-api
|
|
:: clear
|
|
for /d %%F in (test\node-api\??_*) do (
|
|
rd /s /q %%F
|
|
)
|
|
:: building node-api
|
|
setlocal
|
|
set npm_config_nodedir=%~dp0
|
|
"%node_exe%" "%~dp0tools\build-addons.js" "%~dp0deps\npm\node_modules\node-gyp\bin\node-gyp.js" "%~dp0test\node-api"
|
|
if errorlevel 1 exit /b 1
|
|
endlocal
|
|
goto run-tests
|
|
|
|
:run-tests
|
|
if defined test_check_deopts goto node-check-deopts
|
|
if defined test_node_inspect goto node-test-inspect
|
|
goto node-tests
|
|
|
|
:node-check-deopts
|
|
python tools\test.py --mode=release --check-deopts parallel sequential
|
|
if defined test_node_inspect goto node-test-inspect
|
|
goto node-tests
|
|
|
|
:node-test-inspect
|
|
set USE_EMBEDDED_NODE_INSPECT=1
|
|
%node_exe% tools\test-npm-package.js --install deps\node-inspect test
|
|
goto node-tests
|
|
|
|
:node-tests
|
|
if not defined test_npm goto no-test-npm
|
|
set npm_test_cmd="%node_exe%" tools\test-npm-package.js --install --logfile=test-npm.tap deps\npm test-node
|
|
echo %npm_test_cmd%
|
|
%npm_test_cmd%
|
|
if errorlevel 1 goto exit
|
|
:no-test-npm
|
|
|
|
if "%test_args%"=="" goto test-v8
|
|
if "%config%"=="Debug" set test_args=--mode=debug %test_args%
|
|
if "%config%"=="Release" set test_args=--mode=release %test_args%
|
|
if defined no_cctest echo Skipping cctest because no-cctest was specified && goto run-test-py
|
|
if not exist "%config%\cctest.exe" echo cctest.exe not found. Run "vcbuild test" or "vcbuild cctest" to build it. && goto run-test-py
|
|
echo running 'cctest %cctest_args%'
|
|
"%config%\cctest" %cctest_args%
|
|
if %errorlevel% neq 0 set exit_code=%errorlevel%
|
|
:run-test-py
|
|
echo running 'python tools\test.py %test_args%'
|
|
python tools\test.py %test_args%
|
|
if %errorlevel% neq 0 set exit_code=%errorlevel%
|
|
goto test-v8
|
|
|
|
:test-v8
|
|
if not defined custom_v8_test goto lint-cpp
|
|
call tools/test-v8.bat
|
|
if errorlevel 1 goto exit
|
|
goto lint-cpp
|
|
|
|
:lint-cpp
|
|
if not defined lint_cpp goto lint-js
|
|
if defined NODEJS_MAKE goto run-make-lint
|
|
where make > NUL 2>&1 && make -v | findstr /C:"GNU Make" 1> NUL
|
|
if "%ERRORLEVEL%"=="0" set "NODEJS_MAKE=make PYTHON=python" & goto run-make-lint
|
|
where wsl > NUL 2>&1
|
|
if "%ERRORLEVEL%"=="0" set "NODEJS_MAKE=wsl make" & goto run-make-lint
|
|
echo Could not find GNU Make, needed for linting C/C++
|
|
goto lint-js
|
|
|
|
:run-make-lint
|
|
%NODEJS_MAKE% lint-cpp
|
|
goto lint-js
|
|
|
|
:lint-js
|
|
if not defined lint_js goto lint-md-build
|
|
if not exist tools\node_modules\eslint goto no-lint
|
|
echo running lint-js
|
|
%node_exe% tools\node_modules\eslint\bin\eslint.js --cache --max-warnings=0 --report-unused-disable-directives --rule "linebreak-style: 0" .eslintrc.js benchmark doc lib test tools
|
|
goto lint-md-build
|
|
|
|
:no-lint
|
|
echo Linting is not available through the source tarball.
|
|
echo Use the git repo instead: $ git clone https://github.com/nodejs/node.git
|
|
goto lint-md-build
|
|
|
|
:lint-md-build
|
|
if not defined lint_md_build goto lint-md
|
|
echo "Deprecated no-op target 'lint_md_build'"
|
|
goto lint-md
|
|
|
|
:lint-md
|
|
if not defined lint_md goto exit
|
|
echo Running Markdown linter on docs...
|
|
SETLOCAL ENABLEDELAYEDEXPANSION
|
|
set lint_md_files=
|
|
for /D %%D IN (doc\*) do (
|
|
for %%F IN (%%D\*.md) do (
|
|
set "lint_md_files="%%F" !lint_md_files!"
|
|
)
|
|
)
|
|
%node_exe% tools\lint-md\lint-md.mjs %lint_md_files%
|
|
ENDLOCAL
|
|
goto exit
|
|
|
|
:format-md
|
|
if not defined lint_md goto exit
|
|
echo Running Markdown formatter on docs...
|
|
SETLOCAL ENABLEDELAYEDEXPANSION
|
|
set lint_md_files=
|
|
for /D %%D IN (doc\*) do (
|
|
for %%F IN (%%D\*.md) do (
|
|
set "lint_md_files="%%F" !lint_md_files!"
|
|
)
|
|
)
|
|
%node_exe% tools\lint-md\lint-md.mjs --format %lint_md_files%
|
|
ENDLOCAL
|
|
goto exit
|
|
|
|
:create-msvs-files-failed
|
|
echo Failed to create vc project files.
|
|
del .used_configure_flags
|
|
set exit_code=1
|
|
goto exit
|
|
|
|
:help
|
|
echo vcbuild.bat [debug/release] [msi] [doc] [test/test-all/test-addons/test-doc/test-js-native-api/test-node-api/test-benchmark/test-internet/test-pummel/test-simple/test-message/test-tick-processor/test-known-issues/test-node-inspect/test-check-deopts/test-npm/test-async-hooks/test-v8/test-v8-intl/test-v8-benchmarks/test-v8-all] [ignore-flaky] [static/dll] [noprojgen] [projgen] [small-icu/full-icu/without-intl] [nobuild] [nosnapshot] [noetw] [ltcg] [licensetf] [sign] [ia32/x86/x64/arm64] [vs2019/vs2022] [download-all] [lint/lint-ci/lint-js/lint-md] [lint-md-build] [package] [build-release] [upload] [no-NODE-OPTIONS] [link-module path-to-module] [debug-http2] [debug-nghttp2] [clean] [cctest] [no-cctest] [openssl-no-asm]
|
|
echo Examples:
|
|
echo vcbuild.bat : builds release build
|
|
echo vcbuild.bat debug : builds debug build
|
|
echo vcbuild.bat release msi : builds release build and MSI installer package
|
|
echo vcbuild.bat test : builds debug build and runs tests
|
|
echo vcbuild.bat build-release : builds the release distribution as used by nodejs.org
|
|
echo vcbuild.bat link-module my_module.js : bundles my_module as built-in module
|
|
echo vcbuild.bat lint : runs the C++, documentation and JavaScript linter
|
|
echo vcbuild.bat no-cctest : skip building cctest.exe
|
|
goto exit
|
|
|
|
:exit
|
|
if %errorlevel% neq 0 exit /b %errorlevel%
|
|
exit /b %exit_code%
|
|
|
|
|
|
rem ***************
|
|
rem Subroutines
|
|
rem ***************
|
|
|
|
:getnodeversion
|
|
set NODE_VERSION=
|
|
set TAG=
|
|
set FULLVERSION=
|
|
|
|
for /F "usebackq tokens=*" %%i in (`python "%~dp0tools\getnodeversion.py"`) do set NODE_VERSION=%%i
|
|
if not defined NODE_VERSION (
|
|
echo Cannot determine current version of Node.js
|
|
exit /b 1
|
|
)
|
|
|
|
if not defined DISTTYPE set DISTTYPE=release
|
|
if "%DISTTYPE%"=="release" (
|
|
set FULLVERSION=%NODE_VERSION%
|
|
goto distexit
|
|
)
|
|
if "%DISTTYPE%"=="custom" (
|
|
if not defined CUSTOMTAG (
|
|
echo "CUSTOMTAG is not set for DISTTYPE=custom"
|
|
exit /b 1
|
|
)
|
|
set TAG=%CUSTOMTAG%
|
|
)
|
|
if not "%DISTTYPE%"=="custom" (
|
|
if not defined DATESTRING (
|
|
echo "DATESTRING is not set for nightly"
|
|
exit /b 1
|
|
)
|
|
if not defined COMMIT (
|
|
echo "COMMIT is not set for nightly"
|
|
exit /b 1
|
|
)
|
|
if not "%DISTTYPE%"=="nightly" (
|
|
if not "%DISTTYPE%"=="next-nightly" (
|
|
echo "DISTTYPE is not release, custom, nightly or next-nightly"
|
|
exit /b 1
|
|
)
|
|
)
|
|
set TAG=%DISTTYPE%%DATESTRING%%COMMIT%
|
|
)
|
|
set FULLVERSION=%NODE_VERSION%-%TAG%
|
|
|
|
:distexit
|
|
if not defined DISTTYPEDIR set DISTTYPEDIR=%DISTTYPE%
|
|
set TARGET_NAME=node-v%FULLVERSION%-win-%target_arch%
|
|
goto :EOF
|