From d26cacc03e700db6a15cefab13fe3b007c416325 Mon Sep 17 00:00:00 2001 From: Context Git Mirror Bot Date: Tue, 11 Nov 2014 13:15:03 +0100 Subject: 2014-11-11 12:14:00 --- tex/context/base/cont-new.mkiv | 2 +- tex/context/base/context-version.pdf | Bin 4385 -> 4377 bytes tex/context/base/context.mkiv | 2 +- tex/context/base/publ-aut.lua | 21 ++-- tex/context/base/publ-dat.lua | 55 +++++++--- tex/context/base/publ-imp-apa.lua | 27 +++-- tex/context/base/publ-imp-apa.mkvi | 2 +- tex/context/base/publ-ini.lua | 111 ++++++++++++--------- tex/context/base/publ-tra.lua | 26 ++++- tex/context/base/publ-tra.mkiv | 6 ++ tex/context/base/status-files.pdf | Bin 24700 -> 24717 bytes tex/context/base/status-lua.pdf | Bin 343985 -> 342244 bytes tex/generic/context/luatex/luatex-fonts-merged.lua | 2 +- 13 files changed, 166 insertions(+), 88 deletions(-) (limited to 'tex') diff --git a/tex/context/base/cont-new.mkiv b/tex/context/base/cont-new.mkiv index 7bd25304b..e3ce4e077 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{2014.11.10 23:13} +\newcontextversion{2014.11.11 12:12} %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 056f96946..2391c5443 100644 Binary files a/tex/context/base/context-version.pdf and b/tex/context/base/context-version.pdf differ diff --git a/tex/context/base/context.mkiv b/tex/context/base/context.mkiv index efa0a7383..179709972 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{2014.11.10 23:13} +\edef\contextversion{2014.11.11 12:12} \edef\contextkind {beta} %D For those who want to use this: diff --git a/tex/context/base/publ-aut.lua b/tex/context/base/publ-aut.lua index 971dee45e..7eef49f72 100644 --- a/tex/context/base/publ-aut.lua +++ b/tex/context/base/publ-aut.lua @@ -13,9 +13,6 @@ end local lpeg = lpeg -local context = context -local chardata = characters.data - local type, next, tostring = type, next, tostring local concat = table.concat local utfchar = utf.char @@ -23,16 +20,15 @@ local formatters = string.formatters local P, C, V, Cs, Ct, lpegmatch, lpegpatterns = lpeg.P, lpeg.C, lpeg.V, lpeg.Cs, lpeg.Ct, lpeg.match, lpeg.patterns -local publications = publications or { } - -local datasets = publications.datasets or { } -publications.datasets = datasets +local context = context +local commands = commands +local publications = publications -local writers = publications.writers or { } -publications.writers = writers +local datasets = publications.datasets +local writers = publications.writers +local authors = publications.authors -local authors = publications.authors or { } -publications.authors = authors +local chardata = characters.data local report = logs.reporter("publications","authors") @@ -460,8 +456,7 @@ local function writer(key,snippets) return concat(snippets," ",1,s) end -writers.author = writer -writers.editor = editor +writers.author = writer local default = { "author" } diff --git a/tex/context/base/publ-dat.lua b/tex/context/base/publ-dat.lua index 834fdc10c..0026c2c1f 100644 --- a/tex/context/base/publ-dat.lua +++ b/tex/context/base/publ-dat.lua @@ -48,6 +48,8 @@ local trace_duplicates = true trackers.register("publications.duplicates", fu local report = logs.reporter("publications") local report_duplicates = logs.reporter("publications","duplicates") +local allocate = utilities.storage.allocate + publications = publications or { } local publications = publications @@ -57,6 +59,9 @@ publications.datasets = datasets local writers = publications.writers or { } publications.writers = writers +local authors = publications.authors or { } +publications.authors = authors + local tables = publications.tables or { } publications.tables = tables @@ -68,13 +73,13 @@ publicationsstats.nofdefinitions = 0 publicationsstats.nofshortcuts = 0 publicationsstats.nofdatasets = 0 -local privates = { +local privates = allocate { category = true, tag = true, index = true, } -local specials = { +local specials = allocate { key = true, crossref = true, keywords = true, @@ -95,7 +100,7 @@ local v_all = interfaces and interfaces.variables.all or "all" local xmlplaceholder = "\n" -local defaultshortcuts = { +local defaultshortcuts = allocate { jan = "1", feb = "2", mar = "3", @@ -115,7 +120,7 @@ local separator = space * "+" * space local l_splitter = lpeg.tsplitat(separator) local d_splitter = lpeg.splitat (separator) -local implicitfields = { +local implicits = allocate { category = "implicit", tag = "implicit", key = "implicit", @@ -124,14 +129,14 @@ local implicitfields = { crossref = "implicit", } -local types = { +local origins = allocate { "optional", "extra", "required", "virtual", } -local virtuals = { +local virtuals = allocate { "authoryear", "authoryears", "authornum", @@ -139,6 +144,17 @@ local virtuals = { "suffix", } +local defaulttypes = allocate { + author = "author", + editor = "author", + publisher = "author", +} + +tables.implicits = implicits +tables.origins = origins +tables.virtuals = virtuals +tables.types = defaulttypes + local unknownfield = function(t,k) local v = "extra" t[k] = v @@ -151,11 +167,18 @@ local unknowncategory = function(t,k) optional = false, virtual = false, fields = setmetatableindex(unknownfield), + types = defaulttypes, } t[k] = v return v end +local unknowntype = function(t,k) + local v = "string" + t[k] = v + return v +end + local default = { name = name, version = "1.00", @@ -163,18 +186,19 @@ local default = { author = "anonymous", copyright = "no one", categories = setmetatableindex(unknowncategory), + types = setmetatableindex(defaulttypes,unknowntype), } +-- maybe at some point we can han da handlers table with per field +-- a found, fetch, ... method + local function checkfield(specification,category,data) - local list = setmetatableindex({},implicitfields) + local list = setmetatableindex({},implicits) data.fields = list data.category = category local sets = data.sets or { } - if data.virtual == nil then -- so false is valid - data.virtual = specification.virtual - end - for i=1,#types do - local t = types[i] + for i=1,#origins do + local t = origins[i] local d = data[t] if d then for i=1,#d do @@ -218,6 +242,13 @@ local specifications = setmetatableindex(function(t,name) end setmetatableindex(categories,unknowncategory) -- + local types = specification.types + if not types then + types = defaulttypes + specification.types = types + end + setmetatableindex(types,unknowntype) + -- local fields = setmetatableindex(unknownfield) specification.fields = fields -- diff --git a/tex/context/base/publ-imp-apa.lua b/tex/context/base/publ-imp-apa.lua index 7e0d06121..3ee67f6d1 100644 --- a/tex/context/base/publ-imp-apa.lua +++ b/tex/context/base/publ-imp-apa.lua @@ -199,7 +199,7 @@ categories.booklet = { "subtitle", "type", "file", "address", "howpublished", - "note", + "note", "isbn", }, } @@ -207,11 +207,11 @@ categories.booklet = { categories.incollection = { sets = { - author = { "author", "editor", "publisher" }, + author = { "author", "editor", "publisher", "title" }, }, required = { "author", - "title", "booktitle", + "booktitle", "year", }, optional = { @@ -220,23 +220,25 @@ categories.incollection = { "volume", "number", "series", "chapter", "pages", "address", - "note", "isbn", + "note", "isbn" }, } -- the proceedings of a conference. categories.proceedings = { + sets = { + author = { "editor", "publisher", "title" }, + }, required = { - "title", + "author", "year" }, optional = { - "editor", "subtitle", "file", "volume", "number", "series", "pages", "month", - "address", "publisher", "organization", + "address", "organization", "note", "isbn" }, } @@ -400,13 +402,16 @@ categories.other = { -- if all else fails to match: categories.literal = { + sets = { + author = { "key" }, + }, required = { - "key", + "author", "text" }, - optional = { - -- whatever comes up - }, + -- optional = { + -- -- whatever comes up + -- }, virtual = false, } diff --git a/tex/context/base/publ-imp-apa.mkvi b/tex/context/base/publ-imp-apa.mkvi index ef148e657..e6055bd35 100644 --- a/tex/context/base/publ-imp-apa.mkvi +++ b/tex/context/base/publ-imp-apa.mkvi @@ -363,7 +363,6 @@ % we make the authoryear active, pointing to the citation \texdefinition{btx:apa:inject} {\s!internal(\currentbtxinternal)} { -<\btxfoundname{author},\btxfoundtype{author}> \doifelse {\btxfoundname{author}} {editor} { \texdefinition{btx:apa:editor-or-editors} } { @@ -661,6 +660,7 @@ \stoptexdefinition % #author is author, editor, organization, howpublished or assignee + \starttexdefinition btx:apa:wherefrom-publisher-author-is- #author \btxdoifelse {country} { \btxspace diff --git a/tex/context/base/publ-ini.lua b/tex/context/base/publ-ini.lua index 054e20d37..188995b0a 100644 --- a/tex/context/base/publ-ini.lua +++ b/tex/context/base/publ-ini.lua @@ -146,6 +146,7 @@ local ctx_btxstopciteauthor = context.btxstopciteauthor local ctx_btxstartsubcite = context.btxstartsubcite local ctx_btxstopsubcite = context.btxstopsubcite local ctx_btxlistsetup = context.btxlistsetup +local ctx_btxflushauthor = context.btxflushauthor local registeredcitevariants = publications.registeredcitevariants or allocate() local registeredlistvariants = publications.registeredlistvariants or allocate() @@ -698,11 +699,6 @@ local function shortsorter(a,b) return a[4] < b[4] end -local authorkeys = { - "author", - "editor", -} - function publications.enhance(dataset) -- for the moment split runs (maybe publications.enhancers) statistics.starttiming(publications) if type(dataset) == "string" then @@ -714,12 +710,20 @@ function publications.enhance(dataset) -- for the moment split runs (maybe publi local luadata = dataset.luadata local details = dataset.details local ordered = dataset.ordered - -- authors: todo, get authorkeys from current specification (so we need to redo when that spec changes) + local types = currentspecification.types -- or { author = "author", editor = "author" } + local authors = { } + -- + for k, v in next, types do + if v == "author" then + authors[#authors+1] = k + end + end + -- for tag, entry in next, luadata do local detail = { } details[tag] = detail - for i=1,#authorkeys do - local key = authorkeys[i] + for i=1,#authors do + local key = authors[i] local value = entry[key] if value then detail[key] = splitauthorstring(value) @@ -900,6 +904,32 @@ end do + local typesetters = { } + publications.typesetters = typesetters + + local function defaulttypesetter(field,value,manipulator) + if value and value ~= "" then + value = tostring(value) + context(manipulator and applymanipulation(manipulator,value) or value) + end + end + + setmetatableindex(typesetters,function(t,k) + local v = defaulttypesetter + t[k] = v + return v + end) + + function typesetters.string(field,value,manipulator) + if value and value ~= "" then + context(manipulator and applymanipulation(manipulator,value) or value) + end + end + + function typesetters.author(field,value,manipulator) + ctx_btxflushauthor(field) + end + -- if there is no specification then we're in trouble but there is -- always a default anyway -- @@ -921,7 +951,6 @@ do return false end local kind = fields[field] - -- if ignoredfields and kind == "optional" and ignoredfields[field] then if ignoredfields and ignoredfields[field] then return false else @@ -932,44 +961,31 @@ do end local function found(dataset,tag,field,valid,fields) - local details = nil - local function check_f(field) - local value = fields[field] - if type(value) == "string" then - return value - end - end - local function check_d(field) - local value = details[field] - if type(value) == "string" then - return value - end - end if valid == true then -- local fields = dataset.luadata[tag] - local okay = check_f(field) + local okay = fields[field] if okay then - return okay + return field, okay end - details = dataset.details[tag] - local okay = check_d(field) + local details = dataset.details[tag] + local okay = details[field] if okay then - return okay + return field, okay end elseif valid then -- local fields = dataset.luadata[tag] for i=1,#valid do local field = valid[i] - local okay = check_f(field) + local okay = fields[field] if okay then - return okay + return field, okay end end - details = dataset.details[tag] + local details = dataset.details[tag] for i=1,#valid do - local okay = check_d(field) + local okay = details[field] if okay then - return okay + return field, okay end end end @@ -987,10 +1003,6 @@ do end local fields = catspec.fields if fields then - local kind = (not check or data[field]) and fields[field] - if kind then - return what and kind or field - end local sets = catspec.sets if sets then local set = sets[field] @@ -1014,6 +1026,10 @@ do end end end + local kind = (not check or data[field]) and fields[field] + if kind then + return what and kind or field + end end end end @@ -1034,9 +1050,9 @@ do local category = fields.category local valid = permitted(category,field) if valid then - local okay = found(dataset,tag,field,valid,fields) - if okay then - context(manipulator and applymanipulation(manipulator,okay) or okay) + local name, value = found(dataset,tag,field,valid,fields) + if value then + typesetters[currentspecification.types[name]](field,value,manipulator) else report("%s %s %a in category %a for tag %a in dataset %a","unknown","entry",field,category,tag,name) end @@ -1060,8 +1076,8 @@ do if permitted(category,field) then local manipulator, field = splitmanipulation(field) local value = fields[field] - if type(value) == "string" then - context(manipulator and applymanipulation(manipulator,value) or value) + if value then + typesetters[currentspecification.types[field]](field,value,manipulator) else report("%s %s %a in category %a for tag %a in dataset %a","unknown","field",field,category,tag,name) end @@ -1087,8 +1103,8 @@ do if permitted(category,field) then local manipulator, field = splitmanipulation(field) local value = details[field] - if type(value) == "string" then - context(manipulator and applymanipulation(manipulator,value) or value) + if value then + typesetters[currentspecification.types[field]](field,value,manipulator) else report("%s %s %a in category %a for tag %a in dataset %a","unknown","detail",field,category,tag,name) end @@ -1114,7 +1130,8 @@ do local category = fields.category local valid = permitted(category,field) if valid then - return found(dataset,tag,field,valid,fields) + local value, field = found(dataset,tag,field,valid,fields) + return value and value ~= "" end end end @@ -1444,10 +1461,10 @@ local function byspec(dataset,list,method) -- todo: yearsuffix local a, b = lpegmatch(splitspec,f[i]) if b then if a == "detail" or a == "entry" then - local w = writers[b] + local t = currentspecification.types[b] + local w = t and writers[t] if w then - -- r[#r+1] = formatters["(%s.%s and writers[%q](%s.%s,snippets))"](a,b,b,a,b) - r[#r+1] = formatters["(%s.%s and writers[%q](%s.%s))"](a,b,b,a,b) + r[#r+1] = formatters["(%s.%s and writers[%q](%s.%s))"](a,b,t,a,b) else r[#r+1] = formatters["%s.%s"](a,b,a,b) end diff --git a/tex/context/base/publ-tra.lua b/tex/context/base/publ-tra.lua index a6141c769..09dab888a 100644 --- a/tex/context/base/publ-tra.lua +++ b/tex/context/base/publ-tra.lua @@ -19,7 +19,7 @@ local specifications = publications.specifications local context = context local ctx_NC, ctx_NR, ctx_HL, ctx_FL, ctx_ML, ctx_LL = context.NC, context.NR, context.HL, context.FL, context.ML, context.LL -local ctx_bold, ctx_monobold, ctx_rotate, ctx_llap = context.bold, context.formatted.monobold, context.rotate, context.llap +local ctx_bold, ctx_monobold, ctx_rotate, ctx_llap, ctx_rlap = context.bold, context.formatted.monobold, context.rotate, context.llap, context.rlap local ctx_starttabulate, ctx_stoptabulate = context.starttabulate, context.stoptabulate local privates = publications.tables.privates @@ -283,6 +283,30 @@ function tracers.showfields(settings) ctx_stoptabulate() end +function tracers.showtables(settings) + for name, list in sortedhash(publications.tables) do + ctx_starttabulate { "|Tl|Tl|" } + ctx_FL() + ctx_NC() + ctx_rlap(function() ctx_bold(name) end) + ctx_NC() + ctx_NC() + ctx_NR() + ctx_FL() + for k, v in sortedhash(list) do + ctx_NC() + context(k) + ctx_NC() + context(tostring(v)) + ctx_NC() + ctx_NR() + end + ctx_LL() + ctx_stoptabulate() + end +end + commands.showbtxdatasetfields = tracers.showdatasetfields commands.showbtxdatasetcompleteness = tracers.showdatasetcompleteness commands.showbtxfields = tracers.showfields +commands.showbtxtables = tracers.showtables diff --git a/tex/context/base/publ-tra.mkiv b/tex/context/base/publ-tra.mkiv index 566992a01..6f4167d83 100644 --- a/tex/context/base/publ-tra.mkiv +++ b/tex/context/base/publ-tra.mkiv @@ -23,6 +23,7 @@ \unexpanded\def\showbtxdatasetfields {\dosingleempty\publ_show_dataset_fields} \unexpanded\def\showbtxdatasetcompleteness{\dosingleempty\publ_show_dataset_completeness} \unexpanded\def\showbtxfields {\dosingleempty\publ_show_fields} +\unexpanded\def\showbtxtables {\dosingleempty\publ_show_tables} \def\publ_show_dataset_whatever#1[#2]% {\begingroup @@ -61,6 +62,11 @@ % \publ_specification_pop \endgroup} +\def\publ_show_tables[#1]% + {\begingroup + \ctxcommand{showbtxtables{}}% + \endgroup} + \protect \continueifinputfile{publ-tra.mkiv} diff --git a/tex/context/base/status-files.pdf b/tex/context/base/status-files.pdf index 3da4d77e2..0cd6b92cb 100644 Binary files a/tex/context/base/status-files.pdf and b/tex/context/base/status-files.pdf differ diff --git a/tex/context/base/status-lua.pdf b/tex/context/base/status-lua.pdf index a6ccfe118..5182fb633 100644 Binary files a/tex/context/base/status-lua.pdf and b/tex/context/base/status-lua.pdf differ diff --git a/tex/generic/context/luatex/luatex-fonts-merged.lua b/tex/generic/context/luatex/luatex-fonts-merged.lua index 180394ce6..dc2bb35bf 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 : 11/10/14 23:13:18 +-- merge date : 11/11/14 12:12:33 do -- begin closure to overcome local limits and interference -- cgit v1.2.3