11 EXEEXT := $(shell $(PYTHON) -c \
12 "import sys; print('.exe' if sys.platform == 'win32' else '')")
14 NODE ?= ./iojs$(EXEEXT)
15 NODE_EXE = iojs$(EXEEXT)
16 NODE_G_EXE = iojs_g$(EXEEXT)
18 # Default to verbose builds.
19 # To do quiet/pretty builds, run `make V=` to set V to an empty string,
20 # or set the V environment variable to an empty string.
30 # BUILDTYPE=Debug builds both release and debug builds. If you want to compile
31 # just the debug build, run `make -C out BUILDTYPE=Debug` instead.
32 ifeq ($(BUILDTYPE),Release)
33 all: out/Makefile $(NODE_EXE)
35 all: out/Makefile $(NODE_EXE) $(NODE_G_EXE)
38 # The .PHONY is needed to ensure that we recursively use the out/Makefile
39 # to check for changes.
40 .PHONY: $(NODE_EXE) $(NODE_G_EXE)
43 $(NODE_EXE): config.gypi
44 $(NINJA) -C out/Release/
45 ln -fs out/Release/$(NODE_EXE) $@
47 $(NODE_G_EXE): config.gypi
48 $(NINJA) -C out/Debug/
49 ln -fs out/Debug/$(NODE_EXE) $@
51 $(NODE_EXE): config.gypi out/Makefile
52 $(MAKE) -C out BUILDTYPE=Release V=$(V)
53 ln -fs out/Release/$(NODE_EXE) $@
55 $(NODE_G_EXE): config.gypi out/Makefile
56 $(MAKE) -C out BUILDTYPE=Debug V=$(V)
57 ln -fs out/Debug/$(NODE_EXE) $@
60 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
63 $(PYTHON) tools/gyp_node.py -f ninja
65 $(PYTHON) tools/gyp_node.py -f make
68 config.gypi: configure
70 $(error Stale $@, please re-run ./configure)
72 $(error No $@, please run ./configure first)
76 $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
79 $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
82 -rm -rf out/Makefile $(NODE_EXE) $(NODE_G_EXE) out/$(BUILDTYPE)/$(NODE_EXE) blog.html email.md
83 @if [ -d out ]; then find out/ -name '*.o' -o -name '*.a' | xargs rm -rf; fi
88 -rm -f config.gypi icu_config.gypi
90 -rm -rf $(NODE_EXE) $(NODE_G_EXE) blog.html email.md
93 -rm -rf deps/icu4c*.tgz deps/icu4c*.zip deps/icu-tmp
96 $(PYTHON) tools/test.py --mode=release message parallel sequential -J
101 $(PYTHON) tools/test.py --mode=release parallel -J
104 $(PYTHON) tools/test.py --mode=release --valgrind sequential parallel message
106 test/gc/node_modules/weak/build/Release/weakref.node: $(NODE_EXE)
107 ./$(NODE_EXE) deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \
108 --directory="$(shell pwd)/test/gc/node_modules/weak" \
109 --nodedir="$(shell pwd)"
111 build-addons: $(NODE_EXE)
112 rm -rf test/addons/doc-*/
113 ./$(NODE_EXE) tools/doc/addon-verify.js
115 $(sort $(dir $(wildcard test/addons/*/*.gyp))), \
116 ./$(NODE_EXE) deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \
117 --directory="$(shell pwd)/$(dir)" \
118 --nodedir="$(shell pwd)" && ) echo "build done"
120 test-gc: all test/gc/node_modules/weak/build/Release/weakref.node
121 $(PYTHON) tools/test.py --mode=release gc
123 test-build: all build-addons
125 test-all: test-build test/gc/node_modules/weak/build/Release/weakref.node
126 $(PYTHON) tools/test.py --mode=debug,release
128 test-all-valgrind: test-build
129 $(PYTHON) tools/test.py --mode=debug,release --valgrind
132 $(PYTHON) tools/test.py -J parallel sequential message addons
134 test-release: test-build
135 $(PYTHON) tools/test.py --mode=release
137 test-debug: test-build
138 $(PYTHON) tools/test.py --mode=debug
140 test-message: test-build
141 $(PYTHON) tools/test.py message
144 $(PYTHON) tools/test.py parallel sequential
147 $(PYTHON) tools/test.py pummel
150 $(PYTHON) tools/test.py internet
153 $(PYTHON) tools/test.py debugger
155 test-npm: $(NODE_EXE)
156 rm -rf npm-cache npm-tmp npm-prefix
157 mkdir npm-cache npm-tmp npm-prefix
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_EXE) cli.js install --ignore-scripts
162 cd deps/npm ; npm_config_cache="$(shell pwd)/npm-cache" \
163 npm_config_prefix="$(shell pwd)/npm-prefix" \
164 npm_config_tmp="$(shell pwd)/npm-tmp" \
165 ../../$(NODE_EXE) cli.js run-script test-all && \
166 ../../$(NODE_EXE) cli.js prune --prod && \
168 rm -rf npm-cache npm-tmp npm-prefix
170 test-npm-publish: $(NODE_EXE)
171 npm_package_config_publishtest=true ./$(NODE_EXE) deps/npm/test/run.js
173 test-addons: test-build
174 $(PYTHON) tools/test.py --mode=release addons
177 $(MAKE) --directory=tools faketime
178 $(PYTHON) tools/test.py --mode=release timers
181 $(MAKE) --directory=tools clean
183 apidoc_sources = $(wildcard doc/api/*.markdown)
184 apidocs = $(addprefix out/,$(apidoc_sources:.markdown=.html)) \
185 $(addprefix out/,$(apidoc_sources:.markdown=.json))
187 apidoc_dirs = out/doc out/doc/api/ out/doc/api/assets
189 apiassets = $(subst api_assets,api/assets,$(addprefix out/,$(wildcard doc/api_assets/*)))
193 out/doc/sh_javascript.min.js
195 doc: $(apidoc_dirs) $(website_files) $(apiassets) $(apidocs) tools/doc/ $(NODE_EXE)
200 out/doc/api/assets/%: doc/api_assets/% out/doc/api/assets/
203 out/doc/changelog.html: CHANGELOG.md doc/changelog-head.html doc/changelog-foot.html tools/build-changelog.sh $(NODE_EXE)
204 bash tools/build-changelog.sh
209 out/doc/api/%.json: doc/api/%.markdown $(NODE_EXE)
210 out/Release/$(NODE_EXE) tools/doc/generate.js --format=json $< > $@
212 out/doc/api/%.html: doc/api/%.markdown $(NODE_EXE)
213 out/Release/$(NODE_EXE) tools/doc/generate.js --format=html --template=doc/template.html $< > $@
215 email.md: CHANGELOG.md tools/email-footer.md
216 bash tools/changelog-head.sh | sed 's|^\* #|* \\#|g' > $@
217 cat tools/email-footer.md | sed -e 's|__VERSION__|'$(VERSION)'|g' >> $@
220 cat $< | ./$(NODE_EXE) tools/doc/node_modules/.bin/marked > $@
222 docopen: out/doc/api/all.html
223 -google-chrome out/doc/api/all.html
228 RAWVER=$(shell $(PYTHON) tools/getnodeversion.py)
230 RELEASE=$(shell $(PYTHON) tools/getnodeisrelease.py)
231 PLATFORM=$(shell uname | tr '[:upper:]' '[:lower:]')
232 ifeq ($(findstring x86_64,$(shell uname -m)),x86_64)
237 ifeq ($(DESTCPU),x64)
240 ifeq ($(DESTCPU),arm)
246 TARNAME=iojs-$(VERSION)
248 TAG = nightly-$(NIGHTLY)
249 TARNAME=iojs-$(VERSION)-$(TAG)
251 TARBALL=$(TARNAME).tar
252 BINARYNAME=$(TARNAME)-$(PLATFORM)-$(ARCH)
253 BINARYTAR=$(BINARYNAME).tar
254 XZ=$(shell which xz > /dev/null 2>&1; echo $$?)
255 PKG=out/$(TARNAME).pkg
256 packagemaker=/Developer/Applications/Utilities/PackageMaker.app/Contents/MacOS/PackageMaker
258 PKGSRC=iojs-$(DESTCPU)-$(RAWVER).tgz
260 PKGSRC=iojs-$(DESTCPU)-$(RAWVER)-$(TAG).tgz
263 dist: doc $(TARBALL) $(PKG)
268 @if [ "$(shell git status --porcelain | egrep -v '^\?\? ')" = "" ]; then \
272 echo "The git repository is not clean." >&2 ; \
273 echo "Please commit changes before building release tarball." >&2 ; \
275 git status --porcelain | egrep -v '^\?\?' >&2 ; \
279 @if [ "$(NIGHTLY)" != "" -o "$(RELEASE)" = "1" ]; then \
283 echo "#NODE_VERSION_IS_RELEASE is set to $(RELEASE)." >&2 ; \
284 echo "Did you remember to update src/node_version.cc?" >&2 ; \
293 rm -rf out/deps out/Release
294 $(PYTHON) ./configure --without-snapshot --dest-cpu=ia32 --tag=$(TAG)
295 $(MAKE) install V=$(V) DESTDIR=$(PKGDIR)/32
296 rm -rf out/deps out/Release
297 $(PYTHON) ./configure --without-snapshot --dest-cpu=x64 --tag=$(TAG)
298 $(MAKE) install V=$(V) DESTDIR=$(PKGDIR)
299 SIGN="$(APP_SIGN)" PKGDIR="$(PKGDIR)" bash tools/osx-codesign.sh
300 lipo $(PKGDIR)/32/usr/local/bin/iojs \
301 $(PKGDIR)/usr/local/bin/iojs \
302 -output $(PKGDIR)/usr/local/bin/iojs-universal \
304 mv $(PKGDIR)/usr/local/bin/iojs-universal $(PKGDIR)/usr/local/bin/iojs
307 --id "org.nodejs.Node" \
308 --doc tools/osx-pkg.pmdoc \
310 SIGN="$(INT_SIGN)" PKG="$(PKG)" bash tools/osx-productsign.sh
312 $(TARBALL): release-only $(NODE_EXE) doc
313 git archive --format=tar --prefix=$(TARNAME)/ HEAD | tar xf -
314 mkdir -p $(TARNAME)/doc/api
315 cp doc/iojs.1 $(TARNAME)/doc/iojs.1
316 cp -r out/doc/api/* $(TARNAME)/doc/api/
317 rm -rf $(TARNAME)/deps/v8/test # too big
318 rm -rf $(TARNAME)/doc/images # too big
319 rm -rf $(TARNAME)/deps/zlib/contrib # too big, unused
320 find $(TARNAME)/ -type l | xargs rm # annoying on windows
321 tar -cf $(TARNAME).tar $(TARNAME)
323 gzip -c -f -9 $(TARNAME).tar > $(TARNAME).tar.gz
325 xz -c -f -9 $(TARNAME).tar > $(TARNAME).tar.xz
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.md $(BINARYNAME)
339 tar -cf $(BINARYNAME).tar $(BINARYNAME)
341 gzip -c -f -9 $(BINARYNAME).tar > $(BINARYNAME).tar.gz
343 xz -c -f -9 $(BINARYNAME).tar > $(BINARYNAME).tar.xz
349 $(PKGSRC): release-only
351 $(PYTHON) configure --prefix=/ --without-snapshot \
352 --dest-cpu=$(DESTCPU) --tag=$(TAG) $(CONFIG_FLAGS)
353 $(MAKE) install DESTDIR=dist
354 (cd dist; find * -type f | sort) > packlist
355 pkg_info -X pkg_install | \
356 egrep '^(MACHINE_ARCH|OPSYS|OS_VERSION|PKGTOOLS_VERSION)' > build-info
357 pkg_create -B build-info -c tools/pkgsrc/comment -d tools/pkgsrc/description \
358 -f packlist -I /opt/local -p dist -U $(PKGSRC)
363 $(MAKE) -C tools/wrk/ clean
368 $(MAKE) -C tools/wrk/
371 @$(NODE) benchmark/common.js net
374 @$(NODE) benchmark/common.js crypto
377 @$(NODE) benchmark/common.js tls
380 @$(NODE) benchmark/common.js http
383 @$(NODE) benchmark/common.js fs
386 @$(MAKE) -C benchmark/misc/function_call/
387 @$(NODE) benchmark/common.js misc
390 @$(NODE) benchmark/common.js arrays
393 @$(NODE) benchmark/common.js buffers
395 bench-all: bench bench-misc bench-array bench-buffer
397 bench: bench-net bench-http bench-fs bench-tls
400 benchmark/http_simple_bench.sh
403 ./$(NODE_EXE) benchmark/idle_server.js &
405 ./$(NODE_EXE) benchmark/idle_clients.js &
408 PYTHONPATH=tools/closure_linter/ $(PYTHON) tools/closure_linter/closure_linter/fixjsstyle.py --strict --nojsdoc -r lib/ -r src/ --exclude_files lib/punycode.js
411 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
414 CPPLINT_EXCLUDE += src/node_dtrace.cc
415 CPPLINT_EXCLUDE += src/node_dtrace.cc
416 CPPLINT_EXCLUDE += src/node_root_certs.h
417 CPPLINT_EXCLUDE += src/node_win32_perfctr_provider.cc
418 CPPLINT_EXCLUDE += src/queue.h
419 CPPLINT_EXCLUDE += src/tree.h
420 CPPLINT_EXCLUDE += src/v8abbr.h
422 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/*))
425 @$(PYTHON) tools/cpplint.py $(CPPLINT_FILES)
429 .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