| -include config.mk |
| |
| BUILDTYPE ?= Release |
| PYTHON ?= python |
| DESTDIR ?= |
| SIGN ?= |
| PREFIX ?= /usr/local |
| FLAKY_TESTS ?= run |
| TEST_CI_ARGS ?= |
| STAGINGSERVER ?= node-www |
| |
| OSTYPE := $(shell uname -s | tr '[A-Z]' '[a-z]') |
| |
| # Determine EXEEXT |
| EXEEXT := $(shell $(PYTHON) -c \ |
| "import sys; print('.exe' if sys.platform == 'win32' else '')") |
| |
| NODE ?= ./node$(EXEEXT) |
| NODE_EXE = node$(EXEEXT) |
| NODE_G_EXE = node_g$(EXEEXT) |
| |
| # Flags for packaging. |
| BUILD_DOWNLOAD_FLAGS ?= --download=all |
| BUILD_INTL_FLAGS ?= --with-intl=small-icu |
| BUILD_RELEASE_FLAGS ?= $(BUILD_DOWNLOAD_FLAGS) $(BUILD_INTL_FLAGS) |
| |
| # Default to verbose builds. |
| # To do quiet/pretty builds, run `make V=` to set V to an empty string, |
| # or set the V environment variable to an empty string. |
| V ?= 1 |
| |
| # BUILDTYPE=Debug builds both release and debug builds. If you want to compile |
| # just the debug build, run `make -C out BUILDTYPE=Debug` instead. |
| ifeq ($(BUILDTYPE),Release) |
| all: out/Makefile $(NODE_EXE) |
| else |
| all: out/Makefile $(NODE_EXE) $(NODE_G_EXE) |
| endif |
| |
| # The .PHONY is needed to ensure that we recursively use the out/Makefile |
| # to check for changes. |
| .PHONY: $(NODE_EXE) $(NODE_G_EXE) |
| |
| $(NODE_EXE): config.gypi out/Makefile |
| $(MAKE) -C out BUILDTYPE=Release V=$(V) |
| ln -fs out/Release/$(NODE_EXE) $@ |
| |
| $(NODE_G_EXE): config.gypi out/Makefile |
| $(MAKE) -C out BUILDTYPE=Debug V=$(V) |
| ln -fs out/Debug/$(NODE_EXE) $@ |
| |
| out/Makefile: common.gypi deps/uv/uv.gyp deps/http_parser/http_parser.gyp deps/zlib/zlib.gyp deps/v8/build/toolchain.gypi deps/v8/build/features.gypi deps/v8/tools/gyp/v8.gyp node.gyp config.gypi |
| $(PYTHON) tools/gyp_node.py -f make |
| |
| config.gypi: configure |
| if [ -f $@ ]; then |
| $(error Stale $@, please re-run ./configure) |
| else |
| $(error No $@, please run ./configure first) |
| fi |
| |
| install: all |
| $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)' |
| |
| uninstall: |
| $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)' |
| |
| clean: |
| -rm -rf out/Makefile $(NODE_EXE) $(NODE_G_EXE) out/$(BUILDTYPE)/$(NODE_EXE) |
| @if [ -d out ]; then find out/ -name '*.o' -o -name '*.a' -o -name '*.d' | xargs rm -rf; fi |
| -rm -rf node_modules |
| @if [ -d deps/icu ]; then echo deleting deps/icu; rm -rf deps/icu; fi |
| -rm -f test.tap |
| |
| distclean: |
| -rm -rf out |
| -rm -f config.gypi icu_config.gypi config_fips.gypi |
| -rm -f config.mk |
| -rm -rf $(NODE_EXE) $(NODE_G_EXE) |
| -rm -rf node_modules |
| -rm -rf deps/icu |
| -rm -rf deps/icu4c*.tgz deps/icu4c*.zip deps/icu-tmp |
| -rm -f $(BINARYTAR).* $(TARBALL).* |
| |
| check: test |
| |
| cctest: all |
| @out/$(BUILDTYPE)/$@ |
| |
| test: | cctest # Depends on 'all'. |
| $(PYTHON) tools/test.py --mode=release message parallel sequential -J |
| $(MAKE) jslint |
| $(MAKE) cpplint |
| |
| test-parallel: all |
| $(PYTHON) tools/test.py --mode=release parallel -J |
| |
| test-valgrind: all |
| $(PYTHON) tools/test.py --mode=release --valgrind sequential parallel message |
| |
| test/gc/node_modules/weak/build/Release/weakref.node: $(NODE_EXE) |
| $(NODE) deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \ |
| --directory="$(shell pwd)/test/gc/node_modules/weak" \ |
| --nodedir="$(shell pwd)" |
| |
| # Implicitly depends on $(NODE_EXE), see the build-addons rule for rationale. |
| test/addons/.docbuildstamp: doc/api/addons.markdown |
| $(RM) -r test/addons/doc-*/ |
| $(NODE) tools/doc/addon-verify.js |
| touch $@ |
| |
| ADDONS_BINDING_GYPS := \ |
| $(filter-out test/addons/doc-*/binding.gyp, \ |
| $(wildcard test/addons/*/binding.gyp)) |
| |
| # Implicitly depends on $(NODE_EXE), see the build-addons rule for rationale. |
| test/addons/.buildstamp: $(ADDONS_BINDING_GYPS) | test/addons/.docbuildstamp |
| # Cannot use $(wildcard test/addons/*/) here, it's evaluated before |
| # embedded addons have been generated from the documentation. |
| for dirname in test/addons/*/; do \ |
| $(NODE) deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \ |
| --directory="$$PWD/$$dirname" \ |
| --nodedir="$$PWD"; \ |
| done |
| touch $@ |
| |
| # .buildstamp and .docbuildstamp need $(NODE_EXE) but cannot depend on it |
| # directly because it calls make recursively. The parent make cannot know |
| # if the subprocess touched anything so it pessimistically assumes that |
| # .buildstamp and .docbuildstamp are out of date and need a rebuild. |
| # Just goes to show that recursive make really is harmful... |
| # TODO(bnoordhuis) Force rebuild after gyp or node-gyp update. |
| build-addons: $(NODE_EXE) test/addons/.buildstamp |
| |
| test-gc: all test/gc/node_modules/weak/build/Release/weakref.node |
| $(PYTHON) tools/test.py --mode=release gc |
| |
| test-build: | all build-addons |
| |
| test-all: test-build test/gc/node_modules/weak/build/Release/weakref.node |
| $(PYTHON) tools/test.py --mode=debug,release |
| |
| test-all-valgrind: test-build |
| $(PYTHON) tools/test.py --mode=debug,release --valgrind |
| |
| test-ci: | build-addons |
| $(PYTHON) tools/test.py -p tap --logfile test.tap --mode=release --flaky-tests=$(FLAKY_TESTS) \ |
| $(TEST_CI_ARGS) addons message parallel sequential |
| |
| test-release: test-build |
| $(PYTHON) tools/test.py --mode=release |
| |
| test-debug: test-build |
| $(PYTHON) tools/test.py --mode=debug |
| |
| test-message: test-build |
| $(PYTHON) tools/test.py message |
| |
| test-simple: | cctest # Depends on 'all'. |
| $(PYTHON) tools/test.py parallel sequential |
| |
| test-pummel: all |
| $(PYTHON) tools/test.py pummel |
| |
| test-internet: all |
| $(PYTHON) tools/test.py internet |
| |
| test-debugger: all |
| $(PYTHON) tools/test.py debugger |
| |
| test-npm: $(NODE_EXE) |
| NODE=$(NODE) tools/test-npm.sh |
| |
| test-npm-publish: $(NODE_EXE) |
| npm_package_config_publishtest=true $(NODE) deps/npm/test/run.js |
| |
| test-addons: test-build |
| $(PYTHON) tools/test.py --mode=release addons |
| |
| test-timers: |
| $(MAKE) --directory=tools faketime |
| $(PYTHON) tools/test.py --mode=release timers |
| |
| test-timers-clean: |
| $(MAKE) --directory=tools clean |
| |
| apidoc_sources = $(wildcard doc/api/*.markdown) |
| apidocs = $(addprefix out/,$(apidoc_sources:.markdown=.html)) \ |
| $(addprefix out/,$(apidoc_sources:.markdown=.json)) |
| |
| apidoc_dirs = out/doc out/doc/api/ out/doc/api/assets |
| |
| apiassets = $(subst api_assets,api/assets,$(addprefix out/,$(wildcard doc/api_assets/*))) |
| |
| doc: $(apidoc_dirs) $(apiassets) $(apidocs) tools/doc/ $(NODE_EXE) |
| |
| $(apidoc_dirs): |
| mkdir -p $@ |
| |
| out/doc/api/assets/%: doc/api_assets/% out/doc/api/assets/ |
| cp $< $@ |
| |
| out/doc/%: doc/% |
| cp -r $< $@ |
| |
| out/doc/api/%.json: doc/api/%.markdown $(NODE_EXE) |
| $(NODE) tools/doc/generate.js --format=json $< > $@ |
| |
| out/doc/api/%.html: doc/api/%.markdown $(NODE_EXE) |
| $(NODE) tools/doc/generate.js --format=html --template=doc/template.html $< > $@ |
| |
| docopen: out/doc/api/all.html |
| -google-chrome out/doc/api/all.html |
| |
| docclean: |
| -rm -rf out/doc |
| |
| run-ci: |
| $(PYTHON) ./configure $(CONFIG_FLAGS) |
| $(MAKE) |
| $(MAKE) test-ci |
| |
| RAWVER=$(shell $(PYTHON) tools/getnodeversion.py) |
| VERSION=v$(RAWVER) |
| |
| # For nightly builds, you must set DISTTYPE to "nightly", "next-nightly" or |
| # "custom". For the nightly and next-nightly case, you need to set DATESTRING |
| # and COMMIT in order to properly name the build. |
| # For the rc case you need to set CUSTOMTAG to an appropriate CUSTOMTAG number |
| |
| ifndef DISTTYPE |
| DISTTYPE=release |
| endif |
| ifeq ($(DISTTYPE),release) |
| FULLVERSION=$(VERSION) |
| else # ifeq ($(DISTTYPE),release) |
| ifeq ($(DISTTYPE),custom) |
| ifndef CUSTOMTAG |
| $(error CUSTOMTAG is not set for DISTTYPE=custom) |
| endif # ifndef CUSTOMTAG |
| TAG=$(CUSTOMTAG) |
| else # ifeq ($(DISTTYPE),custom) |
| ifndef DATESTRING |
| $(error DATESTRING is not set for nightly) |
| endif # ifndef DATESTRING |
| ifndef COMMIT |
| $(error COMMIT is not set for nightly) |
| endif # ifndef COMMIT |
| ifneq ($(DISTTYPE),nightly) |
| ifneq ($(DISTTYPE),next-nightly) |
| $(error DISTTYPE is not release, custom, nightly or next-nightly) |
| endif # ifneq ($(DISTTYPE),next-nightly) |
| endif # ifneq ($(DISTTYPE),nightly) |
| TAG=$(DISTTYPE)$(DATESTRING)$(COMMIT) |
| endif # ifeq ($(DISTTYPE),custom) |
| FULLVERSION=$(VERSION)-$(TAG) |
| endif # ifeq ($(DISTTYPE),release) |
| |
| DISTTYPEDIR ?= $(DISTTYPE) |
| RELEASE=$(shell sed -ne 's/\#define NODE_VERSION_IS_RELEASE \([01]\)/\1/p' src/node_version.h) |
| PLATFORM=$(shell uname | tr '[:upper:]' '[:lower:]') |
| NPMVERSION=v$(shell cat deps/npm/package.json | grep '"version"' | sed 's/^[^:]*: "\([^"]*\)",.*/\1/') |
| |
| ifeq ($(findstring x86_64,$(shell uname -m)),x86_64) |
| DESTCPU ?= x64 |
| else |
| DESTCPU ?= x86 |
| endif |
| ifeq ($(DESTCPU),x64) |
| ARCH=x64 |
| else |
| ifeq ($(DESTCPU),arm) |
| ARCH=arm |
| else |
| ifeq ($(DESTCPU),ppc64) |
| ARCH=ppc64 |
| else |
| ifeq ($(DESTCPU),ppc) |
| ARCH=ppc |
| else |
| ARCH=x86 |
| endif |
| endif |
| endif |
| endif |
| |
| # enforce "x86" over "ia32" as the generally accepted way of referring to 32-bit intel |
| ifeq ($(ARCH),ia32) |
| override ARCH=x86 |
| endif |
| ifeq ($(DESTCPU),ia32) |
| override DESTCPU=x86 |
| endif |
| |
| TARNAME=node-$(FULLVERSION) |
| TARBALL=$(TARNAME).tar |
| BINARYNAME=$(TARNAME)-$(PLATFORM)-$(ARCH) |
| BINARYTAR=$(BINARYNAME).tar |
| # OSX doesn't have xz installed by default, http://macpkg.sourceforge.net/ |
| XZ=$(shell which xz > /dev/null 2>&1; echo $$?) |
| XZ_COMPRESSION ?= 9 |
| PKG=$(TARNAME).pkg |
| PACKAGEMAKER ?= /Developer/Applications/Utilities/PackageMaker.app/Contents/MacOS/PackageMaker |
| PKGDIR=out/dist-osx |
| |
| release-only: |
| @if [ "$(shell git status --porcelain | egrep -v '^\?\? ')" = "" ]; then \ |
| exit 0 ; \ |
| else \ |
| echo "" >&2 ; \ |
| echo "The git repository is not clean." >&2 ; \ |
| echo "Please commit changes before building release tarball." >&2 ; \ |
| echo "" >&2 ; \ |
| git status --porcelain | egrep -v '^\?\?' >&2 ; \ |
| echo "" >&2 ; \ |
| exit 1 ; \ |
| fi |
| @if [ "$(DISTTYPE)" != "release" -o "$(RELEASE)" = "1" ]; then \ |
| exit 0; \ |
| else \ |
| echo "" >&2 ; \ |
| echo "#NODE_VERSION_IS_RELEASE is set to $(RELEASE)." >&2 ; \ |
| echo "Did you remember to update src/node_version.h?" >&2 ; \ |
| echo "" >&2 ; \ |
| exit 1 ; \ |
| fi |
| |
| $(PKG): release-only |
| rm -rf $(PKGDIR) |
| rm -rf out/deps out/Release |
| $(PYTHON) ./configure \ |
| --dest-cpu=x64 \ |
| --tag=$(TAG) \ |
| --release-urlbase=$(RELEASE_URLBASE) \ |
| $(CONFIG_FLAGS) $(BUILD_RELEASE_FLAGS) |
| $(MAKE) install V=$(V) DESTDIR=$(PKGDIR) |
| SIGN="$(CODESIGN_CERT)" PKGDIR="$(PKGDIR)" bash tools/osx-codesign.sh |
| cat tools/osx-pkg.pmdoc/index.xml.tmpl \ |
| | sed -E "s/\\{nodeversion\\}/$(FULLVERSION)/g" \ |
| | sed -E "s/\\{npmversion\\}/$(NPMVERSION)/g" \ |
| > tools/osx-pkg.pmdoc/index.xml |
| $(PACKAGEMAKER) \ |
| --id "org.nodejs.pkg" \ |
| --doc tools/osx-pkg.pmdoc \ |
| --out $(PKG) |
| SIGN="$(PRODUCTSIGN_CERT)" PKG="$(PKG)" bash tools/osx-productsign.sh |
| |
| pkg: $(PKG) |
| |
| pkg-upload: pkg |
| ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)" |
| chmod 664 node-$(FULLVERSION).pkg |
| scp -p node-$(FULLVERSION).pkg $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).pkg |
| ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).pkg.done" |
| |
| $(TARBALL): release-only $(NODE_EXE) doc |
| git checkout-index -a -f --prefix=$(TARNAME)/ |
| mkdir -p $(TARNAME)/doc/api |
| cp doc/node.1 $(TARNAME)/doc/node.1 |
| cp -r out/doc/api/* $(TARNAME)/doc/api/ |
| rm -rf $(TARNAME)/deps/v8/{test,samples,tools/profviz} # too big |
| rm -rf $(TARNAME)/doc/images # too big |
| rm -rf $(TARNAME)/deps/uv/{docs,samples,test} |
| rm -rf $(TARNAME)/deps/openssl/{doc,demos,test} |
| rm -rf $(TARNAME)/deps/zlib/contrib # too big, unused |
| find $(TARNAME)/ -type l | xargs rm # annoying on windows |
| tar -cf $(TARNAME).tar $(TARNAME) |
| rm -rf $(TARNAME) |
| gzip -c -f -9 $(TARNAME).tar > $(TARNAME).tar.gz |
| ifeq ($(XZ), 0) |
| xz -c -f -$(XZ_COMPRESSION) $(TARNAME).tar > $(TARNAME).tar.xz |
| endif |
| rm $(TARNAME).tar |
| |
| tar: $(TARBALL) |
| |
| tar-upload: tar |
| ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)" |
| chmod 664 node-$(FULLVERSION).tar.gz |
| scp -p node-$(FULLVERSION).tar.gz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).tar.gz |
| ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).tar.gz.done" |
| ifeq ($(XZ), 0) |
| chmod 664 node-$(FULLVERSION).tar.xz |
| scp -p node-$(FULLVERSION).tar.xz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).tar.xz |
| ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).tar.xz.done" |
| endif |
| |
| doc-upload: tar |
| ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)" |
| chmod -R ug=rw-x+X,o=r+X out/doc/ |
| scp -pr out/doc/ $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/docs/ |
| ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/docs.done" |
| |
| $(TARBALL)-headers: config.gypi release-only |
| $(PYTHON) ./configure \ |
| --prefix=/ \ |
| --dest-cpu=$(DESTCPU) \ |
| --tag=$(TAG) \ |
| --release-urlbase=$(RELEASE_URLBASE) \ |
| $(CONFIG_FLAGS) $(BUILD_RELEASE_FLAGS) |
| HEADERS_ONLY=1 $(PYTHON) tools/install.py install '$(TARNAME)' '/' |
| find $(TARNAME)/ -type l | xargs rm # annoying on windows |
| tar -cf $(TARNAME)-headers.tar $(TARNAME) |
| rm -rf $(TARNAME) |
| gzip -c -f -9 $(TARNAME)-headers.tar > $(TARNAME)-headers.tar.gz |
| ifeq ($(XZ), 0) |
| xz -c -f -$(XZ_COMPRESSION) $(TARNAME)-headers.tar > $(TARNAME)-headers.tar.xz |
| endif |
| rm $(TARNAME)-headers.tar |
| |
| tar-headers: $(TARBALL)-headers |
| |
| tar-headers-upload: tar-headers |
| ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)" |
| chmod 664 $(TARNAME)-headers.tar.gz |
| scp -p $(TARNAME)-headers.tar.gz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/$(TARNAME)-headers.tar.gz |
| ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/$(TARNAME)-headers.tar.gz.done" |
| ifeq ($(XZ), 0) |
| chmod 664 $(TARNAME)-headers.tar.xz |
| scp -p $(TARNAME)-headers.tar.xz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/$(TARNAME)-headers.tar.xz |
| ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/$(TARNAME)-headers.tar.xz.done" |
| endif |
| |
| $(BINARYTAR): release-only |
| rm -rf $(BINARYNAME) |
| rm -rf out/deps out/Release |
| $(PYTHON) ./configure \ |
| --prefix=/ \ |
| --dest-cpu=$(DESTCPU) \ |
| --tag=$(TAG) \ |
| --release-urlbase=$(RELEASE_URLBASE) \ |
| $(CONFIG_FLAGS) $(BUILD_RELEASE_FLAGS) |
| $(MAKE) install DESTDIR=$(BINARYNAME) V=$(V) PORTABLE=1 |
| cp README.md $(BINARYNAME) |
| cp LICENSE $(BINARYNAME) |
| cp CHANGELOG.md $(BINARYNAME) |
| tar -cf $(BINARYNAME).tar $(BINARYNAME) |
| rm -rf $(BINARYNAME) |
| gzip -c -f -9 $(BINARYNAME).tar > $(BINARYNAME).tar.gz |
| ifeq ($(XZ), 0) |
| xz -c -f -$(XZ_COMPRESSION) $(BINARYNAME).tar > $(BINARYNAME).tar.xz |
| endif |
| rm $(BINARYNAME).tar |
| |
| binary: $(BINARYTAR) |
| |
| binary-upload: binary |
| ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)" |
| chmod 664 node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.gz |
| scp -p node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.gz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.gz |
| ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.gz.done" |
| ifeq ($(XZ), 0) |
| chmod 664 node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.xz |
| scp -p node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.xz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.xz |
| ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.xz.done" |
| endif |
| |
| haswrk=$(shell which wrk > /dev/null 2>&1; echo $$?) |
| wrk: |
| ifneq ($(haswrk), 0) |
| @echo "please install wrk before proceeding. More information can be found in benchmark/README.md." >&2 |
| @exit 1 |
| endif |
| |
| bench-net: all |
| @$(NODE) benchmark/common.js net |
| |
| bench-crypto: all |
| @$(NODE) benchmark/common.js crypto |
| |
| bench-tls: all |
| @$(NODE) benchmark/common.js tls |
| |
| bench-http: wrk all |
| @$(NODE) benchmark/common.js http |
| |
| bench-fs: all |
| @$(NODE) benchmark/common.js fs |
| |
| bench-misc: all |
| @$(MAKE) -C benchmark/misc/function_call/ |
| @$(NODE) benchmark/common.js misc |
| |
| bench-array: all |
| @$(NODE) benchmark/common.js arrays |
| |
| bench-buffer: all |
| @$(NODE) benchmark/common.js buffers |
| |
| bench-url: all |
| @$(NODE) benchmark/common.js url |
| |
| bench-events: all |
| @$(NODE) benchmark/common.js events |
| |
| bench-util: all |
| @$(NODE) benchmark/common.js util |
| |
| bench-all: bench bench-misc bench-array bench-buffer bench-url bench-events |
| |
| bench: bench-net bench-http bench-fs bench-tls |
| |
| bench-http-simple: |
| benchmark/http_simple_bench.sh |
| |
| bench-idle: |
| $(NODE) benchmark/idle_server.js & |
| sleep 1 |
| $(NODE) benchmark/idle_clients.js & |
| |
| jslint: |
| $(NODE) tools/eslint/bin/eslint.js src lib test tools/eslint-rules \ |
| --rulesdir tools/eslint-rules --reset --quiet |
| |
| CPPLINT_EXCLUDE ?= |
| CPPLINT_EXCLUDE += src/node_lttng.cc |
| CPPLINT_EXCLUDE += src/node_root_certs.h |
| CPPLINT_EXCLUDE += src/node_lttng_tp.h |
| CPPLINT_EXCLUDE += src/node_win32_perfctr_provider.cc |
| CPPLINT_EXCLUDE += src/queue.h |
| CPPLINT_EXCLUDE += src/tree.h |
| CPPLINT_EXCLUDE += src/v8abbr.h |
| CPPLINT_EXCLUDE += $(wildcard test/addons/doc-*/*.cc test/addons/doc-*/*.h) |
| |
| CPPLINT_FILES = $(filter-out $(CPPLINT_EXCLUDE), $(wildcard \ |
| deps/debugger-agent/include/* \ |
| deps/debugger-agent/src/* \ |
| src/*.c \ |
| src/*.cc \ |
| src/*.h \ |
| test/addons/*/*.cc \ |
| test/addons/*/*.h \ |
| tools/icu/*.cc \ |
| tools/icu/*.h \ |
| )) |
| |
| cpplint: |
| @$(PYTHON) tools/cpplint.py $(CPPLINT_FILES) |
| |
| lint: jslint cpplint |
| |
| .PHONY: lint cpplint jslint bench clean docopen docclean doc dist distclean \ |
| check uninstall install install-includes install-bin all staticlib \ |
| dynamiclib test test-all test-addons build-addons website-upload pkg \ |
| blog blogclean tar binary release-only bench-http-simple bench-idle \ |
| bench-all bench bench-misc bench-array bench-buffer bench-net \ |
| bench-http bench-fs bench-tls cctest run-ci |