From 3f6c5a937685bd169026aed3221e54c41bf69c7a Mon Sep 17 00:00:00 2001 From: liusi Date: Wed, 15 Mar 2017 11:12:32 +0800 Subject: [PATCH 1/4] build: add cpp linting to windows build This PR adds cpp linting to windows build script. After this change, running command `vcbuild lint` will run both cpp linting and javascript linting on a windows machine. Fixes: https://github.com/nodejs/node/issues/11816 --- CONTRIBUTING.md | 3 +-- vcbuild.bat | 56 ++++++++++++++++++++++++++++++++++++++++++++----- 2 files changed, 52 insertions(+), 7 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 290cad8faaeb7a..e56c4ef535e995 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -176,8 +176,7 @@ Running `make test`/`vcbuild test` will run the linter as well unless one or more tests fail. If you want to run the linter without running tests, use -`make lint`/`vcbuild jslint`. At this time, only JavaScript linting is -available on Windows. `make lint` on POSIX will run both JavaScript linting and +`make lint`/`vcbuild lint`. It will run both JavaScript linting and C++ linting. If you are updating tests and just want to run a single test to check it, you diff --git a/vcbuild.bat b/vcbuild.bat index f07c50b0fbfc91..d879ef76052a1c 100644 --- a/vcbuild.bat +++ b/vcbuild.bat @@ -27,6 +27,7 @@ set msi= set upload= set licensertf= set jslint= +set cpplint= set build_testgc_addon= set noetw= set noetw_msi_arg= @@ -58,7 +59,7 @@ 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% addons doctool known_issues message parallel sequential -J&set jslint=1&set build_addons=1&goto arg-ok +if /i "%1"=="test" set test_args=%test_args% addons doctool known_issues message parallel sequential -J&set cpplint=1&set jslint=1&set build_addons=1&goto arg-ok if /i "%1"=="test-ci" set test_args=%test_args% %test_ci_args% -p tap --logfile test.tap addons doctool inspector known_issues message sequential parallel&set cctest_args=%cctest_args% --gtest_output=tap:cctest.tap&set build_addons=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-simple" set test_args=%test_args% sequential parallel -J&goto arg-ok @@ -68,11 +69,13 @@ 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 jslint=1&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 @@ -323,14 +326,14 @@ for /d %%F in (test\addons\??_*) do ( "%node_exe%" tools\doc\addon-verify.js if %errorlevel% neq 0 exit /b %errorlevel% :: building addons -SetLocal EnableDelayedExpansion +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! ) -EndLocal +endlocal goto run-tests :run-tests @@ -340,15 +343,57 @@ set USE_EMBEDDED_NODE_INSPECT=1 goto node-tests :node-tests -if "%test_args%"=="" goto jslint +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 @@ -362,6 +407,7 @@ 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 From 15ae7c0863639611ea36fd1c51a089356ae33f1e Mon Sep 17 00:00:00 2001 From: liusi Date: Wed, 15 Mar 2017 13:05:53 +0800 Subject: [PATCH 2/4] remove accidentally added new line --- vcbuild.bat | 1 - 1 file changed, 1 deletion(-) diff --git a/vcbuild.bat b/vcbuild.bat index d879ef76052a1c..e4c5276bf2af6e 100644 --- a/vcbuild.bat +++ b/vcbuild.bat @@ -407,7 +407,6 @@ 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 From 3822b82658502f021e97753e1c44b8549a28d0db Mon Sep 17 00:00:00 2001 From: liusi Date: Thu, 16 Mar 2017 15:35:27 +0800 Subject: [PATCH 3/4] make file path comparison work for windows machine as well. --- tools/cpplint.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/tools/cpplint.py b/tools/cpplint.py index b5a05f0af39ba7..143ce4b25b0abc 100644 --- a/tools/cpplint.py +++ b/tools/cpplint.py @@ -1074,7 +1074,8 @@ def RepositoryName(self): """ fullname = self.FullName() # XXX(bnoordhuis) Expects that cpplint.py lives in the tools/ directory. - toplevel = os.path.abspath(os.path.join(os.path.dirname(__file__), '..')) + toplevel = os.path.abspath( + os.path.join(os.path.dirname(__file__), '..')).replace('\\', '/') prefix = os.path.commonprefix([fullname, toplevel]) return fullname[len(prefix) + 1:] From 1743f76884b9de688b3bc3516f79df3b4b6024e7 Mon Sep 17 00:00:00 2001 From: liusi Date: Thu, 16 Mar 2017 16:44:13 +0800 Subject: [PATCH 4/4] indent by 4 spaces instead. --- tools/cpplint.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/cpplint.py b/tools/cpplint.py index 143ce4b25b0abc..305220060c5cdb 100644 --- a/tools/cpplint.py +++ b/tools/cpplint.py @@ -1075,7 +1075,7 @@ def RepositoryName(self): fullname = self.FullName() # XXX(bnoordhuis) Expects that cpplint.py lives in the tools/ directory. toplevel = os.path.abspath( - os.path.join(os.path.dirname(__file__), '..')).replace('\\', '/') + os.path.join(os.path.dirname(__file__), '..')).replace('\\', '/') prefix = os.path.commonprefix([fullname, toplevel]) return fullname[len(prefix) + 1:]