diff options
52 files changed, 1522 insertions, 830 deletions
diff --git a/context/data/scite/lexers/scite-context-lexer-pdf.lua b/context/data/scite/lexers/scite-context-lexer-pdf.lua index bddcc282d..05517bb64 100644 --- a/context/data/scite/lexers/scite-context-lexer-pdf.lua +++ b/context/data/scite/lexers/scite-context-lexer-pdf.lua @@ -12,7 +12,7 @@ local lexer = lexer local token = lexer.token local P, R, S = lpeg.P, lpeg.R, lpeg.S -local pdflexer = { "pdf" } +local pdflexer = { _NAME = "pdf" } local pdfobjectlexer = lexer.load("scite-context-lexer-pdf-object") local pdfxreflexer = lexer.load("scite-context-lexer-pdf-xref") @@ -60,3 +60,5 @@ pdflexer._rules = { } pdflexer._tokenstyles = context.styleset + +return pdflexer diff --git a/context/data/scite/scite-pragma.properties b/context/data/scite/scite-pragma.properties index 9e06a586a..450c609b0 100644 --- a/context/data/scite/scite-pragma.properties +++ b/context/data/scite/scite-pragma.properties @@ -24,7 +24,8 @@ $(filter.context)\ $(filter.metafun)\ $(filter.example)\ $(filter.lua)\ -$(filter.text) +$(filter.text)\ +$(filter.pdf) # Editor: menus @@ -33,4 +34,5 @@ TeX|tex||\ Metapost|metapost||\ XML|xml||\ Lua|lua||\ -Text|txt|| +Text|txt||\ +PDF|pdf|| diff --git a/metapost/context/base/mp-core.mpiv b/metapost/context/base/mp-core.mpiv index 25ad04abb..509801b02 100644 --- a/metapost/context/base/mp-core.mpiv +++ b/metapost/context/base/mp-core.mpiv @@ -390,6 +390,21 @@ def prepare_multi_pars (expr fn,fx,fy,fw,fh,fd, last_multi_par_shift := origin ; +% save _tx_, _ty_, _fx_, _fy_ ; +% if use_multi_par_region : +% _fx_ := fx ; %min(xpart ulcorner RegionTextArea,fx) ; +% _fy_ := fy ; %min(xpart ulcorner RegionTextArea,fy) ; +% _tx_ := min(xpart lrcorner RegionTextArea,tx) ; +% _ty_ := min(xpart lrcorner RegionTextArea,ty) ; +% else : +% _fx_ := fx ; +% _fy_ := fy ; +% _tx_ := tx ; +% _ty_ := ty ; +% fi ; + +% numeric fpos ; fpos := 1 ; initialize_box_pos(fpos,fn,_fx_,_fy_,fw,fh,fd) ; +% numeric tpos ; tpos := 2 ; initialize_box_pos(tpos,tn,_tx_,_ty_,tw,th,td) ; numeric fpos ; fpos := 1 ; initialize_box_pos(fpos,fn,fx,fy,fw,fh,fd) ; numeric tpos ; tpos := 2 ; initialize_box_pos(tpos,tn,tx,ty,tw,th,td) ; numeric wpos ; wpos := 3 ; initialize_box_pos(wpos,wn,wx,wy,ww,wh,wd) ; diff --git a/scripts/context/lua/mtxrun.lua b/scripts/context/lua/mtxrun.lua index 93110ad46..90ebe0b93 100644 --- a/scripts/context/lua/mtxrun.lua +++ b/scripts/context/lua/mtxrun.lua @@ -8249,8 +8249,8 @@ apply_axis['child'] = function(list) c = c + 1 collected[c] = dk dk.ni = k -- refresh - en = en + 1 - dk.ei = en + en = en + 1 + dk.ei = en end end ll.en = en diff --git a/scripts/context/stubs/mswin/mtxrun.lua b/scripts/context/stubs/mswin/mtxrun.lua index 93110ad46..90ebe0b93 100644 --- a/scripts/context/stubs/mswin/mtxrun.lua +++ b/scripts/context/stubs/mswin/mtxrun.lua @@ -8249,8 +8249,8 @@ apply_axis['child'] = function(list) c = c + 1 collected[c] = dk dk.ni = k -- refresh - en = en + 1 - dk.ei = en + en = en + 1 + dk.ei = en end end ll.en = en diff --git a/scripts/context/stubs/unix/mtxrun b/scripts/context/stubs/unix/mtxrun index 93110ad46..90ebe0b93 100644 --- a/scripts/context/stubs/unix/mtxrun +++ b/scripts/context/stubs/unix/mtxrun @@ -8249,8 +8249,8 @@ apply_axis['child'] = function(list) c = c + 1 collected[c] = dk dk.ni = k -- refresh - en = en + 1 - dk.ei = en + en = en + 1 + dk.ei = en end end ll.en = en diff --git a/tex/context/base/anch-bar.mkiv b/tex/context/base/anch-bar.mkiv index 47cd4835e..bebfaa714 100644 --- a/tex/context/base/anch-bar.mkiv +++ b/tex/context/base/anch-bar.mkiv @@ -110,13 +110,10 @@ linecolor=\getvalue{\??br#1\c!rulecolor}, distance=\the\sidebardistance}}% \stoppositionoverlay - \bpos{side:\the\currentsidebar}\ignorespaces} - -% \def\dostopsidebar#1% -% {\removelastspace\tpos{side:#1}\carryoverpar\egroup} + \bpos{side:\the\currentsidebar}} \unexpanded\def\stopsidebar - {\removelastspace\tpos{side:\the\currentsidebar}\carryoverpar\egroup} + {\removelastspace\epos{side:\the\currentsidebar}\carryoverpar\egroup} \startMPpositionmethod{mpos:bar} \startMPpositiongraphic{mpos:bar}{linecolor,linewidth,distance}% diff --git a/tex/context/base/anch-bck.mkvi b/tex/context/base/anch-bck.mkvi index bfe18a5cb..5ac1b039b 100644 --- a/tex/context/base/anch-bck.mkvi +++ b/tex/context/base/anch-bck.mkvi @@ -22,10 +22,10 @@ % This might be overloaded later on: -\defineoverlay[\v!text-2][\positionoverlay{\v!text-2}] -\defineoverlay[\v!text-1][\positionoverlay{\v!text-1}] -\defineoverlay[\v!text+1][\positionoverlay{\v!text+1}] -\defineoverlay[\v!text+2][\positionoverlay{\v!text+2}] +% \defineoverlay[\v!text-2][\positionoverlay{\v!text-2}] +% \defineoverlay[\v!text-1][\positionoverlay{\v!text-1}] +% \defineoverlay[\v!text+1][\positionoverlay{\v!text+1}] +% \defineoverlay[\v!text+2][\positionoverlay{\v!text+2}] % Paragraph positions: @@ -72,8 +72,6 @@ %D Some MP -\newcount\localpositionnumber % incremented elsewhere - \newcount\MPparcounter \def\MPself {\MPvar{self}} @@ -82,8 +80,7 @@ \def\MPwself {w:\MPvar{self}} \def\MPparanchor {p:\number\MPparcounter} -\def\textbackgroundoverlay#tag{\iflocalpositioning\v!local\else\v!text\fi#tag} -\def\MPanchornumber {\iflocalpositioning\the\localpositionnumber\else\the\realpageno\fi} +% \carryoverpar is needed for left/right floats % \definetextbackground[more][state=start,backgroundcolor=red] % location=paragraph % \definetextbackground[test][state=start,backgroundcolor=green] @@ -216,26 +213,26 @@ \unexpanded\def\stoptextbackground {\anch_backgrounds_text_stop_indeed - \carryoverpar\endgroup} + \carryoverpar\endgroup} % why doesn't this work ? \unexpanded\def\starttextbackgroundmanual {\begingroup \usetextbackgroundstyleandcolor\c!style\c!color - \fpos\v_anch_backgrounds_text_current\ignorespaces} + \bpos\v_anch_backgrounds_text_current} \unexpanded\def\stoptextbackgroundmanual - {\tpos\v_anch_backgrounds_text_current - \endgroup} + {\epos\v_anch_backgrounds_text_current + \carryoverpar\endgroup} \def\anch_backgrounds_text_start_txt {\ifvmode \dontleavehmode \fi \begingroup \usetextbackgroundstyleandcolor\c!style\c!color - \fpos\v_anch_backgrounds_text_current\ignorespaces} + \bpos\v_anch_backgrounds_text_current} \def\anch_backgrounds_text_stop_txt - {\tpos\v_anch_backgrounds_text_current - \endgroup} + {\epos\v_anch_backgrounds_text_current + \carryoverpar\endgroup} \newskip\textbackgroundskip @@ -249,12 +246,12 @@ \ifgridsnapping \spac_helpers_assign_skip\textbackgroundskip{\textbackgroundparameter\c!topoffset}% \ifdim\textbackgroundskip>\zeropoint - \struttedbox{\hbox{\raise\textbackgroundskip\hbox{\fpos\v_anch_backgrounds_text_current}}}% + \struttedbox{\hbox{\raise\textbackgroundskip\hbox{\bpos\v_anch_backgrounds_text_current}}}% \else - \fpos\v_anch_backgrounds_text_current + \bpos\v_anch_backgrounds_text_current \fi \else - \fpos\v_anch_backgrounds_text_current + \bpos\v_anch_backgrounds_text_current \fi \endgraf % we need a vertical nobreak - 29/06/2004 \endgroup @@ -303,15 +300,15 @@ \spac_helpers_assign_skip\textbackgroundskip{\textbackgroundparameter\c!bottomoffset}% \ifgridsnapping % experimental, pascal (todo: topoffset in same way) \ifdim\textbackgroundskip>\zeropoint - \struttedbox\plusone{\hbox{\lower\textbackgroundskip\hbox{\tpos\v_anch_backgrounds_text_current}}}% + \struttedbox\plusone{\hbox{\lower\textbackgroundskip\hbox{\epos\v_anch_backgrounds_text_current}}}% \else - \tpos\v_anch_backgrounds_text_current + \epos\v_anch_backgrounds_text_current \fi \else - \tpos\v_anch_backgrounds_text_current + \epos\v_anch_backgrounds_text_current \fi \endgraf - \endgroup + \carryoverpar\endgroup \endgraf % new \textbackgroundparameter\c!after} @@ -544,7 +541,7 @@ % we can flush 5 in one call (saved 4 lua calls) .. brrr wself .. will change -% \def\MPposset#1{\ctxcommand{MPposset("#1")}} +\def\MPposset#1{\ctxcommand{MPposset("#1")}} \startMPpositionmethod{mpos:par:columnset} \MPparcounter\MPn\MPbself\relax @@ -557,8 +554,8 @@ \startMPpositiongraphic{mpos:par}{fillcolor,filloffset,linecolor,gridcolor,linewidth,gridwidth,gridshift,lineradius} \includeMPgraphic{mpos:par:setup} ; \includeMPgraphic{mpos:par:extra} ; - prepare_multi_pars(\MPpos\MPbself,\MPpos\MPeself,\MPpos\MPwself,\MPpos\MPparanchor,\MPpardata\MPparanchor) ; - % prepare_multi_pars(\MPposset{\MPvar{self}}) ; + % prepare_multi_pars(\MPpos\MPbself,\MPpos\MPeself,\MPpos\MPwself,\MPpos\MPparanchor,\MPpardata\MPparanchor) ; + prepare_multi_pars(\MPposset{\MPvar{self}}) ; relocate_multipars(-\MPxy\MPanchorid) ; % inside layerpos \includeMPgraphic{\MPvar{mp}} ; \stopMPpositiongraphic @@ -566,6 +563,45 @@ \regionpositioningfalse \stopMPpositionmethod +% new: + +% \setuptextbackground +% [\c!mp=mpos:par:region, +% \c!method=mpos:par:region] + +\startMPpositionmethod{mpos:par:region} + \startMPpositiongraphic{mpos:par}{fillcolor,filloffset,linecolor,gridcolor,linewidth,gridwidth,gridshift,lineradius} + \includeMPgraphic{mpos:par:setup} ; + \includeMPgraphic{mpos:par:extra} ; + \ctxcommand{fetchmultipar("\MPvar{self}",\the\realpageno,"\MPanchorid")} + \includeMPgraphic{\MPvar{mp}} ; + setbounds currentpicture to multibox ; + \stopMPpositiongraphic + \MPpositiongraphic{mpos:par}{}% +\stopMPpositionmethod + +\startuseMPgraphic{mpos:par:region} + \iftracepositions + show_multi_pars + \else + draw_multi_pars + \fi ; +\stopuseMPgraphic + +\startuseMPgraphic{mpos:par:region:kind} + for i=1 upto nofmultipars : + fill multipars[i] %^ shifted (0,2mm) + withcolor + if multikind[i] = "single" : yellow + elseif multikind[i] = "first" : red + elseif multikind[i] = "middle" : green + elseif multikind[i] = "last" : blue + fi + withtransparency (1,.5) + ; + endfor ; +\stopuseMPgraphic + %D \starttyping %D \setupbackground %D [test] diff --git a/tex/context/base/anch-pgr.lua b/tex/context/base/anch-pgr.lua new file mode 100644 index 000000000..3d020ca64 --- /dev/null +++ b/tex/context/base/anch-pgr.lua @@ -0,0 +1,480 @@ +if not modules then modules = { } end modules ['anch-pgr'] = { + version = 1.001, + comment = "companion to anch-pgr.mkiv", + author = "Hans Hagen, PRAGMA-ADE, Hasselt NL", + copyright = "PRAGMA ADE / ConTeXt Development Team", + license = "see context related readme files" +} + +local format = string.format +local concat, sort = table.concat, table.sort +local splitter = lpeg.splitat(":") +local lpegmatch = lpeg.match + +local jobpositions = job.positions + +local report_graphics = logs.reporter("graphics") + +local function pair(x,y) + return format("(%.5fpt,%.5fpt)",x/65536,y/65536) +end + +local function path(t) + return concat(t,"--") .. "--cycle" +end + +local function regionarea(r) + local rx, ry = r.x, r.y + local rw = rx + r.w + local rh = ry + r.h + local rd = ry - r.d + return { + pair(rx, rh - ry), + pair(rw, rh - ry), + pair(rw, rd - ry), + pair(rx, rd - ry), + } +end + +local function add(t,x,y) + local last = t[#t] + if not last or last[1] ~= x or last[2] ~= y then + t[#t+1] = { x, y } + end +end + +local function clip(t,ytop,ybot) + local first, last = 1, #t + for i=first,last do + local y = t[i][2] + if ytop < y then + first = i + end + if ybot > y then + last = i + break + end + end + local lp = { } + lp[#lp+1] = { t[first][1], ytop } + for i=first+1,last-1 do + lp[#lp+1] = { t[i][1], t[i][2] } + end + lp[#lp+1] = { t[last][1], ybot } + return lp +end + +local function shapes(r,rx,ry,rw,rh,rd,lytop,lybot,rytop,rybot) + -- we assume that we only hang per page and not cross pages + -- which makes sense as hanging is only uses in special cases + -- + -- we can remove data as soon as a page is done so we could + -- remember per page and discard areas after each shipout + local paragraphs = r.paragraphs + local left = { { rx, rh } } + local right = { { rw, rh } } + if paragraphs then + for i=1,#paragraphs do + local p = paragraphs[i] + local ha = p.ha + if ha and ha ~= 0 then + local py = p.y + local ph = p.h + local pd = p.d + local hi = p.hi + local hang = ha * (ph + pd) + local py_ph = py + ph + -- ha < 0 hi < 0 : right top + -- ha < 0 hi > 0 : left top + if ha < 0 then + if hi < 0 then -- right + add(right,rw , py_ph) + add(right,rw + hi, py_ph) + add(right,rw + hi, py_ph + hang) + add(right,rw , py_ph + hang) + else + -- left + add(left,rx, py_ph) + add(left,rx + hi, py_ph) + add(left,rx + hi, py_ph + hang) + add(left,rx, py_ph + hang) + end + end + end + end + end + -- we can have a simple variant when no paragraphs + add(left,rx,rd) + add(right,rw,rd) + return clip(left,lytop,lybot), clip(right,rytop,rybot) +end + +local function singlepart(b,e,r,left,right) + local bx, by = b.x, b.y + local ex, ey = e.x, e.y + local rx, ry = r.x, r.y + local rw = rx + r.w + local rh = ry + r.h + local rd = ry - r.d + if left then + rx = rx + left + rw = rw - right + end + local bh = by + b.h + local bd = by - b.d + local eh = ey + e.h + local ed = ey - e.d + local area = { } + local leftshapes, rightshapes = shapes(r,rx,ry,rw,rh,rd,bd,ed,bh,eh) + add(area,bx,bh-ry) + for i=1,#rightshapes do + local ri = rightshapes[i] + add(area,ri[1],ri[2]-ry) + end + add(area,ex,eh-ry) + add(area,ex,ed-ry) + for i=#leftshapes,1,-1 do + local li = leftshapes[i] + add(area,li[1],li[2]-ry) + end + add(area,bx,bd-ry) + for i=1,#area do + local a = area[i] + area[i] = pair(a[1],a[2]) + end + return { -- no collapsing yet + location = "single", + region = r, + area = area, + } +end + +local function firstpart(b,r,left,right) + local bx, by = b.x, b.y + local rx, ry = r.x, r.y + local rw = rx + r.w + local rh = ry + r.h + local rd = ry - r.d + if left then + rx = rx + left + rw = rw - right + end + local bh = by + b.h + local bd = by - b.d + local area = { } + local leftshapes, rightshapes = shapes(r,rx,ry,rw,rh,rd,bd,rd,bh,rd) + add(area,bx,bh-ry) + for i=1,#rightshapes do + local ri = rightshapes[i] + add(area,ri[1],ri[2]-ry) + end + for i=#leftshapes,1,-1 do + local li = leftshapes[i] + add(area,li[1],li[2]-ry) + end + add(area,bx,bd-ry) + for i=1,#area do + local a = area[i] + area[i] = pair(a[1],a[2]) + end + return { + location = "first", + region = r, + area = area, + } +end + +local function middlepart(r,left,right) + local rx, ry = r.x, r.y + local rw = rx + r.w + local rh = ry + r.h + local rd = ry - r.d + if left then + rx = rx + left + rw = rw - right + end + local area = { } + local leftshapes, rightshapes = shapes(r,rx,ry,rw,rh,rd,rh,rd,rh,rd) + for i=#leftshapes,1,-1 do + local li = leftshapes[i] + add(area,li[1],li[2]-ry) + end + for i=1,#rightshapes do + local ri = rightshapes[i] + add(area,ri[1],ri[2]-ry) + end + for i=1,#area do + local a = area[i] + area[i] = pair(a[1],a[2]) + end + return { + location = "middle", + region = r, + area = area, + } +end + +local function lastpart(e,r,left,right) + local ex, ey = e.x, e.y + local rx, ry = r.x, r.y + local rw = rx + r.w + local rh = ry + r.h + local rd = ry - r.d + if left then + rx = rx + left + rw = rw - right + end + local eh = ey + e.h + local ed = ey - e.d + local area = { } + -- two cases: till end and halfway e line + local leftshapes, rightshapes = shapes(r,rx,ry,rw,rh,rd,rh,ed,rh,eh) + for i=1,#rightshapes do + local ri = rightshapes[i] + add(area,ri[1],ri[2]-ry) + end + add(area,ex,eh-ry) + add(area,ex,ed-ry) + for i=#leftshapes,1,-1 do + local li = leftshapes[i] + add(area,li[1],li[2]-ry) + end + for i=1,#area do + local a = area[i] + area[i] = pair(a[1],a[2]) + end + return { + location = "last", + region = r, + area = area, + } +end + +graphics = graphics or { } +local backgrounds = { } + +graphics.backgrounds = backgrounds + +local function calculate(tag) + local collected = jobpositions.collected + local b = collected[format("b:%s",tag)] + local e = collected[format("e:%s",tag)] + if not b or not e then + report_graphics("invalid tag '%s'",tag) + return { } + end + local br = b.r + local er = e.r + if not br or not er then + report_graphics("invalid region for '%s'",tag) + return { } + end + local btag, bindex = lpegmatch(splitter,br) + local etag, eindex = lpegmatch(splitter,er) + if not bindex or not eindex or btag ~= etag then + report_graphics("invalid indices for '%s'",tag) + return { } + end + local bindex = tonumber(bindex) + local eindex = tonumber(eindex) + -- Here we compensate for columns (in tables): a table can have a set of column + -- entries and these are shared. We compensate left/right based on the columns + -- x and w but need to take the region into acount where the specification was + -- flushed and not the begin pos's region, because otherwise we get the wrong + -- compensation for assymetrical doublesided layouts. + local left = 0 + local right = 0 + local rc = b.c + if rc then + rc = collected[rc] + if rc then + local tb = collected[rc.r] + if tb then + left = -(tb.x - rc.x) + right = (tb.w - rc.w - left) -- tb.x - rc.x + end + end + end + -- Obeying intermediate changes of left/rightskip makes no sense as it will + -- look bad, so we only look at the begin situation. + -- + local bn = b.n + if bn then + local bp = collected[format("p:%s",bn)] + if bp then + left = left + bp.ls + right = right + bp.rs + end + end + -- + if bindex == eindex then + return { + [b.p] = { singlepart(b,e,collected[br],left,right) } + } + else + local pars = { + [b.p] = { firstpart(b,collected[br],left,right) } + } + for i=bindex+1,eindex-1 do + br = format("%s:%s",btag,i) + local r = collected[br] + if not r then + report_graphics("invalid middle for '%s'",br) + else + local p = r.p + local pp = pars[p] + if pp then + pp[#pp+1] = middlepart(r,left,right) + else + pars[p] = { middlepart(r,left,right) } + end + end + end + local p = e.p + local pp = pars[p] + if pp then + pp[#pp+1] = lastpart(e,collected[er],left,right) + else + pars[p] = { lastpart(e,collected[er],left,right) } + end + return pars + end +end + +local pending = { } -- needs gc + +local function register(data,n,anchor) + local pa = pending[anchor] + if not pa then + pa = { } + pending[anchor] = pa + end + for page, pagedata in next, data do + local pap = pa[page] + if pap then + pap[#pap+1] = n + else + pa[page] = { n } + end + end +end + +function graphics.backgrounds.registered(anchor,page) + local pa = pending[anchor] + if pa then + concat(pa,",") + else + return "" + end +end + +local pbg = { } -- will move to pending + +function graphics.backgrounds.calculate(n) + if not pbg[n] then + pbg[n] = calculate("pbg",n) or { } + end +end + +local multilocs = { + single = 1, -- maybe 0 + first = 1, + middle = 2, + last = 3, +} + +local template_a = [[ +path multiregs[], multipars[], multibox ; +string multikind[] ; +numeric multilocs[], nofmultipars ; +nofmultipars := %s ; +multibox := unitsquare xyscaled %s ; +]] + +local template_b = [[ +multilocs[%s] := %s ; +multikind[%s] := "%s" ; +multipars[%s] := (%s) shifted - %s ; +]] + +local template_c = [[ +multiregs[%s] := (%s) shifted - %s ; +]] + +local template_d = [[ +setbounds currentpicture to multibox ; +]] + +function graphics.backgrounds.fetch(n,page,anchor) + local data = pbg[n] + if not data then + data = calculate(n) + pbg[n] = data -- can be replaced by register + register(data,n,anchor) + end + if data then + local pagedata = data[page] + if pagedata then + local nofmultipars = #pagedata +-- report_graphics("fetching '%s' at page %s using anchor '%s' containing %s multipars",n,page,anchor,nofmultipars) + local a = jobpositions.collected[anchor] + if not a then + report_graphics("missing anchor '%s'",anchor) + else + local trace = false + local x, y, w, h, d = a.x, a.y, a.w, a.h, a.d + local result = { format(template_a,nofmultipars,pair(w,h+d)) } + for i=1,nofmultipars do + local region = pagedata[i] + result[#result+1] = format(template_b, + i, multilocs[region.location], + i, region.location, + i, path(region.area), pair(x,y-region.region.y)) + if trace then + result[#result+1] = format(template_c, + i, path(regionarea(region.region)), offset) + end + end + data[page] = nil + result[#result+1] = template_d + result = concat(result,"\n") + return result + end + end + end + return format(template_a,0,"origin") +end + +function commands.fetchmultipar(n,page,anchor) + context(graphics.backgrounds.fetch(n,page,anchor)) +end + +local doifelse = commands.doifelse + +function commands.doifelsemultipar(n,page) + local data = pbg[n] + if not data then + data = calculate(n) + pbg[n] = data + end + if page then + doifelse(data and data[page] and true) + else + doifelse(data and next(data) and true) + end +end + +function commands.doifelserangeonpage(first,last,page) + local collected = jobpositions.collected + local f = collected[first] + if not f then + doifelse(false) + return + end + local l = collected[last] + if not l then + doifelse(false) + return + end + doifelse(page >= f.p and page <= l.p) +end diff --git a/tex/context/base/anch-pgr.mkiv b/tex/context/base/anch-pgr.mkiv index 8b586c5b2..e882dba41 100644 --- a/tex/context/base/anch-pgr.mkiv +++ b/tex/context/base/anch-pgr.mkiv @@ -17,23 +17,14 @@ %D the reference point on the page. The next macros do so and %D are hooked into the page building routine. -\unprotect - -%D Here we implement position actions (was a dummy). +\registerctxluafile{anch-pgr}{1.001} -\unexpanded\def\showanchor#1% - {\normalexpanded{\writestatus{#1} - {\MPp{#1}\string|\MPx{#1}\string|\MPy{#1}\string|\MPw{#1}\string|\MPh{#1}\string|\MPd{#1}}}} +\unprotect -%D A few more low level macros take care of defining and -%D recalling actions. We could save this information in the -%D position containers themselves, this would save hash -%D entries, but at the cost of much more time consuming -%D expansion. Actions are saved globally! -%D -%D The lists can become quite long (also because there can -%D be lots of parameters passed on) so we provide a hook -%D to clean up the list afterwards. +%D A few more low level macros take care of defining and recalling +%D actions. Actions are saved globally! The lists can become quite +%D long because there can be lots of parameters passed on so we +%D clean up the list afterwards. \newtoks\everypositionaction \newtoks\everyinsertpositionaction @@ -43,41 +34,46 @@ \installcorenamespace{positioncleanup} \unexpanded\def\dosetpositionaction#1% - {\setgvalue{\??positionaction#1}} + {\expandafter\gdef\csname\??positionaction#1\endcsname} % nicely gobbles spaces -\def\doifpositionaction#1% +\unexpanded\def\doifpositionaction#1% {\ifcsname\??positionaction#1\endcsname \expandafter\firstofoneargument \else \expandafter\gobbleoneargument \fi} -\def\doifpositionactionelse#1% +\unexpanded\def\doifpositionactionelse#1% {\ifcsname\??positionaction#1\endcsname \expandafter\firstoftwoarguments \else \expandafter\secondoftwoarguments \fi} -\def\dopositionaction#1% test saves hash entry in etex - {\ifcsname\??positionaction#1\endcsname - \anch_positions_action_indeed{#1}% +\unexpanded\def\dopositionaction#1% + {\edef\currentpositionaction{#1}% + \ifcsname\??positionaction\currentpositionaction\endcsname + \anch_positions_action_indeed \fi} -\def\anch_positions_action_indeed#1% - {\ifcase\MPp{#1}\relax - \traceposstring\clap\cyan{<#1>}% shouldn't happen too often - \else - \begingroup - \setbox\scratchbox\hbox - {\traceposstring\clap\red{<#1>}% - \the\everyinsertpositionaction - \the\everypositionaction - \csname\??positionaction#1\endcsname - \anch_positions_cleanup_action{#1}}% - \smashedbox\scratchbox % smashing is really needed else we get problems with too big overlays - \endgroup - \fi} +\def\anch_positions_action_indeed + {\doifpositionelse\currentpositionaction + \anch_positions_action_indeed_yes + \anch_positions_action_indeed_nop} + +\def\anch_positions_action_indeed_nop + {\traceposstring\clap\cyan{<\currentpositionaction>}} + +\def\anch_positions_action_indeed_yes % we need a way to figure out if we have actions + {\begingroup + \setbox\scratchbox\hbox + {\traceposstring\clap\red{<\currentpositionaction>}% + \the\everyinsertpositionaction + \the\everypositionaction + \csname\??positionaction\currentpositionaction\endcsname + \anch_positions_cleanup_action}% + \smashedbox\scratchbox % smashing is really needed else we get problems with too big overlays + \endgroup} %D Here the complication has to do with collecting actions %D for later execution. This collection is especially handy @@ -85,79 +81,38 @@ %D series of actions are stored in a macro that is cleaned up %D after each invocation. -% this can probably be done better - -% \def\anch_positions_cleanup_action#1% not in trialtypesetting -% {\ifcsname\??positioncleanup#1\endcsname -% \the\everycleanpositionaction -% \iflocalpositioning -% \letgvalue{\??positioncleanup#1}\empty -% \else -% \setxvalue{\??positioncleanup#1}{\getvalue{\??positioncleanup#1}}% -% \fi -% \fi} - -\def\anch_positions_cleanup_action#1% not in trialtypesetting - {\ifcsname\??positioncleanup#1\endcsname +\def\anch_positions_cleanup_action % not in trialtypesetting + {\ifcsname\??positioncleanup\currentpositionaction\endcsname \the\everycleanpositionaction \iflocalpositioning % erase - \expandafter\let\csname\??positioncleanup#1\endcsname\empty + \expandafter\let\csname\??positioncleanup\currentpositionaction\endcsname\empty \else - % globalize - \global\expandafter\let\csname\??positioncleanup#1\expandafter\endcsname\csname\??positioncleanup#1\endcsname + % globalize expansion cleans up + \setxvalue{\??positioncleanup\currentpositionaction}{\csname\??positioncleanup\currentpositionaction\endcsname}% \fi \fi} \def\handlepositionaction#1\with#2\on#3% ugly {\begingroup - \edef\!!stringa{\ifx\currentpositionoverlay\empty#3\else\currentpositionoverlay::\MPanchoridentifier\fi}% - \edef\!!stringc{\??positioncleanup\!!stringa}% - \normalexpanded{\dosetpositionaction{\!!stringa}{\noexpand\getvalue{\!!stringc}}}% - \global\let#1\relax - \edef\!!stringb{\ifcsname\!!stringc\endcsname\csname\!!stringc\endcsname\fi}% why ... - \setxvalue\!!stringc{\!!stringb#1#2}% + \edef\currentpositionanchor + {\ifx\currentpositionoverlay\empty#3\else\currentpositionoverlay::\MPanchoridentifier\fi}% + \normalexpanded{\dosetpositionaction{\currentpositionanchor}{\noexpand\getvalue{\??positioncleanup\currentpositionanchor}}}% + \let#1\relax + \ifcsname\??positioncleanup\currentpositionanchor\endcsname + \setxvalue{\??positioncleanup\currentpositionanchor}% + {\csname\??positioncleanup\currentpositionanchor\endcsname#1#2}% + \else + \setxvalue{\??positioncleanup\currentpositionanchor}% + {#1#2}% + \fi \endgroup} -%D The next macros do some housekeeping. - -\def\pageanchor {page:0} % for the moment only one pagesize -\def\textanchor {text:\the\realpageno} -\def\regionanchor{region:0} % placeholder - %D The first version of this module implemented head and tail %D anchors. Currently we stick to just one anchor and derive %D the head and tail anchors from this one. We set these %D anchors before and after each page. -% FOR THE MOMENT DISABLED (was downward compatibity issue) -% -% \def\headanchor{head:\the\realpageno} % virtual position -% \def\tailanchor{tail:\the\realpageno} % virtual position -% -% \def\presetpositionanchors % is this still needed? -% {\ifpositioning -% \anch_positions_preset_anchors -% \fi} -% -% \def\anch_positions_preset_anchors -% {\begingroup -% \!!dimena\ifdim\topskip>\strutht\topskip\else\strutht\fi -% \!!dimenb\dimexpr\MPy\textanchor+\MPh\textanchor-\!!dimena\relax -% \!!dimenc\dimexpr\MPy\textanchor+\strutdp\relax -% \!!dimend\MPx\textanchor -% \!!dimene\MPw\textanchor -% \replacepospxywhd\headanchor\realfolio\!!dimend\!!dimenb\!!dimene\!!dimena\strutdp -% \replacepospxywhd\tailanchor\realfolio\!!dimend\!!dimenc\!!dimene\strutht \strutdp -% \endgroup} -% -% \appendtoks \presetpositionanchors \to \beforeeverypage -% \appendtoks \presetpositionanchors \to \aftereverypage - -% todo: change with each page size change .. can be made more efficient -% as some values are the same .. this one can (at some point) be used -% to provide correction for imposition - \unexpanded\def\anch_positions_register_page#1% this one is flushed first ! ... can't we avoid this one {\ifpositioning\ifcase\realpageno\or \ifdim\printpaperheight=\paperheight @@ -171,8 +126,12 @@ \fi \fi\fi} -\def\anch_positions_register_page_indeed#1% - {\setbox#1\hbox{\hpos\pageanchor{\box#1}}} +% \def\anch_positions_register_page_indeed#1% +% {\setbox#1\hbox{\hpos\pageanchor{\box#1}}} + +\def\anch_positions_register_page_indeed#1% maybe like text + {\ifvbox#1\setbox#1\hbox{\box#1}\fi + \anch_make_page_box{#1}} \unexpanded\def\anch_positions_place_anchors {\ifpositioning @@ -181,32 +140,19 @@ \anch_positions_place_anchors_nop \fi} -% FOR THE MOMENT DISABLED -% -% \def\anch_positions_place_anchors_yes % todo : depth pagebox -% {\begingroup -% \setbox\scratchbox\vbox to \textheight -% {\simpletopskipcorrection -% \hbox{\strut\dopositionaction\headanchor}% ! actions on a virtual position -% \vfill -% \hbox{\strut\dopositionaction\tailanchor}}% ! actions on a virtual position -% \dp\scratchbox\zeropoint -% \wd\scratchbox\makeupwidth % not \zeropoint, else wrong text backgrounds -% \hpos\textanchor{\box\scratchbox}% -% \endgroup} - \def\anch_positions_place_anchors_yes % todo : depth pagebox {\begingroup - \setbox\scratchbox\emptyvbox + \setbox\scratchbox\emptyhbox \ht\scratchbox\textheight \dp\scratchbox\zeropoint \wd\scratchbox\makeupwidth - \hpos\textanchor{\box\scratchbox}% + \anch_mark_text_box\scratchbox + \box\scratchbox \endgroup} \def\anch_positions_place_anchors_nop {\vskip\textheight} - + %D \macros %D {positionoverlay,startpositionoverlay} %D @@ -257,8 +203,8 @@ %D %D \typebuffer[graphic] -\def\MPanchoridentifier{mpa} % {mp-anchor} -\def\MPoverlayposprefix{MO::} +\def\MPanchoridentifier{mpa} % {mp-anchor} +\def\MPoverlayposprefix{MO::} % not used %D The rest of the definitions concerning such overlays may %D look complicated, @@ -268,7 +214,10 @@ %D Position actions are automatically executed when a position %D is set. -\let\MPanchornumber\realfolio +\newcount\localpositionnumber % incremented elsewhere + +\def\textbackgroundoverlay#1{\iflocalpositioning\v!local\else\v!text\fi#1} +\def\MPanchornumber {\the\iflocalpositioning\localpositionnumber\else\realpageno\fi} \def\positionoverlay % the test prevents too many redundant positions {\ifpositioning % in (not used) text* position layers @@ -277,53 +226,50 @@ \expandafter\gobbleoneargument \fi} -% keep this for a while -% -% \def\anch_positions_overlay_indeed#1% the test prevents too many redundant positions -% {\vbox to \overlayheight -% {\doifpositionactionelse{#1::\MPanchoridentifier}% -% {\edef\MPanchorid{#1::\MPanchoridentifier:\MPanchornumber}% -% \edef\MPanchor##1{\MPpos{\MPanchorid}}% -% \the\everyinsertpositionaction -% \copyposition{#1::\MPanchoridentifier}{#1::\MPanchoridentifier:\MPanchornumber}% -% \hpos -% {#1::\MPanchoridentifier:\MPanchornumber}% -% % this is ok -% %{\hbox to \overlaywidth{\dopositionaction{#1::\MPanchoridentifier}\hss}}}% -% % but this one prevents cyclic runs due to -% % rounding errors -% {\setbox\scratchbox\hbox to \overlaywidth{\dopositionaction{#1::\MPanchoridentifier}\hss}% -% \ht\scratchbox\overlayheight -% \dp\scratchbox\zeropoint -% \box\scratchbox}}% -% {\hbox to \overlaywidth{\hss}}% -% \vfill}} - \def\anch_positions_overlay_indeed#1% - {\doifpositionactionelse{#1::\MPanchoridentifier}% - \anch_positions_overlay_yes\anch_positions_overlay_nop{#1}} + {\begingroup + \edef\currentpositionoverlay{#1}% + \ifcsname\??positionaction\currentpositionoverlay::\MPanchoridentifier\endcsname + \anch_positions_overlay_compose + \fi + \endgroup} + +\def\MPoverlayanchor#1{\MPpos\MPanchorid} -\def\anch_positions_overlay_yes#1% +\def\anch_positions_overlay_compose {\vbox to \overlayheight - {\edef\MPanchorid{#1::\MPanchoridentifier:\MPanchornumber}% - \edef\MPanchor##1{\MPpos\MPanchorid}% + {%\writestatus{!!!}{\currentpositionoverlay/\MPanchoridentifier/\MPanchornumber}% + \edef\MPanchorid{\currentpositionoverlay::\MPanchoridentifier:\MPanchornumber}% realpageno +% \edef\MPanchor##1{\MPpos\MPanchorid}% + \let\MPanchor\MPoverlayanchor % no need to fetch it already, seldom used \the\everyinsertpositionaction - \copyposition{#1::\MPanchoridentifier}\MPanchorid - \hpos \MPanchorid - %{\hbox to \overlaywidth{\dopositionaction{#1::\MPanchoridentifier}\hss}}}% oscillation due to rounding issues - {\setbox\scratchbox\hbox to \overlaywidth{\dopositionaction{#1::\MPanchoridentifier}\hss}% - \ht\scratchbox\overlayheight - \dp\scratchbox\zeropoint - \box\scratchbox}% + \copyposition{\currentpositionoverlay::\MPanchoridentifier}\MPanchorid + \setbox\scratchbox\hbox to \overlaywidth{\dopositionaction{\currentpositionoverlay::\MPanchoridentifier}\hss}% + \ht\scratchbox\overlayheight + \dp\scratchbox\zeropoint +\ctxcommand{markregionbox(\number\scratchbox,"\MPanchorid")}% needs an hbox + \box\scratchbox \vfill}} -% \def\anch_positions_overlay_nop#1% -% {\setbox\scratchbox\emptyvbox -% \ht\scratchbox\overlayheight -% \wd\scratchbox\overlaywidth -% \box\scratchbox} +\def\positionregionoverlay % shares regions + {\ifpositioning + \expandafter\anch_positions_region_overlay_indeed + \else % also \iftrialtypesetting test here? + \expandafter\gobbletwoarguments + \fi} + +\let\currentpositionregion\empty + +\def\anch_positions_region_overlay_indeed#1#2% + {\begingroup + \edef\currentpositionregion {#1}% + \edef\currentpositionoverlay{#2}% + \ifcsname\??positionaction\currentpositionoverlay::\MPanchoridentifier\endcsname + \anch_positions_region_overlay_compose + \fi + \endgroup} -\let\anch_positions_overlay_nop\gobbleoneargument +% \let\anch_positions_overlay_nop\gobbleoneargument \unexpanded\def\startpositionoverlay {\iftrialtypesetting @@ -341,15 +287,15 @@ \unexpanded\def\stoppositionoverlay {\let\currentpositionoverlay\empty} -\def\resetpositionoverlay#1% - {\dosetpositionaction{#1::\MPanchoridentifier::}{}} +% \def\resetpositionoverlay#1% +% {\dosetpositionaction{#1::\MPanchoridentifier::}{}} \def\handlepositionboxes#1#2#3% {\handlepositionaction\dohandlepositionboxes\with{#1}{#2}{#3}\on{#2}} \def\doinsertpositionboxes#1#2#3% pos tag setups {\ifnum\MPp{#1}=\realpageno\relax % can be sped up - \executeifdefined{\MPoverlayposprefix#1}\gobblethreearguments{#1}{#2}{#3}% + \executeifdefined{\MPoverlayposprefix#1}\gobblethreearguments{#1}{#2}{#3}% not used \fi} \appendtoks @@ -423,10 +369,9 @@ \setupMPvariables[#2][#3]% \edef\currentmpvariableclass{#2}% \anch_positions_meta_graphic_prepare - \obeyMPboxorigin % do we also set the size ? + \obeyMPboxorigin % do we also set the size ? when needed this must be done in mp ... might change \def\anch_positions_meta_graphic_direct{\anch_positions_meta_graphic_nested{#3}}% takes two extra arguments - \setbox\positiongraphicbox\hbox - {\ignorespaces\csname#1#2\endcsname\removelastspace}% + \setbox\positiongraphicbox\hbox{\ignorespaces\csname#1#2\endcsname\removelastspace}% \smashbox\positiongraphicbox \box\positiongraphicbox \endgroup} @@ -493,23 +438,11 @@ {\handlepositionaction\dohandleMPpositiongraphicrange\with{#1}{#2}{#3}{#4}\on{#2}} \def\doinsertMPpositiongraphicrange#1#2#3#4% pos pos tag setups - {\ifnum\MPp{#1}\MPp{#2}>\zerocount - \iflocalpositioning - \donetrue - \else - \donefalse - \ifnum\MPp{#1}=\realpageno - \donetrue - \else\ifnum\MPp{#2}=\realpageno - \donetrue - \else\ifnum\MPp{#1}<\realpageno\relax\ifnum\MPp{#2}>\realpageno - \donetrue - \fi\fi\fi\fi - \fi - \ifdone - \def\currentposition{#1}\MPpositiongraphic{#3}{#4}% - \fi - \fi} + {\ctxcommand{doifelserangeonpage("#1","#2",\number\realpageno)}% + {%\writestatus{YES}{#1/#2 => #3}% + \def\currentposition{#1}% + \MPpositiongraphic{#3}{#4}}% + {}}%\writestatus{NOP}{#1/#2 = #3}}} \appendtoks \let\dohandleMPpositiongraphicrange\doinsertMPpositiongraphicrange diff --git a/tex/context/base/anch-pos.lua b/tex/context/base/anch-pos.lua index 60fc985a2..184da3b9c 100644 --- a/tex/context/base/anch-pos.lua +++ b/tex/context/base/anch-pos.lua @@ -17,8 +17,9 @@ more efficient.</p> -- maybe replace texsp by our own converter (stay at the lua end) -- eventually mp will have large numbers so we can use sp there too -local tostring = tostring -local concat, format, gmatch, match = table.concat, string.format, string.gmatch, string.match +local tostring, next, rawget, setmetatable = tostring, next, rawget, setmetatable +local concat, sort = table.concat, table.sort +local format, gmatch, match = string.format, string.gmatch, string.match local rawget = rawget local lpegmatch = lpeg.match local insert, remove = table.insert, table.remove @@ -51,9 +52,59 @@ job.positions = jobpositions _plib_ = jobpositions +local default = { + __index = { + x = 0, -- x position baseline + y = 0, -- y position baseline + w = 0, -- width + h = 0, -- height + d = 0, -- depth + p = 0, -- page + ls = 0, -- leftskip + rs = 0, -- rightskip + hi = 0, -- hangindent + ha = 0, -- hangafter + hs = 0, -- hsize + pi = 0, -- parindent + } +} + +local function sorter(a,b) + return a.y > b.y +end + local function initializer() tobesaved = jobpositions.tobesaved collected = jobpositions.collected + -- enhance regions with paragraphs + for tag, data in next, collected do + local hi = data.hi + if hi and hi ~= 0 then + local region = data.r + if region then + local r = collected[region] + local paragraphs = r.paragraphs + if not paragraphs then + r.paragraphs = { data } + else + paragraphs[#paragraphs+1] = data + end + end + end + end + -- sort this data and add metatable + for tag, data in next, collected do + local region = data.r + if region then + local r = collected[region] + local paragraphs = r.paragraphs + if paragraphs and #paragraphs > 1 then + sort(paragraphs,sorter) + end + end + -- so, we can be sparse and don't need 'or 0' code + setmetatable(data,default) + end end job.register('job.positions.collected', tobesaved, initializer) @@ -61,8 +112,11 @@ job.register('job.positions.collected', tobesaved, initializer) local regions = { } local nofregions = 0 local region = nil + +local columns = { } local nofcolumns = 0 local column = nil + local nofpages = nil -- beware ... we're not sparse here as lua will reserve slots for the nilled @@ -124,10 +178,10 @@ local function enhance(data) if data.y == true then data.y = pdf.v end - if data.p == true then -- or 0 + if data.p == true then data.p = texcount.realpageno end - if data.c == true then -- or 0 + if data.c == true then data.c = column end if data.w == 0 then @@ -172,35 +226,48 @@ jobpositions.setall = setall jobpositions.set = set jobpositions.get = get --- function jobpositions.pushregion(tag,w,h,d) --- if w then --- setdim(tag,w,h,d) --- end --- insert(regions,tag) --- region = tag --- end - --- function jobpositions.popregion() --- remove(regions) --- region = regions[#regions] --- end - --- function jobpositions.markregionbox(n,tag) --- if not tag or tag == "" then --- nofregions = nofregions + 1 --- tag = nofregions --- end --- local box = texbox[n] --- local push = new_latelua(format("_plib_.pushregion(%q,%s,%s,%s)",tag,box.width,box.height,box.depth)) --- local pop = new_latelua("_plib_.popregion()") --- local head = box.list --- local tail = find_tail(head) --- head.prev = push --- push.next = head --- pop .prev = tail --- tail.next = pop --- box.list = push --- end +-- will become private table (could also become attribute driven but too nasty +-- as attributes can bleed e.g. in margin stuff) + +function jobpositions.b_col(tag) + tobesaved[tag] = { + r = true, + x = pdf.h, + w = 0, + } + insert(columns,tag) + column = tag +end + +function jobpositions.e_col(tag) + local t = tobesaved[column] + if not t then + -- something's wrong + else + t.w = pdf.h - t.x + t.r = region + end + remove(columns) + column = columns[#columns] +end + +function commands.bcolumn(tag,register) + insert(columns,tag) + column = tag + if register then + context(new_latelua(format("_plib_.b_col(%q)",tag))) + end +end + +function commands.ecolumn(register) + if register then + context(new_latelua("_plib_.e_col()")) + end + remove(columns) + column = columns[#columns] +end + +-- regions function jobpositions.b_region(tag) local last = tobesaved[tag] @@ -211,8 +278,8 @@ function jobpositions.b_region(tag) end function jobpositions.e_region() - remove(regions) tobesaved[region].y = pdf.v + remove(regions) region = regions[#regions] end @@ -222,56 +289,20 @@ function jobpositions.markregionbox(n,tag) tag = format("region:%s",nofregions) end local box = texbox[n] + local w = box.width + local h = box.height + local d = box.depth tobesaved[tag] = { p = true, x = true, y = true, - w = box.width, - h = box.height, - d = box.depth, + w = w ~= 0 and w or nil, + h = h ~= 0 and h or nil, + d = d ~= 0 and d or nil, } local push = new_latelua(format("_plib_.b_region(%q)",tag)) local pop = new_latelua("_plib_.e_region()") - local head = box.list - local tail = find_tail(head) - head.prev = push - push.next = head - pop .prev = tail - tail.next = pop - box.list = push -end - --- here the page is part of the column so we can only save when we reassign --- the table (column:* => column:*:*) - -function jobpositions.b_column(w,h,d) -- there can be multiple column ranges per page - local page = texcount.realpageno -- we could have a nice page synchronizer (saves calls) - if page ~= nofpages then - nofpages = page - nofcolumns = 1 - else - nofcolumns = nofcolumns + 1 - end - column = nofcolumns - if w then - set(format("column:%s:%s",page,column), { - x = true, - y = true, - w = w, - h = h, - d = d, - }) - end -end - -function jobpositions.e_column() - column = nil -end - -function jobpositions.markcolumnbox(n,column) - local box = texbox[n] - local push = new_latelua(format("_plib_.b_column(%s,%s,%s)",box.width,box.height,box.depth)) - local pop = new_latelua("_plib_.e_column()") + -- maybe we should construct a hbox first (needs experimenting) so that we can avoid some at the tex end local head = box.list if head then local tail = find_tail(head) @@ -303,7 +334,8 @@ function commands.parpos() -- todo: relate to localpar (so this is an intermedia local strutbox = texbox.strutbox local t = { p = true, - -- c = true, + c = true, + r = true, x = true, y = true, h = strutbox.height, @@ -338,7 +370,7 @@ end function commands.posxy(name) -- can node.write be used here? tobesaved[name] = { p = true, - -- c = true, + c = column, r = true, x = true, y = true, @@ -350,7 +382,7 @@ end function commands.poswhd(name,w,h,d) tobesaved[name] = { p = true, - -- c = true, + c = column, r = true, x = true, y = true, @@ -365,7 +397,7 @@ end function commands.posplus(name,w,h,d,extra) tobesaved[name] = { p = true, - -- c = true, + c = column, r = true, x = true, y = true, @@ -382,7 +414,7 @@ function commands.posstrut(name,w,h,d) local strutbox = texbox.strutbox tobesaved[name] = { p = true, - -- c = true, + c = column, r = true, x = true, y = true, @@ -414,22 +446,12 @@ function jobpositions.copy(target,source) end function jobpositions.replace(id,p,x,y,w,h,d) --- local t = collected[id] --- if t then --- t.p = p or t.p --- t.x = x or t.x --- t.y = y or t.y --- t.w = w or t.w --- t.h = h or t.h --- t.d = d or t.d --- else - collected[id] = { p = p, x = x, y = y, w = w, h = h, d = d } --- end + collected[id] = { p = p, x = x, y = y, w = w, h = h, d = d } -- c g end function jobpositions.page(id) local jpi = collected[id] - return jpi and jpi.p or 0 + return jpi and jpi.p end function jobpositions.region(id) @@ -444,7 +466,7 @@ end function jobpositions.paragraph(id) local jpi = collected[id] - return jpi and jpi.n or 0 + return jpi and jpi.n end jobpositions.p = jobpositions.page @@ -454,52 +476,52 @@ jobpositions.n = jobpositions.paragraph function jobpositions.x(id) local jpi = collected[id] - return jpi and jpi.x or 0 + return jpi and jpi.x end function jobpositions.y(id) local jpi = collected[id] - return jpi and jpi.y or 0 + return jpi and jpi.y end function jobpositions.width(id) local jpi = collected[id] - return jpi and jpi.w or 0 + return jpi and jpi.w end function jobpositions.height(id) local jpi = collected[id] - return jpi and jpi.h or 0 + return jpi and jpi.h end function jobpositions.depth(id) local jpi = collected[id] - return jpi and jpi.d or 0 + return jpi and jpi.d end function jobpositions.leftskip(id) local jpi = collected[id] - return jpi and jpi.ls or 0 + return jpi and jpi.ls end function jobpositions.rightskip(id) local jpi = collected[id] - return jpi and jpi.rs or 0 + return jpi and jpi.rs end function jobpositions.hsize(id) local jpi = collected[id] - return jpi and jpi.hs or 0 + return jpi and jpi.hs end function jobpositions.parindent(id) local jpi = collected[id] - return jpi and jpi.pi or 0 + return jpi and jpi.pi end function jobpositions.hangindent(id) local jpi = collected[id] - return jpi and jpi.hi or 0 + return jpi and jpi.hi end function jobpositions.hangafter(id) @@ -510,9 +532,7 @@ end function jobpositions.xy(id) local jpi = collected[id] if jpi then - local x = jpi.x or 0 - local y = jpi.y or 0 - return x, y + return jpi.x, jpi.y else return 0, 0 end @@ -521,10 +541,7 @@ end function jobpositions.lowerleft(id) local jpi = collected[id] if jpi then - local x = jpi.x or 0 - local y = jpi.y or 0 - local d = jpi.d or 0 - return x, y - d + return jpi.x, jpi.y - jpi.d else return 0, 0 end @@ -533,11 +550,7 @@ end function jobpositions.lowerright(id) local jpi = collected[id] if jpi then - local x = jpi.x or 0 - local y = jpi.y or 0 - local w = jpi.w or 0 - local d = jpi.d or 0 - return x + w, y - d + return jpi.x + jpi.w, jpi.y - jpi.d else return 0, 0 end @@ -546,11 +559,7 @@ end function jobpositions.upperright(id) local jpi = collected[id] if jpi then - local x = jpi.x or 0 - local y = jpi.y or 0 - local w = jpi.w or 0 - local h = jpi.h or 0 - return x + w, y + h + return jpi.x + jpi.w, jpi.y + jpi.h else return 0, 0 end @@ -559,10 +568,7 @@ end function jobpositions.upperleft(id) local jpi = collected[id] if jpi then - local x = jpi.x or 0 - local y = jpi.y or 0 - local h = jpi.h or 0 - return x, y + h + return jpi.x, jpi.y + jpi.h else return 0, 0 end @@ -571,7 +577,7 @@ end function jobpositions.position(id) local jpi = collected[id] if jpi then - return jpi.p or 0, jpi.x or 0, jpi.y or 0, jpi.w or 0, jpi.h or 0, jpi.d or 0 + return jpi.p, jpi.x, jpi.y, jpi.w, jpi.h, jpi.d else return 0, 0, 0, 0, 0, 0 end @@ -600,31 +606,31 @@ local function overlapping(one,two,overlappingmargin) -- hm, strings so this is if not overlappingmargin then overlappingmargin = 2 end - local x_one = one.x or 0 - local x_two = two.x or 0 - local w_two = two.w or 0 + local x_one = one.x + local x_two = two.x + local w_two = two.w local llx_one = x_one - overlappingmargin local urx_two = x_two + w_two + overlappingmargin if llx_one > urx_two then return false end - local w_one = one.w or 0 + local w_one = one.w local urx_one = x_one + w_one + overlappingmargin local llx_two = x_two - overlappingmargin if urx_one < llx_two then return false end - local y_one = one.y or 0 - local y_two = two.y or 0 - local d_one = one.d or 0 - local h_two = two.h or 0 + local y_one = one.y + local y_two = two.y + local d_one = one.d + local h_two = two.h local lly_one = y_one - d_one - overlappingmargin local ury_two = y_two + h_two + overlappingmargin if lly_one > ury_two then return false end - local h_one = one.h or 0 - local d_two = two.d or 0 + local h_one = one.h + local d_two = two.d local ury_one = y_one + h_one + overlappingmargin local lly_two = y_two - d_two - overlappingmargin if ury_one < lly_two then @@ -663,7 +669,7 @@ function commands.MPp(id) local jpi = collected[id] if jpi then local p = jpi.p - if p then + if p and p ~= true then context(p) return end @@ -675,8 +681,8 @@ function commands.MPx(id) local jpi = collected[id] if jpi then local x = jpi.x - if x then - context("%spt",x*pt) + if x and p ~= true then + context("%.5fpt",x*pt) return end end @@ -687,8 +693,8 @@ function commands.MPy(id) local jpi = collected[id] if jpi then local y = jpi.y - if y then - context("%spt",y*pt) + if y and p ~= true then + context("%.5fpt",y*pt) return end end @@ -700,7 +706,7 @@ function commands.MPw(id) if jpi then local w = jpi.w if w then - context("%spt",w*pt) + context("%.5fpt",w*pt) return end end @@ -712,7 +718,7 @@ function commands.MPh(id) if jpi then local h = jpi.h if h then - context("%spt",h*pt) + context("%.5fpt",h*pt) return end end @@ -733,9 +739,9 @@ end function commands.MPxy(id) local jpi = collected[id] if jpi then - context('(%spt,%spt)', - (jpi.x or 0)*pt, - (jpi.y or 0)*pt + context('(%.5fpt,%.5fpt)', + jpi.x*pt, + jpi.y*pt ) else context('(0,0)') @@ -745,48 +751,48 @@ end function commands.MPll(id) local jpi = collected[id] if jpi then - context('(%spt,%spt)', - (jpi.x or 0) *pt, - ((jpi.y or 0)-(jpi.d or 0))*pt + context('(%.5fpt,%.5fpt)', + jpi.x *pt, + (jpi.y-jpi.d)*pt ) else - context('(0,0)') + context('(0,0)') -- for mp only end end function commands.MPlr(id) local jpi = collected[id] if jpi then - context('(%spt,%spt)', - ((jpi.x or 0)+(jpi.w or 0))*pt, - ((jpi.y or 0)-(jpi.d or 0))*pt + context('(%.5fpt,%.5fpt)', + (jpi.x + jpi.w)*pt, + (jpi.y - jpi.d)*pt ) else - context('(0,0)') + context('(0,0)') -- for mp only end end function commands.MPur(id) local jpi = collected[id] if jpi then - context('(%spt,%spt)', - ((jpi.x or 0)+(jpi.w or 0))*pt, - ((jpi.y or 0)+(jpi.h or 0))*pt + context('(%.5fpt,%.5fpt)', + (jpi.x + jpi.w)*pt, + (jpi.y + jpi.h)*pt ) else - context('(0,0)') + context('(0,0)') -- for mp only end end function commands.MPul(id) local jpi = collected[id] if jpi then - context('(%spt,%spt)', - (jpi.x or 0) *pt, - ((jpi.y or 0)+(jpi.h or 0))*pt + context('(%.5fpt,%.5fpt)', + jpi.x *pt, + (jpi.y + jpi.h)*pt ) else - context('(0,0)') + context('(0,0)') -- for mp only end end @@ -795,18 +801,18 @@ local function MPpos(id) if jpi then local p = jpi.p if p then - context("%s,%spt,%spt,%spt,%spt,%spt", + context("%s,%.5fpt,%.5fpt,%.5fpt,%.5fpt,%.5fpt", p, - (jpi.x or 0)*pt, - (jpi.y or 0)*pt, - (jpi.w or 0)*pt, - (jpi.h or 0)*pt, - (jpi.d or 0)*pt + jpi.x*pt, + jpi.y*pt, + jpi.w*pt, + jpi.h*pt, + jpi.d*pt ) return end end - context('0,0,0,0,0,0') + context('0,0,0,0,0,0') -- for mp only end commands.MPpos = MPpos @@ -827,7 +833,7 @@ function commands.MPc(id) local jpi = collected[id] if jpi then local c = jpi.c - if c then + if c and p ~= true then context(c) return end @@ -839,12 +845,11 @@ function commands.MPr(id) local jpi = collected[id] if jpi then local r = jpi.r - if r then + if r and p ~= true then context(r) return end end - -- context("") -- empty so that we can test end local function MPpardata(n) @@ -854,33 +859,33 @@ local function MPpardata(n) t = collected[tag] end if t then - context("%spt,%spt,%spt,%spt,%s,%spt", -- can be %.5f - (t.hs or 0)*pt, - (t.ls or 0)*pt, - (t.rs or 0)*pt, - (t.hi or 0)*pt, - (t.ha or 1), - (t.pi or 0)*pt + context("%.5fpt,%.5fpt,%.5fpt,%.5fpt,%s,%.5fpt", + t.hs*pt, + t.ls*pt, + t.rs*pt, + t.hi*pt, + t.ha, + t.pi*pt ) else - context("0,0,0,0,0,0") -- meant for MP + context("0,0,0,0,0,0") -- for mp only end end commands.MPpardata = MPpardata --- function commands.MPposset(id) -- special helper, used in backgrounds --- local b = format("b:%s",id) --- local e = format("e:%s",id) --- local w = format("w:%s",id) --- local p = format("p:%s",jobpositions.n(b)) --- MPpos(b) context(",") MPpos(e) context(",") MPpos(w) context(",") MPpos(p) context(",") MPpardata(p) --- end +function commands.MPposset(id) -- special helper, used in backgrounds + local b = format("b:%s",id) + local e = format("e:%s",id) + local w = format("w:%s",id) + local p = format("p:%s",jobpositions.n(b)) + MPpos(b) context(",") MPpos(e) context(",") MPpos(w) context(",") MPpos(p) context(",") MPpardata(p) +end function commands.MPls(id) local t = collected[id] if t then - context((t.ls or 0)*pt) + context("%.5fpt",t.ls*pt) else context("0pt") end @@ -889,7 +894,7 @@ end function commands.MPrs(id) local t = collected[id] if t then - context((t.rs or 0)*pt) + context("%.5fpt",t.rs*pt) else context("0pt") end @@ -922,22 +927,31 @@ end function commands.MPxywhd(id) local t = collected[id] if t then - context("%spt,%spt,%spt,%spt,%spt", -- can be %.5f - (t.x or 0)*pt, - (t.y or 0)*pt, - (t.w or 0)*pt, - (t.h or 0)*pt, - (t.d or 0)*pt + context("%.5fpt,%.5fpt,%.5fpt,%.5fpt,%.5fpt", + t.x*pt, + t.y*pt, + t.w*pt, + t.h*pt, + t.d*pt ) else - context("0,0,0,0,0") -- meant for MP + context("0,0,0,0,0") -- for mp only end end -- is testcase already defined? if so, then local function commands.doifpositionelse(name) - commands.testcase(collected[name]) + commands.doifelse(collected[name]) +end + +function commands.doifpositionelse(name) + commands.doif(collected[name]) +end + +function commands.doifpositiononpage(name,page) -- probably always realpageno + local c = collected[name] + commands.testcase(c and c.p == page) end function commands.doifoverlappingelse(one,two,overlappingmargin) diff --git a/tex/context/base/anch-pos.mkiv b/tex/context/base/anch-pos.mkiv index c28747c46..c29c98e5b 100644 --- a/tex/context/base/anch-pos.mkiv +++ b/tex/context/base/anch-pos.mkiv @@ -27,6 +27,11 @@ \writestatus{loading}{ConTeXt Anchoring Macros / Positioning} +%D In \MKIV\ there was already a different housekeeping model +%D for positions quite early, but starting in 2012 more dramatic +%D changes started to happen, especially in relation to background +%D graphics. It will probably take some time to settle. + % saveposition : tag page x y % savepositionwhd : tag page x y w h d % savepositionplus : tag page x y w h d list @@ -181,7 +186,7 @@ \def\MPlr #1{\ctxcommand{MPlr("#1")}} \def\MPur #1{\ctxcommand{MPur("#1")}} \def\MPul #1{\ctxcommand{MPul("#1")}} -\def\MPpos#1{\ctxcommand{MPpos("#1")}} \def\MPanchor{\MPpos} +\def\MPpos#1{\ctxcommand{MPpos("#1")}} \let\MPanchor\MPpos % overloaded locally when needed \def\MPe #1{\ctxcommand{MPe("#1")}} \def\MPls #1{\ctxcommand{MPls("#1")}} \let\MPleftskip\MPls % compatible feature @@ -353,17 +358,18 @@ \let\currentposition\s!unknown -%D A few special ones: +%D A few special ones .. will be cleaned up -\unexpanded\def\anch_mark_column_box - {\ifpositioning - \expandafter\gobbleoneargument - \else - \expandafter\anch_mark_column_box_indeed - \fi} +\def\pageanchor {page:\the\realpageno} % for the moment only one pagesize +\def\textanchor {text:\the\realpageno} +\def\regionanchor{region:0} + +\newcount\c_anch_column % will be delegated to lua +\newcount\c_anch_text % will be delegated to lua \unexpanded\def\anch_mark_column_box#1% - {\ctxcommand{markcolumnbox(\number#1)}} + {\global\advance\c_anch_column\plusone + \ctxcommand{markregionbox(\number#1,"columnarea:\the\c_anch_column")}} % extra height \unexpanded\def\anch_mark_region_box {\iftrialtypesetting @@ -377,6 +383,19 @@ \unexpanded\def\anch_mark_region_box#1% {\ctxcommand{markregionbox(\number#1)}} +\unexpanded\def\anch_mark_flow_box#1% will be extended / renamed + {\hbox\bgroup + \global\advance\c_anch_text\plusone + \ctxcommand{markregionbox(\number#1,"textarea:\the\c_anch_text")}% + \box#1% + \egroup} + +\unexpanded\def\anch_make_page_box#1% maybe like text + {\ctxcommand{markregionbox(\number#1,"\pageanchor")}} % needs an hbox + +\unexpanded\def\anch_mark_text_box#1% + {\ctxcommand{markregionbox(\number#1,"\textanchor")}} % needs an hbox + %D We can copy a position with: %D %D \starttyping @@ -396,6 +415,7 @@ %D \stoptyping \def\doifpositionelse#1{\ctxcommand{doifpositionelse('#1')}} +\def\doifposition #1{\ctxcommand{doifposition('#1')}} %D We have now arrived at a few macros that would make sense as %D support macros, but ended up in the core. @@ -428,45 +448,6 @@ \unexpanded\def\bpos #1{\dontleavehmode \setpositionstrut{b:#1}\ignorespaces} \unexpanded\def\epos #1{\removeunwantedspaces\setpositionstrut{e:#1}} -%unexpanded\def\fpos #1{\dontleavehmode \setpositionstrut{b:#1}\ignorespaces} -%unexpanded\def\tpos #1{\removeunwantedspaces\setpositionstrut{e:#1}} -\unexpanded\def\ffpos#1{\dontleavehmode \setpositionstrut{b:#1}\wpos{#1}\ignorespaces} -%unexpanded\def\ttpos#1{\removeunwantedspaces\setpositionstrut{e:#1}} - -\let\fpos \bpos -\let\tpos \epos -\let\ttpos\epos - -%D Crap: - -\unexpanded\def\wpos#1% will be redone - {\dontleavehmode\vadjust % may disappear if buried - {\setbox\scratchbox\hbox{\raise\strutdp\hbox{\rawwpos{#1}}}% - \rlap{\smashedbox\scratchbox}}} - -\unexpanded\def\wwpos#1% \hsmashed{\llap{\rawwpos{#1}}} - {\rlap - {\setbox\scratchbox\hbox{\rawwpos{#1}}% - \smashedbox\scratchbox}} - -\unexpanded\def\rawwpos#1% - {\hpos{w:#1} - {\strut - \hskip\dimexpr\hsize-\leftskip-\rightskip\relax}} - -% the next macro disables par positions (in inner boxes) and -% only registers the width - -\unexpanded\def\setinnerparpositions - {\let\fpos\ffpos - \let\tpos\ttpos - \let\wpos\wwpos} - -% example of usage: (see for application "techniek") -% -% \appendtoks -% \setinnerparpositions -% \to \everytabulate %D When we want to calculate more complex backgrounds, we %D need to know what the current indentation scheme is. At diff --git a/tex/context/base/anch-tab.mkiv b/tex/context/base/anch-tab.mkiv index 75ba07796..08105ab53 100644 --- a/tex/context/base/anch-tab.mkiv +++ b/tex/context/base/anch-tab.mkiv @@ -13,11 +13,53 @@ \writestatus{loading}{ConTeXt Anchoring Macros / Table Extensions} -%D Beware, the code in this module is somewhat weird and experimental -%D and might be dropped or become a loadable module. - \unprotect +\newcount\c_anch_tabs + +\unexpanded\def\tabl_tabulate_hook_b + {\iftrialtypesetting\else + \ifpositioning + \ifcase\c_tabl_tabulate_noflines % \ifnum\c_tabl_tabulate_noflines=\c_tabl_tabulate_totalnoflines + \tabl_tabulate_hook_b_first + \else + \tabl_tabulate_hook_b_next + \fi + \fi + \fi} + +\unexpanded\def\tabl_tabulate_hook_e + {\iftrialtypesetting\else + \ifpositioning + \ifcase\c_tabl_tabulate_noflines % \ifnum\c_tabl_tabulate_noflines=\c_tabl_tabulate_totalnoflines + \tabl_tabulate_hook_e_first + \else + \tabl_tabulate_hook_e_next + \fi + \fi + \fi} + +\unexpanded\def\tabl_tabulate_hook_b_first + {\ctxcommand{bcolumn("tabulate:\the\c_anch_tabs:\the\c_tabl_tabulate_column",true)}} + +\unexpanded\def\tabl_tabulate_hook_b_next + {\ctxcommand{bcolumn("tabulate:\the\c_anch_tabs:\the\c_tabl_tabulate_column")}} + +\unexpanded\def\tabl_tabulate_hook_e_first + {\ctxcommand{ecolumn(true)}} + +\unexpanded\def\tabl_tabulate_hook_e_next + {\ctxcommand{ecolumn()}} + +% \appendtoks \registerparoptions \to \everypar + +\appendtoks + \global\advance\c_anch_tabs\plusone +\to \everytabulate + +%D Beware, the following code is somewhat weird and experimental +%D and might be dropped or become a loadable module. + %D \macros %D {GFC, GTC, GSC} %D @@ -163,8 +205,8 @@ \iftrialtypesetting\else\ifconditional\tablehaspositions\doflushtabulateepos\fi\fi} \appendtoks - \let\dotablebpos\dotabulatebpos - \let\dotableepos\dotabulateepos + \let\dotablebpos\dotabulatebpos % ? + \let\dotableepos\dotabulateepos % ? \glet\doflushtabulateepos\relax \to \everytabulate diff --git a/tex/context/base/back-exp.mkiv b/tex/context/base/back-exp.mkiv index 311ffe5d2..7811ee5ed 100644 --- a/tex/context/base/back-exp.mkiv +++ b/tex/context/base/back-exp.mkiv @@ -89,8 +89,8 @@ \to \everyenableelements \appendtoks - %\def\dotagcombination{\taggedctxcommand{settagcombination(\combinationparameter\c!nx,\combinationparameter\c!ny)}}% - \unexpanded\def\dotagcombination{\taggedctxcommand{settagcombination(\number\horcombination,\number\totcombination)}}% + \unexpanded\def\dotagcombination{\taggedctxcommand{settagcombination(\combinationparameter\c!nx,\combinationparameter\c!ny)}}% + %\unexpanded\def\dotagcombination{\taggedctxcommand{settagcombination(\number\horcombination,\number\totcombination)}}% \to \everyenableelements \appendtoks diff --git a/tex/context/base/bibl-tra.mkiv b/tex/context/base/bibl-tra.mkiv index 44afd83b8..3531703ad 100644 --- a/tex/context/base/bibl-tra.mkiv +++ b/tex/context/base/bibl-tra.mkiv @@ -188,6 +188,7 @@ [pubs] [\c!state=\v!start, \c!criterium=\@@pbcriterium, + \c!headnumber=\v!always, % needed as we provide our own and need to force \c!width=] \installstructurelistprocessor{pubs:userdata}% @@ -312,8 +313,8 @@ \def\@@pbinumbercommand{\executeifdefined{\??pb:\c!numbercommand:\@@pbnumbering}\firstofoneargument} -\letvalue{\??pb:\c!numbercommand:\v!yes }\firstofoneargument -\letvalue{\??pb:\c!numbercommand:\v!no }\gobbleoneargument +\setvalue{\??pb:\c!numbercommand:\v!yes }#1{#1}% +\setvalue{\??pb:\c!numbercommand:\v!no }#1{} \setvalue{\??pb:\c!numbercommand:\v!short}#1{\bibgetvars\currentpublicationkey} \setvalue{\??pb:\c!numbercommand:\v!bib }#1{\bibgetvarn\currentpublicationkey} @@ -742,7 +743,7 @@ \def\doprocessbibtexentry#1{\typesetapublication{#1}} -\def\typesetpubslist +\unexpanded\def\typesetpubslist {\begingroup \startpacked[\v!blank]% \preloadbiblist @@ -766,7 +767,7 @@ \newif\ifinpublist -\def\initializepubslist +\unexpanded\def\initializepubslist {\def\currentlist{pubs}% \edef\@@pbnumbering{\@@pbnumbering}% \doifelse\@@pbautohang\v!yes @@ -805,12 +806,12 @@ \doifelse{\publicationlistparameter\c!maybeyear}{\v!off}{\def\maybeyear##1{}}{\def\maybeyear##1{##1}}% \forgetall} -\def\outdented#1% move to supp-box ? +\unexpanded\def\outdented#1% move to supp-box ? {\hskip-\hangindent#1\relax} %D The full list of publications -\def\completepublications +\unexpanded\def\completepublications {\dosingleempty\docompletepublications} \def\docompletepublications[#1]% @@ -874,10 +875,10 @@ {\global\advance\bibtexcounter\plusone \def\currentpublicationkey{#1}% \ctxlua{bibtex.hacks.registerplaced("#1")}% - \def\currentlist {pubs}% - \let\currentlistentrynumber \bibtexcounter - \let\currentlistentrytitle \bibtexpubtext - \let\currentlistentrypagenumber\empty + \def \currentlist {pubs}% + \edef\currentlistentrynumber {\number\bibtexcounter}% + \let \currentlistentrytitle \bibtexpubtext + \let \currentlistentrypagenumber\empty \strc_lists_apply_renderingsetup} {}} % invalid diff --git a/tex/context/base/buff-ini.mkiv b/tex/context/base/buff-ini.mkiv index 658f54f33..239a274c0 100644 --- a/tex/context/base/buff-ini.mkiv +++ b/tex/context/base/buff-ini.mkiv @@ -148,7 +148,7 @@ [\c!before=, \c!after=] -\unexpanded\def\processTEXbuffer +\unexpanded\def\processTEXbuffer % keep case, maybe also lower {\dosingleempty\buff_process_tex} \def\buff_process_tex[#1]% diff --git a/tex/context/base/colo-ini.mkiv b/tex/context/base/colo-ini.mkiv index 522f3fd62..013946df6 100644 --- a/tex/context/base/colo-ini.mkiv +++ b/tex/context/base/colo-ini.mkiv @@ -145,6 +145,13 @@ \unexpanded\def\directcolored[#1]{\colo_basics_defined_and_activated{#1}} +\unexpanded\def\fastcolor [#1]#2{\begingroup % is this command still needed? + \colo_helpers_activate{#1}% + #2% + \endgroup} + +\unexpanded\def\directcolor [#1]{\colo_helpers_activate{#1}} + %D The following command is obsolete: diff --git a/tex/context/base/cont-new.mkii b/tex/context/base/cont-new.mkii index 32a8c39ac..889bcd918 100644 --- a/tex/context/base/cont-new.mkii +++ b/tex/context/base/cont-new.mkii @@ -11,7 +11,7 @@ %C therefore copyrighted by \PRAGMA. See mreadme.pdf for %C details. -\newcontextversion{2012.02.08 21:58} +\newcontextversion{2012.02.16 09:55} %D This file is loaded at runtime, thereby providing an %D excellent place for hacks, patches, extensions and new diff --git a/tex/context/base/cont-new.mkiv b/tex/context/base/cont-new.mkiv index 9d29b2868..7c7f46cc1 100644 --- a/tex/context/base/cont-new.mkiv +++ b/tex/context/base/cont-new.mkiv @@ -11,7 +11,7 @@ %C therefore copyrighted by \PRAGMA. See mreadme.pdf for %C details. -\newcontextversion{2012.02.08 21:58} +\newcontextversion{2012.02.16 09:55} %D This file is loaded at runtime, thereby providing an %D excellent place for hacks, patches, extensions and new diff --git a/tex/context/base/context-version.pdf b/tex/context/base/context-version.pdf Binary files differindex 64f82f314..0f6482af5 100644 --- a/tex/context/base/context-version.pdf +++ b/tex/context/base/context-version.pdf diff --git a/tex/context/base/context-version.png b/tex/context/base/context-version.png Binary files differindex 1f8958f7b..7d1d1c52f 100644 --- a/tex/context/base/context-version.png +++ b/tex/context/base/context-version.png diff --git a/tex/context/base/context.mkii b/tex/context/base/context.mkii index de0c56634..9e68e36f0 100644 --- a/tex/context/base/context.mkii +++ b/tex/context/base/context.mkii @@ -20,7 +20,7 @@ %D your styles an modules. \edef\contextformat {\jobname} -\edef\contextversion{2012.02.08 21:58} +\edef\contextversion{2012.02.16 09:55} %D For those who want to use this: diff --git a/tex/context/base/context.mkiv b/tex/context/base/context.mkiv index 240244f40..769744932 100644 --- a/tex/context/base/context.mkiv +++ b/tex/context/base/context.mkiv @@ -23,7 +23,7 @@ %D up and the dependencies are more consistent. \edef\contextformat {\jobname} -\edef\contextversion{2012.02.08 21:58} +\edef\contextversion{2012.02.16 09:55} %D For those who want to use this: @@ -332,8 +332,9 @@ \loadmkvifile{font-lib} \loadmkvifile{font-fil} +\loadmkvifile{font-var} \loadmkvifile{font-fea} -\loadmkvifile{font-mat} % might move below ini +\loadmkvifile{font-mat} \loadmkvifile{font-ini} \loadmkvifile{font-sym} \loadmkvifile{font-sty} diff --git a/tex/context/base/font-col.mkvi b/tex/context/base/font-col.mkvi index d78c082e3..030e9aef7 100644 --- a/tex/context/base/font-col.mkvi +++ b/tex/context/base/font-col.mkvi @@ -77,15 +77,15 @@ \def\font_fallbacks_clone_unique#specification#scale% kind of dododefinefont {\ctxcommand{fontcollectionreport("defining #specification (relative scale: #scale)")}% brrr - \setfalse\font_auto_font_size + \setfalse\c_font_auto_size \let\lastfontidentifier\s!dummy \def\v_font_size_relative{#scale}% \let\v_font_size_absolute\fontbody \font_helpers_low_level_define{#specification}\v_font_identifier_basic \csname\v_font_identifier_basic\endcsname - \setfalse\font_auto_font_size} % no \setfontcharacteristics and \the\everyfontswitch needed + \setfalse\c_font_auto_size} % no \setfontcharacteristics and \the\everyfontswitch needed -\def\font_fallbacks_clone_inherited#font% also a secod argument +\def\font_fallbacks_clone_inherited#font% also a second argument {\font_fallbacks_clone_unique{#font \savedfontspec}} \def\font_fallbacks_register_main #name{\ctxcommand{fontcollectionregister("#name")}} diff --git a/tex/context/base/font-fil.mkvi b/tex/context/base/font-fil.mkvi index 6548c87d8..dcb298619 100644 --- a/tex/context/base/font-fil.mkvi +++ b/tex/context/base/font-fil.mkvi @@ -290,13 +290,13 @@ % resolve \def\font_helpers_set_features_yes#name% - {\ifcsname\??fontfile\fontclass#name\s!features \endcsname\expandafter\let\expandafter\m_font_features + {\ifcsname\??fontfile\fontclass#name\s!features \endcsname\expandafter\let\expandafter\m_font_features % class + symbolic_name \csname\??fontfile\fontclass#name\s!features \endcsname\else - \ifcsname\??fontfile #name\s!features \endcsname\expandafter\let\expandafter\m_font_features + \ifcsname\??fontfile #name\s!features \endcsname\expandafter\let\expandafter\m_font_features % symbolic_name \csname\??fontfile #name\s!features \endcsname\else - \ifcsname\??fontfile\fontclass #name\endcsname\expandafter\font_helpers_set_features_yes + \ifcsname\??fontfile\fontclass #name\endcsname\expandafter\font_helpers_set_features_yes % class + parent_name \csname\??fontfile\fontclass #name\endcsname\else - \ifcsname\??fontfile #name\endcsname\expandafter\font_helpers_set_features_yes + \ifcsname\??fontfile #name\endcsname\expandafter\font_helpers_set_features_yes % parent_name \csname\??fontfile #name\endcsname\else \let\m_font_features\empty\fi\fi\fi\fi} diff --git a/tex/context/base/font-ini.mkvi b/tex/context/base/font-ini.mkvi index ea0c0dedc..f581a1685 100644 --- a/tex/context/base/font-ini.mkvi +++ b/tex/context/base/font-ini.mkvi @@ -483,25 +483,6 @@ \csname\??mappedfontsize\the\dimexpr#from\relax\endcsname\else#from% \fi} -%D \macros -%D {fontstyle,fontalternative,fontsize} -%D -%D Within a bodyfont, fonts can come in different sizes. For instance -%D \type {\tf} is accompanied by \type {\tfa}, \type {\tfb} etc. The -%D first two characters denote the alternative, while the third -%D character in these sequences represents the size. The actual size -%D is saved in a macro. The styles, being roman (\type {\rm}), sans -%D serif (\type {\ss}) etc. are also available in macros in \type {rm}, -%D \type {ss} etc. form. - -\let\defaultfontalternative\s!tf -\let\defaultfontstyle \empty -\let\defaultfontsize \empty - -\let\fontalternative \defaultfontalternative -\let\fontstyle \defaultfontstyle -\let\fontsize \defaultfontsize - \installcorenamespace{fontbodyknown} \installcorenamespace{fontclassyes} % fontclass \installcorenamespace{fontclassnop} % nofontclass @@ -743,17 +724,18 @@ {% we can now set more at the lua end \ctxcommand{definefont_one(\!!bs\luaescapestring{#specification}\!!es)}% the escapestring catches at \somedimen % sets \scaledfontmode and \somefontname and \somefontsize - % MAYBE MOVE THIS TO THE CALLER - \ifx\currentmathsize\empty % CAN BE ZERO - \else - \ifcase\currentmathsize - \or - \let\v_font_size_absolute\textface - \or - \let\v_font_size_absolute\scriptface - \or - \let\v_font_size_absolute\scriptscriptface - \fi + \ifcase\fontface\relax + % \let\v_font_size_absolute\textface % fontbody + \or + \let\v_font_size_absolute\textface + \or + \let\v_font_size_absolute\scriptface + \or + \let\v_font_size_absolute\scriptscriptface + \or + \let\v_font_size_absolute\xtextface + \or + \let\v_font_size_absolute\xxtextface \fi % \ifcase\scaledfontmode\relax @@ -798,7 +780,7 @@ \fi \font_helpers_update_font_parameters \font_helpers_update_font_class_parameters - % \writestatus{fonts}{low level define: #csname/\somefontfile/\number\d_font_scaled_font_size/\currentmathsize/\number\d_font_scaled_text_face}% + % \writestatus{fonts}{low level define: #csname/\somefontfile/\number\d_font_scaled_font_size/\fontface/\number\d_font_scaled_text_face}% \ctxcommand{definefont_two( \ifx\fontclass\empty false\else true\fi, "#csname", @@ -809,7 +791,7 @@ "\m_font_features", "\m_font_class_fallbacks", "\m_font_fallbacks", - 0\currentmathsize, + \fontface, % 1/2/3: text script scriptscript 0/4/5: body x xx \number\d_font_scaled_text_face, "\number\relativefontid", % experiment "\m_font_class_goodies", % experiment (not yet used) @@ -933,13 +915,13 @@ \let\lastfontidentifier\empty -\def\v_font_identifier_basic{\??fontinstancebasic \lastfontidentifier-\fontsize-\currentmathsize} -\def\v_font_identifier_class{\??fontinstanceclass\fontclass-\lastfontidentifier-\fontsize-\currentmathsize} +\def\v_font_identifier_basic{\??fontinstancebasic \lastfontidentifier-\fontsize-\fontface} +\def\v_font_identifier_class{\??fontinstanceclass\fontclass-\lastfontidentifier-\fontsize-\fontface} \let\v_font_identifier_basic_saved\v_font_identifier_basic \let\v_font_identifier_class_saved\v_font_identifier_class -% \def\v_font_identifier_class{\??fontinstanceclass\fontclass-\lastfontidentifier-\fontstyle-\fontsize} % no \currentmathsize +% \def\v_font_identifier_class{\??fontinstanceclass\fontclass-\lastfontidentifier-\fontstyle-\fontsize} % no \fontface \def\font_basics_define_font_without_parameters#identifier#2% {\c_font_feature_inheritance_mode\c_font_feature_inheritance_fontonly @@ -1459,20 +1441,46 @@ % the rest is a size, although in practice one will seldom define the size directly. We might even % drop that as it gives faster code. +% \unexpanded\def\font_basics_define_body_font_nop_xx[#one#two#rest=#value]% local +% {\ifcsname\m_font_asked_style#one#two#rest\endcsname\else\font_basics_check_fontname_combination\m_font_asked_style{#one#two}{#rest}\fi +% \expandafter\let\csname\??fontinstanceclass\m_font_asked_body-\m_font_asked_style-#one#two-#rest\endcsname\undefined +% \unexpanded\expandafter\normaledef\csname\??fontinstanceready\m_font_asked_body-\m_font_asked_style-#one#two-#rest\endcsname +% {\font_helpers_trigger{\m_font_asked_body-\m_font_asked_style-#one#two#rest}{\noexpand\font_rscale_xx{\m_font_asked_style}}{\m_font_asked_body}{\normalunexpanded{#value}}}% +% } + \unexpanded\def\font_basics_define_body_font_nop_xx[#one#two#rest=#value]% local {\ifcsname\m_font_asked_style#one#two#rest\endcsname\else\font_basics_check_fontname_combination\m_font_asked_style{#one#two}{#rest}\fi - \expandafter\let\csname\??fontinstanceclass\m_font_asked_body-\m_font_asked_style-#one#two-#rest\endcsname\undefined - \unexpanded\expandafter\normaledef\csname\??fontinstanceready\m_font_asked_body-\m_font_asked_style-#one#two-#rest\endcsname + \expandafter\let\csname\??fontinstanceclass\m_font_asked_body-\m_font_asked_style-#one#two-#rest-0\endcsname\undefined + \unexpanded\expandafter\normaledef\csname\??fontinstanceready\m_font_asked_body-\m_font_asked_style-#one#two-#rest-0\endcsname + {\font_helpers_trigger{\m_font_asked_body-\m_font_asked_style-#one#two#rest}{\noexpand\font_rscale_xx{\m_font_asked_style}}{\m_font_asked_body}{\normalunexpanded{#value}}}% + \expandafter\let\csname\??fontinstanceclass\m_font_asked_body-\m_font_asked_style-#one#two-#rest-4\endcsname\undefined + \unexpanded\expandafter\normaledef\csname\??fontinstanceready\m_font_asked_body-\m_font_asked_style-#one#two-#rest-4\endcsname + {\font_helpers_trigger{\m_font_asked_body-\m_font_asked_style-#one#two#rest}{\noexpand\font_rscale_xx{\m_font_asked_style}}{\m_font_asked_body}{\normalunexpanded{#value}}}% + \expandafter\let\csname\??fontinstanceclass\m_font_asked_body-\m_font_asked_style-#one#two-#rest-5\endcsname\undefined + \unexpanded\expandafter\normaledef\csname\??fontinstanceready\m_font_asked_body-\m_font_asked_style-#one#two-#rest-5\endcsname {\font_helpers_trigger{\m_font_asked_body-\m_font_asked_style-#one#two#rest}{\noexpand\font_rscale_xx{\m_font_asked_style}}{\m_font_asked_body}{\normalunexpanded{#value}}}% } % \writestatus{fonts}{define \m_asked_style\space nop: \expandafter\meaning\csname\m_font_asked_body\m_font_asked_style#one#two#rest\endcsname}% +% \unexpanded\def\font_basics_define_body_font_yes_xx[#one#two#rest=#value]% global +% {\ifcsname\m_font_asked_style#one#two#rest\endcsname\else\font_basics_check_fontname_combination\m_font_asked_style{#one#two}{#rest}\fi +% \global\expandafter\let\csname\??fontinstanceclass\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest\endcsname\undefined +% \unexpanded\expandafter\normalxdef\csname\??fontinstanceready\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest\endcsname +% {\font_helpers_trigger{\m_font_asked_body-\m_font_asked_style-#one#two#rest}{\number\p_font_rscale}{\m_font_asked_body}{\normalunexpanded{#value}}}% +% } + \unexpanded\def\font_basics_define_body_font_yes_xx[#one#two#rest=#value]% global {\ifcsname\m_font_asked_style#one#two#rest\endcsname\else\font_basics_check_fontname_combination\m_font_asked_style{#one#two}{#rest}\fi - \global\expandafter\let\csname\??fontinstanceclass\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest\endcsname\undefined - \unexpanded\expandafter\normalxdef\csname\??fontinstanceready\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest\endcsname - {\font_helpers_trigger{\m_font_asked_body-\m_font_asked_style-#one#two#rest}{\number\p_font_rscale}{\m_font_asked_body}{\normalunexpanded{#value}}}% + \global\expandafter\let\csname\??fontinstanceclass\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest-1\endcsname\undefined + \unexpanded\expandafter\normalxdef\csname\??fontinstanceready\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest-0\endcsname + {\font_helpers_trigger{\m_font_asked_body-\m_font_asked_style-#one#two#rest-0}{\number\p_font_rscale}{\m_font_asked_body}{\normalunexpanded{#value}}}% + \global\expandafter\let\csname\??fontinstanceclass\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest-2\endcsname\undefined + \unexpanded\expandafter\normalxdef\csname\??fontinstanceready\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest-4\endcsname + {\font_helpers_trigger{\m_font_asked_body-\m_font_asked_style-#one#two#rest-4}{\number\p_font_rscale}{\m_font_asked_body}{\normalunexpanded{#value}}}% + \global\expandafter\let\csname\??fontinstanceclass\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest-3\endcsname\undefined + \unexpanded\expandafter\normalxdef\csname\??fontinstanceready\fontclass-\m_font_asked_body-\m_font_asked_style-#one#two-#rest-5\endcsname + {\font_helpers_trigger{\m_font_asked_body-\m_font_asked_style-#one#two#rest-5}{\number\p_font_rscale}{\m_font_asked_body}{\normalunexpanded{#value}}}% } % \writestatus{fonts}{define \m_asked_style\space yes: {\expandafter\meaning\csname\fontclass\m_font_asked_body\m_font_asked_style#one#two#rest\endcsname} @@ -1692,21 +1700,6 @@ %\font_helpers_set_font_set_font_option_body_fallbacks{#method}{#body}% \fi} -% The following bunch of macros deals with the (run time) -% expansion of names onto the definitions made by \type -% {\definebodyfont}. - -% \let\fontbody \empty % ... 10pt 11pt 12pt ... -% \let\fontstyle \empty % rm ss tt mm hw cg ... -% \let\fontalternative\empty % tf bf sl it bs bi sc ... -% \let\fontsize \empty % xy-abcd ... - -\def\defaultfontbody{\normalizedbodyfontsize} - -\let\fontbody\defaultfontbody - -\let\fontclass\empty \let\globalfontclass\fontclass - % we need to check the fontclass \def\registerfontclass#class% @@ -1734,7 +1727,7 @@ %D So far for synchronisation. (We can inline the following macros.) -\unexpanded\def\setcurrentfont#body#style#alternative#size% +\unexpanded\def\setcurrentfont#body#style#alternative#size% not used {\edef\fontbody {#body}% \edef\fontstyle {#style}% \edef\fontalternative{#alternative}% @@ -1742,7 +1735,7 @@ \font_helpers_check_big_math_synchronization \font_helpers_synchronize_font} -\unexpanded\def\setcurrentfontbody#body% +\unexpanded\def\setcurrentfontbody#body% % not used {\edef\fontbody{#body}% \font_helpers_synchronize_font} @@ -1759,8 +1752,7 @@ \font_helpers_synchronize_font} \unexpanded\def\font_helpers_set_current_xsize_alternative#xsize#alternative% - {% if we want to go smaller then we can always consider a local bodyswitch - \edef\fontsize {#xsize}% + {\edef\fontface{#xsize}% \edef\fontalternative{#alternative}% \font_helpers_synchronize_font} @@ -1813,50 +1805,50 @@ %D so further optimization makes no sense. \def\font_helpers_check_strategy_class_a % --- --- --- --- % pt tt bf a - {\ifcsname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\fontalternative-\fontsize\endcsname + {\ifcsname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\fontalternative-\fontsize-\fontface\endcsname \setfalse\c_font_auto_size - \csname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\fontalternative-\fontsize\endcsname + \csname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\fontalternative-\fontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_class_b \fi} \def\font_helpers_check_strategy_class_b % --- --- --- def % pt tt bf - {\ifcsname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\fontalternative-\defaultfontsize\endcsname + {\ifcsname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\fontalternative-\defaultfontsize-\fontface\endcsname \settrue\c_font_auto_size - \csname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\fontalternative-\defaultfontsize\endcsname + \csname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\fontalternative-\defaultfontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_class_c \fi} \def\font_helpers_check_strategy_class_c % --- --- def --- % pt tt tf a - {\ifcsname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\defaultfontalternative-\fontsize\endcsname + {\ifcsname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\defaultfontalternative-\fontsize-\fontface\endcsname \settrue\c_font_auto_size - \csname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\defaultfontalternative-\fontsize\endcsname + \csname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\defaultfontalternative-\fontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_class_d \fi} \def\font_helpers_check_strategy_class_d % --- --- def def % pt tt tf - {\ifcsname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\defaultfontalternative-\defaultfontsize\endcsname + {\ifcsname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \settrue\c_font_auto_size - \csname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\defaultfontalternative-\defaultfontsize\endcsname + \csname\??fontinstanceready\fontclass-\fontbody-\fontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_class_e \fi} \def\font_helpers_check_strategy_class_e % --- def def def % pt rm tf - {\ifcsname\??fontinstanceready\fontclass-\fontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize\endcsname + {\ifcsname\??fontinstanceready\fontclass-\fontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \setfalse\c_font_auto_size - \csname\??fontinstanceready\fontclass-\fontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize\endcsname + \csname\??fontinstanceready\fontclass-\fontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_class_f % \expandafter\font_helpers_check_strategy_a \fi} \def\font_helpers_check_strategy_class_f % def def def def % rm tf - {\ifcsname\??fontinstanceready\fontclass-\defaultfontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize\endcsname + {\ifcsname\??fontinstanceready\fontclass-\defaultfontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \settrue\c_font_auto_size - \csname\??fontinstanceready\fontclass-\defaultfontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize\endcsname + \csname\??fontinstanceready\fontclass-\defaultfontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_a \fi} @@ -1864,49 +1856,49 @@ % no class \def\font_helpers_check_strategy_a % --- --- --- --- % pt tt bf a - {\ifcsname\??fontinstanceready\fontbody-\fontstyle-\fontalternative-\fontsize\endcsname + {\ifcsname\??fontinstanceready\fontbody-\fontstyle-\fontalternative-\fontsize-\fontface\endcsname \setfalse\c_font_auto_size - \csname\??fontinstanceready\fontbody-\fontstyle-\fontalternative-\fontsize\endcsname + \csname\??fontinstanceready\fontbody-\fontstyle-\fontalternative-\fontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_b \fi} \def\font_helpers_check_strategy_b % --- --- --- --- % pt tt bf a - {\ifcsname\??fontinstanceready\fontbody-\fontstyle-\fontalternative-\defaultfontsize\endcsname + {\ifcsname\??fontinstanceready\fontbody-\fontstyle-\fontalternative-\defaultfontsize-\fontface\endcsname \settrue\c_font_auto_size - \csname\??fontinstanceready\fontbody-\fontstyle-\fontalternative-\defaultfontsize\endcsname + \csname\??fontinstanceready\fontbody-\fontstyle-\fontalternative-\defaultfontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_c \fi} \def\font_helpers_check_strategy_c % --- --- --- --- % pt tt bf a - {\ifcsname\??fontinstanceready\fontbody-\fontstyle-\defaultfontalternative-\fontsize\endcsname + {\ifcsname\??fontinstanceready\fontbody-\fontstyle-\defaultfontalternative-\fontsize-\fontface\endcsname \settrue\c_font_auto_size - \csname\??fontinstanceready\fontbody-\fontstyle-\defaultfontalternative-\fontsize\endcsname + \csname\??fontinstanceready\fontbody-\fontstyle-\defaultfontalternative-\fontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_d \fi} \def\font_helpers_check_strategy_d % --- --- --- --- % pt tt bf a - {\ifcsname\??fontinstanceready\fontbody-\fontstyle-\defaultfontalternative-\defaultfontsize\endcsname + {\ifcsname\??fontinstanceready\fontbody-\fontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \settrue\c_font_auto_size - \csname\??fontinstanceready\fontbody-\fontstyle-\defaultfontalternative-\defaultfontsize\endcsname + \csname\??fontinstanceready\fontbody-\fontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_e \fi} \def\font_helpers_check_strategy_e % --- --- --- --- % pt tt bf a - {\ifcsname\??fontinstanceready\fontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize\endcsname + {\ifcsname\??fontinstanceready\fontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \setfalse\c_font_auto_size - \csname\??fontinstanceready\fontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize\endcsname + \csname\??fontinstanceready\fontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \else \expandafter\font_helpers_check_strategy_f \fi} \def\font_helpers_check_strategy_f % --- --- --- --- % pt tt bf a - {\ifcsname\??fontinstanceready\defaultfontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize\endcsname + {\ifcsname\??fontinstanceready\defaultfontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \settrue\c_font_auto_size - \csname\??fontinstanceready\defaultfontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize\endcsname + \csname\??fontinstanceready\defaultfontbody-\defaultfontstyle-\defaultfontalternative-\defaultfontsize-\fontface\endcsname \fi} \let\applyfontstrategies \font_helpers_check_strategy_a @@ -1938,33 +1930,41 @@ \fi} \def\font_helpers_set_current_font_x_alternative#alternative% - {\font_helpers_set_current_font_xxx_alternative{#alternative}\s!x\scriptstyle + {\font_helpers_set_current_font_xxx_alternative{#alternative}{4}\scriptstyle \currentxfontsize\plusone \let\tx\txx} \def\font_helpers_set_current_font_xx_alternative#alternative% - {\font_helpers_set_current_font_xxx_alternative{#alternative}\s!xx\scriptscriptstyle + {\font_helpers_set_current_font_xxx_alternative{#alternative}{5}\scriptscriptstyle \currentxfontsize\plustwo \let\tx\empty \let\txx\empty} -\def\font_helpers_check_nested_x_fontsize % option - {\ifcase\currentxfontsize\else\ifx\fontsize\empty\else +\def\font_helpers_reset_x_fontsize + {\ifcase\currentxfontsize\else \currentxfontsize\zerocount - \let\fontsize\empty \let\tx\normaltx \let\txx\normaltxx - \fi\fi} + \fi} + +\def\font_helpers_check_nested_x_fontsize % option +% {\ifcase\currentxfontsize\else\ifx\fontsize\empty\else +% \currentxfontsize\zerocount +% \let\fontsize\empty +% \let\tx\normaltx +% \let\txx\normaltxx +% \fi\fi} + {} \def\font_helpers_set_current_font_x_alternative#alternative% {\font_helpers_check_nested_x_fontsize - \font_helpers_set_current_font_xxx_alternative{#alternative}\s!x\scriptstyle + \font_helpers_set_current_font_xxx_alternative{#alternative}{4}\scriptstyle \currentxfontsize\plusone \let\tx\txx} \def\font_helpers_set_current_font_xx_alternative#alternative% {\font_helpers_check_nested_x_fontsize - \font_helpers_set_current_font_xxx_alternative{#alternative}\s!xx\scriptscriptstyle + \font_helpers_set_current_font_xxx_alternative{#alternative}{5}\scriptscriptstyle \currentxfontsize\plustwo \let\tx\empty \let\txx\empty} @@ -2015,13 +2015,36 @@ \def\textface {\currentbodyfontdimension\s!text } \def\scriptface {\currentbodyfontdimension\s!script } \def\scriptscriptface{\currentbodyfontdimension\s!scriptscript} +\def\xtextface {\currentbodyfontdimension\s!x } +\def\xxtextface {\currentbodyfontdimension\s!xx } + +% \unexpanded\def\font_basics_complete_switch#size% +% {\bodyfontsize#size\relax +% \normalizebodyfontsize\normalizedbodyfontsize\bodyfontsize +% \edef\textface {\currentbodyfontdimension\s!text }% +% \edef\scriptface {\currentbodyfontdimension\s!script }% +% \edef\scriptscriptface{\currentbodyfontdimension\s!scriptscript}}% + +\installcorenamespace{fontbodyfaces} \unexpanded\def\font_basics_complete_switch#size% {\bodyfontsize#size\relax \normalizebodyfontsize\normalizedbodyfontsize\bodyfontsize - \edef\textface {\currentbodyfontdimension\s!text }% - \edef\scriptface {\currentbodyfontdimension\s!script }% - \edef\scriptscriptface{\currentbodyfontdimension\s!scriptscript}}% + \expandafter\let\expandafter\font_basics_set_faces\csname\??fontbodyfaces\fontbody\endcsname + \ifx\font_basics_set_faces\relax + \font_basics_set_faces_preset + \fi + \font_basics_set_faces} + +\def\font_basics_set_faces_preset + {\edef\font_basics_set_faces{% 0.2 sec on 10K \tfa + \noexpand\edef\noexpand\textface {\currentbodyfontdimension\s!text }% + \noexpand\edef\noexpand\scriptface {\currentbodyfontdimension\s!script }% + \noexpand\edef\noexpand\scriptscriptface{\currentbodyfontdimension\s!scriptscript}% + \noexpand\edef\noexpand\xtextface {\currentbodyfontdimension\s!x }% + \noexpand\edef\noexpand\xxtextface {\currentbodyfontdimension\s!xx }% + }% + \global\expandafter\let\csname\??fontbodyfaces\fontbody\endcsname\font_basics_set_faces} \def\currentbodyfontdimension#parameter% {\the\dimexpr @@ -2190,7 +2213,7 @@ \font_basics_switch_style \fontstyle} \unexpanded\def\setsmallbodyfont{\font_helpers_set_bodyfont_step\v!small\the\everybodyfont} -\unexpanded\def\setbigbodyfont {\font_helpers_set_bodyfont_step\gg \the\everybodyfont} +\unexpanded\def\setbigbodyfont {\font_helpers_set_bodyfont_step\v!big \the\everybodyfont} \unexpanded\def\setmainbodyfont {\font_basics_switch_points\normalizedbodyfontsize diff --git a/tex/context/base/font-mat.mkvi b/tex/context/base/font-mat.mkvi index 4ecb9d082..7ef0f2b77 100644 --- a/tex/context/base/font-mat.mkvi +++ b/tex/context/base/font-mat.mkvi @@ -73,9 +73,7 @@ \def\mathscriptsuffix {-script} \def\mathscriptscriptsuffix{-scriptscript} -\let\currentmathsize\empty - -\def\mathsizesuffix{\ifcase0\currentmathsize\or\mathtextsuffix\or\mathscriptsuffix\or\mathscriptscriptsuffix\fi} +\def\mathsizesuffix{\ifcase\fontface\or\mathtextsuffix\or\mathscriptsuffix\or\mathscriptscriptsuffix\fi} % Beware: truefontname also does a fallback on defaultfontclass so there % can be some interference here, which is why we use a different method @@ -105,13 +103,13 @@ \nullfont \settrue \c_font_auto_size \fi\fi} -\def\font_helpers_set_math_family_indeed#mrtag#family% \currentmathsize etc are also used later on +\def\font_helpers_set_math_family_indeed#mrtag#family% \fontface etc are also used later on {\let\savedfontbody\fontbody \let\fontfamily#family% - \let\currentmathsize\!!plusthree\font_helpers_set_math_family_a\scriptscriptfont#mrtag\font - \let\currentmathsize\!!plustwo \font_helpers_set_math_family_a\scriptfont #mrtag\font - \let\currentmathsize\!!plusone \font_helpers_set_math_family_a\textfont #mrtag\font - \let\currentmathsize\empty + \let\fontface\!!plusthree\font_helpers_set_math_family_a\scriptscriptfont#mrtag\font + \let\fontface\!!plustwo \font_helpers_set_math_family_a\scriptfont #mrtag\font + \let\fontface\!!plusone \font_helpers_set_math_family_a\textfont #mrtag\font + \let\fontface\!!zerocount \let\fontbody\savedfontbody \setfalse\c_font_auto_size} @@ -128,10 +126,10 @@ \let\defaultfontclass\fontclass % else truefontname falls back on the wrong one \let\savedfontbody\fontbody \let\fontfamily#familytag% - \let\currentmathsize\!!plusthree\font_helpers_set_math_family_bold_a\scriptscriptfont#mbfam#mrfam% - \let\currentmathsize\!!plustwo \font_helpers_set_math_family_bold_a\scriptfont #mbfam#mrfam% - \let\currentmathsize\!!plusone \font_helpers_set_math_family_bold_a\textfont #mbfam#mrfam% - \let\currentmathsize\empty + \let\fontface\!!plusthree\font_helpers_set_math_family_bold_a\scriptscriptfont#mbfam#mrfam% + \let\fontface\!!plustwo \font_helpers_set_math_family_bold_a\scriptfont #mbfam#mrfam% + \let\fontface\!!plusone \font_helpers_set_math_family_bold_a\textfont #mbfam#mrfam% + \let\fontface\!!zerocount \let\fontbody\savedfontbody \let\defaultfontclass\savedfontclass \setfalse\c_font_auto_size} diff --git a/tex/context/base/font-var.mkvi b/tex/context/base/font-var.mkvi new file mode 100644 index 000000000..e50c2bad4 --- /dev/null +++ b/tex/context/base/font-var.mkvi @@ -0,0 +1,53 @@ +%D \module +%D [ file=font-var, +%D version=2011.01.13, % (copied fron font-ini) +%D title=\CONTEXT\ Font Macros, +%D subtitle=Common Variables, +%D author=Hans Hagen, +%D date=\currentdate, +%D copyright={PRAGMA ADE \& \CONTEXT\ Development Team}] +%C +%C This module is part of the \CONTEXT\ macro||package and is +%C therefore copyrighted by \PRAGMA. See mreadme.pdf for +%C details. + +\writestatus{loading}{ConTeXt Font Macros / Common Variables} + +\unprotect + +% some more will move here + +%D \macros +%D {fontstyle,fontalternative,fontsize,fontbody} +%D +%D Within a bodyfont, fonts can come in different sizes. For instance +%D \type {\tf} is accompanied by \type {\tfa}, \type {\tfb} etc. The +%D first two characters denote the alternative, while the third +%D character in these sequences represents the size. The actual size +%D is saved in a macro. The styles, being roman (\type {\rm}), sans +%D serif (\type {\ss}) etc. are also available in macros in \type {rm}, +%D \type {ss} etc. form. + +% fontclass % modern dejavu +% fontbody % ... 10pt 11pt 12pt ... +% fontstyle % rm ss tt mm hw cg ... +% fontalternative % tf bf sl it bs bi sc ... +% fontsize % a b c d ... +% fontface % 0=normal 1=text 2=script 3=scriptscript 4=x 5=xx (math are temporary) + +\def\normalizedbodyfontsize{12pt} + +\def\defaultfontbody {\normalizedbodyfontsize} +\let\defaultfontstyle \empty +\let\defaultfontalternative \s!tf +\let\defaultfontsize \empty + +\let\globalfontclass \empty +\let\fontclass \empty +\let\fontbody \defaultfontbody +\let\fontstyle \defaultfontstyle +\let\fontalternative \defaultfontalternative +\let\fontsize \defaultfontsize +\let\fontface \!!zerocount + +\protect \endinput diff --git a/tex/context/base/lpdf-ano.lua b/tex/context/base/lpdf-ano.lua index 1aebe4e64..4d0a55f80 100644 --- a/tex/context/base/lpdf-ano.lua +++ b/tex/context/base/lpdf-ano.lua @@ -355,7 +355,7 @@ runners["outer"] = function(var,actions) end runners["outer with inner"] = function(var,actions) - local file = references.checkedfile(var.f) + local file = references.checkedfile(var.outer) -- was var.f but fails ... why return link(nil,file,var.inner,var.r,actions) end diff --git a/tex/context/base/lxml-css.lua b/tex/context/base/lxml-css.lua index cf946daf7..112a5e75d 100644 --- a/tex/context/base/lxml-css.lua +++ b/tex/context/base/lxml-css.lua @@ -14,6 +14,10 @@ local lpegmatch, lpegpatterns = lpeg.match, lpeg.patterns xml.css = xml.css or { } local css = xml.css +if not number.dimenfactors then + require("util-dim.lua") +end + local dimenfactors = number.dimenfactors local bpf = 1/dimenfactors.bp local cmf = 1/dimenfactors.cm @@ -75,6 +79,8 @@ css.padding = padding -- print(padding("10pt 20pt 30pt",pixel,hsize,exheight,emwidth)) -- print(padding("10pt 20pt 30pt 40pt",pixel,hsize,exheight,emwidth)) +-- print(padding("0",pixel,hsize,exheight,emwidth)) + -- local currentfont = font.current -- local texdimen = tex.dimen -- local hashes = fonts.hashes diff --git a/tex/context/base/lxml-lpt.lua b/tex/context/base/lxml-lpt.lua index 4e53e55f9..2644abf88 100644 --- a/tex/context/base/lxml-lpt.lua +++ b/tex/context/base/lxml-lpt.lua @@ -164,8 +164,8 @@ apply_axis['child'] = function(list) c = c + 1 collected[c] = dk dk.ni = k -- refresh - en = en + 1 - dk.ei = en + en = en + 1 + dk.ei = en end end ll.en = en diff --git a/tex/context/base/math-ini.mkiv b/tex/context/base/math-ini.mkiv index fa29e49c2..53e1c0779 100644 --- a/tex/context/base/math-ini.mkiv +++ b/tex/context/base/math-ini.mkiv @@ -598,14 +598,23 @@ \unexpanded\def\math_prime_indeed {\iffontchar\textfont\zerocount"FE325\relax - ^\bgroup +% ^\bgroup \expandafter\math_prime_indeed_virtual % virtual mess (using funny signal) \else - \expandafter\math_prime_indeed_normal % gets collapsed +% \expandafter\math_prime_indeed_normal % gets collapsed + \expandafter\math_prime_indeed_crapped % gets collapsed \fi} +\def\math_prime_indeed_crapped + {{^{\math_prime_indeed_normal}}} + \let\prime\math_prime_indeed +\def\math_prime_indeed_virtual + {^\bgroup + \math_prime_indeed_normal + \futurelet\nexttoken\math_prime_indeed_choice} + \installcorenamespace{mathprime} \def\math_prime_indeed_virtual diff --git a/tex/context/base/pack-rul.mkiv b/tex/context/base/pack-rul.mkiv index 43dcef7bf..18f0db163 100644 --- a/tex/context/base/pack-rul.mkiv +++ b/tex/context/base/pack-rul.mkiv @@ -1548,15 +1548,12 @@ % \framed[width=12cm,height=3cm,orientation=-270]{\input ward\relax} \def\pack_framed_start_orientation - {\ifcase\p_framed_orientation\else + {\ifcase\p_framed_orientation \let\pack_framed_stop_orientation\relax \else \scratchcounter\p_framed_orientation % weird .. why \divide\scratchcounter\plustwo \ifodd\scratchcounter - \swapmacros\framedwidth\framedheight - \swapmacros\localwidth\localheight - \swapdimens\d_framed_height\d_framed_width \let\pack_framed_stop_orientation\pack_framed_stop_orientation_odd \else \let\pack_framed_stop_orientation\pack_framed_stop_orientation_even @@ -2184,24 +2181,50 @@ %D possible to the circumstances and act as natural as %D possible. -\def\pack_framed_vboxed_hairline - {\bgroup - \dimen2=\ifconditional\c_framed_has_offset \localoffset \else \zeropoint \fi - \dimen4=\dimexpr\dimen2+\d_framed_linewidth\relax - \setbox0\vbox - {\advance\hsize 2\dimen4 - \vskip\dimen2 - \hrule - \!!height\d_framed_linewidth - \!!depth\zeropoint - \!!width\hsize - \vskip\dimen2}% - \endgraf\obeydepth\nointerlineskip - \moveleft\dimen4\box0 - \endgraf\nointerlineskip\localbegstrut % beware, we might kill it in a style using \vskip\lineheight - \egroup} % so this must not be changed - -\def\pack_framed_hboxed_hairline % use framed dimen +% \unexpanded\def\pack_framed_vboxed_hairline +% {\bgroup +% \dimen2=\ifconditional\c_framed_has_offset \localoffset \else \zeropoint \fi +% \dimen4=\dimexpr\dimen2+\d_framed_linewidth\relax +% \setbox0\vbox +% {\advance\hsize 2\dimen4 +% \vskip\dimen2 +% \hrule +% \!!height\d_framed_linewidth +% \!!depth\zeropoint +% \!!width\hsize +% \vskip\dimen2}% +% \endgraf\obeydepth\nointerlineskip +% \moveleft\dimen4\box0 +% \endgraf\nointerlineskip\localbegstrut % beware, we might kill it in a style using \vskip\lineheight +% \egroup} % so this must not be changed + +\unexpanded\def\pack_framed_vboxed_hairline % nasty overlay mess .. needed for autowidth + {\begingroup + \scratchoffset\ifconditional\c_framed_has_offset \localoffset \else \zeropoint \fi + \scratchwidth \dimexpr\scratchoffset+\d_framed_linewidth\relax + \par + \nointerlineskip + \kern\scratchoffset + \dontleavehmode + \hrule\!!height\d_framed_linewidth\!!depth\zeropoint + \par + \kern-\d_framed_linewidth + \dontleavehmode + \hbox to \zeropoint{\normalhss\vrule\!!height\d_framed_linewidth\!!depth\zeropoint\!!width\scratchwidth}% + \hfill + \hbox to \zeropoint{\vrule\!!height\d_framed_linewidth\!!depth\zeropoint\!!width\scratchwidth\normalhss}% + \par + \nointerlineskip + \kern\scratchoffset + \nointerlineskip + \endgraf + \nointerlineskip + \localbegstrut + \endgroup} + +% todo: + +\unexpanded\def\pack_framed_hboxed_hairline % use framed dimen {\bgroup \dimen2=\ifconditional\c_framed_has_offset \localoffset \else \zeropoint \fi \ifconditional\c_framed_has_height diff --git a/tex/context/base/page-bck.mkiv b/tex/context/base/page-bck.mkiv index 42891e76e..18e0a9f4d 100644 --- a/tex/context/base/page-bck.mkiv +++ b/tex/context/base/page-bck.mkiv @@ -669,6 +669,16 @@ \def\hiddenbackgroundlist {\v!text-2,\v!text-1,\v!foreground,\v!text+1,\v!text+2} +% \defineoverlay[\v!text-2][\positionoverlay{\v!text-2}] +% \defineoverlay[\v!text-1][\positionoverlay{\v!text-1}] +% \defineoverlay[\v!text+1][\positionoverlay{\v!text+1}] +% \defineoverlay[\v!text+2][\positionoverlay{\v!text+2}] + +\defineoverlay[\v!text-2][\positionregionoverlay\textanchor{\v!text-2}] % no new anchor, we share text +\defineoverlay[\v!text-1][\positionregionoverlay\textanchor{\v!text-1}] +\defineoverlay[\v!text+1][\positionregionoverlay\textanchor{\v!text+1}] +\defineoverlay[\v!text+2][\positionregionoverlay\textanchor{\v!text+2}] + \setupbackgrounds [\v!hidden] [\c!background=\hiddenbackgroundlist] @@ -686,7 +696,7 @@ \def\localbackgroundlist {\v!local-2,\v!local-1,\v!foreground,\v!local+1,\v!local+2} -\defineoverlay[\v!local-2][\positionoverlay{\v!local-2}] +\defineoverlay[\v!local-2][\positionoverlay{\v!local-2}] % todo share \defineoverlay[\v!local-1][\positionoverlay{\v!local-1}] \defineoverlay[\v!local+1][\positionoverlay{\v!local+1}] \defineoverlay[\v!local+2][\positionoverlay{\v!local+2}] @@ -698,12 +708,8 @@ \expandafter\gobbleoneargument \fi} -% \def\page_backgrounds_add_local_to_box_indeed#1% -% {\setbox#1\hbox{\fastlocalframed[\??ma\v!local][]{\registerMPlocaltextarea{\box#1}}}% -% \global\advance\localpositionnumber\plusone} % afterwards ! - \def\page_backgrounds_add_local_to_box_indeed#1% - {\setbox#1\hbox{\registerMPlocaltextarea{\box#1}}% + {%\setbox#1\hbox{\registerMPlocaltextarea{\box#1}}% \setbox#1\hbox{\localbackgroundframed{\??ma\v!local}\v!local#1}% \global\advance\localpositionnumber\plusone} % afterwards ! diff --git a/tex/context/base/page-box.mkvi b/tex/context/base/page-box.mkvi index 746944ef3..a13f794f1 100644 --- a/tex/context/base/page-box.mkvi +++ b/tex/context/base/page-box.mkvi @@ -275,28 +275,31 @@ \def\page_areas_registered_box_forget#1#2#3% #1=lower-dp #2=correct-ht #3=box {\box#3} +% \def\page_areas_registered_box_indeed#1#2#3% #1=lower-dp #2=correct-ht #3=box +% {\hbox\bgroup +% \ifx\registerMPtextarea\undefined \else +% \setbox\b_page_areas_registered\emptyhbox +% \wd\b_page_areas_registered\wd#3% +% \ht\b_page_areas_registered\ht#3% +% \dp\b_page_areas_registered\dp#3% +% \ifcase#1\or % 1 +% \setbox\b_page_areas_registered\hbox{\lower\strutdp\box\b_page_areas_registered}% +% \fi +% \ifcase#2\or % 1 +% \setbox\b_page_areas_registered\hbox{\raise\topskip\hbox{\lower\strutht\box\b_page_areas_registered}}% +% \dp\b_page_areas_registered\strutdp +% \fi +% \dp\b_page_areas_registered\strutdp % needed +% \setbox\b_page_areas_registered\hbox +% {\registerMPtextarea{\box\b_page_areas_registered}}% +% \smashbox\b_page_areas_registered +% \box\b_page_areas_registered +% \fi +% \box#3% +% \egroup} + \def\page_areas_registered_box_indeed#1#2#3% #1=lower-dp #2=correct-ht #3=box - {\hbox\bgroup - \ifx\registerMPtextarea\undefined \else - \setbox\b_page_areas_registered\emptyhbox - \wd\b_page_areas_registered\wd#3% - \ht\b_page_areas_registered\ht#3% - \dp\b_page_areas_registered\dp#3% - \ifcase#1\or % 1 - \setbox\b_page_areas_registered\hbox{\lower\strutdp\box\b_page_areas_registered}% - \fi - \ifcase#2\or % 1 - \setbox\b_page_areas_registered\hbox{\raise\topskip\hbox{\lower\strutht\box\b_page_areas_registered}}% - \dp\b_page_areas_registered\strutdp - \fi - \dp\b_page_areas_registered\strutdp % needed - \setbox\b_page_areas_registered\hbox - {\registerMPtextarea{\box\b_page_areas_registered}}% - \smashbox\b_page_areas_registered - \box\b_page_areas_registered - \fi - \box#3% - \egroup} + {\anch_mark_flow_box{#3}} \def\page_areas_register_direct#1% {\xypos{pbd:\realfolio:b}% we could save bytes by only saving the y diff --git a/tex/context/base/page-brk.mkiv b/tex/context/base/page-brk.mkiv index 01e4beb95..82aa809e8 100644 --- a/tex/context/base/page-brk.mkiv +++ b/tex/context/base/page-brk.mkiv @@ -336,7 +336,7 @@ #1\lineheight +\pagetotal \ifdim\lastskip<\parskip+\parskip\fi - \ifthirdargument+#2\fi + \ifsecondargument+#2\fi \relax \ifcase\testpagemethod \ifdim\d_page_tests_test>.99\pagegoal diff --git a/tex/context/base/page-mul.mkiv b/tex/context/base/page-mul.mkiv index 4901c1edf..948ef0bcc 100644 --- a/tex/context/base/page-mul.mkiv +++ b/tex/context/base/page-mul.mkiv @@ -488,10 +488,12 @@ \else \@EA\dohandleallcolumns \fi - {\finishcolumnbox{\hbox - {\ifx\finishcolumnbox\relax\else\strut\fi - \anch_mark_column_box\currentcolumnbox - \box\currentcolumnbox}}% + {\finishcolumnbox + {\setbox\scratchbox\hbox + {\ifx\finishcolumnbox\relax\else\strut\fi + \strut\box\currentcolumnbox}% + \anch_mark_column_box\scratchbox + \box\scratchbox}% \hfil}% \unskip \hskip\colrightskip}}% new @@ -537,28 +539,28 @@ \or % \input tufte \startcolumns \showbaselines \input tufte \stopcolumns \input tufte \ifconditional\someprecolumncontent -% \scratchdimen\topskip -% \advance\scratchdimen -\openstrutheight -% \nointerlineskip -% \vskip-\scratchdimen + % \scratchdimen\topskip + % \advance\scratchdimen -\openstrutheight + % \nointerlineskip + % \vskip-\scratchdimen \nointerlineskip \vskip\dimexpr\openstrutheight-\topskip\relax \fi \or -% \scratchdimen\topskip -% \advance\scratchdimen -\openstrutheight -% \nointerlineskip -% \vskip-\scratchdimen + % \scratchdimen\topskip + % \advance\scratchdimen -\openstrutheight + % \nointerlineskip + % \vskip-\scratchdimen \nointerlineskip \vskip\dimexpr\openstrutheight-\topskip\relax \or % untested but maybe handy -% \scratchdimen\topskip -% \advance\scratchdimen -\openstrutheight -% \nointerlineskip -% \vskip-\scratchdimen -% \vskip-\lineheight -% \vbox{\strut}% + % \scratchdimen\topskip + % \advance\scratchdimen -\openstrutheight + % \nointerlineskip + % \vskip-\scratchdimen + % \vskip-\lineheight + % \vbox{\strut}% \nointerlineskip \vskip\dimexpr\openstrutheight-\topskip-\lineheight\relax \vbox{\strut}% @@ -580,12 +582,12 @@ \vskip-\scratchdimen}% \scratchdimen\noflines\openlineheight \advance\scratchdimen-\openstrutdepth -\ifgridsnapping - % quick hack (at least it works with itemize) -\else - \advance\scratchdimen-\openlineheight - \advance\scratchdimen\topskip -\fi + \ifgridsnapping + % quick hack (at least it works with itemize) + \else + \advance\scratchdimen-\openlineheight + \advance\scratchdimen\topskip + \fi \ht\columnpagebox\scratchdimen \dp\columnpagebox\openstrutdepth % end of mess diff --git a/tex/context/base/page-set.mkiv b/tex/context/base/page-set.mkiv index 674f54831..97ede1357 100644 --- a/tex/context/base/page-set.mkiv +++ b/tex/context/base/page-set.mkiv @@ -522,7 +522,7 @@ \def\OTRSETdofinaloutput {\ifdim\ht\OTRfinalpagebox=\textheight - \bgroup + \bgroup \ifcase\OTRSETbalancemethod \page_otr_construct_and_shipout\box\OTRfinalpagebox \else\ifdim\OTRSETbalht>\zeropoint @@ -543,9 +543,9 @@ \page_otr_construct_and_shipout\box\OTRfinalpagebox \fi \fi \globallet\OTRSETbalht\zeropoint - \egroup + \egroup \fi} - + \definesystemconstant {colset} \definetwopasslist\s!colset @@ -585,7 +585,7 @@ \synchronizenotes \fi} -\def\OTRSETsethsize % of course this does not migrate outside the otr +\def\page_set_command_set_hsize % of course this does not migrate outside the otr {\localcolumnwidth\OTRSETlocalwidth\mofcolumns \textwidth\localcolumnwidth \hsize\localcolumnwidth} @@ -598,7 +598,8 @@ \egroup \else % only if change in width and \column/\break - \egroup \OTRSETsethsize + \egroup + \page_set_command_set_hsize \fi \fi} @@ -627,7 +628,7 @@ {\OTRSETcolumnhbreak \page_otr_flush_all_floats \page_otr_eject_page - % no \OTRSETsethsize, can be mid smaller (like tabulate) + % no \page_set_command_set_hsize, can be mid smaller (like tabulate) % also, this one should be executed at the outer level % (setting hsize inside otr does not work) \page_set_command_synchronize_hsize} @@ -688,7 +689,7 @@ \newconstant\OTRSETflushtextmode % will be replaced -\def\OTRSETflushtextsofar +\def\OTRSETflushtextsofar % needs renaming {\ifcase\OTRSETflushtextmode % don't mess around \or @@ -1591,7 +1592,7 @@ {\xdef\OTRSETlist{#1}}% \OTRSETstartnextpage \OTRSETassignwidths - \OTRSETsethsize + \page_set_command_set_hsize \else \bgroup \fi} @@ -1753,7 +1754,7 @@ \donothing{\OTRSETsetgridcell\mofcolumns\recurselevel\copy\placeholderboxe}}% \egroup}} -\unexpanded\def\page_otr_set_routine +\unexpanded\def\page_set_command_routine {\dontcomplain % new, get rid of overfull message (to be sorted out) \doloop {\OTRSETnaturalflush @@ -1884,11 +1885,10 @@ \mofcolumns\plusone \OTRSETinitializecolumns \OTRSETassignwidths % already done - \OTRSETsethsize + \page_set_command_set_hsize \fi \!!counta#2\!!countb#3\docalculatecolumnsetspan - \expandafter\egroup\expandafter\edef\expandafter - #4\expandafter{\the\!!widtha}} + \expandafter\egroup\expandafter\edef\expandafter#4\expandafter{\the\!!widtha}} % interface to footnotes @@ -2551,7 +2551,7 @@ [\s!page_otr_command_routine =\page_set_command_routine, \s!page_otr_command_package_contents =\page_set_command_package_contents, \s!page_otr_command_set_vsize =\page_set_command_set_vsize, - \s!page_otr_command_set_hsize =\page_set_command_set_hsize, +% \s!page_otr_command_set_hsize =\page_one_command_set_hsize, % tricky, goes wrong \s!page_otr_command_next_page =\page_set_command_next_page, \s!page_otr_command_next_page_and_inserts =\page_set_command_next_page_and_inserts, \s!page_otr_command_synchronize_hsize =\page_set_command_synchronize_hsize, diff --git a/tex/context/base/spac-ali.mkiv b/tex/context/base/spac-ali.mkiv index 1c92def9c..b38fb6ea6 100644 --- a/tex/context/base/spac-ali.mkiv +++ b/tex/context/base/spac-ali.mkiv @@ -547,7 +547,7 @@ \unexpanded\def\usealignparameter#1% faster local variant {\edef\m_spac_align{#1\c!align}% - \ifx\m_spac_align\else + \ifx\m_spac_align\empty\else \expandafter\let\expandafter\raggedcommand\csname\??alignmentnormalcache\m_spac_align\endcsname \ifx\raggedcommand\relax \spac_align_add_to_cache\m_spac_align @@ -615,8 +615,8 @@ \setvalue{\??aligncommand\v!nothanging }{\t_spac_align_collected\expandafter{\the\t_spac_align_collected\font_protruding_disable}} \setvalue{\??aligncommand\v!hz }{\t_spac_align_collected\expandafter{\the\t_spac_align_collected\font_expansion_enable }} \setvalue{\??aligncommand\v!nohz }{\t_spac_align_collected\expandafter{\the\t_spac_align_collected\font_expansion_disable }} -\setvalue{\??aligncommand\v!spacing }{\t_spac_align_collected\expandafter{\the\t_spac_align_collected\enablespacehandling \enablekernhandling }} -\setvalue{\??aligncommand\v!nospacing }{\t_spac_align_collected\expandafter{\the\t_spac_align_collected\disablespacehandling\disablekernhandling}} +%setvalue{\??aligncommand\v!spacing }{\t_spac_align_collected\expandafter{\the\t_spac_align_collected\enablespacehandling \enablekernhandling }} % not in mkiv +%setvalue{\??aligncommand\v!nospacing }{\t_spac_align_collected\expandafter{\the\t_spac_align_collected\disablespacehandling\disablekernhandling}} % not in mkiv \setvalue{\??aligncommand\v!hyphenated }{\t_spac_align_collected\expandafter{\the\t_spac_align_collected\dohyphens}} \setvalue{\??aligncommand\v!nothyphenated }{\t_spac_align_collected\expandafter{\the\t_spac_align_collected\nohyphens}} diff --git a/tex/context/base/status-files.pdf b/tex/context/base/status-files.pdf Binary files differindex 92f846922..e4c854d1d 100644 --- a/tex/context/base/status-files.pdf +++ b/tex/context/base/status-files.pdf diff --git a/tex/context/base/status-lua.pdf b/tex/context/base/status-lua.pdf Binary files differindex baeec7fb3..21a63fa67 100644 --- a/tex/context/base/status-lua.pdf +++ b/tex/context/base/status-lua.pdf diff --git a/tex/context/base/strc-con.mkvi b/tex/context/base/strc-con.mkvi index 0ef2d8b4a..a4df0dc36 100644 --- a/tex/context/base/strc-con.mkvi +++ b/tex/context/base/strc-con.mkvi @@ -212,14 +212,11 @@ \endgroup} \unexpanded\def\strc_constructions_stored_start - {\begingroup - \csname\??constructionstarthandler\currentconstructionhandler\endcsname - } + {\begingroup % brrr \endgroup elsewhere ... will be sorted out + \csname\??constructionstarthandler\currentconstructionhandler\endcsname} \unexpanded\def\strc_constructions_stored_stop - {\csname\??constructionstophandler\currentconstructionhandler\endcsname - %\endgroup % brrr - } + {\csname\??constructionstophandler\currentconstructionhandler\endcsname} \newconstant\c_strc_constructions_nested_state % to be redone @@ -427,7 +424,7 @@ \hangafter-\noflines \else \hangafter-\p_hang - \fi + \fi\fi\fi \relax \hangindent\ifx#1\v!right-\fi\constructionsheadwidth} @@ -750,6 +747,10 @@ \ctxcommand{discardfromlist(\currentconstructionlistentry)}% \fi} +\let\currentconstructionlistnumber \!!zerocount +\let\currentconstructionsynchronize\relax +\let\currentconstructionattribute \attributeunsetvalue + \def\strc_constructions_register_yes[#1][#2]% #1=interfaced-settings, #2=optional user data {\begingroup % similar to structure so we might generalize this \setupcurrentconstruction[#1]% % xdef's will become edef's diff --git a/tex/context/base/strc-flt.mkvi b/tex/context/base/strc-flt.mkvi index 099c6fe5f..fa0a9d960 100644 --- a/tex/context/base/strc-flt.mkvi +++ b/tex/context/base/strc-flt.mkvi @@ -908,19 +908,19 @@ \installcorenamespace{extrafloataction} -\setvalue{\??extrafloataction \v!inner}{\strc_floats_set_extra_action\v!left \v!right} -\setvalue{\??extrafloataction \v!outer}{\strc_floats_set_extra_action\v!right \v!left} -\setvalue{\??extrafloataction\v!innermargin}{\strc_floats_set_extra_action\v!leftmargin \v!rightmargin} -\setvalue{\??extrafloataction\v!outermargin}{\strc_floats_set_extra_action\v!rightmargin\v!leftmargin} -\setvalue{\??extrafloataction \v!inneredge}{\strc_floats_set_extra_action\v!leftedge \v!rightedge} -\setvalue{\??extrafloataction \v!outeredge}{\strc_floats_set_extra_action\v!rightedge \v!leftedge} -\setvalue{\??extrafloataction \v!backspace}{\strc_floats_set_extra_action\v!backspace \v!cutspace} -\setvalue{\??extrafloataction \v!cutspace}{\strc_floats_set_extra_action\v!cutspace \v!backspace} -%setvalue{\??extrafloataction \v!margin}{\strc_floats_set_extra_action\v!cutspace \v!backspace} -\setvalue{\??extrafloataction \v!left}{\strc_floats_set_extra_action\v!left \v!left} -\setvalue{\??extrafloataction \v!right}{\strc_floats_set_extra_action\v!right \v!right} -\setvalue{\??extrafloataction \v!line}{} % only -n*line is handled (see ***) -\setvalue{\??extrafloataction \s!unknown}{\movedownsidefloat[\commalistelement]} +\setvalue{\??extrafloataction \v!inner}#1{\strc_floats_set_extra_action\v!left \v!right} +\setvalue{\??extrafloataction \v!outer}#1{\strc_floats_set_extra_action\v!right \v!left} +\setvalue{\??extrafloataction\v!innermargin}#1{\strc_floats_set_extra_action\v!leftmargin \v!rightmargin} +\setvalue{\??extrafloataction\v!outermargin}#1{\strc_floats_set_extra_action\v!rightmargin\v!leftmargin} +\setvalue{\??extrafloataction \v!inneredge}#1{\strc_floats_set_extra_action\v!leftedge \v!rightedge} +\setvalue{\??extrafloataction \v!outeredge}#1{\strc_floats_set_extra_action\v!rightedge \v!leftedge} +\setvalue{\??extrafloataction \v!backspace}#1{\strc_floats_set_extra_action\v!backspace \v!cutspace} +\setvalue{\??extrafloataction \v!cutspace}#1{\strc_floats_set_extra_action\v!cutspace \v!backspace} +%setvalue{\??extrafloataction \v!margin}#1{\strc_floats_set_extra_action\v!cutspace \v!backspace} +\setvalue{\??extrafloataction \v!left}#1{\strc_floats_set_extra_action\v!left \v!left} +\setvalue{\??extrafloataction \v!right}#1{\strc_floats_set_extra_action\v!right \v!right} +\setvalue{\??extrafloataction \v!line}#1{} % only -n*line is handled (see ***) +\setvalue{\??extrafloataction \s!unknown}#1{\movedownsidefloat[#1]} \def\strc_floats_check_extra_actions % less tracingthis way ... {\doifnotinset\v!text\floatlocation % fuzzy, text overloads left, since then it's a directive @@ -934,8 +934,8 @@ \def\strc_floats_check_extra_actions_step#step% {\csname\??extrafloataction - \ifcsname\??extrafloataction#1\endcsname#step\else\s!unknown\fi - \endcsname} + \ifcsname\??extrafloataction#step\endcsname#step\else\s!unknown\fi + \endcsname{#step}} % pas op, maxbreedte niet instellen als plaats=links/rechts diff --git a/tex/context/base/strc-ini.lua b/tex/context/base/strc-ini.lua index 923d35f6d..8644c87e3 100644 --- a/tex/context/base/strc-ini.lua +++ b/tex/context/base/strc-ini.lua @@ -115,10 +115,23 @@ end local helpers = structures.helpers -function helpers.touserdata(str) - local hash = str and str ~= "" and settings_to_hash(str) - if hash and next(hash) then - return hash +-- function helpers.touserdata(str) +-- local hash = str and str ~= "" and settings_to_hash(str) +-- if hash and next(hash) then +-- return hash +-- end +-- end + +function helpers.touserdata(data) + if type(data) == "string" then + if data == "" then + return nil + else + data = settings_to_hash(data) + end + end + if data and next(data) then + return data end end diff --git a/tex/context/base/strc-lst.lua b/tex/context/base/strc-lst.lua index 734ca3f7e..25d046f4f 100644 --- a/tex/context/base/strc-lst.lua +++ b/tex/context/base/strc-lst.lua @@ -116,6 +116,10 @@ end job.register('structures.lists.collected', tobesaved, initializer) function lists.addto(t) + local u = t.userdata + if u and type(u) == "string" then + t.userdata = helpers.touserdata(u) -- nicer at the tex end + end local m = t.metadata local r = t.references local i = (r and r.internal) or 0 -- brrr @@ -131,10 +135,6 @@ function lists.addto(t) if setcomponent then setcomponent(t) -- might move to the tex end end - local u = t.userdata - if u and type(u) == "string" then - t.userdata = helpers.touserdata(u) -- nicer at the tex end - end return p end diff --git a/tex/context/base/strc-lst.mkvi b/tex/context/base/strc-lst.mkvi index aa3da63e8..a814bdae4 100644 --- a/tex/context/base/strc-lst.mkvi +++ b/tex/context/base/strc-lst.mkvi @@ -65,10 +65,9 @@ \c!numbercommand=\firstofoneargument, \c!textcommand=\firstofoneargument, \c!pagecommand=\firstofoneargument, - \c!pagenumber=\v!yes, - \c!headnumber=\v!yes, % old (keep for a while) -% \c!headnumber=\v!yes, % old (keep for a while) -% \c!sectionnumber=\listparameter\c!headnumber, % use this instead + \c!pagenumber=\v!yes, % better: 'first' + \c!headnumber=\v!yes, % better: 'second' +% \c!sectionnumber=\listparameter\c!headnumber, % use this instead \c!interaction=\v!all, % was \v!sectionnumber, % or make this headnumber (or accept both) \c!label=\v!no, %\c!extras=, @@ -196,10 +195,10 @@ \doifelse{\namedlistparameter{#tag}\c!state}\v!start\strc_lists_write_to_yes\strc_lists_write_to_nop} \def\strc_lists_write_to_nop[#settings]#first#second% - {} + {\endgroup} % \strc_lists_inject_nop[][] \def\strc_lists_write_to_yes[#settings]#first#second% - {\strc_lists_inject[\c!location=\v!here,#settings,\c!type=\s!simple][\s!first={#first},\s!second={#second}]} + {\strc_lists_inject_yes[\c!location=\v!here,#settings,\c!type=\s!simple][\s!first={#first},\s!second={#second}]} %D When placing a list either one or a set can be giving. This makes %D it possible to flush for instance an nested (or merged) table of @@ -715,6 +714,8 @@ \newconditional\c_lists_has_number \newconditional\c_lists_has_page +\newconditional\c_lists_show_number +\newconditional\c_lists_show_page \let\currentlistentrylocation \empty % watch the 'entry' in the name \let\currentlistentrynumber \empty % watch the 'entry' in the name @@ -742,8 +743,31 @@ % because these tests happen often and because we're dealing with % rather complex composed data we have special conditionals; keep % in mind that testing for empty fails do to tagging being applied - \doifstructurelisthaspageelse \settrue\setfalse\c_lists_has_page - \doifstructurelisthasnumberelse\settrue\setfalse\c_lists_has_number + \edef\p_pagenumber{\listparameter\c!pagenumber}% + \ifx\p_pagenumber\v!always + \settrue\c_lists_has_page + \settrue\c_lists_show_page + \else + \doifstructurelisthaspageelse\settrue\setfalse\c_lists_has_page + \ifx\p_pagenumber\v!yes + \settrue\c_lists_show_page + \else + \setfalse\c_lists_show_page + \fi + \fi + % always forces number placement (in bib we use a forced number) + \edef\p_headnumber{\listparameter\c!headnumber}% + \ifx\p_headnumber\v!always + \settrue\c_lists_has_number + \settrue\c_lists_show_number + \else + \doifstructurelisthasnumberelse\settrue\setfalse\c_lists_has_number + \ifx\p_headnumber\v!yes + \settrue\c_lists_show_number + \else + \setfalse\c_lists_show_number + \fi + \fi \to \t_lists_every_renderingsetup \appendtoks @@ -759,6 +783,8 @@ \let\currentlistentrypagenumber\empty \setfalse\c_lists_has_page \setfalse\c_lists_has_number + \setfalse\c_lists_show_page + \setfalse\c_lists_show_number \to \t_lists_every_renderingcleanup \unexpanded\def\strc_lists_apply_renderingsetup @@ -800,8 +826,7 @@ \vbox { \forgetall \hbox \strc_lists_get_reference_attribute\v!all { - \edef\p_headnumber{\listparameter\c!headnumber} - \ifx\p_headnumber\v!yes + \ifconditional\c_lists_show_number % \ifconditional\c_lists_has_page \hbox \strc_lists_get_reference_attribute\v!number { \strc_lists_set_style_color\c!numberstyle\c!numbercolor\v!number @@ -814,8 +839,7 @@ \the\t_lists_every_renderingtext \listparameter\c!textcommand\currentlistentrytitle } - \edef\p_pagenumber{\listparameter\c!pagenumber} - \ifx\p_pagenumber\v!yes + \ifconditional\c_lists_show_page \ifconditional\c_lists_has_page \hbox \strc_lists_get_reference_attribute\v!pagenumber { \strc_lists_set_style_color\c!pagestyle\c!pagecolor\v!pagenumber @@ -864,9 +888,8 @@ \forgetall \strc_lists_set_style_color\c!style\c!color\v!all \scratchhsize\hsize - \edef\p_headnumber{\listparameter\c!headnumber} \ifconditional\c_lists_has_number - \ifx\p_headnumber\v!yes + \ifconditional\c_lists_show_number \setbox\b_strc_lists_number\hbox \strc_lists_get_reference_attribute\v!number \ifdim\scratchwidth>\zeropoint to \scratchwidth \fi { \strc_lists_set_style_color\c!numberstyle\c!numbercolor\v!number \listparameter\c!numbercommand\currentlistsymbol @@ -881,8 +904,7 @@ \setbox\b_strc_lists_number\emptyhbox \fi \ifconditional\c_lists_has_page - \edef\p_pagenumber{\listparameter\c!pagenumber} - \ifx\p_pagenumber\v!yes + \ifconditional\c_lists_show_page \setbox\b_strc_lists_page\hbox { \scratchdimen\listalternativeparameter\c!width \hbox \strc_lists_get_reference_attribute\v!pagenumber \ifdim\scratchdimen>\zeropoint to \scratchdimen\fi { @@ -986,8 +1008,7 @@ \strc_lists_set_style_color\c!style\c!color\v!all \strc_lists_get_destination_attribute \begingroup - \edef\p_headnumber{\listparameter\c!headnumber} - \ifx\p_headnumber\v!yes + \ifconditional\c_lists_show_number \donetrue \ifconditional\c_lists_has_number \else \edef\p_symbol{\listparameter\c!symbol} @@ -1019,8 +1040,7 @@ \endgroup \begingroup \ifconditional\c_lists_has_page - \edef\p_pagenumber{\listparameter\c!pagenumber} - \ifx\p_pagenumber\v!yes + \ifconditional\c_lists_show_page \nobreak \hskip.75em\relax \nobreak diff --git a/tex/context/base/strc-not.mkvi b/tex/context/base/strc-not.mkvi index 0a1ede550..4bfcc291d 100644 --- a/tex/context/base/strc-not.mkvi +++ b/tex/context/base/strc-not.mkvi @@ -184,7 +184,7 @@ \iftrialtypesetting \strc_counters_save\currentconstructionnumber \fi - \strc_counters_increment_sub\currentconstructionnumber\currentconstructionlevel +% \strc_counters_increment_sub\currentconstructionnumber\currentconstructionlevel \else \setfalse\c_strc_constructions_number_state \fi @@ -219,6 +219,7 @@ \unexpanded\def\strc_notations_command#1% {\begingroup \strc_constructions_initialize{#1}% + \strc_counters_increment_sub\currentconstructionnumber\currentconstructionlevel \doifnextoptionalelse\strc_notations_command_yes\strc_notations_command_nop} \unexpanded\def\strc_notations_command_nop#1% @@ -242,6 +243,7 @@ \unexpanded\def\strc_notations_start#1#2% {\begingroup \strc_constructions_initialize{#1}% + \strc_counters_increment_sub\currentconstructionnumber\currentconstructionlevel \normalexpanded % not that efficient but also not that frequently used {\def\noexpand\strc_pickup_yes[##1]##2\csname\e!stop#2\endcsname{\strc_notations_command_yes[##1]{##2}}% \def\noexpand\strc_pickup_nop ##1\csname\e!stop#2\endcsname{\strc_notations_command_nop {##1}}}% @@ -1017,9 +1019,10 @@ \unexpanded\def\setnote [#1]{\getvalue{#1}} \unexpanded\def\setnotetext[#1]{\global\settrue\c_strc_notes_skip\getvalue{#1}} -\def\handlenoteinsert#1#2% tg, id +\unexpanded\def\handlenoteinsert#1#2% tg, id {\begingroup \edef\currentnote{#1}% + \strc_constructions_initialize{#1}% \the\everybeforenoteinsert \insert\currentnoteins\bgroup \the\everyinsidenoteinsert\relax @@ -1035,13 +1038,14 @@ \the\everyafternoteinsert \endgroup} -\def\betweennoteitself#1% tg +\unexpanded\def\betweennoteitself#1% tg {\edef\currentnote{#1}% \doif{\noteparameter\c!paragraph}\v!yes\strc_notes_between_paragraphs} -\def\handlenoteitself#1#2% tg, id +\unexpanded\def\handlenoteitself#1#2% tg, id {\edef\currentnote{#1}% \edef\currentnotenumber{#2}% + \strc_constructions_initialize{#1}% not needed when called in handlenoteinsert \edef\currentconstructionlistentry{\ctxlua{tex.write(structures.notes.listindex("#1",#2))}}% index in list cache % as we can have collected notes (e.g. in tables) we need to recover % \currentdescriptionattribute and \currentdescriptionsynchronize diff --git a/tex/context/base/syst-aux.mkiv b/tex/context/base/syst-aux.mkiv index 08c7166a2..5f00960e0 100644 --- a/tex/context/base/syst-aux.mkiv +++ b/tex/context/base/syst-aux.mkiv @@ -3012,7 +3012,7 @@ %D Apart from the prefixes, a few more \type{\expandafters} %D are needed: -\def\newif#1% +\unexpanded\def\newif#1% {\scratchcounter\escapechar \escapechar\minusone \expandafter\expandafter\expandafter @@ -3029,16 +3029,16 @@ \unexpanded\def\define#1% {\ifdefined#1% \message{[\noexpand#1is already defined]}% - \expandafter\def\expandafter\gobbleddefinition + \unexpanded\expandafter\def\expandafter\gobbleddefinition \else - \expandafter\def + \unexpanded\expandafter\def \fi#1} \def\redefine#1% {\ifdefined#1% \message{[\noexpand#1is redefined]}% \fi - \def#1} + \unexpanded\def#1} % \define\hans{hans} % \redefine\hans{hans} diff --git a/tex/context/base/tabl-tbl.mkiv b/tex/context/base/tabl-tbl.mkiv index 6e2178f39..ee2adb733 100644 --- a/tex/context/base/tabl-tbl.mkiv +++ b/tex/context/base/tabl-tbl.mkiv @@ -420,6 +420,9 @@ \fi \fi\fi} +\let\tabl_tabulate_hook_b\donothing +\let\tabl_tabulate_hook_e\donothing + \def\tabl_tabulate_set_preamble_step#1#2% only makes sense for many tabulates {\normalexpanded{\t_tabl_tabulate_preamble{\the\t_tabl_tabulate_preamble \tabl_tabulate_check_local_vrule_thickness\constantdimenargument\d_tabl_tabulate_vrulethickness @@ -452,6 +455,7 @@ \bgroup \tabl_tabulate_bbskip \bgroup % we cannot combine the if because a cell may have only one ## +\tabl_tabulate_hook_b \c_tabl_tabulate_align\constantnumber\c_tabl_tabulate_align % needed in tag passing \noexpand\dostarttagged\noexpand\t!tabulatecell\noexpand\empty \noexpand\dotagtabulatecell @@ -481,6 +485,7 @@ \tabl_tabulate_shaped_par_end \fi \noexpand#2% +\tabl_tabulate_hook_e \egroup \egroup \aligntab @@ -1065,7 +1070,7 @@ \fi \lettabulationparameter\c!format\p_format \ifsecondargument - \getcurrenttabulationparameters[#2]% + \setupcurrenttabulation[#2]% \fi \tabl_tabulate_start_building} @@ -1923,9 +1928,27 @@ % \glet\tabl_tabulate_flush_collected\empty \ifdim\d_tabl_tabulate_margin>\zeropoint - \t_tabl_tabulate_preamble{\aligntab\tabl_tabulate_flush_indent\strut\alignmark\alignmark\tabskip\d_tabl_tabulate_margin\strut\aligntab\alignmark\alignmark\tabskip\zeropoint}% + \t_tabl_tabulate_preamble + {\aligntab + \tabl_tabulate_flush_indent +% \global\advance\c_tabl_tabulate_noflines\plusone + \strut + \alignmark\alignmark + \tabskip\d_tabl_tabulate_margin + \strut + \aligntab + \alignmark\alignmark + \tabskip\zeropoint}% \else - \t_tabl_tabulate_preamble{\aligntab\tabl_tabulate_flush_indent\strut\alignmark\alignmark\aligntab\alignmark\alignmark\tabskip\zeropoint}% + \t_tabl_tabulate_preamble + {\aligntab + \tabl_tabulate_flush_indent +% \global\advance\c_tabl_tabulate_noflines\plusone + \strut + \alignmark\alignmark + \aligntab + \alignmark\alignmark + \tabskip\zeropoint}% \fi \d_tabl_tabulate_width\zeropoint % these counters are set at the lua end @@ -2208,11 +2231,4 @@ % \NC \digits $@@@.@@1,@@$ \NC\NR % \stoptabulatie -% we don't register the paragraph characteristics, only the -% width - -\appendtoks - \setinnerparpositions % see "techniek" for application -\to \everytabulate - \protect \endinput diff --git a/tex/context/base/type-imp-texgyre.mkiv b/tex/context/base/type-imp-texgyre.mkiv index ef487f262..c2e06ae29 100644 --- a/tex/context/base/type-imp-texgyre.mkiv +++ b/tex/context/base/type-imp-texgyre.mkiv @@ -16,72 +16,6 @@ \starttypescriptcollection[texgyre] - % caps: \definetypeface [pagella] [rm] [serif] [pagella-caps] [default] - - \starttypescript [times,termes] - \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] - \definetypeface [\typescriptone] [\s!ss] [\s!sans] [helvetica] [\s!default] [\s!rscale=0.9] - \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.05] - \definetypeface [\typescriptone] [\s!mm] [\s!math] [times] [\s!default] - \quittypescriptscanning - \stoptypescript - - \starttypescript [palatino,pagella] - \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] - \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] [\s!rscale=1.075] - \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.075] - \definetypeface [\typescriptone] [\s!mm] [\s!math] [palatino] [\s!default] - \quittypescriptscanning - \stoptypescript - - \starttypescript [schoolbook,schola] - \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] - \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] [\s!rscale=1.1] - \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.1] - \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] [\s!rscale=1.1] - \quittypescriptscanning - \stoptypescript - - \starttypescript [bookman,bonum] - \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] - \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] [\s!rscale=1.1] - \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.1] - \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] [\s!rscale=1.1] - \quittypescriptscanning - \stoptypescript - - \starttypescript [chancery,chorus] - \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] - \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] - \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] - \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] - \quittypescriptscanning - \stoptypescript - - \starttypescript [helvetica,heros] - \definetypeface [\typescriptone] [\s!ss] [\s!sans] [\typescriptone] [\s!default] - \definetypeface [\typescriptone] [\s!rm] [\s!serif] [modern] [\s!default] [\s!rscale=1.15] - \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.15] - \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] [\s!rscale=1.15] - \quittypescriptscanning - \stoptypescript - - \starttypescript [avantgarde,adventor] - \definetypeface [\typescriptone] [\s!ss] [\s!sans] [adventor] [\s!default] - \definetypeface [\typescriptone] [\s!rm] [\s!serif] [modern] [\s!default] [\s!rscale=1.15] - \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.15] - \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] - \quittypescriptscanning - \stoptypescript - - \starttypescript [courier,cursor] - \definetypeface [\typescriptone] [\s!tt] [\s!mono] [\typescriptone] [\s!default] - \definetypeface [\typescriptone] [\s!rm] [\s!serif] [modern] [\s!default] - \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] - \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] - \quittypescriptscanning - \stoptypescript - \definetypescriptprefix [f:pagella] [pagella] \definetypescriptprefix [f:palatino] [pagella] \definetypescriptprefix [f:termes] [termes] \definetypescriptprefix [f:times] [termes] \definetypescriptprefix [f:heros] [heros] \definetypescriptprefix [f:helvetica] [heros] @@ -91,7 +25,7 @@ \definetypescriptprefix [f:cursor] [cursor] \definetypescriptprefix [f:courier] [cursor] \definetypescriptprefix [f:chorus] [chorus] \definetypescriptprefix [f:chancery] [chorus] - \starttypescript [serif,sans] [adventor,bonum,bookman,heros,helvetica,pagella,palatino,schola,schoolbook,termes,times] + \starttypescript [\s!serif,\s!sans] [adventor,bonum,bookman,heros,helvetica,pagella,palatino,schola,schoolbook,termes,times] \definefontsynonym [\typescriptprefix{n:\typescripttwo}-Regular] [\s!file:texgyre\typescriptprefix{f:\typescripttwo}-regular] [\s!features=\s!default] \definefontsynonym [\typescriptprefix{n:\typescripttwo}-Italic] [\s!file:texgyre\typescriptprefix{f:\typescripttwo}-italic] [\s!features=\s!default] \definefontsynonym [\typescriptprefix{n:\typescripttwo}-Bold] [\s!file:texgyre\typescriptprefix{f:\typescripttwo}-bold] [\s!features=\s!default] @@ -193,6 +127,74 @@ \definefontsynonym [\s!MonoBoldSlanted] [\s!MonoBoldItalic] \stoptypescript + % interesting is that we cannot move these definitions up (without loosing features) + + % caps: \definetypeface [pagella] [rm] [serif] [pagella-caps] [default] + + \starttypescript [times,termes] + \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] + \definetypeface [\typescriptone] [\s!ss] [\s!sans] [helvetica] [\s!default] [\s!rscale=0.9] + \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.05] + \definetypeface [\typescriptone] [\s!mm] [\s!math] [times] [\s!default] + \quittypescriptscanning + \stoptypescript + + \starttypescript [palatino,pagella] + \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] + \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] [\s!rscale=1.075] + \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.075] + \definetypeface [\typescriptone] [\s!mm] [\s!math] [palatino] [\s!default] + \quittypescriptscanning + \stoptypescript + + \starttypescript [schoolbook,schola] + \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] + \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] [\s!rscale=1.1] + \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.1] + \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] [\s!rscale=1.1] + \quittypescriptscanning + \stoptypescript + + \starttypescript [bookman,bonum] + \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] + \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] [\s!rscale=1.1] + \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.1] + \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] [\s!rscale=1.1] + \quittypescriptscanning + \stoptypescript + + \starttypescript [chancery,chorus] + \definetypeface [\typescriptone] [\s!rm] [\s!serif] [\typescriptone] [\s!default] + \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] + \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] + \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] + \quittypescriptscanning + \stoptypescript + + \starttypescript [helvetica,heros] + \definetypeface [\typescriptone] [\s!ss] [\s!sans] [\typescriptone] [\s!default] + \definetypeface [\typescriptone] [\s!rm] [\s!serif] [modern] [\s!default] [\s!rscale=1.15] + \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.15] + \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] [\s!rscale=1.15] + \quittypescriptscanning + \stoptypescript + + \starttypescript [avantgarde,adventor] + \definetypeface [\typescriptone] [\s!ss] [\s!sans] [adventor] [\s!default] + \definetypeface [\typescriptone] [\s!rm] [\s!serif] [modern] [\s!default] [\s!rscale=1.15] + \definetypeface [\typescriptone] [\s!tt] [\s!mono] [modern] [\s!default] [\s!rscale=1.15] + \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] + \quittypescriptscanning + \stoptypescript + + \starttypescript [courier,cursor] + \definetypeface [\typescriptone] [\s!tt] [\s!mono] [\typescriptone] [\s!default] + \definetypeface [\typescriptone] [\s!rm] [\s!serif] [modern] [\s!default] + \definetypeface [\typescriptone] [\s!ss] [\s!sans] [modern] [\s!default] + \definetypeface [\typescriptone] [\s!mm] [\s!math] [modern] [\s!default] + \quittypescriptscanning + \stoptypescript + \stoptypescriptcollection \starttypescriptcollection[xmath] diff --git a/tex/context/base/typo-cap.mkiv b/tex/context/base/typo-cap.mkiv index 713beaa31..c18315960 100644 --- a/tex/context/base/typo-cap.mkiv +++ b/tex/context/base/typo-cap.mkiv @@ -135,6 +135,8 @@ \usepseudocaps % we use char0 as placeholder for the larger font +% +% here we keep the \groupedcommand \unexpanded\def\pseudosmallcapped{\groupedcommand{\setcharactercasing[1]\signalcharacter\tx}{}} % all upper \unexpanded\def\pseudoSmallcapped{\groupedcommand{\setcharactercasing[5]\signalcharacter\tx}{}} % one upper + font diff --git a/tex/generic/context/luatex/luatex-fonts-merged.lua b/tex/generic/context/luatex/luatex-fonts-merged.lua index 5ea4b6bc2..db5941f2f 100644 --- a/tex/generic/context/luatex/luatex-fonts-merged.lua +++ b/tex/generic/context/luatex/luatex-fonts-merged.lua @@ -1,6 +1,6 @@ -- merged file : luatex-fonts-merged.lua -- parent file : luatex-fonts.lua --- merge date : 02/08/12 21:58:28 +-- merge date : 02/16/12 09:55:05 do -- begin closure to overcome local limits and interference |