1# FreeType 2 top Jamfile. 2# 3# Copyright 2001-2018 by 4# David Turner, Robert Wilhelm, and Werner Lemberg. 5# 6# This file is part of the FreeType project, and may only be used, modified, 7# and distributed under the terms of the FreeType project license, 8# LICENSE.TXT. By continuing to use, modify, or distribute this file you 9# indicate that you have read the license and understand and accept it 10# fully. 11 12 13# The HDRMACRO is already defined in FTJam and is used to add 14# the content of certain macros to the list of included header 15# files. 16# 17# We can compile FreeType 2 with classic Jam however thanks to 18# the following code 19# 20if ! $(JAM_TOOLSET) 21{ 22 rule HDRMACRO 23 { 24 # nothing 25 } 26} 27 28 29# We need to invoke a SubDir rule if the FT2 source directory top is not the 30# current directory. This allows us to build FreeType 2 as part of a larger 31# project easily. 32# 33if $(FT2_TOP) != $(DOT) 34{ 35 SubDir FT2_TOP ; 36} 37 38 39# The following macros define the include directory, the source directory, 40# and the final library name (without library extensions). They can be 41# replaced by other definitions when the library is compiled as part of 42# a larger project. 43# 44 45# Name of FreeType include directory during compilation. 46# This is relative to FT2_TOP. 47# 48FT2_INCLUDE_DIR ?= include ; 49 50# Name of FreeType source directory during compilation. 51# This is relative to FT2_TOP. 52# 53FT2_SRC_DIR ?= src ; 54 55# Name of final library, without extension. 56# 57FT2_LIB ?= $(LIBPREFIX)freetype ; 58 59 60# Define FT2_BUILD_INCLUDE to point to your build-specific directory. 61# This is prepended to FT2_INCLUDE_DIR. It can be used to specify 62# the location of a custom <ft2build.h> which will point to custom 63# versions of `ftmodule.h' and `ftoption.h', for example. 64# 65FT2_BUILD_INCLUDE ?= ; 66 67# The list of modules to compile on any given build of the library. 68# By default, this will contain _all_ modules defined in FT2_SRC_DIR. 69# 70# IMPORTANT: You'll need to change the content of `ftmodule.h' as well 71# if you modify this list or provide your own. 72# 73FT2_COMPONENTS ?= autofit # auto-fitter 74 base # base component (public APIs) 75 bdf # BDF font driver 76 bzip2 # support for bzip2-compressed PCF font 77 cache # cache sub-system 78 cff # CFF/CEF font driver 79 cid # PostScript CID-keyed font driver 80 gzip # support for gzip-compressed PCF font 81 lzw # support for LZW-compressed PCF font 82 pcf # PCF font driver 83 pfr # PFR/TrueDoc font driver 84 psaux # common PostScript routines module 85 pshinter # PostScript hinter module 86 psnames # PostScript names handling 87 raster # monochrome rasterizer 88 sfnt # SFNT-based format support routines 89 smooth # anti-aliased rasterizer 90 truetype # TrueType font driver 91 type1 # PostScript Type 1 font driver 92 type42 # PostScript Type 42 (embedded TrueType) driver 93 winfonts # Windows FON/FNT font driver 94 ; 95 96 97# Don't touch. 98# 99FT2_INCLUDE = $(FT2_BUILD_INCLUDE) 100 [ FT2_SubDir $(FT2_INCLUDE_DIR) ] ; 101 102FT2_SRC = [ FT2_SubDir $(FT2_SRC_DIR) ] ; 103 104# Location of API Reference Documentation 105# 106if $(DOC_DIR) 107{ 108 DOC_DIR = $(DOCDIR:T) ; 109} 110else 111{ 112 DOC_DIR = docs/reference ; 113} 114 115 116# Only used by FreeType developers. 117# 118if $(DEBUG_HINTER) 119{ 120 CCFLAGS += -DDEBUG_HINTER ; 121} 122 123 124# We need `include' in the current include path in order to 125# compile any part of FreeType 2. 126# 127HDRS += $(FT2_INCLUDE) ; 128 129 130# We need to #define FT2_BUILD_LIBRARY so that our sources find the 131# internal headers 132# 133CCFLAGS += -DFT2_BUILD_LIBRARY ; 134 135# Uncomment the following line if you want to build individual source files 136# for each FreeType 2 module. This is only useful during development, and 137# is better defined as an environment variable anyway! 138# 139# FT2_MULTI = true ; 140 141 142# The files `ftheader.h', `internal.h', and `ftserv.h' are used to define 143# macros that are later used in #include statements. They need to be parsed 144# in order to record these definitions. 145# 146HDRMACRO [ FT2_SubDir $(FT2_INCLUDE_DIR) freetype config ftheader.h ] ; 147HDRMACRO [ FT2_SubDir $(FT2_INCLUDE_DIR) freetype internal internal.h ] ; 148HDRMACRO [ FT2_SubDir $(FT2_INCLUDE_DIR) freetype internal ftserv.h ] ; 149 150 151# Now include the Jamfile in `freetype2/src', used to drive the compilation 152# of each FreeType 2 component and/or module. 153# 154SubInclude FT2_TOP $(FT2_SRC_DIR) ; 155 156# Handle the generation of the `ftexport.sym' file, which contains the list 157# of exported symbols. This can be used on Unix by libtool. 158# 159SubInclude FT2_TOP $(FT2_SRC_DIR) tools ; 160 161rule GenExportSymbols 162{ 163 local apinames = apinames$(SUFEXE) ; 164 local aheader ; 165 local headers ; 166 167 for aheader in [ Glob $(2) : *.h ] 168 { 169 switch $(aheader) 170 { 171 case */ftmac.h : 172 if ( $(MAC) || $(OS) = MACOSX ) { 173 headers += $(aheader) ; 174 } 175 case *.h : headers += $(aheader) ; 176 } 177 } 178 179 LOCATE on $(1) = $(ALL_LOCATE_TARGET) ; 180 181 APINAMES on $(1) = apinames$(SUFEXE) ; 182 183 Depends $(1) : $(apinames) $(headers) ; 184 GenExportSymbols1 $(1) : $(headers) ; 185 Clean clean : $(1) ; 186} 187 188actions GenExportSymbols1 bind APINAMES 189{ 190 $(APINAMES) $(2) > $(1) 191} 192 193GenExportSymbols ftexport.sym : include/freetype ; 194 195# Test files (hinter debugging). Only used by FreeType developers. 196# 197if $(DEBUG_HINTER) 198{ 199 SubInclude FT2_TOP tests ; 200} 201 202rule RefDoc 203{ 204 Depends $1 : all ; 205 NotFile $1 ; 206 Always $1 ; 207} 208 209actions RefDoc 210{ 211 python $(FT2_SRC)/tools/docmaker/docmaker.py 212 --prefix=ft2 213 --title=FreeType-2.9 214 --output=$(DOC_DIR) 215 $(FT2_INCLUDE)/freetype/*.h 216 $(FT2_INCLUDE)/freetype/config/*.h 217} 218 219RefDoc refdoc ; 220 221 222# end of top Jamfile 223