diff options
author | Context Git Mirror Bot <phg42.2a@gmail.com> | 2015-08-13 20:15:07 +0200 |
---|---|---|
committer | Context Git Mirror Bot <phg42.2a@gmail.com> | 2015-08-13 20:15:07 +0200 |
commit | ce5f19af64d3127dd778171a9d2d00b1e2a3cbde (patch) | |
tree | bbaf50cce6c0c004051e5c2f39604f7f0134c15e /tex/context/base/page-lin.lua | |
parent | 66db77c6c85c275101199dac3fead77cf6ef4315 (diff) | |
download | context-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.lua | 54 |
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)") |