1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
if not modules then modules = { } end modules ['m-database'] = {
version = 1.001,
comment = "companion to m-database.mkiv",
author = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
copyright = "PRAGMA ADE / ConTeXt Development Team",
license = "see context related readme files"
}
local sub, gmatch = string.sub, string.gmatch
local lpegpatterns, lpegmatch, lpegsplitat = lpeg.patterns, lpeg.match, lpeg.splitat
local lpegP, lpegC, lpegS, lpegCt = lpeg.P, lpeg.C, lpeg.S, lpeg.Ct
local sprint, ctxcatcodes = tex.sprint, tex.ctxcatcodes
buffers.database = buffers.database or { }
local separators = { -- not interfaced
tab = lpegpatterns.tab,
tabs = lpegpatterns.tab^1,
comma = lpegpatterns.comma,
space = lpegpatterns.space,
spaces = lpegpatterns.space^1,
}
function buffers.database.process(settings)
-- table.print(settings)
local data
if settings.type == "file" then
local filename = resolvers.finders.any(settings.database)
data = filename ~= "" and io.loaddata(filename)
data = data and string.splitlines(data)
else
data = buffers.raw(settings.database)
end
local function sprint(c,...)
tex.sprint(tex.ctxcatcodes,[[\tt\bgroup]])
tex.sprint(tex.vrbcatcodes,...)
tex.sprint(tex.ctxcatcodes,[[\egroup\crlf]])
end
if data and #data > 0 then
local separatorchar, quotechar, commentchar = settings.separator, settings.quotechar, settings.commentchar
local before, after = settings.before or "", settings.after or ""
local first, last = settings.first or "", settings.last or ""
local left, right = settings.left or "", settings.right or ""
local command = settings.command
separatorchar = (not separatorchar and ",") or separators[separatorchar] or separatorchar
local separator = type(separatorchar) == "string" and lpegS(separatorchar) or separatorchar
local whatever = lpegC((1 - separator)^0)
if quotechar and quotechar ~= "" then
local quotedata = nil
for chr in gmatch(quotechar,".") do
local quotechar = lpegP(chr)
local quoteword = quotechar * lpeg.C((1 - quotechar)^0) * quotechar
if quotedata then
quotedata = quotedata + quoteword
else
quotedata = quoteword
end
end
whatever = quotedata + whatever
end
local checker = commentchar ~= "" and lpeg.S(commentchar)
local splitter = lpegCt(whatever * (separator * whatever)^0)
local found = false
for i=1,#data do
local line = data[i]
if line ~= "" and (not checker or not lpegmatch(checker,line)) then
local result, r = { }, 0 -- we collect as this is nicer in tracing
local list = lpegmatch(splitter,line)
if not found then
local setups = settings.setups or ""
if setups == "" then
sprint(ctxcatcodes,"\\begingroup")
else
sprint(ctxcatcodes,"\\begingroup\\setups[",setups,"]")
end
sprint(ctxcatcodes,before)
found = true
end
r = r + 1 ; result[r] = first
for j=1,#list do
result[#result+1] = left
if command == "" then
r = r + 1 ; result[r] = list[j]
else
r = r + 1 ; result[r] = command
r = r + 1 ; result[r] = "{"
r = r + 1 ; result[r] = list[j]
r = r + 1 ; result[r] = "}"
end
r = r + 1 ; result[r] = right
end
r = r + 1 ; result[r] = last
sprint(ctxcatcodes,result)
end
end
if found then
sprint(ctxcatcodes,after)
sprint(ctxcatcodes,"\\endgroup")
end
else
-- message
end
end
|