WAF=python tools/waf-light web_root = node@nodejs.org:~/web/nodejs.org/ # # Because we recursively call make from waf we need to make sure that we are # using the correct make. Not all makes are GNU Make, but this likely only # works with gnu make. To deal with this we remember how the user invoked us # via a make builtin variable and use that in all subsequent operations # export NODE_MAKE := $(MAKE) all: program @-[ -f out/Release/node ] && ls -lh out/Release/node all-progress: @$(WAF) -p build program: @$(WAF) --product-type=program build staticlib: @$(WAF) --product-type=cstaticlib build dynamiclib: @$(WAF) --product-type=cshlib build install: @$(WAF) install uninstall: @$(WAF) uninstall test: all python tools/test.py --mode=release simple message test-http1: all python tools/test.py --mode=release --use-http1 simple message test-valgrind: all python tools/test.py --mode=release --valgrind simple message test-all: all python tools/test.py --mode=debug,release test-all-http1: all python tools/test.py --mode=debug,release --use-http1 test-all-valgrind: all python tools/test.py --mode=debug,release --valgrind test-release: all python tools/test.py --mode=release test-debug: all python tools/test.py --mode=debug test-message: all python tools/test.py message test-simple: all python tools/test.py simple test-pummel: all python tools/test.py pummel test-internet: all python tools/test.py internet out/Release/node: all apidoc_sources = $(wildcard doc/api/*.markdown) apidocs = $(addprefix out/,$(apidoc_sources:.markdown=.html)) apidoc_dirs = out/doc out/doc/api/ out/doc/api/assets apiassets = $(subst api_assets,api/assets,$(addprefix out/,$(wildcard doc/api_assets/*))) website_files = \ out/doc/index.html \ out/doc/v0.4_announcement.html \ out/doc/cla.html \ out/doc/sh_main.js \ out/doc/sh_javascript.min.js \ out/doc/sh_vim-dark.css \ out/doc/logo.png \ out/doc/sponsored.png \ out/doc/favicon.ico \ out/doc/pipe.css doc: out/Release/node $(apidoc_dirs) $(website_files) $(apiassets) $(apidocs) $(apidoc_dirs): mkdir -p $@ out/doc/api/assets/%: doc/api_assets/% out/doc/api/assets/ cp $< $@ out/doc/%: doc/% cp $< $@ out/doc/api/%.html: doc/api/%.markdown out/Release/node $(apidoc_dirs) $(apiassets) tools/doctool/doctool.js out/Release/node tools/doctool/doctool.js doc/template.html $< > $@ out/doc/%: website-upload: doc scp -r out/doc/* $(web_root) docopen: out/doc/api/all.html -google-chrome out/doc/api/all.html docclean: -rm -rf out/doc clean: $(WAF) clean -find tools -name "*.pyc" | xargs rm -f distclean: docclean -find tools -name "*.pyc" | xargs rm -f -rm -rf dist-osx -rm -rf out/ node node_g check: @tools/waf-light check VERSION=$(shell git describe) TARNAME=node-$(VERSION) #dist: doc/node.1 doc/api dist: doc git archive --format=tar --prefix=$(TARNAME)/ HEAD | tar xf - mkdir -p $(TARNAME)/doc cp doc/node.1 $(TARNAME)/doc/node.1 cp -r out/doc/api $(TARNAME)/doc/api rm -rf $(TARNAME)/deps/v8/test # too big rm -rf $(TARNAME)/doc/logos # too big tar -cf $(TARNAME).tar $(TARNAME) rm -rf $(TARNAME) gzip -f -9 $(TARNAME).tar bench: benchmark/http_simple_bench.sh bench-idle: ./node benchmark/idle_server.js & sleep 1 ./node benchmark/idle_clients.js & jslint: PYTHONPATH=tools/closure_linter/ python tools/closure_linter/closure_linter/gjslint.py --unix_mode --strict --nojsdoc -r lib/ -r src/ -r test/ cpplint: @python tools/cpplint.py $(wildcard src/*.cc src/*.h src/*.c) lint: jslint cpplint .PHONY: lint cpplint jslint bench clean docopen docclean doc dist distclean check uninstall install all program staticlib dynamiclib test test-all website-upload