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
|
if not modules then modules = { } end modules ['font-imp-tracing'] = {
version = 1.001,
comment = "companion to font-ini.mkiv and hand-ini.mkiv",
author = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
copyright = "PRAGMA ADE / ConTeXt Development Team",
license = "see context related readme files"
}
local next, type = next, type
local formatters = string.formatters
local fonts = fonts
local handlers = fonts.handlers
local registerotffeature = handlers.otf.features.register
local registerafmfeature = handlers.afm.features.register
local settings_to_array = utilities.parsers.settings_to_array
local setmetatableindex = table.setmetatableindex
local helpers = fonts.helpers
local prependcommands = helpers.prependcommands
local charcommand = helpers.commands.char
local variables = interfaces.variables
local v_background = variables.background
local v_frame = variables.frame
local v_empty = variables.empty
local v_none = variables.none
-- for zhichu chen (see mailing list archive): we might add a few more variants
-- in due time
--
-- \definefontfeature[boxed][default][boundingbox=yes] % paleblue
--
-- maybe:
--
-- \definecolor[DummyColor][s=.75,t=.5,a=1] {\DummyColor test} \nopdfcompression
--
-- local gray = { "pdf", "origin", "/Tr1 gs .75 g" }
-- local black = { "pdf", "origin", "/Tr0 gs 0 g" }
-- boundingbox={yes|background|frame|empty|<color>}
local bp = number.dimenfactors.bp
local r = 16384 * bp -- 65536 // 4
local f_1 = formatters["%.6F w 0 %.6F %.6F %.6F re f"]
local f_2 = formatters["[] 0 d 0 J %.6F w %.6F %.6F %.6F %.6F re S"]
local backcache = setmetatableindex(function(t,h)
local h = h * bp
local v = setmetatableindex(function(t,d)
local d = d * bp
local v = setmetatableindex(function(t,w)
local v = { "pdf", "origin", f_1(r,-d,w*bp,h+d) }
t[w] = v
return v
end)
t[d] = v
return v
end)
t[h] = v
return v
end)
local forecache = setmetatableindex(function(t,h)
local h = h * bp
local v = setmetatableindex(function(t,d)
local d = d * bp
local v = setmetatableindex(function(t,w)
-- the frame goes through the boundingbox
local v = { "pdf", "origin", f_2(r,r/2,-d+r/2,w*bp-r,h+d-r) }
t[w] = v
return v
end)
t[d] = v
return v
end)
t[h] = v
return v
end)
local startcolor = nil
local stopcolor = nil
local function initialize(tfmdata,key,value)
if value then
if not backcolors then
local vfspecials = backends.pdf.tables.vfspecials
startcolor = vfspecials.startcolor
stopcolor = vfspecials.stopcolor
end
local characters = tfmdata.characters
local rulecache = backcache
local showchar = true
local color = "palegray"
if type(value) == "string" then
value = settings_to_array(value)
for i=1,#value do
local v = value[i]
if v == v_frame then
rulecache = forecache
elseif v == v_background then
rulecache = backcache
elseif v == v_empty then
showchar = false
elseif v == v_none then
color = nil
else
color = v
end
end
end
local gray = color and startcolor(color) or nil
local black = gray and stopcolor or nil
for unicode, character in next, characters do
local width = character.width or 0
local height = character.height or 0
local depth = character.depth or 0
local rule = rulecache[height][depth][width]
if showchar then
local commands = character.commands
if commands then
if gray then
character.commands = prependcommands (
commands, gray, rule, black
)
else
character.commands = prependcommands (
commands, rule
)
end
else
local char = charcommand[unicode]
if gray then
character.commands = {
gray, rule, black, char
}
else
character.commands = {
rule, char
}
end
end
else
if gray then
character.commands = {
gray, rule, black
}
else
character.commands = {
rule
}
end
end
end
end
end
local specification = {
name = "boundingbox",
description = "show boundingbox",
manipulators = {
base = initialize,
node = initialize,
}
}
registerotffeature(specification)
registerafmfeature(specification)
|