10 EXEEXT := $(shell $(PYTHON) -c \
11 "import sys; print('.exe' if sys.platform == 'win32' else '')")
13 NODE ?= ./iojs$(EXEEXT)
14 NODE_EXE = iojs$(EXEEXT)
15 NODE_G_EXE = iojs_g$(EXEEXT)
17 # Default to verbose builds.
18 # To do quiet/pretty builds, run `make V=` to set V to an empty string,
19 # or set the V environment variable to an empty string.
22 # BUILDTYPE=Debug builds both release and debug builds. If you want to compile
23 # just the debug build, run `make -C out BUILDTYPE=Debug` instead.
24 ifeq ($(BUILDTYPE),Release)
25 all: out/Makefile $(NODE_EXE)
27 all: out/Makefile $(NODE_EXE) $(NODE_G_EXE)
30 # The .PHONY is needed to ensure that we recursively use the out/Makefile
31 # to check for changes.
32 .PHONY: $(NODE_EXE) $(NODE_G_EXE)
34 $(NODE_EXE): config.gypi out/Makefile
35 $(MAKE) -C out BUILDTYPE=Release V=$(V)
36 ln -fs out/Release/$(NODE_EXE) $@
38 $(NODE_G_EXE): config.gypi out/Makefile
39 $(MAKE) -C out BUILDTYPE=Debug V=$(V)
40 ln -fs out/Debug/$(NODE_EXE) $@
42 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
43 $(PYTHON) tools/gyp_node.py -f make
45 config.gypi: configure
47 $(error Stale $@, please re-run ./configure)
49 $(error No $@, please run ./configure first)
53 $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
56 $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
59 -rm -rf out/Makefile $(NODE_EXE) $(NODE_G_EXE) out/$(BUILDTYPE)/$(NODE_EXE) blog.html email.md
60 @if [ -d out ]; then find out/ -name '*.o' -o -name '*.a' | xargs rm -rf; fi
65 -rm -f config.gypi icu_config.gypi
67 -rm -rf $(NODE_EXE) $(NODE_G_EXE) blog.html email.md
70 -rm -rf deps/icu4c*.tgz deps/icu4c*.zip deps/icu-tmp
71 -rm -f $(BINARYTAR).* $(TARBALL).*
78 test: | cctest # Depends on 'all'.
79 $(PYTHON) tools/test.py --mode=release message parallel sequential -J
84 $(PYTHON) tools/test.py --mode=release parallel -J
87 $(PYTHON) tools/test.py --mode=release --valgrind sequential parallel message
89 test/gc/node_modules/weak/build/Release/weakref.node: $(NODE_EXE)
90 ./$(NODE_EXE) deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \
91 --directory="$(shell pwd)/test/gc/node_modules/weak" \
92 --nodedir="$(shell pwd)"
94 build-addons: $(NODE_EXE)
95 rm -rf test/addons/doc-*/
96 ./$(NODE_EXE) tools/doc/addon-verify.js
98 $(sort $(dir $(wildcard test/addons/*/*.gyp))), \
99 ./$(NODE_EXE) deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \
100 --directory="$(shell pwd)/$(dir)" \
101 --nodedir="$(shell pwd)" && ) echo "build done"
103 test-gc: all test/gc/node_modules/weak/build/Release/weakref.node
104 $(PYTHON) tools/test.py --mode=release gc
106 test-build: all build-addons
108 test-all: test-build test/gc/node_modules/weak/build/Release/weakref.node
109 $(PYTHON) tools/test.py --mode=debug,release
111 test-all-valgrind: test-build
112 $(PYTHON) tools/test.py --mode=debug,release --valgrind
115 $(PYTHON) tools/test.py -p tap --logfile test.tap --mode=release message parallel sequential
119 test-release: test-build
120 $(PYTHON) tools/test.py --mode=release
122 test-debug: test-build
123 $(PYTHON) tools/test.py --mode=debug
125 test-message: test-build
126 $(PYTHON) tools/test.py message
128 test-simple: | cctest # Depends on 'all'.
129 $(PYTHON) tools/test.py parallel sequential
132 $(PYTHON) tools/test.py pummel
135 $(PYTHON) tools/test.py internet
138 $(PYTHON) tools/test.py debugger
140 test-npm: $(NODE_EXE)
141 rm -rf npm-cache npm-tmp npm-prefix
142 mkdir npm-cache npm-tmp npm-prefix
143 cd deps/npm ; npm_config_cache="$(shell pwd)/npm-cache" \
144 npm_config_prefix="$(shell pwd)/npm-prefix" \
145 npm_config_tmp="$(shell pwd)/npm-tmp" \
146 ../../$(NODE_EXE) cli.js install --ignore-scripts
147 cd deps/npm ; npm_config_cache="$(shell pwd)/npm-cache" \
148 npm_config_prefix="$(shell pwd)/npm-prefix" \
149 npm_config_tmp="$(shell pwd)/npm-tmp" \
150 ../../$(NODE_EXE) cli.js run-script test-all && \
151 ../../$(NODE_EXE) cli.js prune --prod && \
153 rm -rf npm-cache npm-tmp npm-prefix
155 test-npm-publish: $(NODE_EXE)
156 npm_package_config_publishtest=true ./$(NODE_EXE) deps/npm/test/run.js
158 test-addons: test-build
159 $(PYTHON) tools/test.py --mode=release addons
162 $(MAKE) --directory=tools faketime
163 $(PYTHON) tools/test.py --mode=release timers
166 $(MAKE) --directory=tools clean
168 apidoc_sources = $(wildcard doc/api/*.markdown)
169 apidocs = $(addprefix out/,$(apidoc_sources:.markdown=.html)) \
170 $(addprefix out/,$(apidoc_sources:.markdown=.json))
172 apidoc_dirs = out/doc out/doc/api/ out/doc/api/assets
174 apiassets = $(subst api_assets,api/assets,$(addprefix out/,$(wildcard doc/api_assets/*)))
176 doc: $(apidoc_dirs) $(apiassets) $(apidocs) tools/doc/ $(NODE_EXE)
181 out/doc/api/assets/%: doc/api_assets/% out/doc/api/assets/
187 out/doc/api/%.json: doc/api/%.markdown $(NODE_EXE)
188 out/Release/$(NODE_EXE) tools/doc/generate.js --format=json $< > $@
190 out/doc/api/%.html: doc/api/%.markdown $(NODE_EXE)
191 out/Release/$(NODE_EXE) tools/doc/generate.js --format=html --template=doc/template.html $< > $@
193 docopen: out/doc/api/all.html
194 -google-chrome out/doc/api/all.html
199 RAWVER=$(shell $(PYTHON) tools/getnodeversion.py)
201 FULLVERSION=$(VERSION)
202 RELEASE=$(shell sed -ne 's/\#define NODE_VERSION_IS_RELEASE \([01]\)/\1/p' src/node_version.h)
203 PLATFORM=$(shell uname | tr '[:upper:]' '[:lower:]')
204 NPMVERSION=v$(shell cat deps/npm/package.json | grep '"version"' | sed 's/^[^:]*: "\([^"]*\)",.*/\1/')
205 ifeq ($(findstring x86_64,$(shell uname -m)),x86_64)
210 ifeq ($(DESTCPU),x64)
213 ifeq ($(DESTCPU),arm)
220 TAG = nightly-$(NIGHTLY)
221 FULLVERSION=$(VERSION)-$(TAG)
223 TARNAME=iojs-$(FULLVERSION)
224 TARBALL=$(TARNAME).tar
225 BINARYNAME=$(TARNAME)-$(PLATFORM)-$(ARCH)
226 BINARYTAR=$(BINARYNAME).tar
227 XZ=$(shell which xz > /dev/null 2>&1; echo $$?)
229 PKG=out/$(TARNAME).pkg
230 PACKAGEMAKER ?= /Developer/Applications/Utilities/PackageMaker.app/Contents/MacOS/PackageMaker
232 PKGSRC=iojs-$(DESTCPU)-$(RAWVER).tgz
234 PKGSRC=iojs-$(DESTCPU)-$(RAWVER)-$(TAG).tgz
237 dist: doc $(TARBALL) $(PKG)
242 @if [ "$(shell git status --porcelain | egrep -v '^\?\? ')" = "" ]; then \
246 echo "The git repository is not clean." >&2 ; \
247 echo "Please commit changes before building release tarball." >&2 ; \
249 git status --porcelain | egrep -v '^\?\?' >&2 ; \
253 @if [ "$(NIGHTLY)" != "" -o "$(RELEASE)" = "1" ]; then \
257 echo "#NODE_VERSION_IS_RELEASE is set to $(RELEASE)." >&2 ; \
258 echo "Did you remember to update src/node_version.h?" >&2 ; \
267 rm -rf out/deps out/Release
268 $(PYTHON) ./configure --dest-cpu=ia32 --tag=$(TAG)
269 $(MAKE) install V=$(V) DESTDIR=$(PKGDIR)/32
270 rm -rf out/deps out/Release
271 $(PYTHON) ./configure --dest-cpu=x64 --tag=$(TAG)
272 $(MAKE) install V=$(V) DESTDIR=$(PKGDIR)
273 SIGN="$(APP_SIGN)" PKGDIR="$(PKGDIR)" bash tools/osx-codesign.sh
274 lipo $(PKGDIR)/32/usr/local/bin/iojs \
275 $(PKGDIR)/usr/local/bin/iojs \
276 -output $(PKGDIR)/usr/local/bin/iojs-universal \
278 mv $(PKGDIR)/usr/local/bin/iojs-universal $(PKGDIR)/usr/local/bin/iojs
280 cat tools/osx-pkg.pmdoc/index.xml.tmpl | sed -e 's|__iojsversion__|'$(FULLVERSION)'|g' | sed -e 's|__npmversion__|'$(NPMVERSION)'|g' > tools/osx-pkg.pmdoc/index.xml
282 --id "org.nodejs.Node" \
283 --doc tools/osx-pkg.pmdoc \
285 SIGN="$(INT_SIGN)" PKG="$(PKG)" bash tools/osx-productsign.sh
287 $(TARBALL): release-only $(NODE_EXE) doc
288 git checkout-index -a -f --prefix=$(TARNAME)/
289 mkdir -p $(TARNAME)/doc/api
290 cp doc/iojs.1 $(TARNAME)/doc/iojs.1
291 cp -r out/doc/api/* $(TARNAME)/doc/api/
292 rm -rf $(TARNAME)/deps/v8/{test,samples,tools/profviz} # too big
293 rm -rf $(TARNAME)/doc/images # too big
294 rm -rf $(TARNAME)/deps/uv/{docs,samples,test}
295 rm -rf $(TARNAME)/deps/openssl/{doc,demos,test}
296 rm -rf $(TARNAME)/deps/zlib/contrib # too big, unused
297 find $(TARNAME)/ -type l | xargs rm # annoying on windows
298 tar -cf $(TARNAME).tar $(TARNAME)
300 gzip -c -f -9 $(TARNAME).tar > $(TARNAME).tar.gz
302 xz -c -f -$(XZ_COMPRESSION) $(TARNAME).tar > $(TARNAME).tar.xz
308 $(BINARYTAR): release-only
310 rm -rf out/deps out/Release
311 $(PYTHON) ./configure --prefix=/ --dest-cpu=$(DESTCPU) --tag=$(TAG) $(CONFIG_FLAGS)
312 $(MAKE) install DESTDIR=$(BINARYNAME) V=$(V) PORTABLE=1
313 cp README.md $(BINARYNAME)
314 cp LICENSE $(BINARYNAME)
315 cp CHANGELOG.md $(BINARYNAME)
316 tar -cf $(BINARYNAME).tar $(BINARYNAME)
318 gzip -c -f -9 $(BINARYNAME).tar > $(BINARYNAME).tar.gz
320 xz -c -f -$(XZ_COMPRESSION) $(BINARYNAME).tar > $(BINARYNAME).tar.xz
326 $(PKGSRC): release-only
328 $(PYTHON) configure --prefix=/ \
329 --dest-cpu=$(DESTCPU) --tag=$(TAG) $(CONFIG_FLAGS)
330 $(MAKE) install DESTDIR=dist
331 (cd dist; find * -type f | sort) > packlist
332 pkg_info -X pkg_install | \
333 egrep '^(MACHINE_ARCH|OPSYS|OS_VERSION|PKGTOOLS_VERSION)' > build-info
334 pkg_create -B build-info -c tools/pkgsrc/comment -d tools/pkgsrc/description \
335 -f packlist -I /opt/local -p dist -U $(PKGSRC)
339 haswrk=$(shell which wrk > /dev/null 2>&1; echo $$?)
342 @echo "please install wrk before proceeding. More information can be found in benchmark/README.md." >&2
347 @$(NODE) benchmark/common.js net
350 @$(NODE) benchmark/common.js crypto
353 @$(NODE) benchmark/common.js tls
356 @$(NODE) benchmark/common.js http
359 @$(NODE) benchmark/common.js fs
362 @$(MAKE) -C benchmark/misc/function_call/
363 @$(NODE) benchmark/common.js misc
366 @$(NODE) benchmark/common.js arrays
369 @$(NODE) benchmark/common.js buffers
372 @$(NODE) benchmark/common.js url
375 @$(NODE) benchmark/common.js events
377 bench-all: bench bench-misc bench-array bench-buffer bench-url bench-events
379 bench: bench-net bench-http bench-fs bench-tls
382 benchmark/http_simple_bench.sh
385 ./$(NODE_EXE) benchmark/idle_server.js &
387 ./$(NODE_EXE) benchmark/idle_clients.js &
390 ./$(NODE_EXE) tools/eslint/bin/eslint.js src/*.js lib/*.js --reset --quiet
393 CPPLINT_EXCLUDE += src/node_lttng.cc
394 CPPLINT_EXCLUDE += src/node_root_certs.h
395 CPPLINT_EXCLUDE += src/node_lttng_tp.h
396 CPPLINT_EXCLUDE += src/node_win32_perfctr_provider.cc
397 CPPLINT_EXCLUDE += src/queue.h
398 CPPLINT_EXCLUDE += src/tree.h
399 CPPLINT_EXCLUDE += src/v8abbr.h
401 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/*))
404 @$(PYTHON) tools/cpplint.py $(CPPLINT_FILES)
408 .PHONY: lint cpplint jslint bench clean docopen docclean doc dist distclean \
409 check uninstall install install-includes install-bin all staticlib \
410 dynamiclib test test-all test-addons build-addons website-upload pkg \
411 blog blogclean tar binary release-only bench-http-simple bench-idle \
412 bench-all bench bench-misc bench-array bench-buffer bench-net \
413 bench-http bench-fs bench-tls cctest