--
luatexbase.provides_module({
name = 'luatexja.jfont',
- date = '2015/05/03',
+ date = '2015/09/19',
description = 'Loader for Japanese fonts',
})
module('luatexja.jfont', package.seeall)
local defjfm_res
local jfm_dir, is_def_jfont, is_vert_enabled
+local function norm_val(a)
+ if (not a) or (a==0.) then
+ return nil
+ elseif a==true then
+ return 1
+ else
+ return a
+ end
+end
+
+
function define_jfm(t)
local real_char -- Does current character class have the 'real' character?
if t.dir~=jfm_dir then
end
v.kern = v.kern or {}; v.glue = v.glue or {}
for j,x in pairs(v.glue) do
+ if v.kern[j] then defjfm_res= nil; return end
x.ratio, x[5] = (x.ratio or (x[5] and 0.5*(1+x[5]) or 0.5)), nil
x.priority, x[4] = (x.priority or x[4] or 0), nil
- if v.kern[j] then defjfm_res= nil; return end
+ x.ksp_natural = norm_val(x.ksp_natural)
+ x.ksp_stretch = norm_val(x.ksp_stretch)
+ x.ksp_shrink = norm_val(x.ksp_shrink)
end
for j,x in pairs(v.kern) do
if type(x)=='number' then
v.kern[j] = {x, 0.5}
elseif type(x)=='table' then
- v.kern[j] = { x[1], ratio=x.ratio or x[2] or 0.5 }
+ v.kern[j] = { x[1], ratio=x.ratio or (x[2] and 0.5*(1+x[2]) or 0.5) }
end
end
t.char_type[i] = v
return new
else return nil end
end
-
update_jfm_cache = function (j,sz)
if metrics[j].size_cache[sz] then return end
--local TEMP = node_new(id_kern)
true, h,
ratio=w.ratio/sz,
priority=FROM_JFM + w.priority/sz,
- ksp_natural = w.ksp_natural,
- ksp_stretch = w.ksp_stretch,
- ksp_shrink = w.ksp_shrink,
+ ksp_natural = w.ksp_natural and w.ksp_natural/sz,
+ ksp_stretch = w.ksp_stretch and w.ksp_stretch/sz,
+ ksp_shrink = w.ksp_shrink and w.ksp_shrink/sz,
}
setfield(h, 'width', w[1])
setfield(h, 'stretch', w[2])
local bx = font_extra_basename[bname].vkerns
local lookuphash = id.resources.lookuphash
local desc = id.shared.rawdata.descriptions
- if bx then
+ if bx and lookuphash then
for i,v in pairs(bx) do
lookuphash[i] = lookuphash[i] or v
for j,w in pairs(v) do