12 # Default to verbose builds.
13 # To do quiet/pretty builds, run `make V=` to set V to an empty string,
14 # or set the V environment variable to an empty string.
23 # BUILDTYPE=Debug builds both release and debug builds. If you want to compile
24 # just the debug build, run `make -C out BUILDTYPE=Debug` instead.
25 ifeq ($(BUILDTYPE),Release)
26 all: out/Makefile node
28 all: out/Makefile node node_g
31 # The .PHONY is needed to ensure that we recursively use the out/Makefile
32 # to check for changes.
37 $(NINJA) -C out/Release/
38 ln -fs out/Release/node node
41 $(NINJA) -C out/Debug/
42 ln -fs out/Debug/node $@
44 node: config.gypi out/Makefile
45 $(MAKE) -C out BUILDTYPE=Release V=$(V)
46 ln -fs out/Release/node node
48 node_g: config.gypi out/Makefile
49 $(MAKE) -C out BUILDTYPE=Debug V=$(V)
50 ln -fs out/Debug/node $@
53 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
56 $(PYTHON) tools/gyp_node.py -f ninja
58 $(PYTHON) tools/gyp_node.py -f make
61 config.gypi: configure
63 $(error Stale $@, please re-run ./configure)
65 $(error No $@, please run ./configure first)
69 $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
72 $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
75 -rm -rf out/Makefile node node_g out/$(BUILDTYPE)/node blog.html email.md
76 -find out/ -name '*.o' -o -name '*.a' | xargs rm -rf
81 -rm -f config.gypi icu_config.gypi
83 -rm -rf node node_g blog.html email.md
86 -rm -rf deps/icu4c*.tgz deps/icu4c*.zip deps/icu-tmp
89 $(PYTHON) tools/test.py --mode=release simple message
94 $(PYTHON) tools/test.py --mode=release --use-http1 simple message
97 $(PYTHON) tools/test.py --mode=release --valgrind simple message
99 test/gc/node_modules/weak/build/Release/weakref.node:
100 @if [ ! -f node ]; then make all; fi
101 ./node deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \
102 --directory="$(shell pwd)/test/gc/node_modules/weak" \
103 --nodedir="$(shell pwd)"
106 @if [ ! -f node ]; then make all; fi
107 rm -rf test/addons/doc-*/
108 ./node tools/doc/addon-verify.js
110 $(sort $(dir $(wildcard test/addons/*/*.gyp))), \
111 ./node deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \
112 --directory="$(shell pwd)/$(dir)" \
113 --nodedir="$(shell pwd)" && ) echo "build done"
115 test-gc: all test/gc/node_modules/weak/build/Release/weakref.node
116 $(PYTHON) tools/test.py --mode=release gc
118 test-build: all build-addons
120 test-all: test-build test/gc/node_modules/weak/build/Release/weakref.node
121 $(PYTHON) tools/test.py --mode=debug,release
124 test-all-http1: test-build
125 $(PYTHON) tools/test.py --mode=debug,release --use-http1
127 test-all-valgrind: test-build
128 $(PYTHON) tools/test.py --mode=debug,release --valgrind
130 test-release: test-build
131 $(PYTHON) tools/test.py --mode=release
133 test-debug: test-build
134 $(PYTHON) tools/test.py --mode=debug
136 test-message: test-build
137 $(PYTHON) tools/test.py message
140 $(PYTHON) tools/test.py simple
143 $(PYTHON) tools/test.py pummel
146 $(PYTHON) tools/test.py internet
149 $(PYTHON) tools/test.py debugger
152 rm -rf npm-cache npm-tmp npm-prefix
153 mkdir npm-cache npm-tmp npm-prefix
154 cd deps/npm ; npm_config_cache="$(shell pwd)/npm-cache" \
155 npm_config_prefix="$(shell pwd)/npm-prefix" \
156 npm_config_tmp="$(shell pwd)/npm-tmp" \
157 ../../node cli.js install
158 cd deps/npm ; npm_config_cache="$(shell pwd)/npm-cache" \
159 npm_config_prefix="$(shell pwd)/npm-prefix" \
160 npm_config_tmp="$(shell pwd)/npm-tmp" \
161 ../../node cli.js run-script test-all && \
162 ../../node cli.js prune --prod && \
164 rm -rf npm-cache npm-tmp npm-prefix
166 test-npm-publish: node
167 npm_package_config_publishtest=true ./node deps/npm/test/run.js
169 test-addons: test-build
170 $(PYTHON) tools/test.py --mode=release addons
173 $(MAKE) --directory=tools faketime
174 $(PYTHON) tools/test.py --mode=release timers
177 $(MAKE) --directory=tools clean
179 apidoc_sources = $(wildcard doc/api/*.markdown)
180 apidocs = $(addprefix out/,$(apidoc_sources:.markdown=.html)) \
181 $(addprefix out/,$(apidoc_sources:.markdown=.json))
183 apidoc_dirs = out/doc out/doc/api/ out/doc/api/assets
185 apiassets = $(subst api_assets,api/assets,$(addprefix out/,$(wildcard doc/api_assets/*)))
189 out/doc/sh_javascript.min.js
191 doc: $(apidoc_dirs) $(website_files) $(apiassets) $(apidocs) tools/doc/ out/doc/changelog.html node
196 out/doc/api/assets/%: doc/api_assets/% out/doc/api/assets/
199 out/doc/changelog.html: ChangeLog doc/changelog-head.html doc/changelog-foot.html tools/build-changelog.sh node
200 bash tools/build-changelog.sh
205 out/doc/api/%.json: doc/api/%.markdown node
206 out/Release/node tools/doc/generate.js --format=json $< > $@
208 out/doc/api/%.html: doc/api/%.markdown node
209 out/Release/node tools/doc/generate.js --format=html --template=doc/template.html $< > $@
211 email.md: ChangeLog tools/email-footer.md
212 bash tools/changelog-head.sh | sed 's|^\* #|* \\#|g' > $@
213 cat tools/email-footer.md | sed -e 's|__VERSION__|'$(VERSION)'|g' >> $@
216 cat $< | ./node tools/doc/node_modules/.bin/marked > $@
219 rsync -r out/doc/ node@nodejs.org:~/web/nodejs.org/
220 ssh node@nodejs.org '\
221 rm -f ~/web/nodejs.org/dist/latest &&\
222 ln -s $(VERSION) ~/web/nodejs.org/dist/latest &&\
223 rm -f ~/web/nodejs.org/docs/latest &&\
224 ln -s $(VERSION) ~/web/nodejs.org/docs/latest &&\
225 rm -f ~/web/nodejs.org/dist/node-latest.tar.gz &&\
226 ln -s $(VERSION)/node-$(VERSION).tar.gz ~/web/nodejs.org/dist/node-latest.tar.gz'
228 docopen: out/doc/api/all.html
229 -google-chrome out/doc/api/all.html
234 RAWVER=$(shell $(PYTHON) tools/getnodeversion.py)
236 RELEASE=$(shell $(PYTHON) tools/getnodeisrelease.py)
237 PLATFORM=$(shell uname | tr '[:upper:]' '[:lower:]')
238 ifeq ($(findstring x86_64,$(shell uname -m)),x86_64)
243 ifeq ($(DESTCPU),x64)
246 ifeq ($(DESTCPU),arm)
252 TARNAME=node-$(VERSION)
254 TAG = nightly-$(NIGHTLY)
255 TARNAME=node-$(VERSION)-$(TAG)
257 TARBALL=$(TARNAME).tar.gz
258 BINARYNAME=$(TARNAME)-$(PLATFORM)-$(ARCH)
259 BINARYTAR=$(BINARYNAME).tar.gz
260 PKG=out/$(TARNAME).pkg
261 packagemaker=/Developer/Applications/Utilities/PackageMaker.app/Contents/MacOS/PackageMaker
263 PKGSRC=nodejs-$(DESTCPU)-$(RAWVER).tgz
265 PKGSRC=nodejs-$(DESTCPU)-$(RAWVER)-$(TAG).tgz
268 dist: doc $(TARBALL) $(PKG)
273 @if [ "$(shell git status --porcelain | egrep -v '^\?\? ')" = "" ]; then \
277 echo "The git repository is not clean." >&2 ; \
278 echo "Please commit changes before building release tarball." >&2 ; \
280 git status --porcelain | egrep -v '^\?\?' >&2 ; \
284 @if [ "$(NIGHTLY)" != "" -o "$(RELEASE)" = "1" ]; then \
288 echo "#NODE_VERSION_IS_RELEASE is set to $(RELEASE)." >&2 ; \
289 echo "Did you remember to update src/node_version.cc?" >&2 ; \
298 rm -rf out/deps out/Release
299 $(PYTHON) ./configure --without-snapshot --dest-cpu=ia32 --tag=$(TAG)
300 $(MAKE) install V=$(V) DESTDIR=$(PKGDIR)/32
301 rm -rf out/deps out/Release
302 $(PYTHON) ./configure --without-snapshot --dest-cpu=x64 --tag=$(TAG)
303 $(MAKE) install V=$(V) DESTDIR=$(PKGDIR)
304 SIGN="$(APP_SIGN)" PKGDIR="$(PKGDIR)" bash tools/osx-codesign.sh
305 lipo $(PKGDIR)/32/usr/local/bin/node \
306 $(PKGDIR)/usr/local/bin/node \
307 -output $(PKGDIR)/usr/local/bin/node-universal \
309 mv $(PKGDIR)/usr/local/bin/node-universal $(PKGDIR)/usr/local/bin/node
312 --id "org.nodejs.Node" \
313 --doc tools/osx-pkg.pmdoc \
315 SIGN="$(INT_SIGN)" PKG="$(PKG)" bash tools/osx-productsign.sh
317 $(TARBALL): release-only node doc
318 git archive --format=tar --prefix=$(TARNAME)/ HEAD | tar xf -
319 mkdir -p $(TARNAME)/doc/api
320 cp doc/node.1 $(TARNAME)/doc/node.1
321 cp -r out/doc/api/* $(TARNAME)/doc/api/
322 rm -rf $(TARNAME)/deps/v8/test # too big
323 rm -rf $(TARNAME)/doc/images # too big
324 find $(TARNAME)/ -type l | xargs rm # annoying on windows
325 tar -cf $(TARNAME).tar $(TARNAME)
327 gzip -f -9 $(TARNAME).tar
331 $(BINARYTAR): release-only
333 rm -rf out/deps out/Release
334 $(PYTHON) ./configure --prefix=/ --without-snapshot --dest-cpu=$(DESTCPU) --tag=$(TAG) $(CONFIG_FLAGS)
335 $(MAKE) install DESTDIR=$(BINARYNAME) V=$(V) PORTABLE=1
336 cp README.md $(BINARYNAME)
337 cp LICENSE $(BINARYNAME)
338 cp ChangeLog $(BINARYNAME)
339 tar -cf $(BINARYNAME).tar $(BINARYNAME)
341 gzip -f -9 $(BINARYNAME).tar
345 $(PKGSRC): release-only
347 $(PYTHON) configure --prefix=/ --without-snapshot \
348 --dest-cpu=$(DESTCPU) --tag=$(TAG) $(CONFIG_FLAGS)
349 $(MAKE) install DESTDIR=dist
350 (cd dist; find * -type f | sort) > packlist
351 pkg_info -X pkg_install | \
352 egrep '^(MACHINE_ARCH|OPSYS|OS_VERSION|PKGTOOLS_VERSION)' > build-info
353 pkg_create -B build-info -c tools/pkgsrc/comment -d tools/pkgsrc/description \
354 -f packlist -I /opt/local -p dist -U $(PKGSRC)
358 dist-upload: $(TARBALL) $(PKG)
359 ssh node@nodejs.org mkdir -p web/nodejs.org/dist/$(VERSION)
360 scp $(TARBALL) node@nodejs.org:~/web/nodejs.org/dist/$(VERSION)/$(TARBALL)
361 scp $(PKG) node@nodejs.org:~/web/nodejs.org/dist/$(VERSION)/$(TARNAME).pkg
364 $(MAKE) -C tools/wrk/ clean
369 $(MAKE) -C tools/wrk/
372 @$(NODE) benchmark/common.js net
375 @$(NODE) benchmark/common.js crypto
378 @$(NODE) benchmark/common.js tls
381 @$(NODE) benchmark/common.js http
384 @$(NODE) benchmark/common.js fs
387 @$(MAKE) -C benchmark/misc/function_call/
388 @$(NODE) benchmark/common.js misc
391 @$(NODE) benchmark/common.js arrays
394 @$(NODE) benchmark/common.js buffers
396 bench-all: bench bench-misc bench-array bench-buffer
398 bench: bench-net bench-http bench-fs bench-tls
401 benchmark/http_simple_bench.sh
404 ./node benchmark/idle_server.js &
406 ./node benchmark/idle_clients.js &
409 PYTHONPATH=tools/closure_linter/ $(PYTHON) tools/closure_linter/closure_linter/fixjsstyle.py --strict --nojsdoc -r lib/ -r src/ --exclude_files lib/punycode.js
412 PYTHONPATH=tools/closure_linter/ $(PYTHON) tools/closure_linter/closure_linter/gjslint.py --unix_mode --strict --nojsdoc -r lib/ -r src/ --exclude_files lib/punycode.js
415 CPPLINT_EXCLUDE += src/node_dtrace.cc
416 CPPLINT_EXCLUDE += src/node_dtrace.cc
417 CPPLINT_EXCLUDE += src/node_root_certs.h
418 CPPLINT_EXCLUDE += src/node_win32_perfctr_provider.cc
419 CPPLINT_EXCLUDE += src/queue.h
420 CPPLINT_EXCLUDE += src/tree.h
421 CPPLINT_EXCLUDE += src/v8abbr.h
423 CPPLINT_FILES = $(filter-out $(CPPLINT_EXCLUDE), $(wildcard src/*.cc src/*.h src/*.c tools/icu/*.h tools/icu/*.cc deps/debugger-agent/include/* deps/debugger-agent/src/*))
426 @$(PYTHON) tools/cpplint.py $(CPPLINT_FILES)
430 .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