/ paper / fancyhdr.sty
fancyhdr.sty
  1  % fancyhdr.sty version 3.2
  2  % Fancy headers and footers for LaTeX.
  3  % Piet van Oostrum, 
  4  % Dept of Computer and Information Sciences, University of Utrecht,
  5  % Padualaan 14, P.O. Box 80.089, 3508 TB Utrecht, The Netherlands
  6  % Telephone: +31 30 2532180. Email: piet@cs.uu.nl
  7  % ========================================================================
  8  % LICENCE:
  9  % This file may be distributed under the terms of the LaTeX Project Public
 10  % License, as described in lppl.txt in the base LaTeX distribution.
 11  % Either version 1 or, at your option, any later version.
 12  % ========================================================================
 13  % MODIFICATION HISTORY:
 14  % Sep 16, 1994
 15  % version 1.4: Correction for use with \reversemargin
 16  % Sep 29, 1994:
 17  % version 1.5: Added the \iftopfloat, \ifbotfloat and \iffloatpage commands
 18  % Oct 4, 1994:
 19  % version 1.6: Reset single spacing in headers/footers for use with
 20  % setspace.sty or doublespace.sty
 21  % Oct 4, 1994:
 22  % version 1.7: changed \let\@mkboth\markboth to
 23  % \def\@mkboth{\protect\markboth} to make it more robust
 24  % Dec 5, 1994:
 25  % version 1.8: corrections for amsbook/amsart: define \@chapapp and (more
 26  % importantly) use the \chapter/sectionmark definitions from ps@headings if
 27  % they exist (which should be true for all standard classes).
 28  % May 31, 1995:
 29  % version 1.9: The proposed \renewcommand{\headrulewidth}{\iffloatpage...
 30  % construction in the doc did not work properly with the fancyplain style. 
 31  % June 1, 1995:
 32  % version 1.91: The definition of \@mkboth wasn't restored on subsequent
 33  % \pagestyle{fancy}'s.
 34  % June 1, 1995:
 35  % version 1.92: The sequence \pagestyle{fancyplain} \pagestyle{plain}
 36  % \pagestyle{fancy} would erroneously select the plain version.
 37  % June 1, 1995:
 38  % version 1.93: \fancypagestyle command added.
 39  % Dec 11, 1995:
 40  % version 1.94: suggested by Conrad Hughes <chughes@maths.tcd.ie>
 41  % CJCH, Dec 11, 1995: added \footruleskip to allow control over footrule
 42  % position (old hardcoded value of .3\normalbaselineskip is far too high
 43  % when used with very small footer fonts).
 44  % Jan 31, 1996:
 45  % version 1.95: call \@normalsize in the reset code if that is defined,
 46  % otherwise \normalsize.
 47  % this is to solve a problem with ucthesis.cls, as this doesn't
 48  % define \@currsize. Unfortunately for latex209 calling \normalsize doesn't
 49  % work as this is optimized to do very little, so there \@normalsize should
 50  % be called. Hopefully this code works for all versions of LaTeX known to
 51  % mankind.  
 52  % April 25, 1996:
 53  % version 1.96: initialize \headwidth to a magic (negative) value to catch
 54  % most common cases that people change it before calling \pagestyle{fancy}.
 55  % Note it can't be initialized when reading in this file, because
 56  % \textwidth could be changed afterwards. This is quite probable.
 57  % We also switch to \MakeUppercase rather than \uppercase and introduce a
 58  % \nouppercase command for use in headers. and footers.
 59  % May 3, 1996:
 60  % version 1.97: Two changes:
 61  % 1. Undo the change in version 1.8 (using the pagestyle{headings} defaults
 62  % for the chapter and section marks. The current version of amsbook and
 63  % amsart classes don't seem to need them anymore. Moreover the standard
 64  % latex classes don't use \markboth if twoside isn't selected, and this is
 65  % confusing as \leftmark doesn't work as expected.
 66  % 2. include a call to \ps@empty in ps@@fancy. This is to solve a problem
 67  % in the amsbook and amsart classes, that make global changes to \topskip,
 68  % which are reset in \ps@empty. Hopefully this doesn't break other things.
 69  % May 7, 1996:
 70  % version 1.98:
 71  % Added % after the line  \def\nouppercase
 72  % May 7, 1996:
 73  % version 1.99: This is the alpha version of fancyhdr 2.0
 74  % Introduced the new commands \fancyhead, \fancyfoot, and \fancyhf.
 75  % Changed \headrulewidth, \footrulewidth, \footruleskip to
 76  % macros rather than length parameters, In this way they can be
 77  % conditionalized and they don't consume length registers. There is no need
 78  % to have them as length registers unless you want to do calculations with
 79  % them, which is unlikely. Note that this may make some uses of them
 80  % incompatible (i.e. if you have a file that uses \setlength or \xxxx=)
 81  % May 10, 1996:
 82  % version 1.99a:
 83  % Added a few more % signs
 84  % May 10, 1996:
 85  % version 1.99b:
 86  % Changed the syntax of \f@nfor to be resistent to catcode changes of :=
 87  % Removed the [1] from the defs of \lhead etc. because the parameter is
 88  % consumed by the \@[xy]lhead etc. macros.
 89  % June 24, 1997:
 90  % version 1.99c:
 91  % corrected \nouppercase to also include the protected form of \MakeUppercase
 92  % \global added to manipulation of \headwidth.
 93  % \iffootnote command added.
 94  % Some comments added about \@fancyhead and \@fancyfoot.
 95  % Aug 24, 1998
 96  % version 1.99d
 97  % Changed the default \ps@empty to \ps@@empty in order to allow
 98  % \fancypagestyle{empty} redefinition.
 99  % Oct 11, 2000
100  % version 2.0
101  % Added LPPL license clause.
102  %
103  % A check for \headheight is added. An errormessage is given (once) if the
104  % header is too large. Empty headers don't generate the error even if
105  % \headheight is very small or even 0pt. 
106  % Warning added for the use of 'E' option when twoside option is not used.
107  % In this case the 'E' fields will never be used.
108  %
109  % Mar 10, 2002
110  % version 2.1beta
111  % New command: \fancyhfoffset[place]{length}
112  % defines offsets to be applied to the header/footer to let it stick into
113  % the margins (if length > 0).
114  % place is like in fancyhead, except that only E,O,L,R can be used.
115  % This replaces the old calculation based on \headwidth and the marginpar
116  % area.
117  % \headwidth will be dynamically calculated in the headers/footers when
118  % this is used.
119  %
120  % Mar 26, 2002
121  % version 2.1beta2
122  % \fancyhfoffset now also takes h,f as possible letters in the argument to
123  % allow the header and footer widths to be different.
124  % New commands \fancyheadoffset and \fancyfootoffset added comparable to
125  % \fancyhead and \fancyfoot.
126  % Errormessages and warnings have been made more informative.
127  %
128  % Dec 9, 2002
129  % version 2.1
130  % The defaults for \footrulewidth, \plainheadrulewidth and
131  % \plainfootrulewidth are changed from \z@skip to 0pt. In this way when
132  % someone inadvertantly uses \setlength to change any of these, the value
133  % of \z@skip will not be changed, rather an errormessage will be given.
134  
135  % March 3, 2004
136  % Release of version 3.0
137  
138  % Oct 7, 2004
139  % version 3.1
140  % Added '\endlinechar=13' to \fancy@reset to prevent problems with
141  % includegraphics in header when verbatiminput is active.
142  
143  % March 22, 2005
144  % version 3.2
145  % reset \everypar (the real one) in \fancy@reset because spanish.ldf does
146  % strange things with \everypar between << and >>.
147  
148  \def\ifancy@mpty#1{\def\temp@a{#1}\ifx\temp@a\@empty}
149  
150  \def\fancy@def#1#2{\ifancy@mpty{#2}\fancy@gbl\def#1{\leavevmode}\else
151                                     \fancy@gbl\def#1{#2\strut}\fi}
152  
153  \let\fancy@gbl\global
154  
155  \def\@fancyerrmsg#1{%
156          \ifx\PackageError\undefined
157          \errmessage{#1}\else
158          \PackageError{Fancyhdr}{#1}{}\fi}
159  \def\@fancywarning#1{%
160          \ifx\PackageWarning\undefined
161          \errmessage{#1}\else
162          \PackageWarning{Fancyhdr}{#1}{}\fi}
163  
164  % Usage: \@forc \var{charstring}{command to be executed for each char}
165  % This is similar to LaTeX's \@tfor, but expands the charstring.
166  
167  \def\@forc#1#2#3{\expandafter\f@rc\expandafter#1\expandafter{#2}{#3}}
168  \def\f@rc#1#2#3{\def\temp@ty{#2}\ifx\@empty\temp@ty\else
169                                      \f@@rc#1#2\f@@rc{#3}\fi}
170  \def\f@@rc#1#2#3\f@@rc#4{\def#1{#2}#4\f@rc#1{#3}{#4}}
171  
172  % Usage: \f@nfor\name:=list\do{body}
173  % Like LaTeX's \@for but an empty list is treated as a list with an empty
174  % element
175  
176  \newcommand{\f@nfor}[3]{\edef\@fortmp{#2}%
177      \expandafter\@forloop#2,\@nil,\@nil\@@#1{#3}}
178  
179  % Usage: \def@ult \cs{defaults}{argument}
180  % sets \cs to the characters from defaults appearing in argument
181  % or defaults if it would be empty. All characters are lowercased.
182  
183  \newcommand\def@ult[3]{%
184      \edef\temp@a{\lowercase{\edef\noexpand\temp@a{#3}}}\temp@a
185      \def#1{}%
186      \@forc\tmpf@ra{#2}%
187          {\expandafter\if@in\tmpf@ra\temp@a{\edef#1{#1\tmpf@ra}}{}}%
188      \ifx\@empty#1\def#1{#2}\fi}
189  % 
190  % \if@in <char><set><truecase><falsecase>
191  %
192  \newcommand{\if@in}[4]{%
193      \edef\temp@a{#2}\def\temp@b##1#1##2\temp@b{\def\temp@b{##1}}%
194      \expandafter\temp@b#2#1\temp@b\ifx\temp@a\temp@b #4\else #3\fi}
195  
196  \newcommand{\fancyhead}{\@ifnextchar[{\f@ncyhf\fancyhead h}%
197                                       {\f@ncyhf\fancyhead h[]}}
198  \newcommand{\fancyfoot}{\@ifnextchar[{\f@ncyhf\fancyfoot f}%
199                                       {\f@ncyhf\fancyfoot f[]}}
200  \newcommand{\fancyhf}{\@ifnextchar[{\f@ncyhf\fancyhf{}}%
201                                     {\f@ncyhf\fancyhf{}[]}}
202  
203  % New commands for offsets added
204  
205  \newcommand{\fancyheadoffset}{\@ifnextchar[{\f@ncyhfoffs\fancyheadoffset h}%
206                                             {\f@ncyhfoffs\fancyheadoffset h[]}}
207  \newcommand{\fancyfootoffset}{\@ifnextchar[{\f@ncyhfoffs\fancyfootoffset f}%
208                                             {\f@ncyhfoffs\fancyfootoffset f[]}}
209  \newcommand{\fancyhfoffset}{\@ifnextchar[{\f@ncyhfoffs\fancyhfoffset{}}%
210                                           {\f@ncyhfoffs\fancyhfoffset{}[]}}
211  
212  % The header and footer fields are stored in command sequences with
213  % names of the form: \f@ncy<x><y><z> with <x> for [eo], <y> from [lcr]
214  % and <z> from [hf].
215  
216  \def\f@ncyhf#1#2[#3]#4{%
217      \def\temp@c{}%
218      \@forc\tmpf@ra{#3}%
219          {\expandafter\if@in\tmpf@ra{eolcrhf,EOLCRHF}%
220              {}{\edef\temp@c{\temp@c\tmpf@ra}}}%
221      \ifx\@empty\temp@c\else
222          \@fancyerrmsg{Illegal char `\temp@c' in \string#1 argument:
223            [#3]}%
224      \fi
225      \f@nfor\temp@c{#3}%
226          {\def@ult\f@@@eo{eo}\temp@c
227           \if@twoside\else
228             \if\f@@@eo e\@fancywarning
229               {\string#1's `E' option without twoside option is useless}\fi\fi
230           \def@ult\f@@@lcr{lcr}\temp@c
231           \def@ult\f@@@hf{hf}{#2\temp@c}%
232           \@forc\f@@eo\f@@@eo
233               {\@forc\f@@lcr\f@@@lcr
234                   {\@forc\f@@hf\f@@@hf
235                       {\expandafter\fancy@def\csname
236                        f@ncy\f@@eo\f@@lcr\f@@hf\endcsname
237                        {#4}}}}}}
238  
239  \def\f@ncyhfoffs#1#2[#3]#4{%
240      \def\temp@c{}%
241      \@forc\tmpf@ra{#3}%
242          {\expandafter\if@in\tmpf@ra{eolrhf,EOLRHF}%
243              {}{\edef\temp@c{\temp@c\tmpf@ra}}}%
244      \ifx\@empty\temp@c\else
245          \@fancyerrmsg{Illegal char `\temp@c' in \string#1 argument:
246            [#3]}%
247      \fi
248      \f@nfor\temp@c{#3}%
249          {\def@ult\f@@@eo{eo}\temp@c
250           \if@twoside\else
251             \if\f@@@eo e\@fancywarning
252               {\string#1's `E' option without twoside option is useless}\fi\fi
253           \def@ult\f@@@lcr{lr}\temp@c
254           \def@ult\f@@@hf{hf}{#2\temp@c}%
255           \@forc\f@@eo\f@@@eo
256               {\@forc\f@@lcr\f@@@lcr
257                   {\@forc\f@@hf\f@@@hf
258                       {\expandafter\setlength\csname
259                        f@ncyO@\f@@eo\f@@lcr\f@@hf\endcsname
260                        {#4}}}}}%
261       \fancy@setoffs}
262  
263  % Fancyheadings version 1 commands. These are more or less deprecated,
264  % but they continue to work.
265  
266  \newcommand{\lhead}{\@ifnextchar[{\@xlhead}{\@ylhead}}
267  \def\@xlhead[#1]#2{\fancy@def\f@ncyelh{#1}\fancy@def\f@ncyolh{#2}}
268  \def\@ylhead#1{\fancy@def\f@ncyelh{#1}\fancy@def\f@ncyolh{#1}}
269  
270  \newcommand{\chead}{\@ifnextchar[{\@xchead}{\@ychead}}
271  \def\@xchead[#1]#2{\fancy@def\f@ncyech{#1}\fancy@def\f@ncyoch{#2}}
272  \def\@ychead#1{\fancy@def\f@ncyech{#1}\fancy@def\f@ncyoch{#1}}
273  
274  \newcommand{\rhead}{\@ifnextchar[{\@xrhead}{\@yrhead}}
275  \def\@xrhead[#1]#2{\fancy@def\f@ncyerh{#1}\fancy@def\f@ncyorh{#2}}
276  \def\@yrhead#1{\fancy@def\f@ncyerh{#1}\fancy@def\f@ncyorh{#1}}
277  
278  \newcommand{\lfoot}{\@ifnextchar[{\@xlfoot}{\@ylfoot}}
279  \def\@xlfoot[#1]#2{\fancy@def\f@ncyelf{#1}\fancy@def\f@ncyolf{#2}}
280  \def\@ylfoot#1{\fancy@def\f@ncyelf{#1}\fancy@def\f@ncyolf{#1}}
281  
282  \newcommand{\cfoot}{\@ifnextchar[{\@xcfoot}{\@ycfoot}}
283  \def\@xcfoot[#1]#2{\fancy@def\f@ncyecf{#1}\fancy@def\f@ncyocf{#2}}
284  \def\@ycfoot#1{\fancy@def\f@ncyecf{#1}\fancy@def\f@ncyocf{#1}}
285  
286  \newcommand{\rfoot}{\@ifnextchar[{\@xrfoot}{\@yrfoot}}
287  \def\@xrfoot[#1]#2{\fancy@def\f@ncyerf{#1}\fancy@def\f@ncyorf{#2}}
288  \def\@yrfoot#1{\fancy@def\f@ncyerf{#1}\fancy@def\f@ncyorf{#1}}
289  
290  \newlength{\fancy@headwidth}
291  \let\headwidth\fancy@headwidth
292  \newlength{\f@ncyO@elh}
293  \newlength{\f@ncyO@erh}
294  \newlength{\f@ncyO@olh}
295  \newlength{\f@ncyO@orh}
296  \newlength{\f@ncyO@elf}
297  \newlength{\f@ncyO@erf}
298  \newlength{\f@ncyO@olf}
299  \newlength{\f@ncyO@orf}
300  \newcommand{\headrulewidth}{0.4pt}
301  \newcommand{\footrulewidth}{0pt}
302  \newcommand{\footruleskip}{.3\normalbaselineskip}
303  
304  % Fancyplain stuff shouldn't be used anymore (rather
305  % \fancypagestyle{plain} should be used), but it must be present for
306  % compatibility reasons.
307  
308  \newcommand{\plainheadrulewidth}{0pt}
309  \newcommand{\plainfootrulewidth}{0pt}
310  \newif\if@fancyplain \@fancyplainfalse
311  \def\fancyplain#1#2{\if@fancyplain#1\else#2\fi}
312  
313  \headwidth=-123456789sp %magic constant
314  
315  % Command to reset various things in the headers:
316  % a.o.  single spacing (taken from setspace.sty)
317  % and the catcode of ^^M (so that epsf files in the header work if a
318  % verbatim crosses a page boundary)
319  % It also defines a \nouppercase command that disables \uppercase and
320  % \Makeuppercase. It can only be used in the headers and footers.
321  \let\fnch@everypar\everypar% save real \everypar because of spanish.ldf
322  \def\fancy@reset{\fnch@everypar{}\restorecr\endlinechar=13
323   \def\baselinestretch{1}%
324   \def\nouppercase##1{{\let\uppercase\relax\let\MakeUppercase\relax
325       \expandafter\let\csname MakeUppercase \endcsname\relax##1}}%
326   \ifx\undefined\@newbaseline% NFSS not present; 2.09 or 2e
327     \ifx\@normalsize\undefined \normalsize % for ucthesis.cls
328     \else \@normalsize \fi
329   \else% NFSS (2.09) present
330    \@newbaseline%
331   \fi}
332  
333  % Initialization of the head and foot text.
334  
335  % The default values still contain \fancyplain for compatibility.
336  \fancyhf{} % clear all
337  % lefthead empty on ``plain'' pages, \rightmark on even, \leftmark on odd pages
338  % evenhead empty on ``plain'' pages, \leftmark on even, \rightmark on odd pages
339  \if@twoside
340    \fancyhead[el,or]{\fancyplain{}{\sl\rightmark}}
341    \fancyhead[er,ol]{\fancyplain{}{\sl\leftmark}}
342  \else
343    \fancyhead[l]{\fancyplain{}{\sl\rightmark}}
344    \fancyhead[r]{\fancyplain{}{\sl\leftmark}}
345  \fi
346  \fancyfoot[c]{\rm\thepage} % page number
347  
348  % Use box 0 as a temp box and dimen 0 as temp dimen. 
349  % This can be done, because this code will always
350  % be used inside another box, and therefore the changes are local.
351  
352  \def\@fancyvbox#1#2{\setbox0\vbox{#2}\ifdim\ht0>#1\@fancywarning
353    {\string#1 is too small (\the#1): ^^J Make it at least \the\ht0.^^J
354      We now make it that large for the rest of the document.^^J
355      This may cause the page layout to be inconsistent, however\@gobble}%
356    \dimen0=#1\global\setlength{#1}{\ht0}\ht0=\dimen0\fi
357    \box0}
358  
359  % Put together a header or footer given the left, center and
360  % right text, fillers at left and right and a rule.
361  % The \lap commands put the text into an hbox of zero size,
362  % so overlapping text does not generate an errormessage.
363  % These macros have 5 parameters:
364  % 1. LEFTSIDE BEARING % This determines at which side the header will stick
365  %    out. When \fancyhfoffset is used this calculates \headwidth, otherwise
366  %    it is \hss or \relax (after expansion).
367  % 2. \f@ncyolh, \f@ncyelh, \f@ncyolf or \f@ncyelf. This is the left component.
368  % 3. \f@ncyoch, \f@ncyech, \f@ncyocf or \f@ncyecf. This is the middle comp.
369  % 4. \f@ncyorh, \f@ncyerh, \f@ncyorf or \f@ncyerf. This is the right component.
370  % 5. RIGHTSIDE BEARING. This is always \relax or \hss (after expansion).
371  
372  \def\@fancyhead#1#2#3#4#5{#1\hbox to\headwidth{\fancy@reset
373    \@fancyvbox\headheight{\hbox
374      {\rlap{\parbox[b]{\headwidth}{\raggedright#2}}\hfill
375        \parbox[b]{\headwidth}{\centering#3}\hfill
376        \llap{\parbox[b]{\headwidth}{\raggedleft#4}}}\headrule}}#5}
377  
378  \def\@fancyfoot#1#2#3#4#5{#1\hbox to\headwidth{\fancy@reset
379      \@fancyvbox\footskip{\footrule
380        \hbox{\rlap{\parbox[t]{\headwidth}{\raggedright#2}}\hfill
381          \parbox[t]{\headwidth}{\centering#3}\hfill
382          \llap{\parbox[t]{\headwidth}{\raggedleft#4}}}}}#5}
383  
384  \def\headrule{{\if@fancyplain\let\headrulewidth\plainheadrulewidth\fi
385      \hrule\@height\headrulewidth\@width\headwidth \vskip-\headrulewidth}}
386  
387  \def\footrule{{\if@fancyplain\let\footrulewidth\plainfootrulewidth\fi
388      \vskip-\footruleskip\vskip-\footrulewidth
389      \hrule\@width\headwidth\@height\footrulewidth\vskip\footruleskip}}
390  
391  \def\ps@fancy{%
392  \@ifundefined{@chapapp}{\let\@chapapp\chaptername}{}%for amsbook
393  %
394  % Define \MakeUppercase for old LaTeXen.
395  % Note: we used \def rather than \let, so that \let\uppercase\relax (from
396  % the version 1 documentation) will still work.
397  %
398  \@ifundefined{MakeUppercase}{\def\MakeUppercase{\uppercase}}{}%
399  \@ifundefined{chapter}{\def\sectionmark##1{\markboth
400  {\MakeUppercase{\ifnum \c@secnumdepth>\z@
401   \thesection\hskip 1em\relax \fi ##1}}{}}%
402  \def\subsectionmark##1{\markright {\ifnum \c@secnumdepth >\@ne
403   \thesubsection\hskip 1em\relax \fi ##1}}}%
404  {\def\chaptermark##1{\markboth {\MakeUppercase{\ifnum \c@secnumdepth>\m@ne
405   \@chapapp\ \thechapter. \ \fi ##1}}{}}%
406  \def\sectionmark##1{\markright{\MakeUppercase{\ifnum \c@secnumdepth >\z@
407   \thesection. \ \fi ##1}}}}%
408  %\csname ps@headings\endcsname % use \ps@headings defaults if they exist
409  \ps@@fancy
410  \gdef\ps@fancy{\@fancyplainfalse\ps@@fancy}%
411  % Initialize \headwidth if the user didn't
412  %
413  \ifdim\headwidth<0sp
414  %
415  % This catches the case that \headwidth hasn't been initialized and the
416  % case that the user added something to \headwidth in the expectation that
417  % it was initialized to \textwidth. We compensate this now. This loses if
418  % the user intended to multiply it by a factor. But that case is more
419  % likely done by saying something like \headwidth=1.2\textwidth. 
420  % The doc says you have to change \headwidth after the first call to
421  % \pagestyle{fancy}. This code is just to catch the most common cases were
422  % that requirement is violated.
423  %
424      \global\advance\headwidth123456789sp\global\advance\headwidth\textwidth
425  \fi}
426  \def\ps@fancyplain{\ps@fancy \let\ps@plain\ps@plain@fancy}
427  \def\ps@plain@fancy{\@fancyplaintrue\ps@@fancy}
428  \let\ps@@empty\ps@empty
429  \def\ps@@fancy{%
430  \ps@@empty % This is for amsbook/amsart, which do strange things with \topskip
431  \def\@mkboth{\protect\markboth}%
432  \def\@oddhead{\@fancyhead\fancy@Oolh\f@ncyolh\f@ncyoch\f@ncyorh\fancy@Oorh}%
433  \def\@oddfoot{\@fancyfoot\fancy@Oolf\f@ncyolf\f@ncyocf\f@ncyorf\fancy@Oorf}%
434  \def\@evenhead{\@fancyhead\fancy@Oelh\f@ncyelh\f@ncyech\f@ncyerh\fancy@Oerh}%
435  \def\@evenfoot{\@fancyfoot\fancy@Oelf\f@ncyelf\f@ncyecf\f@ncyerf\fancy@Oerf}%
436  }
437  % Default definitions for compatibility mode:
438  % These cause the header/footer to take the defined \headwidth as width
439  % And to shift in the direction of the marginpar area
440  
441  \def\fancy@Oolh{\if@reversemargin\hss\else\relax\fi}
442  \def\fancy@Oorh{\if@reversemargin\relax\else\hss\fi}
443  \let\fancy@Oelh\fancy@Oorh
444  \let\fancy@Oerh\fancy@Oolh
445  
446  \let\fancy@Oolf\fancy@Oolh
447  \let\fancy@Oorf\fancy@Oorh
448  \let\fancy@Oelf\fancy@Oelh
449  \let\fancy@Oerf\fancy@Oerh
450  
451  % New definitions for the use of \fancyhfoffset
452  % These calculate the \headwidth from \textwidth and the specified offsets.
453  
454  \def\fancy@offsolh{\headwidth=\textwidth\advance\headwidth\f@ncyO@olh
455                     \advance\headwidth\f@ncyO@orh\hskip-\f@ncyO@olh}
456  \def\fancy@offselh{\headwidth=\textwidth\advance\headwidth\f@ncyO@elh
457                     \advance\headwidth\f@ncyO@erh\hskip-\f@ncyO@elh}
458  
459  \def\fancy@offsolf{\headwidth=\textwidth\advance\headwidth\f@ncyO@olf
460                     \advance\headwidth\f@ncyO@orf\hskip-\f@ncyO@olf}
461  \def\fancy@offself{\headwidth=\textwidth\advance\headwidth\f@ncyO@elf
462                     \advance\headwidth\f@ncyO@erf\hskip-\f@ncyO@elf}
463  
464  \def\fancy@setoffs{%
465  % Just in case \let\headwidth\textwidth was used
466    \fancy@gbl\let\headwidth\fancy@headwidth
467    \fancy@gbl\let\fancy@Oolh\fancy@offsolh
468    \fancy@gbl\let\fancy@Oelh\fancy@offselh
469    \fancy@gbl\let\fancy@Oorh\hss
470    \fancy@gbl\let\fancy@Oerh\hss
471    \fancy@gbl\let\fancy@Oolf\fancy@offsolf
472    \fancy@gbl\let\fancy@Oelf\fancy@offself
473    \fancy@gbl\let\fancy@Oorf\hss
474    \fancy@gbl\let\fancy@Oerf\hss}
475  
476  \newif\iffootnote
477  \let\latex@makecol\@makecol
478  \def\@makecol{\ifvoid\footins\footnotetrue\else\footnotefalse\fi
479  \let\topfloat\@toplist\let\botfloat\@botlist\latex@makecol}
480  \def\iftopfloat#1#2{\ifx\topfloat\empty #2\else #1\fi}
481  \def\ifbotfloat#1#2{\ifx\botfloat\empty #2\else #1\fi}
482  \def\iffloatpage#1#2{\if@fcolmade #1\else #2\fi}
483  
484  \newcommand{\fancypagestyle}[2]{%
485    \@namedef{ps@#1}{\let\fancy@gbl\relax#2\relax\ps@fancy}}