| # Makefile that wraps the Gyp and build steps for Unix and Mac (but not Windows) |
| # Uses "make" to build on Unix, and "xcodebuild" to build on Mac. |
| # |
| # Some usage examples (tested on both Linux and Mac): |
| # |
| # # Clean everything |
| # make clean |
| # |
| # # Build and run tests (in Debug mode) |
| # make tests |
| # out/Debug/tests |
| # |
| # # Build and run tests (in Release mode) |
| # make tests BUILDTYPE=Release |
| # out/Release/tests |
| # |
| # # 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 http://code.google.com/p/skia/wiki/DocRoot for complete documentation. |
| |
| BUILDTYPE ?= Debug |
| CWD := $(shell pwd) |
| ALL_TARGETS := skia_base_libs \ |
| bench \ |
| gm \ |
| SampleApp \ |
| tests \ |
| tools |
| |
| ifneq (,$(findstring skia_os=android, $(GYP_DEFINES))) |
| ifeq (,$(findstring android_make_apk=0, $(GYP_DEFINES))) |
| ALL_TARGETS += SkiaAndroidApp |
| endif |
| endif |
| |
| # Default target. This must be listed before all other targets. |
| .PHONY: default |
| default: $(ALL_TARGETS) |
| |
| # 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, but the |
| # recursively invoked Makefile within out/ _is_ allowed to run in parallel |
| # (so you can still get some speedup that way). |
| .NOTPARALLEL: |
| |
| uname := $(shell uname) |
| ifneq (,$(findstring CYGWIN, $(uname))) |
| $(error Cannot build using Make on Windows. See http://code.google.com/p/skia/wiki/GettingStartedOnWindows) |
| endif |
| |
| .PHONY: all |
| all: $(ALL_TARGETS) |
| |
| .PHONY: clean |
| clean: |
| rm -rf out xcodebuild |
| |
| # Add the debugger to the target list after the 'all' target is defined so that the |
| # debugger is only executed with 'make debugger' and not 'make all' as well. The reason |
| # for this is unless the user has Qt installed the debugger target will fail. |
| ALL_TARGETS += debugger |
| |
| # Run gyp no matter what. |
| .PHONY: gyp |
| gyp: |
| $(CWD)/gyp_skia |
| |
| # Run gyp if necessary. |
| # |
| # On Linux, only run gyp if we haven't already generated the platform-specific |
| # Makefiles. If the underlying gyp configuration has changed since these |
| # Makefiles were generated, they will rerun gyp on their own. |
| # |
| # This does not work for Mac, though... so for now, we ALWAYS rerun gyp on Mac. |
| # TODO(epoger): Figure out a better solution for Mac... maybe compare the |
| # gypfile timestamps to the xcodebuild project timestamps? |
| .PHONY: gyp_if_needed |
| gyp_if_needed: |
| ifneq (,$(findstring Linux, $(uname))) |
| $(MAKE) out/Makefile |
| endif |
| ifneq (,$(findstring Darwin, $(uname))) |
| $(CWD)/gyp_skia |
| endif |
| |
| out/Makefile: |
| $(CWD)/gyp_skia |
| |
| # For all specific targets: run gyp if necessary, and then pass control to |
| # the gyp-generated buildfiles. |
| # |
| # For the Mac, we create a convenience symlink to the generated binary. |
| .PHONY: $(ALL_TARGETS) |
| $(ALL_TARGETS):: gyp_if_needed |
| ifneq (,$(findstring skia_os=android, $(GYP_DEFINES))) |
| $(MAKE) -C out $@ BUILDTYPE=$(BUILDTYPE) |
| else ifneq (,$(findstring Linux, $(uname))) |
| $(MAKE) -C out $@ BUILDTYPE=$(BUILDTYPE) |
| else ifneq (,$(findstring Darwin, $(uname))) |
| rm -f out/$(BUILDTYPE) || if test -d out/$(BUILDTYPE); then echo "run 'make clean' or otherwise delete out/$(BUILDTYPE)"; exit 1; fi |
| xcodebuild -project out/gyp/$@.xcodeproj -configuration $(BUILDTYPE) |
| ln -s $(CWD)/xcodebuild/$(BUILDTYPE) out/$(BUILDTYPE) |
| else |
| echo "unknown platform $(uname)" |
| exit 1 |
| endif |