epoger@google.com | 5d2e4cc | 2011-06-22 19:17:28 +0000 | [diff] [blame] | 1 | # Makefile that wraps the Gyp and build steps for Unix and Mac (but not Windows) |
| 2 | # Uses "make" to build on Unix, and "xcodebuild" to build on Mac. |
| 3 | # |
| 4 | # Some usage examples (tested on both Linux and Mac): |
| 5 | # |
| 6 | # # Clean everything |
| 7 | # make clean |
| 8 | # |
| 9 | # # Build and run tests (in Debug mode) |
| 10 | # make tests |
| 11 | # out/Debug/tests |
| 12 | # |
| 13 | # # Build and run tests (in Release mode) |
| 14 | # make tests BUILDTYPE=Release |
| 15 | # out/Release/tests |
| 16 | # |
| 17 | # # Build bench and SampleApp (both in Release mode), and then run them |
| 18 | # make SampleApp bench BUILDTYPE=Release |
| 19 | # out/Release/bench -repeat 2 |
| 20 | # out/Release/SampleApp |
| 21 | # |
| 22 | # # Build all targets (in Debug mode) |
| 23 | # make |
| 24 | # |
| 25 | # If you want more fine-grained control, you can run gyp and then build the |
| 26 | # gyp-generated projects yourself. |
| 27 | # |
| 28 | # See http://code.google.com/p/skia/wiki/DocRoot for complete documentation. |
| 29 | |
| 30 | BUILDTYPE ?= Debug |
| 31 | CWD := $(shell pwd) |
djsollen@google.com | 686989b | 2012-06-29 18:51:29 +0000 | [diff] [blame] | 32 | ALL_TARGETS := core SampleApp bench gm tests tools |
epoger@google.com | c9493a4 | 2011-07-27 14:06:25 +0000 | [diff] [blame] | 33 | |
borenet@google.com | dd3d08e | 2012-06-27 19:04:39 +0000 | [diff] [blame] | 34 | ifneq (,$(findstring skia_os=android, $(GYP_DEFINES))) |
| 35 | ALL_TARGETS += SkiaAndroidApp |
| 36 | endif |
| 37 | |
epoger@google.com | c9493a4 | 2011-07-27 14:06:25 +0000 | [diff] [blame] | 38 | # Default target. This must be listed before all other targets. |
| 39 | .PHONY: default |
djsollen@google.com | 686989b | 2012-06-29 18:51:29 +0000 | [diff] [blame] | 40 | default: $(ALL_TARGETS) |
epoger@google.com | c9493a4 | 2011-07-27 14:06:25 +0000 | [diff] [blame] | 41 | |
| 42 | # As noted in http://code.google.com/p/skia/issues/detail?id=330 , building |
| 43 | # multiple targets in parallel was failing. The special .NOTPARALLEL target |
| 44 | # tells gnu make not to run targets within _this_ Makefile in parallel, but the |
| 45 | # recursively invoked Makefile within out/ _is_ allowed to run in parallel |
| 46 | # (so you can still get some speedup that way). |
| 47 | .NOTPARALLEL: |
epoger@google.com | 5d2e4cc | 2011-06-22 19:17:28 +0000 | [diff] [blame] | 48 | |
| 49 | uname := $(shell uname) |
| 50 | ifneq (,$(findstring CYGWIN, $(uname))) |
| 51 | $(error Cannot build using Make on Windows. See http://code.google.com/p/skia/wiki/GettingStartedOnWindows) |
| 52 | endif |
| 53 | |
epoger@google.com | 5d2e4cc | 2011-06-22 19:17:28 +0000 | [diff] [blame] | 54 | .PHONY: all |
epoger@google.com | c9493a4 | 2011-07-27 14:06:25 +0000 | [diff] [blame] | 55 | all: $(ALL_TARGETS) |
epoger@google.com | 5d2e4cc | 2011-06-22 19:17:28 +0000 | [diff] [blame] | 56 | |
| 57 | .PHONY: clean |
| 58 | clean: |
| 59 | rm -rf out xcodebuild |
| 60 | |
djsollen@google.com | 686989b | 2012-06-29 18:51:29 +0000 | [diff] [blame] | 61 | # Add the debugger to the target list after the 'all' target is defined so that the |
| 62 | # debugger is only executed with 'make debugger' and not 'make all' as well. The reason |
| 63 | # for this is unless the user has Qt installed the debugger target will fail. |
| 64 | ALL_TARGETS += debugger |
| 65 | |
epoger@google.com | c9493a4 | 2011-07-27 14:06:25 +0000 | [diff] [blame] | 66 | # Run gyp no matter what. |
| 67 | .PHONY: gyp |
| 68 | gyp: |
| 69 | $(CWD)/gyp_skia |
| 70 | |
| 71 | # Run gyp if necessary. |
| 72 | # |
| 73 | # On Linux, only run gyp if we haven't already generated the platform-specific |
| 74 | # Makefiles. If the underlying gyp configuration has changed since these |
| 75 | # Makefiles were generated, they will rerun gyp on their own. |
| 76 | # |
| 77 | # This does not work for Mac, though... so for now, we ALWAYS rerun gyp on Mac. |
| 78 | # TODO(epoger): Figure out a better solution for Mac... maybe compare the |
| 79 | # gypfile timestamps to the xcodebuild project timestamps? |
| 80 | .PHONY: gyp_if_needed |
| 81 | gyp_if_needed: |
| 82 | ifneq (,$(findstring Linux, $(uname))) |
| 83 | $(MAKE) out/Makefile |
| 84 | endif |
| 85 | ifneq (,$(findstring Darwin, $(uname))) |
| 86 | $(CWD)/gyp_skia |
| 87 | endif |
| 88 | |
| 89 | out/Makefile: |
| 90 | $(CWD)/gyp_skia |
| 91 | |
| 92 | # For all specific targets: run gyp if necessary, and then pass control to |
| 93 | # the gyp-generated buildfiles. |
epoger@google.com | 5d2e4cc | 2011-06-22 19:17:28 +0000 | [diff] [blame] | 94 | # |
| 95 | # For the Mac, we create a convenience symlink to the generated binary. |
epoger@google.com | c9493a4 | 2011-07-27 14:06:25 +0000 | [diff] [blame] | 96 | .PHONY: $(ALL_TARGETS) |
| 97 | $(ALL_TARGETS):: gyp_if_needed |
borenet@google.com | b52cf3d | 2012-06-05 17:57:48 +0000 | [diff] [blame] | 98 | ifneq (,$(findstring skia_os=android, $(GYP_DEFINES))) |
epoger@google.com | eaacf47 | 2011-06-28 16:48:56 +0000 | [diff] [blame] | 99 | $(MAKE) -C out $@ BUILDTYPE=$(BUILDTYPE) |
borenet@google.com | b52cf3d | 2012-06-05 17:57:48 +0000 | [diff] [blame] | 100 | else ifneq (,$(findstring Linux, $(uname))) |
| 101 | $(MAKE) -C out $@ BUILDTYPE=$(BUILDTYPE) |
| 102 | else ifneq (,$(findstring Darwin, $(uname))) |
epoger@google.com | ab9b658 | 2011-08-15 19:22:39 +0000 | [diff] [blame] | 103 | rm -f out/$(BUILDTYPE) || if test -d out/$(BUILDTYPE); then echo "run 'make clean' or otherwise delete out/$(BUILDTYPE)"; exit 1; fi |
epoger@google.com | 5d2e4cc | 2011-06-22 19:17:28 +0000 | [diff] [blame] | 104 | xcodebuild -project out/gyp/$@.xcodeproj -configuration $(BUILDTYPE) |
epoger@google.com | ab9b658 | 2011-08-15 19:22:39 +0000 | [diff] [blame] | 105 | ln -s $(CWD)/xcodebuild/$(BUILDTYPE) out/$(BUILDTYPE) |
borenet@google.com | b52cf3d | 2012-06-05 17:57:48 +0000 | [diff] [blame] | 106 | else |
| 107 | echo "unknown platform $(uname)" |
| 108 | exit 1 |
chudy@google.com | b678911 | 2012-06-29 14:34:58 +0000 | [diff] [blame] | 109 | endif |