forked from minhngoc25a/freetype2
166 lines
4.2 KiB
Makefile
166 lines
4.2 KiB
Makefile
#
|
|
# FreeType build system -- top-level sub-Makefile
|
|
#
|
|
|
|
|
|
# Copyright 1996-2000, 2001, 2003, 2006 by
|
|
# David Turner, Robert Wilhelm, and Werner Lemberg.
|
|
#
|
|
# This file is part of the FreeType project, and may only be used, modified,
|
|
# and distributed under the terms of the FreeType project license,
|
|
# LICENSE.TXT. By continuing to use, modify, or distribute this file you
|
|
# indicate that you have read the license and understand and accept it
|
|
# fully.
|
|
|
|
|
|
# This file is designed for GNU Make, do not use it with another Make tool!
|
|
#
|
|
# It works as follows:
|
|
#
|
|
# - When invoked for the first time, this Makefile will include the rules
|
|
# found in `PROJECT/builds/detect.mk'. They are in charge of detecting
|
|
# the current platform.
|
|
#
|
|
# A summary of the detection will be displayed, and the file `config.mk'
|
|
# will be created in the current directory.
|
|
#
|
|
# - When invoked later, this Makefile will include the rules found in
|
|
# `config.mk'. This sub-Makefile will define some system-specific
|
|
# variables (like compiler, compilation flags, object suffix, etc.), then
|
|
# include the rules found in `PROJECT/builds/PROJECT.mk', used to build
|
|
# the library.
|
|
#
|
|
# See the comments in `builds/detect.mk' and `builds/PROJECT.mk' for more
|
|
# details on host platform detection and library builds.
|
|
|
|
|
|
.PHONY: all setup distclean modules
|
|
|
|
|
|
# The `space' variable is used to avoid trailing spaces in defining the
|
|
# `T' variable later.
|
|
#
|
|
empty :=
|
|
space := $(empty) $(empty)
|
|
|
|
|
|
# The main configuration file, defining the `XXX_MODULES' variables. We
|
|
# prefer a `modules.cfg' file in OBJ_DIR over TOP_DIR.
|
|
#
|
|
ifndef MODULES_CFG
|
|
MODULES_CFG := $(TOP_DIR)/modules.cfg
|
|
ifneq ($(wildcard $(OBJ_DIR)/modules.cfg),)
|
|
MODULES_CFG := $(OBJ_DIR)/modules.cfg
|
|
endif
|
|
endif
|
|
|
|
|
|
# FTMODULE_H, as its name suggests, indicates where the FreeType module
|
|
# classes resides.
|
|
#
|
|
ifndef FTMODULE_H
|
|
FTMODULE_H := $(OBJ_DIR)/ftmodule.h
|
|
endif
|
|
|
|
|
|
include $(MODULES_CFG)
|
|
|
|
|
|
# The list of modules we are using.
|
|
#
|
|
MODULES := $(FONT_MODULES) \
|
|
$(HINTING_MODULES) \
|
|
$(RASTER_MODULES) \
|
|
$(AUX_MODULES)
|
|
|
|
|
|
ifndef CONFIG_MK
|
|
CONFIG_MK := config.mk
|
|
endif
|
|
|
|
# If no configuration sub-makefile is present, or if `setup' is the target
|
|
# to be built, run the auto-detection rules to figure out which
|
|
# configuration rules file to use.
|
|
#
|
|
# Note that the configuration file is put in the current directory, which is
|
|
# not necessarily $(TOP_DIR).
|
|
|
|
# If `config.mk' is not present, set `check_platform'.
|
|
#
|
|
ifeq ($(wildcard $(CONFIG_MK)),)
|
|
check_platform := 1
|
|
endif
|
|
|
|
# If `setup' is one of the targets requested, set `check_platform'.
|
|
#
|
|
ifneq ($(findstring setup,$(MAKECMDGOALS)),)
|
|
check_platform := 1
|
|
endif
|
|
|
|
# Include the automatic host platform detection rules when we need to
|
|
# check the platform.
|
|
#
|
|
ifdef check_platform
|
|
|
|
all modules: setup
|
|
|
|
include $(TOP_DIR)/builds/detect.mk
|
|
|
|
# This rule makes sense for Unix only to remove files created by a run
|
|
# of the configure script which hasn't been successful (so that no
|
|
# `config.mk' has been created). It uses the built-in $(RM) command of
|
|
# GNU make. Similarly, `nul' is created if e.g. `make setup win32' has
|
|
# been erroneously used.
|
|
#
|
|
# Note: This test is duplicated in `builds/unix/detect.mk'.
|
|
#
|
|
is_unix := $(strip $(wildcard /sbin/init) \
|
|
$(wildcard /usr/sbin/init) \
|
|
$(wildcard /hurd/auth))
|
|
ifneq ($(is_unix),)
|
|
|
|
distclean:
|
|
$(RM) builds/unix/config.cache
|
|
$(RM) builds/unix/config.log
|
|
$(RM) builds/unix/config.status
|
|
$(RM) builds/unix/unix-def.mk
|
|
$(RM) builds/unix/unix-cc.mk
|
|
$(RM) builds/unix/freetype2.pc
|
|
$(RM) nul
|
|
|
|
endif # test is_unix
|
|
|
|
# IMPORTANT:
|
|
#
|
|
# `setup' must be defined by the host platform detection rules to create
|
|
# the `config.mk' file in the current directory.
|
|
|
|
else
|
|
|
|
# A configuration sub-Makefile is present -- simply run it.
|
|
#
|
|
all: single
|
|
|
|
BUILD_PROJECT := yes
|
|
include $(CONFIG_MK)
|
|
|
|
endif # test check_platform
|
|
|
|
|
|
# We always need the list of modules in ftmodule.h.
|
|
#
|
|
all setup: $(FTMODULE_H)
|
|
|
|
|
|
# The `modules' target unconditionally rebuilds the module list.
|
|
#
|
|
modules:
|
|
$(FTMODULE_H_INIT)
|
|
$(FTMODULE_H_CREATE)
|
|
$(FTMODULE_H_DONE)
|
|
|
|
include $(TOP_DIR)/builds/modules.mk
|
|
|
|
|
|
# EOF
|