summaryrefslogtreecommitdiff
path: root/tex
diff options
context:
space:
mode:
authorContext Git Mirror Bot <phg42.2a@gmail.com>2015-03-25 23:15:05 +0100
committerContext Git Mirror Bot <phg42.2a@gmail.com>2015-03-25 23:15:05 +0100
commit41d38174b1d78e7f96dcb94434bf58d10ad08c1a (patch)
tree77e9d05fe143f7ef7e466ec88f00f3548b1bae48 /tex
parent51ca6df7d66393551bdf02032b990144e94c497b (diff)
downloadcontext-41d38174b1d78e7f96dcb94434bf58d10ad08c1a.tar.gz
2015-03-25 22:16:00
Diffstat (limited to 'tex')
-rw-r--r--tex/context/base/anch-bck.mkvi6
-rw-r--r--tex/context/base/anch-pgr.lua3
-rw-r--r--tex/context/base/anch-pos.lua10
-rw-r--r--tex/context/base/back-exp.lua9
-rw-r--r--tex/context/base/back-pdf.lua10
-rw-r--r--tex/context/base/buff-ver.mkiv26
-rw-r--r--tex/context/base/catc-ini.mkiv25
-rw-r--r--tex/context/base/char-ini.lua7
-rw-r--r--tex/context/base/char-ini.mkiv35
-rw-r--r--tex/context/base/char-tex.lua159
-rw-r--r--tex/context/base/char-utf.lua24
-rw-r--r--tex/context/base/cldf-bas.lua24
-rw-r--r--tex/context/base/cldf-ini.lua4
-rw-r--r--tex/context/base/cldf-scn.lua100
-rw-r--r--tex/context/base/cont-new.mkiv2
-rw-r--r--tex/context/base/context-version.pdfbin4384 -> 4343 bytes
-rw-r--r--tex/context/base/context.mkiv13
-rw-r--r--tex/context/base/file-job.mkvi4
-rw-r--r--tex/context/base/file-res.lua2
-rw-r--r--tex/context/base/font-chk.lua16
-rw-r--r--tex/context/base/font-ctx.lua11
-rw-r--r--tex/context/base/font-map.lua4
-rw-r--r--tex/context/base/grph-inc.lua2
-rw-r--r--tex/context/base/l-lpeg.lua198
-rw-r--r--tex/context/base/lang-hyp.lua120
-rw-r--r--tex/context/base/lang-ini.lua20
-rw-r--r--tex/context/base/lang-ini.mkiv4
-rw-r--r--tex/context/base/lpdf-ano.lua2
-rw-r--r--tex/context/base/lpdf-xmp.lua2
-rw-r--r--tex/context/base/luat-cnf.lua3
-rw-r--r--tex/context/base/luat-ini.mkiv50
-rw-r--r--tex/context/base/lxml-ini.lua131
-rw-r--r--tex/context/base/lxml-ini.mkiv4
-rw-r--r--tex/context/base/m-hemistich.mkiv8
-rw-r--r--tex/context/base/m-translate.mkiv31
-rw-r--r--tex/context/base/mlib-run.lua39
-rw-r--r--tex/context/base/mult-aux.mkiv20
-rw-r--r--tex/context/base/mult-mps.lua2
-rw-r--r--tex/context/base/page-brk.mkiv2
-rw-r--r--tex/context/base/publ-dat.lua146
-rw-r--r--tex/context/base/publ-fnd.lua107
-rw-r--r--tex/context/base/publ-imp-apa.lua3
-rw-r--r--tex/context/base/publ-imp-apa.mkvi216
-rw-r--r--tex/context/base/publ-imp-aps.lua149
-rw-r--r--tex/context/base/publ-imp-aps.mkvi1382
-rw-r--r--tex/context/base/publ-imp-author.mkvi82
-rw-r--r--tex/context/base/publ-imp-cite.mkvi42
-rw-r--r--tex/context/base/publ-imp-default.mkvi85
-rw-r--r--tex/context/base/publ-imp-list.mkvi13
-rw-r--r--tex/context/base/publ-ini.lua299
-rw-r--r--tex/context/base/publ-ini.mkiv231
-rw-r--r--tex/context/base/publ-reg.lua37
-rw-r--r--tex/context/base/s-inf-03.mkiv19
-rw-r--r--tex/context/base/s-math-repertoire.mkiv5
-rw-r--r--tex/context/base/scrn-pag.mkvi45
-rw-r--r--tex/context/base/spac-ver.mkiv14
-rw-r--r--tex/context/base/status-files.pdfbin24671 -> 24641 bytes
-rw-r--r--tex/context/base/status-lua.pdfbin343152 -> 398039 bytes
-rw-r--r--tex/context/base/status-mkiv.lua10
-rw-r--r--tex/context/base/strc-doc.lua15
-rw-r--r--tex/context/base/strc-not.mkvi8
-rw-r--r--tex/context/base/strc-num.lua9
-rw-r--r--tex/context/base/strc-reg.mkiv2
-rw-r--r--tex/context/base/supp-box.mkiv4
-rw-r--r--tex/context/base/syst-aux.lua53
-rw-r--r--tex/context/base/syst-aux.mkiv44
-rw-r--r--tex/context/base/syst-ini.mkiv17
-rw-r--r--tex/context/base/syst-lua.lua9
-rw-r--r--tex/context/base/toks-ini.lua97
-rw-r--r--tex/context/base/toks-ini.mkiv2
-rw-r--r--tex/context/base/toks-scn.lua378
-rw-r--r--tex/context/base/type-imp-dejavu.mkiv63
-rw-r--r--tex/context/base/typo-del.mkiv2
-rw-r--r--tex/context/base/typo-itc.lua76
-rw-r--r--tex/context/base/util-seq.lua32
-rw-r--r--tex/context/base/x-set-11.mkiv14
-rw-r--r--tex/context/base/x-xtag.mkiv2
-rw-r--r--tex/generic/context/luatex/luatex-fonts-merged.lua90
78 files changed, 3260 insertions, 1674 deletions
diff --git a/tex/context/base/anch-bck.mkvi b/tex/context/base/anch-bck.mkvi
index 273cf0159..cccf14ee4 100644
--- a/tex/context/base/anch-bck.mkvi
+++ b/tex/context/base/anch-bck.mkvi
@@ -20,6 +20,10 @@
\unprotect
+% we can flush 5 in one call (saved 4 lua calls) .. brrr wself .. will change
+
+\def\MPposset#1{\ctxcommand{MPposset("#1")}} % will go
+
% This might be overloaded later on:
% \defineoverlay[\v!text-2][\positionoverlay{\v!text-2}]
@@ -46,7 +50,7 @@
% tricky: we need to catch newly set! otherwise an old run can have positions
\unexpanded\def\anch_backgrounds_text_initialize
- {\doifelsepositionsused\enableparpositions\donothing
+ {\ctxcommand{doifelsepositionsused()}\enableparpositions\donothing
\global\let\anch_backgrounds_text_initialize\relax}
\appendtoks
diff --git a/tex/context/base/anch-pgr.lua b/tex/context/base/anch-pgr.lua
index 198e8a499..84d0f6939 100644
--- a/tex/context/base/anch-pgr.lua
+++ b/tex/context/base/anch-pgr.lua
@@ -19,9 +19,6 @@ local lpegmatch = lpeg.match
local jobpositions = job.positions
local formatters = string.formatters
-local scanstring = tokens.scanstring
-local scannumber = tokens.scannumber
-local scandimen = tokens.scandimen
local report_graphics = logs.reporter("graphics")
diff --git a/tex/context/base/anch-pos.lua b/tex/context/base/anch-pos.lua
index fc7e24b96..1f366121d 100644
--- a/tex/context/base/anch-pos.lua
+++ b/tex/context/base/anch-pos.lua
@@ -21,8 +21,6 @@ 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 commands, context = commands, context
-
local tostring, next, rawget, setmetatable = tostring, next, rawget, setmetatable
local sort = table.sort
local format, gmatch, match = string.format, string.gmatch, string.match
@@ -30,12 +28,16 @@ local rawget = rawget
local lpegmatch = lpeg.match
local insert, remove = table.insert, table.remove
local allocate, mark = utilities.storage.allocate, utilities.storage.mark
-local texsp = tex.sp
------ texsp = string.todimen -- because we cache this is much faster but no rounding
+local commands = commands
+local context = context
+
+local tex = tex
local texgetcount = tex.getcount
local texsetcount = tex.setcount
local texget = tex.get
+local texsp = tex.sp
+----- texsp = string.todimen -- because we cache this is much faster but no rounding
local pdf = pdf -- h and v are variables
diff --git a/tex/context/base/back-exp.lua b/tex/context/base/back-exp.lua
index d4c252384..70ed78282 100644
--- a/tex/context/base/back-exp.lua
+++ b/tex/context/base/back-exp.lua
@@ -143,6 +143,9 @@ local locatedtag = structurestags.locatedtag
local starttiming = statistics.starttiming
local stoptiming = statistics.stoptiming
+local characterdata = characters.data
+local overloads = fonts.mappings.overloads
+
-- todo: more locals (and optimize)
local exportversion = "0.33"
@@ -2442,11 +2445,11 @@ local function collectresults(head,list,pat,pap) -- is last used (we also have c
-- report_export("skipping character: %C (no attribute)",n.char)
else
-- we could add tonunicodes for ligatures (todo)
- local components = getfield(n,"components")
- if components then -- we loose data
+ local components = getfield(n,"components")
+ local c = getchar(n)
+ if components and (not characterdata[c] or overloads[c]) then -- we loose data
collectresults(components,nil,at) -- this assumes that components have the same attribute as the glyph ... we should be more tolerant (see math)
else
- local c = getchar(n)
if last ~= at then
local tl = taglist[at]
pushcontent()
diff --git a/tex/context/base/back-pdf.lua b/tex/context/base/back-pdf.lua
index f7f995f39..2d6370811 100644
--- a/tex/context/base/back-pdf.lua
+++ b/tex/context/base/back-pdf.lua
@@ -6,8 +6,13 @@ if not modules then modules = { } end modules ['back-pdf'] = {
license = "see context related readme files"
}
+
+local tonumber = tonumber
+local sind, cosd = math.sind, math.cosd
+local insert, remove = table.insert, table.remove
local codeinjections = backends.pdf.codeinjections
+local context = context
local outputfilename
function codeinjections.getoutputfilename()
@@ -19,11 +24,6 @@ end
backends.install("pdf")
-local context = context
-
-local sind, cosd = math.sind, math.cosd
-local insert, remove = table.insert, table.remove
-
local f_matrix = string.formatters["%F %F %F %F"] -- 0.8 is default
function commands.pdfrotation(a)
diff --git a/tex/context/base/buff-ver.mkiv b/tex/context/base/buff-ver.mkiv
index 1e5a9e690..9e0244eca 100644
--- a/tex/context/base/buff-ver.mkiv
+++ b/tex/context/base/buff-ver.mkiv
@@ -75,7 +75,12 @@
\def\buff_verbatim_initialize_type_one
{\let\obeylines\ignorelines
- \usetypestyleandcolor\c!style\c!color
+ \edef\p_buff_option{\typeparameter\c!option}%
+ \ifx\p_buff_option\v!none
+ \usetypestyleandcolor\c!style\c!color
+ \else\ifx\p_buff_option\empty
+ \usetypestyleandcolor\c!style\c!color
+ \fi\fi
\setcatcodetable\vrbcatcodes}
\def\buff_verbatim_initialize_type_two
@@ -114,7 +119,12 @@
\ifx\buff_verbatim_set_line_margin\relax
\doadaptleftskip{\typingparameter\c!margin}%
\fi
- \usetypingstyleandcolor\c!style\c!color
+ \edef\p_buff_option{\typingparameter\c!option}%
+ \ifx\p_buff_option\v!none
+ \usetypingstyleandcolor\c!style\c!color
+ \else\ifx\p_buff_option\empty
+ \usetypingstyleandcolor\c!style\c!color
+ \fi\fi
% will become: \usealignparameter\typingparameter
\doifsomething{\typingparameter\c!align}{\setupalign[\typingparameter\c!align]}} % use fast one
@@ -330,7 +340,7 @@
\ctxcommand{typestring{
data = \!!bs\detokenize{#1}\!!es,
tab = "\typeparameter\c!tab",
- method = "\typeparameter\c!option",
+ method = "\p_buff_option",
nature = "inline",
compact = "\typeparameter\c!compact", % none | all | last (all needed in tabulate etc for manuals)
escape = \!!bs\typeparameter\c!escape\!!es, % new but rather useless imo (escaping in general is not used much)
@@ -346,7 +356,7 @@
data = \!!bs\detokenize{#1}\!!es,
tab = "\typeparameter\c!tab",
method = "nested", % we force a special visualizer
- option = "\typeparameter\c!option", % extra visualizer (maybe: nested,\typeparameter\c!option)
+ option = "\p_buff_option", % extra visualizer (maybe: nested,\typeparameter\c!option)
nature = "inline",
}}%
\dostoptagged
@@ -515,7 +525,7 @@
strip = "\typingparameter\c!strip",
range = "\typingparameter\c!range",
tab = "\typingparameter\c!tab",
- method = "\typingparameter\c!option",
+ method = "\p_buff_option",
escape = \!!bs\typingparameter\c!escape\!!es,
nature = "display",
}}%
@@ -635,7 +645,7 @@
range = "\typingparameter\c!range",
regime = "\currentregime",
tab = "\typingparameter\c!tab",
- method = "\typingparameter\c!option",
+ method = "\p_buff_option",
nature = "display",
}}%
\dostoptagged
@@ -808,7 +818,7 @@
range = "\typingparameter\c!range",
regime = "\currentregime",
tab = "\typingparameter\c!tab",
- method = "\typingparameter\c!option",
+ method = "\p_buff_option",
escape = \!!bs\typingparameter\c!escape\!!es,
nature = "display",
}}%
@@ -850,7 +860,7 @@
name = "#2",
strip = "\typingparameter\c!strip",
tab = "\typingparameter\c!tab",
- method = "\typingparameter\c!option",
+ method = "\p_buff_option",
nature = "direct",
}}}
diff --git a/tex/context/base/catc-ini.mkiv b/tex/context/base/catc-ini.mkiv
index 26cef30de..bb1e47faa 100644
--- a/tex/context/base/catc-ini.mkiv
+++ b/tex/context/base/catc-ini.mkiv
@@ -88,16 +88,25 @@
\xdef\outputnewlinechar{^^J}%
\endgroup}
-%D We predefine some prefixes ahead of syst-aux and mult-sys. We reserve 8 slots
-%D for catcodes.
+%D We predefine some prefixes ahead of syst-aux and mult-sys.
-\def\??catcodelet {1>>} % let : \let
-\def\??catcodedef {2>>} % def : \def
-\def\??catcodeued {3>>} % ued : \unexpanded\def
-\def\??catcodeget {4>>} % \meaning
+% We reserve 8 slots for catcodes.
+%
+% \def\??catcodelet {1>>} % let : \let
+% \def\??catcodedef {2>>} % def : \def
+% \def\??catcodeued {3>>} % ued : \unexpanded\def
+% \def\??catcodeget {4>>} % \meaning
+%
+% \def\??catcodetablet{5>>}
+% \def\??catcodetablen{6>>}
+
+\installsystemnamespace {catcodelet} % let : \let
+\installsystemnamespace {catcodedef} % def : \def
+\installsystemnamespace {catcodeued} % ued : \unexpanded\def
+\installsystemnamespace {catcodeget} % \meaning
-\def\??catcodetablet{5>>}
-\def\??catcodetablen{6>>}
+\installsystemnamespace {catcodetablet}
+\installsystemnamespace {catcodetablen}
\newcount\c_syst_catcodes_n \c_syst_catcodes_n\zerocount % 0 = signal, so advance before allocate
\newcount\c_syst_catcodes_a
diff --git a/tex/context/base/char-ini.lua b/tex/context/base/char-ini.lua
index 0f632935d..b50847d8e 100644
--- a/tex/context/base/char-ini.lua
+++ b/tex/context/base/char-ini.lua
@@ -891,7 +891,6 @@ lpegpatterns.toshape = toshape -- old ones ... will be overloaded
-- function characters.upper (str) return lpegmatch(toupper,str) end
-- function characters.shaped(str) return lpegmatch(toshape,str) end
-
-- local superscripts = allocate() characters.superscripts = superscripts
-- local subscripts = allocate() characters.subscripts = subscripts
@@ -987,9 +986,9 @@ if not characters.lhash then
end
-local lhash = characters.lhash
-local uhash = characters.uhash
-local shash = characters.shash
+local lhash = characters.lhash mark(lhash)
+local uhash = characters.uhash mark(uhash)
+local shash = characters.shash mark(shash)
local utf8lowercharacter = utfchartabletopattern(lhash) / lhash
local utf8uppercharacter = utfchartabletopattern(uhash) / uhash
diff --git a/tex/context/base/char-ini.mkiv b/tex/context/base/char-ini.mkiv
index e130e200f..09e25f7fb 100644
--- a/tex/context/base/char-ini.mkiv
+++ b/tex/context/base/char-ini.mkiv
@@ -64,28 +64,23 @@
% \def\setcclcuc#1#2#3{\global\catcode#1=\lettercatcode\global\lccode#1=#2\global\uccode#1=#3\relax}
% \def\setcclcucself#1{\global\catcode#1=\lettercatcode\global\lccode#1=#1\global\uccode#1=#1\relax }
-\ctxcommand{setcharactercodes()}
-
% Is setting up vrb tpa and tpb needed?
-\ctxcommand{definecatcodetable(
- { % letter catcodes
- \number\texcatcodes,
- \number\ctxcatcodes,
- \number\notcatcodes,
- %number\mthcatcodes,
- \number\vrbcatcodes,
- \number\prtcatcodes,
- \number\tpacatcodes,
- \number\tpbcatcodes,
- \number\txtcatcodes,
- },
- { % activate catcodes
- \number\ctxcatcodes,
- \number\notcatcodes,
- \number\prtcatcodes, % new
- }
-)}
+% move to lua side
+
+\ctxcommand{setlettercatcodes(\number\texcatcodes)}
+\ctxcommand{setlettercatcodes(\number\ctxcatcodes)}
+\ctxcommand{setlettercatcodes(\number\notcatcodes)}
+%ctxcommand{setlettercatcodes(\number\mthcatcodes)}
+\ctxcommand{setlettercatcodes(\number\vrbcatcodes)}
+\ctxcommand{setlettercatcodes(\number\prtcatcodes)}
+\ctxcommand{setlettercatcodes(\number\tpacatcodes)}
+\ctxcommand{setlettercatcodes(\number\tpbcatcodes)}
+\ctxcommand{setlettercatcodes(\number\txtcatcodes)}
+
+\ctxcommand{setactivecatcodes(\number\ctxcatcodes)}
+\ctxcommand{setactivecatcodes(\number\notcatcodes)}
+\ctxcommand{setactivecatcodes(\number\prtcatcodes)}
\def\chardescription#1%
{\ctxcommand{chardescription(\number#1)}}
diff --git a/tex/context/base/char-tex.lua b/tex/context/base/char-tex.lua
index e03307cc3..e1caa64b9 100644
--- a/tex/context/base/char-tex.lua
+++ b/tex/context/base/char-tex.lua
@@ -412,6 +412,11 @@ function texcharacters.safechar(n) -- was characters.safechar
end
end
+if not context or not commands then
+ -- used in e.g. mtx-bibtex
+ return
+end
+
function texcharacters.defineaccents()
for accent, group in next, accentmapping do
context.dodefineaccentcommand(accent)
@@ -421,11 +426,6 @@ function texcharacters.defineaccents()
end
end
-if not context or not commands then
- -- used in e.g. mtx-bibtex
- return
-end
-
-- all kind of initializations
local tex = tex
@@ -476,99 +476,119 @@ local forbidden = tohash { -- at least now
-- 0xFEFF,
}
-function characters.define(tobelettered, tobeactivated) -- catcodetables
+local csletters = characters.csletters -- also a signal that we have initialized
+local activated = { }
- if trace_defining then
- report_defining("defining active character commands")
- end
+if not csletters then
+
+ csletters = allocate()
+ characters.csletters = csletters
- local activated, a = { }, 0
+ report_defining("setting up character related commands")
- for u, chr in next, data do -- these will be commands
+ for u, chr in next, data do -- will move up
local fallback = chr.fallback
if fallback then
contextsprint("{\\catcode",u,"=13\\unexpanded\\gdef ",utfchar(u),"{\\checkedchar{",u,"}{",fallback,"}}}")
- a = a + 1
- activated[a] = u
+ activated[#activated+1] = u
else
local contextname = chr.contextname
+ local category = chr.category
if contextname then
- local category = chr.category
if is_character[category] then
if chr.unicodeslot < 128 then
if is_letter[category] then
- contextsprint(ctxcatcodes,format("\\def\\%s{%s}",contextname,utfchar(u))) -- has no s
+ -- setmacro
+ local c = utfchar(u)
+ contextsprint(ctxcatcodes,format("\\def\\%s{%s}",contextname,c)) -- has no s
+ csletters[c] = u
else
+ -- setchar
contextsprint(ctxcatcodes,format("\\chardef\\%s=%s",contextname,u)) -- has no s
end
else
- contextsprint(ctxcatcodes,format("\\def\\%s{%s}",contextname,utfchar(u))) -- has no s
+ -- setmacro
+ local c = utfchar(u)
+ contextsprint(ctxcatcodes,format("\\def\\%s{%s}",contextname,c)) -- has no s
+ if is_letter[chr.category] and u >= 32 and u <= 65536 then
+ csletters[c] = u
+ end
end
elseif is_command[category] and not forbidden[u] then
+ -- set
contextsprint("{\\catcode",u,"=13\\unexpanded\\gdef ",utfchar(u),"{\\"..contextname,"}}")
- a = a + 1
- activated[a] = u
+ activated[#activated+1] = u
end
+ elseif is_letter[chr.category] and u >= 32 and u <= 65536 then
+ csletters[utfchar(u)] = u
end
end
end
- if tobelettered then -- shared
- local saved = tex.catcodetable
- for i=1,#tobelettered do
- tex.catcodetable = tobelettered[i]
- if trace_defining then
- report_defining("defining letters (global, shared)")
- end
- for u, chr in next, data do
- if not chr.fallback and is_letter[chr.category] and u >= 128 and u <= 65536 then
- texsetcatcode(u,11)
- end
- local range = chr.range
- if range then
- for i=1,range.first,range.last do -- tricky as not all are letters
- texsetcatcode(i,11)
- end
- end
- end
- texsetcatcode(0x200C,11) -- non-joiner
- texsetcatcode(0x200D,11) -- joiner
- for k, v in next, blocks do
- if v.catcode == "letter" then
- for i=v.first,v.last do
- texsetcatcode(i,11)
- end
+ if false then
+ for k, v in next, blocks do
+ if v.catcode == "letter" then
+ for u=v.first,v.last do
+ csletters[utfchar(u)] = u
end
end
end
- tex.catcodetable = saved
end
- local nofactivated = #tobeactivated
- if tobeactivated and nofactivated > 0 then
- for i=1,nofactivated do
- local u = activated[i]
- if u then
- report_defining("character %U is active in set %a, containing %a",u,data[u].description,tobeactivated)
- end
- end
- local saved = tex.catcodetable
- for i=1,#tobeactivated do
- local vector = tobeactivated[i]
- if trace_defining then
- report_defining("defining %a active characters in vector %a",nofactivated,vector)
- end
- tex.catcodetable = vector
- for i=1,nofactivated do
- local u = activated[i]
- if u then
- texsetcatcode(u,13)
- end
- end
- end
- tex.catcodetable = saved
+ if storage then
+ storage.register("characters/csletters", csletters, "characters.csletters")
+ end
+
+end
+
+lpegpatterns.csletter = utfchartabletopattern(csletters)
+
+-- todo: get rid of activated
+-- todo: move first loop out ,merge with above
+
+function characters.setlettercatcodes(cct)
+ if trace_defining then
+ report_defining("assigning letter catcodes to catcode table %a",cct)
end
+ local saved = tex.catcodetable
+ tex.catcodetable = cct
+ texsetcatcode(0x200C,11) -- non-joiner
+ texsetcatcode(0x200D,11) -- joiner
+ for c, u in next, csletters do
+ texsetcatcode(u,11)
+ end
+ -- for u, chr in next, data do
+ -- if not chr.fallback and is_letter[chr.category] and u >= 32 and u <= 65536 then
+ -- texsetcatcode(u,11)
+ -- end
+ -- local range = chr.range
+ -- if range then
+ -- for i=1,range.first,range.last do -- tricky as not all are letters
+ -- texsetcatcode(i,11)
+ -- end
+ -- end
+ -- end
+ -- for k, v in next, blocks do
+ -- if v.catcode == "letter" then
+ -- for u=v.first,v.last do
+ -- texsetcatcode(u,11)
+ -- end
+ -- end
+ -- end
+ tex.catcodetable = saved
+end
+function characters.setactivecatcodes(cct)
+ local saved = tex.catcodetable
+ tex.catcodetable = cct
+ for i=1,#activated do
+ local u = activated[i]
+ texsetcatcode(u,13)
+ if trace_defining then
+ report_defining("character %U (%s) is active in set %a",u,data[u].description,cct)
+ end
+ end
+ tex.catcodetable = saved
end
--[[ldx--
@@ -676,5 +696,6 @@ end
-- entities.gt = utfchar(characters.activeoffset + utfbyte(">"))
-- end
-commands.definecatcodetable = characters.define
-commands.setcharactercodes = characters.setcodes
+commands.setlettercatcodes = characters.setlettercatcodes
+commands.setactivecatcodes = characters.setactivecatcodes
+commands.setcharactercodes = characters.setcodes
diff --git a/tex/context/base/char-utf.lua b/tex/context/base/char-utf.lua
index e3f7605a8..267c97c26 100644
--- a/tex/context/base/char-utf.lua
+++ b/tex/context/base/char-utf.lua
@@ -30,8 +30,11 @@ if not characters.blocks then require("char-ini") end
local lpegmatch = lpeg.match
local lpegpatterns = lpeg.patterns
local p_utf8character = lpegpatterns.utf8character
+local p_utf8byte = lpegpatterns.utf8byte
local utfchartabletopattern = lpeg.utfchartabletopattern
+local formatters = string.formatters
+
local allocate = utilities.storage.allocate or function() return { } end
local charfromnumber = characters.fromnumber
@@ -60,6 +63,8 @@ characters.filters = filters
local utffilters = { }
characters.filters.utf = utffilters
+local data = characters.data
+
-- is characters.combined cached?
--[[ldx--
@@ -611,4 +616,23 @@ end
--
-- print(test,done,test==done,false)
+local f_default = formatters["[%U] "]
+local f_description = formatters["[%s] "]
+
+local function convert(n)
+ local d = data[n]
+ d = d and d.description
+ if d then
+ return f_description(d)
+ else
+ return f_default(n)
+ end
+end
+
+local pattern = Cs((p_utf8byte / convert)^1)
+
+function utffilters.verbose(data)
+ return data and lpegmatch(pattern,data) or ""
+end
+
return characters
diff --git a/tex/context/base/cldf-bas.lua b/tex/context/base/cldf-bas.lua
index b982fc364..1067a17d5 100644
--- a/tex/context/base/cldf-bas.lua
+++ b/tex/context/base/cldf-bas.lua
@@ -24,10 +24,10 @@ if not modules then modules = { } end modules ['cldf-bas'] = {
-- maybe use context.generics
-local type = type
-local format = string.format
-local utfchar = utf.char
-local concat = table.concat
+local type = type
+local format = string.format
+local utfchar = utf.char
+local concat = table.concat
local context = context
local generics = context.generics
@@ -49,13 +49,23 @@ function context.char(k) -- used as escape too, so don't change to utf
elseif n > 0 then
context([[\char%s\relax]],concat(k,[[\relax\char]]))
end
- elseif k then
- context([[\char%s\relax]],k)
+ else
+ if type(k) == "string" then
+ k = tonumber(k)
+ end
+ if type(k) == "number" then
+ context([[\char%s\relax]],k)
+ end
end
end
function context.utfchar(k)
- context(utfchar(k))
+ if type(k) == "string" then
+ k = tonumber(k)
+ end
+ if type(k) == "number" then
+ context(utfchar(k))
+ end
end
-- plain variants
diff --git a/tex/context/base/cldf-ini.lua b/tex/context/base/cldf-ini.lua
index 62158e08b..43d5cebd1 100644
--- a/tex/context/base/cldf-ini.lua
+++ b/tex/context/base/cldf-ini.lua
@@ -315,13 +315,15 @@ local registerfunction, unregisterfunction, reservefunction, knownfunctions, cal
interfaces.scanners = table.setmetatablenewindex(function(t,k,v)
if storedscanners[k] then
+ -- report_cld("warning: scanner %a is already set",k)
+ -- os.exit()
-- \scan_<k> is already in the format
-- report_cld("using interface scanner: %s",k)
else
-- todo: allocate slot here and pass it
storedscanners[k] = true
-- report_cld("installing interface scanner: %s",k)
- context("\\installctxfunction{scan_%s}{interfaces.scanners.%s}",k,k)
+ context("\\installctxfunction{clf_%s}{interfaces.scanners.%s}",k,k)
end
rawset(t,k,v)
end)
diff --git a/tex/context/base/cldf-scn.lua b/tex/context/base/cldf-scn.lua
new file mode 100644
index 000000000..a3d8b0d87
--- /dev/null
+++ b/tex/context/base/cldf-scn.lua
@@ -0,0 +1,100 @@
+if not modules then modules = { } end modules ['cldf-scn'] = {
+ version = 1.001,
+ comment = "companion to cldf-ini.mkiv",
+ author = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
+ copyright = "PRAGMA ADE / ConTeXt Development Team",
+ license = "see context related readme files"
+}
+
+if not tokens.setters then return end
+
+local load, type = load, type
+
+local formatters = string.formatters
+local char = string.char
+local concat = table.concat
+
+local f_action_f = formatters["action%s(%s)"]
+local f_action_s = formatters["local action%s = action[%s]"]
+local f_command = formatters["local action = tokens._action\n%\nt\nreturn function(%s) return %s end"]
+
+local interfaces = interfaces
+local commands = commands
+local scanners = interfaces.scanners
+
+local compile = tokens.compile or function() end
+
+local report = logs.reporter("interfaces","implementor")
+
+function interfaces.implement(specification)
+ local actions = specification.actions
+ local name = specification.name
+ local arguments = specification.arguments
+ local scope = specification.scope
+ if not actions then
+ if name then
+ report("error: no actions for %a",name)
+ else
+ report("error: no actions and no name")
+ end
+ return
+ end
+ local scanner = compile(specification)
+ if not name or name == "" then
+ return scanner
+ end
+ local command = nil
+ if type(actions) == "function" then
+ command = actions
+ elseif actions == context then
+ command = context
+ elseif #actions == 1 then
+ command = actions[1]
+ else
+ tokens._action = actions
+ local f = { }
+ local a = { }
+ local args = ""
+ if arguments then
+ for i=1,#arguments do
+ local v = arguments[i]
+ local t = type(v)
+ if t == "boolean" then
+ a[i] = tostring(v)
+ else
+ a[i] = char(96+i)
+ end
+ end
+ args = concat(a,",")
+ end
+ command = args
+ for i=1,#actions do
+ command = f_action_f(i,command)
+ f[#f+1] = f_action_s(i,i)
+ end
+ command = f_command(f,args,command)
+ command = load(command)
+ if command then
+ command = command()
+ end
+ tokens._action = nil
+ end
+ if scanners[name] then
+ report("warning: 'scanners.%s' is redefined",name)
+ end
+ scanners[name] = scanner
+ if scope == "private" then
+ return
+ end
+ if commands[name] then
+ report("warning: 'commands.%s' is redefined",name)
+ end
+ commands[name] = command
+ -- return scanner, command
+end
+
+-- it's convenient to have copies here:
+
+interfaces.setmacro = tokens.setters.macro
+interfaces.setcount = tokens.setters.count
+interfaces.setdimen = tokens.setters.dimen
diff --git a/tex/context/base/cont-new.mkiv b/tex/context/base/cont-new.mkiv
index 9891ab046..61bfc0ca9 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{2015.03.10 12:09}
+\newcontextversion{2015.03.25 22:13}
%D This file is loaded at runtime, thereby providing an excellent place for
%D hacks, patches, extensions and new features.
diff --git a/tex/context/base/context-version.pdf b/tex/context/base/context-version.pdf
index 2c2c7b0a5..4ffe51b69 100644
--- a/tex/context/base/context-version.pdf
+++ b/tex/context/base/context-version.pdf
Binary files differ
diff --git a/tex/context/base/context.mkiv b/tex/context/base/context.mkiv
index 7d6259737..8252c7b8c 100644
--- a/tex/context/base/context.mkiv
+++ b/tex/context/base/context.mkiv
@@ -28,7 +28,7 @@
%D up and the dependencies are more consistent.
\edef\contextformat {\jobname}
-\edef\contextversion{2015.03.10 12:09}
+\edef\contextversion{2015.03.25 22:13}
\edef\contextkind {beta}
%D For those who want to use this:
@@ -99,6 +99,9 @@
% From here on we have \unexpanded being \normalprotected, as we already had
% \unexpanded long before etex came around.
+\loadmarkfile{luat-ini}
+\loadmarkfile{toks-ini}
+
\loadmarkfile{syst-aux}
\loadmarkfile{syst-lua}
\loadmarkfile{syst-con}
@@ -106,6 +109,9 @@
\loadmarkfile{syst-fnt}
\loadmarkfile{syst-rtp}
+% \loadmarkfile{luat-ini} % moved up
+% \loadmarkfile{toks-ini} % moved up
+
\loadmkvifile{file-ini}
\loadmkvifile{file-res}
\loadmkvifile{file-lib}
@@ -126,9 +132,8 @@
\loadmarkfile{cldf-int} % interface
-\loadmarkfile{luat-ini}
+% \loadmarkfile{luat-ini}
-\loadmarkfile{toks-ini}
\loadmarkfile{toks-tra}
%loadmarkfile{toks-map} % obsolete, never used
@@ -419,7 +424,7 @@
\loadmarkfile{prop-ini} % only for downward compatibility
-\loadmarkfile{mlib-ctx}
+\loadmarkfile{mlib-ctx} % messy order
\loadmarkfile{meta-ini}
\loadmarkfile{meta-tex}
diff --git a/tex/context/base/file-job.mkvi b/tex/context/base/file-job.mkvi
index 243a8d856..171dc1a6a 100644
--- a/tex/context/base/file-job.mkvi
+++ b/tex/context/base/file-job.mkvi
@@ -241,13 +241,13 @@
\newsystemmode\v!environment
\unexpanded\def\startprojectindeed
- {\starttext
+ {%starttext
\pushsystemmode\v!project
\setsystemmode\v!project}
\unexpanded\def\stopprojectindeed
{\popsystemmode\v!project
- \stoptext
+ %stoptext
\signalendofinput\v!project}
\unexpanded\def\startproductindeed
diff --git a/tex/context/base/file-res.lua b/tex/context/base/file-res.lua
index 458ef7276..78fdc3404 100644
--- a/tex/context/base/file-res.lua
+++ b/tex/context/base/file-res.lua
@@ -134,7 +134,7 @@ openers.fix = openers.file loaders.fix = loaders.file
openers.set = openers.file loaders.set = loaders.file
openers.any = openers.file loaders.any = loaders.file
-function getreadfilename(scheme,path,name) -- better do a split and then pass table
+local function getreadfilename(scheme,path,name) -- better do a split and then pass table
local fullname
if hasscheme(name) or is_qualified_path(name) then
fullname = name
diff --git a/tex/context/base/font-chk.lua b/tex/context/base/font-chk.lua
index 591d59d65..e5c46dd62 100644
--- a/tex/context/base/font-chk.lua
+++ b/tex/context/base/font-chk.lua
@@ -17,6 +17,8 @@ local fastcopy = table.fastcopy
local report_fonts = logs.reporter("fonts","checking")
+local allocate = utilities.storage.allocate
+
local fonts = fonts
fonts.checkers = fonts.checkers or { }
@@ -88,7 +90,7 @@ end
fonts.loggers.onetimemessage = onetimemessage
-local mapping = { -- this is just an experiment to illustrate some principles elsewhere
+local mapping = allocate { -- this is just an experiment to illustrate some principles elsewhere
lu = "placeholder uppercase red",
ll = "placeholder lowercase red",
lt = "placeholder uppercase red",
@@ -113,9 +115,15 @@ local mapping = { -- this is just an experiment to illustrate some principles el
so = "placeholder lowercase yellow",
}
-table.setmetatableindex(mapping,function(t,k) v = "placeholder unknown gray" t[k] = v return v end)
+table.setmetatableindex(mapping,
+ function(t,k)
+ v = "placeholder unknown gray"
+ t[k] = v
+ return v
+ end
+)
-local fakes = {
+local fakes = allocate {
{
name = "lowercase",
code = ".025 -.175 m .425 -.175 l .425 .525 l .025 .525 l .025 -.175 l .025 0 l .425 0 l .025 -.175 m h S",
@@ -153,7 +161,7 @@ local fakes = {
},
}
-local variants = {
+local variants = allocate {
{ tag = "gray", r = .6, g = .6, b = .6 },
{ tag = "red", r = .6, g = 0, b = 0 },
{ tag = "green", r = 0, g = .6, b = 0 },
diff --git a/tex/context/base/font-ctx.lua b/tex/context/base/font-ctx.lua
index a7f915023..9f5559290 100644
--- a/tex/context/base/font-ctx.lua
+++ b/tex/context/base/font-ctx.lua
@@ -955,8 +955,11 @@ do -- else too many locals
local ctx_setsomefontsize = context.fntsetsomesize
local ctx_letvaluerelax = context.letvaluerelax
+ local starttiming = statistics.starttiming
+ local stoptiming = statistics.stoptiming
+
function commands.definefont_one(str)
- statistics.starttiming(fonts)
+ starttiming(fonts)
if trace_defining then
report_defining("memory usage before: %s",statistics.memused())
report_defining("start stage one: %s",str)
@@ -1186,7 +1189,7 @@ do -- else too many locals
lastmathids[mathsize] = lastfontid
end
--
- statistics.stoptiming(fonts)
+ stoptiming(fonts)
end
function definers.define(specification)
@@ -1195,7 +1198,7 @@ do -- else too many locals
if not name or name == "" then
return -1
else
- statistics.starttiming(fonts)
+ starttiming(fonts)
--
-- following calls expect a few properties to be set:
--
@@ -1251,7 +1254,7 @@ do -- else too many locals
constructors.finalize(tfmdata)
return id, tfmdata
end
- statistics.stoptiming(fonts)
+ stoptiming(fonts)
end
end
diff --git a/tex/context/base/font-map.lua b/tex/context/base/font-map.lua
index e26f28e34..449a00f2e 100644
--- a/tex/context/base/font-map.lua
+++ b/tex/context/base/font-map.lua
@@ -23,6 +23,8 @@ local fonts = fonts or { }
local mappings = fonts.mappings or { }
fonts.mappings = mappings
+local allocate = utilities.storage.allocate
+
--[[ldx--
<p>Eventually this code will disappear because map files are kind
of obsolete. Some code may move to runtime or auxiliary modules.</p>
@@ -194,7 +196,7 @@ local namesplitter = Ct(C((1 - ligseparator - varseparator)^1) * (ligseparator *
-- to be completed .. for fonts that use unicodes for ligatures which
-- is a actually a bad thing and should be avoided in the first place
-local overloads = {
+local overloads = allocate {
IJ = { name = "I_J", unicode = { 0x49, 0x4A }, mess = 0x0132 },
ij = { name = "i_j", unicode = { 0x69, 0x6A }, mess = 0x0133 },
ff = { name = "f_f", unicode = { 0x66, 0x66 }, mess = 0xFB00 },
diff --git a/tex/context/base/grph-inc.lua b/tex/context/base/grph-inc.lua
index d795deacf..283d7dc72 100644
--- a/tex/context/base/grph-inc.lua
+++ b/tex/context/base/grph-inc.lua
@@ -1560,6 +1560,7 @@ local epstopdf = {
-dBATCH
-dAutoRotatePages=/None
-dPDFSETTINGS=/%presets%
+ -dCompatibilityLevel=%level%
-dEPSCrop
-sOutputFile="%newname%"
"%oldname%"
@@ -1605,6 +1606,7 @@ end
function epsconverter.pdf(oldname,newname,resolution) -- the resolution interface might change
local epstopdf = programs.epstopdf -- can be changed
local presets = epstopdf.resolutions[resolution or "high"] or epstopdf.resolutions.high
+ local level = codeinjections.getformatoption("pdf_level") or "1.3"
local tmpname = oldname
if cleanups.ai then
tmpname = cleaners.ai(oldname)
diff --git a/tex/context/base/l-lpeg.lua b/tex/context/base/l-lpeg.lua
index 192e32f3c..0c8970609 100644
--- a/tex/context/base/l-lpeg.lua
+++ b/tex/context/base/l-lpeg.lua
@@ -888,24 +888,155 @@ end
-- return make(tree)
-- end
+local p_false = P(false)
+local p_true = P(true)
+
+-- local function make(t,hash)
+-- local p = p_false
+-- local keys = sortedkeys(t)
+-- for i=1,#keys do
+-- local k = keys[i]
+-- local v = t[k]
+-- local h = hash[v]
+-- if h then
+-- if next(v) then
+-- p = p + P(k) * (make(v,hash) + p_true)
+-- else
+-- p = p + P(k) * p_true
+-- end
+-- else
+-- if next(v) then
+-- p = p + P(k) * make(v,hash)
+-- else
+-- p = p + P(k)
+-- end
+-- end
+-- end
+-- return p
+-- end
+
+-- local function make(t,hash)
+-- local p = p_false
+-- local keys = sortedkeys(t)
+-- local function making(t,w)
+-- local p = p_false
+-- local keys = sortedkeys(t)
+-- for i=1,#keys do
+-- local k = keys[i]
+-- local v = t[k]
+-- if w then
+-- if next(v) then
+-- p = p + P(k) * (making(v,w) + p_true)
+-- else
+-- p = p + P(k) * p_true
+-- end
+-- else
+-- if next(v) then
+-- p = p + P(k) * making(v,w)
+-- else
+-- p = p + P(k)
+-- end
+-- end
+-- end
+-- return p
+-- end
+-- for i=1,#keys do
+-- local k = keys[i]
+-- local v = t[k]
+-- local h = hash[v]
+-- if h then
+-- if next(v) then
+-- p = p + P(k) * (making(v,true) + p_true)
+-- else
+-- p = p + P(k) * p_true
+-- end
+-- else
+-- if next(v) then
+-- p = p + P(k) * making(v,false)
+-- else
+-- p = p + P(k)
+-- end
+-- end
+-- end
+-- return p
+-- end
+--
+-- function lpeg.utfchartabletopattern(list) -- goes to util-lpg
+-- local tree = { }
+-- local hash = { }
+-- local n = #list
+-- if n == 0 then
+-- for s in next, list do
+-- local t = tree
+-- for c in gmatch(s,".") do
+-- local tc = t[c]
+-- if not tc then
+-- tc = { }
+-- t[c] = tc
+-- end
+-- t = tc
+-- end
+-- hash[t] = s
+-- end
+-- else
+-- for i=1,n do
+-- local t = tree
+-- local s = list[i]
+-- for c in gmatch(s,".") do
+-- local tc = t[c]
+-- if not tc then
+-- tc = { }
+-- t[c] = tc
+-- end
+-- t = tc
+-- end
+-- hash[t] = s
+-- end
+-- end
+-- return make(tree,hash)
+-- end
+
+
local function make(t,hash)
- local p = P(false)
+ local p = p_false
local keys = sortedkeys(t)
+ local function making(t,w)
+ local p = p_false
+ local keys = sortedkeys(t)
+ for i=1,#keys do
+ local k = keys[i]
+ local v = t[k]
+ if w then
+ if v == true then
+ p = p + P(k) * p_true
+ else
+ p = p + P(k) * (making(v,w) + p_true)
+ end
+ else
+ if v == true then
+ p = p + P(k)
+ else
+ p = p + P(k) * making(v,w)
+ end
+ end
+ end
+ return p
+ end
for i=1,#keys do
local k = keys[i]
local v = t[k]
local h = hash[v]
if h then
- if next(v) then
- p = p + P(k) * (make(v,hash) + P(true))
+ if v == true then
+ p = p + P(k) * p_true
else
- p = p + P(k) * P(true)
+ p = p + P(k) * (making(v,true) + p_true)
end
else
- if next(v) then
- p = p + P(k) * make(v,hash)
- else
+ if v == true then
p = p + P(k)
+ else
+ p = p + P(k) * making(v,false)
end
end
end
@@ -914,41 +1045,62 @@ end
function lpeg.utfchartabletopattern(list) -- goes to util-lpg
local tree = { }
- local hash = { }
+-- local hash = { }
+ local hash
local n = #list
if n == 0 then
- -- we could always use this branch
+ hash = list
for s in next, list do
local t = tree
+ local p, pk
for c in gmatch(s,".") do
- local tc = t[c]
- if not tc then
- tc = { }
- t[c] = tc
+ if t == true then
+ t = { [c] = true }
+ p[pk] = t
+ p = t
+ t = true
+ else
+ local tc = t[c]
+ if not tc then
+ tc = true
+ t[c] = tc
+ end
+ p = t
+ t = tc
end
- t = tc
+ pk = c
end
- hash[t] = s
end
else
+ hash = { }
for i=1,n do
local t = tree
local s = list[i]
+ local p, pk
for c in gmatch(s,".") do
- local tc = t[c]
- if not tc then
- tc = { }
- t[c] = tc
+ if t == true then
+ t = { [c] = true }
+ p[pk] = t
+ p = t
+ t = true
+ else
+ local tc = t[c]
+ if not tc then
+ tc = true
+ t[c] = true
+ end
+ p = t
+ t = tc
end
- t = tc
+ pk = c
end
- hash[t] = s
+ hash[s] = true
end
end
return make(tree,hash)
end
--- inspect ( lpeg.utfchartabletopattern {
+-- lpeg.utfchartabletopattern {
-- utfchar(0x00A0), -- nbsp
-- utfchar(0x2000), -- enquad
-- utfchar(0x2001), -- emquad
@@ -964,7 +1116,7 @@ end
-- utfchar(0x200B), -- zerowidthspace
-- utfchar(0x202F), -- narrownobreakspace
-- utfchar(0x205F), -- math thinspace
--- } )
+-- }
-- a few handy ones:
--
diff --git a/tex/context/base/lang-hyp.lua b/tex/context/base/lang-hyp.lua
index 60e1699ca..68edcfc85 100644
--- a/tex/context/base/lang-hyp.lua
+++ b/tex/context/base/lang-hyp.lua
@@ -591,6 +591,7 @@ if context then
local glyph_code = nodecodes.glyph
local disc_code = nodecodes.disc
local math_code = nodecodes.math
+ local hlist_code = nodecodes.hlist
local discretionary_code = disccodes.discretionary
local explicit_code = disccodes.explicit
@@ -614,6 +615,7 @@ if context then
local getnext = nuts.getnext
local getprev = nuts.getprev
local getsubtype = nuts.getsubtype
+ local getlist = nuts.getlist
local insert_before = nuts.insert_before
local insert_after = nuts.insert_after
local copy_node = nuts.copy
@@ -667,42 +669,48 @@ if context then
if specification then
local resources = specification.resources
if resources then
- local patterns = resources.patterns
- if patterns then
- local data = patterns.data
- if data then
- -- regular patterns
- lpegmatch(p_pattern,data,1,dictionary.patterns,dictionary.specials)
- end
- local extra = patterns.extra
- if extra then
- -- special patterns
- lpegmatch(p_pattern,extra,1,dictionary.patterns,dictionary.specials)
- end
- end
- local exceptions = resources.exceptions
- if exceptions then
- local data = exceptions.data
- if data and data ~= "" then
- lpegmatch(p_exception,data,1,dictionary.exceptions)
- end
- end
- local usedchars = lpegmatch(p_split,patterns.characters)
- local characters = { }
- local unicodes = { }
- for i=1,#usedchars do
- local char = usedchars[i]
- local code = utfbyte(char)
- local upper = uccodes[code]
- characters[char] = code
- unicodes [code] = char
- if type(upper) == "table" then
- for i=1,#upper do
- local u = upper[i]
- unicodes[u] = utfchar(u)
+ local characters = dictionary.characters or { }
+ local unicodes = dictionary.unicodes or { }
+ for i=1,#resources do
+ local r = resources[i]
+ if not r.in_dictionary then
+ r.in_dictionary = true
+ local patterns = r.patterns
+ if patterns then
+ local data = patterns.data
+ if data then
+ -- regular patterns
+ lpegmatch(p_pattern,data,1,dictionary.patterns,dictionary.specials)
+ end
+ local extra = patterns.extra
+ if extra then
+ -- special patterns
+ lpegmatch(p_pattern,extra,1,dictionary.patterns,dictionary.specials)
+ end
+ end
+ local exceptions = r.exceptions
+ if exceptions then
+ local data = exceptions.data
+ if data and data ~= "" then
+ lpegmatch(p_exception,data,1,dictionary.exceptions)
+ end
+ end
+ local usedchars = lpegmatch(p_split,patterns.characters)
+ for i=1,#usedchars do
+ local char = usedchars[i]
+ local code = utfbyte(char)
+ local upper = uccodes[code]
+ characters[char] = code
+ unicodes [code] = char
+ if type(upper) == "table" then
+ for i=1,#upper do
+ local u = upper[i]
+ unicodes[u] = utfchar(u)
+ end
+ else
+ unicodes[upper] = utfchar(upper)
+ end
end
- else
- unicodes[upper] = utfchar(upper)
end
end
dictionary.characters = characters
@@ -1423,11 +1431,24 @@ if context then
return head, done
end
- function hyphenators.handler(head)
+ local getcount = tex.getcount
+
+ hyphenators.optimize = false
+
+ function hyphenators.handler(head,groupcode)
if usedmethod then
- return usedmethod(head)
+ if groupcode == "hbox" and hyphenators.optimize then
+ if getcount("hyphenstate") > 0 then
+ forced = false
+ return usedmethod(head)
+ else
+ return head, false
+ end
+ else
+ return usedmethod(head)
+ end
else
- return head, done
+ return head, false
end
end
@@ -1435,16 +1456,22 @@ if context then
methods.original = original
methods.expanded = expanded
methods.traditional = languages.hyphenators.traditional.hyphenate
- methods.none = function(head) return head, false end
+ methods.none = false -- function(head) return head, false end
usedmethod = original
local function setmethod(method)
- usedmethod = type(method) == "string" and methods[method] or methods.tex
+ usedmethod = type(method) == "string" and methods[method]
+ if usedmethod == nil then
+ usedmethod = methods.tex
+ end
end
local function pushmethod(method)
insert(stack,usedmethod)
- setmethod(method)
+ usedmethod = type(method) == "string" and methods[method]
+ if usedmethod == nil then
+ usedmethod = methods.tex
+ end
end
local function popmethod()
usedmethod = remove(stack) or methods.tex
@@ -1497,6 +1524,17 @@ if context then
end
end
+ function nodes.stripdiscretionaries(head)
+ local h = tonut(head)
+ for l in traverse_id(hlist_code,h) do
+ for d in traverse_id(disc_code,getlist(l)) do
+ remove_node(h,false,true)
+ end
+ end
+ return tonode(h)
+ end
+
+
else
-- traditional.loadpatterns("nl","lang-nl")
diff --git a/tex/context/base/lang-ini.lua b/tex/context/base/lang-ini.lua
index 0c3d9d80b..27bab6129 100644
--- a/tex/context/base/lang-ini.lua
+++ b/tex/context/base/lang-ini.lua
@@ -131,7 +131,10 @@ local function loaddefinitions(tag,specification)
if trace_patterns then
report_initialization("pattern specification for language %a: %s",tag,specification.patterns)
end
- local dataused, ok = data.used, false
+ local dataused = data.used
+ local ok = false
+ local resources = data.resources or { }
+ data.resources = resources
for i=1,#definitions do
local definition = definitions[i]
if definition == "" then
@@ -153,14 +156,15 @@ local function loaddefinitions(tag,specification)
report_initialization("loading definition %a for language %a from %a",definition,tag,fullname)
end
local suffix, gzipped = gzip.suffix(fullname)
- local resources = table.load(fullname,gzipped and gzip.load)
- if resources then -- todo: version test
+ local loaded = table.load(fullname,gzipped and gzip.load)
+ if loaded then -- todo: version test
ok, nofloaded = true, nofloaded + 1
- -- instance:patterns (resources.patterns and resources.patterns .data or "")
- -- instance:hyphenation(resources.exceptions and resources.exceptions.data or "")
- instance:patterns (validdata(resources.patterns, "patterns", tag) or "")
- instance:hyphenation(validdata(resources.exceptions,"exceptions",tag) or "")
- data.resources = resources -- so we can use them otherwise
+ -- instance:patterns (loaded.patterns and resources.patterns .data or "")
+ -- instance:hyphenation(loaded.exceptions and resources.exceptions.data or "")
+ instance:patterns (validdata(loaded.patterns, "patterns", tag) or "")
+ instance:hyphenation(validdata(loaded.exceptions,"exceptions",tag) or "")
+ resources[#resources+1] = loaded -- so we can use them otherwise
+
else
report_initialization("invalid definition %a for language %a in %a",definition,tag,filename)
end
diff --git a/tex/context/base/lang-ini.mkiv b/tex/context/base/lang-ini.mkiv
index 71b631be9..ddd7a8808 100644
--- a/tex/context/base/lang-ini.mkiv
+++ b/tex/context/base/lang-ini.mkiv
@@ -438,6 +438,10 @@
\the\everylanguage
\relax}
+% experimental
+
+\newcount\hyphenstate
+
% so far
\newcount\hyphenminoffset
diff --git a/tex/context/base/lpdf-ano.lua b/tex/context/base/lpdf-ano.lua
index ac608baa4..f5e320a00 100644
--- a/tex/context/base/lpdf-ano.lua
+++ b/tex/context/base/lpdf-ano.lua
@@ -117,7 +117,7 @@ local pdf_border_color = nil
local set_border = false
local function pdfborder()
- border_set = true
+ set_border = true
return pdf_border_style, pdf_border_color
end
diff --git a/tex/context/base/lpdf-xmp.lua b/tex/context/base/lpdf-xmp.lua
index 739b29ef7..695f0224a 100644
--- a/tex/context/base/lpdf-xmp.lua
+++ b/tex/context/base/lpdf-xmp.lua
@@ -157,7 +157,7 @@ local function flushxmpinfo()
local producer = format("LuaTeX-%0.2f.%s",tex.luatexversion/100,tex.luatexrevision)
local creator = "LuaTeX + ConTeXt MkIV"
local time = lpdf.timestamp()
- local fullbanner = tex.pdftexbanner
+ local fullbanner = status.banner
-- local fullbanner = gsub(tex.pdftexbanner,"kpse.*","")
pdfaddxmpinfo("DocumentID", documentid)
diff --git a/tex/context/base/luat-cnf.lua b/tex/context/base/luat-cnf.lua
index cf8a1e7e0..0f6b8598f 100644
--- a/tex/context/base/luat-cnf.lua
+++ b/tex/context/base/luat-cnf.lua
@@ -64,7 +64,7 @@ function texconfig.init()
"string", "table", "coroutine", "debug", "file", "io", "lpeg", "math", "os", "package", "bit32",
},
basictex = { -- noad
- "callback", "font", "img", "lang", "lua", "node", "pdf", "status", "tex", "texconfig", "texio", "token",
+ "callback", "font", "img", "lang", "lua", "node", "pdf", "status", "tex", "texconfig", "texio", "token", "newtoken"
},
extralua = {
"gzip", "zip", "zlib", "lfs", "ltn12", "mime", "socket", "md5", "profiler", "unicode", "utf",
@@ -75,6 +75,7 @@ function texconfig.init()
obsolete = {
"fontforge", -- can be filled by luat-log
"kpse",
+ "token",
},
functions = {
"assert", "pcall", "xpcall", "error", "collectgarbage",
diff --git a/tex/context/base/luat-ini.mkiv b/tex/context/base/luat-ini.mkiv
index 168b52095..78a324db2 100644
--- a/tex/context/base/luat-ini.mkiv
+++ b/tex/context/base/luat-ini.mkiv
@@ -34,7 +34,7 @@
% the \type {\normalexpanded} around \type {\directlua}. Something to discuss
% in the team.
-\unexpanded\def\startlua % \stoplua
+\normalprotected\def\startlua % \stoplua
{\begingroup
\obeylualines
\luat_start_lua_indeed}
@@ -42,7 +42,7 @@
\def\luat_start_lua_indeed#1\stoplua
{\normalexpanded{\endgroup\noexpand\directlua{#1}}} % \zerocount is default
-\unexpanded\def\startluacode % \stopluacode
+\normalprotected\def\startluacode % \stopluacode
{\begingroup
\obeylualines
\obeyluatokens
@@ -77,7 +77,7 @@
\edef\lua_letter_seven {\string\7} \edef\lua_letter_eight {\string\8}
\edef\lua_letter_nine {\string\9} \edef\lua_letter_zero {\string\0}
-\appendtoks
+\everyluacode {% \appendtoks
\let\\\lua_letter_backslash
\let\|\lua_letter_bar \let\-\lua_letter_dash
\let\(\lua_letter_lparent \let\)\lua_letter_rparent
@@ -92,13 +92,12 @@
\let\5\lua_letter_five \let\6\lua_letter_six
\let\7\lua_letter_seven \let\8\lua_letter_eight
\let\9\lua_letter_nine \let\0\lua_letter_zero
-\to \everyluacode
+} % \to \everyluacode
-\unexpanded\def\obeyluatokens
+\normalprotected\def\obeyluatokens
{\setcatcodetable\luacatcodes
\the\everyluacode}
-
\edef\luamajorversion{\ctxwrite{_MINORVERSION}}
\edef\luaminorversion{\ctxwrite{_MAJORVERSION}}
@@ -107,35 +106,30 @@
%D
%D We provide an interface for defining instances:
-\def\s!lua{lua} \def\v!code{code} \def\!!name{name} \def\s!data{data}
+\def\s!lua {lua}
+\def\s!code {code}
+\def\s!data {data}
+\def\s!start{start}
+\def\s!stop {stop}
%D Beware: because \type {\expanded} is een convert command, the error
%D message will show \type{<inserted text>} as part of the message.
-\installcorenamespace{luacode}
+\installsystemnamespace{luacode}
-\unexpanded\def\luat_start_named_lua_code#1%
+\normalprotected\def\luat_start_named_lua_code#1%
{\begingroup
\obeylualines
\obeyluatokens
\csname\??luacode#1\endcsname}
-% \unexpanded\def\definenamedlua[#1]#2[#3]% no optional arg handling here yet / we could use numbers instead (more efficient)
-% {\ifcsname\??luacode#1\endcsname \else
-% \scratchcounter\ctxlua{lua.registername("#1","#3")}%
-% \normalexpanded{\xdef\csname\??luacode#1\endcsname##1\csname\e!stop#1\v!code\endcsname}%
-% {\noexpand\normalexpanded{\endgroup\noexpand\directlua\the\scratchcounter{_G=protect("#1\s!data")##1}}}%
-% \expandafter\edef\csname\e!start#1\v!code\endcsname {\luat_start_named_lua_code{#1}}%
-% \expandafter\edef\csname #1\v!code\endcsname##1{\noexpand\directlua\the\scratchcounter{_G=protect("#1\s!data")##1}}%
-% \fi}
-
-\unexpanded\def\definenamedlua[#1]#2[#3]% no optional arg handling here yet / we could use numbers instead (more efficient)
+\normalprotected\def\definenamedlua[#1]#2[#3]% no optional arg handling here yet / we could use numbers instead (more efficient)
{\ifcsname\??luacode#1\endcsname \else
\expandafter\chardef\csname\??luacode:#1\endcsname\ctxlua{lua.registername("#1","#3")}%
- \normalexpanded{\xdef\csname\??luacode#1\endcsname##1\csname\e!stop#1\v!code\endcsname}%
+ \normalexpanded{\xdef\csname\??luacode#1\endcsname##1\csname\s!stop#1\s!code\endcsname}%
{\noexpand\normalexpanded{\endgroup\noexpand\directlua\csname\??luacode:#1\endcsname{_G=protect("#1\s!data")##1}}}%
- \expandafter\edef\csname\e!start#1\v!code\endcsname {\luat_start_named_lua_code{#1}}%
- \expandafter\edef\csname #1\v!code\endcsname##1{\noexpand\directlua\csname\??luacode:#1\endcsname{_G=protect("#1\s!data")##1}}%
+ \expandafter\edef\csname\s!start#1\s!code\endcsname {\luat_start_named_lua_code{#1}}%
+ \expandafter\edef\csname #1\s!code\endcsname##1{\noexpand\directlua\csname\??luacode:#1\endcsname{_G=protect("#1\s!data")##1}}%
\fi}
%D We predefine a few.
@@ -221,7 +215,7 @@
%D Experimental:
-\unexpanded\def\startluaparameterset[#1]%
+\normalprotected\def\startluaparameterset[#1]%
{\begingroup
\obeylualines
\obeyluatokens
@@ -260,7 +254,7 @@
%D \ctxluacode{context("%0.5f",1/3)}
%D \stoptyping
-\unexpanded\def\ctxluacode
+\normalprotected\def\ctxluacode
{\begingroup
\obeylualines
\obeyluatokens
@@ -289,7 +283,7 @@
% \dorecurse{10000}{\ctxlua{context(" C3 ")}} \page
% \stoptext
-\installcorenamespace{ctxfunction}
+\installsystemnamespace{ctxfunction}
\normalprotected\def\startctxfunctiondefinition #1 %
{\begingroup \obeylualines \obeyluatokens \luat_start_lua_function_definition_indeed{#1}}
@@ -297,17 +291,17 @@
% \def\luat_start_lua_function_definition_indeed#1#2\stopctxfunctiondefinition
% {\endgroup\expandafter\edef\csname#1\endcsname{\noexpand\luafunction\ctxcommand{ctxfunction(\!!bs#2\!!es)}\relax}}
-\installcorenamespace{luafunction}
+\installsystemnamespace{luafunction}
\def\luat_start_lua_function_definition_indeed#1#2\stopctxfunctiondefinition
{\endgroup
\expandafter\chardef\csname\??luafunction#1\endcsname\ctxcommand{ctxfunction(\!!bs#2\!!es)}\relax
\expandafter\edef\csname#1\endcsname{\noexpand\luafunction\csname\??luafunction#1\endcsname}}
-% \unexpanded\def\setctxluafunction#1#2% experiment
+% \normalprotected\def\setctxluafunction#1#2% experiment
% {\expandafter\chardef\csname#1\endcsname#2\relax}
-\unexpanded\def\setctxluafunction#1#2% experiment
+\normalprotected\def\setctxluafunction#1#2% experiment
{\expandafter\chardef\csname\??luafunction#1\endcsname#2\relax
\expandafter\edef\csname#1\endcsname{\noexpand\luafunction\csname\??luafunction#1\endcsname}}
diff --git a/tex/context/base/lxml-ini.lua b/tex/context/base/lxml-ini.lua
new file mode 100644
index 000000000..434814b66
--- /dev/null
+++ b/tex/context/base/lxml-ini.lua
@@ -0,0 +1,131 @@
+if not modules then modules = { } end modules ['lxml-ini'] = {
+ version = 1.001,
+ comment = "this module is the basis for the lxml-* ones",
+ author = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
+ copyright = "PRAGMA ADE / ConTeXt Development Team",
+ license = "see context related readme files"
+}
+
+local xml = xml
+local lxml = lxml
+
+local scanners = tokens.scanners
+local scanstring = scanners.string
+
+scanners.lxmlid = function() return getid(scanstring()) end
+
+local implement = interfaces.implement
+
+-- lxml.id
+
+implement { name = "xmldoif", actions = lxml.doif, arguments = { "string", "string" } }
+implement { name = "xmldoifnot", actions = lxml.doifnot, arguments = { "string", "string" } }
+implement { name = "xmldoifelse", actions = lxml.doifelse, arguments = { "string", "string" } }
+implement { name = "xmldoiftext", actions = lxml.doiftext, arguments = { "string", "string" } }
+implement { name = "xmldoifnottext", actions = lxml.doifnottext, arguments = { "string", "string" } }
+implement { name = "xmldoifelsetext", actions = lxml.doifelsetext, arguments = { "string", "string" } }
+
+implement { name = "xmldoifempty", actions = lxml.doifempty, arguments = { "string", "string" } }
+implement { name = "xmldoifnotempty", actions = lxml.doifnotempty, arguments = { "string", "string" } }
+implement { name = "xmldoifelseempty", actions = lxml.doifelseempty, arguments = { "string", "string" } }
+implement { name = "xmldoifselfempty", actions = lxml.doifempty, arguments = "string" }
+implement { name = "xmldoifnotselfempty", actions = lxml.doifnotempty, arguments = "string" }
+implement { name = "xmldoifelseselfempty", actions = lxml.doifelseempty, arguments = "string" }
+
+--------- { name = "xmlcontent", actions = lxml.content, arguments = "string" }
+--------- { name = "xmlflushstripped", actions = lxml.strip, arguments = { "string", true } }
+implement { name = "xmlall", actions = lxml.all, arguments = { "string", "string" } }
+implement { name = "xmlatt", actions = lxml.att, arguments = { "string", "string" } }
+implement { name = "xmlattdef", actions = lxml.att, arguments = { "string", "string", "string" } }
+implement { name = "xmlattribute", actions = lxml.attribute, arguments = { "string", "string", "string" } }
+implement { name = "xmlattributedef", actions = lxml.attribute, arguments = { "string", "string", "string", "string" } }
+implement { name = "xmlchainatt", actions = lxml.chainattribute, arguments = { "string", "string", "string" } }
+implement { name = "xmlchainattdef", actions = lxml.chainattribute, arguments = { "string", "string", "string", "string" } }
+implement { name = "xmlchecknamespace", actions = xml.checknamespace, arguments = { "lxmlid", "string", "string" } }
+implement { name = "xmlcommand", actions = lxml.command, arguments = { "string", "string", "string" } }
+implement { name = "xmlconcat", actions = lxml.concat, arguments = { "string", "string", "string" } } -- \detokenize{#3}
+implement { name = "xmlconcatrange", actions = lxml.concatrange, arguments = { "string", "string", "string", "string", "string" } } -- \detokenize{#5}
+implement { name = "xmlcontext", actions = lxml.context, arguments = { "string", "string" } }
+implement { name = "xmlcount", actions = lxml.count, arguments = { "string", "string" } }
+implement { name = "xmldelete", actions = lxml.delete, arguments = { "string", "string" } }
+implement { name = "xmldirect", actions = lxml.direct, arguments = "string" }
+implement { name = "xmldirectives", actions = lxml.directives.setup, arguments = "string" }
+implement { name = "xmldirectivesafter", actions = lxml.directives.after, arguments = "string" }
+implement { name = "xmldirectivesbefore", actions = lxml.directives.before, arguments = "string" }
+implement { name = "xmldisplayverbatim", actions = lxml.displayverbatim, arguments = "string" }
+implement { name = "xmlelement", actions = lxml.element, arguments = { "string", "integer" } }
+implement { name = "xmlfilter", actions = lxml.filter, arguments = { "string", "string" } }
+implement { name = "xmlfilterlist", actions = lxml.filterlist, arguments = { "string", "string" } }
+implement { name = "xmlfirst", actions = lxml.first, arguments = { "string", "string" } }
+implement { name = "xmlflush", actions = lxml.flush, arguments = "string" }
+implement { name = "xmlflushcontext", actions = lxml.context, arguments = "string" }
+implement { name = "xmlflushlinewise", actions = lxml.flushlinewise, arguments = "string" }
+implement { name = "xmlflushspacewise", actions = lxml.flushspacewise, arguments = "string" }
+implement { name = "xmlfunction", actions = lxml.applyfunction, arguments = { "string", "string" } }
+implement { name = "xmlinclude", actions = lxml.include, arguments = { "string", "string", "string", true } }
+implement { name = "xmlincludeoptions", actions = lxml.include, arguments = { "string", "string", "string", "string" } }
+implement { name = "xmlinclusion", actions = lxml.inclusion, arguments = "string" }
+implement { name = "xmlinclusions", actions = lxml.inclusions, arguments = "string" }
+implement { name = "xmlindex", actions = lxml.index, arguments = { "string", "string", "integer" } }
+implement { name = "xmlinfo", actions = lxml.info, arguments = "string" }
+implement { name = "xmlinlineverbatim", actions = lxml.inlineverbatim, arguments = "string" }
+implement { name = "xmllast", actions = lxml.last, arguments = "string" }
+implement { name = "xmlload", actions = lxml.load, arguments = { "string", "string", "string", "string" } }
+implement { name = "xmlloadbuffer", actions = lxml.loadbuffer, arguments = { "string", "string", "string", "string" } }
+implement { name = "xmlloaddata", actions = lxml.loaddata, arguments = { "string", "string", "string", "string" } }
+implement { name = "xmlloaddirectives", actions = lxml.directives.load, arguments = "string" }
+implement { name = "xmlloadregistered", actions = lxml.loadregistered, arguments = { "string", "string", "string" } }
+implement { name = "xmlmain", actions = lxml.main, arguments = "string" }
+implement { name = "xmlmatch", actions = lxml.match, arguments = "string" }
+implement { name = "xmlname", actions = lxml.name, arguments = "string" }
+implement { name = "xmlnamespace", actions = lxml.namespace, arguments = "string" }
+implement { name = "xmlnonspace", actions = lxml.nonspace, arguments = { "string", "string" } }
+implement { name = "xmlpos", actions = lxml.pos, arguments = "string" }
+implement { name = "xmlraw", actions = lxml.raw, arguments = { "string", "string" } }
+implement { name = "xmlregisterns", actions = xml.registerns, arguments = { "string", "string" } }
+implement { name = "xmlremapname", actions = xml.remapname, arguments = { "lxmlid", "string","string","string" } }
+implement { name = "xmlremapnamespace", actions = xml.renamespace, arguments = { "lxmlid", "string", "string" } }
+implement { name = "xmlsave", actions = lxml.save, arguments = { "string", "string" } }
+implement { name = "xmlsetfunction", actions = lxml.setaction, arguments = { "string", "string", "string" } }
+implement { name = "xmlsetsetup", actions = lxml.setsetup, arguments = { "string", "string", "string" } }
+implement { name = "xmlsnippet", actions = lxml.snippet, arguments = { "string", "integer" } }
+implement { name = "xmlstrip", actions = lxml.strip, arguments = { "string", "string" } }
+implement { name = "xmlstripanywhere", actions = lxml.strip, arguments = { "string", "string", true, true } }
+implement { name = "xmlstripnolines", actions = lxml.strip, arguments = { "string", "string", true } }
+implement { name = "xmlstripped", actions = lxml.stripped, arguments = { "string", "string" } }
+implement { name = "xmlstrippednolines", actions = lxml.stripped, arguments = { "string", "string", true } }
+implement { name = "xmltag", actions = lxml.tag, arguments = "string" }
+implement { name = "xmltext", actions = lxml.text, arguments = { "string", "string" } }
+implement { name = "xmltobuffer", actions = lxml.tobuffer, arguments = { "string", "string", "string" } }
+implement { name = "xmltobufferverbose", actions = lxml.tobuffer, arguments = { "string", "string", "string", true } }
+implement { name = "xmltofile", actions = lxml.tofile, arguments = { "string", "string", "string" } }
+implement { name = "xmltoparameters", actions = lxml.toparameters, arguments = "string" }
+implement { name = "xmlverbatim", actions = lxml.verbatim, arguments = "string" }
+
+implement { name = "xmlstartraw", actions = lxml.startraw }
+implement { name = "xmlstopraw", actions = lxml.stopraw }
+
+implement { name = "xmlprependsetup", actions = lxml.installsetup, arguments = { 1, "string", "string" } } -- 2:*
+implement { name = "xmlappendsetup", actions = lxml.installsetup, arguments = { 2, "string", "string" } } -- 2:*
+implement { name = "xmlbeforesetup", actions = lxml.installsetup, arguments = { 3, "string", "string", "string" } } -- 2:*
+implement { name = "xmlaftersetup", actions = lxml.installsetup, arguments = { 4, "string", "string", "string" } } -- 2:*
+implement { name = "xmlprependdocumentsetup", actions = lxml.installsetup, arguments = { 1, "string", "string" } }
+implement { name = "xmlappenddocumentsetup", actions = lxml.installsetup, arguments = { 2, "string", "string" } }
+implement { name = "xmlbeforedocumentsetup", actions = lxml.installsetup, arguments = { 3, "string", "string", "string" } }
+implement { name = "xmlafterdocumentsetup", actions = lxml.installsetup, arguments = { 4, "string", "string" } }
+implement { name = "xmlremovesetup", actions = lxml.removesetup, arguments = { "string", "string" } } -- 1:*
+implement { name = "xmlremovedocumentsetup", actions = lxml.removesetup, arguments = { "string", "string" } }
+implement { name = "xmlflushdocumentsetups", actions = lxml.flushsetups, arguments = { "string", "string", "string" } } -- 2:*
+implement { name = "xmlresetdocumentsetups", actions = lxml.resetsetups, arguments = "string" }
+
+implement { name = "xmlgetindex", actions = lxml.getindex, arguments = { "string", "string" } }
+implement { name = "xmlwithindex", actions = lxml.withindex, arguments = { "string", "string", "string" } }
+
+implement { name = "xmlsetentity", actions = xml.registerentity, arguments = { "string", "string" } }
+implement { name = "xmltexentity", actions = lxml.registerentity, arguments = { "string", "string" } }
+
+implement { name = "xmlsetcommandtotext", actions = lxml.setcommandtotext, arguments = "string" }
+implement { name = "xmlsetcommandtonone", actions = lxml.setcommandtonone, arguments = "string" }
+
+implement { name = "xmlstarttiming", actions = function() statistics.starttiming(lxml) end }
+implement { name = "xmlstoptiming", actions = function() statistics.stoptiming (lxml) end }
diff --git a/tex/context/base/lxml-ini.mkiv b/tex/context/base/lxml-ini.mkiv
index a7cdff862..d82023c39 100644
--- a/tex/context/base/lxml-ini.mkiv
+++ b/tex/context/base/lxml-ini.mkiv
@@ -56,7 +56,6 @@
%def\xmlcontent #1{\ctxlxml{content("#1")}}
%def\xmlflushstripped #1{\ctxlxml{strip("#1",true)}}
\def\xmldirect #1{\ctxlxml{direct("#1")}} % in loops, not dt but root
-\def\xmlidx #1#2#3{\ctxlxml{idx("#1","#2",\number#3)}} % not ok
\def\xmlinclude #1#2#3{\ctxlxml{include("#1","#2","#3",true)}}
\def\xmlincludeoptions#1#2#3#4{\ctxlxml{include("#1","#2","#3","#4")}}
\def\xmlinclusion #1{\ctxlxml{inclusion("#1")}}
@@ -78,7 +77,7 @@
\def\xmlremapname #1#2#3#4{\ctxlua{xml.remapname(lxml.id("#1"),"#2","#3","#4")}} % element
\def\xmlremapnamespace #1#2#3{\ctxlua{xml.renamespace(lxml.id("#1"),"#2","#3")}} % document
\def\xmlchecknamespace #1#2#3{\ctxlua{xml.checknamespace(lxml.id("#1"),"#2","#3")}} % element
-\def\xmlsetfunction #1#2#3{\ctxlxml{setaction("#1",\!!bs#2\!!es,#3)}}
+\def\xmlsetfunction #1#2#3{\ctxlxml{setaction("#1",\!!bs#2\!!es,"#3")}}
\def\xmlsetsetup #1#2#3{\ctxlxml{setsetup("#1",\!!bs#2\!!es,"#3")}}
\def\xmlstrip #1#2{\ctxlxml{strip("#1","#2")}}
\def\xmlstripnolines #1#2{\ctxlxml{strip("#1","#2",true)}}
@@ -345,7 +344,6 @@
%D Experimental:
\def\xmlgetindex #1{\ctxlxml{getindex("\xmldocument","#1")}}
-\def\xmlrawindex #1{\ctxlxml{rawindex("#1")}}
\def\xmlwithindex #1#2{\ctxlxml{withindex("\xmldocument","#1","#2")}}
\def\xmlreference #1#2{\string\xmlwithindex{#1}{#2}}
diff --git a/tex/context/base/m-hemistich.mkiv b/tex/context/base/m-hemistich.mkiv
index 55fde7b92..685b1670f 100644
--- a/tex/context/base/m-hemistich.mkiv
+++ b/tex/context/base/m-hemistich.mkiv
@@ -41,21 +41,29 @@
{\scratchwidth\availablehsize}
{\scratchwidth\hemistichparameter\c!width\relax}%
\spaceskip\zeropoint\s!plus\plusone\s!fill\relax
+ \dostarttagged\t!division\currenthemistich
\hbox to \scratchwidth\bgroup
\scratchwidth.5\dimexpr\scratchwidth-\hemistichparameter\c!distance\relax
\hbox to \scratchwidth\bgroup
+ \dostarttagged\t!construct\c!lefttext
\usehemistichstyleandcolor\c!leftstyle\c!leftcolor#3%
+ \dostoptagged
\egroup
\hss
\begingroup
+ \dostarttagged\t!construct\c!separator
\usehemistichstyleandcolor\c!separatorstyle\c!separatorcolor
\hemistichparameter\c!separator
+ \dostoptagged
\endgroup
\hss
\hbox to \scratchwidth\bgroup
+ \dostarttagged\t!construct\c!righttext
\usehemistichstyleandcolor\c!rightstyle\c!rightcolor#4%
+ \dostoptagged
\egroup
\egroup
+ \dostoptagged
\endgroup}
\unexpanded\def\hemistichescaesura#1#2#3%
diff --git a/tex/context/base/m-translate.mkiv b/tex/context/base/m-translate.mkiv
index f36f9a9fb..2e6cbe950 100644
--- a/tex/context/base/m-translate.mkiv
+++ b/tex/context/base/m-translate.mkiv
@@ -22,12 +22,34 @@
local compiled, list = nil, nil
+ -- function translators.register(from,to)
+ -- local l = lpeg.P(from)/to
+ -- if not list then
+ -- list = l
+ -- else
+ -- list = list + l
+ -- end
+ -- compiled = nil
+ -- end
+ --
+ -- function translators.translate(s)
+ -- if list then
+ -- if not compiled then
+ -- compiled = lpeg.Cs((list + lpeg.P(1))^0)
+ -- end
+ -- return compiled:match(s)
+ -- else
+ -- return s
+ -- end
+ -- end
+
+ -- local function prepare()
+
function translators.register(from,to)
- local l = lpeg.P(from)/to
if not list then
- list = l
+ list = { [from] = to }
else
- list = list + l
+ list[from] = to
end
compiled = nil
end
@@ -35,7 +57,8 @@
function translators.translate(s)
if list then
if not compiled then
- compiled = lpeg.Cs((list + lpeg.P(1))^0)
+ local tree = lpeg.utfchartabletopattern(list)
+ compiled = lpeg.Cs((tree/list + lpeg.patterns.utf8character)^0 * lpeg.P(-1)) -- the P(1) is needed in order to accept non utf
end
return compiled:match(s)
else
diff --git a/tex/context/base/mlib-run.lua b/tex/context/base/mlib-run.lua
index 61089e7e6..ef4db6941 100644
--- a/tex/context/base/mlib-run.lua
+++ b/tex/context/base/mlib-run.lua
@@ -44,6 +44,8 @@ local texerrormessage = logs.texerrormessage
local starttiming = statistics.starttiming
local stoptiming = statistics.stoptiming
+local formatters = string.formatters
+
local mplib = mplib
metapost = metapost or { }
local metapost = metapost
@@ -177,11 +179,11 @@ function metapost.reporterror(result)
return true
end
-local preamble = [[
+local f_preamble = formatters [ [[
boolean mplib ; mplib := true ;
let dump = endinput ;
input "%s" ;
-]]
+]] ]
local methods = {
double = "double",
@@ -199,6 +201,20 @@ function metapost.scripterror(str)
report_metapost("script error: %s",str)
end
+-- todo: random_seed
+
+local f_textext = formatters[ [[rawtextext("%s")]] ]
+
+function metapost.maketext(s,mode)
+ if mode and mode == 1 then
+ -- report_metapost("ignoring verbatimtex: %s",s)
+ else
+ -- report_metapost("handling btex ... etex: %s",s)
+ s = gsub(s,'"','"&ditto&"')
+ return f_textext(s)
+ end
+end
+
function metapost.load(name,method)
starttiming(mplib)
method = method and methods[method] or "scaled"
@@ -207,13 +223,15 @@ function metapost.load(name,method)
math_mode = method,
run_script = metapost.runscript,
script_error = metapost.scripterror,
+ make_text = metapost.maketext,
+ extensions = 1,
}
report_metapost("initializing number mode %a",method)
local result
if not mpx then
result = { status = 99, error = "out of memory"}
else
- result = mpx:execute(format(preamble, file.addsuffix(name,"mp"))) -- addsuffix is redundant
+ result = mpx:execute(f_preamble(file.addsuffix(name,"mp"))) -- addsuffix is redundant
end
stoptiming(mplib)
metapost.reporterror(result)
@@ -317,10 +335,11 @@ function metapost.process(mpx, data, trialrun, flusher, multipass, isextrapass,
if not mp_inp[mpx] then
mp_tag = mp_tag + 1
local jobname = tex.jobname
- mp_inp[mpx] = io.open(format("%s-mplib-run-%03i.mp", jobname,mp_tag),"w")
- mp_log[mpx] = io.open(format("%s-mplib-run-%03i.log",jobname,mp_tag),"w")
+ mp_inp[mpx] = io.open(formatters["%s-mplib-run-%03i.mp"] (jobname,mp_tag,"w"))
+ mp_log[mpx] = io.open(formatters["%s-mplib-run-%03i.log"](jobname,mp_tag,"w"))
end
- local banner = format("%% begin graphic: n=%s, trialrun=%s, multipass=%s, isextrapass=%s\n\n", metapost.n, tostring(trialrun), tostring(multipass), tostring(isextrapass))
+ local banner = formatters["%% begin graphic: n=%s, trialrun=%s, multipass=%s, isextrapass=%s\n\n"](
+ metapost.n, tostring(trialrun), tostring(multipass), tostring(isextrapass))
mp_inp[mpx]:write(banner)
mp_log[mpx]:write(banner)
end
@@ -359,9 +378,9 @@ function metapost.process(mpx, data, trialrun, flusher, multipass, isextrapass,
-- d = string.gsub(d,"\r","")
if d then
if trace_graphics then
- mp_inp[mpx]:write(format("\n%% begin snippet %s\n",i))
+ mp_inp[mpx]:write(formatters["\n%% begin snippet %s\n"](i))
mp_inp[mpx]:write(d)
- mp_inp[mpx]:write(format("\n%% end snippet %s\n",i))
+ mp_inp[mpx]:write(formatters["\n%% end snippet %s\n"](i))
end
starttiming(metapost.exectime)
result = mpx:execute(d)
@@ -484,7 +503,7 @@ function metapost.directrun(formatname,filename,outputformat,astable,mpdata)
else
output = figures[v]:svg() -- (3) for prologues
end
- local outname = format("%s-%s.%s",basename,v,outputformat)
+ local outname = formatters["%s-%s.%s"](basename,v,outputformat)
report_metapost("saving %s bytes in %a",#output,outname)
io.savedata(outname,output)
end
@@ -517,7 +536,7 @@ function metapost.quickanddirty(mpxformat,data)
stopfigure = function()
end
}
- local data = format("; beginfig(1) ;\n %s\n ; endfig ;",data)
+ local data = formatters["; beginfig(1) ;\n %s\n ; endfig ;"](data)
metapost.process(mpxformat, { data }, false, flusher, false, false, "all")
if code then
return {
diff --git a/tex/context/base/mult-aux.mkiv b/tex/context/base/mult-aux.mkiv
index 1fb951048..2cc1c6399 100644
--- a/tex/context/base/mult-aux.mkiv
+++ b/tex/context/base/mult-aux.mkiv
@@ -223,14 +223,30 @@
\def#8##1{\csname\ifcsname#1#2:##1\endcsname#1#2:##1\else\s!empty\fi\endcsname}%
\def#9##1{\csname#1#2:##1\endcsname}}
+% pre-expansion can be a bit faster but handly any effect on a normal run so let's go for
+% saving some memory
+%
+% \unexpanded\def\mult_interfaces_install_parameter_handler#1#2#3#4#5#6#7#8#9% inlining \csname*\endcsname is more efficient (#3 and #6 only)
+% {\ifx#2\relax\let#2\empty\fi % it is hardly faster but produces less expansion tracing
+% %\def#3##1{\csname#4{#1#2}{##1}\endcsname}%
+% \edef#3##1{\noexpand\csname\noexpand\ifcsname#1\noexpand#2:##1\endcsname#1\noexpand#2:##1\noexpand\else\noexpand\expandafter\noexpand#5\noexpand\csname#1\noexpand#2:\s!parent\endcsname{##1}\noexpand\fi\endcsname}%
+% \edef#4##1##2{\noexpand\ifcsname##1:##2\endcsname##1:##2\noexpand\else\noexpand\expandafter\noexpand#5\noexpand\csname##1:\s!parent\endcsname{##2}\noexpand\fi}%
+% \def #5##1##2{\ifx##1\relax\s!empty\else#4{##1}{##2}\fi}% is {} needed around ##1 ?
+% \edef#6##1##2{\noexpand\csname\noexpand\ifcsname#1##1:##2\endcsname#1##1:##2\noexpand\else\noexpand\expandafter\noexpand#5\noexpand\csname#1##1:\s!parent\endcsname{##2}\noexpand\fi\endcsname}%
+% \def#7##1{\detokenize\expandafter\expandafter\expandafter{\csname#1#2:##1\endcsname}}% always root, no backtrack
+% % \def#7##1{\mult_interfaces_detokenize{\csname#4{#1#2}{##1}\endcsname}}% compact version
+% % \def#7##1{\mult_interfaces_detokenize{\csname\ifcsname#1#2:##1\endcsname#1#2:##1\else\expandafter#5\csname#1#2:\s!parent\endcsname{##1}\fi\endcsname}}%
+% \edef#8##1{\noexpand\csname\noexpand\ifcsname#1\noexpand#2:##1\endcsname#1\noexpand#2:##1\noexpand\else\s!empty\noexpand\fi\endcsname}%
+% \edef#9##1{\noexpand\csname#1#2:##1\endcsname}}
+
\unexpanded\def\installparameterhandler#1#2%
{\normalexpanded
{\mult_interfaces_install_parameter_handler
{\noexpand#1}% \??aa
\expandafter\noexpand\csname current#2\endcsname
\expandafter\noexpand\csname #2parameter\endcsname
- \expandafter\noexpand\csname do#2parameter\endcsname % or : #2_parameter_hash
- \expandafter\noexpand\csname do#2parentparameter\endcsname % or : #2_parent_parameter_hash
+ \expandafter\noexpand\csname do#2parameter\endcsname % or : #2_parameter
+ \expandafter\noexpand\csname do#2parentparameter\endcsname % or : #2_parent_parameter
\expandafter\noexpand\csname named#2parameter\endcsname
\expandafter\noexpand\csname detokenized#2parameter\endcsname
\expandafter\noexpand\csname strict#2parameter\endcsname % checked
diff --git a/tex/context/base/mult-mps.lua b/tex/context/base/mult-mps.lua
index 1275af47b..a6bebc266 100644
--- a/tex/context/base/mult-mps.lua
+++ b/tex/context/base/mult-mps.lua
@@ -66,7 +66,7 @@ return {
"outputformat", "outputtemplate", "filenametemplate", "fontmapfile", "fontmapline",
"fontpart", "fontsize", "glyph", "restoreclipcolor", "troffmode",
--
- "runscript",
+ "runscript", "maketext",
},
commands = {
"upto", "downto",
diff --git a/tex/context/base/page-brk.mkiv b/tex/context/base/page-brk.mkiv
index cf74a73c3..600819b1b 100644
--- a/tex/context/base/page-brk.mkiv
+++ b/tex/context/base/page-brk.mkiv
@@ -178,6 +178,8 @@
\global\pageornamentstate\plusone
\fi}
+% also needed: \page \doifoddpageelse\relax{\page[\v!blank,\v!right]
+
\installpagebreakmethod \v!no
{\ifconditional\c_page_breaks_enabled
\dosomebreak\nobreak
diff --git a/tex/context/base/publ-dat.lua b/tex/context/base/publ-dat.lua
index be5f1eca8..9be765985 100644
--- a/tex/context/base/publ-dat.lua
+++ b/tex/context/base/publ-dat.lua
@@ -409,21 +409,23 @@ do
local space = S(" \t\n\r\f") -- / " "
local collapsed = space^1/" "
+ ----- csletter = R("az","AZ")
+ local csletter = lpegpatterns.csletter
----- command = P("\\") * Cc("btxcmd{") * (R("az","AZ")^1) * Cc("}")
----- command = P("\\") * (Carg(1) * C(R("az","AZ")^1) / function(list,c) list[c] = (list[c] or 0) + 1 return "btxcmd{" .. c .. "}" end)
----- command = P("\\") * (Carg(1) * C(R("az","AZ")^1) * space^0 / function(list,c) list[c] = (list[c] or 0) + 1 return "btxcmd{" .. c .. "}" end)
- local command = P("\\") * (Carg(1) * C(R("az","AZ")^1) * space^0 / function(list,c) list[c] = (list[c] or 0) + 1 return "btxcmd{" .. c .. "}" end)
+ local command = P("\\") * (Carg(1) * C(csletter^1) * space^0 / function(list,c) list[c] = (list[c] or 0) + 1 return "btxcmd{" .. c .. "}" end)
local whatever = P("\\") * P(" ")^1 / " "
+ P("\\") * ( P("hbox") + P("raise") ) -- bah
local somemath = P("$") * ((1-P("$"))^1) * P("$") -- let's not assume nested math
----- character = lpegpatterns.utf8character
local any = P(1)
local done = P(-1)
- local one_l = P("{") / ""
- local one_r = P("}") / ""
- local two_l = P("{{") / ""
- local two_r = P("}}") / ""
+ -- local one_l = P("{") / ""
+ -- local one_r = P("}") / ""
+ -- local two_l = P("{{") / ""
+ -- local two_r = P("}}") / ""
local zero_l_r = P("{}") / "" * #P(1)
local special = P("#") / "\\letterhash "
@@ -460,13 +462,16 @@ do
local function do_definition(category,tag,tab,dataset)
publicationsstats.nofdefinitions = publicationsstats.nofdefinitions + 1
+ if tag == "" then
+ tag = "no-tag-set"
+ end
local fields = dataset.fields
local luadata = dataset.luadata
local hashtag = tag
if luadata[tag] then
local t = tags[tag]
local d = dataset.name
- local n = (t[n] or 0) + 1
+ local n = (t[d] or 0) + 1
t[d] = n
hashtag = tag .. "-" .. n
if trace_duplicates then
@@ -561,23 +566,27 @@ do
[2] = left * V(1) * right,
}
- local unbalanced = P {
- [1] = left * V(2) * right,
- [2] = ((escape * (left+right)) + (collapsed + 1 - (left+right))^1 + V(1))^0,
- }
+ -- local unbalanced = P {
+ -- [1] = left * V(2) * right,
+ -- [2] = ((escape * (left+right)) + (collapsed + 1 - (left+right))^1 + V(1))^0,
+ -- }
+
+ local unbalanced = (left/"") * balanced * (right/"") * P(-1)
local keyword = C((R("az","AZ","09") + S("@_:-"))^1)
local key = C((1-space-equal)^1)
- local tag = C((1-space-comma)^1)
+ local tag = C((1-space-comma)^0)
local reference = keyword
local category = C((1-space-left)^1)
local s_quoted = ((escape*single) + collapsed + (1-single))^0
local d_quoted = ((escape*double) + collapsed + (1-double))^0
local b_value = p_left * balanced * p_right
- local u_value = p_left * unbalanced * p_right -- get rid of outer { }
- local s_value = (single/"") * (u_value + s_quoted) * (single/"")
- local d_value = (double/"") * (u_value + d_quoted) * (double/"")
+ -- local u_value = p_left * unbalanced * p_right -- get rid of outer { }
+ -- local s_value = (single/"") * (u_value + s_quoted) * (single/"")
+ -- local d_value = (double/"") * (u_value + d_quoted) * (double/"")
+ local s_value = (single/"") * (unbalanced + s_quoted) * (single/"")
+ local d_value = (double/"") * (unbalanced + d_quoted) * (double/"")
local r_value = reference * Carg(1) /resolve
local somevalue = d_value + b_value + s_value + r_value
@@ -647,9 +656,9 @@ do
local compact = false -- can be a directive but then we also need to deal with newlines ... not now
- function publications.converttoxml(dataset,nice,dontstore,usedonly) -- we have fields !
+ function publications.converttoxml(dataset,nice,dontstore,usedonly,subset) -- we have fields !
local current = datasets[dataset]
- local luadata = current and current.luadata
+ local luadata = subset or (current and current.luadata)
if luadata then
statistics.starttiming(publications)
--
@@ -1011,73 +1020,86 @@ do
]]
- function savers.bib(dataset,filename,usedonly)
- local current = datasets[dataset]
- local luadata = current.luadata or { }
- local usedonly = usedonly and publications.usedentries()
- local f_start = formatters["@%s{%s,\n"]
- local f_field = formatters[" %s = {%s},\n"]
- local s_stop = "}\n\n"
- local result = { s_preamble }
+ function savers.bib(dataset,filename,tobesaved)
+ local f_start = formatters["@%s{%s,\n"]
+ local f_field = formatters[" %s = {%s},\n"]
+ local s_stop = "}\n\n"
+ local result = { s_preamble }
local n, r = 0, 1
- for tag, data in sortedhash(luadata) do
- if not usedonly or usedonly[tag] then
- r = r + 1 ; result[r] = f_start(data.category or "article",tag)
- for key, value in sortedhash(data) do
- if not privates[key] then
- r = r + 1 ; result[r] = f_field(key,value)
- end
+ for tag, data in sortedhash(tobesaved) do
+ r = r + 1 ; result[r] = f_start(data.category or "article",tag)
+ for key, value in sortedhash(data) do
+ if not privates[key] then
+ r = r + 1 ; result[r] = f_field(key,value)
end
- r = r + 1 ; result[r] = s_stop
- n = n + 1
end
+ r = r + 1 ; result[r] = s_stop
+ n = n + 1
end
report("%s entries from dataset %a saved in %a",n,dataset,filename)
io.savedata(filename,concat(result))
end
- function savers.lua(dataset,filename,usedonly)
- local current = datasets[dataset]
- local luadata = current.luadata or { }
- local usedonly = usedonly and publications.usedentries()
- if usedonly then
- local list = { }
- if usedonly then
- for key, value in next, luadata do
- if not privates[key] and usedonly[key] then
- list[key] = value
- end
- end
- else
- for key, value in next, luadata do
- if not privates[key] then
- list[key] = value
- end
+ function savers.lua(dataset,filename,tobesaved)
+ local list = { }
+ local n = 0
+ for tag, data in next, tobesaved do
+ local t = { }
+ for key, value in next, data do
+ if not privates[key] then
+ d[key] = value
end
end
- luadata = list
+ list[tag] = t
+ n = n + 1
end
- report("%s entries from dataset %a saved in %a",table.count(luadata),dataset,filename)
- table.save(filename,luadata)
+ report("%s entries from dataset %a saved in %a",n,dataset,filename)
+ table.save(filename,list)
end
- function savers.xml(dataset,filename,usedonly)
- local result, n = publications.converttoxml(dataset,true,true,usedonly) -- maybe also private? but then we need to have tag as attr
+ function savers.xml(dataset,filename,tobesaved)
+ local result, n = publications.converttoxml(dataset,true,true,false,tobesaved)
report("%s entries from dataset %a saved in %a",n,dataset,filename)
io.savedata(filename,result)
end
- function publications.save(dataset,filename,kind,usedonly)
+ function publications.save(specification)
+ local dataset = specification.dataset
+ local filename = specification.filename
+ local filetype = specification.filetype
+ local criterium = specification.criterium
statistics.starttiming(publications)
- if not kind or kind == "" then
- kind = file.suffix(filename)
+ if not filename or filename == "" then
+ report("no filename for saving given")
+ return
+ end
+ if not filetype or filetype == "" then
+ filetype = file.suffix(filename)
+ end
+ if not criterium or criterium == "" then
+ criterium = v_all
end
- local saver = savers[kind]
+ local saver = savers[filetype]
if saver then
- usedonly = usedonly ~= v_all
- saver(dataset,filename,usedonly)
+ local current = datasets[dataset]
+ local luadata = current.luadata or { }
+ local tobesaved = { }
+ local result = structures.lists.filter({criterium = criterium, names = "btx"}) or { }
+ for i=1,#result do
+ local userdata = result[i].userdata
+ if userdata then
+ local set = userdata.btxset or v_default
+ if set == dataset then
+ local tag = userdata.btxref
+ if tag then
+ tobesaved[tag] = luadata[tag]
+ end
+ end
+ end
+ end
+ saver(dataset,filename,tobesaved)
else
- report("unknown format %a for saving %a",kind,dataset)
+ report("unknown format %a for saving %a",filetype,dataset)
end
statistics.stoptiming(publications)
return dataset
diff --git a/tex/context/base/publ-fnd.lua b/tex/context/base/publ-fnd.lua
index 2457709ff..65c025f22 100644
--- a/tex/context/base/publ-fnd.lua
+++ b/tex/context/base/publ-fnd.lua
@@ -19,7 +19,7 @@ local publications = publications
local tonumber, next, type = tonumber, next, type
local find = string.find
-local P, R, S, C, Cs, Cp, Cc, Carg, V = lpeg.P, lpeg.R, lpeg.S, lpeg.C, lpeg.Cs, lpeg.Cp, lpeg.Cc, lpeg.Carg, lpeg.V
+local P, R, S, C, Cs, Cp, Cc, Carg, Ct, V = lpeg.P, lpeg.R, lpeg.S, lpeg.C, lpeg.Cs, lpeg.Cp, lpeg.Cc, lpeg.Carg, lpeg.Ct, lpeg.V
local lpegmatch, lpegpatterns = lpeg.match, lpeg.patterns
local concat = table.concat
@@ -143,10 +143,10 @@ local percent = P("-") / "%%"
local word = Cs(lpegpatterns.unquoted + lpegpatterns.argument + valid)
local range = P("<") * space^0 * C((1-space)^1) * space^1 * C((1-space- P(">"))^1) * space^0 * P(">")
-local f_key_fld = formatters[" local kf_%s = get(entry,%q) \n if kf_%s then kf_%s = lower(kf_%s) end"]
-local f_key_set = formatters[" local ks_%s = get(entry,%q,categories)\n if ks_%s then ks_%s = lower(ks_%s) end"]
-local f_number_fld = formatters[" local nf_%s = tonumber(get(entry,%q))"]
-local f_number_set = formatters[" local ns_%s = tonumber(get(entry,%q,categories))"]
+local f_key_fld = formatters[" local kf_%s = get(entry,%q) \n if kf_%s then kf_%s = lower(kf_%s) end"]
+local f_key_set = formatters[" local ks_%s = get(entry,%q,categories)\n if ks_%s then ks_%s = lower(ks_%s) end"]
+local f_number_fld = formatters[" local nf_%s = tonumber(get(entry,%q))"]
+local f_number_set = formatters[" local ns_%s = tonumber(get(entry,%q,categories))"]
local f_fld_exact = formatters["(kf_%s == %q)"]
local f_set_exact = formatters["(ks_%s == %q)"]
@@ -161,7 +161,7 @@ local function test_key_value(keys,where,key,first,last)
if not key or key == "" then
return "(false)"
elseif key == "*" then
- last = "^.*" .. topattern(lowercase(last)) .. ".*$"
+ last = "^.*" .. topattern(lowercase(last)) .. ".*$" -- todo: make an lpeg
return f_all_match(last)
elseif first == false then
-- exact
@@ -197,7 +197,7 @@ end
local p_compare = P { "all",
all = (V("one") + V("operator") + V("nested") + C(" "))^1,
- nested = C("(") * V("all") * C(")"),
+ nested = C("(") * V("all") * C(")"), -- C really needed?
operator = C("and")
+ C("or")
+ C("not"),
@@ -216,11 +216,27 @@ local p_compare = P { "all",
range = range,
}
-local p_combine = space^0
- * (P(",")/" or ")
- * space^0
-
-local pattern = Cs((P("match")/"" * space^0 * p_compare + p_combine)^1)
+-- local p_combine = space^0 * (P(",")/" or ") * space^0
+
+-- local pattern = Cs((P("match")/"" * space^0 * p_compare + p_combine)^1)
+
+local comma = P(",")
+local p_spaces = space^0
+local p_combine = p_spaces * comma * p_spaces / " or "
+local p_expression = P("match")/"" * Cs(p_compare)
+ + Carg(1)
+ * Cc("")
+ * Cc("tag")
+ * Cc(false)
+ * (
+ P("tag") * p_spaces * P("(") * Cs((1-S(")")-space)^1) * p_spaces * P(")")
+ + p_spaces * Cs((1-space-comma)^1) * p_spaces
+ ) / test_key_value
+
+local pattern = Cs {
+ [1] = V(2) * (p_combine * V(2))^0,
+ [2] = p_expression,
+}
-- -- -- -- -- -- -- -- -- -- -- -- --
-- -- -- -- -- -- -- -- -- -- -- -- --
@@ -233,6 +249,14 @@ function publications.anywhere(entry,str) -- helpers
end
end
+-- todo: use an environment instead of
+
+-- table={
+-- { "match", "((kf_editor and find(kf_editor,\"^.*braslau.*$\")))" },
+-- { "hash", "foo1234" },
+-- { "tag", "bar5678" },
+-- }
+
local f_template = string.formatters[ [[
local find = string.find
local lower = characters.lower
@@ -246,46 +270,6 @@ return function(entry)
end
]] ]
------ function compile(expr,start)
--- local function compile(dataset,expr)
--- local keys = { }
--- -- local expression = lpegmatch(pattern,expr,start,keys)
--- local expression = lpegmatch(pattern,expr,1,keys)
--- if trace_match then
--- report("compiling expression: %s",expr)
--- end
--- local definitions = { }
--- local anywhere = false
--- for k, v in next, keys do
--- if k == "anywhere" then
--- anywhere = true
--- else
--- definitions[#definitions+1] = v
--- end
--- end
--- if not anywhere or #definitions == 0 then
--- report("invalid expression: %s",expr)
--- elseif trace_match then
--- for i=1,#definitions do
--- report("% 3i : %s",i,definitions[i])
--- end
--- end
--- definitions = concat(definitions,"\n")
--- local code = f_template(definitions,expression)
--- if trace_match then
--- report("generated code: %s",code)
--- end
--- code = loadstring(code)
--- if type(code) == "function" then
--- code = code()
--- if type(code) == "function" then
--- return code
--- end
--- end
--- report("invalid expression: %s",expr)
--- return false
--- end
-
local function compile(dataset,expr)
local keys = { }
-- local expression = lpegmatch(pattern,expr,start,keys)
@@ -309,11 +293,11 @@ local function compile(dataset,expr)
if trace_match then
report("generated code: %s",code)
end
- code = loadstring(code)
- if type(code) == "function" then
- code = code()
- if type(code) == "function" then
- return code
+ local finder = loadstring(code) -- use an environment
+ if type(finder) == "function" then
+ finder = finder()
+ if type(finder) == "function" then
+ return finder, code
end
end
report("invalid expression: %s",expr)
@@ -344,7 +328,8 @@ end
-- test("match(*:foo)")
-- test("match(*:*)")
-local check = P("match") -- * space^0 * Cp()
+local trigger = (P("match") + P("tag")) * p_spaces * P("(")
+local check = (1-trigger)^0 * trigger
local function finder(dataset,expression)
local found = lpegmatch(check,expression) and compile(dataset,expression) or false
@@ -373,7 +358,11 @@ function publications.search(dataset,expression)
for i=1,#ordered do
local entry = ordered[i]
if find(entry) then
- target[entry.tag] = entry
+ local tag = entry.tag
+ if not target[tag] then
+ -- we always take the first
+ target[tag] = entry
+ end
end
end
return target
diff --git a/tex/context/base/publ-imp-apa.lua b/tex/context/base/publ-imp-apa.lua
index 5182e016d..18360d527 100644
--- a/tex/context/base/publ-imp-apa.lua
+++ b/tex/context/base/publ-imp-apa.lua
@@ -359,7 +359,8 @@ categories.manual = {
"address",
"subtitle", "file",
"editionset", "month", "year",
- "doi", "note", "isbn"
+ "doi", "note", "isbn",
+-- "abstract",
},
}
diff --git a/tex/context/base/publ-imp-apa.mkvi b/tex/context/base/publ-imp-apa.mkvi
index 256636325..87a9c522b 100644
--- a/tex/context/base/publ-imp-apa.mkvi
+++ b/tex/context/base/publ-imp-apa.mkvi
@@ -29,12 +29,6 @@
% The APA style sorts the unnumbered rendered list by authoryear
-% Hans: should we be using or not using \c!, \s! and \v! ??
-
-% Sure: not using \c! and v! would mean that only the english interface is
-% supported and \s! saves some bytes (only within the setups). I'll deal with
-% that in the end.
-
\definebtxrendering
[apa]
[\c!specification=apa,
@@ -48,55 +42,14 @@
\c!distance=.5\emwidth,
\c!margin=3\emwidth]
-% The sameauthor feature may not be APA compliant
-% (there is nothing in the manual cited above).
-% It can be removed using the command:
-% \resetsetups [apa:list:sameauthor]
-
-% Or texdefinition?
-
-\startsetups [apa:list:sameauthor]
- \fastsetup{apa:list:sameauthor:rule}
-\stopsetups
-
-\startsetups [apa:list:sameauthor:rule]
- \blackrule
- [\c!width=\dimexpr\listparameter\c!margin-\interwordspace\relax,
- \c!height=1.5\linewidth]% are you sure you want to inconsistent with the rest? happens nowhere!
-\stopsetups
-
-\startsetups [apa:list:sameauthor:\v!empty]% it's not a space
- \kern\dimexpr\listparameter\c!margin-\interwordspace\relax
-\stopsetups
-
-\startsetups [apa:list:sameauthor:ditto] % horrible !
- \inframed
- [\c!width=\dimexpr\listparameter\c!margin-\interwordspace\relax,
- \c!frame=\v!off,
- \c!align=\v!middle]
- {\doubleprime}
-\stopsetups
-
% set ALL specific APA compliant values
-% Note that fallback is apa, default, then root
\definebtx
[apa]
- [\c!default=, % no fallback on default rendering
- \c!namesep={,\space},
- \c!lastnamesep={,\nobreakspace\textampersand\space}, % comma separated list
- \c!finalnamesep={\nobreakspace\textampersand\space}, % last of two, no comma!
- \c!firstnamesep=\space,
+ [\c!default=default,
\c!otherstext={\space\btxlabeltext{apa:others}},
- \c!juniorsep={\space},
- \c!vonsep={\space},
- \c!initialsep={\space},
- \c!surnamesep={,\space},
- \c!surnameinitialsep={,\space},
- \c!surnamefirstnamesep={,\space},
- \c!pubsep={,\space},
- \c!lastpubsep={,\space\btxlabeltext{apa:and}\space},% not btxcomma?
- \c!finalpubsep={\space\btxlabeltext{apa:and}\space}]
+ %c!journalconversion=\v!normal,
+ \c!monthconversion=\v!month]
\definebtx
[apa:list]
@@ -104,9 +57,10 @@
[\c!otherstext={,\nobreakspace\textellipsis\space},
\c!etallimit=7,
\c!etaldisplay=6,
- %c!journalconversion=\v!normal,
- \c!monthconversion=\v!month,
- \c!authorconversion=invertedshort]
+ \c!authorconversion=invertedshort,
+ \c!separator:names:2={,\space}, % aka namesep - in this namespace
+ \c!separator:names:3={,\nobreakspace\textampersand\space}, % comma separated list
+ \c!separator:names:4= {\nobreakspace\textampersand\space}] % last of two, no comma!
% The following are similar to default, but inherit from apa:list
@@ -282,18 +236,13 @@
\c!etaldisplay=1, % TODO: when 2-4, show all first time, etaldisplay subsequently...
\c!authorconversion=\v!name,
\c!sorttype=authoryear,
- \c!compress=\v!no,
- \c!inbetween=\space,
- \c!range=\endash,
- \c!left=,
- \c!middle=,
- \c!right=]
+ \c!separator:names:2={,\space},
+ \c!separator:names:3={,\space\btxlabeltext{apa:and}\space}, % not \textampersand
+ \c!separator:names:4= {\space\btxlabeltext{apa:and}\space}] % not \textampersand
\definebtx
[apa:cite:author]
[apa:cite]
- [\c!lastnamesep={,\space\btxlabeltext{apa:and}\space}, % not \textampersand
- \c!finalnamesep={\space\btxlabeltext{apa:and}\space}] % not \textampersand
% The following are similar to default, but inherit from apa:cite
@@ -303,20 +252,18 @@
[\c!compress=\v!yes,
\c!left={(},
\c!right={)},
- \c!inbetween={,\space},
- \c!pubsep={;\space},
- \c!lastpubsep={;\space},
- \c!finalpubsep={;\space}]
+ \c!inbetween={,\space}]
+
+\definebtx
+ [apa:cite:default]
+ [apa:cite:authoryear]
\definebtx
[apa:cite:authoryears]
[apa:cite:authoryear]
[\c!left=,
\c!right=,
- \c!inbetween={\space},
- \c!pubsep={;\space},
- \c!lastpubsep={;\space},
- \c!finalpubsep={;\space}]
+ \c!inbetween={\space}]
\definebtx
[apa:cite:authornum]
@@ -351,18 +298,18 @@
\definebtx
[apa:cite:year]
[apa:cite]
- [\c!pubsep={,\space},
- \c!lastpubsep={,\space\btxlabeltext{apa:and}\space}, % not \textampersand
- \c!finalpubsep={\space\btxlabeltext{apa:and}\space}, % not \textampersand
+ [\c!separator:2={,\space}, % :0 and :1 - between items of a list
+ \c!separator:3={,\space\btxlabeltext{apa:and}\space}, % not \textampersand
+ \c!separator:4= {\space\btxlabeltext{apa:and}\space}, % not \textampersand
\c!compress=\v!yes,
\c!sorttype=\v!default]
\definebtx
[apa:cite:title]
[apa:cite]
- [\c!pubsep={,\space},
- \c!lastpubsep={,\space\btxlabeltext{apa:and}\space}, % not \textampersand
- \c!finalpubsep={\space\btxlabeltext{apa:and}\space}, % not \textampersand
+ [\c!separator:2={,\space}, % :0 and :1 - between items of a list
+ \c!separator:3={,\space\btxlabeltext{apa:and}\space}, % not \textampersand
+ \c!separator:4= {\space\btxlabeltext{apa:and}\space}, % not \textampersand
\c!command={\language[\currentbtxlanguage]}, % BAH
\c!style=\v!italic]
@@ -391,9 +338,9 @@
[apa:cite]
[\c!left=,
\c!right=,
- \c!pubsep={,\space},
- \c!lastpubsep={,\space\btxlabeltext{apa:and}\space}, % not \textampersand
- \c!finalpubsep={\space\btxlabeltext{apa:and}\space}] % not \textampersand
+ [\c!separator:2={,\space}, % :0 and :1 - between items of a list
+ \c!separator:3={,\space\btxlabeltext{apa:and}\space}, % not \textampersand
+ \c!separator:4= {\space\btxlabeltext{apa:and}\space}] % not \textampersand
\definebtx
[apa:cite:pages]
@@ -441,18 +388,28 @@
[\c!compress=\v!yes,
\c!left={[},
\c!right={]},
- \c!pubsep={,},
- \c!lastpubsep={,},
- \c!finalpubsep={,}]
+ \c!separator:2={,}, % no space
+ \c!separator:3=\btxparameter{\c!separator:2},
+ \c!separator:4=\btxparameter{\c!separator:2}]
\definebtx
[apa:cite:textnum]
[apa:cite:num]
[\c!left={Ref.\nbsp},
\c!right=,
- \c!pubsep={,},
- \c!lastpubsep={\space\btxlabeltext{apa:and}\space},
- \c!finalpubsep={\space\btxlabeltext{apa:and}\space}]
+ \c!separator:2={,\space},
+ \c!separator:3={\space\btxlabeltext{apa:and}\space},
+ \c!separator:4={\space\btxlabeltext{apa:and}\space}]
+
+\definebtx
+ [apa:cite:entry]
+ [apa:cite]
+ [\c!left=,
+ \c!right=,
+ \c!inbetween={\space},
+ \c!separator:2={;\space},
+ \c!separator:3=\btxparameter{\c!separator:2},
+ \c!separator:4=\btxparameter{\c!separator:2}]
%D Sometimes we have verbose injections in an entry and these can be language
%D dependent, so we use labels.
@@ -476,10 +433,10 @@
apa:mastersthesis={Master's thesis},
apa:phdthesis={Doctoral dissertation},
apa:technicalreport={Tech. Rep.}, % Technical report
- apa:supplement={Suppl.}, % Supplement
+ apa:supplement={Suppl.}, % Supplement (not used?)
apa:patent=Patent,
apa:Author=Author,
- apa:Translator={Trans.}, % Translator(s)
+ apa:Translator={Trans.}, % Translator(s) (not used?)
apa:Advanced={Advanced online publication},
apa:Retrieved={Available from}, % {Retrieved from},
apa:In=In]
@@ -611,46 +568,6 @@
% cite setups
-% as we don't fallback on default (no sane person will render the titles
-% differently so it's a bit over the top):
-
-\startsetups btx:apa:cite:empty
- \fastsetup{\s!btx:\s!cite:\s!empty}
-\stopsetups
-\startsetups btx:apa:cite:unknown
- \fastsetup{\s!btx:\s!cite:\s!unknown}
-\stopsetups
-\startsetups btx:apa:cite:author
- \fastsetup{\s!btx:\s!cite:author}
-\stopsetups
-\startsetups btx:apa:cite:authoryear
- \fastsetup{\s!btx:\s!cite:author}
-\stopsetups
-\startsetups btx:apa:cite:authoryears
- \fastsetup{\s!btx:\s!cite:author}
-\stopsetups
-\startsetups btx:apa:cite:authornum
- \fastsetup{\s!btx:\s!cite:author}
-\stopsetups
-\startsetups btx:apa:cite:title
- \fastsetup{\s!btx:\s!cite:\s!normal}
-\stopsetups
-\startsetups btx:apa:cite:booktitle
- \fastsetup{btx:apa:cite:title}
-\stopsetups
-\startsetups btx:apa:cite:entry
- \fastsetup{\s!btx:\s!cite:\s!normal}
-\stopsetups
-\startsetups btx:apa:cite:num
- \fastsetup{\s!btx:\s!cite:range}
-\stopsetups
-\startsetups btx:apa:cite:textnum
- \fastsetup{\s!btx:\s!cite:range}
-\stopsetups
-\startsetups btx:apa:cite:year
- \fastsetup{\s!btx:\s!cite:range}
-\stopsetups
-
\startsetups btx:apa:cite:author:year
\texdefinition{\s!btx:\s!cite:concat}
\ifx\currentbtxfirst\empty
@@ -709,6 +626,35 @@
\fi
\stopsetups
+% The sameauthor feature may not be APA compliant
+% (there is nothing in the manual cited above).
+% It can be removed using the command:
+% \resetsetups [apa:list:sameauthor]
+
+% Or texdefinition?
+
+\startsetups [apa:list:sameauthor]
+ \fastsetup{apa:list:sameauthor:rule}
+\stopsetups
+
+\startsetups [apa:list:sameauthor:rule]
+ \blackrule
+ [\c!width=\dimexpr\listparameter\c!margin-\interwordspace\relax,
+ \c!height=1.5\linewidth]% are you sure you want to inconsistent with the rest? happens nowhere!
+\stopsetups
+
+\startsetups [apa:list:sameauthor:\v!empty]% it's not a space
+ \kern\dimexpr\listparameter\c!margin-\interwordspace\relax
+\stopsetups
+
+\startsetups [apa:list:sameauthor:ditto] % horrible !
+ \inframed
+ [\c!width=\dimexpr\listparameter\c!margin-\interwordspace\relax,
+ \c!frame=\v!off,
+ \c!align=\v!middle]
+ {\doubleprime}
+\stopsetups
+
%D Instead of texdefinitions without arguments, we could have used setups but in my
%D editor (hh, scite) the commands stand out better. It also saves an additional
%D component in the name (e.g. common:) because commands and setups have a different
@@ -853,7 +799,7 @@
\texdefinition{btx:apa:author-or-editor} {editor}
}
\btxspace
- \btxstartstyleandcolor[apa:list:title] % NOT :\currentbtxcategory !
+ \btxstartstyleandcolor[apa:list:title]
\texdefinition{btx:apa:composed-title} {booktitle}
\btxstopstyleandcolor
\btxperiod
@@ -917,8 +863,9 @@
}
\stoptexdefinition
+ % this could be simplified!
+
\starttexdefinition btx:apa:journal-volume-number-pages
- % this could be simplified!
\btxdoif {journal} {
\btxspace
\btxstartstyleandcolor[apa:list:journal]
@@ -1020,8 +967,9 @@
\definebreakpoint [doi][-][nleft=3,type=1]
\definebreakpoint [doi][.][nleft=3,type=1]
+% use \btxentry here?
+
\starttexdefinition btx:apa:url
- % use \btxentry here?
\btxspace
\btxlabeltext{apa:Retrieved}
\btxspace
@@ -1039,8 +987,9 @@
\endgroup
\stoptexdefinition
+% use \btxentry here?
+
\starttexdefinition btx:apa:doi
- % use \btxentry here?
\btxspace
\begingroup
\setbreakpoints[doi]
@@ -1056,8 +1005,9 @@
\endgroup
\stoptexdefinition
+% also issn - see publ-imp-apa.lua
+
\starttexdefinition btx:apa:isbn
- % also issn - see publ-imp-apa.lua
\btxdoif {isbn} {
\btxleftparenthesis
\WORD{\btxfoundname{isbn}}:\btxspace
@@ -1121,8 +1071,10 @@
% Required fields: title, year
% Optional fields: editor, publisher, subtitle, series, volume, number, month, organization, doi, url, issn, note
+% needs to be tuned...
+
\startsetups btx:apa:list:periodical
- \fastsetup{btx:apa:list:article} % needs to be tuned...
+ \fastsetup{btx:apa:list:article}
\stopsetups
% National and international standards issued by a standards body
diff --git a/tex/context/base/publ-imp-aps.lua b/tex/context/base/publ-imp-aps.lua
index 1530bc09d..c143e648b 100644
--- a/tex/context/base/publ-imp-aps.lua
+++ b/tex/context/base/publ-imp-aps.lua
@@ -30,43 +30,27 @@ local specification = {
-- vons Last, Jrs, First
-- Vons, Last, Jrs, First
--
- author = "author",
+ author = "author", -- interpreted as name(s)
editor = "author",
artist = "author",
interpreter = "author",
composer = "author",
producer = "author",
- doi = "url",
- url = "url",
- page = "pagenumber",
+ doi = "url", -- an external link
+ url = "url",
+ page = "pagenumber", -- number or range: f--t
pages = "pagenumber",
- keywords = "keyword",
+ volume = "range",
+ number = "range",
+ keywords = "keyword", -- comma|-|separated list
+ year = "number",
},
--
-- categories with their specific fields
--
categories = {
--
- -- the following fields are for documentation and testing purposes
- --
- ["demo-a"] = {
- sets = {
- author = { "author", "institution", "organization" },
- doi = { "doi", "url" },
- },
- required = { "author", "title", "year", "note", "doi" },
- optional = { "subtitle", "file" },
- },
- ["demo-b"] = {
- sets = {
- authors = { "author", "institution", "organization" },
- doi = { "doi", "url" },
- },
- required = { "authors", "title", "year", "note", "doi" },
- optional = { "subtitle", "file" },
- },
- --
- -- more categories are added below
+ -- categories are added below
--
},
}
@@ -78,7 +62,8 @@ local generic = {
-- allows the substitution of an alternate field.
--
-- note that anything can get assigned a doi or be available online.
- doi = { "doi", "url" },
+ doi = { "doi", "url" },
+ editionset = { "edition", "volume", "number", "pages" },
}
-- Note that the APS specification allows an additional field "collaboration"
@@ -90,7 +75,7 @@ local generic = {
-- all other fields will be ignored.
-- Sets contain either/or in order of precedence.
---
+--
-- For a category *not* defined here yet present in the dataset, *all* fields
-- are taken as optional. This allows for flexibility in the addition of new
-- categories.
@@ -130,7 +115,7 @@ categories.magazine = {
optional = {
"collaboration",
"subtitle", "type", "file",
- "volume",
+ "number",
"month", "day",
"doi", "note", "isbn"
},
@@ -182,16 +167,16 @@ categories.standard = {
categories.book = {
sets = {
- author = { "author", "editor", "publisher", "title" },
- edition = { "edition", "volume", "number", "pages" },
- doi = generic.doi,
+ author = { "author", "editor", "publisher", "title" },
+ editionset = generic.editionset,
+ doi = generic.doi,
},
required = { "author" },
optional = {
"collaboration",
"year", "month", "day",
"subtitle", "type", "file",
- "edition", "series",
+ "editionset", "series",
"address",
"doi", "note", "isbn"
},
@@ -201,9 +186,9 @@ categories.book = {
categories.inbook = {
sets = {
- author = { "author", "editor", "publisher", "title", "chapter" },
- edition = { "edition", "volume", "number", "pages" },
- doi = generic.doi,
+ author = { "author", "editor", "publisher", "title", },
+ editionset = generic.editionset,
+ doi = generic.doi,
},
required = {
"author",
@@ -212,64 +197,69 @@ categories.inbook = {
optional = {
"collaboration",
"subtitle", "type", "file",
- "edition", "series",
+ "booktitle",
+ -- "chapter",
+ "editionset", "series",
"month",
"address",
"doi", "note", "isbn"
},
}
--- a work that is printed and bound, but without a named publisher or sponsoring institution.
+-- a book having its own title as part of a collection.
+-- (like inbook, but we here make booktitle required)
-categories.booklet = {
+categories.incollection = {
sets = {
- author = { "author", "title" },
- doi = generic.doi,
+ author = { "author", "editor", "publisher", "title", },
+ editionset = generic.editionset,
+ doi = generic.doi,
},
required = {
- "author"
+ "author",
+ "booktitle",
+ "year",
},
optional = {
"collaboration",
- "year", "month",
"subtitle", "type", "file",
+ "editionset", "series",
+ "chapter",
+ "month",
"address",
- "howpublished",
"doi", "note", "isbn"
- },
+ },
}
--- a part of a book having its own title.
+-- a work that is printed and bound, but without a named publisher or sponsoring institution.
-categories.incollection = {
+categories.booklet = {
sets = {
- author = { "author", "editor", "publisher", "title" },
- edition = { "edition", "volume", "number", "pages" },
- doi = generic.doi,
+ author = { "author", "title", },
+ publisher = { "howpublished" }, -- no "publisher"!
+ doi = generic.doi,
},
required = {
- "author",
- "booktitle",
- "year",
+ "author"
},
optional = {
+ "publisher",
"collaboration",
+ "year", "month",
"subtitle", "type", "file",
- "month",
- "edition", "series",
- "chapter",
"address",
"doi", "note", "isbn"
- },
+ },
}
-- the proceedings of a conference.
categories.proceedings = {
sets = {
- author = { "editor", "publisher", "title" },
- edition = { "edition", "volume", "number", "pages" },
- doi = generic.doi,
+ author = { "editor", "organization", "publisher", "title" }, -- no "author"!
+ publisher = { "publisher", "organization" },
+ editionset = generic.editionset,
+ doi = generic.doi,
},
required = {
"author",
@@ -277,10 +267,11 @@ categories.proceedings = {
},
optional = {
"collaboration",
+ "publisher",
"subtitle", "file",
- "edition", "series",
+ "editionset", "series",
"month",
- "address", "organization",
+ "address",
"doi", "note", "isbn"
},
}
@@ -347,9 +338,10 @@ categories.phdthesis = categories.mastersthesis
categories.techreport = {
sets = {
- -- no "edition"!
- edition = { "type", "volume", "number", "pages" },
- doi = generic.doi,
+ author = { "author", "institution", "publisher", "title" },
+ publisher = { "publisher", "institution", },
+ editionset = { "type", "volume", "number", "pages" }, -- no "edition"!
+ doi = generic.doi,
},
required = {
"author",
@@ -359,10 +351,11 @@ categories.techreport = {
},
optional = {
"collaboration",
+ "publisher",
+ "address",
"subtitle", "file",
- "edition", -- set, not field!
+ "editionset",
"month",
- "address",
"doi", "note", "isbn"
},
}
@@ -371,18 +364,21 @@ categories.techreport = {
categories.manual = {
sets = {
- edition = { "edition", "volume", "number", "pages" },
- doi = generic.doi,
+ author = { "author", "organization", "publisher", "title" },
+ publisher = { "publisher", "organization", },
+ editionset = generic.editionset,
+ doi = generic.doi,
},
required = {
"title"
},
optional = {
+ "author", "publisher",
"collaboration",
+ "address",
"subtitle", "file",
- "author", "address", "organization",
- "edition", "month", "year",
- "doi", "note", "isbn"
+ "editionset", "month", "year",
+ "doi", "note", "isbn",
},
}
@@ -390,21 +386,26 @@ categories.manual = {
categories.patent = {
sets = {
+ author = { "author", "assignee", },
+ publisher = { "publisher", "assignee", },
+ year = { "year", "yearfiled", },
+ month = { "month", "monthfiled", },
+ day = { "day", "dayfiled", },
doi = generic.doi,
},
required = {
"nationality",
"number",
- "year", "yearfiled"
+ "year",
},
optional = {
"type",
--check this: "language",
+ "author", "publisher",
"collaboration",
- "author", "assignee",
"title", "subtitle", "file",
"address",
- "day", "dayfiled", "month", "monthfiled",
+ "day", "month",
"doi", "note"
},
}
diff --git a/tex/context/base/publ-imp-aps.mkvi b/tex/context/base/publ-imp-aps.mkvi
index dde6a289a..996f78592 100644
--- a/tex/context/base/publ-imp-aps.mkvi
+++ b/tex/context/base/publ-imp-aps.mkvi
@@ -1,10 +1,6 @@
-\endinput
-
-% todo
-
%D \module
%D [ file=publ-imp-aps,
-%D version=2013.12.12,
+%D version=2015.03.22,
%D title=APS bibliography style,
%D subtitle=Publications,
%D author=Alan Braslau and Hans Hagen,
@@ -31,105 +27,73 @@
%D }
%D \stopTEX
-% set all APS compliant values (may be redundant but we do not count on defaults.)
+\definebtxrendering
+ [aps]
+ [\c!specification=aps]
+
+\setupbtxlist
+ [aps]
+ [alternative=paragraph,
+ width=auto,
+ distance=0pt]
-\setupbtxrendering
- [sorttype=, % num ?
- numbering=yes]
+% set ALL specific APS compliant values
-\definebtxlistvariant
+\definebtx
[aps]
- [\c!namesep={,\space},
- \c!lastnamesep={,\space and\space},
- \c!finalnamesep={,\space and\space},
- \c!firstnamesep=\space,
- \c!otherstext={\space\btxlabeltext{\currentbtxspecification:others}},
- \c!juniorsep=\space,
- \c!vonsep=\space,
- \c!initialsep=\space, % between initials and lastname
- %\c!initialssep=\space, % between multiple initials % todo
- %\c!initialsterminator={.}, % todo
- \c!surnamesep={,\space},
- \c!surnameinitialsep={,\space},
- \c!surnamefirstnamesep={,\space},
+ [\c!default=default,
+ \c!otherstext={\space\btxlabeltext{aps:others}},
\c!etallimit=10,
- \c!etaldisplay=\btxlistvariantparameter\c!etallimit,
- %\c!journalconversion=\v!normal,
+ \c!etaldisplay=\btxparameter\c!etallimit,
+ %c!journalconversion=\v!normal,
\c!monthconversion=\v!month,
- \c!authorconversion=normalshort]
-
-\definebtxlistvariant
- [author]
-
-\definebtxlistvariant
- [editor]
- [author]
-
-% like \setupbtxlistvariant above but not exactly...
-
-\setupbtxcitevariant
- [\c!alternative=num,
- \c!namesep=\btxlistvariantparameter\c!namesep,
- \c!lastnamesep=\btxlistvariantparameter\c!lastnamesep,
- \c!finalnamesep={\nobreakspace\textampersand\space}, % no comma!
- \c!firstnamesep=\btxlistvariantparameter\c!firstnamesep,
- \c!otherstext=\btxlistvariantparameter\c!otherstext,
- \c!juniorsep=\btxlistvariantparameter\c!juniorsep,
- \c!vonsep=\btxlistvariantparameter\c!vonsep,
- \c!initialsep=\btxlistvariantparameter\c!initialsep,
- %\c!initialssep=\btxlistvariantparameter\c!initialssep,
- %\c!initialsterminator=\btxlistvariantparameter\c!initialsterminator,
- \c!surnamesep=\btxlistvariantparameter\c!surnamesep,
- \c!surnameinitialsep=\btxlistvariantparameter\c!surnameinitialsep,
- \c!surnamefirstnamesep=\btxlistvariantparameter\c!surnamefirstnamesep,
- \c!etallimit=\btxlistvariantparameter\c!etallimit,
- \c!etaldisplay=\btxlistvariantparameter\c!etaldisplay,
- % \c!monthconversion=\btxlistvariantparameter\c!monthconversion,
- \c!authorconversion=\btxlistvariantparameter\c!authorconversion,
- \c!interaction=\v!start,
- % \c!setups=btx:cite:initialize,
- \c!pubsep={,\space},
- \c!lastpubsep={\space\btxlabeltext{\currentbtxspecification:and}\space},
- \c!finalpubsep={\space\btxlabeltext{\currentbtxspecification:and}\space},
- \c!sorttype=,
- \c!compress=\v!no,
- \c!inbetween=\space,
- \c!range=\endash,
- \c!left={[},
- \c!middle=,
- \c!right={]}]
+ \c!separator:names:2={,\space},
+ \c!separator:names:3={,\space\btxlabeltext{aps:and}\space}, % not \textampersand
+ \c!separator:names:4= {\space\btxlabeltext{aps:and}\space}] % not \textampersand
+
+\definebtx
+ [aps:list]
+ [aps]
+ [\c!authorconversion=normalshort,
+ placetitle=\v!yes] % can be set to no for journal, for example.
+ % this does not work - see below? (would title=yes be acceptable?)
+
+% The following are similar to default, but inherit from aps:list
-\definebtxcitevariant
- [author]
- [\c!lastnamesep={,\nobreakspace\textampersand\space},
- \c!finalnamesep={\nobreakspace\textampersand\space}, % no comma!
- \c!authorconversion=\v!name]
-
-\definebtxcitevariant
- [authoryear]
- [\c!compress=\v!yes,
- \c!inbetween={,\space},
- \c!left={(},
- \c!right={)},
- \c!pubsep={;\space},
- \c!lastpubsep={;\space},
- \c!finalpubsep={;\space},
- \c!lastnamesep={,\space\btxlabeltext{\currentbtxspecification:and}\space},
- \c!finalnamesep={\space\btxlabeltext{\currentbtxspecification:and}\space}, % no comma!
- \c!authorconversion=\v!name]
-
-\definebtxcitevariant
- [authoryears]
- [authoryear]
- [\c!left=,
- \c!inbetween={\space(},
- \c!pubsep={);\space},
- \c!lastpubsep={);\space},
- \c!finalpubsep={);\space},
- \c!lastnamesep={,\space\btxlabeltext{\currentbtxspecification:and}\space},
- \c!finalnamesep={\space\btxlabeltext{\currentbtxspecification:and}\space}, % no comma!
- \c!authorconversion=\v!name]
+\definebtx
+ [aps:list:author]
+ [aps:list]
+\definebtx
+ [aps:list:editor]
+ [aps:list:author]
+
+\definebtx
+ [aps:list:suffix]
+ [aps:list]
+
+\definebtx
+ [aps:list:url]
+ [aps:list]
+
+\definebtx
+ [aps:list:doi]
+ [aps:list]
+
+\definebtx
+ [aps:list:invertedshort]
+ [aps:list]
+
+\definebtx
+ [aps:list:short]
+ [aps:list]
+
+% This is for numbering=yes
+\definebtx
+ [aps:list:yes]
+ [aps:list]
+ [\c!command={\high}, % also, left, right, stopper, style, color...
+ \c!align=flushright]
%D In order to be able to get journals expanded (or normalized or abbreviated) you need
%D to load a list:
@@ -138,6 +102,303 @@
%D \btxloadjournallist[journals.txt] % the jabref list
%D \stoptyping
+% TODO
+
+\definebtx
+ [aps:list:journal]
+ [\c!style=\v!italic]
+ %command=\btxexpandedjournal] % btxabbreviatedjournal
+
+\definebtx
+ [aps:list:title]
+ [\c!style=\v!italic,
+ \c!command=\Word]
+
+\definebtx
+ [aps:list:title:article]
+ [aps:list:title]
+ [\c!style=] % journal is set in italics
+
+\definebtx
+ [aps:list:title:magazine]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:newspaper]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:periodical]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:standard]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:book]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:inbook]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:incollection]
+ [aps:list:title]
+ [\c!style=] % booktitle is set in italics
+
+\definebtx
+ [aps:list:title:proceedings]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:inproceedings]
+ [aps:list:title]
+ [\c!style=] % booktitle is set in italics
+
+\definebtx
+ [aps:list:title:conference]
+ [aps:list:title]
+ [\c!style=] % booktitle is set in italics
+
+\definebtx
+ [aps:list:title:thesis]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:phdthesis]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:mastersthesis]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:booklet]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:manual]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:techreport]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:unpublished]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:patent]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:electronic]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:other]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:misc]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:title:literal]
+ [aps:list:title]
+
+\definebtx
+ [aps:list:type]
+ [\c!command=\Word]
+
+% We define [page] settings in the aps namespace, inheriting the root
+% settings, in order to eventually allow for modifications without touching
+% root.
+
+\definebtx
+ [aps:page]
+ [\s!page]
+
+\definebtx
+ [aps:page:list]
+ [aps:page]
+ [\c!command={\wordright}]
+
+\definebtx
+ [aps:cite]
+ [aps:list]
+ [\c!authorconversion=\v!name]
+
+\definebtx
+ [aps:cite:author]
+ [aps:cite]
+
+% The following are similar to default, but inherit from aps:cite
+
+\definebtx
+ [aps:cite:authoryear]
+ [aps:cite:author]
+ [\c!compress=\v!yes,
+ \c!left={(},
+ \c!right={)},
+ \c!inbetween={,\space}]
+
+\definebtx
+ [aps:cite:authoryears]
+ [aps:cite:authoryear]
+ [\c!left=,
+ \c!right=,
+ \c!inbetween={\space}]
+
+\definebtx
+ [aps:cite:authornum]
+ [aps:cite:author]
+ [\c!left={(},
+ \c!right={)},
+ \c!sorttype=authornum]
+
+\definebtx
+ [aps:cite:authorref]
+ [aps:cite:authornum]
+
+\definebtx
+ [aps:cite:author:num] % todo
+ [aps:cite:authornum]
+ [\c!left={[},
+ \c!right={]}]
+
+\definebtx
+ [aps:cite:author:year] % todo
+ [aps:cite:authoryear]
+ [\c!left=,
+ \c!right=]
+
+\definebtx
+ [aps:cite:author:years] % todo
+ [aps:cite:authoryears]
+ [\c!inbetween=,
+ \c!left=(,
+ \c!right=)]
+
+\definebtx
+ [aps:cite:year]
+ [aps:cite]
+ [\c!compress=\v!yes]
+
+\definebtx
+ [aps:cite:title]
+ [aps:cite]
+ [\c!command={\language[\currentbtxlanguage]}, % BAH
+ \c!style=\v!italic]
+
+\definebtx
+ [aps:cite:booktitle]
+ [aps:cite:title]
+
+\definebtx
+ [aps:cite:tag]
+ [aps:cite]
+ [\c!left={[},
+ \c!right={]}]
+
+\definebtx
+ [aps:cite:key]
+ [aps:cite:tag]
+
+\definebtx
+ [aps:cite:serial]
+ [aps:cite]
+ [\c!left={[},
+ \c!right={]}]
+
+\definebtx
+ [aps:cite:page]
+ [aps:cite]
+ [\c!left=,
+ \c!right=,
+ [\c!separator:2={,\space}, % :0 and :1 - between items of a list
+ \c!separator:3={,\space\btxlabeltext{aps:and}\space}, % not \textampersand
+ \c!separator:4= {\space\btxlabeltext{aps:and}\space}] % not \textampersand
+
+\definebtx
+ [aps:cite:pages]
+ [aps:cite:page]
+
+\definebtx
+ [aps:cite:keywords]
+ [aps:cite]
+ [\c!left={(},
+ \c!right={)}]
+
+\definebtx
+ [aps:cite:invertedshort]
+ [aps:cite]
+
+\definebtx
+ [aps:cite:short]
+ [aps:cite]
+ [\c!left={[},
+ \c!right={]}]
+
+\definebtx
+ [aps:cite:category]
+ [aps:cite]
+ [\c!left={[},
+ \c!right={]}]
+
+\definebtx
+ [aps:cite:type]
+ [aps:cite:category]
+
+\definebtx
+ [aps:cite:url]
+ [aps:cite]
+ [\c!left={[},
+ \c!right={]}]
+
+\definebtx
+ [aps:cite:doi]
+ [aps:cite:url]
+
+\definebtx
+ [aps:cite:num]
+ [aps:cite]
+ [\c!compress=\v!yes,
+ \c!left={[},
+ \c!right={]},
+ %\c!left=, % TODO: PRB uses superscript references...
+ %\c!right=, % and after punctuation, PRA, C, D, E, and L are before!
+ %\c!command={\high},
+ \c!separator:2={,}, % no space
+ \c!separator:3=\btxparameter{\c!separator:2},
+ \c!separator:4=\btxparameter{\c!separator:2}]
+
+\definebtx
+ [aps:cite:default]
+ [aps:cite:num]
+
+\definebtx
+ [aps:cite:textnum]
+ [aps:cite:num]
+ [\c!left={Ref.\nbsp},
+ \c!command=,
+ \c!separator:2={,\space},
+ \c!separator:3={\space\btxlabeltext{aps:and}\space},
+ \c!separator:4={\space\btxlabeltext{aps:and}\space}]
+
+\definebtx
+ [aps:cite:entry]
+ [aps:cite]
+ [\c!left=,
+ \c!right=,
+ \c!inbetween={\space},
+ \c!separator:2={;\space},
+ \c!separator:3=\btxparameter{\c!separator:2},
+ \c!separator:4=\btxparameter{\c!separator:2}]
+
%D Sometimes we have verbose injections in an entry and these can be language
%D dependent, so we use labels.
%D
@@ -146,222 +407,332 @@
\setupbtxlabeltext
[en]
- [aps:mastersthesis={Master's thesis},
- aps:phdthesis={PhD thesis},
+ [aps:and=and,
+ aps:number={no.},
+ aps:edition={ed.},
+ aps:Editor={Ed.},
+ aps:Editors={Eds.},
+ aps:Volume={Vol.},
+ aps:Volumes={Vols.},
+ aps:others={et al.},
+ aps:page={p.},
+ aps:pages={pp.},
+ aps:mastersthesis={Master's thesis},
+ aps:phdthesis={Doctoral dissertation},
aps:technicalreport={Tech. Rep.}, % Technical report
- aps:supplement={Suppl.}, % Supplement
+ aps:supplement={Suppl.}, % Supplement (not used?)
aps:patent=Patent,
- aps:Translator={Trans.}, % Translator(s)
- aps:Editor={Ed.}, % Editor
- aps:Editors={Eds.}, % Editors
- aps:edition={ed.}, % edition
- aps:volume=volume, % used?
- aps:Volume={Vol.}, % Volume
- aps:Volumes={Vols.}, % Volumes
- aps:number=number,
- aps:Number={No.}, % Number
- aps:nd={n.d.}, % no date
- aps:in=in,
- aps:of=of,
- aps:In=In,
- aps:Part={Pt.}, % Part
- aps:p={p.},
- aps:pp={pp.},
- aps:pages=pages,
- aps:and=and,
- aps:period={. },
aps:Author=Author,
- aps:Reference={Ref.},
- aps:References={Refs.},
- aps:Advanced={to be published},
+ aps:Translator={Trans.}, % Translator(s) (not used?)
+ aps:inpress={in press},
+ aps:tobe={to be published},
+ aps:unpublished={unpublished},
+ aps:Advanced={Advanced online publication},
aps:Retrieved={Available from}, % {Retrieved from},
- aps:others={\it et al.}]
+ aps:In=In]
+
+% Check this (google translate!!):
+
+\setupbtxlabeltext
+ [nl]
+ [aps:and=en,
+ aps:number={nr.},
+ aps:edition={ed.}, % editie
+ aps:Editor=Editor, % Ed./Eds.
+ aps:Editors=Editors,
+ aps:Volume={Vol.},
+ aps:Volumes={Vols.},
+ aps:others={et al.},
+ aps:page={p.},
+ aps:pages={pp.},
+ aps:mastersthesis=Masterproef,
+ aps:phdthesis=Proefschrift,
+ aps:technicalreport={Technisch rapport}, % Technical report
+ aps:supplement=Supplement,
+ aps:patent=Octrooi,
+ aps:Author=Auteur,
+ aps:Translator=Vertaler,
+ aps:inpress={in press}, % CHECK THESE!
+ aps:tobe={worden gepubliceerd},
+ aps:unpublished={onuitgegeven},
+ aps:Advanced={Geavanceerde online publicatie},
+ aps:Retrieved={Beschikbaar vanaf}, % {Ontvangen van},
+ aps:In=In]
\setupbtxlabeltext
[fr]
- [aps:mastersthesis={Thèse de master (DEA, DESS, master)},
- aps:phdthesis={Thèse de doctorat},
- aps:technicalreport={Rapport technique},
- aps:supplement=Supplément,
- aps:patent=Brevet,
- aps:Translator=Traducteur,
+ [aps:and=et,
+ aps:others={et al.},
+ aps:number={n\high{o}},
+ aps:edition={édition},
aps:Editor=Éditeur,
aps:Editors=Éditeurs,
- aps:edition=édition,
- aps:volume=volume,
aps:Volume=Volume,
aps:Volumes=Volumes,
- aps:number=numéro,
- aps:Number=Numéro,
- aps:nd={s.d.} % sans date
- aps:in=dans,
- aps:of=de,
- aps:In=Dans,
- aps:Part=Partie,
- aps:p={p.},
- aps:pp={pp.},
- aps:pages=pages,
- aps:and=et,
- aps:period={. },
+ aps:others={et al.},
+ aps:page={p.},
+ aps:pages={pp.},
+ aps:mastersthesis={Thèse de master (DEA, DESS, master)},
+ aps:phdthesis={Thèse de doctorat},
+ aps:technicalreport={Rapport technique},
+ aps:supplement=Supplément,
+ aps:patent=Brevet,
aps:Author=Auteur,
- aps:Reference={Réf.},
- aps:References={Réfs.},
- aps:Advanced={à être publié},
+ aps:Translator=Traducteur,
+ aps:inpress={sous impression},
+ aps:tobe={à paraître},
+ aps:unpublished={inédit}, % pour un livre
+ aps:Advanced={Publication en ligne anticipée},
aps:Retrieved={Disponible à}, % {Téléchargé de},
- aps:others={\it et al.}]
+ aps:In=Dans]
\setupbtxlabeltext
[de]
- [aps:mastersthesis={Masterarbeit},
+ [aps:and=und,
+ aps:number={nr.},
+ aps:edition=Auf\/lage,
+ aps:Editor=Herausgeber, % Hrsg./Hg.
+ aps:Editors=Herausgeber,
+ aps:Volume=Band, % Bd.
+ aps:Volumes={Bände},
+ aps:others={et al.},
+ aps:page={S.},
+ aps:pages={S.},
+ aps:mastersthesis={Masterarbeit},
aps:phdthesis={Dissertation},
aps:technicalreport={Technischer Bericht},
aps:supplement={Beilage}, % Supplement
aps:patent=Patent,
- aps:Translator={Übersetzer}, % Übers.
- aps:Editor=Herausgeber, % Hrsg./Hg.
- aps:Editors=Herausgeber,
- aps:edition=Auf\/lage,
- aps:volume=Band, % Bd.
- aps:Volume=Band,
- aps:Volumes={Bände},
- aps:number=Nummer,
- aps:Number={Nr.},
- aps:nd={o.D.}, % ohne Datum (mostly: o.J. / ohne Jahr)
- aps:in=in,
- aps:of=von,
- aps:In=In,
- aps:Part=Teil,
- aps:p={S.},
- aps:pp={S.},
- aps:pages=Seiten,
- aps:and=und,
- aps:period={. },
aps:Author=Autor,
- aps:Reference={Ref.},
- aps:References={Ref.},
- aps:Advanced={veröffentlicht werden},
+ aps:Translator={Übersetzer}, % Übers.
+ aps:inpress={in der Presse}, % CHECK THESE!
+ aps:tobe={veröffentlicht werden},
+ aps:unpublished={unveröffentlicht},
+ aps:Advanced={Erweiterte Online-Publikation},
aps:Retrieved={heruntergeladen von},
- aps:others={\it et al.}]
+ aps:In=In]
% thanks: Andrea Valle
\setupbtxlabeltext
[it]
- [aps:mastersthesis={Tesi di laurea},
+ [aps:and=e,
+ aps:number={nº},
+ aps:edition={ed.}, % edizione
+ aps:Editor={A cura di},
+ aps:Editors={A cura di},
+ aps:Volume={Vol.}, % Volume
+ aps:Volumes={Vol.}, % Volumi
+ aps:others={et al.},
+ aps:page={p.},
+ aps:pages={pp.},
+ aps:mastersthesis={Tesi di laurea},
aps:phdthesis={Tesi di dottorato},
aps:technicalreport={Relazione tecnica},
aps:supplement={Supplemento},
aps:patent=Brevetto,
- aps:Translator={Trad.}, % Translator(s)
- aps:Editor={A cura di},
- aps:Editors={A cura di},
- aps:edition={ed.},
- aps:volume=volume,
- aps:Volume={Vol.},
- aps:Volumes={Vol.},
- aps:number=numero,
- aps:Number=Numero,
- aps:nd={s.d.},
- aps:in=in,
- aps:of=di,
- aps:In=In,
- aps:Part=Parte,
- aps:p={p.},
- aps:pp={pp.},
- aps:pages=pagine,
- aps:and=e,
- aps:period={. },
aps:Author=Autore,
- aps:Reference={Rif.},
- aps:References={Rif.},
- aps:Advanced={da pubblicare},
+ aps:Translator={Trad.}, % Translator(s)
+ aps:inpress={in press}, % CHECK THESE!
+ aps:tobe={da pubblicare},
+ aps:unpublished={inedito},
+ aps:Advanced={Pre-pubblicazione on line},
aps:Retrieved={Accessible online},
- aps:others={\it et al.}]
+ aps:In=In]
-%D Instead of texdefinitions without arguments, we could have used setups but in my
-%D editor (hh, scite) the commands stand out better. It also saves an additional
-%D component in the name (e.g. common:) because commands and setups have a different
-%D namespace, so similar calls don't clash. Performance of definitions is somewhat
-%D better.
+\setupbtxlabeltext
+ [es]
+ [aps:and=y,
+ aps:number={nº},
+ aps:edition={ed.}, % edición
+ aps:Editor=Editor, % Ed./Eds.
+ aps:Editors=Editores,
+ aps:Volume={Vol.}, % Volumen
+ aps:Volumes={Vols.}, % Volúmenes
+ aps:others={et al.},
+ aps:page={p.},
+ aps:pages={pp.},
+ aps:mastersthesis={Tesis de maestría},
+ aps:phdthesis={Tesis doctoral},
+ aps:technicalreport={Informe técnico},
+ aps:supplement=Suplemento,
+ aps:patent=Patente,
+ aps:Author=Autor,
+ aps:Translator=Traductor,
+ aps:inpress={en prensa}, % CHECK THESE!
+ aps:tobe={que se publicará},
+ aps:unpublished={inédito},
+ aps:Advanced={Publicación en línea avanzada},
+ aps:Retrieved={Disponible desde}, % {Obtenido de},
+ aps:In=En]
+
+% cite setups
+
+\startsetups btx:aps:nd
+ \doifelse {\currentbtxcategory} {journal} {
+ \btxlabeltext{aps:tobe}
+ } {
+ \doifelse {\currentbtxcategory} {book} {
+ \btxlabeltext{aps:inpress}
+ } {
+ \btxlabeltext{aps:unpublished}
+ }
+ }
+\stopsetups
-%D \btxdoif... and \btxflush rely on the definitions in publ-imp-aps.lua:
-%D fields that are not listed as required nor optional are IGNORED.
+\startsetups btx:aps:cite:author:year
+ \texdefinition{\s!btx:\s!cite:concat}
+ \ifx\currentbtxfirst\empty
+ \fastsetup{btx:aps:nd}
+ \else
+ \texdefinition {\s!btx:\s!cite:inject} {
+ \btxcitereference
+ \currentbtxfirst
+ }
+ \ifx\currentbtxsecond\empty \else
+ \btxparameter\v!inbetween
+ \texdefinition {\s!btx:\s!cite:inject} {
+ \currentbtxsecond
+ }
+ \fi
+ \ifx\currentbtxthird\empty \else
+ \texdefinition {\s!btx:\s!cite:inject} {
+ \currentbtxthird
+ }
+ \fi
+ \fi
+\stopsetups
-% First some helpers:
+\startsetups btx:aps:cite:author:years
+ \fastsetup{btx:aps:cite:author:year}
+\stopsetups
-\starttexdefinition btx:aps:inject #link #content
+\startsetups [btx:aps:page:list]
+ \fastsetup{\s!btx:\s!page:concat}
+ \ifx\currentbtxlastpage\empty
+ \btxlabeltext{aps:page}
+ \else
+ \btxlabeltext{aps:pages}
+ \fi
+ \btxnbsp
\ifconditional\btxinteractive
- \ifx\currentbtxinternal\empty
- #content
- \else
+ \goto {
+ \currentbtxfirstpage
+ } [
+ internal(\currentbtxfirstinternal)
+ ]
+ \ifx\currentbtxlastpage\empty \else
+ \btxparameter\c!pageconnector
\goto {
- #content
+ \currentbtxlastpage
} [
- #link
+ internal(\currentbtxlastinternal)
]
\fi
\else
- #content
+ \currentbtxfirstpage
+ \ifx\currentbtxlastpage\empty \else
+ \btxparameter\c!pageconnector
+ \currentbtxlastpage
+ \fi
\fi
-\stoptexdefinition
+\stopsetups
-\starttexdefinition btx:aps:title
- \btxdoif {file} {
- % we make the title active, opening file
- \texdefinition{btx:aps:inject} {url(file:\btxflush{file})}
- }
- {
- \begingroup
- \it
- \btxflush{Word -> title}
- \btxdoif {subtitle} {
+%D Instead of texdefinitions without arguments, we could have used setups but in my
+%D editor (hh, scite) the commands stand out better. It also saves an additional
+%D component in the name (e.g. common:) because commands and setups have a different
+%D namespace, so similar calls don't clash. Performance of definitions is somewhat
+%D better.
+
+%D We use "texdefinitions" (with eventual arguments) for helpers that are used
+%D in the rendering "setups" defined for each category below.
+
+%D Note that \btxdoif... and \btxflush rely on the definitions in
+%D publ-imp-aps.lua: fields that are not listed as required nor optional are
+%D IGNORED. We also make heavy use of the notion of sets - comma-separated lists
+%D of alternative fields to be used in hierarchal order. For example:
+%D author = { "author", "editor", "publisher", "title" }, will return the
+%D author field if it exists; if not, the editor field will be returned, if it
+%D exists; if not, the publisher field will be returned, if it exists; if not,
+%D the title field will be returned, it it exists; if not, nothing will be
+%D returned. In lua syntax, it can be understood as
+%D author or editor or publisher or title or ""
+
+\starttexdefinition btx:aps:composed-title #title
+ \begingroup
+ \language[\currentbtxlanguage]
+ \btxusecommand[aps:list:title:\currentbtxcategory] {
+ \btxflush{#title}
+ \btxdoif {sub#title} {
\btxcolon
- \btxflush{Word -> subtitle}
- }
- \italiccorrection
- \endgroup
- \doifnot {\currentbtxcategory} {techreport} {
- \doifnotmode {btx:aps:thesis} {
- \btxdoif{type} {
- \btxleftbracket
- \btxflush{Word -> type}
- \btxrightbracket
- }
+ \btxflush{sub#title}
}
}
- }
+ \endgroup
\stoptexdefinition
-% need for a global option to activate or inhibit....
+\starttexdefinition btx:aps:title
+ \setmode{btx:aps:title-placed}
+ % we make the title active, opening file
+ \btxdoifelse {file} {
+ \texdefinition{btx:format:inject}
+ {url(file:\btxflush{file})}
+ {
+ \btxstartstyleandcolor [aps:list:title:\currentbtxcategory]
+ \texdefinition{btx:aps:composed-title}{title}
+ \btxstopstyleandcolor
+ }
+ } {
+ \btxstartstyleandcolor [aps:list:title:\currentbtxcategory]
+ \texdefinition{btx:aps:composed-title}{title}
+ \btxstopstyleandcolor
+ }
+\stoptexdefinition
-\starttexdefinition btx:aps:optional-title
- \btxdoif {title} {
- \btxdoif {file} {
- % we make the title active, opening file
- \texdefinition{btx:aps:inject} {url(file:\btxflush{file})}
- }
- {
- \quotation{%
- \btxflush{Word -> title}
- \btxdoif {subtitle} {
- \btxcolon
- \btxflush{Word -> subtitle}
- }
+\starttexdefinition btx:aps:title-if-not-placed
+ \doifmodeelse {btx:aps:title-placed} {
+ \resetmode{btx:aps:title-placed}
+ } {
+ %does not work (need to check the setting)
+ %\doifelse{\btxparameter{placetitle}}\v!yes {
+ \btxdoif {title} {
+ \texdefinition {btx:aps:title}
+ \btxcomma
}
- \btxcomma
- }
+ %}
}
\stoptexdefinition
-\starttexdefinition btx:aps:editor
- \btxflush{editor}
- \btxleftparenthesis
- \btxsingularorplural {editor} {
- \btxlabeltext{aps:Editor}
+\starttexdefinition btx:aps:year
+ \btxdoifelse {year} {
+ \btxflush{year}
} {
- \btxlabeltext{aps:Editors}
+ \fastsetup{btx:aps:nd}
+ }
+\stoptexdefinition
+
+%\starttexdefinition btx:aps:suffixedyear
+% \btxdoifelse {year} {
+% \btxflush{year}
+% \btxflush{suffix}
+% } {
+% \fastsetup{btx:aps:nd}
+% }
+%\stoptexdefinition
+
+\starttexdefinition btx:aps:author-or-editor #author
+ \btxdoif {#author} {
+ \btxflush{#author}
+ \doif {\btxfoundname{#author}} {editor} {
+ \btxleftparenthesis
+ \btxsingularorplural {editor} {
+ \btxlabeltext{aps:Editor}
+ } {
+ \btxlabeltext{aps:Editors}
+ }
+ \btxrightparenthesisperiod
+ }
}
- \btxrightparenthesisperiod
\stoptexdefinition
\starttexdefinition btx:aps:author
@@ -375,98 +746,137 @@
}
\stoptexdefinition
-\starttexdefinition btx:aps:italic #field
- \begingroup
- \it
- \btxflush{#field}
- \italiccorrection
- \endgroup
-\stoptexdefinition
-
-\starttexdefinition btx:aps:bold #field
- \begingroup
- \bf
- \btxflush{#field}
- \endgroup
-\stoptexdefinition
-
-\starttexdefinition btx:aps:editor-in- #title
- \btxdoifelse {editor} {
+\starttexdefinition btx:aps:editor-in
+ \btxdoif {booktitle} {
\btxlabeltext{aps:In}
- \btxspace
- \texdefinition{btx:aps:editor}
- \btxdoif {#title} {
- \texdefinition{btx:aps:italic}{Word -> #title}
- }
- } {
- \btxdoif {#title} {
- \btxlabeltext{aps:In}
+ \doifnot {\btxfoundname{author}} {editor} {
\btxspace
- \texdefinition{btx:aps:italic}{Word -> #title}
+ \texdefinition{btx:aps:author-or-editor} {editor}
}
+ \btxspace
+ \btxstartstyleandcolor[aps:list:title]
+ \texdefinition{btx:aps:composed-title} {booktitle}
+ \btxstopstyleandcolor
+ \btxcomma
}
\stoptexdefinition
\starttexdefinition btx:aps:editionset
- \btxdoifelse {edition} {
- \btxspace
- \doif {\currentbtxcategory} {techreport} {
- \btxdoifelse {type} {
- \btxflush{Word -> type}
- } {
- \btxlabeltext{aps:technicalreport}
- }
- \setmode{btx:aps:comma}
- }
- \doif {\btxfoundname{edition}} {edition} {
- \doifmode {btx:aps:comma}
- {\btxcomma}
- \btxflush{edition}
- \btxspace
- \btxlabeltext{aps:edition}
- \setmode{btx:aps:comma}
- }
- \btxdoif {volume} {
- \doifmode {btx:aps:comma}
- {\btxcomma}
- \btxoneorrange {volume} {
- \btxlabeltext{aps:Volume}
- } {
- \btxlabeltext{aps:Volumes}
+ \doif {\currentbtxcategory} {techreport} {
+ \btxdoifelse {type} {
+ \btxusecommand[aps:list:type] {
+ \btxflush{type}
}
- \btxspace
- \btxflush{volume}
- \setmode{btx:aps:comma}
- }
- \btxdoif {number} {
- \doifmode {btx:aps:comma}
- {\btxcomma}
- \btxlabeltext{aps:Number}
- \btxspace
- \btxflush{number}
- \setmode{btx:aps:comma}
+ } {
+ \btxlabeltext{aps:technicalreport}
}
- \btxdoif {pages} {
- \doifmode {btx:aps:comma}
- {\btxcomma}
- \btxoneorrange {pages} {
- \btxlabeltext{aps:p}
- } {
- \btxlabeltext{aps:pp}
- }
- \btxspace
- \btxflush{pages}
+ \btxcomma
+ }
+ \btxdoif {volume} {
+ \btxoneorrange {volume} {
+ \btxlabeltext{aps:Volume}
+ } {
+ \btxlabeltext{aps:Volumes}
}
- \btxperiod
- } {
- \doif {\currentbtxcategory} {techreport} {
- \btxleftparenthesis
- \btxlabeltext{aps:technicalreport}
- \btxrightparenthesisperiod
+ \btxspace
+ \btxflush{volume}
+ \btxcomma
+ }
+ \btxdoif {number} {
+ \btxlabeltext{aps:number}
+ \btxspace
+ \btxflush{number}
+ \btxcomma
+ }
+ \btxdoif {edition} {
+ \btxflush{edition}
+ \btxspace
+ \btxlabeltext{aps:edition}
+ \btxcomma
+ }
+ \btxdoif {pages} {
+ \btxoneorrange {pages} {
+ \btxlabeltext{aps:page}
+ } {
+ \btxlabeltext{aps:pages}
}
+ \btxnbsp
+ \btxflush{pages}
+ \btxcomma
}
\stoptexdefinition
+%% this could be simplified!
+%\starttexdefinition btx:aps:journal-volume-number-pages
+% \btxdoif {journal} {
+% \btxspace
+% \btxstartstyleandcolor[aps:list:journal]
+% \btxusecommand[aps:list:journal] {
+% \btxflush{journal}
+% }
+% \btxstopstyleandcolor
+% \btxdoif {volume} {
+% \btxcomma
+% \btxstartstyleandcolor[aps:list:journal]
+% \btxflush{volume}
+% \btxstopstyleandcolor
+% \btxdoifnot {number} {
+% \btxdoifelse {pages}
+% {\btxcomma}
+% {\btxperiod}
+% }
+% }
+% \btxdoif {number} {
+% \btxdoifelse {volume} {
+% \removeunwantedspaces(
+% } {
+% \btxcomma
+% \btxleftparenthesis
+% }
+% \btxflush{number}
+% \btxdoifelse {pages}
+% {\btxrightparenthesiscomma}
+% {\btxrightparenthesisperiod}
+% }
+% \btxdoif {pages} {
+% \btxdoifnot {volume} {
+% \btxdoifnot {number} {
+% \btxcomma
+% }
+% }
+% \doif {\currentbtxcategory} {newspaper} {
+% \btxoneorrange {pages} {
+% \btxlabeltext{aps:page}
+% } {
+% \btxlabeltext{aps:pages}
+% }
+% \btxnbsp
+% }
+% \btxflush{pages}
+% \btxperiod
+% }
+% \doifnot {\currentbtxcategory} {newspaper} {
+% \btxdoifnot {volume} {
+% \btxdoifnot {number} {
+% \btxdoifnot {pages} {
+% \btxdoifelse {doi} {
+% \btxperiod
+% \btxlabeltext{aps:Advanced}
+% \btxperiod
+% } {
+% \btxdoif {url} {
+% \btxperiod
+% \btxlabeltext{aps:Advanced}
+% \btxperiod
+% }
+% }
+% }
+% }
+% }
+% }
+% }
+%\stoptexdefinition
+
\starttexdefinition btx:aps:journal-volumeset-year
\btxdoif {journal} {
% expandedjournal abbreviatedjournal
@@ -492,24 +902,44 @@
\btxflush{pages}
}
\btxleftparenthesis
- \btxdoifelse {year} {
- \btxflush{year}
- } {
- \btxlabeltext{aps:Advanced}
- }
+ \fastsetup{btx:aps:year}
\btxrightparenthesis
\btxperiod
}
\stoptexdefinition
+\starttexdefinition btx:aps:publisher-wherefrom-year
+ \removeunwantedspaces
+ \removepunctuation
+ \btxleftparenthesis
+ \btxflush{publisher}
+ \btxdoifelse {address} {
+ \btxdoif {publisher} {
+ \btxcomma
+ }
+ \btxflush{address}
+ \btxdoif {country} {
+ \btxcomma
+ \btxflush{country}
+ }
+ \btxcomma
+ } {
+ \btxdoif {publisher} {
+ \btxcomma
+ }
+ }
+ \fastsetup{btx:aps:year}
+ \btxrightparenthesis
+\stoptexdefinition
+
\definebreakpoints[doi]
\definebreakpoint [doi][:][nleft=3,type=1]
\definebreakpoint [doi][/][nleft=3,type=1]
\definebreakpoint [doi][-][nleft=3,type=1]
\definebreakpoint [doi][.][nleft=3,type=1]
+% use \btxentry here?
\starttexdefinition btx:aps:url
- % use \btxentry here?
\btxspace
\btxlabeltext{aps:Retrieved}
\btxspace
@@ -527,8 +957,8 @@
\endgroup
\stoptexdefinition
+% use \btxentry here?
\starttexdefinition btx:aps:doi
- % use \btxentry here?
\btxspace
\begingroup
\setbreakpoints[doi]
@@ -544,143 +974,128 @@
\endgroup
\stoptexdefinition
+% also issn - see publ-imp-aps.lua
\starttexdefinition btx:aps:isbn
- % also issn - see publ-imp-aps.lua
\btxdoif {isbn} {
\btxleftparenthesis
\WORD{\btxfoundname{isbn}}:\btxspace
+ \setbreakpoints[doi]
\btxflush{isbn}
\btxrightparenthesis
}
\stoptexdefinition
\starttexdefinition btx:aps:note
- % grouping could indeed be useful for note.
\btxdoif {note} {
- \btxspace
- {\btxflush{note}}
+ \btxleftparenthesis
+ \btxflush{note}
+ \btxrightparenthesis
}
\stoptexdefinition
-\starttexdefinition btx:aps:url-note-doi
+\starttexdefinition btx:aps:url-doi-note
\doif {\btxfoundname{doi}} {url} {
\texdefinition{btx:aps:url}
}
\texdefinition{btx:aps:isbn}
- \texdefinition{btx:aps:note}
\doif {\btxfoundname{doi}} {doi} {
\texdefinition{btx:aps:doi}
}
+ \texdefinition{btx:aps:note}
\removeunwantedspaces
\stoptexdefinition
-\starttexdefinition btx:aps:publisher-wherefrom-year
- \btxleftparenthesis
- \btxflush{publisher}
- \btxdoifelse {address} {
- \btxdoif {publisher} {
- \btxcomma
- }
- \btxflush{address}
- \btxdoif {country} {
- \btxcomma
- \btxflush{country}
- }
- \btxcomma
- } {
- \btxdoif {publisher} {
- \btxcomma
- }
- }
- \btxdoifelse {year} {
- \btxflush{year}
- } {
- \btxlabeltext{aps:Advanced}
- }
- \btxrightparenthesis
-\stoptexdefinition
-
-% Then by category
+% Then setups, by category
% An article from a journal
% Required fields: author or editor or title, journal, (year).
% Optional fields: volume, number, pages, type, doi, url, note.
% Note that bibtex (and tools) do not include editor (e.g. special issue or section)
-\startsetups btx:aps:article
+\startsetups btx:aps:list:article
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:optional-title}
+ \texdefinition{btx:aps:title-if-not-placed}
\texdefinition{btx:aps:journal-volumeset-year}
\texdefinition{btx:aps:url-note-doi}
\stopsetups
% An article from a magazine.
% Required fields: author or title, journal, (year).
-% Optional fields: volume, number, pages, type, month, day, doi, url, note.
+% Optional fields: number, pages, type, month, day, doi, url, note.
-\startsetups btx:aps:magazine
- \texdefinition{btx:aps:author}
- \texdefinition{btx:aps:optional-title}
- \texdefinition{btx:aps:journal-volumeset-year}
- \texdefinition{btx:aps:url-note-doi}
+\startsetups btx:aps:list:magazine
+ \fastsetup{btx:aps:list:article}
\stopsetups
% An article from a newspaper.
% Required fields: author or title, journal, (year).
% Optional fields: volume, number, pages, type, month, day, doi, url, note.
-\startsetups btx:aps:newspaper
+\startsetups btx:aps:list:newspaper
+ \fastsetup{btx:aps:list:article}
+\stopsetups
+
+% A complete issue of a periodical, such as a special issue of a journal.
+% Required fields: title, year
+% Optional fields: editor, publisher, subtitle, series, volume, number, month, organization, doi, url, issn, note
+
+% needs to be tuned...
+\startsetups btx:aps:list:periodical
+ \fastsetup{btx:aps:list:article}
+\stopsetups
+
+% National and international standards issued by a standards body
+% Required fields: author, institution, or organization, year, title
+% Optional fields: subtitle, doi, url, note
+
+\startsetups btx:aps:list:standard
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:optional-title}
- \texdefinition{btx:aps:journal-volumeset-year}
- \texdefinition{btx:aps:url-note-doi}
+ \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:url-doi-note}
\stopsetups
+% year?
% A book with an explicit publisher.
% Required fields: author or editor or publisher, title, (year).
% Optional fields: volume or number, series, address, edition, month, day, note.
+% APS? ignores: month, day
% todo: series?
-\startsetups btx:aps:book
+\startsetups btx:aps:list:book
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
- \texdefinition{btx:aps:publisher-wherefrom-year}
+ \texdefinition{btx:aps:title-if-not-placed}
\texdefinition{btx:aps:editionset}
- \texdefinition{btx:aps:url-note-doi}
+ \texdefinition{btx:aps:publisher-wherefrom-year}
+ \texdefinition{btx:aps:url-doi-note}
\stopsetups
+% There is some debate about how inbook should differ from incollection
+
% A part of a book, which may be a chapter (or section or whatever) and/or a range of pages.
+% (note that inbook is handled differently by bibtex and biblatex)
% Required fields: author or editor, title, chapter and/or pages, publisher, year.
% Optional fields: volume or number, series, type, address, edition, month, note.
+% We add optional: booktitle.
+% APS? ignores: chapter, month
-% todo: series?
-
-\startsetups btx:aps:inbook
+\startsetups btx:aps:list:inbook
\texdefinition{btx:aps:author}
- \btxdoif {chapter} {
- \btxflush{Word -> chapter}
- \btxspace
- }
- \texdefinition{btx:aps:editor-in-}{title}
- \texdefinition{btx:aps:publisher-wherefrom-year}
+ \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:editor-in}
\texdefinition{btx:aps:editionset}
- \texdefinition{btx:aps:url-note-doi}
+ \texdefinition{btx:aps:publisher-wherefrom-year}
+ \texdefinition{btx:aps:url-doi-note}
\stopsetups
+% chapter?
% A part of a book having its own title.
% Required fields: author, title, booktitle, publisher, year.
% Optional fields: editor, volume or number, series, type, chapter, pages, address, edition, month, note.
+% APS? ignores: chapter, month
-% todo: series?
-
-\startsetups btx:aps:incollection
- \texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
- \texdefinition{btx:aps:editor-in-}{booktitle}
- \texdefinition{btx:aps:publisher-wherefrom-year}
- \texdefinition{btx:aps:editionset}
- \texdefinition{btx:aps:url-note-doi}
+\startsetups btx:aps:list:incollection
+ \fastsetup{btx:aps:list:inbook}
\stopsetups
% The proceedings of a conference.
@@ -688,57 +1103,46 @@
% Optional fields: editor, volume or number, series, address, month, organization, publisher, note.
% todo: series?
-\startsetups btx:aps:proceedings
- \texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
- \btxdoif {editor} {
- \btxdoif {organization} {
- \btxspace
- \btxflush{organization}
- \btxcomma
- }
- }
- \texdefinition{btx:aps:publisher-wherefrom-year}
- \texdefinition{btx:aps:editionset}
- \texdefinition{btx:aps:url-note-doi}
+\startsetups btx:aps:list:proceedings
+ \fastsetup{btx:aps:list:book}
\stopsetups
% An article in a conference proceedings.
% Required fields: author, title, booktitle, year.
% Optional fields: editor, volume or number, series, pages, address, month, organization, publisher, note.
-% todo: series?
-\startsetups btx:aps:inproceedings
+\startsetups btx:aps:list:inproceedings
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
- \texdefinition{btx:aps:editor-in-}{booktitle}
+ \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:editor-in}
+ \texdefinition{btx:aps:editionset}
\btxdoif {organization} {
\btxspace
\btxflush{organization}
\btxcomma
}
\texdefinition{btx:aps:publisher-wherefrom-year}
- \texdefinition{btx:aps:editionset}
- \texdefinition{btx:aps:url-note-doi}
+ \texdefinition{btx:aps:url-doi-note}
\stopsetups
-\startsetups btx:aps:conference
- \fastsetup{btx:aps:inproceedings}
+\startsetups btx:aps:list:conference
+ \fastsetup{btx:aps:list:inproceedings}
\stopsetups
% A thesis.
% Required fields: author, title, school, year.
% Optional fields: type, address, month, note.
-\startsetups btx:aps:thesis
- \setmode{btx:aps:thesis}
+\startsetups btx:aps:list:thesis
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
+ \texdefinition{btx:aps:title-if-not-placed}
\btxleftparenthesis
\btxdoifelse {type} {
- \btxflush{Word -> type}
+ \btxusecommand[aps:list:type] {
+ \btxflush{type}
+ }
} {
- \Word{\btxlabeltext{aps:\currentbtxcategory}}
+ \btxlabeltext{aps:\currentbtxcategory}
}
\btxrightparenthesis
\btxdoif {school} {
@@ -758,60 +1162,47 @@
}
}
\btxperiod
- \texdefinition{btx:aps:url-note-doi}
+ \texdefinition{btx:aps:url-doi-note}
\stopsetups
-\startsetups btx:aps:phdthesis
- \fastsetup{btx:aps:thesis}
+\startsetups btx:aps:list:phdthesis
+ \fastsetup{btx:aps:list:thesis}
\stopsetups
-\startsetups btx:aps:mastersthesis
- \fastsetup{btx:aps:thesis}
+\startsetups btx:aps:list:mastersthesis
+ \fastsetup{btx:aps:list:thesis}
\stopsetups
% A work that is printed and bound, but without a named publisher or sponsoring institution.
% Required field: title.
% Optional fields: author, howpublished, address, month, year, note.
-\startsetups btx:aps:booklet
- \texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
- \texdefinition{btx:aps:publisher-wherefrom-year}
- \texdefinition{btx:aps:url-note-doi}
+\startsetups btx:aps:list:booklet
+ \fastsetup{btx:aps:list:book}
\stopsetups
% Technical documentation.
% Required field: title.
% Optional fields: author, organization, address, edition, month, year, note.
-\startsetups btx:aps:manual
- \texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
- \texdefinition{btx:aps:publisher-wherefrom-year}
- \texdefinition{btx:aps:editionset}
- \texdefinition{btx:aps:url-note-doi}
+\startsetups btx:aps:list:manual
+ \fastsetup{btx:aps:list:book}
\stopsetups
% A report published by a school or other institution, usually numbered within a series.
% Required fields: author, title, institution, year.
% Optional fields: type, number, address, month, note.
-\startsetups btx:aps:techreport
- \texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
- \texdefinition{btx:aps:publisher-wherefrom-year}
- \texdefinition{btx:aps:editionset}
- \texdefinition{btx:aps:url-note-doi}
+\startsetups btx:aps:list:techreport
+ \fastsetup{btx:aps:list:book}
\stopsetups
% A document having an author and title, but not formally published.
% Required fields: author, title, note.
% Optional fields: month, year.
-\startsetups btx:aps:unpublished
- \texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
- \texdefinition{btx:aps:url-note-doi}
+\startsetups btx:aps:list:unpublished
+ \fastsetup{btx:aps:list:book}
\stopsetups
% A patent. Note that this category was not defined with BIBTEX. Below from JabRef:
@@ -821,9 +1212,9 @@
% todo: yearfiled, monthfiled, dayfiled
-\startsetups btx:aps:patent
+\startsetups btx:aps:list:patent
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
+ \texdefinition{btx:aps:title-if-not-placed}
\begingroup
\it
\btxdoif {nationality} {
@@ -834,41 +1225,14 @@
\btxlabeltext{aps:patent}
\btxdoif {number} {
\btxspace
- \btxlabeltext{aps:Number}
+ \btxlabeltext{aps:number}
\btxspace
\btxflush{number}
}
\btxperiod
\italiccorrection
\endgroup
- \btxdoifelse {author} {
- \btxdoifelse {country} {
- \btxspace
- \btxdoif {address} {
- \btxflush{address}
- \btxcomma
- }
- \btxflush{country}
- \btxdoifelse {assignee}
- {\btxcolon} {\btxperiod}
- } {
- \btxdoifelse {address} {
- \btxspace
- \btxflush{address}
- \btxdoifelse {assignee}
- {\btxcolon} {\btxperiod}
- } {
- \btxdoifelse {assignee}
- {\btxspace} {}
- }
- }
- \btxdoif {assignee} {
- \btxflush{assignee}
- \btxperiod
- }
- } {
- \texdefinition{btx:aps:publisher-wherefrom-year}
- }
+ \texdefinition{btx:aps:publisher-wherefrom-year}
\texdefinition{btx:aps:url}
\texdefinition{btx:aps:note}
\stopsetups
@@ -880,9 +1244,9 @@
% Like Misc below but includes organization.
-\startsetups btx:aps:electronic
+\startsetups btx:aps:list:electronic
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
+ \texdefinition{btx:aps:title-if-not-placed}
\btxdoif {organization} {
\btxspace
\btxflush{organization}
@@ -893,50 +1257,42 @@
\btxflush{howpublished}
\btxperiod
}
- \texdefinition{btx:aps:url-note-doi}
+ \texdefinition{btx:aps:url-doi-note}
\stopsetups
% Other. Note that this category was not defined with BIBTEX. Below from JabRef:
% Required fields: author or title, year
% Optional fields: note, doi, url
-\startsetups btx:aps:other
- \texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
- \texdefinition{btx:aps:url-note-doi}
+\startsetups btx:aps:list:other
+ \fastsetup{btx:aps:list:book}
\stopsetups
% Use this type when nothing else fits.
% Required fields: none.
% Optional fields: author, title, howpublished, month, year, note.
-\startsetups btx:aps:misc
+\startsetups btx:aps:list:misc
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title}
+ \texdefinition{btx:aps:title-if-not-placed}
\btxdoif {howpublished} {
\btxspace
\btxflush{howpublished}
\btxperiod
}
- \texdefinition{btx:aps:url-note-doi}
+ \texdefinition{btx:aps:url-doi-note}
\stopsetups
% If all else fails to match:
-\startsetups btx:aps:literal
+\startsetups btx:aps:list:literal
+ %\btxleftparenthesis
+ \removeunwantedspaces(
+ \btxflush{key}
+ \btxrightparenthesis
\btxdoif {text} {
\btxflush{text}
}
\stopsetups
-%D Experiment:
-
-\startsetups btx:aps:lefttext
- \currentbtxlefttext
-\stopsetups
-
-\startsetups btx:aps:righttext
- \currentbtxrighttext
-\stopsetups
-
\stopbtxrenderingdefinitions
diff --git a/tex/context/base/publ-imp-author.mkvi b/tex/context/base/publ-imp-author.mkvi
index 6547573cf..534d8ce0b 100644
--- a/tex/context/base/publ-imp-author.mkvi
+++ b/tex/context/base/publ-imp-author.mkvi
@@ -31,15 +31,9 @@
\startsetups \s!btx:\s!cite:\s!author:concat
\ifcase\currentbtxoverflow
- \ifcase\currentbtxconcat \or \or
- \btxparameter\c!namesep
- \or
- \btxparameter\c!lastnamesep
- \or
- \btxparameter\c!finalnamesep
- \fi
+ \btxparameter{\c!separator:names:\number\currentbtxconcat}
\else
- % \btxparameter\c!namesep
+ %\btxparameter{\c!separator:names:2}
\fi
\stopsetups
@@ -53,18 +47,18 @@
\fastsetup{\s!btx:\s!cite:\s!author:concat}
\ifx\currentbtxfirstnames\empty \else
\currentbtxfirstnames
- \btxparameter\c!firstnamesep
+ \btxparameter{\c!separator:firstnames}
\fi
\ifx\currentbtxvons\empty \else
\currentbtxvons
\ifx\currentbtxsurnames\empty \else
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\fi
\fi
\ifx\currentbtxsurnames\empty \else
\currentbtxsurnames
\ifx\currentbtxjuniors\empty \else
- \btxparameter\c!juniorsep
+ \btxparameter{\c!separator:juniors}
\currentbtxjuniors
\fi
\fi
@@ -75,18 +69,18 @@
\fastsetup{\s!btx:\s!cite:\s!author:concat}
\ifx\currentbtxinitials\empty \else
\currentbtxinitials
- \btxparameter\c!initialsep
+ \btxparameter{\c!separator:initials}
\fi
\ifx\currentbtxvons\empty \else
\currentbtxvons
\ifx\currentbtxsurnames\empty \else
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\fi
\fi
\ifx\currentbtxsurnames\empty \else
\currentbtxsurnames
\ifx\currentbtxjuniors\empty \else
- \btxparameter\c!juniorsep
+ \btxparameter{\c!separator:juniors}
\currentbtxjuniors
\fi
\fi
@@ -99,25 +93,25 @@
\texdefinition{\s!btx:\s!cite:\s!author:\s!de}
\doifmode {\s!btx:\s!de} {
\currentbtxvons
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
}
\fi
\ifx\currentbtxsurnames\empty \else
\currentbtxsurnames
\ifx\currentbtxjuniors\empty \else
- \btxparameter\c!juniorsep
+ \btxparameter{\c!separator:juniors}
\currentbtxjuniors
\fi
\fi
\ifx\currentbtxfirstnames\empty
% firstnames are optional
\else
- \btxparameter\c!surnamefirstnamesep
+ \btxparameter{\c!separator:invertedfirstnames}
\currentbtxfirstnames
\fi
\ifx\currentbtxvons\empty \else
\doifnotmode {\s!btx:\s!de} {
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\currentbtxvons
}
\fi
@@ -130,25 +124,25 @@
\texdefinition{\s!btx:\s!cite:\s!author:\s!de}
\doifnotmode {\s!btx:\s!de} {
\currentbtxvons
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
}
\fi
\ifx\currentbtxsurnames\empty \else
\currentbtxsurnames
\ifx\currentbtxjuniors\empty \else
- \btxparameter\c!juniorsep
+ \btxparameter{\c!separator:juniors}
\currentbtxjuniors
\fi
\fi
\ifx\currentbtxinitials\empty
% initials are optional
\else
- \btxparameter\c!surnameinitialsep
+ \btxparameter{\c!separator:invertedinitials}
\currentbtxinitials
\fi
\ifx\currentbtxvons\empty \else
\doifmode {\s!btx:\s!de} {
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\currentbtxvons
}
\fi
@@ -160,13 +154,13 @@
% is this treated differently in german?
\ifx\currentbtxvons\empty \else
\currentbtxvons
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\fi
\currentbtxsurnames
\ifcase\currentbtxauthorstate \else
% potential clash of names so we force initials
\ifx\currentbtxinitials\empty \else
- \btxparameter\c!surnameinitialsep
+ \btxparameter{\c!separator:invertedinitials}
\currentbtxinitials
\fi
\fi
@@ -177,15 +171,9 @@
\startsetups \s!btx:\s!list:\s!author:concat
\ifcase\currentbtxoverflow
- \ifcase\currentbtxconcat \or \or
- \btxparameter\c!namesep
- \or
- \btxparameter\c!lastnamesep
- \or
- \btxparameter\c!finalnamesep
- \fi
+ \btxparameter{\c!separator:names:\number\currentbtxconcat}
\else
- \btxparameter\c!namesep
+ \btxparameter{\c!separator:names:2}
\fi
\stopsetups
@@ -199,18 +187,18 @@
\fastsetup{\s!btx:\s!list:\s!author:concat}
\ifx\currentbtxfirstnames\empty \else
\currentbtxfirstnames
- \btxparameter\c!firstnamesep
+ \btxparameter{\c!separator:firstnames}
\fi
\ifx\currentbtxvons\empty \else
\currentbtxvons
\ifx\currentbtxsurnames\empty \else
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\fi
\fi
\ifx\currentbtxsurnames\empty \else
\currentbtxsurnames
\ifx\currentbtxjuniors\empty \else
- \btxparameter\c!juniorsep
+ \btxparameter{\c!separator:juniors}
\currentbtxjuniors
\fi
\fi
@@ -221,18 +209,18 @@
\fastsetup{\s!btx:\s!list:\s!author:concat}
\ifx\currentbtxinitials\empty \else
\currentbtxinitials
- \btxparameter\c!initialsep
+ \btxparameter{\c!separator:initials}
\fi
\ifx\currentbtxvons\empty \else
\currentbtxvons
\ifx\currentbtxsurnames\empty \else
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\fi
\fi
\ifx\currentbtxsurnames\empty \else
\currentbtxsurnames
\ifx\currentbtxjuniors\empty \else
- \btxparameter\c!juniorsep
+ \btxparameter{\c!separator:juniors}
\currentbtxjuniors
\fi
\fi
@@ -245,25 +233,25 @@
\texdefinition{\s!btx:\s!cite:\s!author:\s!de}
\doifnotmode {\s!btx:\s!de} {
\currentbtxvons
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
}
\fi
\ifx\currentbtxsurnames\empty \else
\currentbtxsurnames
\ifx\currentbtxjuniors\empty \else
- \btxparameter\c!juniorsep
+ \btxparameter{\c!separator:juniors}
\currentbtxjuniors
\fi
\fi
\ifx\currentbtxfirstnames\empty
% firstnames are optional
\else
- \btxparameter\c!surnamefirstnamesep
+ \btxparameter{\c!separator:invertedfirstnames}
\currentbtxfirstnames
\fi
\ifx\currentbtxvons\empty \else
\doifmode {\s!btx:\s!de} {
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\currentbtxvons
}
\fi
@@ -276,25 +264,25 @@
\texdefinition{\s!btx:\s!cite:\s!author:\s!de}
\doifnotmode {\s!btx:\s!de} {
\currentbtxvons
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
}
\fi
\ifx\currentbtxsurnames\empty \else
\currentbtxsurnames
\ifx\currentbtxjuniors\empty \else
- \btxparameter\c!juniorsep
+ \btxparameter{\c!separator:juniors}
\currentbtxjuniors
\fi
\fi
\ifx\currentbtxinitials\empty
% initials are optional
\else
- \btxparameter\c!surnameinitialsep
+ \btxparameter{\c!separator:invertedinitials}
\currentbtxinitials
\fi
\ifx\currentbtxvons\empty \else
\doifmode {\s!btx:\s!de} {
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\currentbtxvons
}
\fi
@@ -306,7 +294,7 @@
% is this treated differently in german?
\ifx\currentbtxvons\empty \else
\currentbtxvons
- \btxparameter\c!vonsep
+ \btxparameter{\c!separator:vons}
\fi
\currentbtxsurnames
\fastsetup{\s!btx:\s!list:\s!author:others}
diff --git a/tex/context/base/publ-imp-cite.mkvi b/tex/context/base/publ-imp-cite.mkvi
index f743a7212..ca4f2a970 100644
--- a/tex/context/base/publ-imp-cite.mkvi
+++ b/tex/context/base/publ-imp-cite.mkvi
@@ -51,13 +51,18 @@
\startsetups btx:cite:unknown
\begingroup
\btxcitereference
- \currentbtxfirst
+ unknown: \currentbtxfirst
\endgroup
\stopsetups
-\startsetups btx:cite:invalid
+\startsetups btx:cite:empty
\btxcitereference
- <\currentbtxreference>
+ <empty>
+\stopsetups
+
+\startsetups btx:cite:invalid
+ \btxcitereference
+ {\tt <\currentbtxreference>}
\stopsetups
% \startsetups btx:cite:normal
@@ -101,13 +106,7 @@
%\stopsetups
\starttexdefinition btx:cite:concat
- \ifcase\currentbtxconcat \or \or
- \btxparameter\c!pubsep
- \or
- \btxparameter\c!lastpubsep
- \or
- \btxparameter\c!finalpubsep
- \fi
+ \btxparameter{\c!separator:\number\currentbtxconcat}
\stoptexdefinition
\startsetups btx:cite:normal
@@ -117,21 +116,21 @@
\else
\texdefinition {\s!btx:\s!cite:inject} {
\btxcitereference
- \btxusecommand[\currentbtxspecification:cite:\currentbtxcitevariant] {
+ \btxusecommand[\currentbtxspecification:cite:\currentbtxcitealternative] {
\currentbtxfirst
}
}
\ifx\currentbtxsecond\empty \else
\btxparameter\v!inbetween
\texdefinition {\s!btx:\s!cite:inject} {
- \btxusecommand[\currentbtxspecification:cite:\currentbtxcitevariant] {
+ \btxusecommand[\currentbtxspecification:cite:\currentbtxcitealternative] {
\currentbtxsecond
}
}
\fi
\ifx\currentbtxthird\empty \else
\texdefinition {\s!btx:\s!cite:inject} {
- \btxusecommand[\currentbtxspecification:cite:\currentbtxvariant] {
+ \btxusecommand[\currentbtxspecification:cite:\currentbtxcitealternative] {
\currentbtxthird
}
}
@@ -194,6 +193,11 @@
\fi
\stopsetups
+\startsetups \s!btx:\s!cite:entry
+ \texdefinition{\s!btx:\s!cite:concat}
+ \btxhandleciteentry
+\stopsetups
+
% these three are goodies to get something bit are not set up as it makes no
% sense to have something root for combinations like this (esp not because one
% gets default anyway
@@ -219,6 +223,12 @@
\startsetups btx:cite:num
\fastsetup{btx:cite:range}
\stopsetups
+\startsetups btx:cite:default
+ \fastsetup{btx:cite:num}
+\stopsetups
+\startsetups btx:cite:textnum
+ \fastsetup{btx:cite:num}
+\stopsetups
\startsetups btx:cite:year
\fastsetup{btx:cite:range}
\stopsetups
@@ -231,13 +241,13 @@
\else\ifconditional\btxinteractive
\goto {
\btxcitereference
- \hyphenatedurl{\doif{\currentbtxcitevariant}{doi}{doi:}\currentbtxfirst}
+ \hyphenatedurl{\doif{\currentbtxcitealternative}{doi}{doi:}\currentbtxfirst}
} [
- url(\doif{\currentbtxcitevariant}{doi}{http://dx.doi.org/}\currentbtxfirst)
+ url(\doif{\currentbtxcitealternative}{doi}{http://dx.doi.org/}\currentbtxfirst)
]
\else
\btxcitereference
- \hyphenatedurl{\doif{\currentbtxcitevariant}{doi}{doi:}\currentbtxfirst}
+ \hyphenatedurl{\doif{\currentbtxcitealternative}{doi}{doi:}\currentbtxfirst}
\fi\fi
\stopsetups
diff --git a/tex/context/base/publ-imp-default.mkvi b/tex/context/base/publ-imp-default.mkvi
index e3e032d12..c6657ffa9 100644
--- a/tex/context/base/publ-imp-default.mkvi
+++ b/tex/context/base/publ-imp-default.mkvi
@@ -22,46 +22,30 @@
% \definebtx [\s!default:\s!list ] [\s!list]
% \definebtx [\s!default:\s!author] [\s!author]
-\definebtxrendering % no need to set \c!default ! ... also confusing
+\definebtxrendering
[\s!default]
[\c!specification=\s!default]
\definebtx
[\s!default]
- [\c!namesep={,\space},
- \c!lastnamesep={\space\btxlabeltext{default:and}\space},
- \c!finalnamesep={\space\btxlabeltext{default:and}\space},
- \c!firstnamesep=\space,
+ [\c!default=, % we do not want to fall|-|back on ourself.
\c!otherstext={\space\btxlabeltext{default:others}},
- \c!juniorsep=\space,
- \c!vonsep=\space,
- \c!initialsep=\space,
- \c!surnamesep={,\space},
- \c!surnameinitialsep={,\space},
- \c!surnamefirstnamesep={,\space},
- \c!pubsep={,\space},
- \c!lastpubsep={,\space\btxlabeltext{default:and}\space},
- \c!finalpubsep={\space\btxlabeltext{default:and}\space}]
+ %c!journalconversion=\v!normal,
+ \c!monthconversion=\v!number,
+ \c!separator:names:2={,\space},
+ \c!separator:names:3={\space\btxlabeltext{default:and}\space},
+ \c!separator:names:4={\space\btxlabeltext{default:and}\space}]
\definebtx
[\s!default:\s!list]
[\s!default]
- [%c!journalconversion=\v!normal,
- \c!monthconversion=\v!number,
- \c!authorconversion=normalshort]
+ [\c!authorconversion=normalshort]
\definebtx
[\s!default:\s!cite]
[\s!default:\s!list]
[\c!alternative=num,
- \c!authorconversion=\v!name,
- \c!sorttype=,
- \c!compress=\v!no,
- \c!inbetween=\space,
- \c!range=\endash,
- \c!left=,
- \c!middle=,
- \c!right=]
+ \c!authorconversion=\v!name]
% We define [page] settings in the default namespace, inheriting the root
% settings, in order to eventually allow for modifications without touching
@@ -71,6 +55,10 @@
[\s!default:\s!page]
[\s!page]
+\definebtx
+ [\s!default:\s!page:list]
+ [\s!default:\s!page]
+
% List variants, some having specific settings:
\definebtx
@@ -130,10 +118,7 @@
[\s!default:\s!cite:authornum]
[\s!default:\s!cite:author]
[\c!left={(},
- \c!right={)},
- \c!pubsep={;\space},
- \c!lastpubsep={;\space},
- \c!finalpubsep={;\space}]
+ \c!right={)}]
\definebtx
[\s!default:\s!cite:authoryear]
@@ -141,10 +126,7 @@
[\c!compress=\v!yes,
\c!left={(},
\c!right={)},
- \c!inbetween={,\space},
- \c!pubsep={;\space},
- \c!lastpubsep={;\space},
- \c!finalpubsep={;\space}]
+ \c!inbetween={,\space}]
\definebtx
[\s!default:\s!cite:authorref]
@@ -253,18 +235,28 @@
[\c!compress=\v!yes,
\c!left={[},
\c!right={]},
- \c!pubsep={,},
- \c!lastpubsep={,},
- \c!finalpubsep={,}]
+ \c!separator:2={,}, % no space
+ \c!separator:3=\btxparameter{\c!separator:2},
+ \c!separator:4=\btxparameter{\c!separator:2}]
+
+\definebtx
+ [\s!default:\s!cite:default]
+ [\s!default:\s!cite:num]
\definebtx
[\s!default:\s!cite:textnum]
[\s!default:\s!cite:num]
[\c!left=, % in apa: {Ref.\nbsp} or so
\c!right=,
- \c!pubsep={,},
- \c!lastpubsep={,\space\btxlabeltext{default:and}\space},
- \c!finalpubsep={\space\btxlabeltext{default:and}\space}]
+ \c!separator:2={,\space},
+ \c!separator:3={,\space\btxlabeltext{default:and}\space},
+ \c!separator:4= {\space\btxlabeltext{default:and}\space}]
+
+\definebtx
+ [\s!default:\s!cite:entry]
+ [\s!default:\s!cite]
+ [\c!left={(},
+ \c!right={)}]
% Multilingual text strings
@@ -509,6 +501,9 @@
\startsetups \s!btx:\s!default:\s!cite:authornum
\fastsetup{\s!btx:\s!cite:author}
\stopsetups
+\startsetups \s!btx:\s!default:\s!cite:authorref
+ \fastsetup{\s!btx:\s!cite:authorref}
+\stopsetups
\startsetups \s!btx:\s!default:\s!cite:author:num
\fastsetup{\s!btx:\s!cite:range}
@@ -548,8 +543,11 @@
\startsetups \s!btx:\s!default:\s!cite:num
\fastsetup{\s!btx:\s!cite:range}
\stopsetups
+\startsetups \s!btx:\s!default:\s!cite:default
+ \fastsetup{\s!btx:\s!default:\s!cite:num}
+\stopsetups
\startsetups \s!btx:\s!default:\s!cite:textnum
- \fastsetup{\s!btx:\s!cite:range}
+ \fastsetup{\s!btx:\s!default:\s!cite:num}
\stopsetups
\startsetups \s!btx:\s!default:\s!cite:title
\fastsetup{\s!btx:\s!cite:normal}
@@ -566,9 +564,12 @@
\startsetups \s!btx:\s!default:\s!cite:url
\fastsetup{\s!btx:\s!cite:url}
\stopsetups
+\startsetups \s!btx:\s!default:\s!cite:nocite
+ \fastsetup{\s!btx:\s!cite:nocite}
+\stopsetups
-\startsetups \s!btx:\s!default:\s!cite:unknown
- \fastsetup{\s!btx:\s!cite:unknown}
+\startsetups \s!btx:\s!default:\s!cite:entry
+ \fastsetup{\s!btx:\s!cite:entry}
\stopsetups
\startsetups \s!btx:\s!default:\s!cite:none
\fastsetup{\s!btx:\s!cite:none}
diff --git a/tex/context/base/publ-imp-list.mkvi b/tex/context/base/publ-imp-list.mkvi
index 815bb2038..77c009911 100644
--- a/tex/context/base/publ-imp-list.mkvi
+++ b/tex/context/base/publ-imp-list.mkvi
@@ -51,9 +51,16 @@
\stopsetups
\startsetups \s!btx:\s!list:yes
- \texdefinition {\s!btx:\s!list:inject} {
- \currentbtxfirst
- }
+ \btxstartstyleandcolor [\currentbtxspecification:list:yes]
+ \btxusecommand[\currentbtxspecification:list:yes] {
+ %\btxparameter\c!left
+ \texdefinition {\s!btx:\s!list:inject} {
+ \currentbtxfirst
+ \btxparameter\c!stopper
+ }
+ %\btxparameter\c!right
+ }
+ \btxstopstyleandcolor
\stopsetups
\startsetups \s!btx:\s!list:num
\texdefinition {\s!btx:\s!list:inject} {
diff --git a/tex/context/base/publ-ini.lua b/tex/context/base/publ-ini.lua
index f20bf5102..789b772fe 100644
--- a/tex/context/base/publ-ini.lua
+++ b/tex/context/base/publ-ini.lua
@@ -93,85 +93,72 @@ manipulatormethods.WORD = converters.WORD
manipulatormethods.Words = converters.Words
manipulatormethods.WORDS = converters.WORDS
-local context = context
-local commands = commands
-
-local ctx_doifelse = commands.doifelse
-local ctx_doif = commands.doif
-local ctx_doifnot = commands.doifnot
-
-local ctx_firstoftwoarguments = context.firstoftwoarguments
-local ctx_secondoftwoarguments = context.secondoftwoarguments
-local ctx_firstofoneargument = context.firstofoneargument
-
-local ctx_gobbleoneargument = context.gobbleoneargument
-local ctx_gobbletwoarguments = context.gobbletwoarguments
-
-local ctx_btxdirectlink = context.btxdirectlink
-local ctx_btxhandlelistentry = context.btxhandlelistentry
-local ctx_btxhandlelisttextentry = context.btxhandlelisttextentry
-local ctx_btxchecklistentry = context.btxchecklistentry
-local ctx_btxchecklistcombi = context.btxchecklistcombi
------ ctx_btxsetcitereference = context.btxsetcitereference
------ ctx_btxsetlistreference = context.btxsetlistreference
-
-local ctx_btxsetdataset = context.btxsetdataset
-local ctx_btxsettag = context.btxsettag
-local ctx_btxsetnumber = context.btxsetnumber
-local ctx_btxsetlanguage = context.btxsetlanguage
-local ctx_btxsetcombis = context.btxsetcombis
-local ctx_btxsetcategory = context.btxsetcategory
-local ctx_btxcitesetup = context.btxcitesetup
-local ctx_btxpagesetup = context.btxpagesetup
-local ctx_btxsetfirst = context.btxsetfirst
-local ctx_btxsetsecond = context.btxsetsecond
-local ctx_btxsetthird = context.btxsetthird
-local ctx_btxsetinternal = context.btxsetinternal
-local ctx_btxsetlefttext = context.btxsetlefttext
-local ctx_btxsetrighttext = context.btxsetrighttext
-local ctx_btxsetbefore = context.btxsetbefore
-local ctx_btxsetafter = context.btxsetafter
-local ctx_btxsetbacklink = context.btxsetbacklink
-local ctx_btxsetbacktrace = context.btxsetbacktrace
-local ctx_btxsetcount = context.btxsetcount
-local ctx_btxsetconcat = context.btxsetconcat
-local ctx_btxsetoveflow = context.btxsetoverflow
-local ctx_btxsetfirstpage = context.btxsetfirstpage
-local ctx_btxsetlastpage = context.btxsetlastpage
-local ctx_btxsetfirstinternal = context.btxsetfirstinternal
-local ctx_btxsetlastinternal = context.btxsetlastinternal
-local ctx_btxstartcite = context.btxstartcite
-local ctx_btxstopcite = context.btxstopcite
-local ctx_btxstartciteauthor = context.btxstartciteauthor
-local ctx_btxstopciteauthor = context.btxstopciteauthor
-local ctx_btxstartsubcite = context.btxstartsubcite
-local ctx_btxstopsubcite = context.btxstopsubcite
-local ctx_btxstartlistentry = context.btxstartlistentry
-local ctx_btxstoplistentry = context.btxstoplistentry
-local ctx_btxlistsetup = context.btxlistsetup
-local ctx_btxflushauthor = context.btxflushauthor
-local ctx_btxsetnoflistentries = context.btxsetnoflistentries
-local ctx_btxsetcurrentlistentry = context.btxsetcurrentlistentry
-local ctx_btxsetcurrentlistindex = context.btxsetcurrentlistindex
-
-local ctx_setmacro = tokens.setters and tokens.setters.macro
-
-languages.data = languages.data or { }
-local data = languages.data
-
--- local registeredcitevariants = publications.registeredcitevariants or { }
--- local registeredlistvariants = publications.registeredlistvariants or { }
---
--- storage.register("publications/registeredcitevariants", registeredcitevariants,"publications.registeredcitevariants")
--- storage.register("publications/registeredlistvariants", registeredlistvariants,"publications.registeredlistvariants")
---
--- function commands.registerbtxcitevariant(name,parent)
--- registeredcitevariants[name] = parent or ""
--- end
---
--- function commands.registerbtxlistvariant(name,parent)
--- registeredlistvariants[name] = parent or ""
--- end
+local context = context
+local commands = commands
+
+local ctx_doifelse = commands.doifelse
+local ctx_doif = commands.doif
+local ctx_doifnot = commands.doifnot
+
+local ctx_firstoftwoarguments = context.firstoftwoarguments
+local ctx_secondoftwoarguments = context.secondoftwoarguments
+local ctx_firstofoneargument = context.firstofoneargument
+
+local ctx_gobbleoneargument = context.gobbleoneargument
+local ctx_gobbletwoarguments = context.gobbletwoarguments
+
+local ctx_btxdirectlink = context.btxdirectlink
+local ctx_btxhandlelistentry = context.btxhandlelistentry
+local ctx_btxhandlelisttextentry = context.btxhandlelisttextentry
+local ctx_btxchecklistentry = context.btxchecklistentry
+local ctx_btxchecklistcombi = context.btxchecklistcombi
+----- ctx_btxsetcitereference = context.btxsetcitereference
+----- ctx_btxsetlistreference = context.btxsetlistreference
+
+local ctx_btxsetdataset = context.btxsetdataset
+local ctx_btxsettag = context.btxsettag
+local ctx_btxsetnumber = context.btxsetnumber
+local ctx_btxsetlanguage = context.btxsetlanguage
+local ctx_btxsetcombis = context.btxsetcombis
+local ctx_btxsetcategory = context.btxsetcategory
+local ctx_btxcitesetup = context.btxcitesetup
+local ctx_btxpagesetup = context.btxpagesetup
+local ctx_btxsetfirst = context.btxsetfirst
+local ctx_btxsetsecond = context.btxsetsecond
+local ctx_btxsetthird = context.btxsetthird
+local ctx_btxsetinternal = context.btxsetinternal
+local ctx_btxsetlefttext = context.btxsetlefttext
+local ctx_btxsetrighttext = context.btxsetrighttext
+local ctx_btxsetbefore = context.btxsetbefore
+local ctx_btxsetafter = context.btxsetafter
+local ctx_btxsetbacklink = context.btxsetbacklink
+local ctx_btxsetbacktrace = context.btxsetbacktrace
+local ctx_btxsetcount = context.btxsetcount
+local ctx_btxsetconcat = context.btxsetconcat
+local ctx_btxsetoveflow = context.btxsetoverflow
+local ctx_btxsetfirstpage = context.btxsetfirstpage
+local ctx_btxsetlastpage = context.btxsetlastpage
+local ctx_btxsetfirstinternal = context.btxsetfirstinternal
+local ctx_btxsetlastinternal = context.btxsetlastinternal
+local ctx_btxstartcite = context.btxstartcite
+local ctx_btxstopcite = context.btxstopcite
+local ctx_btxstartciteauthor = context.btxstartciteauthor
+local ctx_btxstopciteauthor = context.btxstopciteauthor
+local ctx_btxstartsubcite = context.btxstartsubcite
+local ctx_btxstopsubcite = context.btxstopsubcite
+local ctx_btxstartlistentry = context.btxstartlistentry
+local ctx_btxstoplistentry = context.btxstoplistentry
+local ctx_btxlistsetup = context.btxlistsetup
+local ctx_btxflushauthor = context.btxflushauthor
+local ctx_btxsetnoflistentries = context.btxsetnoflistentries
+local ctx_btxsetcurrentlistentry = context.btxsetcurrentlistentry
+local ctx_btxsetcurrentlistindex = context.btxsetcurrentlistindex
+
+local implement = interfaces.implement
+local ctx_setmacro = interfaces.setmacro
+
+languages.data = languages.data or { }
+local data = languages.data
local specifications = publications.specifications
local currentspecification = specifications[false]
@@ -1269,12 +1256,7 @@ do
publications.found = found
publications.get = get
- function commands.btxfieldname(name,tag,field) context(get(name,tag,field,false,false)) end
- function commands.btxfieldtype(name,tag,field) context(get(name,tag,field,true, false)) end
- function commands.btxfoundname(name,tag,field) context(get(name,tag,field,false,true )) end
- function commands.btxfoundtype(name,tag,field) context(get(name,tag,field,true, true )) end
-
- function commands.btxflush(name,tag,field)
+ local function btxflush(name,tag,field)
local dataset = rawget(datasets,name)
if dataset then
local fields = dataset.luadata[tag]
@@ -1300,7 +1282,7 @@ do
end
end
- function commands.btxfield(name,tag,field)
+ local function btxfield(name,tag,field)
local dataset = rawget(datasets,name)
if dataset then
local fields = dataset.luadata[tag]
@@ -1325,7 +1307,7 @@ do
end
end
- function commands.btxdetail(name,tag,field)
+ local function btxdetail(name,tag,field)
local dataset = rawget(datasets,name)
if dataset then
local fields = dataset.luadata[tag]
@@ -1355,6 +1337,26 @@ do
end
end
+ local function btxdirect(name,tag,field)
+ local dataset = rawget(datasets,name)
+ if dataset then
+ local fields = dataset.luadata[tag]
+ if fields then
+ local manipulator, field = splitmanipulation(field)
+ local value = fields[field]
+ if value then
+ context(typesetters.default(field,value,manipulator))
+ elseif trace_detail then
+ report("field %a of tag %a in dataset %a has no value",field,tag,name)
+ end
+ else
+ report("unknown tag %a in dataset %a",tag,name)
+ end
+ else
+ report("unknown dataset %a",name)
+ end
+ end
+
local function okay(name,tag,field)
local dataset = rawget(datasets,name)
if dataset then
@@ -1372,9 +1374,41 @@ do
publications.okay = okay
- function commands.btxdoifelse(name,tag,field) ctx_doifelse(okay(name,tag,field)) end
- function commands.btxdoif (name,tag,field) ctx_doif (okay(name,tag,field)) end
- function commands.btxdoifnot (name,tag,field) ctx_doifnot (okay(name,tag,field)) end
+ if implement then
+
+ implement { name = "btxfield", actions = btxfield, arguments = { "string", "string", "string" } }
+ implement { name = "btxdetail", actions = btxdetail, arguments = { "string", "string", "string" } }
+ implement { name = "btxflush", actions = btxflush, arguments = { "string", "string", "string" } }
+ implement { name = "btxdirect", actions = btxdirect, arguments = { "string", "string", "string" } }
+
+ implement { name = "btxfieldname", actions = { get, context }, arguments = { "string", "string", "string", false, false } }
+ implement { name = "btxfieldtype", actions = { get, context }, arguments = { "string", "string", "string", true, false } }
+ implement { name = "btxfoundname", actions = { get, context }, arguments = { "string", "string", "string", false, true } }
+ implement { name = "btxfoundtype", actions = { get, context }, arguments = { "string", "string", "string", true, true } }
+
+ implement { name = "btxdoifelse", actions = { okay, ctx_btxdoifelse }, arguments = { "string", "string", "string" } }
+ implement { name = "btxdoif", actions = { okay, ctx_btxdoif }, arguments = { "string", "string", "string" } }
+ implement { name = "btxdoifnot", actions = { okay, ctx_btxdoifnot }, arguments = { "string", "string", "string" } }
+
+
+ else
+
+ commands.btxflush = btxflush
+ commands.btxfield = btxfield
+ commands.btxdetail = btxdetail
+ commands.btxdirect = btxdirect
+
+ function commands.btxfieldname(name,tag,field) context(get(name,tag,field,false,false)) end
+ function commands.btxfieldtype(name,tag,field) context(get(name,tag,field,true, false)) end
+ function commands.btxfoundname(name,tag,field) context(get(name,tag,field,false,true )) end
+ function commands.btxfoundtype(name,tag,field) context(get(name,tag,field,true, true )) end
+
+ function commands.btxdoifelse (name,tag,field) ctx_doifelse(okay(name,tag,field)) end
+ function commands.btxdoif (name,tag,field) ctx_doif (okay(name,tag,field)) end
+ function commands.btxdoifnot (name,tag,field) ctx_doifnot (okay(name,tag,field)) end
+
+ end
+
end
@@ -1468,39 +1502,6 @@ do
-- helper
- -- local function sortedtags(dataset,list,sorttype)
- -- local luadata = datasets[dataset].luadata
- -- local valid = { }
- -- for i=1,#list do
- -- local tag = list[i]
- -- local entry = luadata[tag]
- -- if entry then
- -- local key = entry[sorttype]
- -- if key then
- -- valid[#valid+1] = {
- -- tag = tag,
- -- split = sortsplitter(sortstripper(key))
- -- }
- -- end
- -- end
- -- end
- -- if #valid == 0 or #valid ~= #list then
- -- return list
- -- else
- -- sorters.sort(valid,basicsorter)
- -- for i=1,#valid do
- -- valid[i] = valid[i].tag
- -- end
- -- return valid
- -- end
- -- end
- --
- -- if sorttype and sorttype ~= "" then
- -- tags = sortedtags(dataset,tags,sorttype)
- -- end
-
- -- why shorts vs tags: only for sorting
-
function lists.register(dataset,tag,short) -- needs checking now that we split
local r = renderings[dataset]
if not short or short == "" then
@@ -1560,6 +1561,8 @@ do
end
end
+ -- todo: names = { "btx" }
+
methods[v_force] = function (dataset,rendering,keyword)
-- only for checking, can have duplicates, todo: collapse page numbers, although
-- we then also needs deferred writes
@@ -1601,7 +1604,9 @@ do
local pages = { }
local current = datasets[dataset]
local luadata = current.luadata
-rendering.result = result
+ -- handy for tracing :
+ rendering.result = result
+ --
for listindex=1,#result do
local r = result[listindex]
local u = r.userdata
@@ -2094,13 +2099,6 @@ do
end
end
- -- function commands.btxcitevariant(dataset,block,tags,variant) -- uses? specification ?
- -- local action = citevariants[variant]
- -- if action then
- -- action(dataset,tags,variant)
- -- end
- -- end
-
-- sorter
local keysorter = function(a,b)
@@ -2119,41 +2117,6 @@ do
end
end
- -- local suffix = 0
- -- local function setsuffix(entry,suffix,sortfld)
- -- entry.suffix = suffix
- -- local dataset = datasets[entry.dataset]
- -- if dataset then
- -- local suffixes = dataset.suffixes[entry.tag]
- -- if suffixes then
- -- suffixes[sortfld] = suffix
- -- else
- -- dataset.suffixes[entry.tag] = { [sortfld] = suffix }
- -- end
- -- end
- -- end
- -- for i=1,#source do
- -- local entry = source[i]
- -- local sortfld = entry.sortfld
- -- if sortfld then
- -- local value = entry.sortkey
- -- if value == oldvalue then
- -- if suffix == 0 then
- -- suffix = 1
- -- local entry = source[i-1]
- -- setsuffix(entry,suffix,sortfld)
- -- end
- -- suffix = suffix + 1
- -- setsuffix(entry,suffix,sortfld)
- -- else
- -- oldvalue = value
- -- suffix = 0
- -- end
- -- else
- -- break
- -- end
- -- end
-
local function compresslist(source)
for i=1,#source do
local t = type(source[i].sortkey)
@@ -2321,10 +2284,10 @@ do
ctx_btxsetrighttext(righttext[i] or "")
end
if before then
- ctx_btxsetbefore(before[i] or #before == 1 and before[1] or "")
+ ctx_btxsetbefore(before[i] or (#before == 1 and before[1]) or "")
end
if after then
- ctx_btxsetafter(after[i] or #after == 1 and after[1] or "")
+ ctx_btxsetafter(after[i] or (#after == 1 and after[1]) or "")
end
--
ctx_btxsetbacklink(currentcitation)
diff --git a/tex/context/base/publ-ini.mkiv b/tex/context/base/publ-ini.mkiv
index e0e0489ab..f376d3e7e 100644
--- a/tex/context/base/publ-ini.mkiv
+++ b/tex/context/base/publ-ini.mkiv
@@ -11,6 +11,10 @@
%C therefore copyrighted by \PRAGMA. See mreadme.pdf for
%C details.
+
+% TODO: s! vs v! for default and neutral key/values
+% todo: too many refs in list
+
% todo: tagging
% todo: we cannot use 'default' as this wipes metadata names (maybe no longer do that)
% todo: \v!cite => \s!cite
@@ -182,10 +186,7 @@
\installcommandhandler \??btxregister {btxregister} \??btxregister
\installcommandhandler \??btxrendering {btxrendering} \??btxrendering
-% named: check all listvariant and citevariant
-
-\let\currentbtxcitevariant\empty
-\let\currentbtxlistvariant\empty
+\let\currentbtxcitealternative\empty
\let\currentbtxspecificationfallback\empty
@@ -257,11 +258,12 @@
% [default]
% [mybibs.bib]
+\let\startpublication\relax
+\let\stoppublication \relax
+
\unexpanded\def\startpublication
{\dodoubleempty\publ_set_publication}
-\let\stoppublication\relax
-
\def\publ_set_publication[#1][#2]%
{\begingroup
\catcode\commentasciicode\othercatcode
@@ -343,17 +345,39 @@
% \btxfield : current
% \btxspecificfield : dataset,tag,key
-\def\btxfield #1{\ctxcommand{btxfield("\currentbtxdataset","\currentbtxtag","#1")}}
-\def\btxdetail #1{\ctxcommand{btxdetail("\currentbtxdataset","\currentbtxtag","#1")}}
-\def\btxflush #1{\ctxcommand{btxflush("\currentbtxdataset","\currentbtxtag","#1")}}
-\def\btxfieldname #1{\ctxcommand{btxfieldname("\currentbtxdataset","\currentbtxtag","#1")}}
-\def\btxfieldtype #1{\ctxcommand{btxfieldtype("\currentbtxdataset","\currentbtxtag","#1")}}
-\def\btxfoundname #1{\ctxcommand{btxfoundname("\currentbtxdataset","\currentbtxtag","#1")}}
-\def\btxfoundtype #1{\ctxcommand{btxfoundtype("\currentbtxdataset","\currentbtxtag","#1")}}
+\ifdefined\clf_btxfield % {#1} will go
+
+ \def\btxfield #1{\clf_btxfield {\currentbtxdataset}{\currentbtxtag}{#1}}
+ \def\btxdetail #1{\clf_btxdetail {\currentbtxdataset}{\currentbtxtag}{#1}}
+ \def\btxflush #1{\clf_btxflush {\currentbtxdataset}{\currentbtxtag}{#1}}
+ \def\btxdirect #1{\clf_btxdirect {\currentbtxdataset}{\currentbtxtag}{#1}}
+ \def\btxfieldname #1{\clf_btxfieldname {\currentbtxdataset}{\currentbtxtag}{#1}}
+ \def\btxfieldtype #1{\clf_btxfieldtype {\currentbtxdataset}{\currentbtxtag}{#1}}
+ \def\btxfoundname #1{\clf_btxfoundname {\currentbtxdataset}{\currentbtxtag}{#1}}
+ \def\btxfoundtype #1{\clf_btxfoundtype {\currentbtxdataset}{\currentbtxtag}{#1}}
+ % \def\btxauthorfield#1{\clf_btxauthorfield\currentbtxauthorindex{#1}}
+ \def\btxdoifelse #1{\clf_btxdoifelse {\currentbtxdataset}{\currentbtxtag}{#1}}
+ \def\btxdoif #1{\clf_btxdoif {\currentbtxdataset}{\currentbtxtag}{#1}}
+ \def\btxdoifnot #1{\clf_btxdoifnot {\currentbtxdataset}{\currentbtxtag}{#1}}
+
+\else
+
+ \def\btxfield #1{\ctxcommand{btxfield("\currentbtxdataset","\currentbtxtag","#1")}}
+ \def\btxdetail #1{\ctxcommand{btxdetail("\currentbtxdataset","\currentbtxtag","#1")}}
+ \def\btxflush #1{\ctxcommand{btxflush("\currentbtxdataset","\currentbtxtag","#1")}}
+ \def\btxdirect #1{\ctxcommand{btxdirect("\currentbtxdataset","\currentbtxtag","#1")}}
+ \def\btxfieldname #1{\ctxcommand{btxfieldname("\currentbtxdataset","\currentbtxtag","#1")}}
+ \def\btxfieldtype #1{\ctxcommand{btxfieldtype("\currentbtxdataset","\currentbtxtag","#1")}}
+ \def\btxfoundname #1{\ctxcommand{btxfoundname("\currentbtxdataset","\currentbtxtag","#1")}}
+ \def\btxfoundtype #1{\ctxcommand{btxfoundtype("\currentbtxdataset","\currentbtxtag","#1")}}
+ % \def\btxauthorfield#1{\ctxcommand{btxauthorfield(\number\currentbtxauthorindex,"#1")}}
+ \def\btxdoifelse #1{\ctxcommand{btxdoifelse("\currentbtxdataset","\currentbtxtag","#1")}}
+ \def\btxdoif #1{\ctxcommand{btxdoif("\currentbtxdataset","\currentbtxtag","#1")}}
+ \def\btxdoifnot #1{\ctxcommand{btxdoifnot("\currentbtxdataset","\currentbtxtag","#1")}}
+
+\fi
+
\def\btxauthorfield#1{\ctxcommand{btxauthorfield(\number\currentbtxauthorindex,"#1")}}
-\def\btxdoifelse #1{\ctxcommand{btxdoifelse("\currentbtxdataset","\currentbtxtag","#1")}}
-\def\btxdoif #1{\ctxcommand{btxdoif("\currentbtxdataset","\currentbtxtag","#1")}}
-\def\btxdoifnot #1{\ctxcommand{btxdoifnot("\currentbtxdataset","\currentbtxtag","#1")}}
\let\btxsetup\fastsetup
@@ -500,9 +524,6 @@
\newtoks \everysetupbtxlistplacement % name will change
\newtoks \everysetupbtxciteplacement % name will change
-% \def\publ_list_processor % bibref -> btx (old method, keep as reference)
-% {\ctxcommand{btxaddtolist("\currentbtxrendering",\currentlistindex,"btxref")}}
-
\definelist % only used for selecting
[\s!btx]
@@ -604,9 +625,10 @@
\fi
\begingroup
\usebtxstyleandcolor\c!style\c!color
+ \ignorespaces
\fastbtxsetup\s!list\currentbtxcategory
- \endgroup
\removeunwantedspaces
+ \endgroup
\ifconditional\c_btx_list_pages
\btx_entry_inject_pages
\fi
@@ -821,7 +843,7 @@
\unexpanded\def\btx_reference_indeed
{\begingroup
- \let\currentbtxlistvariant\currentbtxnumbering
+ %let\currentbtxlistvariant\currentbtxnumbering
\setbtxparameterset\c!list\currentbtxnumbering
\ifx\currentbtxnumbering\empty
% nothing
@@ -869,19 +891,25 @@
{\ifx\currentbtxdataset\v!default\else\s!btxset="\currentbtxdataset",\fi%
\s!btxref="\currentbtxtag",%
\s!btxspc="\currentbtxspecification",%
- \ifx\currentbtxbefore\empty\else\s!btxbtx={\currentbtxbefore},\fi%
- \ifx\currentbtxafter \empty\else\s!btxatx={\currentbtxafter },\fi%
+ \ifx\currentbtxbefore\empty\else\s!btxbtx=\!!bs\currentbtxbefore\!!es,\fi%
+ \ifx\currentbtxafter \empty\else\s!btxatx=\!!bs\currentbtxafter \!!es,\fi%
\ifx\currentbtxbacklink\currentbtxbacktrace\s!btxint="\currentbtxbacklink"\else\s!btxbck="\currentbtxbacktrace"\fi}%
{\s!btx::\v!list::\number\c_btx_list_reference}%
{\currentbtxnumber}}
+\newconditional\c_btx_cite_reference_injected
+
\unexpanded\def\btx_cite_reference_inject
- {\dontleavehmode
- \iftrialtypesetting \else
- \ifx\currentbtxbacklink\empty
- % can be made empty when combining author / year
- \else
- \btx_cite_reference_inject_indeed
+ {\ifconditional\c_btx_cite_reference_injected
+ \else
+ \dontleavehmode
+ \iftrialtypesetting \else
+ \ifx\currentbtxbacklink\empty
+ % can be made empty when combining author / year
+ \else
+ \btx_cite_reference_inject_indeed
+ \settrue\c_btx_cite_reference_injected
+ \fi
\fi
\fi}
@@ -894,8 +922,8 @@
[\s!btx]%
[\ifx\currentbtxdataset\v!default\else\s!btxset=\currentbtxdataset,\fi%
\s!btxref=\currentbtxtag,%
- \ifx\currentbtxbefore\empty\else\s!btxbtx={\currentbtxbefore},\fi%
- \ifx\currentbtxafter \empty\else\s!btxatx={\currentbtxafter },\fi%
+ \ifx\currentbtxbefore\empty\else\s!btxbtx=\!!bs\currentbtxbefore\!!es,\fi%
+ \ifx\currentbtxafter \empty\else\s!btxatx=\!!bs\currentbtxafter \!!es,\fi%
\s!btxint=\number\currentbtxbacklink
\ifx\currentbtxciteuservariables\empty\else,\currentbtxciteuservariables\fi]}}
@@ -936,12 +964,13 @@
{\begingroup
\edef\currentbtxfield{#2}%
\setbtxparameterset\s!list\currentbtxfield
- \let\currentbtxlistvariant\currentbtxfield
+ %let\currentbtxlistvariant\currentbtxfield
\ctxcommand{btxauthor("\currentbtxdataset","\currentbtxtag","\currentbtxfield",{
combiner = "#1",
kind = "list",
etallimit = "\btxparameter\c!etallimit",
etaldisplay = "\btxparameter\c!etaldisplay",
+ symbol = "\btxparameter{\c!stopper:initials}",
})}%
\endgroup}
@@ -961,6 +990,7 @@
kind = "cite",
etallimit = "\btxparameter\c!etallimit",
etaldisplay = "\btxparameter\c!etaldisplay",
+ symbol = "\btxparameter{\c!stopper:initials}",
})}%
\endgroup}
@@ -1086,8 +1116,8 @@
\unexpanded\def\publ_cite_tags_indeed#1%
{\letinteractionparameter\c!style\empty
\setbtxparametersetroot\s!cite % we need to get the default
- \edef\currentbtxcitevariant{\btxparameter\c!alternative}%
- \setbtxparameterset\s!cite\currentbtxcitevariant
+ \edef\currentbtxcitealternative{\btxparameter\c!alternative}%
+ \setbtxparameterset\s!cite\currentbtxcitealternative
\edef\currentbtxcitetag{#1}%
\the\everysetupbtxciteplacement
\publ_cite_variant
@@ -1116,11 +1146,11 @@
\edef\p_alternative{\dummyparameter\c!alternative}%
\ifx\p_alternative\empty
\setbtxparametersetroot\s!cite
- \edef\currentbtxcitevariant{\btxparameter\c!alternative}%
+ \edef\currentbtxcitealternative{\btxparameter\c!alternative}%
\else
- \let\currentbtxcitevariant\p_alternative
+ \let\currentbtxcitealternative\p_alternative
\fi
- \setbtxparameterset\s!cite\currentbtxcitevariant
+ \setbtxparameterset\s!cite\currentbtxcitealternative
\setupcurrentbtx[#1]%
%
\edef\p_publ_cite_before {\dummyparameter\c!before}%
@@ -1134,9 +1164,9 @@
\def\publ_cite_tags_variants_indeed#1[#2]%
{\letinteractionparameter\c!style\empty
- \edef\currentbtxcitevariant{#1}%
+ \edef\currentbtxcitealternative{#1}%
\edef\currentbtxcitetag{#2}%
- \setbtxparameterset\s!cite\currentbtxcitevariant
+ \setbtxparameterset\s!cite\currentbtxcitealternative
\the\everysetupbtxciteplacement
\publ_cite_variant
\endgroup}
@@ -1151,22 +1181,18 @@
\unexpanded\def\publ_cite_handle_variant#1%
{\begingroup
- \edef\currentbtxcitevariant{#1}%
- \setbtxparameterset\s!cite\currentbtxcitevariant
+ \edef\currentbtxcitealternative{#1}%
+ \setbtxparameterset\s!cite\currentbtxcitealternative
\the\everysetupbtxciteplacement
\dosingleargument\publ_cite_handle_variant_indeed}
-\def\publ_cite_handle_variant_indeed[#1]%
- {\letbtxparameter\c!alternative\currentbtxcitevariant
- \usebtxstyleandcolor\c!style\c!color
- \uselanguageparameter\btxdatasetparameter % new
- \btxparameter\v!left
- \edef\currentbtxreference{#1}%
+\unexpanded\def\publ_cite_handle_variant_blob
+ {\btxparameter\v!left
\ctxcommand{btxhandlecite{%
dataset = "\currentbtxdataset",%
reference = \!!bs\currentbtxreference\!!es,%
markentry = \iftrialtypesetting false\else true\fi,%
- variant = "\currentbtxcitevariant",%
+ variant = "\currentbtxcitealternative",%
sorttype = "\btxparameter\c!sorttype",%
compress = "\btxparameter\c!compress",%
author = "\btxparameter\c!author",%
@@ -1175,8 +1201,15 @@
before = \!!bs\p_publ_cite_before\!!es,%
after = \!!bs\p_publ_cite_after\!!es,%
}}%
- \btxparameter\v!right
- \ctxcommand{flushmarked()}%
+ \ctxcommand{flushmarked()}% maybe: \iftrialtypesetting\else ... \fi
+ \btxparameter\v!right}
+
+\def\publ_cite_handle_variant_indeed[#1]%
+ {\letbtxparameter\c!alternative\currentbtxcitealternative
+ \edef\currentbtxreference{#1}%
+ \usebtxstyleandcolor\c!style\c!color
+ \uselanguageparameter\btxdatasetparameter % new
+ \btxparameter\c!command{\publ_cite_handle_variant_blob}%
\endgroup}
\unexpanded\def\btxcitation
@@ -1327,6 +1360,10 @@
\newtoks\everybtxciteentry
+\prependtoks
+ \setfalse\c_btx_cite_reference_injected
+\to \everybtxciteentry
+
\unexpanded\def\btxcitesetup#1%
{\the\everybtxciteentry
\everybtxciteentry\emptytoks % tricky maybe not when subcites
@@ -1341,8 +1378,8 @@
\unexpanded\def\btxstartsubcite#1%
{\begingroup
\btxcitereset % todo: limited set
- \def\currentbtxcitevariant{#1}%
- \setbtxparameterset\s!cite\currentbtxcitevariant
+ \def\currentbtxcitealternative{#1}%
+ \setbtxparameterset\s!cite\currentbtxcitealternative
\usebtxstyleandcolor\c!style\c!color
\btxparameter\c!left
\relax}
@@ -1354,8 +1391,8 @@
\unexpanded\def\btxstartciterendering[#1]%
{\begingroup
- \edef\currentbtxcitevariant{#1}%
- \setbtxparameterset\s!cite\currentbtxcitevariant
+ \edef\currentbtxcitealternative{#1}%
+ \setbtxparameterset\s!cite\currentbtxcitealternative
\usebtxstyleandcolor\c!style\c!color
\btxparameter\c!left
\relax}
@@ -1408,9 +1445,34 @@
{\dotripleargument\publ_save_dataset}
\unexpanded\def\publ_save_dataset[#1][#2][#3]%
+ {\ifthirdargument
+ \publ_save_dataset_indeed[#1][#2][#3]%
+ \else\ifsecondargument
+ \doifassignmentelse{#2}%
+ {\publ_save_dataset_indeed[\s!default][#1][#2]}%
+ {\publ_save_dataset_indeed[#1][#2][]}%
+ \else\iffirstargument
+ \doifassignmentelse{#1}%
+ {\publ_save_dataset_indeed[\s!default][\jobname-saved.bib][#1]}%
+ {\publ_save_dataset_indeed[\s!default][#1][]}%
+ % \else
+ % % bad news
+ \fi\fi\fi}
+
+\unexpanded\def\publ_save_dataset_indeed[#1][#2][#3]%
{\begingroup
- \getdummyparameters[\c!criterium=\v!all,\c!alternative=,#3]% % all or used
- \ctxcommand{btxsavedataset("#1","#2","\dummyparameter\c!alternative","\dummyparameter\c!criterium")}%
+ \getdummyparameters
+ [\c!criterium=\v!all,%
+ \c!type=,%
+ \c!dataset=#1,%
+ \c!file=#2,%
+ #3]% % all or used
+ \ctxcommand{btxsavedataset{
+ dataset = "\dummyparameter\c!dataset",
+ filename = "\dummyparameter\c!file",
+ filetype = "\dummyparameter\c!type",
+ criterium = "\dummyparameter\c!criterium"
+ }}%
\endgroup}
% \savebtxdataset[default][e:/tmp/foo.bib]
@@ -1419,28 +1481,17 @@
%D In-text entries:
-% \definebtxcitevariant
-% [entry]
-
\unexpanded\def\placecitation{\citation[entry]} % [#1]
\unexpanded\def\btxhandleciteentry
{\dontleavehmode
\begingroup
- \def\currentbtxcitevariant{entry}%
- \setbtxparameterset\s!cite\currentbtxcitevariant % needs checking
+ \def\currentbtxcitealternative{entry}%
+ \setbtxparameterset\s!cite\currentbtxcitealternative % needs checking
\btxcitereference
\btx_entry_inject
\endgroup}
-\startsetups \s!btx:\s!cite:entry
- \ifx\currentbtxfirst\empty
- \fastbtxsetup\s!cite\s!unknown
- \else
- \btxhandleciteentry
- \fi
-\stopsetups
-
%D Registers
% \setupbtxregister
@@ -1484,19 +1535,19 @@
\unexpanded\def\btxindexedauthor#1#2#3#4#5#6% alternative von last first junior
{\begingroup
- \def\currentbtxcitevariant{#1}%
- \ifx\currentbtxcitevariant\empty
- \edef\currentbtxcitevariant{invertedshort}%
+ \def\currentbtxcitealternative{#1}%
+ \ifx\currentbtxcitealternative\empty
+ \edef\currentbtxcitealternative{invertedshort}% maybe we need some default here too?
\fi
- \let\currentbtxlistvariant\currentbtxcitevariant % we inherit
+ %let\currentbtxlistvariant\currentbtxcitealternative % we inherit
\the\everysetupbtxciteplacement
\def\currentbtxvons {#2}%
\def\currentbtxsurnames {#3}%
\def\currentbtxinitials {#4}%
\def\currentbtxfirstnames {#5}%
\def\currentbtxjuniors {#6}%
- \setbtxparameterset\s!cite\currentbtxcitevariant
- \fastsetup{\s!btx:\s!cite:\s!author:\currentbtxcitevariant}%
+ \setbtxparameterset\s!cite\currentbtxcitealternative
+ \fastsetup{\s!btx:\s!cite:\s!author:\currentbtxcitealternative}%
\endgroup}
%D We hook some setters in the definition sets:
@@ -1562,15 +1613,33 @@
\c!separator={;\space},
\c!distance=1.5\emwidth]
-% Quite some interpunction and labels are the same of at least consistent witin
+% Quite some interpunction and labels are the same of at least consistent within
% a standard when citations and list entries are involved. We assume that each
-% standard defines its own set but it can fall back on the defaults.
+% standard defines its own set but it can fall back on these defaults.
\setupbtx
- [\c!alternative=\v!num, % default cite
- \c!interaction=\v!start,
+ [\c!interaction=\v!start,
+ \c!alternative=num, % default cite form
+ \c!inbetween=\space,
+ \c!range=\endash, % separator:range?
+ \c!compress=\v!no,
\c!etallimit=3,
- \c!etaldisplay=\btxparameter\c!etallimit]
+ \c!etaldisplay=\btxparameter\c!etallimit,
+ \c!otherstext={\space et al.},
+ \c!separator:firstnames={\space},
+ \c!separator:juniors={\space},
+ \c!separator:vons={\space},
+ \c!separator:initials={\space},
+ \c!stopper:initials={.},
+ %\c!surnamesep={,\space}, % is this used anywhere?
+ \c!separator:invertedinitials={,\space},
+ \c!separator:invertedfirstnames={,\space},
+ \c!separator:names:2={,\space}, % separates multiple names
+ \c!separator:names:3=\btxparameter{\c!separator:2}, % before last name in a list
+ \c!separator:names:4=\btxparameter{\c!separator:2}, % between only two names
+ \c!separator:2={;\space}, % aka pubsep - separates multiple objects
+ \c!separator:3=\btxparameter{separator:2}, % before last object in a list
+ \c!separator:4=\btxparameter{separator:2}] % between only two objects
% Do we want these in the format? Loading them delayed is somewhat messy.
@@ -1592,7 +1661,7 @@
\setupbtx
[\c!specification=\s!default,
\c!dataset=\v!default,
- \c!default=]
+ \c!default=\v!default]
\loadbtxdefinitionfile
[\s!default]
diff --git a/tex/context/base/publ-reg.lua b/tex/context/base/publ-reg.lua
index 531c4dcf0..0a0815eeb 100644
--- a/tex/context/base/publ-reg.lua
+++ b/tex/context/base/publ-reg.lua
@@ -47,29 +47,32 @@ function commands.setbtxregister(specification)
s = { }
registrations[register] = s
end
- local d = s[dataset]
- if not d then
- d = { }
- s[dataset] = d
- end
- --
- -- check all
- --
local processors = name ~= register and name or ""
if processor == "" then
processor = nil
elseif processor then
processor = "btx:r:" .. processor
end
- --
- d.active = specification.state ~= v_stop
- d.once = specification.method == v_once or false
- d.field = field
- d.processor = processor
- d.alternative = d.alternative or specification.alternative
- d.register = register
- d.dataset = dataset
- d.done = d.done or { }
+ local datasets = utilities.parsers.settings_to_array(dataset)
+ for i=1,#datasets do
+ local dataset = datasets[i]
+ local d = s[dataset]
+ if not d then
+ d = { }
+ s[dataset] = d
+ end
+ --
+ -- check all
+ --
+ d.active = specification.state ~= v_stop
+ d.once = specification.method == v_once or false
+ d.field = field
+ d.processor = processor
+ d.alternative = d.alternative or specification.alternative
+ d.register = register
+ d.dataset = dataset
+ d.done = d.done or { }
+ end
--
sequence = { }
for register, s in sortedhash(registrations) do
diff --git a/tex/context/base/s-inf-03.mkiv b/tex/context/base/s-inf-03.mkiv
index 48449d690..7699c46d4 100644
--- a/tex/context/base/s-inf-03.mkiv
+++ b/tex/context/base/s-inf-03.mkiv
@@ -159,16 +159,16 @@ local skipglobal = table.tohash {
"_G", "_M", "_ENV", "",
"context", "modules", "global", "arg", "utf", 1,
"_ptbs_", "_pcol_", "_plib_", "_clib_", "_tlib_",
- "kpse",
+ "kpse", "commands",
}
local skipkeys = table.tohash {
"_pcol_", "_plib_", "_clib_", "_tlib_", "_bpnf_", "_ptbs_",
- "_cldf_", "_cldn_",
+ "_cldf_", "_cldn_", "_cldo_",
"_clmb_", "_clme_", "_clmm_", "_clmn_", "_clma_", "_clmh_",
"_G", "_M", "_ENV", "",
+ -- "global", "shortcuts",
"_VERSION", "_COPYRIGHT", "_DESCRIPTION", "_NAME", "_PACKAGE", "__unload",
-
}
local sameglobal = {
@@ -196,6 +196,8 @@ local variant = 1 -- all parents
local variant = 2 -- parent name too
local variant = 3 -- no parents
+local done = { }
+
local function childtables(key,tab,handler,depth)
depth = depth or 1
local keys = sortedkeys(tab) -- no sorted_pairs
@@ -214,6 +216,10 @@ local function childtables(key,tab,handler,depth)
t = "data"
handler(s,t,depth)
else
+if done[v] then
+ -- logs.report("inf-03","key %a in %a already done",k,v)
+else
+ done[v] = true
handler(s,t,depth)
if variant == 3 then
childtables(false,v,handler,depth+1)
@@ -223,6 +229,7 @@ local function childtables(key,tab,handler,depth)
childtables(s,v,handler,depth+1)
end
end
+end
else
handler(s,t,depth)
end
@@ -245,6 +252,7 @@ end
local function show(title,subtitle,alias,builtin,t,lib,libcolor,glo,glocolor,mark,obsolete)
-- todo: table as argument
+-- print(title,subtitle,alias,builtin,t,lib,libcolor,glo,glocolor,mark,obsolete)
local keys = sortedkeys(t) -- no sorted_pairs
if #keys > 0 then
local fulltitle = title
@@ -341,6 +349,8 @@ end
show("global","",sameglobal.global,false,_G,builtin,"darkgreen",globals,"darkblue",false,obsolete)
+-- inspect(table.sortedkeys(context))
+
for k, v in table.sortedpairs(_G) do
if not skipglobal[k] and not obsolete[k] and type(v) == "table" and not marked(v) then
@@ -351,7 +361,8 @@ for k, v in table.sortedpairs(_G) do
elseif extralua[k] then show(k,"extra lua",sameglobal[k],extralua[k],v,builtin[k],"darkred", false,false,true)
elseif basictex[k] then show(k,"basic tex",sameglobal[k],basictex[k],v,builtin[k],"darkred", false,false,true)
elseif extratex[k] then show(k,"extra tex",sameglobal[k],extratex[k],v,builtin[k],"darkred", false,false,true)
- else show(k,"context", sameglobal[k],false, v,builtin[k],"darkyellow",false,false,true)
+ else
+ show(k,"context", sameglobal[k],false, v,builtin[k],"darkyellow",false,false,true)
end
end
end
diff --git a/tex/context/base/s-math-repertoire.mkiv b/tex/context/base/s-math-repertoire.mkiv
index eeda5f66c..08c58aea3 100644
--- a/tex/context/base/s-math-repertoire.mkiv
+++ b/tex/context/base/s-math-repertoire.mkiv
@@ -421,7 +421,7 @@
\continueifinputfile{s-math-repertoire.mkiv}
-\showmathcharacterssetbodyfonts{lucidaot,cambria,xits,modern,pagella,termes,bonum,schola}
+\showmathcharacterssetbodyfonts{lucidaot,cambria,xits,modern,pagella,termes,bonum,schola,dejavu}
\starttext
@@ -437,10 +437,11 @@
% \setupbodyfont[stix, 12pt]
% \setupbodyfont[xits, 12pt]
% \setupbodyfont[lucida, 12pt]
- \setupbodyfont[lucidaot, 12pt]
+ % \setupbodyfont[lucidaot, 12pt]
% \setupbodyfont[pagella, 12pt]
% \setupbodyfont[bonum, 12pt]
% \setupbodyfont[schola, 12pt]
+ \setupbodyfont[dejavu, 12pt]
} {
diff --git a/tex/context/base/scrn-pag.mkvi b/tex/context/base/scrn-pag.mkvi
index 5bbdadda8..749c98e7a 100644
--- a/tex/context/base/scrn-pag.mkvi
+++ b/tex/context/base/scrn-pag.mkvi
@@ -124,13 +124,24 @@
%
% \starttext \input ward \stoptext
-\def\scrn_canvas_synchronize_simple
+\let\scrn_canvas_synchronize_simple \relax
+\let\scrn_canvas_synchronize_complex\relax
+
+\appendtoks
+ \global\let\scrn_canvas_synchronize_simple \scrn_canvas_synchronize_simple_indeed
+ \global\let\scrn_canvas_synchronize_complex\scrn_canvas_synchronize_complex_indeed
+\to \everysetuplayout
+
+\def\scrn_canvas_synchronize_simple_indeed
{\ctxcommand{setupcanvas{
paperwidth = \number\printpaperwidth,
paperheight = \number\printpaperheight
- }}}
+ }}%
+ %\global\let\scrn_canvas_synchronize_simple \relax
+ \global\let\scrn_canvas_synchronize_complex\relax
+ }
-\def\scrn_canvas_synchronize_complex
+\def\scrn_canvas_synchronize_complex_indeed
{\scrn_canvas_calculate % otherwise we need to hook it into setuppage etc
\ctxcommand{setupcanvas{
mode = "\interactionscreenparameter\c!option",
@@ -142,12 +153,22 @@
height = \number\canvasheight,
paperwidth = \number\canvasmaxwidth,
paperheight = \number\canvasmaxheight
- }}}
+ }}%
+ %\global\let\scrn_canvas_synchronize_simple \relax
+ \global\let\scrn_canvas_synchronize_complex\relax
+ }
\appendtoks
- \doifcommonelse{\interactionscreenparameter\c!option}{\v!max,\v!fit}%
- {\global\settrue \c_scrn_canvas_tight_page}%
- {\global\setfalse\c_scrn_canvas_tight_page}%
+ \begingroup
+ \edef\p_option{\interactionscreenparameter\c!option}%
+ \ifx\p_option\v!max
+ \global\settrue \c_scrn_canvas_tight_page
+ \else\ifx\p_option\v!fit
+ \global\settrue \c_scrn_canvas_tight_page
+ \else
+ \global\setfalse\c_scrn_canvas_tight_page
+ \fi\fi
+ \endgroup
\to \everysetupinteractionscreen
\setupinteractionscreen
@@ -159,6 +180,11 @@
\c!topspace=\topspace,
\c!option=\v!auto]
+\appendtoks
+ \global\let\scrn_canvas_synchronize_simple \scrn_canvas_synchronize_simple
+ \global\let\scrn_canvas_synchronize_complex\scrn_canvas_synchronize_complex
+\to \everysetupinteractionscreen
+
%D Conditional page breaks:
\unexpanded\def\screen
@@ -177,7 +203,10 @@
{\dosingleempty\scrn_transitions_setup}
\def\scrn_transitions_setup[#list]%
- {\edef\scrn_transitions_list{#list}}
+ {\edef\scrn_transitions_list{#list}%
+ \ifx\scrn_transitions_list\v!reset
+ \let\scrn_transitions_list\empty
+ \fi}
\def\scrn_transitions_set
{\iflocation \ifx\scrn_transitions_list\empty \else
diff --git a/tex/context/base/spac-ver.mkiv b/tex/context/base/spac-ver.mkiv
index d61c7651b..d635d1435 100644
--- a/tex/context/base/spac-ver.mkiv
+++ b/tex/context/base/spac-ver.mkiv
@@ -142,6 +142,20 @@
\spacing\currentrelativeinterlinespace
\fi}
+\unexpanded\def\spac_linespacing_setup_use
+ {\ifcsname\namedinterlinespacehash\m_spac_interlinespace\s!parent\endcsname
+ \let\currentinterlinespace\m_spac_interlinespace
+ \spac_linespacing_setup_specified_interline_space
+ % \else
+ % we only support named interlinespaces
+ \fi}
+
+\unexpanded\def\useinterlinespaceparameter#1% see footnotes
+ {\edef\m_spac_interlinespace{#1\c!interlinespace}%
+ \ifx\m_spac_interlinespace\empty \else
+ \spac_linespacing_setup_use
+ \fi}
+
\newtoks\everysetupglobalinterlinespace
\newtoks\everysetuplocalinterlinespace
diff --git a/tex/context/base/status-files.pdf b/tex/context/base/status-files.pdf
index fc9fe0003..d42a70729 100644
--- a/tex/context/base/status-files.pdf
+++ b/tex/context/base/status-files.pdf
Binary files differ
diff --git a/tex/context/base/status-lua.pdf b/tex/context/base/status-lua.pdf
index 0a2a851dc..1905df03e 100644
--- a/tex/context/base/status-lua.pdf
+++ b/tex/context/base/status-lua.pdf
Binary files differ
diff --git a/tex/context/base/status-mkiv.lua b/tex/context/base/status-mkiv.lua
index 11d9991d6..45c282256 100644
--- a/tex/context/base/status-mkiv.lua
+++ b/tex/context/base/status-mkiv.lua
@@ -320,7 +320,6 @@ return {
},
{
category = "mkiv",
- comment = "maybe this becomes a runtime module",
filename = "toks-ini",
loading = "always",
status = "okay",
@@ -4758,7 +4757,14 @@ return {
{
category = "lua",
filename = "toks-ini",
- status = "todo",
+ loading = "toks-ini",
+ status = "okay",
+ },
+ {
+ category = "lua",
+ filename = "toks-scn",
+ loading = "toks-ini",
+ status = "okay",
},
{
category = "lua",
diff --git a/tex/context/base/strc-doc.lua b/tex/context/base/strc-doc.lua
index f63832035..1f7f01e4f 100644
--- a/tex/context/base/strc-doc.lua
+++ b/tex/context/base/strc-doc.lua
@@ -1011,18 +1011,3 @@ commands.popsectionblock = sections.popblock
commands.registersection = sections.register
commands.setsectionentry = sections.setentry
commands.reportstructure = sections.reportstructure
---
-
--- local byway = "^" .. v_by -- ugly but downward compatible
-
--- function commands.way(way)
--- context((gsub(way,byway,"")))
--- end
-
-local pattern = P(v_by)^-1 * C(P(1)^1)
-
-function commands.way(way)
- if way ~= "" then
- context(lpegmatch(pattern,way))
- end
-end
diff --git a/tex/context/base/strc-not.mkvi b/tex/context/base/strc-not.mkvi
index 3de4766ca..982dc2fbe 100644
--- a/tex/context/base/strc-not.mkvi
+++ b/tex/context/base/strc-not.mkvi
@@ -1182,6 +1182,7 @@
\insert\currentnoteinsertionnumber\bgroup
\the\everyinsidenoteinsert\relax
\usesetupsparameter\noteparameter % experimental
+ \useinterlinespaceparameter\noteparameter
\doifelse{\noteparameter\c!paragraph}\v!yes
{\nointerlineskip
\startvboxtohboxseparator
@@ -1354,11 +1355,14 @@
% idea: tag with attr and then just flush them again
\def\strc_notes_flush_global
- {\doifelse{\noteparameter\c!paragraph}\v!yes
+ {\begingroup
+ \useinterlinespaceparameter\noteparameter
+ \doifelse{\noteparameter\c!paragraph}\v!yes
{\vbox\starthboxestohbox
\iftrialtypesetting\unvcopy\else\unvbox\fi\currentnoteinsertionnumber
\stophboxestohbox}
- {\iftrialtypesetting\unvcopied\else\unvboxed\fi\currentnoteinsertionnumber}}
+ {\iftrialtypesetting\unvcopied\else\unvboxed\fi\currentnoteinsertionnumber}%
+ \endgroup}
%D Supporting end notes is surprisingly easy. Even better, we
%D can combine this feature with solving the common \TEX\
diff --git a/tex/context/base/strc-num.lua b/tex/context/base/strc-num.lua
index e1fc60030..808d23fde 100644
--- a/tex/context/base/strc-num.lua
+++ b/tex/context/base/strc-num.lua
@@ -589,6 +589,15 @@ function commands.doifnotcounter (name) commands.doifnot (counterdata[name]) end
function commands.incrementedcounter(...) context(counters.add(...)) end
+local pattern = lpeg.P(variables.by)^-1 * lpeg.C(lpeg.P(1)^1)
+local lpegmatch = lpeg.match
+
+function commands.way(way)
+ if way and way ~= "" then
+ context(lpegmatch(pattern,way))
+ end
+end
+
-- the noreset is somewhat messy ... always false messes up e.g. itemize but true the pagenumbers
--
-- if this fails i'll clean up this still somewhat experimental mechanism (but i need use cases)
diff --git a/tex/context/base/strc-reg.mkiv b/tex/context/base/strc-reg.mkiv
index eedf86a66..f08a65516 100644
--- a/tex/context/base/strc-reg.mkiv
+++ b/tex/context/base/strc-reg.mkiv
@@ -314,7 +314,7 @@
\setnextinternalreference
\xdef\currentregisternumber{\ctxcommand{storeregister{
metadata = { name = "\currentregister" },
- entries = { { \!!bs#2\!!es }, { \!!bs#3\!!es } },
+ entries = { \!!bs#2\!!es, \!!bs#3\!!es },
processors = { \!!bs#4\!!es, \!!bs#5\!!es },
}
}}%
diff --git a/tex/context/base/supp-box.mkiv b/tex/context/base/supp-box.mkiv
index 26609443b..5cfedac7c 100644
--- a/tex/context/base/supp-box.mkiv
+++ b/tex/context/base/supp-box.mkiv
@@ -2803,6 +2803,10 @@
\setbox\nextbox\hbox{#2}%
\normalexpanded{\endgroup\edef\noexpand#1{\ctxcommand{boxtostring(\number\nextbox)}}}}
+%D Even more dirty:
+
+\let\hyphenatedhbox\hbox
+
\protect \endinput
% a bit of test code:
diff --git a/tex/context/base/syst-aux.lua b/tex/context/base/syst-aux.lua
index 69c9f8168..fba27a303 100644
--- a/tex/context/base/syst-aux.lua
+++ b/tex/context/base/syst-aux.lua
@@ -11,18 +11,23 @@ if not modules then modules = { } end modules ['syst-aux'] = {
-- utfmatch(str,"(.?)(.*)$")
-- utf.sub(str,1,1)
-local commands, context = commands, context
-
local tonumber = tonumber
-local settings_to_array = utilities.parsers.settings_to_array
local format = string.format
local utfsub = utf.sub
-local P, S, R, C, Cc, Cs, Carg, lpegmatch, utf8character = lpeg.P, lpeg.S, lpeg.R, lpeg.C, lpeg.Cc, lpeg.Cs, lpeg.Carg, lpeg.match, lpeg.patterns.utf8character
+local P, S, R, C, Cc, Cs, Carg, lpegmatch = lpeg.P, lpeg.S, lpeg.R, lpeg.C, lpeg.Cc, lpeg.Cs, lpeg.Carg, lpeg.match
local todimen = number.todimen
-local setvalue = context.setvalue
+local commands = commands
+local context = context
+
+local setcatcode = tex.setcatcode
+
+local utf8character = lpeg.patterns.utf8character
+local settings_to_array = utilities.parsers.settings_to_array
+
+local setvalue = context.setvalue
-local pattern = C(utf8character^-1) * C(P(1)^0)
+local pattern = C(utf8character^-1) * C(P(1)^0)
function commands.getfirstcharacter(str)
local first, rest = lpegmatch(pattern,str)
@@ -99,8 +104,15 @@ local sentinel = spaces * (nohash^1 / "\\%0")
local sargument = (single * digit)^1
local dargument = (double * digit)^1
-local pattern = Cs(
- ( P("global") / "\\global" )^0
+local usespaces = nil
+local texpreamble = nil
+
+local pattern = Cs( -- ^-1
+ ( P("spaces") / function() usespaces = true return "" end )^0
+ * spaces
+ * ( P("nospaces") / function() usespaces = false return "" end )^0
+ * spaces
+ * ( P("global") / "\\global" )^0
* spaces
* ( P("unexpanded") / "\\unexpanded" )^0
* spaces
@@ -119,10 +131,27 @@ local pattern = Cs(
)
)
-function commands.thetexdefinition(str)
--- print(str)
--- print(lpegmatch(pattern,str))
- context(lpegmatch(pattern,str))
+local ctx_dostarttexdefinition = context.dostarttexdefinition
+
+function commands.texdefinition_1(str)
+ usespaces = nil
+ texpreamble = lpegmatch(pattern,str)
+ if usespaces == true then
+ setcatcode(32,10) -- space
+ setcatcode(13, 5) -- endofline
+ elseif usespaces == false then
+ setcatcode(32, 9) -- ignore
+ setcatcode(13, 9) -- ignore
+ else
+ -- this is default
+ -- setcatcode(32,10) -- space
+ -- setcatcode(13, 9) -- ignore
+ end
+ ctx_dostarttexdefinition()
+end
+
+function commands.texdefinition_2()
+ context(texpreamble)
end
local upper, lower, strip = utf.upper, utf.lower, string.strip
diff --git a/tex/context/base/syst-aux.mkiv b/tex/context/base/syst-aux.mkiv
index 38afd034f..9546026e9 100644
--- a/tex/context/base/syst-aux.mkiv
+++ b/tex/context/base/syst-aux.mkiv
@@ -74,13 +74,20 @@
% %def\expunded#1{\normalexpanded\expandafter{#1}}
% \def\expunded#1{\expandafter\empty#1} % used within an edef anyway
-
%D As we don't have namespace definers yet, we use a special one:
-\newcount\c_syst_helpers_n_of_namespaces \c_syst_helpers_n_of_namespaces\pluseight % 1-8 reserved for catcodes
+\ifdefined\c_syst_helpers_n_of_namespaces
+
+ % lets plug in a better error message
+
+\else
+
+ \newcount\c_syst_helpers_n_of_namespaces \c_syst_helpers_n_of_namespaces\pluseight % 1-8 reserved for catcodes
+
+ \def\v_interfaces_prefix_template_system{\number \c_syst_helpers_n_of_namespaces>>}
+ %def\v_interfaces_prefix_template_system{\characters\c_syst_helpers_n_of_namespaces>>} % no \characters yet
-\def\v_interfaces_prefix_template_system{\number \c_syst_helpers_n_of_namespaces>>}
-%def\v_interfaces_prefix_template_system{\characters\c_syst_helpers_n_of_namespaces>>} % no \characters yet
+\fi
\unexpanded\def\installsystemnamespace#1% maybe move this to syst-ini
{\ifcsname ??#1\endcsname
@@ -3258,6 +3265,25 @@
% [here #oeps: \the\scratchcounter]
% \stoptexdefinition
+% \bgroup \obeylines
+%
+% \global\let\stoptexdefinition\relax
+%
+% \unexpanded\gdef\starttexdefinition%
+% {\bgroup%
+% \obeylines%
+% \syst_helpers_start_tex_definition_one}
+%
+% \gdef\syst_helpers_start_tex_definition_one#1
+% {\catcode\endoflineasciicode\ignorecatcode%
+% \syst_helpers_start_tex_definition_two{#1}}
+%
+% \gdef\syst_helpers_start_tex_definition_two#1#2\stoptexdefinition%
+% {\egroup%
+% \ctxcommand{thetexdefinition("#1")}{#2}}
+%
+% \egroup
+
\bgroup \obeylines
\global\let\stoptexdefinition\relax
@@ -3265,15 +3291,15 @@
\unexpanded\gdef\starttexdefinition%
{\bgroup%
\obeylines%
- \syst_helpers_start_tex_definition_one}
+ \syst_helpers_start_tex_definition}
-\gdef\syst_helpers_start_tex_definition_one#1
+\gdef\syst_helpers_start_tex_definition#1
{\catcode\endoflineasciicode\ignorecatcode%
- \syst_helpers_start_tex_definition_two{#1}}
+ \ctxcommand{texdefinition_1("#1")}}
-\gdef\syst_helpers_start_tex_definition_two#1#2\stoptexdefinition%
+\gdef\dostarttexdefinition#1\stoptexdefinition%
{\egroup%
- \ctxcommand{thetexdefinition("#1")}{#2}}
+ \ctxcommand{texdefinition_2()}{#1}}
\egroup
diff --git a/tex/context/base/syst-ini.mkiv b/tex/context/base/syst-ini.mkiv
index 879f3ed53..5ff80531a 100644
--- a/tex/context/base/syst-ini.mkiv
+++ b/tex/context/base/syst-ini.mkiv
@@ -1115,4 +1115,21 @@
%D
%D So let's see what \TEX\ can do now that we've opened up the basic machinery.
+%D Now we define a few helpers that we need in a very early stage. We hav eno message system
+%D yet but redundant definitions are fatal anyway.
+
+\newcount\c_syst_helpers_n_of_namespaces \c_syst_helpers_n_of_namespaces\pluseight % 1-8 reserved for catcodes
+
+\def\v_interfaces_prefix_template_system{\number \c_syst_helpers_n_of_namespaces>>}
+%def\v_interfaces_prefix_template_system{\characters\c_syst_helpers_n_of_namespaces>>} % no \characters yet
+
+\normalprotected\def\installsystemnamespace#1%
+ {\ifcsname ??#1\endcsname
+ \immediate\write16{fatal error: duplicate system namespace '#1'}%
+ \expandafter\normalend
+ \else
+ \global\advance\c_syst_helpers_n_of_namespaces\plusone
+ \expandafter\edef\csname ??#1\endcsname{\v_interfaces_prefix_template_system}%
+ \fi}
+
\protect \endinput
diff --git a/tex/context/base/syst-lua.lua b/tex/context/base/syst-lua.lua
index c50c5f1ca..37353c74e 100644
--- a/tex/context/base/syst-lua.lua
+++ b/tex/context/base/syst-lua.lua
@@ -14,6 +14,9 @@ commands = commands or { }
local commands = commands
local context = context
+local csprint = context.sprint
+
+local prtcatcodes = tex.prtcatcodes
function commands.writestatus(...) logs.status(...) end -- overloaded later
@@ -30,24 +33,30 @@ local ctx_gobbleoneargument = context.gobbleoneargument -- context.constru
function commands.doifelse(b)
if b then
ctx_firstoftwoarguments()
+-- csprint(prtcatcodes,[[\ui_ft]]) -- ctx_firstoftwoarguments
else
ctx_secondoftwoarguments()
+-- csprint(prtcatcodes,[[\ui_st]]) -- ctx_secondoftwoarguments
end
end
function commands.doif(b)
if b then
ctx_firstofoneargument()
+-- context.__flushdirect(prtcatcodes,[[\ui_fo]]) -- ctx_firstofonearguments
else
ctx_gobbleoneargument()
+-- context.__flushdirect(prtcatcodes,[[\ui_go]]) -- ctx_gobbleonearguments
end
end
function commands.doifnot(b)
if b then
ctx_gobbleoneargument()
+-- csprint(prtcatcodes,[[\ui_go]]) -- ctx_gobbleonearguments
else
ctx_firstofoneargument()
+-- csprint(prtcatcodes,[[\ui_fo]]) -- ctx_firstofonearguments
end
end
diff --git a/tex/context/base/toks-ini.lua b/tex/context/base/toks-ini.lua
index 82c801b88..9fcbd4345 100644
--- a/tex/context/base/toks-ini.lua
+++ b/tex/context/base/toks-ini.lua
@@ -61,6 +61,8 @@ if newtoken then
local scan_glue = newtoken.scan_glue
local scan_keyword = newtoken.scan_keyword
local scan_token = newtoken.scan_token
+ local scan_word = newtoken.scan_word
+ local scan_number = newtoken.scan_number
local get_next = newtoken.get_next
@@ -102,52 +104,69 @@ if newtoken then
local t = { } -- small optimization, a shared variable that is not reset
- local function scan_word()
- local n = 0
- while true do
- local c = scan_code()
- if c then
- n = n + 1
- t[n] = utfchar(c)
- elseif scan_code(space_bits) then
- if n > 0 then
+ if scan_word then
+
+ scan_number = function(base)
+ local s = scan_word()
+ if not s then
+ return nil
+ elseif base then
+ return tonumber(s,base)
+ else
+ return tonumber(s)
+ end
+ end
+
+ else
+
+ scan_word = function()
+ local n = 0
+ while true do
+ local c = scan_code()
+ if c then
+ n = n + 1
+ t[n] = utfchar(c)
+ elseif scan_code(space_bits) then
+ if n > 0 then
+ break
+ end
+ elseif n > 0 then
break
+ else
+ return
end
- elseif n > 0 then
- break
- else
- return
end
+ return concat(t,"",1,n)
end
- return concat(t,"",1,n)
- end
- -- so we gobble the space (like scan_int) (number has to be space or non-char terminated
- -- as we accept 0xabcd and such so there is no clear separator for a keyword
-
- local function scan_number(base)
- local n = 0
- while true do
- local c = scan_code()
- if c then
- n = n + 1
- t[n] = char(c)
- elseif scan_code(space_bits) then
- if n > 0 then
+ -- so we gobble the space (like scan_int) (number has to be space or non-char terminated
+ -- as we accept 0xabcd and such so there is no clear separator for a keyword
+
+ scan_number = function(base)
+ local n = 0
+ while true do
+ local c = scan_code()
+ if c then
+ n = n + 1
+ t[n] = char(c)
+ elseif scan_code(space_bits) then
+ if n > 0 then
+ break
+ end
+ elseif n > 0 then
break
+ else
+ return
end
- elseif n > 0 then
- break
+ end
+ local s = concat(t,"",1,n)
+ if base then
+ return tonumber(s,base)
else
- return
+ return tonumber(s)
end
end
- local s = concat(t,"",1,n)
- if base then
- return tonumber(s,base)
- else
- return tonumber(s)
- end
+
end
-- -- the next one cannot handle \iftrue true\else false\fi
@@ -193,10 +212,16 @@ if newtoken then
tokens.getters = { -- these don't expand
token = get_next,
+ count = tex.getcount,
+ dimen = tex.getdimen,
+ box = tex.getbox,
}
tokens.setters = {
macro = set_macro,
+ count = tex.setcount,
+ dimen = tex.setdimen,
+ box = tex.setbox,
}
end
diff --git a/tex/context/base/toks-ini.mkiv b/tex/context/base/toks-ini.mkiv
index c23b84e06..49625a939 100644
--- a/tex/context/base/toks-ini.mkiv
+++ b/tex/context/base/toks-ini.mkiv
@@ -14,6 +14,8 @@
\writestatus{loading}{ConTeXt Token Support / Initialization}
\registerctxluafile{toks-ini}{1.001}
+\registerctxluafile{toks-scn}{1.001}
+\registerctxluafile{cldf-scn}{1.001}
\unprotect
diff --git a/tex/context/base/toks-scn.lua b/tex/context/base/toks-scn.lua
new file mode 100644
index 000000000..3da962dad
--- /dev/null
+++ b/tex/context/base/toks-scn.lua
@@ -0,0 +1,378 @@
+if not modules then modules = { } end modules ['toks-scn'] = {
+ version = 1.001,
+ author = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
+ copyright = "PRAGMA ADE / ConTeXt Development Team",
+ license = "see context related readme files"
+}
+
+-- Writing this kind of code (and completing the newtoken code base) is fun. I did
+-- so with the brilliant film music from The Girl with the Dragon Tattoo running in a
+-- loop in the background (three cd's by Trent Reznor and Atticus Ross). An alien
+-- feeling helps with alien code.
+
+-- todo: more \let's at the tex end
+
+local type, next, tostring, tonumber = type, next, tostring, tonumber
+
+local formatters = string.formatters
+local concat = table.concat
+local loadstring = loadstring
+
+local scanners = tokens.scanners
+local tokenbits = tokens.bits
+
+if not scanners then return end -- for now
+
+local scanstring = scanners.string
+local scaninteger = scanners.integer
+local scannumber = scanners.number
+local scankeyword = scanners.keyword
+local scanword = scanners.word
+local scancode = scanners.code
+local scanboolean = scanners.boolean
+local scandimen = scanners.dimen
+
+if not scanstring then return end -- for now
+
+local todimen = number.todimen
+
+local lpegmatch = lpeg.match
+local p_unquoted = lpeg.patterns.unquoted
+
+local trace_compile = false trackers.register("tokens.compile", function(v) trace_compile = v end)
+local report_compile = logs.reporter("tokens","compile")
+local report_scan = logs.reporter("tokens","scan")
+
+local open = tokenbits.open
+local close = tokenbits.close
+
+local function scanopen()
+ while true do
+ local c = scancode(open)
+ if c == 123 then
+ return true
+ -- elseif c ~= 32 then
+ elseif not c then
+ return
+ end
+ end
+end
+
+local function scanclose()
+ while true do
+ local c = scancode(close)
+ if c == 125 then
+ return true
+ -- elseif c ~= 32 then
+ elseif not c then
+ return
+ end
+ end
+end
+
+scanners.scanopen = scanopen
+scanners.scanclose = scanclose
+
+local shortcuts = {
+ tokens = tokens,
+ bits = tokenbits,
+ open = open,
+ close = close,
+ scanners = scanners,
+ scanstring = scanstring,
+ scaninteger = scaninteger,
+ scannumber = scannumber,
+ scankeyword = scankeyword,
+ scanword = scanword,
+ scancode = scancode,
+ scanboolean = scanboolean,
+ scandimen = scandimen,
+ scandimension = scandimen,
+ scanopen = scanopen,
+ scanclose = scanclose,
+ todimen = todimen,
+ tonumber = tonumber,
+ tostring = tostring,
+ inspect = inspect,
+ report = report_scan,
+}
+
+tokens.shortcuts = shortcuts
+
+local load = load
+local dump = string.dump
+
+local function loadstripped(code)
+ return load(code,nil,nil,shortcuts)
+ -- return load(dump(load(code),true),nil,nil,shortcuts)
+end
+
+tokens.converters = {
+ tonumber = "tonumber",
+ todimen = "todimen",
+ toglue = "todimen",
+ tostring = "tostring",
+}
+
+local f_if = formatters[ " if scankeyword('%s') then data['%s'] = scan%s()"]
+local f_elseif = formatters[" elseif scankeyword('%s') then data['%s'] = scan%s()"]
+local f_local = formatters["local scan%s = scanners.%s"]
+local f_scan = formatters["scan%s()"]
+local f_shortcut = formatters["local %s = scanners.converters.%s"]
+
+local f_if_c = formatters[ " if scankeyword('%s') then data['%s'] = %s(scan%s())"]
+local f_elseif_c = formatters[" elseif scankeyword('%s') then data['%s'] = %s(scan%s())"]
+local f_scan_c = formatters["%s(scan%s())"]
+
+local f_any = formatters[" else local key = scanword() if key then data[key] = scan%s() else break end end"]
+local f_any_c = formatters[" else local key = scanword() if key then data[key] = %s(scan%s()) else break end end"]
+local s_done = " else break end"
+
+local f_table = formatters["%\nt\nreturn function()\n local data = { }\n%s\n return %s\nend\n"]
+local f_sequence = formatters["%\nt\n%\nt\n%\nt\nreturn function()\n return %s\nend\n"]
+local f_simple = formatters["%\nt\nreturn function()\n return %s\nend\n"]
+local f_string = formatters["%q"]
+local f_action_f = formatters["action%s(%s)"]
+local f_action_s = formatters["local action%s = tokens._action[%s]"]
+local f_nested = formatters["local function scan%s()\n local data = { }\n%s\n return data\nend\n"]
+
+-- local f_check = formatters[ [[
+-- local wrapped = false
+-- while true do
+-- local c = scancode(open)
+-- if c == 123 then
+-- wrapped = true
+-- break
+-- elseif c ~= 32 then
+-- break
+-- end
+-- end
+-- while true do
+-- ]] .. "%\nt\n" .. [[
+-- %s
+-- end
+-- if wrapped then
+-- while true do
+-- local c = scancode(close)
+-- if c == 125 then
+-- break
+-- elseif c ~= 32 then
+-- break
+-- end
+-- end
+-- end
+-- ]] ]
+
+local f_check = formatters[ [[
+ local wrapped = scanopen()
+ while true do
+ ]] .. "%\nt\n" .. [[
+ %s
+ end
+ if wrapped then
+ scanclose()
+ end
+]] ]
+
+function tokens.compile(specification)
+ local f = { }
+ local n = 0
+ local c = { }
+ local t = specification.arguments or specification
+ local a = specification.actions or nil
+ if type(a) == "function" then
+ a = { a }
+ end
+ local code
+ local function compile(t,nested)
+ local done = s_done
+ local r = { }
+ local m = 0
+ for i=1,#t do
+ local ti = t[i]
+ local t1 = ti[1]
+ local t2 = ti[2] or "string"
+ if type(t2) == "table" then
+ n = n + 1
+ f[n] = compile(t2,n)
+ t2 = n
+ end
+ local t3 = ti[3]
+ if type(t3) == "function" then
+ -- todo: also create shortcut
+ elseif t3 then
+ c[t3] = f_shortcut(t3,t3)
+ if t1 == "*" then
+ done = f_any_c(t3,t2)
+ else
+ m = m + 1
+ r[m] = (m > 1 and f_elseif_c or f_if_c)(t1,t1,t3,t2)
+ end
+ else
+ if t1 == "*" then
+ done = f_any(t2)
+ else
+ m = m + 1
+ r[m] = (m > 1 and f_elseif or f_if )(t1,t1,t2)
+ end
+ end
+ end
+ local c = f_check(r,done)
+ if nested then
+ return f_nested(nested,c)
+ else
+ return c
+ end
+ end
+ local tt = type(t)
+ if tt == "string" then
+ if a then
+ code = f_scan(t)
+ tokens._action = a
+ for i=1,#a do
+ code = f_action_f(i,code)
+ f[#f+1] = f_action_s(i,i)
+ end
+ code = f_simple(f,code)
+ else
+ return scanners[t]
+ end
+ elseif tt ~= "table" then
+ return
+ elseif #t == 1 then
+ local ti = t[1]
+ if type(ti) == "table" then
+ ti = compile(ti)
+ code = "data"
+ if a then
+ tokens._action = a
+ for i=1,#a do
+ code = f_action_f(i,code)
+ f[#f+1] = f_action_s(i,i)
+ end
+ end
+ code = f_table(f,ti,code)
+ elseif a then
+ code = f_scan(ti)
+ tokens._action = a
+ for i=1,#a do
+ code = f_action_f(i,code)
+ f[#f+1] = f_action_s(i,i)
+ end
+ code = f_simple(f,code)
+ else
+ return scanners[ti]
+ end
+ else
+ local r = { }
+ local p = { }
+ local m = 0
+ for i=1,#t do
+ local ti = t[i]
+ local tt = type(ti)
+ if tt == "table" then
+ if ti[1] == "_constant_" then
+ local v = ti[2]
+ if type(v) == "string" then
+ r[i] = f_string(v)
+ else
+ r[i] = tostring(v)
+ end
+ else
+ m = m + 1
+ p[m] = compile(ti,100+m)
+ r[i] = f_scan(100+m)
+ end
+ elseif tt == "number" then
+ r[i] = tostring(ti)
+ elseif tt == "boolean" then
+ r[i] = tostring(ti)
+ else
+ local s = lpegmatch(p_unquoted,ti)
+ if s and ti ~= s then
+ r[i] = ti -- a string, given as "'foo'" or '"foo"'
+ elseif scanners[ti] then
+ r[i] = f_scan(ti)
+ else
+ report_compile("unknown scanner %a",ti)
+ r[i] = ti
+ end
+ end
+ end
+ code = concat(r,",")
+ if a then
+ tokens._action = a
+ for i=1,#a do
+ code = f_action_f(i,code)
+ f[#f+1] = f_action_s(i,i)
+ end
+ end
+ code = f_sequence(c,f,p,code)
+ end
+ if not code then
+ return
+ end
+ if trace_compile then
+ report_compile("code: %s",code)
+ end
+ local code, message = loadstripped(code)
+ if code then
+ code = code() -- sets action
+ else
+ report_compile("error in code: %s",code)
+ report_compile("error message: %s",message)
+ end
+ if a then
+ tokens._action = nil
+ end
+ if code then
+ return code
+ end
+end
+
+-- local fetch = tokens.compile {
+-- "string",
+-- "string",
+-- {
+-- { "data", "string" },
+-- { "tab", "string" },
+-- { "method", "string" },
+-- { "foo", {
+-- { "method", "integer" },
+-- { "compact", "number" },
+-- { "nature" },
+-- { "*" }, -- any key
+-- } },
+-- { "compact", "string", "tonumber" },
+-- { "nature", "boolean" },
+-- { "escape", "string" },
+-- { "escape" },
+-- }
+-- "boolean",
+-- }
+--
+-- os.exit()
+
+function tokens.scantable(t,data)
+ if not data then
+ data = { }
+ end
+ local wrapped = scanopen()
+ while true do
+ local key = scanword()
+ if key then
+ local get = t[key]
+ if get then
+ data[key] = get()
+ else
+ -- catch all we can get
+ end
+ else
+ break
+ end
+ end
+ if wrapped then
+ scanclose()
+ end
+ return data
+end
diff --git a/tex/context/base/type-imp-dejavu.mkiv b/tex/context/base/type-imp-dejavu.mkiv
index de1f7752c..41cf1f701 100644
--- a/tex/context/base/type-imp-dejavu.mkiv
+++ b/tex/context/base/type-imp-dejavu.mkiv
@@ -15,33 +15,6 @@
\starttypescriptcollection[dejavu]
- \starttypescript [\s!mono] [dejavu-condensed] [\s!name]
- \setups[\s!font:\s!fallback:\s!mono]
- % \definefontsynonym [\s!Mono] [\s!name:dejavusansmonocondensed] [\s!features=\s!none]
- % \definefontsynonym [\s!MonoBold] [\s!name:dejavusansmonoboldcondensed] [\s!features=\s!none]
- % \definefontsynonym [\s!MonoItalic] [\s!name:dejavusansmonoobliquecondensed] [\s!features=\s!none]
- % \definefontsynonym [\s!MonoBoldItalic] [\s!name:dejavusansmonoboldobliquecondensed] [\s!features=\s!none]
- \definefontsynonym [\s!Mono] [\s!name:dejavusansmono] [\s!features=dejavu-condensed-mono]
- \definefontsynonym [\s!MonoBold] [\s!name:dejavusansmonobold] [\s!features=dejavu-condensed-mono]
- \definefontsynonym [\s!MonoItalic] [\s!name:dejavusansmonooblique] [\s!features=dejavu-condensed-mono]
- \definefontsynonym [\s!MonoBoldItalic] [\s!name:dejavusansmonoboldoblique] [\s!features=dejavu-condensed-mono]
- \stoptypescript
-
- % \starttypescript [\s!mono] [dejavu-condensed] [\s!name]
- % \setups[\s!font:\s!fallback:\s!mono]
- % \definefontsynonym [\s!Mono] [\s!name:dejavusansmono] [\s!features=\s!none]
- % \definefontsynonym [\s!MonoBold] [\s!name:dejavusansmonobold] [\s!features=\s!none]
- % \definefontsynonym [\s!MonoItalic] [\s!name:dejavusansmonooblique] [\s!features=\s!none]
- % \definefontsynonym [\s!MonoBoldItalic] [\s!name:dejavusansmonoboldoblique] [\s!features=\s!none]
- % \stoptypescript
-
- \starttypescript[dejavu-condensed]
- \definetypeface [dejavu-condensed] [\s!rm] [\s!serif] [dejavu-condensed] [\s!default]
- \definetypeface [dejavu-condensed] [\s!ss] [\s!sans] [dejavu-condensed] [\s!default]
- \definetypeface [dejavu-condensed] [\s!tt] [\s!mono] [dejavu-condensed] [\s!default]
- \definetypeface [dejavu-condensed] [\s!mm] [\s!math] [xits] [\s!default] [\s!rscale=1.2]
- \stoptypescript
-
\starttypescript [\s!serif] [dejavu] [\s!name]
\setups[\s!font:\s!fallback:\s!serif]
\definefontsynonym [\s!Serif] [\s!name:dejavuserif] [\s!features=\s!default]
@@ -66,11 +39,17 @@
\definefontsynonym [\s!MonoBoldItalic] [\s!name:dejavusansmonoboldoblique] [\s!features=\s!none]
\stoptypescript
+ \starttypescript [\s!math][dejavu][\s!name]
+ %\loadfontgoodies[dejavu]
+ \definefontsynonym[\s!MathRoman][file:dejavu-math.otf][\s!features=\s!math\mathsizesuffix]
+ \stoptypescript
+
\starttypescript[dejavu]
\definetypeface [dejavu] [\s!rm] [\s!serif] [dejavu] [\s!default]
\definetypeface [dejavu] [\s!ss] [\s!sans] [dejavu] [\s!default]
\definetypeface [dejavu] [\s!tt] [\s!mono] [dejavu] [\s!default]
- \definetypeface [dejavu] [\s!mm] [\s!math] [xits] [\s!default] [\s!rscale=1.2]
+% \definetypeface [dejavu] [\s!mm] [\s!math] [xits] [\s!default] [\s!rscale=1.2]
+ \definetypeface [dejavu] [\s!mm] [\s!math] [dejavu] [\s!default]
\stoptypescript
\starttypescript[dejavubidi]
@@ -96,4 +75,32 @@
\definefontsynonym [\s!SansBoldItalic] [\s!name:dejavusanscondensedboldoblique] [\s!features=\s!default]
\stoptypescript
+ \starttypescript [\s!mono] [dejavu-condensed] [\s!name]
+ \setups[\s!font:\s!fallback:\s!mono]
+ % \definefontsynonym [\s!Mono] [\s!name:dejavusansmonocondensed] [\s!features=\s!none]
+ % \definefontsynonym [\s!MonoBold] [\s!name:dejavusansmonoboldcondensed] [\s!features=\s!none]
+ % \definefontsynonym [\s!MonoItalic] [\s!name:dejavusansmonoobliquecondensed] [\s!features=\s!none]
+ % \definefontsynonym [\s!MonoBoldItalic] [\s!name:dejavusansmonoboldobliquecondensed] [\s!features=\s!none]
+ \definefontsynonym [\s!Mono] [\s!name:dejavusansmono] [\s!features=dejavu-condensed-mono]
+ \definefontsynonym [\s!MonoBold] [\s!name:dejavusansmonobold] [\s!features=dejavu-condensed-mono]
+ \definefontsynonym [\s!MonoItalic] [\s!name:dejavusansmonooblique] [\s!features=dejavu-condensed-mono]
+ \definefontsynonym [\s!MonoBoldItalic] [\s!name:dejavusansmonoboldoblique] [\s!features=dejavu-condensed-mono]
+ \stoptypescript
+
+ % \starttypescript [\s!mono] [dejavu-condensed] [\s!name]
+ % \setups[\s!font:\s!fallback:\s!mono]
+ % \definefontsynonym [\s!Mono] [\s!name:dejavusansmono] [\s!features=\s!none]
+ % \definefontsynonym [\s!MonoBold] [\s!name:dejavusansmonobold] [\s!features=\s!none]
+ % \definefontsynonym [\s!MonoItalic] [\s!name:dejavusansmonooblique] [\s!features=\s!none]
+ % \definefontsynonym [\s!MonoBoldItalic] [\s!name:dejavusansmonoboldoblique] [\s!features=\s!none]
+ % \stoptypescript
+
+ \starttypescript[dejavu-condensed]
+ \definetypeface [dejavu-condensed] [\s!rm] [\s!serif] [dejavu-condensed] [\s!default]
+ \definetypeface [dejavu-condensed] [\s!ss] [\s!sans] [dejavu-condensed] [\s!default]
+ \definetypeface [dejavu-condensed] [\s!tt] [\s!mono] [dejavu-condensed] [\s!default]
+% \definetypeface [dejavu-condensed] [\s!mm] [\s!math] [xits] [\s!default] [\s!rscale=1.2]
+ \definetypeface [dejavu-condensed] [\s!mm] [\s!math] [dejavu] [\s!default]
+ \stoptypescript
+
\stoptypescriptcollection
diff --git a/tex/context/base/typo-del.mkiv b/tex/context/base/typo-del.mkiv
index 2b4e6e6aa..4c3c5ab3d 100644
--- a/tex/context/base/typo-del.mkiv
+++ b/tex/context/base/typo-del.mkiv
@@ -394,7 +394,7 @@
\blank[\p_delimited_spaceafter]%
\fi
\useindentnextparameter\delimitedtextparameter
- \dorechecknextindentation}% AM: This was missing!
+ \aftergroup\dorechecknextindentation}% AM: This was missing!
\def\typo_delimited_start_txt
{\let\typo_delimited_stop\typo_delimited_stop_txt
diff --git a/tex/context/base/typo-itc.lua b/tex/context/base/typo-itc.lua
index 5e1ff3fbc..1de481a49 100644
--- a/tex/context/base/typo-itc.lua
+++ b/tex/context/base/typo-itc.lua
@@ -228,6 +228,12 @@ function italics.handler(head)
replaceinserted = nil
postinserted = nil
elseif id == disc_code then
+ previnserted = nil
+ previtalic = 0
+ replaceinserted = nil
+ replaceitalic = 0
+ postinserted = nil
+ postitalic = 0
replace = getfield(current,"replace")
if replace then
local current = find_tail(replace)
@@ -259,18 +265,21 @@ function italics.handler(head)
replace = current
end
end
- else
- replaceitalic = 0
+-- else
+-- replaceitalic = 0
end
- else
- replaceitalic = 0
+-- else
+-- replaceitalic = 0
end
- else
- replaceitalic = 0
+-- else
+-- replaceitalic = 0
end
- replaceinserted = nil
+-- replaceinserted = nil
+-- else
+-- replaceitalic = 0
+-- replaceinserted = nil
end
- local post = getfield(current,"post")
+ post = getfield(current,"post")
if post then
local current = find_tail(post)
if getid(current) ~= glyph_code then
@@ -286,7 +295,7 @@ function italics.handler(head)
local cd = data[char]
if not cd then
-- this really can happen
- postitalic = 0
+-- postitalic = 0
else
postitalic = cd.italic or cd.italic_correction
if not postitalic then
@@ -301,16 +310,19 @@ function italics.handler(head)
post = current
end
end
- else
- postitalic = 0
+-- else
+-- postitalic = 0
end
- else
- postitalic = 0
+-- else
+-- postitalic = 0
end
- else
- postitalic = 0
+-- else
+-- postitalic = 0
end
- postinserted = nil
+-- postinserted = nil
+-- else
+-- postitalic = 0
+-- postinserted = nil
end
elseif id == kern_code then -- how about fontkern ?
previnserted = nil
@@ -350,23 +362,37 @@ function italics.handler(head)
end
elseif id == math_code then
current = end_of_math(current)
+ previnserted = nil
+ previtalic = 0
+ replaceinserted = nil
+ replaceitalic = 0
+ postinserted = nil
+ postitalic = 0
else
if previtalic ~= 0 then
if trace_italics then
report_italics("inserting %p between %s italic %C and whatever",previtalic,"glyph",prevchar)
end
insert_node_after(prevhead,prev,new_correction_kern(previtalic))
- previnserted = nil
- previtalic = 0
- done = true
+ previnserted = nil
+ previtalic = 0
+ replaceinserted = nil
+ replaceitalic = 0
+ postinserted = nil
+ postitalic = 0
+ done = true
else
if replaceitalic ~= 0 then
if trace_italics then
report_italics("inserting %p between %s italic %C and whatever",replaceritalic,"replace",replacechar)
end
insert_node_after(replacehead,replace,new_correction_kern(replaceitalic))
- replaceitalic = 0
+ previnserted = nil
+ previtalic = 0
replaceinserted = nil
+ replaceitalic = 0
+ postinserted = nil
+ postitalic = 0
done = true
end
if postitalic ~= 0 then
@@ -374,9 +400,13 @@ function italics.handler(head)
report_italics("inserting %p between %s italic %C and whatever",postitalic,"post",postchar)
end
insert_node_after(posthead,post,new_correction_kern(postitalic))
- postinserted = nil
- postitalic = 0
- done = true
+ previnserted = nil
+ previtalic = 0
+ replaceinserted = nil
+ replaceitalic = 0
+ postinserted = nil
+ postitalic = 0
+ done = true
end
end
end
diff --git a/tex/context/base/util-seq.lua b/tex/context/base/util-seq.lua
index 4dd9ddc33..08fc4e95c 100644
--- a/tex/context/base/util-seq.lua
+++ b/tex/context/base/util-seq.lua
@@ -17,13 +17,15 @@ use locals to refer to them when compiling the chain.</p>
-- todo: protect groups (as in tasks)
-local format, gsub, concat, gmatch = string.format, string.gsub, table.concat, string.gmatch
+local gsub, concat, gmatch = string.gsub, table.concat, string.gmatch
local type, load = type, load
utilities = utilities or { }
local tables = utilities.tables
local allocate = utilities.storage.allocate
+local formatters = string.formatters
+
local sequencers = { }
utilities.sequencers = sequencers
@@ -217,20 +219,23 @@ local function construct(t)
for i=1,#actions do
local action = actions[i]
if not askip[action] then
+ local localized
if type(action) == "function" then
local name = localize(tostring(action))
functions[name] = action
- action = format("utilities.sequencers.functions.%s",name)
+ action = formatters["utilities.sequencers.functions.%s"](name)
+ localized = localize(name) -- shorter than action
+ else
+ localized = localize(action)
end
- local localized = localize(action)
n = n + 1
- variables[n] = format("local %s = %s",localized,action)
+ variables[n] = formatters["local %s = %s"](localized,action)
if not returnvalues then
- calls[n] = format("%s(%s)",localized,arguments)
+ calls[n] = formatters["%s(%s)"](localized,arguments)
elseif n == 1 then
- calls[n] = format("local %s = %s(%s)",returnvalues,localized,arguments)
+ calls[n] = formatters["local %s = %s(%s)"](returnvalues,localized,arguments)
else
- calls[n] = format("%s = %s(%s)",returnvalues,localized,arguments)
+ calls[n] = formatters["%s = %s(%s)"](returnvalues,localized,arguments)
end
end
end
@@ -243,9 +248,9 @@ local function construct(t)
variables = concat(variables,"\n")
calls = concat(calls,"\n")
if results then
- t.compiled = format("%s\nreturn function(%s)\n%s\nreturn %s\nend",variables,arguments,calls,results)
+ t.compiled = formatters["%s\nreturn function(%s)\n%s\nreturn %s\nend"](variables,arguments,calls,results)
else
- t.compiled = format("%s\nreturn function(%s)\n%s\nend",variables,arguments,calls)
+ t.compiled = formatters["%s\nreturn function(%s)\n%s\nend"](variables,arguments,calls)
end
end
-- print(t.compiled)
@@ -271,6 +276,7 @@ compile = function(t,compiler,n) -- already referred to in sequencers.new
if compiled == "" then
runner = false
else
+-- inspect(compiled)
runner = compiled and load(compiled)() -- we can use loadstripped here
end
t.runner = runner
@@ -327,12 +333,12 @@ function sequencers.nodeprocessor(t,nofarguments) -- todo: handle 'kind' in plug
if not askip[action] then
local localized = localize(action)
n = n + 1
- vars[n] = format("local %s = %s",localized,action)
+ vars[n] = formatters["local %s = %s"](localized,action)
-- only difference with tostring is kind and rets (why no return)
if kind[action] == "nohead" then
- calls[n] = format(" ok = %s(head%s) done = done or ok",localized,args)
+ calls[n] = formatters[" ok = %s(head%s) done = done or ok"](localized,args)
else
- calls[n] = format(" head, ok = %s(head%s) done = done or ok",localized,args)
+ calls[n] = formatters[" head, ok = %s(head%s) done = done or ok"](localized,args)
end
-- local s = " print('" .. tostring(group) .. " " .. tostring(action) .. " : ' .. tostring(head)) "
-- calls[n] = s .. calls[n] .. s
@@ -340,6 +346,6 @@ function sequencers.nodeprocessor(t,nofarguments) -- todo: handle 'kind' in plug
end
end
end
- local processor = #calls > 0 and format(template_yes,concat(vars,"\n"),args,concat(calls,"\n")) or template_nop
+ local processor = #calls > 0 and formatters[template_yes](concat(vars,"\n"),args,concat(calls,"\n")) or template_nop
return processor
end
diff --git a/tex/context/base/x-set-11.mkiv b/tex/context/base/x-set-11.mkiv
index c0575e625..53e172102 100644
--- a/tex/context/base/x-set-11.mkiv
+++ b/tex/context/base/x-set-11.mkiv
@@ -57,7 +57,7 @@
2: -- wordt verwerkt
3: -- is niet gedefinieerd
4: -- wordt nogmaals verwerkt
- optional: optioneel
+ optional: opt
displaymath: formule
index: ingang
math: formule
@@ -95,7 +95,7 @@
2: -- is processed
3: -- is undefined
4: -- is processed again
- optional: optional
+ optional: opt
displaymath: formula
index: entry
math: formula
@@ -133,7 +133,7 @@
2: -- wird verarbeitet
3: -- ist undefiniert
4: -- ist mehrmals verarbeitet
- optional: optioneel
+ optional: opt
displaymath: formula
index: entry
math: formula
@@ -171,7 +171,7 @@
2: -- je zpracovano
3: -- je nedefinovano
4: -- je zpracovano znovu
- optional: optioneel
+ optional: opt
displaymath: formula
index: entry
math: formula
@@ -209,7 +209,7 @@
2: -- is processed
3: -- is undefined
4: -- is processed again
- optional: optioneel
+ optional: opt
displaymath: formula
index: entry
math: formula
@@ -247,7 +247,7 @@
2: este procesat --
3: -- este nedefinit
4: -- este procesat din nou
- optional: optioneel
+ optional: opt
displaymath: formula
index: entry
math: formula
@@ -285,7 +285,7 @@
2: -- est traité
3: -- n'est pas défini
4: -- est traité de nouveau
- optional: optionel
+ optional: opt
displaymath: formule
index: entrée
math: formule
diff --git a/tex/context/base/x-xtag.mkiv b/tex/context/base/x-xtag.mkiv
index 09490cc8f..ab95c567e 100644
--- a/tex/context/base/x-xtag.mkiv
+++ b/tex/context/base/x-xtag.mkiv
@@ -14,7 +14,7 @@
%D Here we load the \MKII\ (mostly) streaming \XML\ parser. We
%D define a couple of catcode regimes first.
-\ifdefined\XMLbanner \endinput \fi
+\endinput
\writestatus{xtag}{this module is obsolete, use the mkiv-xml features or use mkii instead}
diff --git a/tex/generic/context/luatex/luatex-fonts-merged.lua b/tex/generic/context/luatex/luatex-fonts-merged.lua
index b6621525a..0c307c7bc 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 : 03/10/15 12:09:17
+-- merge date : 03/25/15 22:13:54
do -- begin closure to overcome local limits and interference
@@ -660,24 +660,48 @@ function lpeg.append(list,pp,delayed,checked)
end
return p
end
+local p_false=P(false)
+local p_true=P(true)
local function make(t,hash)
- local p=P(false)
+ local p=p_false
local keys=sortedkeys(t)
+ local function making(t,w)
+ local p=p_false
+ local keys=sortedkeys(t)
+ for i=1,#keys do
+ local k=keys[i]
+ local v=t[k]
+ if w then
+ if v==true then
+ p=p+P(k)*p_true
+ else
+ p=p+P(k)*(making(v,w)+p_true)
+ end
+ else
+ if v==true then
+ p=p+P(k)
+ else
+ p=p+P(k)*making(v,w)
+ end
+ end
+ end
+ return p
+ end
for i=1,#keys do
local k=keys[i]
local v=t[k]
local h=hash[v]
if h then
- if next(v) then
- p=p+P(k)*(make(v,hash)+P(true))
+ if v==true then
+ p=p+P(k)*p_true
else
- p=p+P(k)*P(true)
+ p=p+P(k)*(making(v,true)+p_true)
end
else
- if next(v) then
- p=p+P(k)*make(v,hash)
- else
+ if v==true then
p=p+P(k)
+ else
+ p=p+P(k)*making(v,false)
end
end
end
@@ -685,34 +709,55 @@ local function make(t,hash)
end
function lpeg.utfchartabletopattern(list)
local tree={}
- local hash={}
+ local hash
local n=#list
if n==0 then
+ hash=list
for s in next,list do
local t=tree
+ local p,pk
for c in gmatch(s,".") do
- local tc=t[c]
- if not tc then
- tc={}
- t[c]=tc
+ if t==true then
+ t={ [c]=true }
+ p[pk]=t
+ p=t
+ t=true
+ else
+ local tc=t[c]
+ if not tc then
+ tc=true
+ t[c]=tc
+ end
+ p=t
+ t=tc
end
- t=tc
+ pk=c
end
- hash[t]=s
end
else
+ hash={}
for i=1,n do
local t=tree
local s=list[i]
+ local p,pk
for c in gmatch(s,".") do
- local tc=t[c]
- if not tc then
- tc={}
- t[c]=tc
+ if t==true then
+ t={ [c]=true }
+ p[pk]=t
+ p=t
+ t=true
+ else
+ local tc=t[c]
+ if not tc then
+ tc=true
+ t[c]=true
+ end
+ p=t
+ t=tc
end
- t=tc
+ pk=c
end
- hash[t]=s
+ hash[s]=true
end
end
return make(tree,hash)
@@ -5280,6 +5325,7 @@ local report_fonts=logs.reporter("fonts","loading")
local fonts=fonts or {}
local mappings=fonts.mappings or {}
fonts.mappings=mappings
+local allocate=utilities.storage.allocate
local function loadlumtable(filename)
local lumname=file.replacesuffix(file.basename(filename),"lum")
local lumfile=resolvers.findfile(lumname,"map") or ""
@@ -5381,7 +5427,7 @@ mappings.fromunicode16=fromunicode16
local ligseparator=P("_")
local varseparator=P(".")
local namesplitter=Ct(C((1-ligseparator-varseparator)^1)*(ligseparator*C((1-ligseparator-varseparator)^1))^0)
-local overloads={
+local overloads=allocate {
IJ={ name="I_J",unicode={ 0x49,0x4A },mess=0x0132 },
ij={ name="i_j",unicode={ 0x69,0x6A },mess=0x0133 },
ff={ name="f_f",unicode={ 0x66,0x66 },mess=0xFB00 },