1 % fancyhdr.sty version 1.99d
2 % Fancy headers and footers for LaTeX.
3 % Piet van Oostrum, Dept of Computer Science, University of Utrecht
4 % Padualaan 14, P.O. Box 80.089, 3508 TB Utrecht, The Netherlands
5 % Telephone: +31 30 2532180. Email: piet@cs.ruu.nl
6 % ========================================================================
7 % LICENCE: This is free software. You are allowed to use and distribute
8 % this software in any way you like. You are also allowed to make modified
9 % versions of it, but you can distribute a modified version only if you
10 % clearly indicate that it is a modified version and the person(s) who
11 % modified it. This indication should be in a prominent place, e.g. in the
12 % top of the file. If possible a contact address, preferably by email,
13 % should be given for these persons. If that is feasible the modifications
14 % should be indicated in the source code.
15 % ========================================================================
16 % MODIFICATION HISTORY:
18 % version 1.4: Correction for use with \reversemargin
20 % version 1.5: Added the \iftopfloat, \ifbotfloat and \iffloatpage commands
22 % version 1.6: Reset single spacing in headers/footers for use with
23 % setspace.sty or doublespace.sty
25 % version 1.7: changed \let\@mkboth\markboth to
26 % \def\@mkboth{\protect\markboth} to make it more robust
28 % version 1.8: corrections for amsbook/amsart: define \@chapapp and (more
29 % importantly) use the \chapter/sectionmark definitions from ps@headings if
30 % they exist (which should be true for all standard classes).
32 % version 1.9: The proposed \renewcommand{\headrulewidth}{\iffloatpage...
33 % construction in the doc did not work properly with the fancyplain style.
35 % version 1.91: The definition of \@mkboth wasn't restored on subsequent
36 % \pagestyle{fancy}'s.
38 % version 1.92: The sequence \pagestyle{fancyplain} \pagestyle{plain}
39 % \pagestyle{fancy} would erroneously select the plain version.
41 % version 1.93: \fancypagestyle command added.
43 % version 1.94: suggested by Conrad Hughes <chughes@maths.tcd.ie>
44 % CJCH, Dec 11, 1995: added \footruleskip to allow control over footrule
45 % position (old hardcoded value of .3\normalbaselineskip is far too high
46 % when used with very small footer fonts).
48 % version 1.95: call \@normalsize in the reset code if that is defined,
49 % otherwise \normalsize.
50 % this is to solve a problem with ucthesis.cls, as this doesn't
51 % define \@currsize. Unfortunately for latex209 calling \normalsize doesn't
52 % work as this is optimized to do very little, so there \@normalsize should
53 % be called. Hopefully this code works for all versions of LaTeX known to
56 % version 1.96: initialize \headwidth to a magic (negative) value to catch
57 % most common cases that people change it before calling \pagestyle{fancy}.
58 % Note it can't be initialized when reading in this file, because
59 % \textwidth could be changed afterwards. This is quite probable.
60 % We also switch to \MakeUppercase rather than \uppercase and introduce a
61 % \nouppercase command for use in headers. and footers.
63 % version 1.97: Two changes:
64 % 1. Undo the change in version 1.8 (using the pagestyle{headings} defaults
65 % for the chapter and section marks. The current version of amsbook and
66 % amsart classes don't seem to need them anymore. Moreover the standard
67 % latex classes don't use \markboth if twoside isn't selected, and this is
68 % confusing as \leftmark doesn't work as expected.
69 % 2. include a call to \ps@empty in ps@@fancy. This is to solve a problem
70 % in the amsbook and amsart classes, that make global changes to \topskip,
71 % which are reset in \ps@empty. Hopefully this doesn't break other things.
74 % Added % after the line \def\nouppercase
76 % version 1.99: This is the alpha version of fancyhdr 2.0
77 % Introduced the new commands \fancyhead, \fancyfoot, and \fancyhf.
78 % Changed \headrulewidth, \footrulewidth, \footruleskip to
79 % macros rather than length parameters, In this way they can be
80 % conditionalized and they don't consume length registers. There is no need
81 % to have them as length registers unless you want to do calculations with
82 % them, which is unlikely. Note that this may make some uses of them
83 % incompatible (i.e. if you have a file that uses \setlength or \xxxx=)
86 % Added a few more % signs
89 % Changed the syntax of \f@nfor to be resistent to catcode changes of :=
90 % Removed the [1] from the defs of \lhead etc. because the parameter is
91 % consumed by the \@[xy]lhead etc. macros.
94 % corrected \nouppercase to also include the protected form of \MakeUppercase
95 % \global added to manipulation of \headwidth.
96 % \iffootnote command added.
97 % Some comments added about \@fancyhead and \@fancyfoot.
100 % Changed the default \ps@empty to \ps@@empty in order to allow
101 % \fancypagestyle{empty} redefinition.
105 \def\if@mpty
#1#2#3{\def\temp@ty
{#1}\ifx\@empty
\temp@ty
#2\else#3\fi}
107 % Usage: \@forc \var{charstring}{command to be executed for each char}
108 % This is similar to LaTeX's \@tfor, but expands the charstring.
110 \def\@forc
#1#2#3{\expandafter\f@rc
\expandafter#1\expandafter{#2}{#3}}
111 \def\f@rc
#1#2#3{\def\temp@ty
{#2}\ifx\@empty
\temp@ty
\else
112 \f@@rc
#1#2\f@@rc
{#3}\fi}
113 \def\f@@rc
#1#2#3\f@@rc
#4{\def#1{#2}#4\f@rc
#1{#3}{#4}}
115 % Usage: \f@nfor\name:=list\do{body}
116 % Like LaTeX's \@for but an empty list is treated as a list with an empty
119 \newcommand{\f@nfor
}[3]{\edef\@fortmp
{#2}%
120 \expandafter\@forloop
#2,\@nil,\@nil\@@
#1{#3}}
122 % Usage: \def@ult \cs{defaults}{argument}
123 % sets \cs to the characters from defaults appearing in argument
124 % or defaults if it would be empty. All characters are lowercased.
126 \newcommand\def@ult
[3]{%
127 \edef\temp@a
{\lowercase{\edef\noexpand\temp@a
{#3}}}\temp@a
130 {\expandafter\if@in
\tmpf@ra
\temp@a
{\edef#1{#1\tmpf@ra
}}{}}%
131 \ifx\@empty
#1\def#1{#2}\fi}
133 % \if@in <char><set><truecase><falsecase>
135 \newcommand{\if@in
}[4]{%
136 \edef\temp@a
{#2}\def\temp@b#
#1#1#
#2\temp@b
{\def\temp@b
{#
#1}}%
137 \expandafter\temp@b
#2#1\temp@b
\ifx\temp@a
\temp@b
#4\else #3\fi}
139 \newcommand{\fancyhead}{\@ifnextchar
[{\f@ncyhf h
}{\f@ncyhf h
[]}}
140 \newcommand{\fancyfoot}{\@ifnextchar
[{\f@ncyhf f
}{\f@ncyhf f
[]}}
141 \newcommand{\fancyhf}{\@ifnextchar
[{\f@ncyhf
{}}{\f@ncyhf
{}[]}}
143 % The header and footer fields are stored in command sequences with
144 % names of the form: \f@ncy<x><y><z> with <x> for [eo], <y> form [lcr]
147 \def\f@ncyhf
#1[#2]#3{%
150 {\expandafter\if@in
\tmpf@ra
{eolcrhf,EOLCRHF
}%
151 {}{\edef\temp@c
{\temp@c
\tmpf@ra
}}}%
152 \ifx\@empty
\temp@c
\else
153 \ifx\PackageError\undefined
154 \errmessage{Illegal char `
\temp@c' in fancyhdr argument:
156 \PackageError{Fancyhdr
}{Illegal char `
\temp@c' in fancyhdr argument:
160 {\def@ult
\f@@@eo
{eo
}\temp@c
161 \def@ult
\f@@@lcr
{lcr
}\temp@c
162 \def@ult
\f@@@hf
{hf
}{#1\temp@c
}%
164 {\@forc
\f@@lcr
\f@@@lcr
166 {\expandafter\fancy@def
\csname
167 f@ncy
\f@@eo
\f@@lcr
\f@@hf
\endcsname
170 % Fancyheadings version 1 commands. These are more or less deprecated,
171 % but they continue to work.
173 \newcommand{\lhead}{\@ifnextchar
[{\@xlhead
}{\@ylhead
}}
174 \def\@xlhead
[#1]#2{\fancy@def
\f@ncyelh
{#1}\fancy@def
\f@ncyolh
{#2}}
175 \def\@ylhead
#1{\fancy@def
\f@ncyelh
{#1}\fancy@def
\f@ncyolh
{#1}}
177 \newcommand{\chead}{\@ifnextchar
[{\@xchead
}{\@ychead
}}
178 \def\@xchead
[#1]#2{\fancy@def
\f@ncyech
{#1}\fancy@def
\f@ncyoch
{#2}}
179 \def\@ychead
#1{\fancy@def
\f@ncyech
{#1}\fancy@def
\f@ncyoch
{#1}}
181 \newcommand{\rhead}{\@ifnextchar
[{\@xrhead
}{\@yrhead
}}
182 \def\@xrhead
[#1]#2{\fancy@def
\f@ncyerh
{#1}\fancy@def
\f@ncyorh
{#2}}
183 \def\@yrhead
#1{\fancy@def
\f@ncyerh
{#1}\fancy@def
\f@ncyorh
{#1}}
185 \newcommand{\lfoot}{\@ifnextchar
[{\@xlfoot
}{\@ylfoot
}}
186 \def\@xlfoot
[#1]#2{\fancy@def
\f@ncyelf
{#1}\fancy@def
\f@ncyolf
{#2}}
187 \def\@ylfoot
#1{\fancy@def
\f@ncyelf
{#1}\fancy@def
\f@ncyolf
{#1}}
189 \newcommand{\cfoot}{\@ifnextchar
[{\@xcfoot
}{\@ycfoot
}}
190 \def\@xcfoot
[#1]#2{\fancy@def
\f@ncyecf
{#1}\fancy@def
\f@ncyocf
{#2}}
191 \def\@ycfoot
#1{\fancy@def
\f@ncyecf
{#1}\fancy@def
\f@ncyocf
{#1}}
193 \newcommand{\rfoot}{\@ifnextchar
[{\@xrfoot
}{\@yrfoot
}}
194 \def\@xrfoot
[#1]#2{\fancy@def
\f@ncyerf
{#1}\fancy@def
\f@ncyorf
{#2}}
195 \def\@yrfoot
#1{\fancy@def
\f@ncyerf
{#1}\fancy@def
\f@ncyorf
{#1}}
198 \newcommand{\headrulewidth}{0.4pt
}
199 \newcommand{\footrulewidth}{\z@skip
}
200 \newcommand{\footruleskip}{.3\normalbaselineskip}
202 % Fancyplain stuff shouldn't be used anymore (rather
203 % \fancypagestyle{plain} should be used), but it must be present for
204 % compatibility reasons.
206 \newcommand{\plainheadrulewidth}{\z@skip
}
207 \newcommand{\plainfootrulewidth}{\z@skip
}
208 \newif\if@fancyplain \@fancyplainfalse
209 \def\fancyplain#1#2{\if@fancyplain
#1\else#2\fi}
211 \headwidth=-
123456789sp
%magic constant
213 % Command to reset various things in the headers:
214 % a.o. single spacing (taken from setspace.sty)
215 % and the catcode of ^^M (so that epsf files in the header work if a
216 % verbatim crosses a page boundary)
217 % It also defines a \nouppercase command that disables \uppercase and
218 % \Makeuppercase. It can only be used in the headers and footers.
219 \def\fancy@reset
{\restorecr
220 \def\baselinestretch{1}%
221 \def\nouppercase#
#1{{\let\uppercase\relax\let\MakeUppercase\relax
222 \expandafter\let\csname MakeUppercase
\endcsname\relax#
#1}}%
223 \ifx\undefined\@newbaseline
% NFSS not present; 2.09 or 2e
224 \ifx\@normalsize
\undefined \normalsize % for ucthesis.cls
225 \else \@normalsize
\fi
226 \else% NFSS (2.09) present
230 % Initialization of the head and foot text.
232 % The default values still contain \fancyplain for compatibility.
233 \fancyhf{} % clear all
234 % lefthead empty on ``plain'' pages, \rightmark on even, \leftmark on odd pages
235 % evenhead empty on ``plain'' pages, \leftmark on even, \rightmark on odd pages
236 \fancyhead[el,or
]{\fancyplain{}{\sl\rightmark}}
237 \fancyhead[er,ol
]{\fancyplain{}{\sl\leftmark}}
238 \fancyfoot[c
]{\rm\thepage} % page number
240 % Put together a header or footer given the left, center and
241 % right text, fillers at left and right and a rule.
242 % The \lap commands put the text into an hbox of zero size,
243 % so overlapping text does not generate an errormessage.
244 % These macros have 5 parameters:
245 % 1. \@lodd or \@rodd % This determines at which side the header will stick
247 % 2. \f@ncyolh, \f@ncyelh, \f@ncyolf or \f@ncyelf. This is the left component.
248 % 3. \f@ncyoch, \f@ncyech, \f@ncyocf or \f@ncyecf. This is the middle comp.
249 % 4. \f@ncyorh, \f@ncyerh, \f@ncyorf or \f@ncyerf. This is the right component.
250 % 5. \@lodd or \@rodd % This determines at which side the header will stick
251 % out. This is the reverse of parameter nr. 1. One of them is always
252 % \relax and the other one is \hss (after expansion).
254 \def\@fancyhead
#1#2#3#4#5{#1\hbox to
\headwidth{\fancy@reset
\vbox{\hbox
255 {\rlap{\parbox[b
]{\headwidth}{\raggedright#2\strut}}\hfill
256 \parbox[b
]{\headwidth}{\centering#3\strut}\hfill
257 \llap{\parbox[b
]{\headwidth}{\raggedleft#4\strut}}}\headrule}}#5}
259 \def\@fancyfoot
#1#2#3#4#5{#1\hbox to
\headwidth{\fancy@reset
\vbox{\footrule
260 \hbox{\rlap{\parbox[t
]{\headwidth}{\raggedright#2\strut}}\hfill
261 \parbox[t
]{\headwidth}{\centering#3\strut}\hfill
262 \llap{\parbox[t
]{\headwidth}{\raggedleft#4\strut}}}}}#5}
264 \def\headrule{{\if@fancyplain
\let\headrulewidth\plainheadrulewidth\fi
265 \hrule\@height
\headrulewidth\@width
\headwidth \vskip-
\headrulewidth}}
267 \def\footrule{{\if@fancyplain
\let\footrulewidth\plainfootrulewidth\fi
268 \vskip-
\footruleskip\vskip-
\footrulewidth
269 \hrule\@width
\headwidth\@height
\footrulewidth\vskip\footruleskip}}
272 \@ifundefined
{@chapapp
}{\let\@chapapp
\chaptername}{}%for amsbook
274 % Define \MakeUppercase for old LaTeXen.
275 % Note: we used \def rather than \let, so that \let\uppercase\relax (from
276 % the version 1 documentation) will still work.
278 \@ifundefined
{MakeUppercase
}{\def\MakeUppercase{\uppercase}}{}%
279 \@ifundefined
{chapter
}{\def\sectionmark#
#1{\markboth
280 {\MakeUppercase{\ifnum \c@secnumdepth>
\z@
281 \thesection\hskip 1em
\relax \fi #
#1}}{}}%
282 \def\subsectionmark#
#1{\markright {\ifnum \c@secnumdepth >\@ne
283 \thesubsection\hskip 1em
\relax \fi #
#1}}}%
284 {\def\chaptermark#
#1{\markboth {\MakeUppercase{\ifnum \c@secnumdepth>
\m@ne
285 \@chapapp\
\thechapter. \
\fi #
#1}}{}}%
286 \def\sectionmark#
#1{\markright{\MakeUppercase{\ifnum \c@secnumdepth >
\z@
287 \thesection. \
\fi #
#1}}}}%
288 %\csname ps@headings\endcsname % use \ps@headings defaults if they exist
290 \gdef\ps@fancy
{\@fancyplainfalse
\ps@@fancy
}%
291 % Initialize \headwidth if the user didn't
295 % This catches the case that \headwidth hasn't been initialized and the
296 % case that the user added something to \headwidth in the expectation that
297 % it was initialized to \textwidth. We compensate this now. This loses if
298 % the user intended to multiply it by a factor. But that case is more
299 % likely done by saying something like \headwidth=1.2\textwidth.
300 % The doc says you have to change \headwidth after the first call to
301 % \pagestyle{fancy}. This code is just to catch the most common cases were
302 % that requirement is violated.
304 \global\advance\headwidth123456789sp\global\advance\headwidth\textwidth
306 \def\ps@fancyplain
{\ps@fancy
\let\ps@plain
\ps@plain@fancy
}
307 \def\ps@plain@fancy
{\@fancyplaintrue
\ps@@fancy
}
308 \let\ps@@empty
\ps@empty
310 \ps@@empty
% This is for amsbook/amsart, which do strange things with \topskip
311 \def\@mkboth
{\protect\markboth}%
312 \def\@oddhead
{\@fancyhead\@lodd
\f@ncyolh
\f@ncyoch
\f@ncyorh\@rodd
}%
313 \def\@oddfoot
{\@fancyfoot\@lodd
\f@ncyolf
\f@ncyocf
\f@ncyorf\@rodd
}%
314 \def\@evenhead
{\@fancyhead\@rodd
\f@ncyelh
\f@ncyech
\f@ncyerh\@lodd
}%
315 \def\@evenfoot
{\@fancyfoot\@rodd
\f@ncyelf
\f@ncyecf
\f@ncyerf\@lodd
}%
317 \def\@lodd
{\if@reversemargin
\hss\else\relax\fi}
318 \def\@rodd
{\if@reversemargin
\relax\else\hss\fi}
321 \let\latex@makecol\@makecol
322 \def\@makecol
{\ifvoid\footins\footnotetrue\else\footnotefalse\fi
323 \let\topfloat\@toplist
\let\botfloat\@botlist
\latex@makecol
}
324 \def\iftopfloat#1#2{\ifx\topfloat\empty #2\else #1\fi}
325 \def\ifbotfloat#1#2{\ifx\botfloat\empty #2\else #1\fi}
326 \def\iffloatpage#1#2{\if@fcolmade
#1\else #2\fi}
328 \newcommand{\fancypagestyle}[2]{%
329 \@namedef
{ps@
#1}{\let\fancy@def
\def#2\relax\ps@fancy
}}