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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
|
if not modules then modules = { } end modules ['core-two'] = {
version = 1.001,
comment = "companion to core-two.tex",
author = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
copyright = "PRAGMA ADE / ConTeXt Development Team",
license = "see context related readme files"
}
local remove, concat = table.remove, table.concat
local texprint = tex.print
--[[ldx--
<p>We save multi-pass information in the main utility table. This is a
bit of a mess because we support old and new methods.</p>
--ldx]]--
jobpasses = jobpasses or { }
jobpasses.collected = jobpasses.collected or { }
jobpasses.tobesaved = jobpasses.tobesaved or { }
local collected, tobesaved = jobpasses.collected, jobpasses.tobesaved
local function initializer()
collected, tobesaved = jobpasses.collected, jobpasses.tobesaved
end
job.register('jobpasses.collected', jobpasses.tobesaved, initializer, nil)
local function allocate(id)
local p = tobesaved[id]
if not p then
p = { }
tobesaved[id] = p
end
return p
end
jobpasses.define = allocate
function jobpasses.save(id,str)
local jti = allocate(id)
jti[#jti+1] = str
end
function jobpasses.savetagged(id,tag,str)
local jti = allocate(id)
jti[tag] = str
end
function jobpasses.getcollected(id)
return collected[id] or { }
end
function jobpasses.gettobesaved(id)
return allocate(id)
end
function jobpasses.get(id)
local jti = collected[id]
if jti and #jti > 0 then
texprint(remove(jti,1))
end
end
function jobpasses.first(id)
local jti = collected[id]
if jti and #jti > 0 then
texprint(jti[1])
end
end
function jobpasses.last(id)
local jti = collected[id]
if jti and #jti > 0 then
texprint(jti[#jti])
end
end
jobpasses.check = jobpasses.first
function jobpasses.find(id,n)
local jti = collected[id]
if jti and jti[n] then
texprint(jti[n])
end
end
function jobpasses.count(id)
local jti = collected[id]
texprint((jti and #jti) or 0)
end
function jobpasses.list(id)
local jti = collected[id]
if jti then
texprint(concat(jti,','))
end
end
function jobpasses.doifinlistelse(id,str)
local jti = collected[id]
if jti then
local found = false
for _, v in next, jti do
if v == str then
found = true
break
end
end
commands.testcase(found)
else
commands.testcase(false)
end
end
--
function jobpasses.savedata(id,data)
local jti = allocate(id)
jti[#jti+1] = data
return #jti
end
function jobpasses.getdata(id,index,default)
local jti = collected[id]
texprint((jit and jti[index]) or default)
end
function jobpasses.getfield(id,index,tag,default)
local jti = collected[id]
jti = jti and jti[index]
texprint((jti and jti[tag]) or default)
end
|