From e343508964be6518698e3b9ed211b487d985bd92 Mon Sep 17 00:00:00 2001 From: Philipp Gesang Date: Sun, 26 Jan 2014 13:21:04 +0100 Subject: [db] integrate the values for italic angle and weight into style choice --- luaotfload-database.lua | 74 ++++++++++++++++++++++++++++++++++++++----------- 1 file changed, 58 insertions(+), 16 deletions(-) diff --git a/luaotfload-database.lua b/luaotfload-database.lua index 98c5d3f..09106a5 100644 --- a/luaotfload-database.lua +++ b/luaotfload-database.lua @@ -1479,10 +1479,7 @@ local organize_styledata = function (fontname, return { -- see http://www.microsoft.com/typography/OTSPEC/features_pt.htm#size size = get_size_info (metadata), - weight = { - pfminfo.weight, -- integer (multiple of 100?) - sanitize_fontname (info.weight), -- style name - }, + weight = pfminfo.weight or 400, split = split_fontname (fontname), width = pfminfo.width, italicangle = metadata.italicangle, @@ -1601,8 +1598,7 @@ t1_fullinfo = function (filename, _subfont, location, basename, format) size = false, splitstyle = splitstyle, fontstyle_name = style ~= "" and style or weight, - weight = { metadata.pfminfo.weight, - weight }, + weight = metadata.pfminfo.weight or 400, italicangle = italicangle, } end @@ -2458,13 +2454,55 @@ local check_regular do local splitfontname = lpeg.splitat "-" - local choose_exact = function (field) - if italic_synonym [field] then + --[[doc-- + + Regarding the italic angle, only a small minority of fonts advertise + oblique shape despite having a zero angle. On my machine, these are + + + # /luaotfload-tool.lua --list=subfamily:italic --fields=italicangle,plainname | grep -e '\s0\s' | cut -f 2,3 + 0 Quattrocento Sans Italic + 0 Libre Baskerville Italic + 0 Cabin Italic + 0 PersianModern-Italic + 0 PersianModern-ItalicShadow + 0 PersianModern-ItalicOutline + 0 Alegreya SC Italic + 0 Alegreya Italic + 0 XB Niloofar Italic + 0 Bukyvede-Italic + + (Weirdly, some of those set a nonzero italic angle only for the + bold italic variant, while neglecting to do so for the oblique + shape with normal weight ...) + These outliers can be detected by checking the appropriate subfamily + etc. fields. + + --doc]]-- + + local choose_exact = function (field, weight, italicangle) + local i = false + local b = false + + if italicangle ~= 0 or italic_synonym [field] then + i = true + end + + if weight == 700 or field == "bold" then + b = true + end + + if field == "bolditalic" or field == "boldoblique" then + b = true + i = true + end + + if i and b then + return "bi" + elseif i then return "i" - elseif field == "bold" then + elseif b then return "b" - elseif field == "bolditalic" or field == "boldoblique" then - return "bi" end return false @@ -2473,16 +2511,18 @@ do pick_style = function (fontstyle_name, prefmodifiers, subfamily, - splitstyle) + splitstyle, + weight, + italicangle) local style if fontstyle_name then - style = choose_exact (fontstyle_name) + style = choose_exact (fontstyle_name, weight, italicangle) end if not style then if prefmodifiers then - style = choose_exact (prefmodifiers) + style = choose_exact (prefmodifiers, weight, italicangle) elseif subfamily then - style = choose_exact (subfamily) + style = choose_exact (subfamily, weight, italicangle) end end -- if not style and splitstyle then @@ -2628,7 +2668,9 @@ local collect_families = function (mappings) local modifier = pick_style (fontstyle_name, prefmodifiers, subfamily, - splitstyle) + splitstyle, + weight, + italicangle) if not modifier then --- regular, exact only modifier = check_regular (fontstyle_name, -- cgit v1.2.3 From 3a82aa62d66be113ef4d5f13e9723d70943b02e3 Mon Sep 17 00:00:00 2001 From: Philipp Gesang Date: Sun, 26 Jan 2014 13:23:39 +0100 Subject: [tool] remove obsolete source documentation --- luaotfload-tool.lua | 15 --------------- 1 file changed, 15 deletions(-) diff --git a/luaotfload-tool.lua b/luaotfload-tool.lua index 32086e1..5b7e0a2 100755 --- a/luaotfload-tool.lua +++ b/luaotfload-tool.lua @@ -88,21 +88,6 @@ end require(loader_path) ---[[doc-- -Depending on how the script is called we change its behavior. -For backwards compatibility, moving or symlinking the script to a -file name starting with \fileent{mkluatexfontdb} will cause it to -trigger a database update on every run. -Running as \fileent{luaotfload-tool} -- the new name -- will do this upon -request only. - -There are two naming conventions followed here: firstly that of -utilities such as \fileent{mktexpk}, \fileent{mktexlsr} and the likes, -and secondly that of \fileent{fmtutil}. -After support for querying the database was added, the latter appeared -to be the more appropriate. ---doc]]-- - config = config or { } local config = config local luaotfloadconfig = config.luaotfload or { } -- cgit v1.2.3 From 0f8d086d5f04f945198c054bc80c2a4f19cc6a8e Mon Sep 17 00:00:00 2001 From: Philipp Gesang Date: Sun, 26 Jan 2014 13:38:16 +0100 Subject: [db] do not rely on italic angle when determining the font style The italic angle will be non-zero for semibold and other variants which messes up the assignment of font families. --- luaotfload-database.lua | 46 +++++++--------------------------------------- 1 file changed, 7 insertions(+), 39 deletions(-) diff --git a/luaotfload-database.lua b/luaotfload-database.lua index 09106a5..28109ec 100644 --- a/luaotfload-database.lua +++ b/luaotfload-database.lua @@ -1483,10 +1483,6 @@ local organize_styledata = function (fontname, split = split_fontname (fontname), width = pfminfo.width, italicangle = metadata.italicangle, --- italicangle = { --- metadata.italicangle, -- float --- info.italicangle, -- truncated to integer point size? --- }, --- this is for querying, see www.ntg.nl/maps/40/07.pdf for details units_per_em = metadata.units_per_em, version = metadata.version, @@ -2454,37 +2450,11 @@ local check_regular do local splitfontname = lpeg.splitat "-" - --[[doc-- - - Regarding the italic angle, only a small minority of fonts advertise - oblique shape despite having a zero angle. On my machine, these are - - - # /luaotfload-tool.lua --list=subfamily:italic --fields=italicangle,plainname | grep -e '\s0\s' | cut -f 2,3 - 0 Quattrocento Sans Italic - 0 Libre Baskerville Italic - 0 Cabin Italic - 0 PersianModern-Italic - 0 PersianModern-ItalicShadow - 0 PersianModern-ItalicOutline - 0 Alegreya SC Italic - 0 Alegreya Italic - 0 XB Niloofar Italic - 0 Bukyvede-Italic - - (Weirdly, some of those set a nonzero italic angle only for the - bold italic variant, while neglecting to do so for the oblique - shape with normal weight ...) - These outliers can be detected by checking the appropriate subfamily - etc. fields. - - --doc]]-- - - local choose_exact = function (field, weight, italicangle) + local choose_exact = function (field, weight) local i = false local b = false - if italicangle ~= 0 or italic_synonym [field] then + if italic_synonym [field] then i = true end @@ -2512,17 +2482,16 @@ do prefmodifiers, subfamily, splitstyle, - weight, - italicangle) + weight) local style if fontstyle_name then - style = choose_exact (fontstyle_name, weight, italicangle) + style = choose_exact (fontstyle_name, weight) end if not style then if prefmodifiers then - style = choose_exact (prefmodifiers, weight, italicangle) + style = choose_exact (prefmodifiers, weight) elseif subfamily then - style = choose_exact (subfamily, weight, italicangle) + style = choose_exact (subfamily, weight) end end -- if not style and splitstyle then @@ -2669,8 +2638,7 @@ local collect_families = function (mappings) prefmodifiers, subfamily, splitstyle, - weight, - italicangle) + weight) if not modifier then --- regular, exact only modifier = check_regular (fontstyle_name, -- cgit v1.2.3 From 814443264c28faa585b364196b164cf5a9eed4ba Mon Sep 17 00:00:00 2001 From: Philipp Gesang Date: Sun, 26 Jan 2014 13:47:46 +0100 Subject: [parsers] fix incomplete feature separator rule --- luaotfload-parsers.lua | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/luaotfload-parsers.lua b/luaotfload-parsers.lua index 42a43aa..51d251c 100644 --- a/luaotfload-parsers.lua +++ b/luaotfload-parsers.lua @@ -56,6 +56,7 @@ local lfsisdir = lfs.isdir local dot = P"." local colon = P":" +local semicolon = P";" local comma = P"," local noncomma = 1 - comma local slash = P"/" @@ -476,7 +477,7 @@ local check_garbage = function (_,i, garbage) return false end -local featuresep = comma +local featuresep = comma + semicolon --- modifiers --------------------------------------------------------- --[[doc-- -- cgit v1.2.3