# Makefile that wraps the Gyp and build steps for Unix and Mac (but not Windows) # Uses "ninja" to build the code. # # Some usage examples (tested on both Linux and Mac): # # # Clean everything # make clean # # # Build and run tests (in Debug mode) # make dm # out/Debug/dm # # # Build and run tests (in Release mode) # make dm BUILDTYPE=Release # out/Release/dm # # # Build bench and SampleApp (both in Release mode), and then run them # make SampleApp bench BUILDTYPE=Release # out/Release/bench -repeat 2 # out/Release/SampleApp # # # Build all targets (in Debug mode) # make # # If you want more fine-grained control, you can run gyp and then build the # gyp-generated projects yourself. # # See https://sites.google.com/site/skiadocs/ for complete documentation. SKIA_OUT ?= out BUILDTYPE ?= Debug CWD := $(shell pwd) # Soon we should be able to get rid of VALID_TARGETS, and just pass control # to the gyp-generated Makefile for *any* target name. # But that will be a bit complicated, so let's keep it for a future CL. # Tracked as https://code.google.com/p/skia/issues/detail?id=947 ('eliminate # need for VALID_TARGETS in toplevel Makefile') # # TODO(epoger): I'm not sure if the above comment is still valid in a ninja # world. VALID_TARGETS := \ nanobench \ debugger \ dm \ everything \ gm \ most \ pathops_unittest \ pdfviewer \ SampleApp \ SampleApp_APK \ skhello \ skia_lib \ skpskgr_test \ tools \ skpdiff # Default target. This must be listed before all other targets. .PHONY: default default: most # As noted in http://code.google.com/p/skia/issues/detail?id=330 , building # multiple targets in parallel was failing. The special .NOTPARALLEL target # tells gnu make not to run targets within this Makefile in parallel. # Targets that ninja builds at this Makefile's behest should not be affected. .NOTPARALLEL: uname := $(shell uname) ifneq (,$(findstring CYGWIN, $(uname))) $(error Cannot build using Make on Windows. See https://sites.google.com/site/skiadocs/user-documentation/quick-start-guides/windows) endif # If user requests "make all", chain to our explicitly-declared "everything" # target. See https://code.google.com/p/skia/issues/detail?id=932 ("gyp # automatically creates "all" target on some build flavors but not others") .PHONY: all all: everything .PHONY: clean clean: rm -rf out xcodebuild ifneq (out, $(SKIA_OUT)) rm -rf $(SKIA_OUT) endif # Run gyp no matter what. .PHONY: gyp gyp: $(CWD)/gyp_skia # For all specific targets: run gyp if necessary, and then pass control to # the gyp-generated buildfiles. .PHONY: $(VALID_TARGETS) $(VALID_TARGETS):: gyp ninja -C $(SKIA_OUT)/$(BUILDTYPE) $@