summaryrefslogtreecommitdiff
path: root/tex/context/base/page-lin.lua
diff options
context:
space:
mode:
authorContext Git Mirror Bot <phg42.2a@gmail.com>2015-08-13 20:15:07 +0200
committerContext Git Mirror Bot <phg42.2a@gmail.com>2015-08-13 20:15:07 +0200
commitce5f19af64d3127dd778171a9d2d00b1e2a3cbde (patch)
treebbaf50cce6c0c004051e5c2f39604f7f0134c15e /tex/context/base/page-lin.lua
parent66db77c6c85c275101199dac3fead77cf6ef4315 (diff)
downloadcontext-ce5f19af64d3127dd778171a9d2d00b1e2a3cbde.tar.gz
2015-08-13 19:35:00
Diffstat (limited to 'tex/context/base/page-lin.lua')
-rw-r--r--tex/context/base/page-lin.lua54
1 files changed, 45 insertions, 9 deletions
diff --git a/tex/context/base/page-lin.lua b/tex/context/base/page-lin.lua
index d2476b2da..73dba30b6 100644
--- a/tex/context/base/page-lin.lua
+++ b/tex/context/base/page-lin.lua
@@ -237,7 +237,7 @@ local function check_number(n,a,skip,sameline)
report_lines("skipping line number %s for setup %a: %s (%s)",#current_list,a,s,d.continue or v_no)
end
end
- ctx_makelinenumber(tag,skipflag,s,getfield(n,"shift"),getfield(n,"width"),leftmarginwidth(getlist(n)),getfield(n,"dir"))
+ ctx_makelinenumber(tag,skipflag,s,getfield(n,"width"),getfield(n,"dir"))
end
end
@@ -357,6 +357,38 @@ end
-- setfield(h,"list",ti) -- the number
-- setfield(n,"list",h)
+-- function boxed.stage_two(n,m)
+-- if #current_list > 0 then
+-- m = m or lines.scratchbox
+-- local t, tn = { }, 0
+-- for l in traverse_id(hlist_code,getlist(getbox(m))) do
+-- tn = tn + 1
+-- t[tn] = copy_node(l) -- use take_box instead
+-- end
+-- for i=1,#current_list do
+-- local li = current_list[i]
+-- local n, m, ti = li[1], li[2], t[i]
+-- if ti then
+-- local d = getfield(n,"dir")
+-- local l = getlist(n)
+-- if d == "TRT" then
+-- local w = getfield(n,"width")
+-- ti = hpack_nodes(linked_nodes(new_kern(-w),ti,new_kern(w)))
+-- end
+-- setfield(ti,"next",l)
+-- setfield(l,"prev",ti)
+-- setfield(n,"list",ti)
+-- resolve(n,m)
+-- else
+-- report_lines("error in linenumbering (1)")
+-- return
+-- end
+-- end
+-- end
+-- end
+
+local addtoline = typesetters.paragraphs and typesetters.paragraphs.addtoline
+
function boxed.stage_two(n,m)
if #current_list > 0 then
m = m or lines.scratchbox
@@ -369,15 +401,19 @@ function boxed.stage_two(n,m)
local li = current_list[i]
local n, m, ti = li[1], li[2], t[i]
if ti then
- local d = getfield(n,"dir")
- local l = getlist(n)
- if d == "TRT" then
- local w = getfield(n,"width")
- ti = hpack_nodes(linked_nodes(new_kern(-w),ti,new_kern(w)))
+ if addtoline then
+ addtoline(n,ti)
+ else
+ local d = getfield(n,"dir")
+ local l = getlist(n)
+ if d == "TRT" then
+ local w = getfield(n,"width")
+ ti = hpack_nodes(linked_nodes(new_kern(-w),ti,new_kern(w)))
+ end
+ setfield(ti,"next",l)
+ setfield(l,"prev",ti)
+ setfield(n,"list",ti)
end
- setfield(ti,"next",l)
- setfield(l,"prev",ti)
- setfield(n,"list",ti)
resolve(n,m)
else
report_lines("error in linenumbering (1)")