--
luatexbase.provides_module({
name = 'luatexja.stack',
- date = '2020-07-30',
+ date = '2022-08-17',
description = 'LuaTeX-ja stack system',
})
luatexja.stack = {}
local fastcopy = table.fastcopy
local setcount, getcount = tex.setcount, tex.getcount
local scan_int, scan_keyword = token.scan_int, token.scan_keyword
+local tex_nest = tex.nest
ltjs.hmode = 0 -- dummy
local charprop_stack_table={};
+
ltjs.charprop_stack_table = charprop_stack_table
charprop_stack_table[0]={}
charprop_stack_table[i] = fastcopy(charprop_stack_table[i-1])
setcount('ltj@@stack', i)
if gd~=0 then tex.globaldefs = gd end
- if tex.nest[tex.nest.ptr].mode == -ltjs.hmode then -- rest. hmode のみ
+ if tex_nest[tex_nest.ptr].mode == -ltjs.hmode then -- rest. hmode のみ
local g = node_new(id_whatsit, sid_user)
g.user_id=STCK; g.type=100; g.value=j; node.write(g)
end
local i = get_stack_level()
charprop_stack_table[i][m] = p
if luatexja.isglobal=='global' then
- for j,v in pairs(charprop_stack_table) do
- charprop_stack_table[j][m] = p
- end
+ for j,v in pairs(charprop_stack_table) do v[m] = p end
end
end
ltjs.set_stack_table = set_stack_table
end
-- EXT: sp: glue_spec
+local getglue = node.getglue
function ltjs.set_stack_skip(m,sp)
local i = get_stack_level()
if not sp then return end
if not charprop_stack_table[i][m] then
charprop_stack_table[i][m] = {}
end
- charprop_stack_table[i][m].width = sp.width
- charprop_stack_table[i][m].stretch = sp.stretch
- charprop_stack_table[i][m].shrink = sp.shrink
- charprop_stack_table[i][m].stretch_order = sp.stretch_order
- charprop_stack_table[i][m].shrink_order = sp.shrink_order
+ local w,st,sh,sto,sho = getglue(sp)
+ local c = charprop_stack_table[i][m]
+ c.width, c.stretch, c.shrink, c.stretch_order, c.shrink_order = w, st, sh, sto, sho
if luatexja.isglobal=='global' then
for j,v in pairs(charprop_stack_table) do
- if not charprop_stack_table[j][m] then charprop_stack_table[j][m] = {} end
- charprop_stack_table[j][m].width = sp.width
- charprop_stack_table[j][m].stretch = sp.stretch
- charprop_stack_table[j][m].shrink = sp.shrink
- charprop_stack_table[j][m].stretch_order = sp.stretch_order
- charprop_stack_table[j][m].shrink_order = sp.shrink_order
+ if not v[m] then v[m] = {} end
+ local c = v[m]
+ c.width, c.stretch, c.shrink, c.stretch_order, c.shrink_order = w, st, sh, sto, sho
end
end
end
ltjs.orig_char_table = orig_char_table
ltjs.list_dir = nil -- dummy
ltjs.table_current_stack = nil -- dummy
+local dummy_skip_table = { width = 0, stretch = 0, shrink = 0, stretch_order = 0, shrink_order = 0 }
function ltjs.report_stack_level(bsl)
ltjs.table_current_stack = charprop_stack_table[bsl]
return bsl
end
function ltjs.fast_get_stack_skip(m)
- return ltjs.table_current_stack[m]
- or { width = 0, stretch = 0, shrink = 0, stretch_order = 0, shrink_order = 0 }
+ return ltjs.table_current_stack[m] or dummy_skip_table
end
-- For other situations, use the following instead:
function ltjs.get_stack_skip(m, idx)
- return charprop_stack_table[idx][m]
- or { width = 0, stretch = 0, shrink = 0, stretch_order = 0, shrink_order = 0 }
+ return charprop_stack_table[idx][m] or dummy_skip_table
end
function ltjs.get_stack_table(mc, d, idx)
- local i = charprop_stack_table[idx][mc]
- return i or d
+ return charprop_stack_table[idx][mc] or d
end