aboutsummaryrefslogtreecommitdiffhomepage
path: root/Makefile
diff options
context:
space:
mode:
authorGravatar epoger@google.com <epoger@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2011-06-07 14:48:41 +0000
committerGravatar epoger@google.com <epoger@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2011-06-07 14:48:41 +0000
commit1e8e056afc6a7fc533f696e93771bde861a53db7 (patch)
tree45be1d87bbd3be35cf4d4e0517f5836d5a5ad7d9 /Makefile
parent288ff33d06776d6b105f8056af30191510ca0e3f (diff)
Some final cleanups leading up to The Official Switch to Gyp
see http://codereview.appspot.com/4580043 1. Create a single public skia.gyp file that all outside projects (Chrome, Android, etc.) should depend on from now on. I haven't yet created targets suitable for those projects to use, but this is where we should add them. 2. Make gyp generate its Makefiles within out/ directory, rather than polluting directories under source control. 3. Modify trunk/Makefile to automatically run gyp_skia and then call the generated Makefile, to ease developer transition. git-svn-id: http://skia.googlecode.com/svn/trunk@1526 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'Makefile')
-rw-r--r--Makefile340
1 files changed, 32 insertions, 308 deletions
diff --git a/Makefile b/Makefile
index 9fc989a5af..b1d857998c 100644
--- a/Makefile
+++ b/Makefile
@@ -1,316 +1,40 @@
-# Simple makefile for skia library and test apps
+# Makefile that redirects almost all make directives to the gyp-generated Makefile.
+#
+# Note that this method of building works only on Unix (not Mac or Windows).
+# See http://code.google.com/p/skia/wiki/DocRoot for complete documentation.
-# setup our defaults
-CC := gcc
-GPP := g++
-C_INCLUDES := -Iinclude/config -Iinclude/core -Iinclude/effects -Iinclude/images -Iinclude/ports
-C_INCLUDES += -Iinclude/gpu -Iinclude/utils -Igpu/include
-C_INCLUDES += -Ithird_party/glu
+# Directory within which we want all generated files to be written.
+outdir := out
-CFLAGS := -Wall -fstrict-aliasing
-#CFLAGS += -W -Wextra -Wcast-align -Wchar-subscripts -Wformat -Wformat-security -Wno-format-y2k -Wno-parentheses -Wno-unused-parameter -Wpointer-arith -Wreturn-type -Wundef -Wwrite-strings
-CFLAGS_SSE2 = $(CFLAGS) -msse2
-LINKER_OPTS := -lpthread -lz
-DEFINES := -DSK_CAN_USE_FLOAT
-HIDE = @
-
-ifeq ($(SKIA_SCALAR),fixed)
- DEFINES += -DSK_SCALAR_IS_FIXED
-else
- DEFINES += -DSK_SCALAR_IS_FLOAT
-endif
-
-ifeq ($(SKIA_DEBUG),true)
- DEFINES += -DSK_DEBUG -DSK_SUPPORT_UNIT -DGR_DEBUG=1
- CFLAGS += -g
-else
- CFLAGS += -O3
- DEFINES += -DSK_RELEASE -DGR_DEBUG=0
-endif
-
-DEFINES += -DGR_IMPLEMENTATION=1
-
-ifneq ($(SKIA_PDF_SUPPORT),false)
- DEFINES += -DSK_SUPPORT_PDF
- DEFINES += -DSK_ZLIB_INCLUDE="<zlib.h>"
-endif
-
-ifeq ($(SKIA_SHARED),true)
- CFLAGS += -fPIC
- LIBSKIA = out/libskia.so
-else
- LIBSKIA = out/libskia.a
-endif
-
-# start with the core (required)
-include src/core/core_files.mk
-SRC_LIST := $(addprefix src/core/, $(SOURCE))
-
-# add the opts (optimizations)
-include src/opts/opts_sse2_files.mk
-#include src/opts/opts_files.mk
-SRC_LIST += $(addprefix src/opts/, $(SOURCE))
-
-# we usually need ports
-include src/ports/ports_files.mk
-SRC_LIST += $(addprefix src/ports/, $(SOURCE))
-
-# do we want effects?
-include src/effects/effects_files.mk
-SRC_LIST += $(addprefix src/effects/, $(SOURCE))
-
-# core image files
-include src/images/images_files.mk
-SRC_LIST += $(addprefix src/images/, $(SOURCE))
-
-# core util files
-include src/utils/utils_files.mk
-SRC_LIST += $(addprefix src/utils/, $(SOURCE))
-
-# GPU files
-include gpu/src/gr_files.mk
-SRC_LIST += $(addprefix gpu/src/, $(SOURCE))
-
-# GPU support files
-include src/gpu/skgr_files.mk
-SRC_LIST += $(addprefix src/gpu/, $(SOURCE))
-
-# pdf backend files
-ifneq ($(SKIA_PDF_SUPPORT),false)
- C_INCLUDES += -Iinclude/pdf
- include src/pdf/pdf_files.mk
- SRC_LIST += $(addprefix src/pdf/, $(SOURCE))
-endif
-
-# extra files we want to build to prevent bit-rot, but not link
-JUST_COMPILE_LIST := src/ports/SkFontHost_tables.cpp
-
-# conditional files based on our platform
-ifeq ($(SKIA_BUILD_FOR),mac)
- # make it work with 10.4 for our font port
-# GPP := g++-4.0
-# SDK := /Developer/SDKs/MacOSX10.4u.sdk
-# SDK_OPTS := -isysroot $(SDK) -mmacosx-version-min=10.4
-# CC := gcc-4.0 $(SDK_OPTS)
-
- C_INCLUDES += -I/opt/local/include
- LINKER_OPTS += -L/opt/local/lib -framework Carbon -lpng
- DEFINES += -DSK_BUILD_FOR_MAC -DSK_ENABLE_LIBPNG
- ifeq ($(SKIA_MESA),true)
- C_INCLUDES += -I/usr/X11/include
- LINKER_OPTS += -L/usr/X11/lib -lOSMesa -lGLU
- DEFINES += -DSK_MESA
- else
- LINKER_OPTS += -framework OpenGL -framework AGL
- endif
- C_INCLUDES += -Iinclude/utils/mac
-# SRC_LIST += src/ports/SkImageDecoder_CG.cpp
- SRC_LIST += src/utils/mac/SkCreateCGImageRef.cpp
- ifeq ($(SKIA_MESA),true)
- SRC_LIST += src/utils/mesa/SkEGLContext_Mesa.cpp
- else
- SRC_LIST += src/utils/mac/SkEGLContext_mac.cpp
- endif
- SRC_LIST += src/core/SkTypefaceCache.cpp
- SRC_LIST += src/ports/SkFontHost_mac_coretext.cpp
-
- # these are our registry-based factories
- SRC_LIST += src/images/SkImageDecoder_Factory.cpp
- SRC_LIST += src/images/SkImageEncoder_Factory.cpp
- SRC_LIST += src/images/SkImageDecoder_libpng.cpp
- # support files
- SRC_LIST += src/images/SkScaledBitmapSampler.cpp
-
- ifeq ($(SKIA_MESA),true)
- SRC_LIST += gpu/src/mesa/GrGLDefaultInterface_mesa.cpp
- else
- SRC_LIST += gpu/src/mac/GrGLDefaultInterface_mac.cpp
- endif
-
-else
- LINKER_OPTS += -lpng -lfreetype
- DEFINES += -DSK_BUILD_FOR_UNIX -DSK_ENABLE_LIBPNG -DGR_LINUX_BUILD=1
- ifeq ($(SKIA_MESA),true)
- LINKER_OPTS += -lOSMesa -lGLU
- DEFINES += -DSK_MESA
- else
- LINKER_OPTS += -lGL -lGLU -lX11
- endif
-
- #Assume the color order for now.
- DEFINES += -DSK_SAMPLES_FOR_X
-
- # needed for freetype support
- C_INCLUDES += -I/usr/include/freetype2
- SRC_LIST += src/ports/SkFontHost_linux.cpp
- SRC_LIST += src/ports/SkFontHost_gamma_none.cpp
- SRC_LIST += src/ports/SkFontHost_FreeType.cpp
- SRC_LIST += src/ports/SkFontHost_FreeType_Subpixel.cpp
- ifeq ($(SKIA_MESA),true)
- SRC_LIST += src/utils/mesa/SkEGLContext_Mesa.cpp
- else
- SRC_LIST += src/utils/unix/SkEGLContext_Unix.cpp
- endif
- # these are our registry-based factories
- SRC_LIST += src/images/SkImageDecoder_Factory.cpp
- SRC_LIST += src/images/SkImageEncoder_Factory.cpp
- SRC_LIST += src/images/SkImageDecoder_libpng.cpp
- # support files
- SRC_LIST += src/images/SkScaledBitmapSampler.cpp
-
- ifeq ($(SKIA_MESA),true)
- SRC_LIST += gpu/src/mesa/GrGLDefaultInterface_mesa.cpp
- else
- SRC_LIST += gpu/src/unix/GrGLDefaultInterface_unix.cpp
- endif
-endif
-
-# For these files, and these files only, compile with -msse2.
-SSE2_OBJS := out/src/opts/SkBlitRow_opts_SSE2.o \
- out/src/opts/SkBitmapProcState_opts_SSE2.o \
- out/src/opts/SkUtils_opts_SSE2.o
-$(SSE2_OBJS) : CFLAGS := $(CFLAGS_SSE2)
-
-out/%.o : %.cpp
- @mkdir -p $(dir $@)
- $(HIDE)$(CC) $(C_INCLUDES) $(CFLAGS) $(DEFINES) -c $< -o $@
- @echo "compiling $@"
-
-%.s : %.cpp
- @mkdir -p $(dir $@)
- $(CC) $(C_INCLUDES) $(CFLAGS) $(DEFINES) -S -c $< -o $@
-
-# now build out objects
-OBJ_LIST := $(SRC_LIST:.cpp=.o)
-OBJ_LIST := $(addprefix out/, $(OBJ_LIST))
-
-# we want to compile these, but we don't actually link them
-JUST_COMPILE_OBJS := $(JUST_COMPILE_LIST:.cpp=.o)
-JUST_COMPILE_OBJS := $(addprefix out/, $(JUST_COMPILE_OBJS))
-
-out/libskia.a: Makefile $(OBJ_LIST) $(JUST_COMPILE_OBJS)
- $(HIDE)$(AR) ru $@ $(OBJ_LIST)
- $(HIDE)ranlib $@
-
-out/libskia.so: Makefile $(OBJ_LIST) $(JUST_COMPILE_OBJS)
- $(HIDE)$(GPP) -shared -o $@ $(OBJ_LIST) $(JUST_COMPILE_OBJS) $(LINKER_OPTS)
-
-##############################################################################
-
-BENCH_SRCS := RectBench.cpp SkBenchmark.cpp benchmain.cpp BitmapBench.cpp \
- RepeatTileBench.cpp DecodeBench.cpp FPSBench.cpp PathBench.cpp \
- GradientBench.cpp MatrixBench.cpp ScalarBench.cpp
-
-BENCH_SRCS := $(addprefix bench/, $(BENCH_SRCS))
-
-# add any optional codecs for this app
-ifeq ($(SKIA_BUILD_FOR),mac)
- BENCH_SRCS += bench/TextBench.cpp
-else
- BENCH_SRCS += src/images/SkImageDecoder_libpng.cpp
-endif
-
-BENCH_OBJS := $(BENCH_SRCS:.cpp=.o)
-BENCH_OBJS := $(addprefix out/, $(BENCH_OBJS))
-
-bench: $(BENCH_OBJS) $(LIBSKIA)
- @echo "linking bench..."
- $(HIDE)$(GPP) $(BENCH_OBJS) $(LIBSKIA) -o out/bench/bench $(LINKER_OPTS)
-
-##############################################################################
-
-# we let tests cheat and see private headers, so we can unittest modules
-C_INCLUDES += -Isrc/core
-
-include tests/tests_files.mk
-ifneq ($(SKIA_PDF_SUPPORT),false)
- SOURCE += PDFPrimitivesTest.cpp
+# GYP-generated Makefiles only work on Linux/Unix (not Mac or Windows).
+uname := $(shell uname)
+ifneq (,$(findstring Darwin, $(uname)))
+ $(error Cannot build using Make on Mac. See http://code.google.com/p/skia/wiki/GettingStartedOnMac)
endif
-TESTS_SRCS := $(addprefix tests/, $(SOURCE))
-
-TESTS_OBJS := $(TESTS_SRCS:.cpp=.o)
-TESTS_OBJS := $(addprefix out/, $(TESTS_OBJS))
-
-tests: $(TESTS_OBJS) $(LIBSKIA)
- @echo "linking tests..."
- $(HIDE)$(GPP) $(TESTS_OBJS) $(LIBSKIA) -o out/tests/tests $(LINKER_OPTS)
-
-##############################################################################
-
-SKIMAGE_SRCS := skimage_main.cpp
-
-SKIMAGE_SRCS := $(addprefix tools/, $(SKIMAGE_SRCS))
-
-SKIMAGE_OBJS := $(SKIMAGE_SRCS:.cpp=.o)
-SKIMAGE_OBJS := $(addprefix out/, $(SKIMAGE_OBJS))
-
-skimage: $(SKIMAGE_OBJS) $(LIBSKIA)
- @echo "linking skimage..."
- $(HIDE)$(GPP) $(SKIMAGE_OBJS) $(LIBSKIA) -o out/tools/skimage $(LINKER_OPTS)
-
-##############################################################################
-
-SKDIFF_SRCS := skdiff_main.cpp
-SKDIFF_SRCS := $(addprefix tools/, $(SKDIFF_SRCS))
-SKDIFF_OBJS := $(SKDIFF_SRCS:.cpp=.o)
-SKDIFF_OBJS := $(addprefix out/, $(SKDIFF_OBJS))
-skdiff: $(SKDIFF_OBJS) out/libskia.a
- @echo "linking skdiff..."
- $(HIDE)$(GPP) $(SKDIFF_OBJS) out/libskia.a -o out/tools/skdiff $(LINKER_OPTS)
-
-##############################################################################
-
-SKHELLO_SRCS := skhello.cpp
-
-SKHELLO_SRCS := $(addprefix tools/, $(SKHELLO_SRCS))
-
-SKHELLO_OBJS := $(SKHELLO_SRCS:.cpp=.o)
-SKHELLO_OBJS := $(addprefix out/, $(SKHELLO_OBJS))
-
-skhello: $(SKHELLO_OBJS) $(LIBSKIA)
- @echo "linking shkello..."
- $(HIDE)$(GPP) $(SKHELLO_OBJS) $(LIBSKIA) -o out/tools/skhello $(LINKER_OPTS)
-
-##############################################################################
-
-include gm/gm_files.mk
-GM_SRCS := $(addprefix gm/, $(SOURCE))
-
-ifneq ($(SKIA_BUILD_FOR),mac)
- GM_SRCS += src/images/SkImageDecoder_libpng.cpp
+ifneq (,$(findstring CYGWIN, $(uname)))
+ $(error Cannot build using Make on Windows. See http://code.google.com/p/skia/wiki/GettingStartedOnWindows)
endif
-GM_OBJS := $(GM_SRCS:.cpp=.o)
-GM_OBJS := $(addprefix out/, $(GM_OBJS))
-
-gm: $(GM_OBJS) $(LIBSKIA)
- @echo "linking gm..."
- $(HIDE)$(GPP) $(GM_OBJS) $(LIBSKIA) -o out/gm/gm $(LINKER_OPTS)
-
-##############################################################################
-
-.PHONY: all
-all: $ bench gm skimage tests skhello skdiff
+# Default target. This must be listed before all other targets.
+.PHONY: default
+default: all
.PHONY: clean
clean:
- $(HIDE)rm -rf out
-
-.PHONY: help
-help:
- @echo "Targets:"
- @echo " <default>: out/libskia.a"
- @echo " bench: out/bench/bench"
- @echo " gm: out/gm/gm"
- @echo " skimage: out/tools/skimage"
- @echo " skhello: out/tools/skhello"
- @echo " tests: out/tests/tests"
- @echo " clean: removes entire out/ directory"
- @echo " help: this text"
- @echo "Options: (after make, or in bash shell)"
- @echo " SKIA_DEBUG=true for debug build"
- @echo " SKIA_SHARED=true for shared-object libskia build"
- @echo " SKIA_SCALAR=fixed for fixed-point build"
- @echo " SKIA_BUILD_FOR=mac for mac build (e.g. CG for image decoding)"
- @echo " SKIA_PDF_SUPPORT=false to disable the pdf generation backend"
- @echo ""
+ rm -rf $(outdir)
+
+# Any target OTHER than clean...
+# Ask gyp to create the real Makefile, and then pass control to it.
+%:
+ ./gyp_skia -f make
+ make -C $(outdir) $@
+
+# Unfortunately, this is a bit ugly, but necessary.
+# If there are any files/directories within the same directory as this Makefile
+# which share the same name as a target ("tests", for example), then make
+# will refuse to rebuild those targets because the file already exists.
+local_filenames := $(shell ls)
+.PHONY: $(local_filenames)
+$(local_filenames)::
+ ./gyp_skia -f make
+ make -C $(outdir) $@