summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--tex/context/base/cldf-scn.lua2
-rw-r--r--tex/context/base/cont-new.mkiv2
-rw-r--r--tex/context/base/context-version.pdfbin4321 -> 0 bytes
-rw-r--r--tex/context/base/context.mkiv2
-rw-r--r--tex/context/base/lpdf-xmp.lua3
-rw-r--r--tex/context/base/mult-ini.lua1
-rw-r--r--tex/context/base/publ-dat.lua10
-rw-r--r--tex/context/base/publ-imp-apa.mkvi102
-rw-r--r--tex/context/base/publ-imp-aps.lua36
-rw-r--r--tex/context/base/publ-imp-aps.mkvi195
-rw-r--r--tex/context/base/publ-ini.lua13
-rw-r--r--tex/context/base/publ-ini.mkiv18
-rw-r--r--tex/context/base/regi-ini.mkiv4
-rw-r--r--tex/context/base/status-files.pdfbin24664 -> 0 bytes
-rw-r--r--tex/context/base/status-lua.pdfbin399807 -> 0 bytes
-rw-r--r--tex/context/base/strc-lst.lua33
-rw-r--r--tex/context/base/strc-not.lua108
-rw-r--r--tex/context/base/strc-not.mkvi42
-rw-r--r--tex/context/base/strc-num.lua47
-rw-r--r--tex/context/base/strc-num.mkiv78
-rw-r--r--tex/context/base/strc-sec.mkiv65
-rw-r--r--tex/context/base/toks-ini.lua8
-rw-r--r--tex/context/base/typo-cap.lua6
-rw-r--r--tex/context/base/typo-cap.mkiv12
-rw-r--r--tex/context/base/typo-chr.lua15
-rw-r--r--tex/context/base/typo-chr.mkiv2
-rw-r--r--tex/context/base/typo-krn.lua7
-rw-r--r--tex/context/base/typo-krn.mkiv5
-rw-r--r--tex/context/base/x-asciimath.lua125
-rw-r--r--tex/context/base/x-asciimath.mkiv3
-rw-r--r--tex/generic/context/luatex/luatex-fonts-merged.lua2
31 files changed, 441 insertions, 505 deletions
diff --git a/tex/context/base/cldf-scn.lua b/tex/context/base/cldf-scn.lua
index a3d8b0d87..13339c362 100644
--- a/tex/context/base/cldf-scn.lua
+++ b/tex/context/base/cldf-scn.lua
@@ -86,7 +86,7 @@ function interfaces.implement(specification)
if scope == "private" then
return
end
- if commands[name] then
+ if commands[name] and not specification.overload then
report("warning: 'commands.%s' is redefined",name)
end
commands[name] = command
diff --git a/tex/context/base/cont-new.mkiv b/tex/context/base/cont-new.mkiv
index f266d155c..d5d8dae02 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.26 22:52}
+\newcontextversion{2015.03.27 21:39}
%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
deleted file mode 100644
index 19bc2b33e..000000000
--- a/tex/context/base/context-version.pdf
+++ /dev/null
Binary files differ
diff --git a/tex/context/base/context.mkiv b/tex/context/base/context.mkiv
index ceead82bf..5f7b96523 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.26 22:52}
+\edef\contextversion{2015.03.27 21:39}
\edef\contextkind {beta}
%D For those who want to use this:
diff --git a/tex/context/base/lpdf-xmp.lua b/tex/context/base/lpdf-xmp.lua
index 695f0224a..aa205d10a 100644
--- a/tex/context/base/lpdf-xmp.lua
+++ b/tex/context/base/lpdf-xmp.lua
@@ -158,7 +158,6 @@ local function flushxmpinfo()
local creator = "LuaTeX + ConTeXt MkIV"
local time = lpdf.timestamp()
local fullbanner = status.banner
- -- local fullbanner = gsub(tex.pdftexbanner,"kpse.*","")
pdfaddxmpinfo("DocumentID", documentid)
pdfaddxmpinfo("InstanceID", instanceid)
@@ -173,7 +172,7 @@ local function flushxmpinfo()
pdfaddtoinfo("Creator", creator)
pdfaddtoinfo("CreationDate", time)
pdfaddtoinfo("ModDate", time)
--- pdfaddtoinfo("PTEX.Fullbanner", fullbanner) -- no checking done on existence
+ -- pdfaddtoinfo("PTEX.Fullbanner", fullbanner) -- no checking done on existence
local blob = xml.tostring(xml.first(xmp or valid_xmp(),"/x:xmpmeta"))
local md = pdfdictionary {
diff --git a/tex/context/base/mult-ini.lua b/tex/context/base/mult-ini.lua
index 9baf6574e..c64ac8c05 100644
--- a/tex/context/base/mult-ini.lua
+++ b/tex/context/base/mult-ini.lua
@@ -309,6 +309,7 @@ implement {
implement {
name = "writestatus",
+ overload = true,
actions = interfaces.writestatus,
arguments = { "string", "string" },
}
diff --git a/tex/context/base/publ-dat.lua b/tex/context/base/publ-dat.lua
index 68e2c5a0c..a6226a4fc 100644
--- a/tex/context/base/publ-dat.lua
+++ b/tex/context/base/publ-dat.lua
@@ -1112,10 +1112,12 @@ do
name = "btxsavedataset",
actions = publications.save,
arguments = {
- { "dataset" },
- { "filename" },
- { "filetype" },
- { "criterium" },
+ {
+ { "dataset" },
+ { "filename" },
+ { "filetype" },
+ { "criterium" },
+ }
}
}
diff --git a/tex/context/base/publ-imp-apa.mkvi b/tex/context/base/publ-imp-apa.mkvi
index 84d263e5c..c812a76be 100644
--- a/tex/context/base/publ-imp-apa.mkvi
+++ b/tex/context/base/publ-imp-apa.mkvi
@@ -595,7 +595,7 @@
\fastsetup{btx:apa:cite:author:year}
\stopsetups
-\startsetups [btx:apa:page:list]
+\startsetups btx:apa:page:list
\fastsetup{\s!btx:\s!page:concat}
\ifx\currentbtxlastpage\empty
\btxlabeltext{apa:page}
@@ -633,21 +633,23 @@
% Or texdefinition?
-\startsetups [apa:list:sameauthor]
+\startsetups apa:list:sameauthor
\fastsetup{apa:list:sameauthor:rule}
\stopsetups
-\startsetups [apa:list:sameauthor:rule]
+\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!
+ \c!height=1.5\linewidth]% \linewidth is just too thin with respect to font strokes...
\stopsetups
-\startsetups [apa:list:sameauthor:\v!empty]% it's not a space
+\startsetups [apa:list:sameauthor:\v!empty]
\kern\dimexpr\listparameter\c!margin-\interwordspace\relax
\stopsetups
-\startsetups [apa:list:sameauthor:ditto] % horrible !
+% horrible !
+
+\startsetups apa:list:sameauthor:ditto
\inframed
[\c!width=\dimexpr\listparameter\c!margin-\interwordspace\relax,
\c!frame=\v!off,
@@ -675,6 +677,7 @@
%D returned. In lua syntax, it can be understood as
%D author or editor or publisher or title or ""
+% #title can be title or booktitle
\starttexdefinition btx:apa:translated-title #title
\ifx\currentbtxlanguage\empty
@@ -713,7 +716,7 @@
\starttexdefinition btx:apa:title
\setmode{btx:apa:title-placed}
- % we make the title active, opening file
+ % we make the title active, opening "file"
\btxdoifelse {file} {
\texdefinition{btx:format:inject}
{url(file:\btxflush{file})}
@@ -729,6 +732,7 @@
}
\btxdoif {title} {
\btxperiod
+ % TODO: this period may NOT be wanted, as in: Title (2nd ed.).
}
\stoptexdefinition
@@ -743,7 +747,7 @@
}
\stoptexdefinition
-\starttexdefinition nospaces btx:apa:suffixedyear
+\starttexdefinition btx:apa:suffixedyear
\btxdoifelse {year} {
\btxflush{year}
\btxflush{suffix}
@@ -752,6 +756,8 @@
}
\stoptexdefinition
+% #author may be author(set) or editor
+
\starttexdefinition btx:apa:author-or-editor #author
\btxdoif {#author} {
\btxflush{#author}
@@ -806,11 +812,22 @@
}
\stoptexdefinition
+% TODO: The title is terminated with period. However,
+% we probably don't want this before the parenthesis.
+
+\starttexdefinition btx:apa:leftparenthesis-or-comma
+ \doifmodeelse {btx:apa:editionset-is-empty} {
+ \btxleftparenthesis
+ \resetmode{btx:apa:editionset-is-empty}
+ } {
+ \btxcomma
+ }
+\stoptexdefinition
+
\starttexdefinition btx:apa:editionset
- \btxleftparenthesis
- \setmode{btx:apa:editionset-empty}
+ \setmode{btx:apa:editionset-is-empty}
\doif {\currentbtxcategory} {techreport} {
- \resetmode{btx:apa:editionset-empty}
+ \texdefinition{btx:apa:leftparenthesis-or-comma}
\btxdoifelse {type} {
\btxusecommand[apa:list:type] {
\btxflush{type}
@@ -818,10 +835,9 @@
} {
\btxlabeltext{apa:technicalreport}
}
- \btxcomma
}
\btxdoif {volume} {
- \resetmode{btx:apa:editionset-empty}
+ \texdefinition{btx:apa:leftparenthesis-or-comma}
\btxoneorrange {volume} {
\btxlabeltext{apa:Volume}
} {
@@ -829,24 +845,21 @@
}
\btxspace
\btxflush{volume}
- \btxcomma
}
\btxdoif {number} {
- \resetmode{btx:apa:editionset-empty}
+ \texdefinition{btx:apa:leftparenthesis-or-comma}
\btxlabeltext{apa:number}
\btxspace
\btxflush{number}
- \btxcomma
}
\btxdoif {edition} {
- \resetmode{btx:apa:editionset-empty}
+ \texdefinition{btx:apa:leftparenthesis-or-comma}
\btxflush{edition}
\btxspace
\btxlabeltext{apa:edition}
- \btxcomma
}
\btxdoif {pages} {
- \resetmode{btx:apa:editionset-empty}
+ \texdefinition{btx:apa:leftparenthesis-or-comma}
\btxoneorrange {pages} {
\btxlabeltext{apa:page}
} {
@@ -854,11 +867,8 @@
}
\btxnbsp
\btxflush{pages}
- \btxcomma
}
- \removeunwantedspaces
- \removepunctuation
- \doifnotmode {btx:apa:editionset-empty} {
+ \doifnotmode {btx:apa:editionset-is-empty} {
\btxrightparenthesisperiod
}
\stoptexdefinition
@@ -872,36 +882,26 @@
\btxusecommand[apa:list:journal] {
\btxflush{journal}
}
- \btxstopstyleandcolor
- \btxdoif {volume} {
+ \btxdoifelse {volume} {
\btxcomma
- \btxstartstyleandcolor[apa:list:journal]
- \btxflush{volume}
+ \btxflush{volume}
\btxstopstyleandcolor
- \btxdoifnot {number} {
- \btxdoifelse {pages}
- {\btxcomma}
- {\btxperiod}
+ \btxdoif {number} {
+ %\btxleftparenthesis
+ (\btxflush{number}
+ \btxrightparenthesis
}
- }
- \btxdoif {number} {
- \btxdoifelse {volume} {
- \removeunwantedspaces(
- } {
+ } {
+ \btxstopstyleandcolor
+ \btxdoif {number} {
\btxcomma
\btxleftparenthesis
+ \btxflush{number}
+ \btxrightparenthesis
}
- \btxflush{number}
- \btxdoifelse {pages}
- {\btxrightparenthesiscomma}
- {\btxrightparenthesisperiod}
}
\btxdoif {pages} {
- \btxdoifnot {volume} {
- \btxdoifnot {number} {
- \btxcomma
- }
- }
+ \btxcomma
\doif {\currentbtxcategory} {newspaper} {
\btxoneorrange {pages} {
\btxlabeltext{apa:page}
@@ -911,22 +911,16 @@
\btxnbsp
}
\btxflush{pages}
- \btxperiod
}
+ \btxperiod
\doifnot {\currentbtxcategory} {newspaper} {
\btxdoifnot {volume} {
\btxdoifnot {number} {
\btxdoifnot {pages} {
- \btxdoifelse {doi} {
- \btxperiod
+ \btxdoif {doi} {%set: doi or url
+ \btxspace
\btxlabeltext{apa:Advanced}
\btxperiod
- } {
- \btxdoif {url} {
- \btxperiod
- \btxlabeltext{apa:Advanced}
- \btxperiod
- }
}
}
}
diff --git a/tex/context/base/publ-imp-aps.lua b/tex/context/base/publ-imp-aps.lua
index c143e648b..5977fdb27 100644
--- a/tex/context/base/publ-imp-aps.lua
+++ b/tex/context/base/publ-imp-aps.lua
@@ -86,7 +86,7 @@ local categories = specification.categories
categories.article = {
sets = {
- author = { "author", "editor", "title" },
+ author = { "author", "editor" },
volume = { "volume", "number", "pages" },
doi = generic.doi,
isbn = { "issn" },
@@ -97,7 +97,7 @@ categories.article = {
optional = {
"collaboration",
"year",
- "subtitle", "type", "file",
+ "title", "subtitle", "type", "file",
"journal", "volume",
"doi", "note", "isbn"
},
@@ -114,7 +114,7 @@ categories.magazine = {
},
optional = {
"collaboration",
- "subtitle", "type", "file",
+ "title", "subtitle", "type", "file",
"number",
"month", "day",
"doi", "note", "isbn"
@@ -167,15 +167,18 @@ categories.standard = {
categories.book = {
sets = {
- author = { "author", "editor", "publisher", "title" },
+ author = { "author", "editor", "publisher" },
editionset = generic.editionset,
doi = generic.doi,
},
- required = { "author" },
+ required = {
+ "author",
+ "title",
+ },
optional = {
"collaboration",
"year", "month", "day",
- "subtitle", "type", "file",
+ "title", "subtitle", "type", "file",
"editionset", "series",
"address",
"doi", "note", "isbn"
@@ -186,13 +189,14 @@ categories.book = {
categories.inbook = {
sets = {
- author = { "author", "editor", "publisher", "title", },
+ author = { "author", "editor", "publisher", },
editionset = generic.editionset,
doi = generic.doi,
},
required = {
"author",
"year" ,
+ "title",
},
optional = {
"collaboration",
@@ -211,7 +215,7 @@ categories.inbook = {
categories.incollection = {
sets = {
- author = { "author", "editor", "publisher", "title", },
+ author = { "author", "editor", "publisher" },
editionset = generic.editionset,
doi = generic.doi,
},
@@ -222,7 +226,7 @@ categories.incollection = {
},
optional = {
"collaboration",
- "subtitle", "type", "file",
+ "title", "subtitle", "type", "file",
"editionset", "series",
"chapter",
"month",
@@ -235,12 +239,12 @@ categories.incollection = {
categories.booklet = {
sets = {
- author = { "author", "title", },
publisher = { "howpublished" }, -- no "publisher"!
doi = generic.doi,
},
required = {
- "author"
+ "author",
+ "title",
},
optional = {
"publisher",
@@ -256,7 +260,7 @@ categories.booklet = {
categories.proceedings = {
sets = {
- author = { "editor", "organization", "publisher", "title" }, -- no "author"!
+ author = { "editor", "organization", "publisher" }, -- no "author"!
publisher = { "publisher", "organization" },
editionset = generic.editionset,
doi = generic.doi,
@@ -268,7 +272,7 @@ categories.proceedings = {
optional = {
"collaboration",
"publisher",
- "subtitle", "file",
+ "title", "subtitle", "file",
"editionset", "series",
"month",
"address",
@@ -283,7 +287,7 @@ categories.inproceedings = {
required = categories.incollection.required,
optional = {
"collaboration",
- "subtitle", "type", "file",
+ "title", "subtitle", "type", "file",
"month",
"edition", "series",
"address", "organization",
@@ -338,7 +342,7 @@ categories.phdthesis = categories.mastersthesis
categories.techreport = {
sets = {
- author = { "author", "institution", "publisher", "title" },
+ author = { "author", "institution", "publisher" },
publisher = { "publisher", "institution", },
editionset = { "type", "volume", "number", "pages" }, -- no "edition"!
doi = generic.doi,
@@ -364,7 +368,7 @@ categories.techreport = {
categories.manual = {
sets = {
- author = { "author", "organization", "publisher", "title" },
+ author = { "author", "organization", "publisher" },
publisher = { "publisher", "organization", },
editionset = generic.editionset,
doi = generic.doi,
diff --git a/tex/context/base/publ-imp-aps.mkvi b/tex/context/base/publ-imp-aps.mkvi
index 996f78592..3179e8149 100644
--- a/tex/context/base/publ-imp-aps.mkvi
+++ b/tex/context/base/publ-imp-aps.mkvi
@@ -56,7 +56,6 @@
[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
@@ -422,13 +421,9 @@
aps:technicalreport={Tech. Rep.}, % Technical report
aps:supplement={Suppl.}, % Supplement (not used?)
aps:patent=Patent,
- aps:Author=Author,
- 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:In=In]
% Check this (google translate!!):
@@ -450,13 +445,9 @@
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
@@ -477,13 +468,9 @@
aps:technicalreport={Rapport technique},
aps:supplement=Supplément,
aps:patent=Brevet,
- aps:Author=Auteur,
- 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:In=Dans]
\setupbtxlabeltext
@@ -503,13 +490,9 @@
aps:technicalreport={Technischer Bericht},
aps:supplement={Beilage}, % Supplement
aps:patent=Patent,
- aps:Author=Autor,
- 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:In=In]
% thanks: Andrea Valle
@@ -531,13 +514,9 @@
aps:technicalreport={Relazione tecnica},
aps:supplement={Supplemento},
aps:patent=Brevetto,
- aps:Author=Autore,
- 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:In=In]
\setupbtxlabeltext
@@ -557,19 +536,15 @@
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} {
+ \doifelse {\currentbtxcategory} {article} {
\btxlabeltext{aps:tobe}
} {
\doifelse {\currentbtxcategory} {book} {
@@ -672,34 +647,28 @@
\stoptexdefinition
\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
+ \btxdoif {title} {
+ % 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
+ }
+ \btxcomma
}
\stoptexdefinition
-\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
- }
- %}
+\starttexdefinition btx:aps:optional-title
+ \doif{\btxparameter{placetitle}}\v!yes {
+ \texdefinition {btx:aps:title}
}
\stoptexdefinition
@@ -711,39 +680,32 @@
}
\stoptexdefinition
-%\starttexdefinition btx:aps:suffixedyear
-% \btxdoifelse {year} {
-% \btxflush{year}
-% \btxflush{suffix}
-% } {
-% \fastsetup{btx:aps:nd}
-% }
-%\stoptexdefinition
+% #author may be author(set) or editor
\starttexdefinition btx:aps:author-or-editor #author
\btxdoif {#author} {
\btxflush{#author}
- \doif {\btxfoundname{#author}} {editor} {
+ \doifelse {\btxfoundname{#author}} {editor} {
\btxleftparenthesis
\btxsingularorplural {editor} {
\btxlabeltext{aps:Editor}
} {
\btxlabeltext{aps:Editors}
}
- \btxrightparenthesisperiod
+ \btxrightparenthesis
+ } {
+ \btxdoif {collaboration} {
+ \btxleftparenthesis
+ \btxflush{collaboration}
+ \btxrightparenthesis
+ }
}
}
\stoptexdefinition
\starttexdefinition btx:aps:author
\btxflush{author}
- \btxdoifelse {collaboration} {
- \btxleftparenthesis
- \btxflush{collaboration}
- \btxrightparenthesiscomma
- } {
- \btxcomma
- }
+ \btxcomma
\stoptexdefinition
\starttexdefinition btx:aps:editor-in
@@ -764,7 +726,7 @@
\starttexdefinition btx:aps:editionset
\doif {\currentbtxcategory} {techreport} {
\btxdoifelse {type} {
- \btxusecommand[aps:list:type] {
+ \btxusecommand[\currentbtx:type] {
\btxflush{type}
}
} {
@@ -806,77 +768,6 @@
}
\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
@@ -902,7 +793,7 @@
\btxflush{pages}
}
\btxleftparenthesis
- \fastsetup{btx:aps:year}
+ \texdefinition{btx:aps:year}
\btxrightparenthesis
\btxperiod
}
@@ -928,7 +819,7 @@
\btxcomma
}
}
- \fastsetup{btx:aps:year}
+ \texdefinition{btx:aps:year}
\btxrightparenthesis
\stoptexdefinition
@@ -941,8 +832,6 @@
% use \btxentry here?
\starttexdefinition btx:aps:url
\btxspace
- \btxlabeltext{aps:Retrieved}
- \btxspace
\begingroup
\setbreakpoints[doi]
\ifconditional\btxinteractive
@@ -1014,7 +903,7 @@
\startsetups btx:aps:list:article
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:optional-title}
\texdefinition{btx:aps:journal-volumeset-year}
\texdefinition{btx:aps:url-note-doi}
\stopsetups
@@ -1050,7 +939,7 @@
\startsetups btx:aps:list:standard
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:title}
\texdefinition{btx:aps:url-doi-note}
\stopsetups
% year?
@@ -1064,7 +953,7 @@
\startsetups btx:aps:list:book
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:title}
\texdefinition{btx:aps:editionset}
\texdefinition{btx:aps:publisher-wherefrom-year}
\texdefinition{btx:aps:url-doi-note}
@@ -1081,7 +970,7 @@
\startsetups btx:aps:list:inbook
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:title}
\texdefinition{btx:aps:editor-in}
\texdefinition{btx:aps:editionset}
\texdefinition{btx:aps:publisher-wherefrom-year}
@@ -1113,7 +1002,7 @@
\startsetups btx:aps:list:inproceedings
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:title}
\texdefinition{btx:aps:editor-in}
\texdefinition{btx:aps:editionset}
\btxdoif {organization} {
@@ -1135,7 +1024,7 @@
\startsetups btx:aps:list:thesis
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:title}
\btxleftparenthesis
\btxdoifelse {type} {
\btxusecommand[aps:list:type] {
@@ -1214,7 +1103,7 @@
\startsetups btx:aps:list:patent
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:title}
\begingroup
\it
\btxdoif {nationality} {
@@ -1246,7 +1135,7 @@
\startsetups btx:aps:list:electronic
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:title}
\btxdoif {organization} {
\btxspace
\btxflush{organization}
@@ -1274,7 +1163,7 @@
\startsetups btx:aps:list:misc
\texdefinition{btx:aps:author}
- \texdefinition{btx:aps:title-if-not-placed}
+ \texdefinition{btx:aps:title}
\btxdoif {howpublished} {
\btxspace
\btxflush{howpublished}
diff --git a/tex/context/base/publ-ini.lua b/tex/context/base/publ-ini.lua
index 42d4c4251..ea6f22e0d 100644
--- a/tex/context/base/publ-ini.lua
+++ b/tex/context/base/publ-ini.lua
@@ -1,4 +1,4 @@
-if not modules then modules = { } end modules ['publ-ini'] = {
+7if not modules then modules = { } end modules ['publ-ini'] = {
version = 1.001,
comment = "this module part of publication support",
author = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
@@ -1980,11 +1980,11 @@ do
arguments = { "string", "string" }
}
- implement {
- name = "btxresolvelistreference",
- actions = lists.resolve,
- arguments = { "string", "string" }
- }
+ -- implement {
+ -- name = "btxresolvelistreference",
+ -- actions = lists.resolve,
+ -- arguments = { "string", "string" }
+ -- }
implement {
name = "btxcollectlistentries",
@@ -2303,6 +2303,7 @@ do
--
ctx_btxstartcite()
ctx_btxsettag(tag)
+ ctx_btxsetcategory(entry.category or "unknown")
--
if oneleft then
if i == 1 then
diff --git a/tex/context/base/publ-ini.mkiv b/tex/context/base/publ-ini.mkiv
index 6c96aaf2a..a7494058e 100644
--- a/tex/context/base/publ-ini.mkiv
+++ b/tex/context/base/publ-ini.mkiv
@@ -701,7 +701,7 @@
\else
\let\currentbtxrendering\currentbtxspecification
\fi\fi
- \setbtxparameterset\s!list\currentbtxspecification
+ \setbtxparameterset\currentbtxspecification\s!list
\the\everybtxlistrendering
\ifconditional#1\relax
\edef\currentbtxrenderingtitle{\btxrenderingparameter\c!title}%
@@ -1057,14 +1057,14 @@
% till here
-\unexpanded\def\btxnumberedreference[#1]% \bibtexnumref (replaced by \cite[num])
- {\dontleavehmode
- \begingroup
- \btxparameter\v!left
- \penalty\plustenthousand % todo
- \clf_btxresolvelistreference{\currentbtxdataset}{#1}% todo: split dataset from #1, so another call
- \btxparameter\v!right
- \endgroup}
+% \unexpanded\def\btxnumberedreference[#1]% \bibtexnumref (replaced by \cite[num])
+% {\dontleavehmode
+% \begingroup
+% \btxparameter\v!left
+% \penalty\plustenthousand % todo
+% \clf_btxresolvelistreference{\currentbtxdataset}{#1}% todo: split dataset from #1, so another call
+% \btxparameter\v!right
+% \endgroup}
%D When a publication is cited, we need to signal that somehow. This is done with the
%D following (not user) command. We could tag without injecting a node but this way
diff --git a/tex/context/base/regi-ini.mkiv b/tex/context/base/regi-ini.mkiv
index 71add44a1..6190393d8 100644
--- a/tex/context/base/regi-ini.mkiv
+++ b/tex/context/base/regi-ini.mkiv
@@ -25,9 +25,9 @@
\let\currentregime\empty
-\unexpanded\def\enableregime[#1]{\clf_enableregime}
+\unexpanded\def\enableregime[#1]{\clf_enableregime{#1}}
\unexpanded\def\disableregime {\clf_disableregime}
-\unexpanded\def\startregime [#1]{\clf_startregime}
+\unexpanded\def\startregime [#1]{\clf_startregime{#1}}
\unexpanded\def\stopregime {\clf_stopregime}
\protect \endinput
diff --git a/tex/context/base/status-files.pdf b/tex/context/base/status-files.pdf
deleted file mode 100644
index 493ddbafd..000000000
--- a/tex/context/base/status-files.pdf
+++ /dev/null
Binary files differ
diff --git a/tex/context/base/status-lua.pdf b/tex/context/base/status-lua.pdf
deleted file mode 100644
index baf911308..000000000
--- a/tex/context/base/status-lua.pdf
+++ /dev/null
Binary files differ
diff --git a/tex/context/base/strc-lst.lua b/tex/context/base/strc-lst.lua
index 06506cb7f..73ee44487 100644
--- a/tex/context/base/strc-lst.lua
+++ b/tex/context/base/strc-lst.lua
@@ -198,6 +198,12 @@ function lists.addto(t) -- maybe more more here (saves parsing at the tex end)
m.level = structures.sections.currentlevel()
end
local numberdata = t.numberdata
+ if numberdata then
+ local numbers = numberdata.numbers
+ if type(numbers) == "string" then
+ numberdata.numbers = structures.counters.compact(numbers,nil,true)
+ end
+ end
local group = numberdata and numberdata.group
local name = m.name
if not group then
@@ -232,13 +238,6 @@ function lists.addto(t) -- maybe more more here (saves parsing at the tex end)
if trace_lists then
report_lists("added %a, internal %a",name,p)
end
- local n = t.numberdata
- if n then
- local numbers = n.numbers
- if type(numbers) == "string" then
- n.numbers = structures.counters.compact(numbers,nil,true)
- end
- end
return p
end
@@ -1134,22 +1133,22 @@ implement { name = "doiflisthaspageelse", actions = { lists.haspagedata, com
implement { name = "doiflisthasnumberelse", actions = { lists.hasnumberdata, commands.doifelse }, arguments = { "string", "integer" } }
implement { name = "doiflisthasentry", actions = { lists.iscached, commands.doifelse }, arguments = { "integer" } }
-local function savedlistnumber(name,n)
+local function savedlisttitle(name,n,tag)
local data = cached[tonumber(n)]
if data then
- local numberdata = data.numberdata
- if numberdata then
- typesetnumber(numberdata,"number",numberdata or false)
+ local titledata = data.titledata
+ if titledata then
+ helpers.title(titledata[tag] or titledata.title or "",data.metadata)
end
end
end
-local function savedlisttitle(name,n,tag)
+local function savedlistnumber(name,n)
local data = cached[tonumber(n)]
if data then
- local titledata = data.titledata
- if titledata then
- helpers.title(titledata[tag] or titledata.title or "",data.metadata)
+ local numberdata = data.numberdata
+ if numberdata then
+ typesetnumber(numberdata,"number",numberdata or false)
end
end
end
@@ -1165,6 +1164,10 @@ local function savedlistprefixednumber(name,n)
end
end
+lists.savedlisttitle = savedlisttitle
+lists.savedlistnumber = savedlistnumber
+lists.savedlistprefixednumber = savedlistprefixednumber
+
implement {
name = "savedlistnumber",
actions = savedlistnumber,
diff --git a/tex/context/base/strc-not.lua b/tex/context/base/strc-not.lua
index 40b78d59f..71eccf1ce 100644
--- a/tex/context/base/strc-not.lua
+++ b/tex/context/base/strc-not.lua
@@ -38,6 +38,8 @@ local variables = interfaces.variables
local context = context
local commands = commands
+local implement = interfaces.implement
+
-- state: store, insert, postpone
local function store(tag,n)
@@ -69,9 +71,11 @@ end
notes.store = store
-function commands.storenote(tag,n)
- context(store(tag,n))
-end
+implement {
+ name = "storenote",
+ actions = { store, context },
+ arguments = { "string", "integer" }
+}
local function get(tag,n) -- tricky ... only works when defined
local nd = notedata[tag]
@@ -108,9 +112,11 @@ end
notes.listindex = listindex
-function commands.notelistindex(tag,n)
- context(listindex(tag,n))
-end
+implement {
+ name = "notelistindex",
+ actions = { listindex, context },
+ arguments = { "string", "integer" }
+}
local function setstate(tag,newkind)
local state = notestates[tag]
@@ -144,18 +150,28 @@ end
notes.setstate = setstate
notes.getstate = getstate
-commands.setnotestate = setstate
+implement {
+ name = "setnotestate",
+ actions = setstate,
+ arguments = { "string", "string" }
+}
-function commands.getnotestate(tag)
- context(getstate(tag))
-end
+implement {
+ name = "getnotestate",
+ actions = { getstate, context },
+ arguments = "string"
+}
function notes.define(tag,kind,number)
local state = setstate(tag,kind)
state.number = number
end
-commands.definenote = notes.define
+implement {
+ name = "definenote",
+ actions = notes.define,
+ arguments = { "string", "string", "integer" }
+}
function notes.save(tag,newkind)
local state = notestates[tag]
@@ -184,8 +200,8 @@ function notes.restore(tag,forcedstate)
end
end
-commands.savenote = notes.save
-commands.restorenote = notes.restore
+implement { name = "savenote", actions = notes.save, arguments = { "string", "string" } }
+implement { name = "restorenote", actions = notes.restore, arguments = { "string", "string" } }
local function hascontent(tag)
local ok = notestates[tag]
@@ -205,9 +221,11 @@ end
notes.hascontent = hascontent
-function commands.doifnotecontent(tag)
- commands.doif(hascontent(tag))
-end
+implement {
+ name = "doifnotecontent",
+ actions = { hascontent, commands.doif },
+ arguments = "string",
+}
local function internal(tag,n)
local nd = get(tag,n)
@@ -243,9 +261,11 @@ end
notes.doifonsamepageasprevious = onsamepageasprevious
-function commands.doifnoteonsamepageasprevious(tag)
- commands.doifelse(onsamepageasprevious(tag))
-end
+implement {
+ name = "doifnoteonsamepageasprevious",
+ actions = { onsamepageasprevious, commands.doifelse },
+ arguments = "string",
+}
function notes.checkpagechange(tag) -- called before increment !
local nd = notedata[tag] -- can be unset at first entry
@@ -277,7 +297,10 @@ function notes.postpone()
end
end
-commands.postponenotes = notes.postpone
+implement {
+ name = "postponenotes",
+ actions = notes.postpone
+}
function notes.setsymbolpage(tag,n,l)
local l = l or listindex(tag,n)
@@ -297,7 +320,11 @@ function notes.setsymbolpage(tag,n,l)
end
end
-commands.setnotesymbolpage = notes.setsymbolpage
+implement {
+ name = "setnotesymbolpage",
+ actions = notes.setsymbolpage,
+ arguments = { "string", "integer" }
+}
local function getsymbolpage(tag,n)
local li = internal(tag,n)
@@ -351,11 +378,11 @@ notes.getsymbolpage = getsymbolpage
notes.getnumberpage = getnumberpage
notes.getdeltapage = getdeltapage
-function commands.notesymbolpage(tag,n) context(getsymbolpage(tag,n)) end
-function commands.notenumberpage(tag,n) context(getnumberpage(tag,n)) end
-function commands.notedeltapage (tag,n) context(getdeltapage (tag,n)) end
+implement { name = "notesymbolpage", actions = { getsymbolpage, context }, arguments = { "string", "integer" } }
+implement { name = "notenumberpage", actions = { getnumberpage, context }, arguments = { "string", "integer" } }
+implement { name = "notedeltapage", actions = { getdeltapage, context }, arguments = { "string", "integer" } }
-function commands.flushnotes(tag,whatkind,how) -- store and postpone
+local function flushnotes(tag,whatkind,how) -- store and postpone
local state = notestates[tag]
local kind = state.kind
if kind == whatkind then
@@ -411,15 +438,26 @@ function commands.flushnotes(tag,whatkind,how) -- store and postpone
end
end
-function commands.flushpostponednotes()
+local function flushpostponednotes()
if trace_notes then
report_notes("flushing all postponed notes")
end
for tag, _ in next, notestates do
- commands.flushnotes(tag,"postpone")
+ flushnotes(tag,"postpone")
end
end
+implement {
+ name = "flushpostponednotes",
+ actions = flushpostponednotes
+}
+
+implement {
+ name = "flushnotes",
+ actions = flushnotes,
+ arguments = { "string", "string", "string" }
+}
+
function notes.resetpostponed()
if trace_notes then
report_notes("resetting all postponed notes")
@@ -432,13 +470,17 @@ function notes.resetpostponed()
end
end
-function commands.notetitle(tag,n)
- command.savedlisttitle(tag,notedata[tag][n])
-end
+implement {
+ name = "notetitle",
+ actions = function(tag,n) lists.savedlisttitle(tag,notedata[tag][n]) end,
+ arguments = { "string", "integer" }
+}
-function commands.noteprefixednumber(tag,n,spec)
- commands.savedlistprefixednumber(tag,notedata[tag][n])
-end
+implement {
+ name = "noteprefixednumber",
+ actions = function(tag,n) lists.savedlistprefixednumber(tag,notedata[tag][n]) end,
+ arguments = { "string", "integer" }
+}
function notes.internalid(tag,n)
local nd = get(tag,n)
diff --git a/tex/context/base/strc-not.mkvi b/tex/context/base/strc-not.mkvi
index 982dc2fbe..bfa029e2b 100644
--- a/tex/context/base/strc-not.mkvi
+++ b/tex/context/base/strc-not.mkvi
@@ -393,7 +393,7 @@
\setexpandednoteparameter\s!insert{\namednoteparameter\currentnoteparent\s!insert}%
\definenotation[\currentnote][\currentnoteparent][\c!type=\v!note]%
\fi
- \ctxcommand{definenote("\currentnote","insert",\number\currentnoteinsertionnumber)}%
+ \clf_definenote{\currentnote}{insert}\currentnoteinsertionnumber\relax
\to \everydefinenote
% maybe we will share this at some point:
@@ -438,7 +438,7 @@
\strc_notes_inject_dummy
\else
\begingroup
- \edef\currentnotenumber{\ctxcommand{storenote("\currentnote",\currentconstructionlistentry)}}%
+ \edef\currentnotenumber{\clf_storenote{\currentnote}\currentconstructionlistentry}%
\settrue\processingnote
\ifconditional\c_strc_notes_skip
\globallet\lastnotesymbol\strc_notes_inject_symbol_nop
@@ -520,7 +520,7 @@
\endcsname}
\setvalue{\??noteinteractioninline\v!yes}%
- {\strc_references_get_simple_page_reference{page(\ctxcommand{notenumberpage("\currentnote",\currentnotenumber)})}%
+ {\strc_references_get_simple_page_reference{page(\clf_notenumberpage{\currentnote}\currentnotenumber)}%
\edef\strc_notes_get_reference_attribute_symbol{attr\referenceattribute\currentreferenceattribute}%
\let \strc_notes_set_style_color_inline \strc_notes_set_style_color_inline_yes}
@@ -540,7 +540,7 @@
% page(...) : we could have a dedicated one
\setvalue{\??noteinteractiondisplay\v!yes}%
- {\strc_references_get_simple_page_reference{page(\ctxcommand{notesymbolpage("\currentnote",\currentnotenumber)})}%
+ {\strc_references_get_simple_page_reference{page(\clf_notesymbolpage{\currentnote}\currentnotenumber)}%
\edef\strc_notes_set_reference_attribute_number{\attribute\referenceattribute\currentreferenceattribute}%
\let \strc_notes_set_reference_attribute_text \donothing
\let \strc_notes_set_destination_attribute_text\donothing
@@ -553,7 +553,7 @@
\let\strc_notes_set_style_color_display \strc_notes_set_style_color_display_nop}
\setvalue{\??noteinteractiondisplay\v!all}%
- {\strc_references_get_simple_page_reference{page(\ctxcommand{notesymbolpage("\currentnote",\currentnotenumber)})}%
+ {\strc_references_get_simple_page_reference{page(\clf_notesymbolpage{\currentnote}\currentnotenumber)}%
\edef\strc_notes_set_reference_attribute_text {\attribute\referenceattribute\currentreferenceattribute}%
%\strc_references_set_simple_page_reference{note:\cldcontext{structures.notes.internalid("\currentnote",\currentnotenumber)}}%
\strc_references_set_simple_page_reference{note:\currentnote:\currentnotenumber}%
@@ -562,7 +562,7 @@
\let \strc_notes_set_style_color_display \strc_notes_set_style_color_display_yes}
\setvalue{\??noteinteractiondisplay\v!text}%
- {\strc_references_get_simple_page_reference{page(\ctxcommand{notesymbolpage("\currentnote",\currentnotenumber)})}%
+ {\strc_references_get_simple_page_reference{page(\clf_notesymbolpage{\currentnote}\currentnotenumber)}%
\edef\strc_notes_set_reference_attribute_text {\attribute\referenceattribute\currentreferenceattribute}%
%\strc_references_set_simple_page_reference{note:\cldcontext{structures.notes.internalid("\currentnote",\currentnotenumber)}}%
\strc_references_set_simple_page_reference{note:\currentnote:\currentnotenumber}%
@@ -587,7 +587,7 @@
{\iftrialtypesetting
% keep
\else\ifx\currentcolorparameter\empty
- \scratchcounter\ctxcommand{notedeltapage("\currentnote",\currentnotenumber)}\relax % todo calculate once
+ \scratchcounter\clf_notedeltapage{\currentnote}\currentnotenumber\relax % todo calculate once
\setlocationcolorspecified\scratchcounter
\fi\fi}
@@ -606,7 +606,7 @@
% in mkii the pointer only showed up in pagewise notes
\unexpanded\def\strc_notes_inject_pointer % todo calculate once
- {\ifcase\ctxcommand{notedeltapage("\currentnote",\currentnotenumber)}\relax
+ {\ifcase\clf_notedeltapage{\currentnote}\currentnotenumber\relax\relax
% unknown
\or
% same page
@@ -655,7 +655,7 @@
\hbox \strc_notes_get_reference_attribute_symbol \bgroup
\dostarttagged\t!descriptionsymbol\currentnote
\dotagsetnotesymbol
- \noteparameter\c!textcommand{\ctxcommand{noteprefixednumber("\currentnote",\currentnotenumber)}}%
+ \noteparameter\c!textcommand{\clf_noteprefixednumber{\currentnote}\currentnotenumber\relax}%
% the next one can cycle so we need to make sure it has no advance width
\doif{\noteparameter\c!indicator}\v!yes\strc_notes_inject_pointer
\dostoptagged
@@ -1030,7 +1030,7 @@
\def\strc_notes_set_location_text % we don't use inserts anyway (e.g. endnotes)
{\settrue\c_strc_notes_delayed
- \ctxcommand{setnotestate("\currentnote","store")}%
+ \clf_setnotestate{\currentnote}{store}%
\page_inserts_set_location\currentnoteinsertion\v!text % \setupinsertion[\currentnote][\c!location=\v!text]%
\global\count\currentnoteinsertionnumber\zerocount
\global\dimen\currentnoteinsertionnumber\maxdimen
@@ -1205,7 +1205,7 @@
\edef\currentnote{#tag}%
\strc_constructions_initialize{#tag}%
\strc_notes_synchronize
- \edef\currentconstructionlistentry{\ctxcommand{notelistindex("\currentnote",#id)}}% index in list cache
+ \edef\currentconstructionlistentry{\clf_notelistindex{\currentnote}#id}% index in list cache
% as we can have collected notes (e.g. in tables) we need to recover
% \currentdescriptionattribute and \currentdescriptionsynchronize
%
@@ -1226,7 +1226,7 @@
}
\unexpanded\def\strc_notes_inject_text % hm main?
- {\ctxcommand{savedlisttitle("\currentconstructionmain",\currentconstructionlistentry)}}
+ {\clf_savedlisttitle{\currentconstructionmain}\currentconstructionlistentry\relax}
\let\startpushnote\relax
\let\stoppushnote \relax
@@ -1400,7 +1400,7 @@
{\ifconditional\postponingnotes\else
\global\settrue\postponingnotes
\global\let\flushnotes\doflushnotes
- \ctxcommand{postponenotes()}%
+ \clf_postponenotes
\fi}
\let\flushnotes\relax
@@ -1410,7 +1410,7 @@
\begingroup
\let\flushnotes \relax
\let\postponenotes\relax
- \ctxcommand{flushpostponednotes()}% this also resets the states !
+ \clf_flushpostponednotes% this also resets the states !
\global\setfalse\postponednote
\global\setfalse\postponingnotes
\global\let\flushnotes\relax
@@ -1457,20 +1457,20 @@
\strc_counters_save{#tag}%
\strc_counters_reset{#tag}%
\fi
- \ctxcommand{savenote("#tag","store")}}
+ \clf_savenote{#tag}{store}}
\def\strc_notes_local_stop_step#tag%
{\p_strc_notes_continue{\noteparameter\c!continue}%
\ifx\p_strc_notes_continue\v!yes \else
\strc_counters_restore{#tag}%
\fi
- \ctxcommand{restorenote("#tag")}}
+ \clf_restorenote{#tag}}
\unexpanded\def\placelocalnotes
{\dodoubleempty\strc_notes_local_place}
\def\strc_notes_local_place[#tag][#settings]%
- {\doif{\ctxcommand{getnotestate("#tag")}}{store}{\strc_notes_local_place_indeed{#settings}{#tag}}}
+ {\doif{\clf_getnotestate{#tag}}{store}{\strc_notes_local_place_indeed{#settings}{#tag}}}
\def\strc_notes_local_place_indeed#settings#tag%
{\begingroup
@@ -1530,7 +1530,7 @@
\def\strc_notes_place_indeed#settings#tag% settings note
{\edef\currentnote{#tag}% grouping ?
- \doifelse{\ctxcommand{getnotestate("#tag")}}{store}
+ \doifelse{\clf_getnotestate{#tag}}{store}
\strc_notes_local_place_indeed
\strc_notes_global_place_indeed
{#settings}{#tag}}
@@ -1550,7 +1550,7 @@
{\setvalue{\??notealternative#alternative}{#command}}
\unexpanded\def\doifnotescollected#tag%
- {\ctxcommand{doifnotecontent("#tag")}}
+ {\clf_doifnotecontent{#tag}}
\def\strc_notes_place_local_alternative % will be a setup (wrapper)
{\doifnotescollected\currentnote
@@ -1577,7 +1577,7 @@
% setups ?
-\def\flushlocalnotes#tag{\ctxcommand{flushnotes("#tag","store","\noteparameter\c!criterium")}}
+\def\flushlocalnotes#tag{\clf_flushnotes{#tag}{store}{\noteparameter\c!criterium}}
\installnotealternative \v!none
{\flushlocalnotes\currentnote}
@@ -1769,7 +1769,7 @@
%D }
%D \stoptyping
-\def\doifnoteonsamepageelse[#tag]{\ctxcommand{doifnoteonsamepageasprevious("#tag")}}
+\def\doifnoteonsamepageelse[#tag]{\clf_doifnoteonsamepageasprevious{#tag}}
%D New trickery:
diff --git a/tex/context/base/strc-num.lua b/tex/context/base/strc-num.lua
index 15c543b08..0203334ff 100644
--- a/tex/context/base/strc-num.lua
+++ b/tex/context/base/strc-num.lua
@@ -396,10 +396,8 @@ local function check(name,data,start,stop)
end
end
-counters.reset = reset
-counters.set = set
-function counters.setown(name,n,value)
+local function setown(name,n,value)
local cd = counterdata[name]
if cd then
local d = allocate(name,n)
@@ -417,7 +415,7 @@ function counters.setown(name,n,value)
end
end
-function counters.restart(name,n,newstart,noreset)
+local function restart(name,n,newstart,noreset)
local cd = counterdata[name]
if cd then
newstart = tonumber(newstart)
@@ -445,7 +443,7 @@ function counters.restore(name)
end
end
-function counters.add(name,n,delta)
+local function add(name,n,delta)
local cd = counterdata[name]
if cd and (cd.state == v_start or cd.state == "") then
local data = cd.data
@@ -514,7 +512,12 @@ local function get(name,n,key)
end
end
-counters.get = get
+counters.reset = reset
+counters.set = set
+counters.add = add
+counters.get = get
+counters.setown = setown
+counters.restart = restart
function counters.value(name,n) -- what to do with own
return get(name,n or 1,'number') or 0
@@ -600,20 +603,20 @@ end
--
-implement { name = "addcounter", actions = counters.add, arguments = { "string", "integer", "integer" } }
-implement { name = "setcounter", actions = counters.set, arguments = { "string", 1, "integer" } }
-implement { name = "setowncounter", actions = counters.setown, arguments = { "string", 1, "string" } }
-implement { name = "restartcounter", actions = counters.restart, arguments = { "string", 1, "integer" } }
-implement { name = "resetcounter", actions = counters.reset, arguments = { "string", 1 } }
-implement { name = "incrementcounter", actions = counters.add, arguments = { "string", 1, 1 } }
-implement { name = "decrementcounter", actions = counters.add, arguments = { "string", 1, -1 } }
-
-implement { name = "setsubcounter", actions = counters.set, arguments = { "string", "integer", "integer" } }
-implement { name = "setownsubcounter", actions = counters.setown, arguments = { "string", "integer", "string" } }
-implement { name = "restartsubcounter", actions = counters.restart, arguments = { "string", "integer", "integer" } }
-implement { name = "resetsubcounter", actions = counters.reset, arguments = { "string", "integer" } }
-implement { name = "incrementsubcounter", actions = counters.add, arguments = { "string", "integer", 1 } }
-implement { name = "decrementsubcounter", actions = counters.add, arguments = { "string", "integer", -1 } }
+implement { name = "addcounter", actions = add, arguments = { "string", "integer", "integer" } }
+implement { name = "setcounter", actions = set, arguments = { "string", 1, "integer" } }
+implement { name = "setowncounter", actions = setown, arguments = { "string", 1, "string" } }
+implement { name = "restartcounter", actions = restart, arguments = { "string", 1, "integer" } }
+implement { name = "resetcounter", actions = reset, arguments = { "string", 1 } }
+implement { name = "incrementcounter", actions = add, arguments = { "string", 1, 1 } }
+implement { name = "decrementcounter", actions = add, arguments = { "string", 1, -1 } }
+
+implement { name = "setsubcounter", actions = set, arguments = { "string", "integer", "integer" } }
+implement { name = "setownsubcounter", actions = setown, arguments = { "string", "integer", "string" } }
+implement { name = "restartsubcounter", actions = restart, arguments = { "string", "integer", "integer" } }
+implement { name = "resetsubcounter", actions = reset, arguments = { "string", "integer" } }
+implement { name = "incrementsubcounter", actions = add, arguments = { "string", "integer", 1 } }
+implement { name = "decrementsubcounter", actions = add, arguments = { "string", "integer", -1 } }
implement { name = "rawcountervalue", actions = { counters.raw , context }, arguments = { "string", 1 } }
implement { name = "countervalue", actions = { counters.value , context }, arguments = { "string", 1 } }
@@ -634,8 +637,8 @@ implement { name = "subsubcountervalues", actions = { counters.subs , con
implement { name = "savecounter", actions = counters.save, arguments = "string" }
implement { name = "restorecounter", actions = counters.restore, arguments = "string" }
-implement { name = "incrementedcounter", actions = { counters.add, context }, arguments = { "string", 1, 1 } }
-implement { name = "decrementedcounter", actions = { counters.add, context }, arguments = { "string", 1, -1 } }
+implement { name = "incrementedcounter", actions = { add, context }, arguments = { "string", 1, 1 } }
+implement { name = "decrementedcounter", actions = { add, context }, arguments = { "string", 1, -1 } }
implement { name = "showcounter", actions = showcounter, arguments = "string" } -- todo
implement { name = "checkcountersetup", actions = checkcountersetup, arguments = { "string", "integer", "integer", "string" } }
diff --git a/tex/context/base/strc-num.mkiv b/tex/context/base/strc-num.mkiv
index bd736f249..8cee9c3b0 100644
--- a/tex/context/base/strc-num.mkiv
+++ b/tex/context/base/strc-num.mkiv
@@ -54,7 +54,7 @@
\edef\p_start{\counterparameter\c!start}%
\clf_definecounter
name {\currentcounter}%
- start \ifx\p_start\empty\zerocount\else\p_start\fi
+ start \ifx\p_start\empty\zerocount\else\numexpr\p_start\relax\fi
counter {\counterparameter\s!counter}%
method {\counterparameter\c!method}%
\relax
@@ -70,7 +70,7 @@
\ifx\currentcounter\empty \else
\edef\p_number{\counterparameter\c!number}%
\ifx\p_number\empty \else
- \clf_setcounter{\counterparameter\s!name}\p_number\relax
+ \clf_setcounter{\counterparameter\s!name}\numexpr\p_number\relax
\letcounterparameter\c!number\empty
\fi
\edef\p_start{\counterparameter\c!start}%
@@ -241,26 +241,26 @@
\expandafter\gobbleoneoptional
\fi}
-\def\strc_counters_set_two [#1][#2][#3]{\clf_setsubcounter {\namedcounterparameter{#1}\s!name}#2 #3\relax}
-\def\strc_counters_setown_two [#1][#2][#3]{\clf_setownsubcounter {\namedcounterparameter{#1}\s!name}#2{#3}}
-\def\strc_counters_restart_two [#1][#2][#3]{\clf_restartsubcounter {\namedcounterparameter{#1}\s!name}#2 #3\relax}
-\def\strc_counters_reset_two [#1][#2]{\clf_resetsubcounter {\namedcounterparameter{#1}\s!name}#2\relax}
-\def\strc_counters_increment_two [#1][#2]{\clf_incrementsubcounter {\namedcounterparameter{#1}\s!name}#2\relax}
-\def\strc_counters_decrement_two [#1][#2]{\clf_decrementsubcounter {\namedcounterparameter{#1}\s!name}#2\relax}
-
-\def\strc_counters_raw_two [#1][#2]{\clf_subcountervalue {\namedcounterparameter{#1}\s!name}#2 }
-\def\strc_counters_last_two [#1][#2]{\clf_lastsubcountervalue {\namedcounterparameter{#1}\s!name}#2 }
-\def\strc_counters_first_two [#1][#2]{\clf_firstsubcountervalue {\namedcounterparameter{#1}\s!name}#2 }
-\def\strc_counters_next_two [#1][#2]{\clf_nextsubcountervalue {\namedcounterparameter{#1}\s!name}#2 }
-\def\strc_counters_prev_two [#1][#2]{\clf_previoussubcountervalue{\namedcounterparameter{#1}\s!name}#2 }
-\def\strc_counters_subs_two [#1][#2]{\clf_subsubcountervalues {\namedcounterparameter{#1}\s!name}#2 }
-
-\def\strc_counters_set_one [#1][#2][#3]{\clf_setcounter {\namedcounterparameter{#1}\s!name}#2\relax}
+\def\strc_counters_set_two [#1][#2][#3]{\clf_setsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax\numexpr#3\relax}
+\def\strc_counters_setown_two [#1][#2][#3]{\clf_setownsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax{#3}}
+\def\strc_counters_restart_two [#1][#2][#3]{\clf_restartsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax\numexpr#3\relax}
+\def\strc_counters_reset_two [#1][#2]{\clf_resetsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\def\strc_counters_increment_two [#1][#2]{\clf_incrementsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\def\strc_counters_decrement_two [#1][#2]{\clf_decrementsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+
+\def\strc_counters_raw_two [#1][#2]{\clf_subcountervalue {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\def\strc_counters_last_two [#1][#2]{\clf_lastsubcountervalue {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\def\strc_counters_first_two [#1][#2]{\clf_firstsubcountervalue {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\def\strc_counters_next_two [#1][#2]{\clf_nextsubcountervalue {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\def\strc_counters_prev_two [#1][#2]{\clf_previoussubcountervalue{\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\def\strc_counters_subs_two [#1][#2]{\clf_subsubcountervalues {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+
+\def\strc_counters_set_one [#1][#2][#3]{\clf_setcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
\def\strc_counters_setown_one [#1][#2][#3]{\clf_setowncounter {\namedcounterparameter{#1}\s!name}{#2}}
-\def\strc_counters_restart_one [#1][#2][#3]{\clf_restartcounter {\namedcounterparameter{#1}\s!name}#2\relax}
-\def\strc_counters_reset_one [#1][#2]{\clf_resetcounter {\namedcounterparameter{#1}\s!name}\relax}
-\def\strc_counters_increment_one [#1][#2]{\clf_incrementcounter {\namedcounterparameter{#1}\s!name}\relax}
-\def\strc_counters_decrement_one [#1][#2]{\clf_decrementcounter {\namedcounterparameter{#1}\s!name}\relax}
+\def\strc_counters_restart_one [#1][#2][#3]{\clf_restartcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\def\strc_counters_reset_one [#1][#2]{\clf_resetcounter {\namedcounterparameter{#1}\s!name}}
+\def\strc_counters_increment_one [#1][#2]{\clf_incrementcounter {\namedcounterparameter{#1}\s!name}}
+\def\strc_counters_decrement_one [#1][#2]{\clf_decrementcounter {\namedcounterparameter{#1}\s!name}}
\def\strc_counters_raw_one [#1][#2]{\clf_countervalue {\namedcounterparameter{#1}\s!name}}
\def\strc_counters_last_one [#1][#2]{\clf_lastcountervalue {\namedcounterparameter{#1}\s!name}}
@@ -272,12 +272,12 @@
\def\strc_counters_save_one [#1]{\clf_savecounter {\namedcounterparameter{#1}\s!name}}
\def\strc_counters_restore_one [#1]{\clf_restorecounter {\namedcounterparameter{#1}\s!name}}
-\unexpanded\def\strc_counters_set #1#2{\clf_setcounter {\namedcounterparameter{#1}\s!name}#2\relax}
+\unexpanded\def\strc_counters_set #1#2{\clf_setcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
\unexpanded\def\strc_counters_setown #1#2{\clf_setowncounter {\namedcounterparameter{#1}\s!name}{#2}}
-\unexpanded\def\strc_counters_restart #1#2{\clf_restartcounter {\namedcounterparameter{#1}\s!name}#2\relax}
-\unexpanded\def\strc_counters_reset #1{\clf_resetcounter {\namedcounterparameter{#1}\s!name}\relax}
-\unexpanded\def\strc_counters_increment #1{\clf_incrementcounter {\namedcounterparameter{#1}\s!name}\relax}
-\unexpanded\def\strc_counters_decrement #1{\clf_decrementcounter {\namedcounterparameter{#1}\s!name}\relax}
+\unexpanded\def\strc_counters_restart #1#2{\clf_restartcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\unexpanded\def\strc_counters_reset #1{\clf_resetcounter {\namedcounterparameter{#1}\s!name}}
+\unexpanded\def\strc_counters_increment #1{\clf_incrementcounter {\namedcounterparameter{#1}\s!name}}
+\unexpanded\def\strc_counters_decrement #1{\clf_decrementcounter {\namedcounterparameter{#1}\s!name}}
\def\strc_counters_raw #1{\clf_countervalue {\namedcounterparameter{#1}\s!name}}
\def\strc_counters_last #1{\clf_lastcountervalue {\namedcounterparameter{#1}\s!name}}
@@ -286,19 +286,19 @@
\def\strc_counters_prev #1{\clf_previouscountervalue {\namedcounterparameter{#1}\s!name}}
\def\strc_counters_subs #1{\clf_subcountervalues {\namedcounterparameter{#1}\s!name}}
-\unexpanded\def\strc_counters_set_sub #1#2#3{\clf_setsubcounter {\namedcounterparameter{#1}\s!name}#2 #3\relax}
-\unexpanded\def\strc_counters_setown_sub #1#2#3{\clf_setownsubcounter {\namedcounterparameter{#1}\s!name}#2{#3}}
-\unexpanded\def\strc_counters_restart_sub #1#2#3{\clf_restartsubcounter {\namedcounterparameter{#1}\s!name}#2 #3\relax}
-\unexpanded\def\strc_counters_reset_sub #1#2{\clf_resetsubcounter {\namedcounterparameter{#1}\s!name}#2\relax}
-\unexpanded\def\strc_counters_increment_sub #1#2{\clf_incrementsubcounter {\namedcounterparameter{#1}\s!name}#2\relax}
-\unexpanded\def\strc_counters_decrement_sub #1#2{\clf_decrementsubcounter {\namedcounterparameter{#1}\s!name}#2\relax}
+\unexpanded\def\strc_counters_set_sub #1#2#3{\clf_setsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax\numexpr#3\relax}
+\unexpanded\def\strc_counters_setown_sub #1#2#3{\clf_setownsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax{#3}}
+\unexpanded\def\strc_counters_restart_sub #1#2#3{\clf_restartsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax\numexpr#3\relax}
+\unexpanded\def\strc_counters_reset_sub #1#2{\clf_resetsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\unexpanded\def\strc_counters_increment_sub #1#2{\clf_incrementsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+\unexpanded\def\strc_counters_decrement_sub #1#2{\clf_decrementsubcounter {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
- \def\strc_counters_raw_sub #1#2{\clf_subcountervalue {\namedcounterparameter{#1}\s!name}#2 } % maybe raw
- \def\strc_counters_last_sub #1#2{\clf_lastsubcountervalue {\namedcounterparameter{#1}\s!name}#2 }
- \def\strc_counters_first_sub #1#2{\clf_firstsubcountervalue {\namedcounterparameter{#1}\s!name}#2 }
- \def\strc_counters_next_sub #1#2{\clf_nextsubcountervalue {\namedcounterparameter{#1}\s!name}#2 }
- \def\strc_counters_prev_sub #1#2{\clf_previoussubcountervalue{\namedcounterparameter{#1}\s!name}#2 }
- \def\strc_counters_subs_sub #1#2{\clf_subsubcountervalues {\namedcounterparameter{#1}\s!name}#2 }
+ \def\strc_counters_raw_sub #1#2{\clf_subcountervalue {\namedcounterparameter{#1}\s!name}\numexpr#2\relax} % maybe raw
+ \def\strc_counters_last_sub #1#2{\clf_lastsubcountervalue {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+ \def\strc_counters_first_sub #1#2{\clf_firstsubcountervalue {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+ \def\strc_counters_next_sub #1#2{\clf_nextsubcountervalue {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+ \def\strc_counters_prev_sub #1#2{\clf_previoussubcountervalue{\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
+ \def\strc_counters_subs_sub #1#2{\clf_subsubcountervalues {\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
\unexpanded\def\strc_counters_save #1{\clf_savecounter {\namedcounterparameter{#1}\s!name}}
\unexpanded\def\strc_counters_restore #1{\clf_restorecounter {\namedcounterparameter{#1}\s!name}}
@@ -338,7 +338,7 @@
\strc_counters_reset{#1}%
\fi
\fi
- \clf_incrementsubcounter{\namedcounterparameter{#1}\s!name}#2\relax}
+ \clf_incrementsubcounter{\namedcounterparameter{#1}\s!name}\numexpr#2\relax}
\unexpanded\def\convertedcounter
{\dodoubleempty\strc_counters_converted}
diff --git a/tex/context/base/strc-sec.mkiv b/tex/context/base/strc-sec.mkiv
index a4084187f..759941c85 100644
--- a/tex/context/base/strc-sec.mkiv
+++ b/tex/context/base/strc-sec.mkiv
@@ -175,71 +175,6 @@
\setnextinternalreference
\storeinternalreference\currentstructurename\nextinternalreference %
\strc_sectioning_set_reference_prefix
-% \ctxcommand{% todo: combine with next call, adapt marks accordingly
-% setsectionentry{
-% references = {
-% internal = \nextinternalreference,
-% block = "\currentsectionblock",
-% reference = "\currentstructurereference",
-% referenceprefix = "\currentstructurereferenceprefix",
-% backreference = "\currentstructurebackreference",
-% },
-% directives = {
-% resetset = "\structureparameter\c!sectionresetset",
-% },
-% metadata = {
-% kind = "section",
-% name = "\currentstructurename",
-% catcodes = \the\ifx\currentstructurecatcodes\empty\catcodetable\else\csname\currentstructurecatcodes\endcsname\fi,
-% coding = "\currentstructurecoding",
-% \ifx\currentstructurecoding\s!xml
-% xmlroot = "\xmldocument",
-% \fi
-% \ifx\currentstructurexmlsetup\empty \else
-% xmlsetup = "\currentstructurexmlsetup",
-% \fi
-% \ifx\currentstructuresaveinlist\v!no
-% nolist = true,
-% \fi
-% \ifx\currentstructureincrementnumber\v!yes
-% increment = "\currentstructureincrementnumber",
-% \fi
-% },
-% titledata = { % we can add mark and reference
-% label = \!!bs\detokenize\expandafter{\currentstructurelabel }\!!es,
-% title = \!!bs\detokenize\expandafter{\currentstructuretitle }\!!es,
-% \ifx\currentstructurebookmark\currentstructuretitle \else
-% bookmark = \!!bs\detokenize\expandafter{\currentstructurebookmark }\!!es,
-% \fi
-% \ifx\currentstructuremarking\currentstructuretitle \else
-% marking = \!!bs\detokenize\expandafter{\currentstructuremarking }\!!es,
-% \fi
-% \ifx\currentstructuresaveinlist\v!no \else
-% \ifx\currentstructurelist\currentstructuretitle \else
-% list = \!!bs\detokenize\expandafter{\currentstructurelist}\!!es,
-% \fi
-% \fi
-% },
-% numberdata = {
-% % needed ?
-% block = "\currentsectionblock",
-% \ifx\currentstructureshownumber\v!no
-% hidenumber = true, % titles
-% \fi
-% % so far
-% separatorset = "\structureparameter\c!sectionseparatorset",
-% conversion = "\structureparameter\c!sectionconversion", % for good old times sake
-% conversionset = "\structureparameter\c!sectionconversionset",
-% starter = \!!bs\structureparameter\c!sectionstarter\!!es,
-% stopper = \!!bs\structureparameter\c!sectionstopper\!!es,
-% set = "\structureparameter\c!sectionset",
-% segments = "\structureparameter\c!sectionsegments",
-% ownnumber = "\currentstructureownnumber",
-% language = "\currentlanguage", % for the moment, needed for bookmarks conversion
-% },
-% userdata = \!!bs\detokenize{#3}\!!es % will be converted to table at the lua end
-% }
-% }%
\clf_setsectionentry
references {
internal \nextinternalreference\space
diff --git a/tex/context/base/toks-ini.lua b/tex/context/base/toks-ini.lua
index 0cd25a36c..f8b945890 100644
--- a/tex/context/base/toks-ini.lua
+++ b/tex/context/base/toks-ini.lua
@@ -68,7 +68,13 @@ if newtoken then
local set_macro = newtoken.set_macro
- set_macro = function(k,v) context.setvalue(k,v or '') end
+ set_macro = function(k,v,g)
+ if g == "global" then
+ context.setgvalue(k,v or '')
+ else
+ context.setvalue(k,v or '')
+ end
+ end
local bits = {
escape = 2^ 0,
diff --git a/tex/context/base/typo-cap.lua b/tex/context/base/typo-cap.lua
index fdc7740de..80a74bac9 100644
--- a/tex/context/base/typo-cap.lua
+++ b/tex/context/base/typo-cap.lua
@@ -432,4 +432,8 @@ end
-- interface
-commands.setcharactercasing = cases.set
+interfaces.implement {
+ name = "setcharactercasing",
+ actions = cases.set,
+ arguments = { "string", "integer" }
+}
diff --git a/tex/context/base/typo-cap.mkiv b/tex/context/base/typo-cap.mkiv
index eef4951fb..2859ba104 100644
--- a/tex/context/base/typo-cap.mkiv
+++ b/tex/context/base/typo-cap.mkiv
@@ -77,7 +77,7 @@
% test \Word{test TEST \TeX} test
\unexpanded\def\setcharactercasing[#1]%
- {\ctxcommand{setcharactercasing("#1",\number\fontid\font)}}
+ {\clf_setcharactercasing{#1}\fontid\font}
% todo: names casings
@@ -166,21 +166,15 @@
%
% here we keep the \groupedcommand
-% \def\typo_capitals_set_fake#1%
-% {\edef\currentcapitals{#1}%
-% \scratchcounter\fontid\font
-% \usecapitalsstyleparameter\c!style
-% \ctxcommand{setcharactercasing("\currentcapitals",\number\scratchcounter,\number\fontid\font)}}
-
\def\typo_capitals_set_fake#1%
{\edef\currentcapitals{#1}%
- \ctxcommand{setcharactercasing("\currentcapitals",\number\fontid\font)}%
+ \clf_setcharactercasing{\currentcapitals}\fontid\font
\usecapitalsstyleparameter\c!style}
\def\typo_capitals_set_real#1%
{\edef\currentcapitals{#1}%
\sc
- \ctxcommand{setcharactercasing("\currentcapitals",\number\fontid\font)}}
+ \clf_setcharactercasing{\currentcapitals}\fontid\font}
\unexpanded\def\pseudosmallcapped{\groupedcommand{\typo_capitals_set_fake\v!WORD }\donothing} % all upper
\unexpanded\def\pseudoSmallcapped{\groupedcommand{\typo_capitals_set_fake\v!capital}\donothing} % one upper + font
diff --git a/tex/context/base/typo-chr.lua b/tex/context/base/typo-chr.lua
index 87cffa7d4..073574218 100644
--- a/tex/context/base/typo-chr.lua
+++ b/tex/context/base/typo-chr.lua
@@ -72,13 +72,19 @@ if not modules then modules = { } end modules ['typo-chr'] = {
--
-- local enabled = false
--
--- function commands.signal(what)
+-- local function signal(what)
-- if not enabled then
-- nodes.tasks.prependaction("processors","normalizers", "typesetters.signals.handler")
-- enabled = true
-- end
-- context(stringusernode(signal,what))
-- end
+--
+-- interfaces.implement {
+-- name = "signal",
+-- actions = signal,
+-- arguments = "string",
+-- }
local nodecodes = nodes.nodecodes
local glyph_code = nodecodes.glyph
@@ -88,7 +94,7 @@ local free_node = node.free
local punctuation = characters.is_punctuation
-function commands.removepunctuation()
+local function removepunctuation()
local list = texnest[texnest.ptr]
if list then
local tail = list.tail
@@ -102,3 +108,8 @@ function commands.removepunctuation()
end
end
end
+
+interfaces.implement {
+ name = "removepunctuation",
+ actions = removepunctuation,
+}
diff --git a/tex/context/base/typo-chr.mkiv b/tex/context/base/typo-chr.mkiv
index 138bf348a..23efecb22 100644
--- a/tex/context/base/typo-chr.mkiv
+++ b/tex/context/base/typo-chr.mkiv
@@ -22,6 +22,6 @@
\registerctxluafile{typo-chr}{1.001}
%unexpanded\def\removepunctuation{\ctxcommand{signal("removepunctuation")}}
-\unexpanded\def\removepunctuation{\ctxcommand{removepunctuation()}}
+\unexpanded\def\removepunctuation{\clf_removepunctuation}
\protect
diff --git a/tex/context/base/typo-krn.lua b/tex/context/base/typo-krn.lua
index 1616577dc..46a977cfd 100644
--- a/tex/context/base/typo-krn.lua
+++ b/tex/context/base/typo-krn.lua
@@ -622,4 +622,9 @@ end
-- interface
-commands.setcharacterkerning = kerns.set
+interfaces.implement {
+ name = "setcharacterkerning",
+ actions = kerns.set,
+ arguments = "string"
+}
+
diff --git a/tex/context/base/typo-krn.mkiv b/tex/context/base/typo-krn.mkiv
index f5f452ae5..e638ab85f 100644
--- a/tex/context/base/typo-krn.mkiv
+++ b/tex/context/base/typo-krn.mkiv
@@ -35,13 +35,10 @@
\typo_kerning_set
\fi}
-% \def\typo_kerning_set
-% {\ctxcommand{setcharacterkerning(\characterkerningparameter\c!factor)}}
-
\def\typo_kerning_set
{\usecharacterkerningstyleandcolor\c!style\c!color % goodie, maybe also strut
\useaddfontfeatureparameter\characterkerningparameter
- \ctxcommand{setcharacterkerning("\characterkerningparameter\c!factor")}}
+ \clf_setcharacterkerning{\characterkerningparameter\c!factor}}
\unexpanded\def\resetcharacterkerning % fast one
{\attribute\kernattribute\attributeunsetvalue}
diff --git a/tex/context/base/x-asciimath.lua b/tex/context/base/x-asciimath.lua
index 7defd3387..5914c3c69 100644
--- a/tex/context/base/x-asciimath.lua
+++ b/tex/context/base/x-asciimath.lua
@@ -758,45 +758,67 @@ local issimplified = {
-- special mess
-local d_one = lpeg.R("09")
-local d_two = d_one * d_one
-local d_three = d_two * d_one
-local d_spaced = (Carg(1) * d_three)^1
-local d_split = P(-1) + P(",")
-
-local digitized = Cs((
- d_three * d_spaced * d_split +
- d_two * d_spaced * d_split +
- d_one * d_spaced * d_split +
- P(1)
- )^1)
-
--- print(lpeg.match(digitized,"1"))
--- print(lpeg.match(digitized,"12"))
--- print(lpeg.match(digitized,"123"))
--- print(lpeg.match(digitized,"1234"))
--- print(lpeg.match(digitized,"12345"))
--- print(lpeg.match(digitized,"123456"))
--- print(lpeg.match(digitized,"1234567"))
--- print(lpeg.match(digitized,"12345678"))
--- print(lpeg.match(digitized,"123456789"))
-
--- print(lpeg.match(digitized,"1,1"))
--- print(lpeg.match(digitized,"12,12"))
--- print(lpeg.match(digitized,"123,123"))
--- print(lpeg.match(digitized,"1234,1234"))
--- print(lpeg.match(digitized,"12345,12345"))
--- print(lpeg.match(digitized,"123456,123456"))
--- print(lpeg.match(digitized,"1234567,1234567"))
--- print(lpeg.match(digitized,"12345678,12345678"))
--- print(lpeg.match(digitized,"123456789,123456789"))
+local d_one = R("09")
+local d_two = d_one * d_one
+local d_three = d_two * d_one
+local d_four = d_three * d_one
+local d_split = P(-1) + P(",")
+
+local d_spaced = (Carg(1) * d_three)^1
+
+local digitized_1 = Cs ( (
+ d_three * d_spaced * d_split +
+ d_two * d_spaced * d_split +
+ d_one * d_spaced * d_split +
+ P(1)
+ )^1 )
+
+local p_fourbefore = d_four * d_split
+local p_fourafter = d_four * P(-1)
+
+local p_beforecomma = d_three * d_spaced * d_split
+ + d_two * d_spaced * d_split
+ + d_one * d_spaced * d_split
+ + d_one * d_split
+
+local p_aftercomma = p_fourafter
+ + d_three * d_spaced
+ + d_two * d_spaced
+ + d_one * d_spaced
+
+local digitized_2 = Cs (
+ p_fourbefore * p_aftercomma +
+ p_beforecomma * ((p_aftercomma + d_one^1)^0)
+ )
+
+local d_spaced = (Carg(1) * (d_three + d_two + d_one))^1
+local p_aftercomma = p_fourafter
+ + d_three * d_spaced * P(1)^0
+
+local digitized_3 = Cs (
+ p_fourbefore * p_aftercomma +
+ p_beforecomma * ((p_aftercomma + d_one^1)^0)
+ )
+
+local splitmethods = {
+ digitized_1,
+ digitized_2,
+ digitized_3,
+}
+
+local splitmethod = nil
function asciimath.setup(settings)
- local separator = settings.separator
- if separator == interfaces.variables.yes then
- digitseparator = utfchar(0x2008)
- elseif separator and separator ~= "" then
- digitseparator = separator
+ splitmethod = splitmethods[tonumber(settings.splitmethod) or 0]
+ if splitmethod then
+ local separator = settings.separator
+ if separator == true or not interfaces or interfaces.variables.yes then
+ digitseparator = utfchar(0x2008)
+ elseif type(separator) == "string" and separator ~= "" then
+ digitseparator = separator
+ else
+ splitmethod = nil
+ end
end
end
@@ -804,8 +826,8 @@ local collected_digits = { }
local collected_filename = "asciimath-digits.lua"
function numbermess(s)
- if digitseparator then
- local d = lpegmatch(digitized,s,1,digitseparator)
+ if splitmethod then
+ local d = lpegmatch(splitmethod,s,1,digitseparator)
if d then
if trace_digits and s ~= d then
collected_digits[s] = d
@@ -816,6 +838,29 @@ function numbermess(s)
return s
end
+asciimath.setup { splitmethod = 3 }
+
+local t = {
+ "1", "12", "123", "1234", "12345", "123456", "1234567", "12345678", "123456789",
+ "1,1",
+ "12,12",
+ "123,123",
+ "1234,1234",
+ "12345,1234",
+ "1234,12345",
+ "12345,12345",
+ "123456,123456",
+ "1234567,1234567",
+ "12345678,12345678",
+ "123456789,123456789",
+ "0,1234",
+ "1234,0",
+ "1234,00",
+ "0,123456789",
+}
+for i=1,#t do print(formatters["%-20s : [%s]"](t[i],numbermess(t[i]))) end
+
+
statistics.register("asciimath",function()
if trace_digits then
local n = table.count(collected_digits)
@@ -1762,7 +1807,7 @@ if not context then
-- convert("10000,00001")
-- convert("4/18*100text(%)~~22,2")
-- convert("4/18*100text(%)≈22,2")
-convert("62541/(197,6)≈316,05")
+-- convert("62541/(197,6)≈316,05")
-- convert([[sum x]])
-- convert([[sum^(1)_(2) x]])
diff --git a/tex/context/base/x-asciimath.mkiv b/tex/context/base/x-asciimath.mkiv
index 27d19693f..7007893ae 100644
--- a/tex/context/base/x-asciimath.mkiv
+++ b/tex/context/base/x-asciimath.mkiv
@@ -151,7 +151,8 @@
\appendtoks
\ctxlua{moduledata.asciimath.setup {
- separator = "\asciimathparameter\c!separator",
+ splitmethod = "\asciimathparameter\c!splitmethod",
+ separator = "\asciimathparameter\c!separator",
}}%
\to \everysetupasciimath
diff --git a/tex/generic/context/luatex/luatex-fonts-merged.lua b/tex/generic/context/luatex/luatex-fonts-merged.lua
index b97021447..1ae47cf63 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/26/15 22:52:35
+-- merge date : 03/27/15 21:39:51
do -- begin closure to overcome local limits and interference