|
|
|
@echo off
|
|
|
|
|
|
|
|
cd %~dp0
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
@rem Process arguments.
|
|
|
|
set config=Release
|
|
|
|
set target=Build
|
|
|
|
set target_arch=x64
|
|
|
|
set target_env=
|
|
|
|
set noprojgen=
|
|
|
|
set nobuild=
|
|
|
|
set sign=
|
|
|
|
set nosnapshot=
|
|
|
|
set cctest_args=
|
|
|
|
set test_args=
|
|
|
|
set package=
|
|
|
|
set msi=
|
|
|
|
set upload=
|
|
|
|
set licensertf=
|
|
|
|
set jslint=
|
|
|
|
set cpplint=
|
|
|
|
set build_testgc_addon=
|
|
|
|
set noetw=
|
|
|
|
set noetw_msi_arg=
|
|
|
|
set noperfctr=
|
|
|
|
set noperfctr_msi_arg=
|
build, i18n: improve Intl build, add "--with-intl"
The two main goals of this change are:
- To make it easier to build the Intl option using ICU (particularly,
using a newer ICU than v8/Chromium's version)
- To enable a much smaller ICU build with only English support The goal
here is to get node.js binaries built this way by default so that the
Intl API can be used. Additional data can be added at execution time
(see Readme and wiki)
More details are at https://github.com/joyent/node/pull/7719
In particular, this change adds the "--with-intl=" configure option to
provide more ways of building "Intl":
- "full-icu" picks up an ICU from deps/icu
- "small-icu" is similar, but builds only English
- "system-icu" uses pkg-config to find an installed ICU
- "none" does nothing (no Intl)
For Windows builds, the "full-icu" or "small-icu" options are added to
vcbuild.bat.
Note that the existing "--with-icu-path" option is not removed from
configure, but may not be used alongside the new option.
Wiki changes have already been made on
https://github.com/joyent/node/wiki/Installation
and a new page created at
https://github.com/joyent/node/wiki/Intl
(marked as provisional until this change lands.)
Summary of changes:
* README.md : doc updates
* .gitignore : added "deps/icu" as this is the location where ICU is
unpacked to.
* Makefile : added the tools/icu/* files to cpplint, but excluded a
problematic file.
* configure : added the "--with-intl" option mentioned above.
Calculate at config time the list of ICU source files to use and data
packaging options.
* node.gyp : add the new files src/node_i18n.cc/.h as well as ICU
linkage.
* src/node.cc : add call into
node::i18n::InitializeICUDirectory(icu_data_dir) as well as new
--icu-data-dir option and NODE_ICU_DATA env variable to configure ICU
data loading. This loading is only relevant in the "small"
configuration.
* src/node_i18n.cc : new source file for the above Initialize..
function, to setup ICU as needed.
* tools/icu : new directory with some tools needed for this build.
* tools/icu/icu-generic.gyp : new .gyp file that builds ICU in some new
ways, both on unix/mac and windows.
* tools/icu/icu-system.gyp : new .gyp file to build node against a
pkg-config detected ICU.
* tools/icu/icu_small.json : new config file for the "English-only" small
build.
* tools/icu/icutrim.py : new tool for trimming down ICU data. Reads the
above .json file.
* tools/icu/iculslocs.cc : new tool for repairing ICU data manifests
after trim operation.
* tools/icu/no-op.cc : dummy file to force .gyp into using a C++ linker.
* vcbuild.bat : added small-icu and full-icu options, to call into
configure.
* Fixed toolset dependencies, see
https://github.com/joyent/node/pull/7719#issuecomment-54641687
Note that because of a bug in gyp {CC,CXX}_host must also be set.
Otherwise gcc/g++ will be used by default for part of the build.
Reviewed-by: Trevor Norris <trev.norris@gmail.com>
Reviewed-by: Fedor Indutny <fedor@indutny.com>
11 years ago
|
|
|
set i18n_arg=
|
build: i18n: add icu config options
Make "--with-intl=none" the default and add "intl-none" option to
vcbuild.bat.
If icu data is missing print a warning unless either --download=all or
--download=icu is set. If set then automatically download, verify (MD5)
and unpack the ICU data if not already available.
There's a "list" of URLs being used, but right now only the first is
picked up. The logic works something like this:
* If there is no directory deps/icu,
* If no zip file (currently icu4c-54_1-src.zip),
* Download zip file (icu-project.org -> sf.net)
* Verify the MD5 sum of the zipfile
* If bad, print error and exit
* Unpack the zipfile into deps/icu
* If deps/icu now exists, use it, else fail with help text
Add the configuration option "--with-icu-source=..."
Usage:
* --with-icu-source=/path/to/my/other/icu
* --with-icu-source=/path/to/icu54.zip
* --with-icu-source=/path/to/icu54.tgz
* --with-icu-source=http://example.com/icu54.tar.bz2
Add the configuration option "--with-icu-locals=...". Allows choosing
which locales are used in the "small-icu" case.
Example:
configure --with-intl=small-icu --with-icu-locales=tlh,grc,nl
(Also note that as of this writing, neither Klingon nor Ancient Greek
are in upstream CLDR data. Serving suggestion only.)
Don't use hard coded ../../out paths on windows. This was suggested by
@misterdjules as it causes test failures. With this fix, "out" is no
longer created on windows and the following can run properly:
python tools/test.py simple
Reduce space by about 1MB with ICU 54 (over without this patch). Also
trims a few other source files, but only conditional on the exact ICU
version used. This is to future-proof - a file that is unneeded now may
be needed in future ICUs.
Also:
* Update distclean to remove icu related files
* Refactor some code into tools/configure.d/nodedownload.py
* Update docs
* Add test
PR-URL: https://github.com/joyent/node/pull/8719
Fixes: https://github.com/joyent/node/issues/7676#issuecomment-64704230
[trev.norris@gmail.com small change to test's whitespace and logic]
Signed-off-by: Trevor Norris <trev.norris@gmail.com>
10 years ago
|
|
|
set download_arg=
|
|
|
|
set build_release=
|
|
|
|
set enable_vtune_arg=
|
|
|
|
set configure_flags=
|
|
|
|
set build_addons=
|
|
|
|
set dll=
|
|
|
|
set build_addons_napi=
|
|
|
|
set test_node_inspect=
|
|
|
|
|
|
|
|
:next-arg
|
|
|
|
if "%1"=="" goto args-done
|
|
|
|
if /i "%1"=="debug" set config=Debug&goto arg-ok
|
|
|
|
if /i "%1"=="release" set config=Release&goto arg-ok
|
|
|
|
if /i "%1"=="clean" set target=Clean&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"=="vc2015" set target_env=vc2015&goto arg-ok
|
|
|
|
if /i "%1"=="noprojgen" set noprojgen=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"=="noperfctr" set noperfctr=1&goto arg-ok
|
|
|
|
if /i "%1"=="licensertf" set licensertf=1&goto arg-ok
|
|
|
|
if /i "%1"=="test" set test_args=%test_args% doctool known_issues message parallel sequential addons addons-napi -J&set cpplint=1&set jslint=1&set build_addons=1&set build_addons_napi=1&goto arg-ok
|
|
|
|
if /i "%1"=="test-ci" set test_args=%test_args% %test_ci_args% -p tap --logfile test.tap doctool inspector known_issues message sequential parallel addons addons-napi&set cctest_args=%cctest_args% --gtest_output=tap:cctest.tap&set build_addons=1&set build_addons_napi=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-addons-napi" set test_args=%test_args% addons-napi&set build_addons_napi=1&goto arg-ok
|
|
|
|
if /i "%1"=="test-simple" set test_args=%test_args% sequential parallel -J&goto arg-ok
|
|
|
|
if /i "%1"=="test-message" set test_args=%test_args% message&goto arg-ok
|
|
|
|
if /i "%1"=="test-gc" set test_args=%test_args% gc&set build_testgc_addon=1&goto arg-ok
|
|
|
|
if /i "%1"=="test-inspector" set test_args=%test_args% inspector&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-all" set test_args=%test_args% sequential parallel message gc inspector internet pummel&set build_testgc_addon=1&set cpplint=1&set jslint=1&goto arg-ok
|
|
|
|
if /i "%1"=="test-known-issues" set test_args=%test_args% known_issues&goto arg-ok
|
|
|
|
if /i "%1"=="test-node-inspect" set test_node_inspect=1&goto arg-ok
|
|
|
|
if /i "%1"=="jslint" set jslint=1&goto arg-ok
|
|
|
|
if /i "%1"=="jslint-ci" set jslint_ci=1&goto arg-ok
|
|
|
|
if /i "%1"=="lint" set cpplint=1&set jslint=1&goto arg-ok
|
|
|
|
if /i "%1"=="lint-ci" set cpplint=1&set jslint_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=small-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
|
build, i18n: improve Intl build, add "--with-intl"
The two main goals of this change are:
- To make it easier to build the Intl option using ICU (particularly,
using a newer ICU than v8/Chromium's version)
- To enable a much smaller ICU build with only English support The goal
here is to get node.js binaries built this way by default so that the
Intl API can be used. Additional data can be added at execution time
(see Readme and wiki)
More details are at https://github.com/joyent/node/pull/7719
In particular, this change adds the "--with-intl=" configure option to
provide more ways of building "Intl":
- "full-icu" picks up an ICU from deps/icu
- "small-icu" is similar, but builds only English
- "system-icu" uses pkg-config to find an installed ICU
- "none" does nothing (no Intl)
For Windows builds, the "full-icu" or "small-icu" options are added to
vcbuild.bat.
Note that the existing "--with-icu-path" option is not removed from
configure, but may not be used alongside the new option.
Wiki changes have already been made on
https://github.com/joyent/node/wiki/Installation
and a new page created at
https://github.com/joyent/node/wiki/Intl
(marked as provisional until this change lands.)
Summary of changes:
* README.md : doc updates
* .gitignore : added "deps/icu" as this is the location where ICU is
unpacked to.
* Makefile : added the tools/icu/* files to cpplint, but excluded a
problematic file.
* configure : added the "--with-intl" option mentioned above.
Calculate at config time the list of ICU source files to use and data
packaging options.
* node.gyp : add the new files src/node_i18n.cc/.h as well as ICU
linkage.
* src/node.cc : add call into
node::i18n::InitializeICUDirectory(icu_data_dir) as well as new
--icu-data-dir option and NODE_ICU_DATA env variable to configure ICU
data loading. This loading is only relevant in the "small"
configuration.
* src/node_i18n.cc : new source file for the above Initialize..
function, to setup ICU as needed.
* tools/icu : new directory with some tools needed for this build.
* tools/icu/icu-generic.gyp : new .gyp file that builds ICU in some new
ways, both on unix/mac and windows.
* tools/icu/icu-system.gyp : new .gyp file to build node against a
pkg-config detected ICU.
* tools/icu/icu_small.json : new config file for the "English-only" small
build.
* tools/icu/icutrim.py : new tool for trimming down ICU data. Reads the
above .json file.
* tools/icu/iculslocs.cc : new tool for repairing ICU data manifests
after trim operation.
* tools/icu/no-op.cc : dummy file to force .gyp into using a C++ linker.
* vcbuild.bat : added small-icu and full-icu options, to call into
configure.
* Fixed toolset dependencies, see
https://github.com/joyent/node/pull/7719#issuecomment-54641687
Note that because of a bug in gyp {CC,CXX}_host must also be set.
Otherwise gcc/g++ will be used by default for part of the build.
Reviewed-by: Trevor Norris <trev.norris@gmail.com>
Reviewed-by: Fedor Indutny <fedor@indutny.com>
11 years ago
|
|
|
if /i "%1"=="small-icu" set i18n_arg=%1&goto arg-ok
|
|
|
|
if /i "%1"=="full-icu" set i18n_arg=%1&goto arg-ok
|
build: i18n: add icu config options
Make "--with-intl=none" the default and add "intl-none" option to
vcbuild.bat.
If icu data is missing print a warning unless either --download=all or
--download=icu is set. If set then automatically download, verify (MD5)
and unpack the ICU data if not already available.
There's a "list" of URLs being used, but right now only the first is
picked up. The logic works something like this:
* If there is no directory deps/icu,
* If no zip file (currently icu4c-54_1-src.zip),
* Download zip file (icu-project.org -> sf.net)
* Verify the MD5 sum of the zipfile
* If bad, print error and exit
* Unpack the zipfile into deps/icu
* If deps/icu now exists, use it, else fail with help text
Add the configuration option "--with-icu-source=..."
Usage:
* --with-icu-source=/path/to/my/other/icu
* --with-icu-source=/path/to/icu54.zip
* --with-icu-source=/path/to/icu54.tgz
* --with-icu-source=http://example.com/icu54.tar.bz2
Add the configuration option "--with-icu-locals=...". Allows choosing
which locales are used in the "small-icu" case.
Example:
configure --with-intl=small-icu --with-icu-locales=tlh,grc,nl
(Also note that as of this writing, neither Klingon nor Ancient Greek
are in upstream CLDR data. Serving suggestion only.)
Don't use hard coded ../../out paths on windows. This was suggested by
@misterdjules as it causes test failures. With this fix, "out" is no
longer created on windows and the following can run properly:
python tools/test.py simple
Reduce space by about 1MB with ICU 54 (over without this patch). Also
trims a few other source files, but only conditional on the exact ICU
version used. This is to future-proof - a file that is unneeded now may
be needed in future ICUs.
Also:
* Update distclean to remove icu related files
* Refactor some code into tools/configure.d/nodedownload.py
* Update docs
* Add test
PR-URL: https://github.com/joyent/node/pull/8719
Fixes: https://github.com/joyent/node/issues/7676#issuecomment-64704230
[trev.norris@gmail.com small change to test's whitespace and logic]
Signed-off-by: Trevor Norris <trev.norris@gmail.com>
10 years ago
|
|
|
if /i "%1"=="intl-none" set i18n_arg=%1&goto arg-ok
|
|
|
|
if /i "%1"=="without-intl" set i18n_arg=%1&goto arg-ok
|
build: i18n: add icu config options
Make "--with-intl=none" the default and add "intl-none" option to
vcbuild.bat.
If icu data is missing print a warning unless either --download=all or
--download=icu is set. If set then automatically download, verify (MD5)
and unpack the ICU data if not already available.
There's a "list" of URLs being used, but right now only the first is
picked up. The logic works something like this:
* If there is no directory deps/icu,
* If no zip file (currently icu4c-54_1-src.zip),
* Download zip file (icu-project.org -> sf.net)
* Verify the MD5 sum of the zipfile
* If bad, print error and exit
* Unpack the zipfile into deps/icu
* If deps/icu now exists, use it, else fail with help text
Add the configuration option "--with-icu-source=..."
Usage:
* --with-icu-source=/path/to/my/other/icu
* --with-icu-source=/path/to/icu54.zip
* --with-icu-source=/path/to/icu54.tgz
* --with-icu-source=http://example.com/icu54.tar.bz2
Add the configuration option "--with-icu-locals=...". Allows choosing
which locales are used in the "small-icu" case.
Example:
configure --with-intl=small-icu --with-icu-locales=tlh,grc,nl
(Also note that as of this writing, neither Klingon nor Ancient Greek
are in upstream CLDR data. Serving suggestion only.)
Don't use hard coded ../../out paths on windows. This was suggested by
@misterdjules as it causes test failures. With this fix, "out" is no
longer created on windows and the following can run properly:
python tools/test.py simple
Reduce space by about 1MB with ICU 54 (over without this patch). Also
trims a few other source files, but only conditional on the exact ICU
version used. This is to future-proof - a file that is unneeded now may
be needed in future ICUs.
Also:
* Update distclean to remove icu related files
* Refactor some code into tools/configure.d/nodedownload.py
* Update docs
* Add test
PR-URL: https://github.com/joyent/node/pull/8719
Fixes: https://github.com/joyent/node/issues/7676#issuecomment-64704230
[trev.norris@gmail.com small change to test's whitespace and logic]
Signed-off-by: Trevor Norris <trev.norris@gmail.com>
10 years ago
|
|
|
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"=="enable-vtune" set enable_vtune_arg=1&goto arg-ok
|
|
|
|
if /i "%1"=="dll" set dll=1&goto arg-ok
|
|
|
|
|
|
|
|
echo Error: invalid command line option `%1`.
|
|
|
|
exit /b 1
|
|
|
|
|
|
|
|
:arg-ok
|
|
|
|
: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=small-icu
|
|
|
|
)
|
|
|
|
|
|
|
|
:: assign path to node_exe
|
|
|
|
set "node_exe=%config%\node.exe"
|
|
|
|
|
|
|
|
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 noperfctr set configure_flags=%configure_flags% --without-perfctr& set noperfctr_msi_arg=/p:NoPerfCtr=1
|
|
|
|
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 enable_vtune_arg set configure_flags=%configure_flags% --enable-vtune-profiling
|
|
|
|
if defined dll set configure_flags=%configure_flags% --shared
|
|
|
|
|
|
|
|
if "%i18n_arg%"=="full-icu" set configure_flags=%configure_flags% --with-intl=full-icu
|
|
|
|
if "%i18n_arg%"=="small-icu" set configure_flags=%configure_flags% --with-intl=small-icu
|
|
|
|
if "%i18n_arg%"=="intl-none" set configure_flags=%configure_flags% --with-intl=none
|
|
|
|
if "%i18n_arg%"=="without-intl" set configure_flags=%configure_flags% --without-intl
|
|
|
|
|
|
|
|
if defined config_flags set configure_flags=%configure_flags% %config_flags%
|
build, i18n: improve Intl build, add "--with-intl"
The two main goals of this change are:
- To make it easier to build the Intl option using ICU (particularly,
using a newer ICU than v8/Chromium's version)
- To enable a much smaller ICU build with only English support The goal
here is to get node.js binaries built this way by default so that the
Intl API can be used. Additional data can be added at execution time
(see Readme and wiki)
More details are at https://github.com/joyent/node/pull/7719
In particular, this change adds the "--with-intl=" configure option to
provide more ways of building "Intl":
- "full-icu" picks up an ICU from deps/icu
- "small-icu" is similar, but builds only English
- "system-icu" uses pkg-config to find an installed ICU
- "none" does nothing (no Intl)
For Windows builds, the "full-icu" or "small-icu" options are added to
vcbuild.bat.
Note that the existing "--with-icu-path" option is not removed from
configure, but may not be used alongside the new option.
Wiki changes have already been made on
https://github.com/joyent/node/wiki/Installation
and a new page created at
https://github.com/joyent/node/wiki/Intl
(marked as provisional until this change lands.)
Summary of changes:
* README.md : doc updates
* .gitignore : added "deps/icu" as this is the location where ICU is
unpacked to.
* Makefile : added the tools/icu/* files to cpplint, but excluded a
problematic file.
* configure : added the "--with-intl" option mentioned above.
Calculate at config time the list of ICU source files to use and data
packaging options.
* node.gyp : add the new files src/node_i18n.cc/.h as well as ICU
linkage.
* src/node.cc : add call into
node::i18n::InitializeICUDirectory(icu_data_dir) as well as new
--icu-data-dir option and NODE_ICU_DATA env variable to configure ICU
data loading. This loading is only relevant in the "small"
configuration.
* src/node_i18n.cc : new source file for the above Initialize..
function, to setup ICU as needed.
* tools/icu : new directory with some tools needed for this build.
* tools/icu/icu-generic.gyp : new .gyp file that builds ICU in some new
ways, both on unix/mac and windows.
* tools/icu/icu-system.gyp : new .gyp file to build node against a
pkg-config detected ICU.
* tools/icu/icu_small.json : new config file for the "English-only" small
build.
* tools/icu/icutrim.py : new tool for trimming down ICU data. Reads the
above .json file.
* tools/icu/iculslocs.cc : new tool for repairing ICU data manifests
after trim operation.
* tools/icu/no-op.cc : dummy file to force .gyp into using a C++ linker.
* vcbuild.bat : added small-icu and full-icu options, to call into
configure.
* Fixed toolset dependencies, see
https://github.com/joyent/node/pull/7719#issuecomment-54641687
Note that because of a bug in gyp {CC,CXX}_host must also be set.
Otherwise gcc/g++ will be used by default for part of the build.
Reviewed-by: Trevor Norris <trev.norris@gmail.com>
Reviewed-by: Fedor Indutny <fedor@indutny.com>
11 years ago
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
call :getnodeversion || exit /b 1
|
|
|
|
|
|
|
|
if "%target%"=="Clean" rmdir /Q /S "%~dp0%config%\node-v%FULLVERSION%-win-%target_arch%" > nul 2> nul
|
|
|
|
|
|
|
|
if defined noprojgen if defined nobuild if not defined sign if not defined msi goto licensertf
|
|
|
|
|
|
|
|
@rem Set environment for msbuild
|
|
|
|
|
|
|
|
@rem Look for Visual Studio 2015
|
|
|
|
echo Looking for Visual Studio 2015
|
|
|
|
if not defined VS140COMNTOOLS goto msbuild-not-found
|
|
|
|
if not exist "%VS140COMNTOOLS%\..\..\vc\vcvarsall.bat" goto msbuild-not-found
|
|
|
|
echo Found Visual Studio 2015
|
|
|
|
if defined msi (
|
|
|
|
echo Looking for WiX installation for Visual Studio 2015...
|
|
|
|
if not exist "%WIX%\SDK\VS2015" (
|
|
|
|
echo Failed to find WiX install for Visual Studio 2015
|
|
|
|
echo VS2015 support for WiX is only present starting at version 3.10
|
|
|
|
goto wix-not-found
|
|
|
|
)
|
|
|
|
)
|
|
|
|
if "%VCVARS_VER%" NEQ "140" (
|
|
|
|
call "%VS140COMNTOOLS%\..\..\vc\vcvarsall.bat"
|
|
|
|
SET VCVARS_VER=140
|
|
|
|
)
|
|
|
|
if not defined VCINSTALLDIR goto msbuild-not-found
|
|
|
|
set GYP_MSVS_VERSION=2015
|
|
|
|
set PLATFORM_TOOLSET=v140
|
|
|
|
goto msbuild-found
|
|
|
|
|
|
|
|
:msbuild-not-found
|
|
|
|
echo Failed to find Visual Studio installation.
|
|
|
|
goto exit
|
|
|
|
|
|
|
|
:wix-not-found
|
|
|
|
echo Build skipped. To generate installer, you need to install Wix.
|
|
|
|
goto run
|
|
|
|
|
|
|
|
:msbuild-found
|
|
|
|
|
|
|
|
:project-gen
|
|
|
|
@rem Skip project generation if requested.
|
|
|
|
if defined noprojgen goto msbuild
|
|
|
|
|
|
|
|
@rem Generate the VS project.
|
|
|
|
echo configure %configure_flags% --dest-cpu=%target_arch% --tag=%TAG%
|
|
|
|
python configure %configure_flags% --dest-cpu=%target_arch% --tag=%TAG%
|
|
|
|
if errorlevel 1 goto create-msvs-files-failed
|
|
|
|
if not exist node.sln goto create-msvs-files-failed
|
|
|
|
echo Project files generated.
|
|
|
|
|
|
|
|
:msbuild
|
|
|
|
@rem Skip build if requested.
|
|
|
|
if defined nobuild goto sign
|
|
|
|
|
|
|
|
@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"
|
|
|
|
msbuild node.sln %msbcpu% /t:%target% /p:Configuration=%config% /p:Platform=%msbplatform% /clp:NoSummary;NoItemAndPropertyList;Verbosity=minimal /nologo
|
|
|
|
if errorlevel 1 goto exit
|
|
|
|
if "%target%" == "Clean" goto exit
|
|
|
|
|
|
|
|
: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 package
|
|
|
|
|
|
|
|
%config%\node tools\license2rtf.js < LICENSE > %config%\license.rtf
|
|
|
|
if errorlevel 1 echo Failed to generate license.rtf&goto exit
|
|
|
|
|
|
|
|
:package
|
|
|
|
if not defined package goto msi
|
|
|
|
echo Creating package...
|
|
|
|
cd Release
|
|
|
|
mkdir node-v%FULLVERSION%-win-%target_arch% > nul 2> nul
|
|
|
|
mkdir node-v%FULLVERSION%-win-%target_arch%\node_modules > nul 2>nul
|
|
|
|
|
|
|
|
copy /Y node.exe node-v%FULLVERSION%-win-%target_arch%\ > nul
|
|
|
|
if errorlevel 1 echo Cannot copy node.exe && goto package_error
|
|
|
|
copy /Y ..\LICENSE node-v%FULLVERSION%-win-%target_arch%\ > nul
|
|
|
|
if errorlevel 1 echo Cannot copy LICENSE && goto package_error
|
|
|
|
copy /Y ..\README.md node-v%FULLVERSION%-win-%target_arch%\ > nul
|
|
|
|
if errorlevel 1 echo Cannot copy README.md && goto package_error
|
|
|
|
copy /Y ..\CHANGELOG.md node-v%FULLVERSION%-win-%target_arch%\ > nul
|
|
|
|
if errorlevel 1 echo Cannot copy CHANGELOG.md && goto package_error
|
|
|
|
robocopy /e ..\deps\npm node-v%FULLVERSION%-win-%target_arch%\node_modules\npm > nul
|
|
|
|
if errorlevel 8 echo Cannot copy npm package && goto package_error
|
|
|
|
copy /Y ..\deps\npm\bin\npm node-v%FULLVERSION%-win-%target_arch%\ > nul
|
|
|
|
if errorlevel 1 echo Cannot copy npm && goto package_error
|
|
|
|
copy /Y ..\deps\npm\bin\npm.cmd node-v%FULLVERSION%-win-%target_arch%\ > nul
|
|
|
|
if errorlevel 1 echo Cannot copy npm.cmd && goto package_error
|
|
|
|
copy /Y ..\tools\msvs\nodevars.bat node-v%FULLVERSION%-win-%target_arch%\ > nul
|
|
|
|
if errorlevel 1 echo Cannot copy nodevars.bat && goto package_error
|
|
|
|
if not defined noetw (
|
|
|
|
copy /Y ..\src\res\node_etw_provider.man node-v%FULLVERSION%-win-%target_arch%\ > nul
|
|
|
|
if errorlevel 1 echo Cannot copy node_etw_provider.man && goto package_error
|
|
|
|
)
|
|
|
|
if not defined noperfctr (
|
|
|
|
copy /Y ..\src\res\node_perfctr_provider.man node-v%FULLVERSION%-win-%target_arch%\ > nul
|
|
|
|
if errorlevel 1 echo Cannot copy node_perfctr_provider.man && goto package_error
|
|
|
|
)
|
|
|
|
|
|
|
|
echo Creating node-v%FULLVERSION%-win-%target_arch%.7z
|
|
|
|
del node-v%FULLVERSION%-win-%target_arch%.7z > nul 2> nul
|
|
|
|
7z a -r -mx9 -t7z node-v%FULLVERSION%-win-%target_arch%.7z node-v%FULLVERSION%-win-%target_arch% > nul
|
|
|
|
if errorlevel 1 echo Cannot create node-v%FULLVERSION%-win-%target_arch%.7z && goto package_error
|
|
|
|
|
|
|
|
echo Creating node-v%FULLVERSION%-win-%target_arch%.zip
|
|
|
|
del node-v%FULLVERSION%-win-%target_arch%.zip > nul 2> nul
|
|
|
|
7z a -r -mx9 -tzip node-v%FULLVERSION%-win-%target_arch%.zip node-v%FULLVERSION%-win-%target_arch% > nul
|
|
|
|
if errorlevel 1 echo Cannot create node-v%FULLVERSION%-win-%target_arch%.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 run
|
|
|
|
|
|
|
|
:msibuild
|
|
|
|
echo Building node-v%FULLVERSION%-%target_arch%.msi
|
|
|
|
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
|
|
|
|
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 run
|
|
|
|
|
|
|
|
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%"
|
|
|
|
scp -F %SSHCONFIG% Release\node.exe %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node.exe
|
|
|
|
scp -F %SSHCONFIG% Release\node.lib %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node.lib
|
|
|
|
scp -F %SSHCONFIG% Release\node_pdb.zip %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node_pdb.zip
|
|
|
|
scp -F %SSHCONFIG% Release\node_pdb.7z %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/win-%target_arch%/node_pdb.7z
|
|
|
|
scp -F %SSHCONFIG% Release\node-v%FULLVERSION%-win-%target_arch%.7z %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/node-v%FULLVERSION%-win-%target_arch%.7z
|
|
|
|
scp -F %SSHCONFIG% Release\node-v%FULLVERSION%-win-%target_arch%.zip %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/node-v%FULLVERSION%-win-%target_arch%.zip
|
|
|
|
scp -F %SSHCONFIG% node-v%FULLVERSION%-%target_arch%.msi %STAGINGSERVER%:nodejs/%DISTTYPEDIR%/v%FULLVERSION%/
|
|
|
|
ssh -F %SSHCONFIG% %STAGINGSERVER% "touch nodejs/%DISTTYPEDIR%/v%FULLVERSION%/node-v%FULLVERSION%-%target_arch%.msi.done nodejs/%DISTTYPEDIR%/v%FULLVERSION%/node-v%FULLVERSION%-win-%target_arch%.zip.done nodejs/%DISTTYPEDIR%/v%FULLVERSION%/node-v%FULLVERSION%-win-%target_arch%.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%*"
|
|
|
|
|
|
|
|
:run
|
|
|
|
@rem Run tests if requested.
|
|
|
|
|
|
|
|
@rem Build test/gc add-on if required.
|
|
|
|
if "%build_testgc_addon%"=="" goto build-addons
|
|
|
|
"%config%\node" deps\npm\node_modules\node-gyp\bin\node-gyp rebuild --directory="%~dp0test\gc" --nodedir="%~dp0."
|
|
|
|
if errorlevel 1 goto build-testgc-addon-failed
|
|
|
|
goto build-addons
|
|
|
|
|
|
|
|
:build-testgc-addon-failed
|
|
|
|
echo Failed to build test/gc add-on."
|
|
|
|
goto exit
|
|
|
|
|
|
|
|
:build-addons
|
|
|
|
if not defined build_addons goto build-addons-napi
|
|
|
|
if not exist "%node_exe%" (
|
|
|
|
echo Failed to find node.exe
|
|
|
|
goto build-addons-napi
|
|
|
|
)
|
|
|
|
echo Building addons
|
|
|
|
:: clear
|
|
|
|
for /d %%F in (test\addons\??_*) do (
|
|
|
|
rd /s /q %%F
|
|
|
|
)
|
|
|
|
:: generate
|
|
|
|
"%node_exe%" tools\doc\addon-verify.js
|
|
|
|
if %errorlevel% neq 0 exit /b %errorlevel%
|
|
|
|
:: building addons
|
|
|
|
setlocal EnableDelayedExpansion
|
|
|
|
for /d %%F in (test\addons\*) do (
|
|
|
|
"%node_exe%" deps\npm\node_modules\node-gyp\bin\node-gyp rebuild ^
|
|
|
|
--directory="%%F" ^
|
|
|
|
--nodedir="%cd%"
|
|
|
|
if !errorlevel! neq 0 exit /b !errorlevel!
|
|
|
|
)
|
|
|
|
|
|
|
|
:build-addons-napi
|
|
|
|
if not defined build_addons_napi goto run-tests
|
|
|
|
if not exist "%node_exe%" (
|
|
|
|
echo Failed to find node.exe
|
|
|
|
goto run-tests
|
|
|
|
)
|
|
|
|
echo Building addons-napi
|
|
|
|
:: clear
|
|
|
|
for /d %%F in (test\addons-napi\??_*) do (
|
|
|
|
rd /s /q %%F
|
|
|
|
)
|
|
|
|
:: building addons-napi
|
|
|
|
for /d %%F in (test\addons-napi\*) do (
|
|
|
|
"%node_exe%" deps\npm\node_modules\node-gyp\bin\node-gyp rebuild ^
|
|
|
|
--directory="%%F" ^
|
|
|
|
--nodedir="%cd%"
|
|
|
|
)
|
|
|
|
endlocal
|
|
|
|
goto run-tests
|
|
|
|
|
|
|
|
:run-tests
|
|
|
|
if not defined test_node_inspect goto node-tests
|
|
|
|
set USE_EMBEDDED_NODE_INSPECT=1
|
|
|
|
%config%\node tools\test-npm-package.js --install deps\node-inspect test
|
|
|
|
goto node-tests
|
|
|
|
|
|
|
|
:node-tests
|
|
|
|
if "%test_args%"=="" goto cpplint
|
|
|
|
if "%config%"=="Debug" set test_args=--mode=debug %test_args%
|
|
|
|
if "%config%"=="Release" set test_args=--mode=release %test_args%
|
|
|
|
echo running 'cctest %cctest_args%'
|
|
|
|
"%config%\cctest" %cctest_args%
|
|
|
|
echo running 'python tools\test.py %test_args%'
|
|
|
|
python tools\test.py %test_args%
|
|
|
|
goto cpplint
|
|
|
|
|
|
|
|
:cpplint
|
|
|
|
if not defined cpplint goto jslint
|
|
|
|
echo running cpplint
|
|
|
|
set cppfilelist=
|
|
|
|
setlocal enabledelayedexpansion
|
|
|
|
for /f "tokens=*" %%G in ('dir /b /s /a src\*.c src\*.cc src\*.h ^
|
|
|
|
test\addons\*.cc test\addons\*.h test\cctest\*.cc test\cctest\*.h ^
|
|
|
|
test\gc\binding.cc tools\icu\*.cc tools\icu\*.h') do (
|
|
|
|
set relpath=%%G
|
|
|
|
set relpath=!relpath:*%~dp0=!
|
|
|
|
call :add-to-list !relpath!
|
|
|
|
)
|
|
|
|
( endlocal
|
|
|
|
set cppfilelist=%localcppfilelist%
|
|
|
|
)
|
|
|
|
python tools/cpplint.py %cppfilelist%
|
|
|
|
python tools/check-imports.py
|
|
|
|
goto jslint
|
|
|
|
|
|
|
|
:add-to-list
|
|
|
|
echo %1 | findstr /c:"src\node_root_certs.h"
|
|
|
|
if %errorlevel% equ 0 goto exit
|
|
|
|
|
|
|
|
echo %1 | findstr /c:"src\queue.h"
|
|
|
|
if %errorlevel% equ 0 goto exit
|
|
|
|
|
|
|
|
echo %1 | findstr /c:"src\tree.h"
|
|
|
|
if %errorlevel% equ 0 goto exit
|
|
|
|
|
|
|
|
@rem skip subfolders under /src
|
|
|
|
echo %1 | findstr /r /c:"src\\.*\\.*"
|
|
|
|
if %errorlevel% equ 0 goto exit
|
|
|
|
|
|
|
|
echo %1 | findstr /r /c:"test\\addons\\[0-9].*_.*\.h"
|
|
|
|
if %errorlevel% equ 0 goto exit
|
|
|
|
|
|
|
|
echo %1 | findstr /r /c:"test\\addons\\[0-9].*_.*\.cc"
|
|
|
|
if %errorlevel% equ 0 goto exit
|
|
|
|
|
|
|
|
set "localcppfilelist=%localcppfilelist% %1"
|
|
|
|
goto exit
|
|
|
|
|
|
|
|
:jslint
|
|
|
|
if defined jslint_ci goto jslint-ci
|
|
|
|
if not defined jslint goto exit
|
|
|
|
if not exist tools\eslint\lib\eslint.js goto no-lint
|
|
|
|
echo running jslint
|
|
|
|
%config%\node tools\eslint\bin\eslint.js --cache --rule "linebreak-style: 0" --rulesdir=tools\eslint-rules benchmark lib test tools
|
|
|
|
goto exit
|
|
|
|
|
|
|
|
:jslint-ci
|
|
|
|
echo running jslint-ci
|
|
|
|
%config%\node tools\jslint.js -J -f tap -o test-eslint.tap benchmark lib test tools
|
|
|
|
goto exit
|
|
|
|
|
|
|
|
: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 exit
|
|
|
|
|
|
|
|
:create-msvs-files-failed
|
|
|
|
echo Failed to create vc project files.
|
|
|
|
goto exit
|
|
|
|
|
|
|
|
:help
|
|
|
|
echo vcbuild.bat [debug/release] [msi] [test-all/test-uv/test-inspector/test-internet/test-pummel/test-simple/test-message] [clean] [noprojgen] [small-icu/full-icu/without-intl] [nobuild] [sign] [x86/x64] [vc2015] [download-all] [enable-vtune] [lint/lint-ci]
|
|
|
|
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 enable-vtune : builds nodejs with Intel VTune profiling support to profile JavaScript
|
|
|
|
goto exit
|
|
|
|
|
|
|
|
:exit
|
|
|
|
goto :EOF
|
|
|
|
|
|
|
|
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 exit
|
|
|
|
)
|
|
|
|
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%
|
|
|
|
|
|
|
|
:exit
|
|
|
|
if not defined DISTTYPEDIR set DISTTYPEDIR=%DISTTYPE%
|
|
|
|
goto :EOF
|