1
2
3
4
5
6
7
8
9
10
11
12
13
14\writestatus{loading}{ConTeXt Font Macros Emphasis}
15
16\unprotect
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\lettonothing\m_font_emphasized_typeface
42
43\def\font_emphasis_checked_typeface#slanted#italic
44 {\edef\m_font_emphasized_typeface{\font_bodyfontvariable\s!em}
45 \ifx\m_font_emphasized_typeface\v!slanted
46 #slanted
47 \orelse\ifx\m_font_emphasized_typeface\v!italic
48 #italic
49 \orelse\ifempty\m_font_emphasized_typeface
50 #slanted
51 \else
52 \csname\m_font_emphasized_typeface\endcsname
53 \fi}
54
55\permanent\protected\def\emphasistypeface{\font_emphasis_checked_typeface\sl\it}
56\permanent\protected\def\emphasisboldface{\font_emphasis_checked_typeface\bs\bi}
57
58\permanent\protected\def\normalboldface
59 {\relax
60 \ifx\fontalternative\s!tf\bf\orelse
61 \ifx\fontalternative\s!it\bi\orelse
62 \ifx\fontalternative\s!sl\bs\orelse
63 \ifx\fontalternative\s!bf \orelse
64 \ifx\fontalternative\s!bi \orelse
65 \ifx\fontalternative\s!bs \else
66 \bf\fi}
67
68\permanent\protected\def\normalitalicface
69 {\relax
70 \ifx\fontalternative\s!tf\it\orelse
71 \ifx\fontalternative\s!it \orelse
72 \ifx\fontalternative\s!sl\it\orelse
73 \ifx\fontalternative\s!bf\bi\orelse
74 \ifx\fontalternative\s!bi\bi\orelse
75 \ifx\fontalternative\s!bs\bi\else
76 \it\fi}
77
78\permanent\protected\def\normalslantedface
79 {\relax
80 \ifx\fontalternative\s!tf\sl\orelse
81 \ifx\fontalternative\s!it\sl\orelse
82 \ifx\fontalternative\s!sl \orelse
83 \ifx\fontalternative\s!bf\bs\orelse
84 \ifx\fontalternative\s!bi\bs\orelse
85 \ifx\fontalternative\s!bs\bs\else
86 \sl\fi}
87
88\permanent\protected\def\normaltypeface
89 {\relax
90 \ifx\fontalternative\s!tf \orelse
91 \ifx\fontalternative\s!it\tf\orelse
92 \ifx\fontalternative\s!sl\tf\orelse
93 \ifx\fontalternative\s!bf \orelse
94 \ifx\fontalternative\s!bi\bf\orelse
95 \ifx\fontalternative\s!bs\bf\else
96 \tf\fi}
97
98\permanent\protected\def\swaptypeface
99 {\relax
100 \ifx\fontalternative\s!it \tf \orelse
101 \ifx\fontalternative\s!sl \tf \orelse
102 \ifx\fontalternative\s!bf \emphasisboldface \orelse
103 \ifx\fontalternative\s!bs \bf \orelse
104 \ifx\fontalternative\s!bi \bf \else
105 \emphasistypeface \fi}
106
107\aliased\let\typeface \normaltypeface
108\aliased\let\boldface \normalboldface
109\aliased\let\slantedface\normalslantedface
110\aliased\let\italicface \normalitalicface
111\aliased\let\swapface \swaptypeface
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\newconditional\c_font_emphasis_needed
156
157\permanent\protected\def\em
158 {\dontleavehmode
159
160 \ifdim\slantperpoint>\zeropoint
161 \c_font_emphasis_needed\conditionaltrue
162 \else
163 \c_font_emphasis_needed\conditionalfalse
164 \fi
165 \font_emphasis_set_emphasis_boldface
166 \ifx\fontalternative\s!it
167 \enforced\permanent\protected\def\emphasistypeface{\it}\tf
168 \orelse\ifx\fontalternative\s!sl
169 \enforced\permanent\protected\def\emphasistypeface{\sl}\tf
170 \orelse\ifx\fontalternative\s!bf
171 \emphasisboldface
172 \orelse\ifx\fontalternative\s!bs
173 \enforced\permanent\protected\def\emphasisboldface{\bs}\bf
174 \orelse\ifx\fontalternative\s!bi
175 \enforced\permanent\protected\def\emphasisboldface{\bi}\bf
176 \else
177 \emphasistypeface
178 \fi
179 \ifconditional\c_font_emphasis_needed\else
180 \expandafter\aftergroup
181 \fi
182 \emphasiscorrection}
183
184
185
186
187\let\font_emphasis_saved_emphasis_boldface\relax
188
189\def\font_emphasis_set_emphasis_boldface
190 {\let\font_emphasis_saved_emphasis_boldface\bf
191 \let\font_emphasis_set_emphasis_boldface\relax
192 \enforced\let\bf\font_emphasis_bold_bold}
193
194\protected\def\font_emphasis_bold_bold
195 {
196 \enforced\let\bf\relax
197 \ifx\fontalternative\s!it
198 \bi
199 \orelse\ifx\fontalternative\s!sl
200 \bs
201 \else
202 \font_emphasis_saved_emphasis_boldface
203 \fi
204 \enforced\let\bf\font_emphasis_saved_emphasis_boldface}
205
206
207
208
209
210\aliased\let\normalitaliccorrection\/
211
212\let\italiccorrection\normalitaliccorrection
213
214\permanent\protected\def\emphasiscorrection
215 {\ifhmode\ifnum\currentgrouptype=\aligngroupcode\else
216 \expandafter\expandafter\expandafter\font_emphasis_look
217 \fi\fi}
218
219\def\font_emphasis_look
220 {\begingroup
221 \futurelet\nexttoken\font_emphasis_test}
222
223\def\font_emphasis_test
224 {\ifcat\noexpand\nexttoken,
225 \expandafter\font_emphasis_a
226 \else
227 \expandafter\font_emphasis_b
228 \fi}
229
230\def\font_emphasis_a
231 {\futurelet\nexttoken\font_emphasis_correction}
232
233\def\font_emphasis_correction
234 {\setbox\scratchbox\hbox{\nexttoken}
235 \ifzeropt\ht\scratchbox
236 \expandafter\font_emphasis_b
237 \orelse\ifdim\ht\scratchbox<.3\exheight
238 \expandafter\expandafter\expandafter\endgroup
239 \else
240 \expandafter\expandafter\expandafter\font_emphasis_b
241 \fi}
242
243\def\font_emphasis_b
244 {\scratchskip\lastskip
245 \ifzeropt\scratchskip
246 \italiccorrection\relax
247 \else
248 \unskip\italiccorrection\hskip\scratchskip
249 \fi
250 \endgroup}
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291\permanent\protected\def\font_tf{\tf} \permanent\protected\def\font_bf{\bf}
292\permanent\protected\def\font_sl{\sl} \permanent\protected\def\font_bs{\bs}
293\permanent\protected\def\font_it{\it} \permanent\protected\def\font_bi{\bi}
294
295\protected\def\font_emphasis_bf{\bf
296 \enforced\aliased\let\emphit\font_bi
297 \enforced\aliased\let\emphsl\font_bs}
298\protected\def\font_emphasis_it{\it
299 \enforced\aliased\let\emphbf\font_bi
300 \enforced\aliased\let\emphsl\font_sl}
301\protected\def\font_emphasis_sl{\sl
302 \enforced\aliased\let\emphbf\font_bs
303 \enforced\aliased\let\emphit\font_it}
304\protected\def\font_emphasis_tf{\tf
305 \enforced\aliased\let\emphbf\font_bf
306 \enforced\aliased\let\emphit\font_it
307 \enforced\aliased\let\emphsl\font_sl}
308
309\permanent\protected\def\emphbf{\dontleavehmode\triggergroupedcommandcs\font_emphasis_bf}
310\permanent\protected\def\emphit{\dontleavehmode\triggergroupedcommandcs\font_emphasis_it}
311\permanent\protected\def\emphsl{\dontleavehmode\triggergroupedcommandcs\font_emphasis_sl}
312\permanent\protected\def\emphtf{\dontleavehmode\triggergroupedcommandcs\font_emphasis_tf}
313\permanent\protected\def\emph {\dontleavehmode\triggergroupedcommandcs\em}
314
315\permanent\protected\def\emphasized{\dontleavehmode\bgroup\em\let\nexttoken}
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331\protect \endinput
332 |