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\let\m_font_emphasized_typeface\empty
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 \else\ifx\m_font_emphasized_typeface\v!italic
48 #italic
49 \else\ifx\m_font_emphasized_typeface\empty
50 #slanted
51 \else
52 \csname\m_font_emphasized_typeface\endcsname
53 \fi\fi\fi}
54
55\unexpanded\def\emphasistypeface{\font_emphasis_checked_typeface\sl\it}
56\unexpanded\def\emphasisboldface{\font_emphasis_checked_typeface\bs\bi}
57
58\unexpanded\def\normalboldface
59 {\relax\ifx\fontalternative\s!it\bi
60 \else \ifx\fontalternative\s!sl\bs
61 \else \bf\fi\fi}
62
63\unexpanded\def\normalitalicface
64 {\relax\ifx\fontalternative\s!tf\it
65 \else \ifx\fontalternative\s!bf\bi
66 \else \tf\fi\fi}
67
68\unexpanded\def\normalslantedface
69 {\relax\ifx\fontalternative\s!tf\sl
70 \else \ifx\fontalternative\s!bf\bs
71 \else \tf\fi\fi}
72
73\unexpanded\def\normaltypeface
74 {\relax
75 \ifx\fontalternative\s!bi \it \else
76 \ifx\fontalternative\s!bs \sl \else
77 \tf \fi\fi}
78
79\unexpanded\def\swaptypeface
80 {\relax
81 \ifx\fontalternative\s!it \tf \else
82 \ifx\fontalternative\s!sl \tf \else
83 \ifx\fontalternative\s!bf \emphasisboldface \else
84 \ifx\fontalternative\s!bs \bf \else
85 \ifx\fontalternative\s!bi \bf \else
86 \emphasistypeface \fi\fi\fi\fi\fi}
87
88\let\typeface \normaltypeface
89\let\boldface \normalboldface
90\let\slantedface\normalslantedface
91\let\italicface \normalitalicface
92\let\swapface \swaptypeface
93
94
95
96
97
98
99\newconditional\c_font_emphasis_needed
100
101\unexpanded\def\em
102 {\relax
103 \ifdim\slantperpoint>\zeropoint
104 \settrue\c_font_emphasis_needed
105 \else
106 \setfalse\c_font_emphasis_needed
107 \fi
108 \font_emphasis_set_emphasis_boldface
109 \ifx\fontalternative\s!it
110 \unexpanded\def\emphasistypeface{\it}\tf
111 \else\ifx\fontalternative\s!sl
112 \unexpanded\def\emphasistypeface{\sl}\tf
113 \else\ifx\fontalternative\s!bf
114 \emphasisboldface
115 \else\ifx\fontalternative\s!bs
116 \unexpanded\def\emphasisboldface{\bs}\bf
117 \else\ifx\fontalternative\s!bi
118 \unexpanded\def\emphasisboldface{\bi}\bf
119 \else
120 \emphasistypeface
121 \fi\fi\fi\fi\fi
122 \ifconditional\c_font_emphasis_needed\else
123 \expandafter\aftergroup
124 \fi
125 \emphasiscorrection}
126
127
128
129
130\let\font_emphasis_saved_emphasis_boldface\relax
131
132\def\font_emphasis_set_emphasis_boldface
133 {\let\font_emphasis_saved_emphasis_boldface\bf
134 \let\font_emphasis_set_emphasis_boldface\relax
135 \let\bf\font_emphasis_bold_bold}
136
137\unexpanded\def\font_emphasis_bold_bold
138 {
139 \let\bf\relax
140 \ifx\fontalternative\s!it
141 \bi
142 \else\ifx\fontalternative\s!sl
143 \bs
144 \else
145 \font_emphasis_saved_emphasis_boldface
146 \fi\fi
147 \let\bf\font_emphasis_saved_emphasis_boldface}
148
149
150
151
152
153\let\italiccorrection=\/
154
155\def\emphasiscorrection
156 {\ifhmode\ifnum\currentgrouptype=\aligngroupcode\else
157 \expandafter\expandafter\expandafter\font_emphasis_look
158 \fi\fi}
159
160\def\font_emphasis_look
161 {\begingroup
162 \futurelet\nexttoken\font_emphasis_test}
163
164\def\font_emphasis_test
165 {\ifcat\noexpand\nexttoken,
166 \expandafter\font_emphasis_a
167 \else
168 \expandafter\font_emphasis_b
169 \fi}
170
171\def\font_emphasis_a
172 {\futurelet\nexttoken\font_emphasis_correction}
173
174\def\font_emphasis_correction
175 {\setbox\scratchbox\hbox{\nexttoken}
176 \ifzeropt\ht\scratchbox
177 \expandafter\font_emphasis_b
178 \else\ifdim\ht\scratchbox<.3\exheight
179 \expandafter\expandafter\expandafter\endgroup
180 \else
181 \expandafter\expandafter\expandafter\font_emphasis_b
182 \fi\fi}
183
184\def\font_emphasis_b
185 {\scratchskip\lastskip
186 \ifzeropt\scratchskip
187 \italiccorrection\relax
188 \else
189 \unskip\italiccorrection\hskip\scratchskip
190 \fi
191 \endgroup}
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231\unexpanded\def\font_emphasis_bf{\bf\def\emphit{\bi}\def\emphsl{\bs}}
232\unexpanded\def\font_emphasis_it{\it\def\emphbf{\bi}\def\emphsl{\sl}}
233\unexpanded\def\font_emphasis_sl{\sl\def\emphbf{\bs}\def\emphit{\it}}
234\unexpanded\def\font_emphasis_tf{\tf\def\emphbf{\bf}\def\emphit{\it}\def\emphsl{\sl}}
235
236\unexpanded\def\emphbf{\triggergroupedcommandcs\font_emphasis_bf}
237\unexpanded\def\emphit{\triggergroupedcommandcs\font_emphasis_it}
238\unexpanded\def\emphsl{\triggergroupedcommandcs\font_emphasis_sl}
239\unexpanded\def\emphtf{\triggergroupedcommandcs\font_emphasis_tf}
240\unexpanded\def\emph {\triggergroupedcommandcs\em}
241
242\unexpanded\def\emphasized{\bgroup\em\let\nexttoken}
243
244
245
246
247
248
249
250
251
252
253
254\protect \endinput
255 |