-
Notifications
You must be signed in to change notification settings - Fork 15
/
relsize.sty
397 lines (349 loc) · 15.2 KB
/
relsize.sty
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
184
185
186
187
188
189
190
191
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
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
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
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
% relsize.sty 4.1 Mar 29, 2013
%
% Setting the font size relative to the current size
%
% Authored by Donald Arseneau <[email protected]> and Matt Swift <[email protected]>.
% (Inspired by smaller.sty author Bernie Cosell)
%
% This software is contributed to the public domain by its authors, who disclaim
% all copyrights. For people and jurisdictions that do not recognize contribution
% to the public domain, this software is licensed by the terms of the unlicense,
% <http://unlicense.org/>
%
% commands are:
% \relsize{n} where n gives the number of steps ("mag-step" = factor of 1.2)
% to change the size by; n = 3 changes from \normalsize to
% \LARGE size. Negative n selects smaller fonts. n is an
% integer (or half-integer).
%
% \smaller = \relsize{-1}, \smaller[n] = \relsize{-n}
% \larger = \relsize{1}, \larger[n] = \relsize{n}
%
% \textsmaller{text}, \textlarger{text} - versions that take an argument
%
% \relscale{f} like \relsize, but instead of scale-steps,
% the parameter is a scale factor, such as .75
% \textscale{f}{text}
%
% The font-size command nearest the requested size will be used, and if
% the size error is more than \RSpercentTolerance, then the size will
% be adjusted more precisely using \fontsize. (The default empty
% \RSpercentTolerance signals automatic handling, choosing the tolerance
% based on the font declarations.)
%
% \mathsmaller{A}, \mathlarger{B} - math versions
% (The math versions are entirely different from the text versions.)
%
% More comments at the end of this file, and full documentation in
% relsize-doc.pdf
\ProvidesPackage{relsize}[2013/03/29 ver 4.1]
\DeclareRobustCommand\relsize[1]{%
\ifmmode \@nomath\relsize\else
\begingroup
% number of demi-magsteps -> \@tempcnta
\@tempdima#1\p@ \@tempdima2.0002\@tempdima \divide\@tempdima\p@
\@tempcnta\@tempdima
% \message{^^JChange \the\@tempcnta\space half-magsteps from \f@size. }%
% calculate desired target size -> \@tempdimb
\@tempdimb\f@size\p@
\ifnum\@tempcnta<\z@
\def\@tempa{.912871}\@tempcnta=-\@tempcnta
\else
\def\@tempa{1.09545}%
\fi
\@whilenum {\@tempcnta>\z@}\do {%
\advance\@tempcnta\m@ne
\@tempdimb\@tempa\@tempdimb}%
% \message{ target size \the\@tempdimb. }%
\rs@scaleToB
\fi}
\DeclareRobustCommand\relscale[1]{%
\ifmmode \@nomath\relscale\else
\begingroup
\@tempdimb\f@size\p@ \@tempdimb#1\@tempdimb
\rs@scaleToB
\fi}
\DeclareRobustCommand\textscale[2]{\leavevmode
\begingroup\relscale{#1}#2\endgroup}
% Change font size to \@tempdimb. Follows from \relsize or \relscale
\def\rs@scaleToB{%
%\message{Change font size from \f@size\space to \the\@tempdimb. }%
% perform automatic tolerance adjustment, if requested
\ifx\RSpercentTolerance\@empty \rs@autoTol \fi
% apply limits
\ifdim\@tempdimb<\RSsmallest
\rs@size@warning{\the\@tempdimb}{small}{\RSsmallest}%
\@tempdimb=\RSsmallest
\fi
\ifdim\@tempdimb>\RSlargest
\rs@size@warning{\the\@tempdimb}{large}{\RSlargest}%
\@tempdimb=\RSlargest
\fi
% Look up that size in list of pre-defined sizes. Put error of
% closest match in \@tempdima
\def\@tempa{\relax}\@tempdima-\@m\p@
\let\rs@size\rs@lookup \rs@fontsizes
%\message{Look up best as \expandafter\string\@tempa, off by \the\@tempdima}%
% See how close match was (abs difference -> \@tempdima)
\ifdim\@tempdima<\z@ \@tempdima-\@tempdima\fi
% ... percentage error in \@tempdima (as a count)
% (messiness to prevent numeric overflows)
\ifdim\@tempdima<160\p@ \@tempdima 100\@tempdima
\ifdim\@tempdimb>\p@ \divide\@tempdima\@tempdimb \fi
%\message{or \number\@tempdima \@percentchar. }%
\fi
% if error is beyond tolerance, append \fontsize adjustment.
\ifnum\@tempdima>\RSpercentTolerance
%\message{Adjust size to \strip@pt\@tempdimb. }%
\@tempdima1.2\@tempdimb % baselineskip (could be improved)
\edef\@tempa{\expandafter\noexpand\@tempa \noexpand\fontsize
{\strip@pt\@tempdimb}{\strip@pt\@tempdima}\noexpand\selectfont}\fi
% Now execute size-change command \@tempa
\expandafter\endgroup\@tempa
%\message{Font size is now \f@size. }%
}
% For each defined font size, compare its actual size to the desired
% size (\@tempdimb) and the error of the best previous match (\@tempdima).
% Record this command (\@tempa) if it is closer.
\def\rs@lookup#1#2{% #1=command #2=size
\begingroup
\advance\@tempdimb-#2\relax
\ifdim\@absVal\@tempdimb<\@absVal\@tempdima % improvement
\endgroup
\def\@tempa{#1}%
\@tempdima#2\relax \advance\@tempdima-\@tempdimb
\else
\endgroup
\fi}
\def\@absVal#1{\ifnum#1<\z@-\fi#1}
% Tolerance for size mis-match (%). The empty definition triggers
% automatic selection: 5 for scalable fonts, 30 otherwise.
\def\rs@autoTol{%
\expandafter\expandafter\expandafter\rs@autoTOL
\expandafter\meaning
\csname\f@encoding/\f@family/\f@series/\f@shape\endcsname-\delimiter
}
\def\rs@autoTOL#1>#2-#3\delimiter{%
\ifx\delimiter#3\delimiter % no -
\def\RSpercentTolerance{30}%
\else % font size def has -, assume it covers continuum
\def\RSpercentTolerance{5}%
\fi
% \message{ Automatic tolerance is \RSpercentTolerance. }%
}
% Warning messages
\newcommand\rs@size@warning[3]{\PackageWarning{relsize}{%
Font size #1 is too #2.\MessageBreak Using #3 instead}}
% derived commands
\DeclareRobustCommand\larger[1][\@ne]{\relsize{+#1}}
\DeclareRobustCommand\smaller[1][\@ne]{\relsize{-#1}}
\DeclareRobustCommand\textlarger[2][\@ne]{\leavevmode{\relsize{+#1}#2}}
\DeclareRobustCommand\textsmaller[2][\@ne]{\leavevmode{\relsize{-#1}#2}}
% Some initializations.
% Default empty definition triggers auto-tolerance.
% Beware that \providecommand makes \long macro that fails to trigger.
\def\RSpercentTolerance{}
% The next two aren't the real initializations! The real ones are done
% in \@tempb below. The user can change them afterwards.
\def\RSsmallest{999pt}
\def\RSlargest{1pt}
% Right now we assemble a list of the font sizes
\def\rs@size{\noexpand\rs@size\noexpand}
\def\rs@fontsizes{}
\def\@tempa#1{\ifx\@undefined#1\else
\expandafter\@tempb#1\@empty\relax\relax\delimiter{#1}\fi}
% parse definition of font-size command (like \large)
% #1 = \@setfontsize #2 = the command (\large) #3 = size #4 = rest
\def\@tempb#1#2#3#4\delimiter#5{%
\def\@tempc{\protect !\@empty}\def\@tempd{#1!#3}%
\ifx\@tempc\@tempd % self-protected: recurse.
\expandafter\@tempb#2\@empty\relax\relax\delimiter{#5}%
\else
\@tempdimb\z@
\def\@tempc{\@setfontsize !#5}\def\@tempd{#1!#2}%
\ifx\@tempc\@tempd % Normal LaTeX2e
\afterassignment\strip@prefix \@tempdimb #3pt>%
\else
\def\@tempc{\@xsetfontsize !#5}\def\@tempd{#1!#2}%
\ifx\@tempc\@tempd % AMS (defines \@xp=\expandafter. Note: they have their own \larger/\smaller)
\chardef\@currsizeindex#3\relax
\edef\@tempc{\@xp\ifcase\@xp\@currsizeindex\@typesizes\fi}%
\afterassignment\strip@prefix \@tempdimb \@xp\@firstoftwo\@tempc pt>%
\else
\def\@tempc{\@setsize !#5}\def\@tempd{#1!#2}%
\ifx\@tempc\@tempd % 2.09 style
\afterassignment\strip@prefix \@tempdimb #3pt>%
\else
\def\@tempc{\slide@setsize !#5}\def\@tempd{#1!#2}%
\ifx\@tempc\@tempd % seminar
\afterassignment\strip@prefix \@tempdimb #3pt>%
\else
\def\@tempc{\fontsize}\def\@tempd{#1}%
\ifx\@tempc\@tempd % simple
\afterassignment\strip@prefix \@tempdimb #2pt>%
\else
%\message{Could not parse meaning of \string#5. }%
\fi\fi\fi\fi\fi
% Checked 5 possible definitions
\ifdim\@tempdimb=\z@ % Failed to parse size from definition
\else % Take note of this size.
\edef\rs@fontsizes{\rs@fontsizes\rs@size#5{\the\@tempdimb}}%
\ifdim\@tempdimb<\RSsmallest \edef\RSsmallest{\the\@tempdimb}\fi
\ifdim\@tempdimb>\RSlargest \edef\RSlargest{\the\@tempdimb}\fi
%\message{\string#5 has size \the\@tempdimb. ^^J}%
\fi
\fi
}
% examine each (expected) pre-defined font size
\@tempa\normalsize
\@tempa\small
\@tempa\footnotesize
\@tempa\large
\@tempa\Large
\@tempa\LARGE
\@tempa\scriptsize
\@tempa\tiny
\@tempa\huge
\@tempa\Huge
% moresize.sty
\@tempa\HUGE
\@tempa\ssmall
% beamer
\@tempa\Tiny
\@tempa\TINY
% AMS classes
\@tempa\SMALL
\@tempa\Small
%\show\rs@fontsizes
% Check that we recorded sizes for at least two font-size commands.
% Value of \RSpercentTolerance is both a setting and a flag
\ifx\rs@fontsizes\@empty
\def\RSpercentTolerance{0}%
\else\ifdim\RSsmallest<\RSlargest\else
\def\RSpercentTolerance{3}%
\fi\fi
\ifx\RSpercentTolerance\@empty \else
\PackageWarningNoLine{relsize}
{Failed to get list of defined font sizes.\MessageBreak
Size scaling will attempt arbitrary sizes.}
\def\RSsmallest{\p@}%
\def\RSlargest{100pt}%
\fi
%
% Math commands (completely different)
\DeclareRobustCommand\mathsmaller[1]{\bgroup
\let\rs@makechoice\rs@makesmallerchoice
\def\rs@mathatom{#1}%
\futurelet\@tempa\rs@collect@decor
}
\DeclareRobustCommand\mathlarger[1]{\bgroup
\let\rs@makechoice\rs@makelargerchoice
\def\rs@mathatom{#1}%
\futurelet\@tempa\rs@collect@decor
}
% Collect the tokens that 'decorate' the atom, to apply them directly on the
% symbol, not after the closing brace.
% Math so far is in \rs@mathatom; next tok is \@tempa; continuation is \@tempb
% Don't nest \ifs because token may be \if or \fi or \or...
\def\rs@collect@decor{%
\let\@tempb\rs@makechoice
\ifx\@tempa\limits \let\@tempb\rs@collect@one@decor \fi
\ifx\@tempa\displaylimits \let\@tempb\rs@collect@one@decor \fi
\ifx\@tempa\nolimits \let\@tempb\rs@collect@one@decor \fi
\if\noexpand\@tempa^\let\@tempb\rs@collect@two@decor \fi
\if\noexpand\@tempa_\let\@tempb\rs@collect@two@decor \fi
\ifx\@tempa\sp \let\@tempb\rs@collect@two@decor \fi
\ifx\@tempa\sb \let\@tempb\rs@collect@two@decor \fi
\@tempb}
\def\rs@collect@one@decor#1{%
\expandafter\def\expandafter\rs@mathatom\expandafter{\rs@mathatom#1}%
\futurelet\@tempa\rs@collect@decor}
\def\rs@collect@two@decor#1#2{\expandafter
\def\expandafter\rs@mathatom\expandafter{\rs@mathatom#1{\rs@sstyle{#2}}}%
\futurelet\@tempa\rs@collect@decor}
\let\rs@sstyle\@firstofone
\def\rs@makesmallerchoice{\mathchoice
{\textstyle \let\rs@sstyle\scriptstyle \rs@mathatom}%
{\scriptstyle \let\rs@sstyle\scriptstyle \rs@mathatom}%
{\scriptscriptstyle \let\rs@sstyle\scriptscriptstyle \rs@mathatom}%
{\scriptscriptstyle \let\rs@sstyle\scriptscriptstyle \rs@mathatom}%
\egroup}
\def\rs@makelargerchoice{\mathchoice
{\protected@edef\rs@sstyle##1{%
\protect\set@fontsize {1}{\f@size}{\f@baselineskip}\protect\selectfont
\hbox{$\scriptstyle ##1\m@th$}}%
\mbox{\larger$\displaystyle\rs@mathatom\m@th$}}%
{\displaystyle \let\rs@sstyle\scriptstyle \rs@mathatom}%
{\textstyle \let\rs@sstyle\scriptscriptstyle \rs@mathatom}%
{\scriptstyle \let\rs@sstyle\scriptscriptstyle \rs@mathatom}%
\egroup}
\endinput
==========================================================
R E L S I Z E . S T Y ver 4.1 Mar 29, 2013
by Donald Arseneau, [email protected], Vancouver, Canada
originally based on smaller.sty by Bernie Cosell,
and combined with the version by Matt Swift, [email protected].
It is frequently the case that something should be typeset somewhat larger
or smaller than the surrounding text, whatever that size happens to be.
Specifying such sizing commands explicitly makes it difficult to modify the
font sizes of a document at a later time, and makes it hard to write macros
that work at arbitrary sizes. Relsize.sty defines several commands for LaTeX
to set font sizes relative to the current size.
For i being an integer (or half-integer) magstep increment (like 2),
and optional arg [i] defaulting to i=1,
And f being a scale factor (like 0.75)
And text being the text argument
\relsize{i} ungrouped size change by i steps
\larger[i] ungrouped size change by (optional) i steps
\smaller[i] ungrouped size change by (optional) -i steps
\relscale{f} ungrouped size change by scale factor f
\textlarger[i]{text} "text" size enlarged by i steps
\textsmaller[i]{text} "text" size reduced by i steps
\textscale{f}{text} "text" sized scaled by factor f
If the size requested is too small or too large, a warning is given, and
the size will only change as far as appropriate, typically \tiny or \Huge.
These limits are controlled by the commands \RSsmallest and \RSlargest, which
get set automatically when relsize.sty is loaded, but you can redefine them
to other length values: \renewcommand\RSlargest{50pt}.
Fine point: The combination \relsize{n}\relsize{-n} is not guaranteed to
restore the current font size!
Typically, the font-size commands do not select fonts at regular size
intervals. \relsize (and the others) will select, and execute, the command
for the size closest to the desired size. Then, if the relative difference
from the target size is more than \RSpercentTolerance a further font-size
selection is made. By default, \RSpercentTolerance is an empty macro, which
causes automatic selection: "30" (30%) when the current "fontshape" definition
is composed of only discrete sizes, and "5" when the fontshape definition
covers ranges of sizes. The higher setting for discrete fonts ensures
only the pre-defined sizes get used. (By default LaTeX uses Computer
Modern fonts at discrete sizes; you get full coverage of sizes by using
\usepackage{type1cm} or various other font packages.) For special uses,
or when the font shape definitions are not parsed properly, you can redefine
the percent tolerance:
\renewcommand\RSpercentTolerance{10}.
All of the commands described above are text commands; they cannot be used
in math mode. There are special \mathsmaller and \mathlarger commands
provided, but these do not use the same sizes that the text versions use.
Instead, they step between the usual math "styles" which you can explicitly
set using the commands \displaystyle, \textstyle, \scriptstyle, and
\scriptscriptstyle [see Lamport, LaTeX/Manual (1st ed, p.54); GMS The LaTeX
Companion, p.255]. However, the \mathlarger command will also increase the
size beyond regular \displaystyle by selecting a larger regular font size
(using \larger). (Yes, this is a kludge, and doesn't work very well, but
it can still be useful.) If you want to use this to create big integral
signs, then you must also load the package "exscale" so that math symbols
can change size. The sizes selected are:
Current style \mathsmaller gives \mathlarger gives
--------------- ---------------------- ------------------------
\displaystyle \textstyle (almost same) \displaystyle in a \larger font
\textstyle \scriptstyle \displaystyle (almost same)
\scriptstyle \scriptscriptstyle \textstyle
\scriptscriptstyle \scriptscriptstyle (same) \scriptstyle
These commands will attempt to attach superscripts and subscripts to the
symbol as if the symbol were used alone, but math accents and the math
spacing behave as if the symbol is enclosed in braces (which it is).
Operators should be explicitly declared to use the right operator
type (\mathrel, \mathbin, \mathop) to get the correct spacing.
Due to their oddities, the math larger/smaller commands should not be
trusted blindly, and they will not be useful in every instance.
Donald Arseneau [email protected]