Merge pull request #24 from google/chrome/m54
[platform/upstream/libSkiaSharp.git] / Makefile
1 # Makefile that wraps the Gyp and build steps for Unix and Mac (but not Windows)
2 # Uses "ninja" to build the code.
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 dm
11 #   out/Debug/dm
12 #
13 #   # Build and run tests (in Release mode)
14 #   make dm BUILDTYPE=Release
15 #   out/Release/dm
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 https://skia.org for complete documentation.
29
30 SKIA_OUT ?= out
31 BUILDTYPE ?= Debug
32 CWD := $(shell pwd)
33
34 # Soon we should be able to get rid of VALID_TARGETS, and just pass control
35 # to the gyp-generated Makefile for *any* target name.
36 # But that will be a bit complicated, so let's keep it for a future CL.
37 # Tracked as https://code.google.com/p/skia/issues/detail?id=947 ('eliminate
38 # need for VALID_TARGETS in toplevel Makefile')
39 #
40 # TODO(epoger): I'm not sure if the above comment is still valid in a ninja
41 # world.
42 VALID_TARGETS := \
43                  nanobench \
44                  visualbench \
45                  debugger \
46                  dm \
47                  everything \
48                  lua_app \
49                  lua_pictures \
50                  most \
51                  pathops_unittest \
52                  SampleApp \
53                  SampleApp_APK \
54                  skhello \
55                  skia_lib \
56                  skpskgr_test \
57                  tools \
58                  skpdiff
59
60 # Default target.  This must be listed before all other targets.
61 .PHONY: default
62 default: most
63
64 # As noted in http://code.google.com/p/skia/issues/detail?id=330 , building
65 # multiple targets in parallel was failing.  The special .NOTPARALLEL target
66 # tells gnu make not to run targets within this Makefile in parallel.
67 # Targets that ninja builds at this Makefile's behest should not be affected.
68 .NOTPARALLEL:
69
70 uname := $(shell uname)
71 ifneq (,$(findstring CYGWIN, $(uname)))
72   $(error Cannot build using Make on Windows. See https://skia.org/user/quick/windows)
73 endif
74
75 # If user requests "make all", chain to our explicitly-declared "everything"
76 # target. See https://code.google.com/p/skia/issues/detail?id=932 ("gyp
77 # automatically creates "all" target on some build flavors but not others")
78 .PHONY: all
79 all: everything
80
81 .PHONY: clean
82 clean:
83         rm -rf out xcodebuild
84 ifneq (out, $(SKIA_OUT))
85         rm -rf $(SKIA_OUT)
86 endif
87
88 # Run gyp no matter what.
89 .PHONY: gyp
90 gyp:
91         $(CWD)/gyp_skia --no-parallel -G config=$(BUILDTYPE)
92
93 # For all specific targets: run gyp if necessary, and then pass control to
94 # the gyp-generated buildfiles.
95 .PHONY: $(VALID_TARGETS)
96 $(VALID_TARGETS):: gyp
97         ninja -C $(SKIA_OUT)/$(BUILDTYPE) $@