############################################################################### # Fonts shipped with the SDK need to be renamed for Java to handle them # properly. Hence, a special script is used to rename the fonts. We bundle all # the fonts that are shipped on a newer non-space-constrained device. However, # OpenType fonts used on these devices are not supported by Java. Their # replacements are added separately. ############################################################################### # The script that renames the font. sdk_font_rename_script := frameworks/base/tools/layoutlib/rename_font/build_font_single.py # Location of the fonttools library that the above script depends on. fonttools_lib := external/fonttools/Lib # A temporary location to store the renamed fonts. atree picks all files in # this directory and bundles it with the SDK. SDK_FONT_TEMP := $(call intermediates-dir-for,PACKAGING,sdk-fonts,HOST,COMMON) # The font configuration files - system_fonts.xml, fallback_fonts.xml etc. sdk_font_config := $(wildcard frameworks/base/data/fonts/*.xml) sdk_font_config := $(addprefix $(SDK_FONT_TEMP)/, $(notdir $(sdk_font_config))) $(sdk_font_config): $(SDK_FONT_TEMP)/%.xml: \ frameworks/base/data/fonts/%.xml $(hide) mkdir -p $(dir $@) $(hide) cp -vf $< $@ # List of fonts on the device that we want to ship. This is all .ttf fonts. sdk_fonts_device := $(filter $(TARGET_OUT)/fonts/%.ttf, $(INTERNAL_SYSTEMIMAGE_FILES)) sdk_fonts_device := $(addprefix $(SDK_FONT_TEMP)/, $(notdir $(sdk_fonts_device))) # Macro to rename the font. sdk_rename_font = PYTHONPATH=$$PYTHONPATH:$(fonttools_lib) $(sdk_font_rename_script) \ $1 $2 # TODO: If the font file is a symlink, reuse the font renamed from the symlink # target. $(sdk_fonts_device): $(SDK_FONT_TEMP)/%.ttf: $(TARGET_OUT)/fonts/%.ttf \ $(sdk_font_rename_script) $(hide) mkdir -p $(dir $@) $(hide) $(call sdk_rename_font,$<,$@) # List of all dependencies - all fonts and configuration files. SDK_FONT_DEPS := $(sdk_fonts_device) $(sdk_font_config) # Define a macro to create rule for addititional fonts that we want to include # in the SDK. # $1 Output font name # $2 Source font path define sdk-extra-font-rule fontfullname := $$(SDK_FONT_TEMP)/$1 ifeq ($$(filter $$(fontfullname),$$(sdk_fonts_device)),) SDK_FONT_DEPS += $$(fontfullname) $$(fontfullname): $2 $$(sdk_font_rename_script) $$(hide) mkdir -p $$(dir $$@) $$(hide) $$(call sdk_rename_font,$$<,$$@) endif fontfullname := endef # These extra fonts are used as a replacement for OpenType fonts. $(eval $(call sdk-extra-font-rule,NanumGothic.ttf,external/naver-fonts/NanumGothic.ttf)) $(eval $(call sdk-extra-font-rule,DroidSansFallback.ttf,frameworks/base/data/fonts/DroidSansFallbackFull.ttf)) sdk-extra-font-rule :=