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}}