build: determine and use EXEEXT on windows
[platform/upstream/nodejs.git] / Makefile
1 -include config.mk
2
3 BUILDTYPE ?= Release
4 PYTHON ?= python
5 NINJA ?= ninja
6 DESTDIR ?=
7 SIGN ?=
8 PREFIX ?= /usr/local
9
10 # Determine EXEEXT
11 EXEEXT=$(shell $(PYTHON) -c "import sysconfig; print(sysconfig.get_config_var('EXE'))")
12
13 NODE ?= ./node$(EXEEXT)
14 NODE_EXE = node$(EXEEXT)
15 NODE_G_EXE = node_g$(EXEEXT)
16
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.
20 V ?= 1
21
22 ifeq ($(USE_NINJA),1)
23 ifneq ($(V),)
24 NINJA := $(NINJA) -v
25 endif
26 endif
27
28 # BUILDTYPE=Debug builds both release and debug builds. If you want to compile
29 # just the debug build, run `make -C out BUILDTYPE=Debug` instead.
30 ifeq ($(BUILDTYPE),Release)
31 all: out/Makefile $(NODE_EXE)
32 else
33 all: out/Makefile $(NODE_EXE) $(NODE_G_EXE)
34 endif
35
36 # The .PHONY is needed to ensure that we recursively use the out/Makefile
37 # to check for changes.
38 .PHONY: $(NODE_EXE) $(NODE_G_EXE)
39
40 ifeq ($(USE_NINJA),1)
41 $(NODE_EXE): config.gypi
42         $(NINJA) -C out/Release/
43         ln -fs out/Release/$(NODE_EXE) $@
44
45 $(NODE_G_EXE): config.gypi
46         $(NINJA) -C out/Debug/
47         ln -fs out/Debug/$(NODE_EXE) $@
48 else
49 $(NODE_EXE): config.gypi out/Makefile
50         $(MAKE) -C out BUILDTYPE=Release V=$(V)
51         ln -fs out/Release/$(NODE_EXE) $@
52
53 $(NODE_G_EXE): config.gypi out/Makefile
54         $(MAKE) -C out BUILDTYPE=Debug V=$(V)
55         ln -fs out/Debug/$(NODE_EXE) $@
56 endif
57
58 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
59 ifeq ($(USE_NINJA),1)
60         touch out/Makefile
61         $(PYTHON) tools/gyp_node.py -f ninja
62 else
63         $(PYTHON) tools/gyp_node.py -f make
64 endif
65
66 config.gypi: configure
67         if [ -f $@ ]; then
68                 $(error Stale $@, please re-run ./configure)
69         else
70                 $(error No $@, please run ./configure first)
71         fi
72
73 install: all
74         $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
75
76 uninstall:
77         $(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
78
79 clean:
80         -rm -rf out/Makefile $(NODE_EXE) $(NODE_G_EXE) out/$(BUILDTYPE)/$(NODE_EXE) blog.html email.md
81         -find out/ -name '*.o' -o -name '*.a' | xargs rm -rf
82         -rm -rf node_modules
83
84 distclean:
85         -rm -rf out
86         -rm -f config.gypi
87         -rm -f config.mk
88         -rm -rf $(NODE_EXE) $(NODE_G_EXE) blog.html email.md
89         -rm -rf node_modules
90
91 test: all
92         $(PYTHON) tools/test.py --mode=release simple message
93         $(MAKE) jslint
94         $(MAKE) cpplint
95
96 test-http1: all
97         $(PYTHON) tools/test.py --mode=release --use-http1 simple message
98
99 test-valgrind: all
100         $(PYTHON) tools/test.py --mode=release --valgrind simple message
101
102 test/gc/node_modules/weak/build/Release/weakref.node:
103         @if [ ! -f $(NODE_EXE) ]; then make all; fi
104         ./$(NODE_EXE) deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \
105                 --directory="$(shell pwd)/test/gc/node_modules/weak" \
106                 --nodedir="$(shell pwd)"
107
108 build-addons:
109         @if [ ! -f node ]; then make all; fi
110         rm -rf test/addons/doc-*/
111         ./node tools/doc/addon-verify.js
112         $(foreach dir, \
113                         $(sort $(dir $(wildcard test/addons/*/*.gyp))), \
114                         ./node deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \
115                                         --directory="$(shell pwd)/$(dir)" \
116                                         --nodedir="$(shell pwd)" && ) echo "build done"
117
118 test-gc: all test/gc/node_modules/weak/build/Release/weakref.node
119         $(PYTHON) tools/test.py --mode=release gc
120
121 test-build: all build-addons
122
123 test-all: test-build test/gc/node_modules/weak/build/Release/weakref.node
124         $(PYTHON) tools/test.py --mode=debug,release
125         make test-npm
126
127 test-all-http1: test-build
128         $(PYTHON) tools/test.py --mode=debug,release --use-http1
129
130 test-all-valgrind: test-build
131         $(PYTHON) tools/test.py --mode=debug,release --valgrind
132
133 test-release: test-build
134         $(PYTHON) tools/test.py --mode=release
135
136 test-debug: test-build
137         $(PYTHON) tools/test.py --mode=debug
138
139 test-message: test-build
140         $(PYTHON) tools/test.py message
141
142 test-simple: all
143         $(PYTHON) tools/test.py simple
144
145 test-pummel: all wrk
146         $(PYTHON) tools/test.py pummel
147
148 test-internet: all
149         $(PYTHON) tools/test.py internet
150
151 test-debugger: all
152         $(PYTHON) tools/test.py debugger
153
154 test-npm: $(NODE_EXE)
155         ./$(NODE_EXE) deps/npm/test/run.js
156
157 test-npm-publish: $(NODE_EXE)
158         npm_package_config_publishtest=true ./$(NODE_EXE) deps/npm/test/run.js
159
160 test-addons: test-build
161         $(PYTHON) tools/test.py --mode=release addons
162
163 test-timers:
164         $(MAKE) --directory=tools faketime
165         $(PYTHON) tools/test.py --mode=release timers
166
167 test-timers-clean:
168         $(MAKE) --directory=tools clean
169
170 apidoc_sources = $(wildcard doc/api/*.markdown)
171 apidocs = $(addprefix out/,$(apidoc_sources:.markdown=.html)) \
172           $(addprefix out/,$(apidoc_sources:.markdown=.json))
173
174 apidoc_dirs = out/doc out/doc/api/ out/doc/api/assets
175
176 apiassets = $(subst api_assets,api/assets,$(addprefix out/,$(wildcard doc/api_assets/*)))
177
178 website_files = \
179         out/doc/sh_main.js    \
180         out/doc/sh_javascript.min.js
181
182 doc: $(apidoc_dirs) $(website_files) $(apiassets) $(apidocs) tools/doc/ out/doc/changelog.html $(NODE_EXE)
183
184 $(apidoc_dirs):
185         mkdir -p $@
186
187 out/doc/api/assets/%: doc/api_assets/% out/doc/api/assets/
188         cp $< $@
189
190 out/doc/changelog.html: ChangeLog doc/changelog-head.html doc/changelog-foot.html tools/build-changelog.sh $(NODE_EXE)
191         bash tools/build-changelog.sh
192
193 out/doc/%: doc/%
194         cp -r $< $@
195
196 out/doc/api/%.json: doc/api/%.markdown $(NODE_EXE)
197         out/Release/$(NODE_EXE) tools/doc/generate.js --format=json $< > $@
198
199 out/doc/api/%.html: doc/api/%.markdown $(NODE_EXE)
200         out/Release/$(NODE_EXE) tools/doc/generate.js --format=html --template=doc/template.html $< > $@
201
202 email.md: ChangeLog tools/email-footer.md
203         bash tools/changelog-head.sh | sed 's|^\* #|* \\#|g' > $@
204         cat tools/email-footer.md | sed -e 's|__VERSION__|'$(VERSION)'|g' >> $@
205
206 blog.html: email.md
207         cat $< | ./$(NODE_EXE) tools/doc/node_modules/.bin/marked > $@
208
209 website-upload: doc
210         rsync -r out/doc/ node@nodejs.org:~/web/nodejs.org/
211         ssh node@nodejs.org '\
212     rm -f ~/web/nodejs.org/dist/latest &&\
213     ln -s $(VERSION) ~/web/nodejs.org/dist/latest &&\
214     rm -f ~/web/nodejs.org/docs/latest &&\
215     ln -s $(VERSION) ~/web/nodejs.org/docs/latest &&\
216     rm -f ~/web/nodejs.org/dist/node-latest.tar.gz &&\
217     ln -s $(VERSION)/node-$(VERSION).tar.gz ~/web/nodejs.org/dist/node-latest.tar.gz'
218
219 docopen: out/doc/api/all.html
220         -google-chrome out/doc/api/all.html
221
222 docclean:
223         -rm -rf out/doc
224
225 RAWVER=$(shell $(PYTHON) tools/getnodeversion.py)
226 VERSION=v$(RAWVER)
227 RELEASE=$(shell $(PYTHON) tools/getnodeisrelease.py)
228 PLATFORM=$(shell uname | tr '[:upper:]' '[:lower:]')
229 ifeq ($(findstring x86_64,$(shell uname -m)),x86_64)
230 DESTCPU ?= x64
231 else
232 DESTCPU ?= ia32
233 endif
234 ifeq ($(DESTCPU),x64)
235 ARCH=x64
236 else
237 ifeq ($(DESTCPU),arm)
238 ARCH=arm
239 else
240 ARCH=x86
241 endif
242 endif
243 TARNAME=node-$(VERSION)
244 ifdef NIGHTLY
245 TAG = nightly-$(NIGHTLY)
246 TARNAME=node-$(VERSION)-$(TAG)
247 endif
248 TARBALL=$(TARNAME).tar.gz
249 BINARYNAME=$(TARNAME)-$(PLATFORM)-$(ARCH)
250 BINARYTAR=$(BINARYNAME).tar.gz
251 PKG=out/$(TARNAME).pkg
252 packagemaker=/Developer/Applications/Utilities/PackageMaker.app/Contents/MacOS/PackageMaker
253
254 PKGSRC=nodejs-$(DESTCPU)-$(RAWVER).tgz
255 ifdef NIGHTLY
256 PKGSRC=nodejs-$(DESTCPU)-$(RAWVER)-$(TAG).tgz
257 endif
258
259 dist: doc $(TARBALL) $(PKG)
260
261 PKGDIR=out/dist-osx
262
263 release-only:
264         @if [ "$(shell git status --porcelain | egrep -v '^\?\? ')" = "" ]; then \
265                 exit 0 ; \
266         else \
267           echo "" >&2 ; \
268                 echo "The git repository is not clean." >&2 ; \
269                 echo "Please commit changes before building release tarball." >&2 ; \
270                 echo "" >&2 ; \
271                 git status --porcelain | egrep -v '^\?\?' >&2 ; \
272                 echo "" >&2 ; \
273                 exit 1 ; \
274         fi
275         @if [ "$(NIGHTLY)" != "" -o "$(RELEASE)" = "1" ]; then \
276                 exit 0; \
277         else \
278           echo "" >&2 ; \
279                 echo "#NODE_VERSION_IS_RELEASE is set to $(RELEASE)." >&2 ; \
280           echo "Did you remember to update src/node_version.cc?" >&2 ; \
281           echo "" >&2 ; \
282                 exit 1 ; \
283         fi
284
285 pkg: $(PKG)
286
287 $(PKG): release-only
288         rm -rf $(PKGDIR)
289         rm -rf out/deps out/Release
290         $(PYTHON) ./configure --without-snapshot --dest-cpu=ia32 --tag=$(TAG)
291         $(MAKE) install V=$(V) DESTDIR=$(PKGDIR)/32
292         rm -rf out/deps out/Release
293         $(PYTHON) ./configure --without-snapshot --dest-cpu=x64 --tag=$(TAG)
294         $(MAKE) install V=$(V) DESTDIR=$(PKGDIR)
295         SIGN="$(APP_SIGN)" PKGDIR="$(PKGDIR)" bash tools/osx-codesign.sh
296         lipo $(PKGDIR)/32/usr/local/bin/node \
297                 $(PKGDIR)/usr/local/bin/node \
298                 -output $(PKGDIR)/usr/local/bin/node-universal \
299                 -create
300         mv $(PKGDIR)/usr/local/bin/node-universal $(PKGDIR)/usr/local/bin/node
301         rm -rf $(PKGDIR)/32
302         $(packagemaker) \
303                 --id "org.nodejs.Node" \
304                 --doc tools/osx-pkg.pmdoc \
305                 --out $(PKG)
306         SIGN="$(INT_SIGN)" PKG="$(PKG)" bash tools/osx-productsign.sh
307
308 $(TARBALL): release-only $(NODE_EXE) doc
309         git archive --format=tar --prefix=$(TARNAME)/ HEAD | tar xf -
310         mkdir -p $(TARNAME)/doc/api
311         cp doc/node.1 $(TARNAME)/doc/node.1
312         cp -r out/doc/api/* $(TARNAME)/doc/api/
313         rm -rf $(TARNAME)/deps/v8/test # too big
314         rm -rf $(TARNAME)/doc/images # too big
315         find $(TARNAME)/ -type l | xargs rm # annoying on windows
316         tar -cf $(TARNAME).tar $(TARNAME)
317         rm -rf $(TARNAME)
318         gzip -f -9 $(TARNAME).tar
319
320 tar: $(TARBALL)
321
322 $(BINARYTAR): release-only
323         rm -rf $(BINARYNAME)
324         rm -rf out/deps out/Release
325         $(PYTHON) ./configure --prefix=/ --without-snapshot --dest-cpu=$(DESTCPU) --tag=$(TAG) $(CONFIG_FLAGS)
326         $(MAKE) install DESTDIR=$(BINARYNAME) V=$(V) PORTABLE=1
327         cp README.md $(BINARYNAME)
328         cp LICENSE $(BINARYNAME)
329         cp ChangeLog $(BINARYNAME)
330         tar -cf $(BINARYNAME).tar $(BINARYNAME)
331         rm -rf $(BINARYNAME)
332         gzip -f -9 $(BINARYNAME).tar
333
334 binary: $(BINARYTAR)
335
336 $(PKGSRC): release-only
337         rm -rf dist out
338         $(PYTHON) configure --prefix=/ --without-snapshot \
339                 --dest-cpu=$(DESTCPU) --tag=$(TAG) $(CONFIG_FLAGS)
340         $(MAKE) install DESTDIR=dist
341         (cd dist; find * -type f | sort) > packlist
342         pkg_info -X pkg_install | \
343                 egrep '^(MACHINE_ARCH|OPSYS|OS_VERSION|PKGTOOLS_VERSION)' > build-info
344         pkg_create -B build-info -c tools/pkgsrc/comment -d tools/pkgsrc/description \
345                 -f packlist -I /opt/local -p dist -U $(PKGSRC)
346
347 pkgsrc: $(PKGSRC)
348
349 dist-upload: $(TARBALL) $(PKG)
350         ssh node@nodejs.org mkdir -p web/nodejs.org/dist/$(VERSION)
351         scp $(TARBALL) node@nodejs.org:~/web/nodejs.org/dist/$(VERSION)/$(TARBALL)
352         scp $(PKG) node@nodejs.org:~/web/nodejs.org/dist/$(VERSION)/$(TARNAME).pkg
353
354 wrkclean:
355         $(MAKE) -C tools/wrk/ clean
356         rm tools/wrk/wrk
357
358 wrk: tools/wrk/wrk
359 tools/wrk/wrk:
360         $(MAKE) -C tools/wrk/
361
362 bench-net: all
363         @$(NODE) benchmark/common.js net
364
365 bench-crypto: all
366         @$(NODE) benchmark/common.js crypto
367
368 bench-tls: all
369         @$(NODE) benchmark/common.js tls
370
371 bench-http: wrk all
372         @$(NODE) benchmark/common.js http
373
374 bench-fs: all
375         @$(NODE) benchmark/common.js fs
376
377 bench-misc: all
378         @$(MAKE) -C benchmark/misc/function_call/
379         @$(NODE) benchmark/common.js misc
380
381 bench-array: all
382         @$(NODE) benchmark/common.js arrays
383
384 bench-buffer: all
385         @$(NODE) benchmark/common.js buffers
386
387 bench-all: bench bench-misc bench-array bench-buffer
388
389 bench: bench-net bench-http bench-fs bench-tls
390
391 bench-http-simple:
392          benchmark/http_simple_bench.sh
393
394 bench-idle:
395         ./$(NODE_EXE) benchmark/idle_server.js &
396         sleep 1
397         ./$(NODE_EXE) benchmark/idle_clients.js &
398
399 jslintfix:
400         PYTHONPATH=tools/closure_linter/ $(PYTHON) tools/closure_linter/closure_linter/fixjsstyle.py --strict --nojsdoc -r lib/ -r src/ --exclude_files lib/punycode.js
401
402 jslint:
403         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
404
405 CPPLINT_EXCLUDE ?=
406 CPPLINT_EXCLUDE += src/node_dtrace.cc
407 CPPLINT_EXCLUDE += src/node_dtrace.cc
408 CPPLINT_EXCLUDE += src/node_root_certs.h
409 CPPLINT_EXCLUDE += src/node_win32_perfctr_provider.cc
410 CPPLINT_EXCLUDE += src/queue.h
411 CPPLINT_EXCLUDE += src/tree.h
412 CPPLINT_EXCLUDE += src/v8abbr.h
413
414 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/*))
415
416 cpplint:
417         @$(PYTHON) tools/cpplint.py $(CPPLINT_FILES)
418
419 lint: jslint cpplint
420
421 .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