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
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
|
if not modules then modules = { } end modules ['back-ini'] = {
version = 1.001,
comment = "companion to back-ini.mkiv",
author = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
copyright = "PRAGMA ADE / ConTeXt Development Team",
license = "see context related readme files"
}
-- -- how to create a shortcut:
--
-- local function something(...)
-- something = backends.codeinjections.something
-- return something(...)
-- end
local next, type = next, type
local format = string.format
backends = backends or { }
local backends = backends
local trace_backend = false trackers.register("backend.initializers", function(v) trace_finalizers = v end)
local report_backend = logs.reporter("backend","initializing")
local allocate = utilities.storage.allocate
local setmetatableindex = table.setmetatableindex
local setaction = nodes.tasks.setaction
local texset = tex.set
local function nothing() return nil end
backends.nothing = nothing
local nodeinjections = { }
local codeinjections = { }
local registrations = { }
local tables = allocate()
local function donothing(t,k)
t[k] = nothing
return nothing
end
setmetatableindex(nodeinjections, donothing)
setmetatableindex(codeinjections, donothing)
setmetatableindex(registrations, donothing)
local defaults = {
nodeinjections = nodeinjections,
codeinjections = codeinjections,
registrations = registrations,
tables = tables,
}
backends.defaults = defaults
backends.nodeinjections = { } setmetatableindex(backends.nodeinjections, nodeinjections)
backends.codeinjections = { } setmetatableindex(backends.codeinjections, codeinjections)
backends.registrations = { } setmetatableindex(backends.registrations, registrations)
backends.tables = { } setmetatableindex(backends.tables, tables)
backends.current = "unknown"
local lmtx_mode = nil
local function lmtxmode()
if lmtx_mode == nil then
lmtx_mode = environment.lmtxmode and drivers and drivers.lmtxversion
end
return lmtx_mode
end
codeinjections.lmtxmode = lmtxmode
function backends.install(what)
if type(what) == "string" then
local backend = backends[what]
if backend then
if trace_backend then
if backend.comment then
report_backend("initializing backend %a, %a",what,backend.comment)
else
report_backend("initializing backend %a",what)
end
end
backends.current = what
for category, default in next, defaults do
local target = backends[category]
local plugin = backend [category]
setmetatableindex(plugin, default)
setmetatableindex(target, plugin)
end
elseif trace_backend then
report_backend("no backend named %a",what)
end
end
end
statistics.register("used backend", function()
local bc = backends.current
if bc ~= "unknown" then
local lmtx = lmtxmode()
local cmnt = backends[bc].comment or "no comment"
if lmtx then
return format("lmtx version %0.2f, %s (%s)",lmtx,bc,cmnt)
else
return format("%s (%s)",bc,cmnt)
end
else
return nil
end
end)
local comment = { "comment", "" }
tables.vfspecials = allocate {
red = comment,
green = comment,
blue = comment,
black = comment,
startslant = comment,
stopslant = comment,
}
-- can best be here
interfaces.implement {
name = "setrealspaces",
arguments = "string",
actions = function(v)
setaction("shipouts","nodes.handlers.accessibility",v == interfaces.variables.yes)
end
}
-- moved to here
local included = table.setmetatableindex( {
context = true,
id = true,
metadata = true,
date = true,
id = true,
pdf = true,
}, function(t,k)
return true
end)
backends.included = included
function backends.timestamp()
return os.date("%Y-%m-%dT%X") .. os.timezone(true)
end
-- Also here:
local paper_width = 0
local paper_height = 0
function codeinjections.setpagedimensions(paperwidth,paperheight)
if paperwidth then
paper_width = paperwidth
end
if paperheight then
paper_height = paperheight
end
if not lmtxmode() then
texset("global","pageheight",paper_height)
texset("global","pagewidth", paper_width)
end
return paper_width, paper_height
end
function codeinjections.getpagedimensions()
return paper_width, paper_height
end
interfaces.implement {
name = "shipoutoffset",
actions = function()
context(lmtxmode() and "0pt" or "-1in") -- the old tex offset
end
}
|