Official mirror of https://gitlab.freedesktop.org/freetype/freetype
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
322 lines
8.5 KiB
322 lines
8.5 KiB
# |
|
# FreeType build system -- top-level sub-Makefile |
|
# |
|
|
|
|
|
# Copyright (C) 1996-2022 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 includes the rules found |
|
# in `PROJECT/builds/detect.mk'. They are in charge of detecting the |
|
# current platform. |
|
# |
|
# A summary of the detection is displayed, and the file `config.mk' is |
|
# created in the current directory. |
|
# |
|
# - When invoked later, this Makefile includes the rules found in |
|
# `config.mk'. This sub-Makefile defines some system-specific variables |
|
# (like compiler, compilation flags, object suffix, etc.), then includes |
|
# 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. |
|
|
|
|
|
# First of all, check whether we have `$(value ...)'. We do this by testing |
|
# for `$(eval ...)' which has been introduced in the same GNU make version. |
|
|
|
eval_available := |
|
$(eval eval_available := T) |
|
ifneq ($(eval_available),T) |
|
$(error FreeType's build system needs a Make program which supports $$(value)) |
|
endif |
|
|
|
|
|
.PHONY: all dist distclean modules setup |
|
|
|
|
|
# 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 |
|
# class file resides. |
|
# |
|
FTMODULE_H ?= $(OBJ_DIR)/ftmodule.h |
|
|
|
|
|
include $(MODULES_CFG) |
|
|
|
|
|
# The list of modules we are using. |
|
# |
|
MODULES := $(FONT_MODULES) \ |
|
$(HINTING_MODULES) \ |
|
$(RASTER_MODULES) \ |
|
$(AUX_MODULES) |
|
|
|
|
|
CONFIG_MK ?= config.mk |
|
|
|
# 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 |
|
|
|
# For builds directly from the git repository we need to copy files |
|
# from `subprojects/dlg' to `src/dlg' and `include/dlg'. |
|
# |
|
ifeq ($(wildcard $(TOP_DIR)/src/dlg/dlg.*),) |
|
ifeq ($(wildcard $(TOP_DIR)/subprojects/dlg/*),) |
|
copy_submodule: check_out_submodule |
|
endif |
|
|
|
setup: copy_submodule |
|
endif |
|
|
|
# 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 windows' 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 /dev/null) \ |
|
$(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 |
|
|
|
|
|
.PHONY: check_out_submodule copy_submodule |
|
|
|
check_out_submodule: |
|
$(info Checking out submodule in `subprojects/dlg') |
|
git submodule init |
|
git submodule update |
|
|
|
copy_submodule: |
|
$(info Copying files from `subprojects/dlg' to `src/dlg' and `include/dlg') |
|
ifeq ($(wildcard include/dlg),) |
|
mkdir $(subst /,$(SEP),include/dlg) |
|
endif |
|
$(COPY) $(subst /,$(SEP),subprojects/dlg/include/dlg/output.h include/dlg) |
|
$(COPY) $(subst /,$(SEP),subprojects/dlg/include/dlg/dlg.h include/dlg) |
|
$(COPY) $(subst /,$(SEP),subprojects/dlg/src/dlg/dlg.c src/dlg) |
|
|
|
|
|
# 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 |
|
|
|
|
|
# get FreeType version string, using a |
|
# poor man's `sed' emulation with make's built-in string functions |
|
# |
|
work := $(strip $(shell $(CAT) \ |
|
$(subst /,$(SEP),$(TOP_DIR)/include/freetype/freetype.h))) |
|
work := $(subst |,x,$(work)) |
|
work := $(subst $(space),|,$(work)) |
|
work := $(subst \#define|FREETYPE_MAJOR|,$(space),$(work)) |
|
work := $(word 2,$(work)) |
|
major := $(subst |,$(space),$(work)) |
|
major := $(firstword $(major)) |
|
|
|
work := $(subst \#define|FREETYPE_MINOR|,$(space),$(work)) |
|
work := $(word 2,$(work)) |
|
minor := $(subst |,$(space),$(work)) |
|
minor := $(firstword $(minor)) |
|
|
|
work := $(subst \#define|FREETYPE_PATCH|,$(space),$(work)) |
|
work := $(word 2,$(work)) |
|
patch := $(subst |,$(space),$(work)) |
|
patch := $(firstword $(patch)) |
|
|
|
# ifneq ($(findstring x0x,x$(patch)x),) |
|
# version := $(major).$(minor) |
|
# winversion := $(major)$(minor) |
|
# else |
|
version := $(major).$(minor).$(patch) |
|
winversion := $(major)$(minor)$(patch) |
|
version_tag := VER-$(major)-$(minor)-$(patch) |
|
# endif |
|
|
|
|
|
# This target builds the tarballs. |
|
# |
|
# Not to be run by a normal user -- there are no attempts to make it |
|
# generic. |
|
|
|
dist: |
|
-rm -rf tmp |
|
rm -f freetype-$(version).tar.gz |
|
rm -f freetype-$(version).tar.xz |
|
rm -f ft$(winversion).zip |
|
|
|
for d in `find . -wholename '*/.git' -prune \ |
|
-o -type f \ |
|
-o -print` ; do \ |
|
mkdir -p tmp/$$d ; \ |
|
done ; |
|
|
|
currdir=`pwd` ; \ |
|
for f in `find . -wholename '*/.git' -prune \ |
|
-o -name .gitattributes \ |
|
-o -name .gitignore \ |
|
-o -name .gitlab-ci.yml \ |
|
-o -name .gitmodules \ |
|
-o -name .mailmap \ |
|
-o -type d \ |
|
-o -print` ; do \ |
|
ln -s $$currdir/$$f tmp/$$f ; \ |
|
done |
|
|
|
cd tmp ; \ |
|
$(MAKE) devel ; \ |
|
$(MAKE) do-dist |
|
|
|
mv tmp freetype-$(version) |
|
|
|
tar -H ustar -chf - freetype-$(version) \ |
|
| gzip -9 -c > freetype-$(version).tar.gz |
|
tar -H ustar -chf - freetype-$(version) \ |
|
| xz -c > freetype-$(version).tar.xz |
|
|
|
@# Use CR/LF for zip files. |
|
zip -lr9 ft$(winversion).zip freetype-$(version) |
|
|
|
rm -fr freetype-$(version) |
|
|
|
|
|
# The locations of the latest `config.guess' and `config.sub' versions (from |
|
# GNU `config' git repository), relative to the `tmp' directory used during |
|
# `make dist'. |
|
# |
|
CONFIG_GUESS = ~/git/config/config.guess |
|
CONFIG_SUB = ~/git/config/config.sub |
|
|
|
# We also use this repository to access the gnulib script that converts git |
|
# commit messages to a ChangeLog file. |
|
CHANGELOG_SCRIPT = ~/git/config/gitlog-to-changelog |
|
|
|
|
|
# Don't say `make do-dist'. Always use `make dist' instead. |
|
# |
|
.PHONY: do-dist |
|
|
|
do-dist: distclean refdoc |
|
@# Without removing the files, `autoconf' and friends follow links. |
|
rm -f builds/unix/aclocal.m4 |
|
rm -f builds/unix/configure.ac |
|
rm -f builds/unix/configure |
|
|
|
sh autogen.sh |
|
rm -rf builds/unix/autom4te.cache |
|
|
|
cp $(CONFIG_GUESS) builds/unix |
|
cp $(CONFIG_SUB) builds/unix |
|
|
|
@# Generate `ChangeLog' file with commits since release 2.11.0 |
|
@# (when we stopped creating this file manually). |
|
$(CHANGELOG_SCRIPT) \ |
|
--format='%B%n' \ |
|
--no-cluster \ |
|
-- VER-2-11-0..$(version_tag) \ |
|
> ChangeLog |
|
|
|
@# Remove intermediate files created by the `refdoc' target. |
|
rm -rf docs/markdown |
|
rm -f docs/mkdocs.yml |
|
|
|
@# Remove more stuff related to git. |
|
rm -rf subprojects/dlg |
|
|
|
# EOF
|
|
|