The Geometry Package: 1 Preface To Version 5
The Geometry Package: 1 Preface To Version 5
Hideo Umeki
                        https://github.com/davidcarlisle/geometry
2020/01/02 v5.9
                                                  Abstract
          This package provides a flexible and easy interface to page dimensions. You can change the page
      layout with intuitive parameters. For instance, if you want to set a margin to 2cm from each edge of
      the paper, you can type just \usepackage[margin=2cm]{geometry}. The page layout can be changed
      in the middle of the document with \newgeometry command.
1    Preface to version 5
    • Changing page layout mid-document.
      The new commands \newgeometry{· · ·} and \restoregeometry allow users to change page dimen-
      sions in the middle of the document. \newgeometry is almost similar to \geometry except that
      \newgeometry disables all the options specified in the preamble and skips the papersize-related
      options: landscape, portrait and paper size options (such as papersize, paper=a4paper and so
      forth).
    • A new set of options to specify the layout area.
      The options specified for the area, in which the page dimensions are calculated, are added: layout,
      layoutsize, layoutwidth, layoutheight and so forth. These options would help to print the specified
      layout to a different sized paper. For example, with a4paper and layout=a5paper, the geometry
      package uses ‘A5’ layout to calculate margins with the paper size still ‘A4’.
    • A new driver option xetex.
      The new driver option xetex is added. The driver auto-detection routine has been revised so as
      to avoid an error with undefined control sequences. Note that ‘geometry.cfg’ in TEX Live, which
      disables the auto-detection routine and sets pdftex, is no longer necessary and has no problem even
      though it still exists. To set xetex is strongly recommended with XELATEX.
    • New paper size presets for JIS B-series and ISO C-series.
      The papersize presets b0j to b6j for JIS (Japanese Industrial Standards) B-series and c0paper to
      c6paper for ISO C-series (v5.4∼) are added.
    • Changing default for underspecified margin.
      In the previous version, if only one margin was specified, bottom=1cm for example, then geometry
      set the other margin with the margin ratio (1:1 by default for the vertical dimensions) and got
      top=1cm in this case. The version 5 sets the text-body size with the default scale (= 0.7) and
      determine the unspecified margin. (See Section 6.5)
    • The option showframe and showcrop works on every page.
      With showframe option, the page frames are shown on every page. In addition, a new option
      showcrop prints crop marks at each corner of layout area on every page. Note that the marks would
      be invisible without specifying the layout size smaller than paper size. Version 5.4 introduced a
      new \shipout overloading process using atbegshi package, so the atbegshi package is required when
      showframe or showcrop option is specified.
    • Loading geometry.cfg precedes processing class options.
      The previous version loaded geometry.cfg after processing the document class options. Now that
      the config file is loaded before processing the class options, you can change the behavior specified
      in geometry.cfg by adding options into \documentclass as well as \usepackage and \geometry.
                                                       1
    • Deleted options: compat2 and twosideshift. The version 5 has no longer compatibility with
      the previous ones. compat2 and twosideshift are gone for simplicity.
2    Introduction
To set dimensions for page layout in LATEX is not straightforward. You need to adjust several LATEX
native dimensions to place a text area where you want. If you want to center the text area in the paper
you use, for example, you have to specify native dimensions as follows:
      \usepackage{calc}
      \setlength\textwidth{7in}
      \setlength\textheight{10in}
      \setlength\oddsidemargin{(\paperwidth-\textwidth)/2 - 1in}
      \setlength\topmargin{(\paperheight-\textheight
                            -\headheight-\headsep-\footskip)/2 - 1in}.
Without package calc, the above example would need more tedious settings. Package geometry provides
an easy way to set page layout parameters. In this case, what you have to do is just
      \usepackage[text={7in,10in},centering]{geometry}.
Besides centering problem, setting margins from each edge of the paper is also troublesome. But geometry
also make it easy. If you want to set each margin to 1.5in, you can type
      \usepackage[margin=1.5in]{geometry}
Thus, the geometry package has an auto-completion mechanism, in which unspecified dimensions are
automatically determined. The geometry package will be also useful when you have to set page layout
obeying the following strict instructions: for example,
      The total allowable width of the text area is 6.5 inches wide by 8.75 inches high. The top
      margin on each page should be 1.2 inches from the top edge of the page. The left margin
      should be 0.9 inch from the left edge. The footer with page number should be at the bottom
      of the text area.
In this case, using geometry you can type
      \usepackage[total={6.5in,8.75in},
                  top=1.2in, left=0.9in, includefoot]{geometry}.
   Setting a text area on the paper in document preparation system has some analogy to placing a
window on the background in the window system. The name ‘geometry’ comes from the -geometry
option used for specifying a size and location of a window in X Window System.
3    Page geometry
Figure 1 shows the page layout dimensions defined in the geometry package. The page layout contains a
total body (printable area) and margins. The total body consists of a body (text area) with an optional
header, footer and marginal notes (marginpar). There are four margins: left, right, top and bottom. For
twosided documents, horizontal margins should be called inner and outer.
            paper   :   total body and margins
       total body   :   body (text area) (optional head, foot and marginpar)
          margins   :   left (inner), right (outer), top and bottom
Each margin is measured from the corresponding edge of a paper. For example, left margin (inner
margin) means a horizontal distance between the left (inner) edge of the paper and that of the total
body. Therefore the left and top margins defined in geometry are different from the native dimensions
\leftmargin and \topmargin. The size of a body (text area) can be modified by \textwidth and
\textheight. The dimensions for paper, total body and margins have the following relations.
                                                   2
                                                  paper
                                6top                                                       headheight
                                                                               head        headsep
                                                                                          
                                ?                                                         
                                     total body                          6
                                                                       textheight
        paperheight
                          height                                              body           marginal note
                left 
                     -                            - right                               marginparsep
             (inner)                                      (outer)                    
                                                                        textwidth - - marginparwidth
                                width                                   ?
                                6bottom                                     foot    H footskip
                                                                                    H
                                ?
                               paperwidth
     Figure 1: Dimension names used in the geometry package. width = textwidth and height =
                textheight by default. left, right, top and bottom are margins. If margins on verso
                pages are swapped by twoside option, margins specified by left and right options are
                used for the inside and outside margins respectively. inner and outer are aliases of left
                and right respectively.
body body
                                                                        ?
                          ?                                                 foot
                              foot        6bottom                                  6bottom
                                          ?                                        ?
     Figure 2: includehead and includefoot include the head and foot respectively into total body. (a)
                height = textheight (default). (b) height = textheight + headheight + headsep +
                footskip if includehead and includefoot. If the top and bottom margins are specified,
                includehead and includefoot result in shorter textheight.
In Equation (3) width:=textwidth by default, while marginparsep and marginparwidth are included in
width if includemp option is set true. In Equation (4), height:=textheight by default. If includehead
is set to true, headheight and headsep are considered as a part of height. In the same way, includefoot
takes footskip into height. Figure 2 shows how these options work in the vertical direction.
    Thus, the page layout consists of three parts (lengths) in each direction: one body and two margins. If
the two of them are explicitly specified, the other length is obvious and no need to be specified. Figure 3
shows a simple model of page dimensions. When a length L is given and is partitioned into the body b,
the margins a and c, it’s obvious that
                                               L=a+b+c                                                  (5)
The specification with two of the three (a,b and c) fixed explicitly is solvable. If two or more are left
unspecified or ‘underspecified’, Equation (5) cannot be solved without any other relation between them.
If all of them are specified, then it needs to check whether or not they satisfy Equation (5), that is too
much specification or ‘overspecified’.
                                                             3
                                                     L                       -
                              a                   b                     c
    The geometry package has auto-completion mechanism that saves the trouble of specifying the page
layout dimensions. For example, you can set
      \usepackage[width=14cm, left=3cm]{geometry}
on A4 paper. In this case you don’t have to set the right margin The details of auto-completion will be
described in Section 6.5.
4     User interface
4.1    Commands
The geometry package provides the following commands:
    • \geometry{hoptionsi}
    • \newgeometry{hoptionsi} and \restoregeometry
    • \savegeometry{hnamei} and \loadgeometry{hnamei}
    \geometry{hoptionsi} changes the page layout according to the options specified in the argument.
This command, if any, should be placed only in the preamble (before \begin{document}).
    The geometry package may be used as part of a class or another package you use in your document.
The command \geometry can overwrite some of the settings in the preamble. Multiple use of \geometry
is allowed and then processed with the options concatenated. If geometry is not yet loaded, you can use
only \usepackage[hoptionsi]{geometry} instead of \geometry.
    \newgeometry{hoptionsi} changes the page layout mid-document. \newgeometry is almost similar to
\geometry except that \newgeometry disables all the options specified by \usepackage and \geometry
in the preamble and skips papersize-related options. \restoregeometry restores the page layout specified
in the preamble. This command has no arguments. See Section 7 for details.
   \savegeometry{hnamei} saves the page dimensions as hnamei where you put this command.
\loadgeometry{hnamei} loads the page dimensions saved as hnamei. See Section 7 for details.
                                                      4
        \usepackage{geometry}
        \geometry{height=10in,a5paper,hmargin={3cm,0.8in}}
or
        \usepackage[a5paper]{geometry}
        \geometry{hmargin={3cm,0.8in},height=8in}
        \geometry{height=10in}.
Thus, multiple use of \geometry just appends options.
  geometry supports package calc 1 . For example,
        \usepackage{calc}
        \usepackage[textheight=20\baselineskip+10pt]{geometry}
     1. Boolean type
        takes a boolean value (true or false). If no value, true is set by default.
               hkeyi=true false.
               hkeyi with no value is equivalent to hkeyi=true.
               hkeyi=hvaluei.
        Examples: width=7in, left=1.25in, footskip=1cm, height=.86\paperheight.
     3. Double-valued type
        takes a pair of comma-separated values in braces. The two values can be shortened to one value if
        they are identical.
               hkeyi={hvalue1 i,hvalue2 i}.
               hkeyi=hvaluei is equivalent to hkeyi={hvaluei,hvaluei}.
        Examples: hmargin={1.5in,1in}, scale=0.8, body={7in,10in}.
     4. Triple-valued type
        takes three mandatory, comma-separated values in braces.
               hkeyi={hvalue1 i,hvalue2 i,hvalue3 i}
        Each value must be a dimension or null. When you give an empty value or ‘*’, it means null and
        leaves the appropriate value to the auto-completion mechanism. You need to specify at least one
        dimension, typically two dimensions. You can set nulls for all the values, but it makes no sense.
        Examples:
             hdivide={2cm,*,1cm}, vdivide={3cm,19cm, }, divide={1in,*,1in}.
5      Option details
                                                                                      †
This section describes all options available in geometry. Options with a dagger           are not available as
arguments of \newgeometry (See Section 7).
     1 CTAN:   macros/latex/required/tools
                                                       5
    5.1     Paper size
    The options below set paper/media size and orientation.
†
    paperpapername
               specifies the paper size by name. paper=hpaper-namei. For convenience, you can specify
               the paper name without paper=. For example, a4paper is equivalent to paper=a4paper.
†
  a0paper, a1paper, a2paper, a3paper, a4paper, a5paper, a6paper,
  b0paper, b1paper, b2paper, b3paper, b4paper, b5paper, b6paper,
  c0paper, c1paper, c2paper, c3paper, c4paper, c5paper, c6paper,
  b0j, b1j, b2j, b3j, b4j, b5j, b6j,
  ansiapaper, ansibpaper, ansicpaper, ansidpaper, ansiepaper,
  letterpaper, executivepaper, legalpaper
               specifies paper name. The value part is ignored even if any. For example, the followings
               have the same effect: a5paper, a5paper=true, a5paper=false and so forth.
               a[0-6]paper, b[0-6]paper and c[0-6]paper are ISO A, B and C series of paper sizes
               respectively. The JIS (Japanese Industrial Standards) A-series is identical to the ISO
               A-series, but the JIS B-series is different from the ISO B-series. b[0-6]j should be used
               for the JIS B-series.
†
  screen       a special paper size with (W,H) = (225mm,180mm). For presentation with PC and
               video projector, “screen,centering” with ‘slide’ documentclass would be useful.
†
  paperwidth   width of the paper. paperwidth=hlengthi.
†
  paperheight height of the paper. paperheight=hlengthi.
†
  papersize    width and height of the paper. papersize={hwidthi,hheighti} or papersize=hlengthi.
†
  landscape    switches the paper orientation to landscape mode.
†
  portrait     switches the paper orientation to portrait mode. This is equivalent to landscape=false.
        The options for paper names (e.g., a4paper) and orientation (portrait and landscape) can be set
    as document class options. For example, you can set \documentclass[a4paper,landscape]{article},
    then a4paper and landscape are processed in geometry as well. This is also the case for twoside and
    twocolumn (see also Section 5.5).
    layout       specifies the layout size by paper name. layout=hpaper-namei. All the paper names
                 defined in geometry are available. See Section 5.1 for details.
    layoutwidth width of the layout. layoutwidth=hlengthi.
    layoutheight height of the layout. layoutheight=hlengthi.
    layoutsize   width and height of the layout. layoutsize={hwidthi,hheighti} or
                 layoutsize=hlengthi.
    layouthoffset specifies the horizontal offset from the left edge of the paper. layouthoffset=hlengthi.
    layoutvoffset specifies the vertical offset from the top edge of the paper. layoutvoffset=hlengthi.
    layoutoffset specifies both horizontal and vertical offsets. layoutoffset={hhoffseti,hvoffseti} or
                 layoutsize=hlengthi.
                                                         6
                        layoutwidth -                   layouthoffset ?
                                                                       layoutvoffset
                      6                                   AA - 
                               head
                                                                        6
                                                                       head
         layoutheight
                               body                                    body
                                foot                                    foot
                      ?
                                       layout                                  layout
                                           paper                                  paper
         Figure 4: The dimensions related to the layout size. Note that the layout size defaults to
                    the same size as the paper, so you don’t have to specify layout-related options
                    explicitly in most cases.
vscale       ratio of height of total body to \paperheight, e.g., vscale=hv-scalei. (0.7 by default)
             vscale=0.9 is equivalent to height=0.9\paperheight.
scale        ratio of total body to the paper. scale={hh-scalei,hv-scalei} or scale=hscalei. (0.7 by
             default)
width totalwidth
             width of total body. width=hlengthi or totalwidth=hlengthi. This dimension defaults to
             textwidth, but if includemp is set to true, width ≥ textwidth because width includes
             the width of the marginal notes. If textwidth and width are specified at the same time,
             textwidth takes priority over width.
height totalheight
             height of total body, excluding header and footer by default. If includehead or
             includefoot is set, height includes the head or foot of the page as well as textheight.
             height=hlengthi or totalheight=hlengthi. If both textheight and height are
             specified, height will be ignored.
total        width and height of total body.
             total={hwidthi,hheighti} or total=hlengthi.
textwidth    specifies \textwidth, the width of body (the text area). textwidth=hlengthi.
textheight   specifies \textheight, the height of body (the text area). textheight=hlengthi.
text body    specifies both \textwidth and \textheight of the body of page.
             body={hwidthi,hheighti} or text=hlengthi.
lines        enables users to specify \textheight by the number of lines. lines=hinteger i.
includehead includes the head of the page, \headheight and \headsep, into total body. It is set to
             false by default. It is opposite to ignorehead. See Figure 2 and Figure 5.
includefoot includes the foot of the page, \footskip, into total body. It is opposite to ignorefoot.
             It is false by default. See Figure 2 and Figure 5.
includeheadfoot
             sets both includehead and includefoot to true, which is opposite to
             ignoreheadfoot. See Figure 2 and Figure 5.
includemp    includes the margin notes, \marginparwidth and \marginparsep, into body when
             calculating horizontal calculation.
includeall   sets both includeheadfoot and includemp to true. See Figure 5.
ignorehead   disregards the head of the page, headheight and headsep, in determining vertical
             layout, but does not change those lengths. It is equivalent to includehead=false. It is
             set to true by default. See also includehead.
ignorefoot   disregards the foot of page, footskip, in determining vertical layout, but does not
             change that length. This option defaults to true. See also includefoot.
ignoreheadfoot
             sets both ignorehead and ignorefoot to true. See also includeheadfoot.
                                                     7
                    (a) includeheadfoot                    (b) includeall
                             total body                            total body
                                          headheight
                         head                                  head
                                          headsep
                        textwidth                            textwidth
                                          footskip
                          foot                                 foot
                                                                          marginparwidth
                                                                         marginparsep
                        textwidth                            textwidth
                                          footskip
                           foot                                foot
                                                                          marginparwidth
                                                                         marginparsep
    Figure 5: Sample layouts for total body with different switches.       (a) includeheadfoot, (b)
               includeall, (c) includefoot and (d) includefoot,includemp. If reversemp is set to
               true, the location of the marginal notes are swapped on every page. Option twoside
               swaps both margins and marginal notes on verso pages. Note that the marginal note, if
               any, is printed despite ignoremp or includemp=false and overrun the page in some cases.
ignoremp     disregards the marginal notes in determining the horizontal margins (defaults to true).
             If marginal notes overrun the page, the warning message will be displayed when
             verbose=true. See also includemp and Figure 5.
ignoreall    sets both ignoreheadfoot and ignoremp to true. See also includeall.
heightrounded
             This option rounds \textheight to n-times (n: an integer) of \baselineskip plus
             \topskip to avoid “underfull vbox” in some cases. For example, if \textheight is
             486pt with \baselineskip 12pt and \topskip 10pt, then
                    (39 × 12pt + 10pt =) 478pt < 486pt < 490pt (= 40 × 12pt + 10pt),
               as a result \textheight is rounded to 490pt. heightrounded=false by default.
   Figure 5 illustrates various layouts with different layout modes. The dimensions for a header and a
footer can be controlled by nohead or nofoot mode, which sets each length to 0pt directly. On the other
hand, options with the prefix ignore do not change the corresponding native dimensions.
   The following options can specify body and margins simultaneously with three comma-separated
values in braces.
                                                       8
vdivide        vertical partitions (top,height,bottom). vdivide={htop margini,hheighti,hbottom
               margini}.
divide         divide={A,B,C} is interpreted as hdivide={A,B,C} and vdivide={A,B,C}.
                                                    9
                 a) every page for oneside or              b) even (back) pages for twoside
                    odd pages for twoside
                                       paper                                    paper
                    - left
                                       - right           - outer      inner -
                       (inner)                  (outer)        (right)   (left)
- bindingoffset bindingoffset
    Figure 6: The option bindingoffset adds the specified length to the inner margin. Note that
               twoside option swaps the horizontal margins and the marginal notes together with
               bindingoffset on even pages (see b)), but asymmetric option suppresses the swap of the
               margins and marginal notes (but bindingoffset is still swapped).
headheight  head
             modifies \headheight, height of header. headheight=hlengthi or head=hlengthi.
headsep      modifies \headsep, separation between header and text (body). headsep=hlengthi.
footskip foot
             modifies \footskip, distance separation between baseline of last line of text and
             baseline of footer. footskip=hlengthi or foot=hlengthi.
nohead       eliminates spaces for the head of the page, which is equivalent to both
             \headheight=0pt and \headsep=0pt.
nofoot       eliminates spaces for the foot of the page, which is equivalent to \footskip=0pt.
noheadfoot   equivalent to nohead and nofoot, which means that \headheight, \headsep and
             \footskip are all set to 0pt.
footnotesep changes the dimension \skip\footins, separation between the bottom of text body and
             the top of footnote text.
marginparwidth marginpar
             modifies \marginparwidth, width of the marginal notes. marginparwidth=hlengthi.
marginparsep modifies \marginparsep, separation between body and marginal notes.
             marginparsep=hlengthi.
nomarginpar shrinks spaces for marginal notes to 0pt, which is equivalent to \marginparwidth=0pt
             and \marginparsep=0pt.
columnsep    modifies \columnsep, the separation between two columns in twocolumn mode.
hoffset      modifies \hoffset. hoffset=hlengthi.
voffset      modifies \voffset. voffset=hlengthi.
offset       horizontal and vertical offset.
             offset={hhoffseti,hvoffseti} or offset=hlengthi.
twocolumn    sets twocolumn mode with \@twocolumntrue. twocolumn=false denotes onecolumn
             mode with\@twocolumnfalse. Instead of twocolumn=false, you can specify onecolumn
             (which defaults to true)
onecolumn    works as twocolumn=false. On the other hand, onecolumn=false is equivalent to
             twocolumn.
twoside      sets both \@twosidetrue and \@mparswitchtrue. See Section 5.4.
textwidth    sets \textwidth directly. See Section 5.3.
textheight   sets \textheight directly. See Section 5.3.
reversemp reversemarginpar
             makes the marginal notes appear in the left (inner) margin with \@reversemargintrue.
             The option doesn’t change includemp mode. It’s set false by default.
                                                      10
    5.6     Drivers
    The package supports drivers dvips, dvipdfm, pdftex, luatex, xetex and vtex. You can also set
    dvipdfm for dvipdfmx and xdvipdfmx The options dvipdfmx and xdvipdfmx are also supported as aliases
    for the dvipdfm option. pdftex for pdflatex, and vtex for VTEX environment. The driver options are
    exclusive. The driver can be set by either driver=hdriver namei or any of the drivers directly like pdftex.
    By default, geometry guesses the driver appropriate to the system in use. Therefore, you don’t have to
    set a driver in most cases. However, if you want to use dvipdfm, you should specify it explicitly.
†
    driver         specifies the driver with driver=hdriver namei. dvips, dvipdfm, pdftex, luatex, vtex,
                   xetex, auto and none are available as a driver name. The names except for auto and
                   none can be specified directly with the name without driver=. driver=auto makes the
                   auto-detection work whatever the previous setting is. driver=none disables the
                   auto-detection and sets no driver, which may be useful when you want to let other
                   package work out the driver setting. For example, if you want to use crop package with
                   geometry, you should call \usepackage[driver=none]{geometry} before the crop
                   package.
†
    dvips          writes the paper size in dvi output with the \special macro. If you use dvips as a
                   DVI-to-PS driver, for example, to print a document with
                   \geometry{a3paper,landscape} on A3 paper in landscape orientation, you don’t need
                   options “-t a3 -t landscape” to dvips.
†
    dvipdfm        works like dvips except for landscape correction. You can set this option when using
                   dvipdfmx and xdvipdfmx to process the dvi output.
†
  pdftex           sets \pdfpagewidth and \pdfpageheight internally.
†
  luatex           sets \pagewidth and \pageheight internally.
†
  xetex            is the same as pdftex except for ignoring \pdf{h,v}origin undefined in XELATEX. This
                   option is introduced in the version 5. Note that ‘geometry.cfg’ in TEX Live, which
                   disables the auto-detection routine and sets pdftex, is no longer necessary, but has no
                   problem even though it’s left undeleted. Instead of xetex, you can specify dvipdfm with
                   XELATEX if you want to use specials of dvipdfm XETEX supports.
†
    vtex           sets dimensions \mediawidth and \mediaheight for VTEX. When this driver is selected
                   (explicitly or automatically), geometry will auto-detect which output mode (DVI, PDF
                   or PS) is selected in VTEX, and do proper settings for it.
    If explicit driver setting is mismatched with the typesetting program in use, the default driver dvips
    would be selected.
                                                        11
†
    truedimen       changes all internal explicit dimension values into true dimensions, e.g., 1in is changed
                    to 1truein. Typically this option will be used together with mag option. Note that this
                    is ineffective against externally specified dimensions. For example, when you set
                    “mag=1440, margin=10pt, truedimen”, margins are not ‘true’ but magnified. If you
                    want to set exact margins, you should set like “mag=1440, margin=10truept,
                    truedimen” instead.
†
    pass            disables all of the geometry options and calculations except verbose and showframe. It
                    is order-independent and can be used for checking out the page layout of the
                    documentclass, other packages and manual settings without geometry.
†
    showframe       shows visible frames for the text area and page, and the lines for the head and foot on
                    the first page.
†
    showcrop        prints crop marks at each corner of user-specified layout area.
    6      Processing options
    6.1     Order of loading
    If there’s geometry.cfg somewhere TEX can find it, geometry loads it first. For example, in geometry.cfg
    you may write \ExecuteOptions{a4paper}, which specifies A4 paper as the default paper. Basically
    you can use all the options defined in geometry with \ExecuteOptions{}.
        The order of loading in the preamble of your document is as follows:
        1. geometry.cfg if it exists.
        2. Options specified with \documentclass[hoptionsi]{...}.
    The options called multiple times overwrite the previous settings. For example,
                          [verbose=true, verbose=false] results in verbose=false.
    [hmargin={3cm,2cm}, left=1cm] is the same as hmargin={1cm,2cm}, where the left (or inner) margin
    is overwritten by left=1cm.
        reset and mag are exceptions. The reset option removes all the geometry options (except pass)
    before it. If you set
           \documentclass[landscape]{article}
           \usepackage[margin=1cm,twoside]{geometry}
           \geometry{a5paper, reset, left=2cm}
    then margin=1cm, twoside and a5paper are removed, and is eventually equivalent to
           \documentclass[landscape]{article}
           \usepackage[left=2cm]{geometry}
        The mag option should be set in advance of any other settings with ‘true’ length, such as
    left=1.5truecm, width=5truein and so on. The \mag primitive can be set before this package is
    called.
                                                       12
6.3    Priority
There are several ways to set dimensions of the body: scale, total, text and lines. The geometry
package gives higher priority to the more concrete specification. Here is the priority rule for body.
For example,
      \usepackage[hscale=0.8, textwidth=7in, width=18cm]{geometry}
is the same as \usepackage[textwidth=7in]{geometry}. Another example:
6.4    Defaults
This section sums up the default settings for the auto-completion described later.
   The default vertical margin ratio is 2/3, namely,
As for the horizontal margin ratio, the default value depends on whether the document is onesided or
twosided,                                           
                                                       1:1     default for oneside,
                   left (inner) : right (outer) =                                                (7)
                                                       2:3     default for twoside.
Obviously the default horizontal margin ratio for oneside is ‘centering’.
  The geometry package has the following default setting for onesided documents:
6.5    Auto-completion
Figure 7 shows schematically how many specification patterns exist and how to solve the ambiguity of the
specifications. Each axis shows the numbers of lengths explicitly specified for body and margins. S(m,b)
presents the specification with a set of numbers (margin, body) = (m, b).
    For example, the specification width=14cm, left=3cm is categorized into S(1,1), which is an adequate
specification. If you add right=4cm, it would be in S(2,1) and overspecified. If only width=14cm is given,
it’s in S(0,1), underspecified.
    The geometry package has the auto-completion mechanism, in which if the layout parameters are
underspecified or overspecified, geometry works out the ambiguity using the defaults and other relations.
Here are the specifications and the completion rules.
      S(0,0) Nothing is specified. The geometry package sets body with the default scale (= 0.7).
             For example, width is set to be 0.7 × layoutwidth. Note that by default
             layoutwidth and layoutheight will be equal to \paperwidth and \paperheight
             respectively. Thus S(0,0) goes to S(0,1). See S(0,1).
                                                   13
                                             margin
                         0                     1                              2
                      S(0,0)                  S(1,0)                        S(2,0)
           0        use scale               use scale                      solvable
                                                    if ratio       P
                                                                   P
                                                                   
                                                                   
                                                    specified                 B
  body
                        BB                   BB
           1     use marginratio           solvable
                                          P
                                          P
                                                                      forget body
                       S(0,1)                S(1,1)                        S(2,1)
    Figure 7: Specifications S(0,0) to S(2,1) and the completion rules (arrows). Column and
               row numbers denote the number of explicitly specified lengths for margin and
               body respectively. S(m,b) denote a specification with a set of the numbers
               (margin, body) = (m, b).
       As for the horizontal margin ratio, the default value depends on whether the
       document is onesided or twosided,
                                                   
                                                      1:1      default for oneside,
                  left (inner) : right (outer) =                                              (9)
                                                      2:3      default for twoside.
       For example, if height=22cm is specified on A4 paper, geometry calculates top margin
       as follows:
                             top = (layoutheight − height) × 2/5
                                                                                       (10)
                                  = (29.7 − 22) × 2/5 = 3.08(cm)
       Thus top margin and body height have been determined, the specification for the
       vertical goes to S(1,1) and all the parameters can be solved.
S(1,0) Only one margin is specified, such as bottom=2cm, left=1in, top=3cm, and so forth.
          • If the margin ratio is not specified, geometry sets body with the default
            scale (= 0.7). For example, if top=2.4cm is specified, geometry sets
                   height = 0.7 × layoutheight (= 0.7\paperheight by default),
            then S(1,0) goes to S(1,1), in which bottom is calculated with
            layoutheight − (height + top) and results in 6.51cm on A4 paper if the layout
            size is equal to the paper size.
       Note that the version 4 or earlier used to set the other margin with the margin ratio.
       In the version 5, therefore, with the same specification, the result will be different
       from the one in the version 4. For example, if only top=2.4cm is specified, you got
       bottom=2.4cm in the version 4 or earlier, but you will get bottom=6.51cm in the
       version 5.
                                              14
     S(2,1) The body and two margins are all specified, such as vdivide={1in,8in,1.5in},
            “left=3cm,width=13cm,right=4cm” and so forth. Since geometry basically gives
            priority to margins if dimensions are overspecified, geometry forgets and resets body.
            For example, if you specify
\usepackage[a4paper,left=3cm,width=13cm,right=4cm]{geometry},
                 Layout L2 (new)
          \restoregeometry
                 Layout L1 (restored)
          \newgeometry{margin=1cm,includefoot}
                 Layout L3 (new)
          \end{document}
                 foot                                            foot
                                                                                        foot
                                         foot
                  L1                  L2 (new)               L1 (restored)            L3 (new)
                                                   15
      \restoregeometry
            L1 (restored)
      \newgeometry{margin=1cm,includefoot}
            L3 (new)
      \loadgeometry{L2}
            L2 (loaded)
      \end{document}
8     Examples
    1. A onesided page layout with the text area centered in the paper. The examples below have the
       same result because the horizontal margin ratio is set 1:1 for oneside by default.
         • centering
         • marginratio=1:1
         • vcentering
    2. A twosided page layout with the inside offset for binding set to 1cm.
         • twoside, bindingoffset=1cm
      In this case, textwidth is shorter than that of the default twosided document by 0.7×1cm (= 0.7cm)
      because the default width of body is set with scale=0.7, which means width = 0.7 × layoutwidth
      (= 0.7\paperwidth by default).
    3. A layout with the left, right, and top margin 3cm, 2cm and 2.5in respectively, with textheight of
       40 lines, and with the head and foot of the page included in total body. The two examples below
       have the same result.
         • left=3cm, right=2cm, lines=40, top=2.5in, includeheadfoot
         • hmargin={3cm,2cm}, tmargin=2.5in, lines=40, includeheadfoot
    4. A layout with the height of total body 10in, the bottom margin 2cm, and the default width. The
       top margin will be calculated automatically. Each solution below results in the same page layout.
         • vdivide={*, 10in, 2cm}
         • bmargin=2cm, height=10in
         • bottom=2cm, textheight=10in
      Note that dimensions for head and foot are excluded from height of total body. An additional
      includefoot makes \footskip included in totalheight. Therefore, in the two cases below,
      textheight in the former layout is shorter than the latter (with 10in exactly) by \footskip.
      In other words, height = textheight + footskip when includefoot=true in this case.
         • bmargin=2cm, height=10in, includefoot
         • bottom=2cm, textheight=10in, includefoot
    5. A layout with textwidth and textheight 90% of the paper and with body centered. Each solution
       below results in the same page layout as long as layoutwidth and layoutheight are not modified
       from the default.
         • scale=0.9, centering
         • text={.9\paperwidth,.9\paperheight}, ratio=1:1
         • width=.9\paperwidth, vmargin=.05\paperheight, marginratio=1:1
         • hdivide={*,0.9\paperwidth,*}, vdivide={*,0.9\paperheight,*} (as for onesided docu-
           ments)
         • margin={0.05\paperwidth,0.05\paperheight}
      You can add heightrounded to avoid an “underfull vbox warning” like
            Underfull \vbox (badness 10000) has occurred while \output is active.
                                                    16
      See Section 5.3 for the detailed description about heightrounded.
    6. A layout with the width of marginal notes set to 3cm and included in the width of total body. The
       following examples are the same.
         • marginparwidth=3cm, includemp
         • marginpar=3cm, ignoremp=false
    7. A layout where body occupies the whole paper with A5 paper in landscape. The following examples
       are the same.
         • a5paper, landscape, scale=1.0
         • landscape=TRUE, paper=a5paper, margin=0pt
    8. A screen size layout appropriate for presentation with PC and video projector.
          \documentclass{slide}
          \usepackage[screen,margin=0.8in]{geometry}
           ...
          \begin{slide}
             ...
          \end{slide}
    9. A layout with fonts and spaces both enlarged from A4 to A3. In the case below, the resulting paper
       size is A3.
         • a4paper, mag=1414.
      If you want to have a layout with two times bigger fonts, but without changing paper size, you can
      type
         • letterpaper, mag=2000, truedimen.
      You can add dvips option, that is useful to preview it with proper paper size by dviout or xdvi.
10. Changing the layout of the first page and leaving the others as default before loading geometry. Use
    pass option, \newgeometry and \restoregeometry.
          \documentclass{book}
          \usepackage[pass]{geometry}
             % ’pass’ disregards the package layout,
             % so the original ’book’ layout is memorized here.
          \begin{document}
          \newgeometry{margin=1cm}% changes the first page dimensions.
             Page 1
          \restoregeometry % restores the original ’book’ layout.
             Page 2 and more
          \end{document}
9     Known problems
    • With mag 6= 1000 and truedimen, paperwidth and paperheight shown in verbose mode are dif-
      ferent from the real size of the resulted PDF. The PDF itself is correct anyway.
    • With mag 6= 1000, no truedimen and hyperref, hyperref should be loaded before geometry. Otherwise
      the resulted PDF size will become wrong.
    • With crop package and mag 6= 1000, center option of crop doesn’t work well.
                                                   17
10     Acknowledgments
The author appreciates helpful suggestions and comments from many people including (in alphabetical
order of family name): Jean-Bernard Addor, Frank Bennett, Alexis Dimitriadis, Friedrich Flender, Adrian
Heathcote, Stephan Hennig, Morten Høgholm, Jonathan Kew, James Kilfiger, Yusuke Kuroki, Jean-
Marc Lasgouttes, Wlodzimierz Macewicz, Frank Mittelbach, Eckhard Neber, Rolf Niepraschk, Hans
Fr. Nordhaug, Heiko Oberdiek, Keith Reckdahl, Peter Riocreux, Will Robertson, Pablo Rodriguez, Nico
Schlöemer, Perry C. Stearns, Frank Stengel, Plamen Tanovski, Petr Uher, Piet van Oostrum, Vladimir
Volovich, Michael Vulis.
                                                  18
                    11        Implementation
                    1    h∗packagei
                    This package requires the following packages: keyval, ifvtex.
                    2    \RequirePackage{keyval}%
                    3    \RequirePackage{ifvtex}%
                          Internal switches are declared here.
                    4  \newif\ifGm@verbose
                     5 \newif\ifGm@landscape
                     6 \newif\ifGm@swap@papersize
                     7 \newif\ifGm@includehead
                     8 \newif\ifGm@includefoot
                     9 \newif\ifGm@includemp
                    10 \newif\ifGm@hbody
                    11 \newif\ifGm@vbody
                    12 \newif\ifGm@heightrounded
                    13 \newif\ifGm@showframe
                    14 \newif\ifGm@showcrop
                    15 \newif\ifGm@pass
                    16 \newif\ifGm@resetpaper
                    17 \newif\ifGm@layout
                    18 \newif\ifGm@newgm
       \Gm@wd@mp    Correction lengths for \textwidth, \oddsidemargin and \evensidemargin in includemp mode.
      \Gm@odd@mp    23 \newdimen\Gm@wd@mp
     \Gm@even@mp    24 \newdimen\Gm@odd@mp
                    25 \newdimen\Gm@even@mp
  \ifGm@preamble    The macro executes the option given as an argument only if it’s specified in the preamble, as the
                    options of \usepackage and/or the argument of \geometry. Otherwise, the macro would print the
                    warning message and ignores the option setting.
                    32 \def\ifGm@preamble#1{%
                    33   \ifGm@newgm
                    34    \Gm@warning{‘#1’: not available in ‘\string\newgeometry’; skipped}%
                    35   \else
                    36     \expandafter\@firstofone
                    37   \fi}%
     \Gm@Dhratio    The default values for the horizontal and vertical marginalratio are defined. \Gm@Dhratiotwo denotes
  \Gm@Dhratiotwo    the default value of horizontal marginratio for twoside page layout with left and right margins
     \Gm@Dvratio    swapped on verso pages, which is set by twoside.
                    38 \def\Gm@Dhratio{1:1}% = left:right default for oneside
                    39 \def\Gm@Dhratiotwo{2:3}% = inner:outer default for twoside.
                    40 \def\Gm@Dvratio{2:3}% = top:bottom default
                                                                      19
   \Gm@Dhscale    The default values for the horizontal and vertical scale are defined with 0.7.
   \Gm@Dvscale    41   \def\Gm@Dhscale{0.7}%
                  42   \def\Gm@Dvscale{0.7}%
      \Gm@save    The definition of the macro saving the real lengths LATEX options.
                  63 \def\Gm@save{%
                  64   \Gm@savelength{paperwidth}%
                  65   \Gm@savelength{paperheight}%
                  66   \Gm@savelength{textwidth}%
                  67   \Gm@savelength{textheight}%
                  68   \Gm@savelength{evensidemargin}%
                  69   \Gm@savelength{oddsidemargin}%
                  70   \Gm@savelength{topmargin}%
                  71   \Gm@savelength{headheight}%
                  72   \Gm@savelength{headsep}%
                  73   \Gm@savelength{topskip}%
                  74   \Gm@savelength{footskip}%
                  75   \Gm@savelength{baselineskip}%
                  76   \Gm@savelength{marginparwidth}%
                  77   \Gm@savelength{marginparsep}%
                  78   \Gm@savelength{columnsep}%
                  79   \Gm@savelength{hoffset}%
                  80   \Gm@savelength{voffset}
                  81   \Gm@savelength{Gm@layoutwidth}%
                  82   \Gm@savelength{Gm@layoutheight}%
                  83   \Gm@savelength{Gm@layouthoffset}%
                  84   \Gm@savelength{Gm@layoutvoffset}%
                  85   \Gm@saveboolean{@twocolumn}%
                  86   \Gm@saveboolean{@twoside}%
                  87   \Gm@saveboolean{@mparswitch}%
                  88   \Gm@saveboolean{@reversemargin}}%
                                                                   20
  \Gm@initnewgm   The macro initializes the parameters for layout in \newgeometry.
                  89  \def\Gm@initnewgm{%
                  90    \Gm@passfalse
                   91   \Gm@swap@papersizefalse
                   92   \Gm@dimlist={}
                   93   \Gm@hbodyfalse
                   94   \Gm@vbodyfalse
                   95   \Gm@heightroundedfalse
                   96   \Gm@includeheadfalse
                   97   \Gm@includefootfalse
                   98   \Gm@includempfalse
                   99   \let\Gm@width\@undefined
                  100   \let\Gm@height\@undefined
                  101   \let\Gm@textwidth\@undefined
                  102   \let\Gm@textheight\@undefined
                  103   \let\Gm@lines\@undefined
                  104   \let\Gm@hscale\@undefined
                  105   \let\Gm@vscale\@undefined
                  106   \let\Gm@hmarginratio\@undefined
                  107   \let\Gm@vmarginratio\@undefined
                  108   \let\Gm@lmargin\@undefined
                  109   \let\Gm@rmargin\@undefined
                  110   \let\Gm@tmargin\@undefined
                  111   \let\Gm@bmargin\@undefined
                  112   \Gm@layoutfalse
                  113   \Gm@layouthoffset\z@
                  114   \Gm@layoutvoffset\z@
                  115   \Gm@bindingoffset\z@}%
   \Gm@initall    This initialization is called as soon as the package is load It’s also called as soon as reset option is
                  specified.
                  116 \def\Gm@initall{%
                  117   \let\Gm@driver\@empty
                  118   \let\Gm@truedimen\@empty
                  119   \let\Gm@paper\@undefined
                  120   \Gm@resetpaperfalse
                  121   \Gm@landscapefalse
                  122   \Gm@verbosefalse
                  123   \Gm@showframefalse
                  124   \Gm@showcropfalse
                  125   \Gm@newgmfalse
                  126   \Gm@initnewgm}%
\Gm@unsetdriver   The macro unsets the specified driver if it has been set.
                  129   \def\Gm@unsetdriver#1{%
                  130     \expandafter\ifx\csname Gm@#1\endcsname\Gm@driver\let\Gm@driver\@empty\fi}%
      \Gm@doif    \Gm@doif excutes the third argument #3 using a boolean value #2 of a option #1. \Gm@doifelse
  \Gm@doifelse    executes the third argument #3 if a boolean option #1 with its value #2 true, and executes the fourth
                  argument #4 if false.
                  136 \def\Gm@doif#1#2#3{%
                  137   \lowercase{\def\Gm@bool{#2}}%
                  138   \ifx\Gm@bool\@empty
                                                                    21
                 139     \let\Gm@bool\Gm@true
                 140   \fi
                 141   \ifx\Gm@bool\Gm@true
                 142   \else
                 143     \ifx\Gm@bool\Gm@false
                 144     \else
                 145        \let\Gm@bool\relax
                 146     \fi
                 147   \fi
                 148   \ifx\Gm@bool\relax
                 149     \Gm@warning{‘#1’ should be set to ‘true’ or ‘false’}%
                 150   \else
                 151     #3
                 152   \fi}%
                 153 \def\Gm@doifelse#1#2#3#4{%
                 154   \Gm@doif{#1}{#2}{\ifx\Gm@bool\Gm@true #3\else #4\fi}}%
  \Gm@defbylen   Macros \Gm@defbylen and \Gm@defbycnt can be used to define \Gm@xxxx variables by length and
  \Gm@defbycnt   counter respectively with calc package.
                 158 \def\Gm@defbylen#1#2{%
                 159   \begingroup\setlength\@tempdima{#2}%
                 160   \expandafter\xdef\csname Gm@#1\endcsname{\the\@tempdima}\endgroup}%
                 161 \def\Gm@defbycnt#1#2{%
                 162   \begingroup\setcounter{Gm@tempcnt}{#2}%
                 163   \expandafter\xdef\csname Gm@#1\endcsname{\the\value{Gm@tempcnt}}\endgroup}%
 \Gm@set@ratio   The macro parses the value of options specifying marginal ratios, which is used in \Gm@setbyratio
                 macro.
                 164   \def\Gm@sep@ratio#1:#2{\@tempcnta=#1\@tempcntb=#2}%
\Gm@setbyratio   The macro determines the dimension specified by #4 calculating #3×a/b, where a and b are given
                 by \Gm@mratio with a : b value. If #1 in brackets is b, a and b are swapped. The second argument
                 with h or v denoting horizontal or vertical is not used in this macro.
                 165 \def\Gm@setbyratio[#1]#2#3#4{% determine #4 by ratio
                 166   \expandafter\Gm@sep@ratio\Gm@mratio\relax
                 167   \if#1b
                 168     \edef\@@tempa{\the\@tempcnta}%
                 169     \@tempcnta=\@tempcntb
                 170     \@tempcntb=\@@tempa\relax
                 171   \fi
                 172   \expandafter\setlength\expandafter\@tempdimb\expandafter
                 173     {\csname Gm@#3\endcsname}%
                 174   \ifnum\@tempcntb>\z@
                 175     \multiply\@tempdimb\@tempcnta
                 176     \divide\@tempdimb\@tempcntb
                 177   \fi
                 178   \expandafter\edef\csname Gm@#4\endcsname{\the\@tempdimb}}%
     \Gm@detiv   This macro determines the fourth length(#4) from #1(layoutwidth or layoutheight), #2 and #3. It is
                 used in \Gm@detall macro.
                 179 \def\Gm@detiv#1#2#3#4{% determine #4.
                 180   \expandafter\setlength\expandafter\@tempdima\expandafter
                 181     {\csname Gm@layout#1\endcsname}%
                 182   \expandafter\setlength\expandafter\@tempdimb\expandafter
                 183     {\csname Gm@#2\endcsname}%
                 184   \addtolength\@tempdima{-\@tempdimb}%
                 185   \expandafter\setlength\expandafter\@tempdimb\expandafter
                 186     {\csname Gm@#3\endcsname}%
                 187   \addtolength\@tempdima{-\@tempdimb}%
                                                                 22
                  188   \ifdim\@tempdima<\z@
                  189     \Gm@warning{‘#4’ results in NEGATIVE (\the\@tempdima).%
                  190     ^^J\@spaces ‘#2’ or ‘#3’ should be shortened in length}%
                  191   \fi
                  192   \expandafter\edef\csname Gm@#4\endcsname{\the\@tempdima}}%
\Gm@detiiandiii   This macro determines #2 and #3 from #1 with the first argument (#1) can be width or height,
                  which is expanded into dimensions of paper and total body. It is used in \Gm@detall macro.
                  193 \def\Gm@detiiandiii#1#2#3{% determine #2 and #3.
                  194   \expandafter\setlength\expandafter\@tempdima\expandafter
                  195     {\csname Gm@layout#1\endcsname}%
                  196   \expandafter\setlength\expandafter\@tempdimb\expandafter
                  197     {\csname Gm@#1\endcsname}%
                  198   \addtolength\@tempdima{-\@tempdimb}%
                  199   \ifdim\@tempdima<\z@
                  200     \Gm@warning{‘#2’ and ‘#3’ result in NEGATIVE (\the\@tempdima).%
                  201                   ^^J\@spaces ‘#1’ should be shortened in length}%
                  202   \fi
                  203   \ifx\Gm@mratio\@undefined
                  204     \expandafter\Gm@sep@ratio\Gm@Dmratio\relax
                  205   \else
                  206     \expandafter\Gm@sep@ratio\Gm@mratio\relax
                  207     \ifnum\@tempcntb>\z@\else
                  208       \Gm@warning{margin ratio a:b should be non-zero; default used}%
                  209       \expandafter\Gm@sep@ratio\Gm@Dmratio\relax
                  210     \fi
                  211   \fi
                  212   \@tempdimb=\@tempdima
                  213   \advance\@tempcntb\@tempcnta
                  214   \divide\@tempdima\@tempcntb
                  215   \multiply\@tempdima\@tempcnta
                  216   \advance\@tempdimb-\@tempdima
                  217   \expandafter\edef\csname Gm@#2\endcsname{\the\@tempdima}%
                  218   \expandafter\edef\csname Gm@#3\endcsname{\the\@tempdimb}}%
    \Gm@detall    This macro determines partition of each direction. The first argument (#1) should be h or v, the
                  second (#2) width or height, the third (#3) lmargin or top, and the last (#4) rmargin or bottom.
                  219 \def\Gm@detall#1#2#3#4{%
                  220   \@tempcnta\z@
                  221   \if#1h
                  222     \let\Gm@mratio\Gm@hmarginratio
                  223     \edef\Gm@Dmratio{\if@twoside\Gm@Dhratiotwo\else\Gm@Dhratio\fi}%
                  224   \else
                  225     \let\Gm@mratio\Gm@vmarginratio
                  226     \edef\Gm@Dmratio{\Gm@Dvratio}%
                  227   \fi
                  \@tempcnta is treated as a three-digit binary value with top, middle and bottom denoted left(top),
                  width(height) and right(bottom) margins user specified respectively.
                  228   \if#1h
                  229     \ifx\Gm@lmargin\@undefined\else\advance\@tempcnta4\relax\fi
                  230     \ifGm@hbody\advance\@tempcnta2\relax\fi
                  231     \ifx\Gm@rmargin\@undefined\else\advance\@tempcnta1\relax\fi
                  232     \Gm@cnth\@tempcnta
                  233   \else
                  234     \ifx\Gm@tmargin\@undefined\else\advance\@tempcnta4\relax\fi
                  235     \ifGm@vbody\advance\@tempcnta2\relax\fi
                  236     \ifx\Gm@bmargin\@undefined\else\advance\@tempcnta1\relax\fi
                  237     \Gm@cntv\@tempcnta
                  238   \fi
                  Case the value is 000 (=0) with nothing fixed (default):
                  239   \ifcase\@tempcnta
                  240     \if#1h
                  241       \Gm@defbylen{width}{\Gm@Dhscale\Gm@layoutwidth}%
                  242     \else
                                                                  23
            243       \Gm@defbylen{height}{\Gm@Dvscale\Gm@layoutheight}%
            244     \fi
            245     \Gm@detiiandiii{#2}{#3}{#4}%
            Case 001 (=1) with right(bottom) fixed:
            246   \or
            247     \ifx\Gm@mratio\@undefined
            248       \if#1h
            249         \Gm@defbylen{width}{\Gm@Dhscale\Gm@layoutwidth}%
            250       \else
            251         \Gm@defbylen{height}{\Gm@Dvscale\Gm@layoutheight}%
            252       \fi
            253       \setlength\@tempdimc{\@nameuse{Gm@#4}}%
            254       \Gm@detiiandiii{#2}{#3}{#4}%
            255       \expandafter\let\csname Gm@#2\endcsname\@undefined
            256       \Gm@defbylen{#4}{\@tempdimc}%
            257     \else
            258       \Gm@setbyratio[f]{#1}{#4}{#3}%
            259     \fi
            260     \Gm@detiv{#2}{#3}{#4}{#2}%
            Case 010 (=2) with width(height) fixed:
            261   \or\Gm@detiiandiii{#2}{#3}{#4}%
            Case 011 (=3) with both width(height) and right(bottom) fixed:
            262   \or\Gm@detiv{#2}{#2}{#4}{#3}%
            Case 100 (=4) with left(top) fixed:
            263   \or
            264     \ifx\Gm@mratio\@undefined
            265       \if#1h
            266         \Gm@defbylen{width}{\Gm@Dhscale\Gm@layoutwidth}%
            267       \else
            268         \Gm@defbylen{height}{\Gm@Dvscale\Gm@layoutheight}%
            269       \fi
            270       \setlength\@tempdimc{\@nameuse{Gm@#3}}%
            271       \Gm@detiiandiii{#2}{#4}{#3}%
            272       \expandafter\let\csname Gm@#2\endcsname\@undefined
            273       \Gm@defbylen{#3}{\@tempdimc}%
            274     \else
            275       \Gm@setbyratio[b]{#1}{#3}{#4}%
            276     \fi
            277     \Gm@detiv{#2}{#3}{#4}{#2}%
            Case 101 (=5) with both left(top) and right(bottom) fixed:
            278   \or\Gm@detiv{#2}{#3}{#4}{#2}%
            Case 110 (=6) with both left(top) and width(height) fixed:
            279   \or\Gm@detiv{#2}{#2}{#3}{#4}%
            Case 111 (=7) with all fixed though it is over-specified:
            280   \or\Gm@warning{Over-specification in ‘#1’-direction.%
            281                   ^^J\@spaces ‘#2’ (\@nameuse{Gm@#2}) is ignored}%
            282     \Gm@detiv{#2}{#3}{#4}{#2}%
            283   \else\fi}%
\Gm@clean   The macro for setting unspecified dimensions to be \@undefined. This is used by \geometry macro.
            284 \def\Gm@clean{%
            285   \ifnum\Gm@cnth<4\let\Gm@lmargin\@undefined\fi
            286   \ifodd\Gm@cnth\else\let\Gm@rmargin\@undefined\fi
            287   \ifnum\Gm@cntv<4\let\Gm@tmargin\@undefined\fi
            288   \ifodd\Gm@cntv\else\let\Gm@bmargin\@undefined\fi
            289   \ifGm@hbody\else
            290     \let\Gm@hscale\@undefined
            291     \let\Gm@width\@undefined
            292     \let\Gm@textwidth\@undefined
            293   \fi
            294   \ifGm@vbody\else
                                                             24
                    295      \let\Gm@vscale\@undefined
                    296      \let\Gm@height\@undefined
                    297      \let\Gm@textheight\@undefined
                    298   \fi
                    299   }%
      \Gm@branch    The macro splits a value into the same two values.
                    317 \def\Gm@branch#1#2#3{%
                    318   \@tempcnta\z@
                    319   \@for\Gm@tmp:=#1\do{%
                    320     \KV@@sp@def\Gm@frag{\Gm@tmp}%
                    321     \edef\Gm@value{\Gm@frag}%
                    322     \ifcase\@tempcnta\relax% cnta == 0
                    323       \setkeys{Gm}{#2=\Gm@value}%
                    324     \or% cnta == 1
                    325       \setkeys{Gm}{#3=\Gm@value}%
                    326     \else\fi
                    327     \advance\@tempcnta\@ne}%
                    328   \ifnum\@tempcnta=\@ne
                    329     \setkeys{Gm}{#3=\Gm@value}%
                    330   \fi}%
   \Gm@setlength    This macro stores LATEX native dimensions, which are stored and set afterwards.
                    340 \def\Gm@setlength#1#2{%
                    341   \let\Gm@len=\relax\let\Gm@td=\relax
                    342   \edef\addtolist{\noexpand\Gm@dimlist=%
                    343   {\the\Gm@dimlist \Gm@len{#1}{#2}}}\addtolist}%
                                                                     25
      \Gm@setsize    The macro sets paperwidth and paperheight dimensions using \Gm@setlength macro.
                     348 \def\Gm@setsize#1(#2,#3)#4{%
                     349   \let\Gm@td\relax
                     350   \expandafter\Gm@setlength\csname #1width\endcsname{#2\Gm@td #4}%
                     351   \expandafter\Gm@setlength\csname #1height\endcsname{#3\Gm@td #4}%
                     352   \ifGm@landscape\Gm@swap@papersizetrue\else\Gm@swap@papersizefalse\fi}%
                                                                       26
                 404 \define@key{Gm}{b3paper}[true]{\Gm@setpaper@ifpre{b3paper}}%
                 405 \define@key{Gm}{b4paper}[true]{\Gm@setpaper@ifpre{b4paper}}%
                 406 \define@key{Gm}{b5paper}[true]{\Gm@setpaper@ifpre{b5paper}}%
                 407 \define@key{Gm}{b6paper}[true]{\Gm@setpaper@ifpre{b6paper}}%
                 408 \define@key{Gm}{c0paper}[true]{\Gm@setpaper@ifpre{c0paper}}%
                 409 \define@key{Gm}{c1paper}[true]{\Gm@setpaper@ifpre{c1paper}}%
                 410 \define@key{Gm}{c2paper}[true]{\Gm@setpaper@ifpre{c2paper}}%
                 411 \define@key{Gm}{c3paper}[true]{\Gm@setpaper@ifpre{c3paper}}%
                 412 \define@key{Gm}{c4paper}[true]{\Gm@setpaper@ifpre{c4paper}}%
                 413 \define@key{Gm}{c5paper}[true]{\Gm@setpaper@ifpre{c5paper}}%
                 414 \define@key{Gm}{c6paper}[true]{\Gm@setpaper@ifpre{c6paper}}%
                 415 \define@key{Gm}{b0j}[true]{\Gm@setpaper@ifpre{b0j}}%
                 416 \define@key{Gm}{b1j}[true]{\Gm@setpaper@ifpre{b1j}}%
                 417 \define@key{Gm}{b2j}[true]{\Gm@setpaper@ifpre{b2j}}%
                 418 \define@key{Gm}{b3j}[true]{\Gm@setpaper@ifpre{b3j}}%
                 419 \define@key{Gm}{b4j}[true]{\Gm@setpaper@ifpre{b4j}}%
                 420 \define@key{Gm}{b5j}[true]{\Gm@setpaper@ifpre{b5j}}%
                 421 \define@key{Gm}{b6j}[true]{\Gm@setpaper@ifpre{b6j}}%
                 422 \define@key{Gm}{ansiapaper}[true]{\Gm@setpaper@ifpre{ansiapaper}}%
                 423 \define@key{Gm}{ansibpaper}[true]{\Gm@setpaper@ifpre{ansibpaper}}%
                 424 \define@key{Gm}{ansicpaper}[true]{\Gm@setpaper@ifpre{ansicpaper}}%
                 425 \define@key{Gm}{ansidpaper}[true]{\Gm@setpaper@ifpre{ansidpaper}}%
                 426 \define@key{Gm}{ansiepaper}[true]{\Gm@setpaper@ifpre{ansiepaper}}%
                 427 \define@key{Gm}{letterpaper}[true]{\Gm@setpaper@ifpre{letterpaper}}%
                 428 \define@key{Gm}{legalpaper}[true]{\Gm@setpaper@ifpre{legalpaper}}%
                 429 \define@key{Gm}{executivepaper}[true]{\Gm@setpaper@ifpre{executivepaper}}%
                 430 \define@key{Gm}{screen}[true]{\Gm@setpaper@ifpre{screen}}%
     ‘hscale’    These options can determine the length(s) of total body giving scale(s) against the paper size.
     ‘vscale’    450 \define@key{Gm}{hscale}{\Gm@hbodytrue\edef\Gm@hscale{#1}}%
      ‘scale’    451 \define@key{Gm}{vscale}{\Gm@vbodytrue\edef\Gm@vscale{#1}}%
                 452 \define@key{Gm}{scale}{\Gm@branch{#1}{hscale}{vscale}}%
       ‘width’   These options give concrete dimension(s) of total body. totalwidth and totalheight are aliases of
      ‘height’   width and height respectively.
       ‘total’   453 \define@key{Gm}{width}{\Gm@hbodytrue\Gm@defbylen{width}{#1}}%
  ‘totalwidth’   454 \define@key{Gm}{height}{\Gm@vbodytrue\Gm@defbylen{height}{#1}}%
 ‘totalheight’   455 \define@key{Gm}{total}{\Gm@branch{#1}{width}{height}}%
                 456 \let\KV@Gm@totalwidth\KV@Gm@width
                 457 \let\KV@Gm@totalheight\KV@Gm@height
                                                                     27
      ‘textwidth’   These options directly sets the dimensions \textwidth and \textheight. body is an alias of text.
     ‘textheight’   458 \define@key{Gm}{textwidth}{\Gm@hbodytrue\Gm@defbylen{textwidth}{#1}}%
           ‘text’   459 \define@key{Gm}{textheight}{\Gm@vbodytrue\Gm@defbylen{textheight}{#1}}%
           ‘body’   460 \define@key{Gm}{text}{\Gm@branch{#1}{textwidth}{textheight}}%
                    461 \let\KV@Gm@body\KV@Gm@text
     ‘ignorehead’   These options exclude head, foot and marginpars when determining body.
     ‘ignorefoot’   472 \define@key{Gm}{ignorehead}[true]{%
 ‘ignoreheadfoot’   473   \Gm@setboolrev[ignorehead]{includehead}{#1}}%
       ‘ignoremp’   474 \define@key{Gm}{ignorefoot}[true]{%
      ‘ignoreall’   475   \Gm@setboolrev[ignorefoot]{includefoot}{#1}}%
                    476 \define@key{Gm}{ignoreheadfoot}[true]{\Gm@doifelse{ignoreheadfoot}{#1}%
                    477   {\Gm@includeheadfalse\Gm@includefootfalse}%
                    478   {\Gm@includeheadtrue\Gm@includefoottrue}}%
                    479 \define@key{Gm}{ignoremp}[true]{%
                    480   \Gm@setboolrev[ignoremp]{includemp}{#1}}%
                    481 \define@key{Gm}{ignoreall}[true]{\Gm@doifelse{ignoreall}{#1}%
                    482   {\Gm@includeheadfalse\Gm@includefootfalse\Gm@includempfalse}%
                    483   {\Gm@includeheadtrue\Gm@includefoottrue\Gm@includemptrue}}%
       ‘hdivide’    The options are useful to specify partitioning in each direction of the paper.
       ‘vdivide’    485 \define@key{Gm}{hdivide}{\Gm@parse@divide{#1}{lmargin}{width}{rmargin}}%
        ‘divide’    486 \define@key{Gm}{vdivide}{\Gm@parse@divide{#1}{tmargin}{height}{bmargin}}%
                    487 \define@key{Gm}{divide}{\Gm@parse@divide{#1}{lmargin}{width}{rmargin}%
                    488   \Gm@parse@divide{#1}{tmargin}{height}{bmargin}}%
        ‘lmargin’   These options set margins. left, inner, innermargin are aliases of lmargin. right, outer,
        ‘rmargin’   outermargin are aliases of rmargin. top and bottom are aliases of tmargin and bmargin respec-
        ‘tmargin’   tively.
        ‘bmargin’   489 \define@key{Gm}{lmargin}{\Gm@defbylen{lmargin}{#1}}%
           ‘left’   490 \define@key{Gm}{rmargin}{\Gm@defbylen{rmargin}{#1}}%
          ‘inner’   491 \let\KV@Gm@left\KV@Gm@lmargin
    ‘innermargin’   492 \let\KV@Gm@inner\KV@Gm@lmargin
          ‘right’   493 \let\KV@Gm@innermargin\KV@Gm@lmargin
                                                                     28
 ‘hmarginratio’    Options specifying the margin ratios.
 ‘vmarginratio’    505 \define@key{Gm}{hmarginratio}{\edef\Gm@hmarginratio{#1}}%
  ‘marginratio’    506 \define@key{Gm}{vmarginratio}{\edef\Gm@vmarginratio{#1}}%
       ‘hratio’    507 \define@key{Gm}{marginratio}{\Gm@branch{#1}{hmarginratio}{vmarginratio}}%
       ‘vratio’    508 \let\KV@Gm@hratio\KV@Gm@hmarginratio
        ‘ratio’    509 \let\KV@Gm@vratio\KV@Gm@vmarginratio
                   510 \let\KV@Gm@ratio\KV@Gm@marginratio
‘bindingoffset’    The macro adds the specified space to the inner margin.
                   521   \define@key{Gm}{bindingoffset}{\Gm@setlength\Gm@bindingoffset{#1}}%
       ‘nohead’    They are only shorthands to set head and/or foot to be 0pt.
       ‘nofoot’    527 \define@key{Gm}{nohead}[true]{\Gm@doifelse{nohead}{#1}%
   ‘noheadfoot’    528   {\Gm@setlength\headheight\z@\Gm@setlength\headsep\z@}{}}%
                   529 \define@key{Gm}{nofoot}[true]{\Gm@doifelse{nofoot}{#1}%
                   530   {\Gm@setlength\footskip\z@}{}}%
                   531 \define@key{Gm}{noheadfoot}[true]{\Gm@doifelse{noheadfoot}{#1}%
                   532   {\Gm@setlength\headheight\z@\Gm@setlength\headsep
                   533   \z@\Gm@setlength\footskip\z@}{}}%
      ‘hoffset’    The former two options set native dimensions \hoffset and \voffset. offset can set both of them
      ‘voffset’    with the same value.
       ‘offset’    541 \define@key{Gm}{hoffset}{\Gm@setlength\hoffset{#1}}%
                   542 \define@key{Gm}{voffset}{\Gm@setlength\voffset{#1}}%
                   543 \define@key{Gm}{offset}{\Gm@branch{#1}{hoffset}{voffset}}%
                                                                    29
  ‘layouthoffset’
  ‘layoutvoffset’    544 \define@key{Gm}{layouthoffset}{\Gm@setlength\Gm@layouthoffset{#1}}%
   ‘layoutoffset’    545 \define@key{Gm}{layoutvoffset}{\Gm@setlength\Gm@layoutvoffset{#1}}%
                     546 \define@key{Gm}{layoutoffset}{\Gm@branch{#1}{layouthoffset}{layoutvoffset}}%
         ‘dviver’
                     555 \define@key{Gm}{driver}{\ifGm@preamble{driver}{%
                     556   \edef\@@tempa{#1}\edef\@@auto{auto}\edef\@@none{none}%
                     557   \ifx\@@tempa\@empty\let\Gm@driver\relax\else
                     558   \ifx\@@tempa\@@none\let\Gm@driver\relax\else
                     559   \ifx\@@tempa\@@auto\let\Gm@driver\@empty\else
                     560   \setkeys{Gm}{#1}\fi\fi\fi\let\@@auto\relax\let\@@none\relax}}%
          ‘dvips’    The geometry package supports dvips, dvipdfm, pdflatex, luatex and vtex. dvipdfm works like
        ‘dvipdfm’    dvips.
       ‘dvipdfmx’    561 \define@key{Gm}{dvips}[true]{\ifGm@preamble{dvips}{%
      ‘xdvipdfmx’    562   \Gm@doifelse{dvips}{#1}{\Gm@setdriver{dvips}}{\Gm@unsetdriver{dvips}}}}%
         ‘pdftex’    563 \define@key{Gm}{dvipdfm}[true]{\ifGm@preamble{dvipdfm}{%
         ‘luatex’    564   \Gm@doifelse{dvipdfm}{#1}{\Gm@setdriver{dvipdfm}}{\Gm@unsetdriver{dvipdfm}}}}%
          ‘xetex’    565 \define@key{Gm}{dvipdfmx}[true]{\ifGm@preamble{dvipdfm}{%
           ‘reset’   The option cancels all the options specified before reset, except pass. mag (6= 1000) with truedimen
                     cannot be also reset.
                     578 \define@key{Gm}{reset}[true]{\ifGm@preamble{reset}{%
                     579   \Gm@doifelse{reset}{#1}{\Gm@restore@org\Gm@initall
                     580   \ProcessOptionsKV[c]{Gm}\Gm@setdefaultpaper}{}}}%
     ‘resetpaper’    If resetpaper is set to true, the paper size redefined in the package is discarded and the original one
                     is restored. This option may be useful to print nonstandard sized documents with normal printers
                     and papers.
                     581   \define@key{Gm}{resetpaper}[true]{\ifGm@preamble{resetpaper}{%
                     582     \Gm@setbool{resetpaper}{#1}}}%
            ‘mag’    mag is expanded immediately when it is specified. So reset can’t reset mag when it is set with
                     truedimen.
                     583   \define@key{Gm}{mag}{\ifGm@preamble{mag}{\mag=#1}}%
                                                                       30
       ‘truedimen’    If truedimen is set to true, all of the internal explicit dimensions is changed to true dimensions,
                      e.g., 1in is changed to 1truein.
                      584 \define@key{Gm}{truedimen}[true]{\ifGm@preamble{truedimen}{%
                      585   \Gm@doifelse{truedimen}{#1}{\let\Gm@truedimen\Gm@true}%
                      586   {\let\Gm@truedimen\@empty}}}%
            ‘pass’    The option makes all the options specified ineffective except verbose switch.
                      587   \define@key{Gm}{pass}[true]{\ifGm@preamble{pass}{\Gm@setbool{pass}{#1}}}%
       ‘showframe’    The showframe option prints page frames to help you understand what the resulting layout is like.
                      588   \define@key{Gm}{showframe}[true]{\Gm@setbool{showframe}{#1}}%
        ‘showcrop’    The showcrop option prints crop marks at each corner of the layout area.
                      589   \define@key{Gm}{showcrop}[true]{\Gm@setbool{showcrop}{#1}}%
\Gm@setdefaultpaper   The macro stores paper dimensions. This macro should be called after \ProcessOptionsKV[c]{Gm}.
                      If the landscape option in \documentclass is specified, the class immediately swaps the paper
                      dimensions.
                      590 \def\Gm@setdefaultpaper{%
                      591   \ifx\Gm@paper\@undefined
                      592     \Gm@setsize{paper}(\strip@pt\paperwidth,\strip@pt\paperheight){pt}%
                      593     \Gm@setsize{Gm@layout}(\strip@pt\paperwidth,\strip@pt\paperheight){pt}%
                      594     \Gm@swap@papersizefalse
                      595   \fi}%
   \Gm@adjustpaper    The macro checks if paperwidth/height is larger than 0pt, which is used in \Gm@process. The paper
                      dimensions can be swapped when paper orientation is changed over by landscape and portrait
                      options.
                      596 \def\Gm@adjustpaper{%
                      597   \ifdim\paperwidth>\p@\else
                      598     \PackageError{geometry}{%
                      599     \string\paperwidth\space(\the\paperwidth) too short}{%
                      600     Set a paper type (e.g., ‘a4paper’).}%
                      601   \fi
                      602   \ifdim\paperheight>\p@\else
                      603     \PackageError{geometry}{%
                      604     \string\paperheight\space(\the\paperheight) too short}{%
                      605     Set a paper type (e.g., ‘a4paper’).}%
                      606   \fi
                      607   \ifGm@swap@papersize
                      608     \setlength\@tempdima{\paperwidth}%
                      609     \setlength\paperwidth{\paperheight}%
                      610     \setlength\paperheight{\@tempdima}%
                      611   \fi
                      612   \ifGm@layout\else
                      613     \setlength\Gm@layoutwidth{\paperwidth}%
                      614     \setlength\Gm@layoutheight{\paperheight}%
                      615   \fi}%
       \Gm@checkmp    The macro checks whether or not the marginpars overrun the page.
                      616 \def\Gm@checkmp{%
                      617   \ifGm@includemp\else
                      618     \@tempcnta\z@\@tempcntb\@ne
                      619     \if@twocolumn
                      620       \@tempcnta\@ne
                      621     \else
                      622       \if@reversemargin
                      623         \@tempcnta\@ne\@tempcntb\z@
                      624       \fi
                      625     \fi
                      626     \@tempdima\marginparwidth
                      627     \advance\@tempdima\marginparsep
                      628     \ifnum\@tempcnta=\@ne
                      629       \@tempdimc\@tempdima
                                                                       31
                 630       \setlength\@tempdimb{\Gm@lmargin}%
                 631       \advance\@tempdimc-\@tempdimb
                 632       \ifdim\@tempdimc>\z@
                 633         \Gm@warning{The marginal notes overrun the    paper edge.^^J
                 634         \@spaces Add \the\@tempdimc\space and more    to the left margin}%
                 635       \fi
                 636     \fi
                 637     \ifnum\@tempcntb=\@ne
                 638       \@tempdimc\@tempdima
                 639       \setlength\@tempdimb{\Gm@rmargin}%
                 640       \advance\@tempdimc-\@tempdimb
                 641       \ifdim\@tempdimc>\z@
                 642         \Gm@warning{The marginal notes overrun the    paper.^^J
                 643         \@spaces Add \the\@tempdimc\space and more    to the right margin}%
                 644       \fi
                 645     \fi
                 646   \fi}%
 \Gm@adjustmp    The macro sets marginpar correction when includemp is set, which is used in \Gm@process. The
                 variables \Gm@wd@mp, \Gm@odd@mp and \Gm@even@mp are set here. Note that \Gm@even@mp should be
                 used only for twoside layout.
                 647 \def\Gm@adjustmp{%
                 648   \ifGm@includemp
                 649     \@tempdimb\marginparwidth
                 650     \advance\@tempdimb\marginparsep
                 651     \Gm@wd@mp\@tempdimb
                 652     \Gm@odd@mp\z@
                 653     \Gm@even@mp\z@
                 654     \if@twocolumn
                 655       \Gm@wd@mp2\@tempdimb
                 656       \Gm@odd@mp\@tempdimb
                 657       \Gm@even@mp\@tempdimb
                 658     \else
                 659       \if@reversemargin
                 660         \Gm@odd@mp\@tempdimb
                 661         \if@mparswitch\else
                 662           \Gm@even@mp\@tempdimb
                 663         \fi
                 664       \else
                 665         \if@mparswitch
                 666           \Gm@even@mp\@tempdimb
                 667         \fi
                 668       \fi
                 669     \fi
                 670   \fi}%
\Gm@adjustbody   If the horizontal dimension of body is specified by user, \Gm@width is set properly here.
                 671 \def\Gm@adjustbody{
                 672   \ifGm@hbody
                 673     \ifx\Gm@width\@undefined
                 674       \ifx\Gm@hscale\@undefined
                 675         \Gm@defbylen{width}{\Gm@Dhscale\Gm@layoutwidth}%
                 676       \else
                 677         \Gm@defbylen{width}{\Gm@hscale\Gm@layoutwidth}%
                 678       \fi
                 679     \fi
                 680     \ifx\Gm@textwidth\@undefined\else
                 681       \setlength\@tempdima{\Gm@textwidth}%
                 682       \ifGm@includemp
                 683         \advance\@tempdima\Gm@wd@mp
                 684       \fi
                 685       \edef\Gm@width{\the\@tempdima}%
                 686     \fi
                 687   \fi
                                                                  32
              If the vertical dimension of body is specified by user, \Gm@height is set properly here.
              688    \ifGm@vbody
              689      \ifx\Gm@height\@undefined
              690        \ifx\Gm@vscale\@undefined
              691          \Gm@defbylen{height}{\Gm@Dvscale\Gm@layoutheight}%
              692        \else
              693          \Gm@defbylen{height}{\Gm@vscale\Gm@layoutheight}%
              694        \fi
              695      \fi
              696      \ifx\Gm@lines\@undefined\else
              \topskip has to be adjusted so that the formula “\textheight = (lines − 1) × \baselineskip +
              \topskip” to be correct even if large font sizes are specified by users. If \topskip is smaller than
              \ht\strutbox, then \topskip is set to \ht\strutbox.
              697         \ifdim\topskip<\ht\strutbox
              698           \setlength\@tempdima{\topskip}%
              699           \setlength\topskip{\ht\strutbox}%
              700           \Gm@warning{\noexpand\topskip was changed from \the\@tempdima\space
              701           to \the\topskip}%
              702         \fi
              703         \setlength\@tempdima{\baselineskip}%
              704         \multiply\@tempdima\Gm@lines
              705         \addtolength\@tempdima{\topskip}%
              706         \addtolength\@tempdima{-\baselineskip}%
              707         \edef\Gm@textheight{\the\@tempdima}%
              708       \fi
              709       \ifx\Gm@textheight\@undefined\else
              710         \setlength\@tempdima{\Gm@textheight}%
              711         \ifGm@includehead
              712           \addtolength\@tempdima{\headheight}%
              713           \addtolength\@tempdima{\headsep}%
              714         \fi
              715         \ifGm@includefoot
              716           \addtolength\@tempdima{\footskip}%
              717         \fi
              718         \edef\Gm@height{\the\@tempdima}%
              719       \fi
              720     \fi}%
                                                               33
                   If includemp is set to true, \textwidth and \oddsidemargin are adjusted.
                   740    \ifGm@includemp
                   741      \advance\textwidth-\Gm@wd@mp
                   742      \advance\oddsidemargin\Gm@odd@mp
                   743    \fi
                   Determining \evensidemargin. In the twoside page layout, the right margin value \Gm@rmargin is
                   used. If the marginal note width is included, \evensidemargin should be corrected by \Gm@even@mp.
                   744     \if@mparswitch
                   745       \setlength\evensidemargin{\Gm@rmargin}%
                   746       \addtolength\evensidemargin{-1\Gm@truedimen in}%
                   747       \ifGm@includemp
                   748         \advance\evensidemargin\Gm@even@mp
                   749       \fi
                   750     \else
                   751       \evensidemargin\oddsidemargin
                   752     \fi
                   The bindingoffset correction for \oddsidemargin.
                   753     \advance\oddsidemargin\Gm@bindingoffset
                   754     \addtolength\topmargin{-1\Gm@truedimen in}%
                   If the head of the page is included in total body, \headheight and \headsep are removed from
                   \textheight, otherwise from \topmargin.
                   755     \ifGm@includehead
                   756       \addtolength\textheight{-\headheight}%
                   757       \addtolength\textheight{-\headsep}%
                   758     \else
                   759       \addtolength\topmargin{-\headheight}%
                   760       \addtolength\topmargin{-\headsep}%
                   761     \fi
                   If the foot of the page is included in total body, \footskip is removed from \textheight.
                   762     \ifGm@includefoot
                   763       \addtolength\textheight{-\footskip}%
                   764     \fi
                   If heightrounded is set, \textheight is rounded.
                   765     \ifGm@heightrounded
                   766       \setlength\@tempdima{\textheight}%
                   767       \addtolength\@tempdima{-\topskip}%
                   768       \@tempcnta\@tempdima
                   769       \@tempcntb\baselineskip
                   770       \divide\@tempcnta\@tempcntb
                   771       \setlength\@tempdimb{\baselineskip}%
                   772       \multiply\@tempdimb\@tempcnta
                   773       \advance\@tempdima-\@tempdimb
                   774       \multiply\@tempdima\tw@
                   775       \ifdim\@tempdima>\baselineskip
                   776         \addtolength\@tempdimb{\baselineskip}%
                   777       \fi
                   778       \addtolength\@tempdimb{\topskip}%
                   779       \textheight\@tempdimb
                   780     \fi
                   The paper width is set back by adding \Gm@bindingoffset.
                   781     \advance\oddsidemargin\Gm@layouthoffset%
                   782     \advance\evensidemargin\Gm@layouthoffset%
                   783     \advance\topmargin\Gm@layoutvoffset%
                   784     \addtolength\Gm@layoutwidth{\Gm@bindingoffset}%
                   785     }% end of \Gm@@process
\Gm@detectdriver   The macro checks the typeset environment and changes the driver option if necessary. To make the
                   engine detection more robust, the macro is rewritten with packages ifpdf, ifvtex and ifxetex.
                   786   \def\Gm@detectdriver{%
                                                                      34
                 If the driver option is not specified explicitly, then driver auto-detection works.
                 787   \ifx\Gm@driver\@empty
                 788     \typeout{*geometry* driver: auto-detecting}%
                 \ifpdf is defined in ifpdf package in ‘oberdiek’ bundle.
                 789     \ifpdf
                 790       \ifx\pdfextension\@undefined
                 791         \Gm@setdriver{pdftex}%
                 792       \else
                 793         \Gm@setdriver{luatex}%
                 794       \fi
                 795     \else
                 796       \Gm@setdriver{dvips}%
                 797     \fi
                 \ifvtex is defined in ifvtex package in ‘oberdiek’ bundle.
                 798     \ifvtex
                 799       \Gm@setdriver{vtex}%
                 800     \fi
                 \ifxetex is defined in ifxetex package written by Will Robertson.
                 801     \ifxetex
                 802       \Gm@setdriver{xetex}
                 803     \fi
                 When the driver option is set by the user, check if it is valid or not.
                 804   \else
                 805     \ifx\Gm@driver\Gm@xetex %%
                 806       \ifxetex\else
                 807         \Gm@warning{Wrong driver   setting: ‘xetex’; trying ‘pdftex’ driver}%
                 808         \Gm@setdriver{pdftex}
                 809       \fi
                 810     \fi
                 811     \ifx\Gm@driver\Gm@vtex
                 812       \ifvtex\else
                 813         \Gm@warning{Wrong driver   setting: ‘vtex’; trying ‘dvips’ driver}%
                 814         \Gm@setdriver{dvips}%
                 815       \fi
                 816     \fi
                 817   \fi
                 818   \ifx\Gm@driver\relax
                 819     \typeout{*geometry* detected   driver: <none>}%
                 820   \else
                 821     \typeout{*geometry* detected   driver: \Gm@driver}%
                 822   \fi}%
\Gm@showparams   Prints the resulted parammeters and dimensions to STDOUT if verbose is true. \Gm@width and
                 \Gm@height are expanded to get the real size.
                 823 \def\Gm@showparams#1{%
                 824   \ifGm@verbose\expandafter\typeout\else\expandafter\wlog\fi
                 825   {\Gm@logcontent{#1}}}%
                 826 \def\Gm@showdim#1{* \string#1=\the#1^^J}%
                 827 \def\Gm@showbool#1{\@nameuse{ifGm@#1}#1\space\fi}%
\Gm@logcontent   The content of geometry paramenters and native dimensions for the page layout.
                 828 \def\Gm@logcontent#1{%
                 829   *geometry* verbose mode - [ #1 ] result:^^J%
                 830   \ifGm@pass * pass: disregarded the geometry package!^^J%
                 831   \else
                 832   * driver: \if\Gm@driver<none>\else\Gm@driver\fi^^J%
                 833   * paper: \ifx\Gm@paper\@undefined<default>\else\Gm@paper\fi^^J%
                 834   * layout: \ifGm@layout<custom>\else<same size as paper>\fi^^J%
                 835   \ifGm@layout
                 836   * layout(width,height): (\the\Gm@layoutwidth,\the\Gm@layoutheight)^^J%
                 837   \fi
                 838   * layoutoffset:(h,v)=(\the\Gm@layouthoffset,\the\Gm@layoutvoffset)^^J%
                                                                   35
839    \@ifundefined{Gm@lines}{}{* lines: \Gm@lines^^J}%
840    \@ifundefined{Gm@hmarginratio}{}{* hratio: \Gm@hmarginratio^^J}%
841    \@ifundefined{Gm@vmarginratio}{}{* vratio: \Gm@vmarginratio^^J}%
842    \ifdim\Gm@bindingoffset=\z@\else
843    * bindingoffset: \the\Gm@bindingoffset^^J\fi
844    * modes: %
845     \Gm@showbool{landscape}%
846     \Gm@showbool{includehead}%
847     \Gm@showbool{includefoot}%
848     \Gm@showbool{includemp}%
849     \if@twoside twoside\space\fi%
850     \if@mparswitch\else\if@twoside asymmetric\space\fi\fi%
851     \Gm@showbool{heightrounded}%
852     \ifx\Gm@truedimen\@empty\else truedimen\space\fi%
853     \Gm@showbool{showframe}%
854     \Gm@showbool{showcrop}%
855    ^^J%
856    * h-part:(L,W,R)=(\Gm@lmargin, \Gm@width, \Gm@rmargin)^^J%
857    * v-part:(T,H,B)=(\Gm@tmargin, \Gm@height, \Gm@bmargin)^^J%
858    \fi
859    \Gm@showdim{\paperwidth}%
860    \Gm@showdim{\paperheight}%
861    \Gm@showdim{\textwidth}%
862    \Gm@showdim{\textheight}%
863    \Gm@showdim{\oddsidemargin}%
864    \Gm@showdim{\evensidemargin}%
865    \Gm@showdim{\topmargin}%
866    \Gm@showdim{\headheight}%
867    \Gm@showdim{\headsep}%
868    \Gm@showdim{\topskip}%
869    \Gm@showdim{\footskip}%
870    \Gm@showdim{\marginparwidth}%
871    \Gm@showdim{\marginparsep}%
872    \Gm@showdim{\columnsep}%
873    * \string\skip\string\footins=\the\skip\footins^^J%
874    \Gm@showdim{\hoffset}%
875    \Gm@showdim{\voffset}%
876    \Gm@showdim{\mag}%
877    * \string\@twocolumn\if@twocolumn true\else false\fi^^J%
878    * \string\@twoside\if@twoside true\else false\fi^^J%
879    * \string\@mparswitch\if@mparswitch true\else false\fi^^J%
880    * \string\@reversemargin\if@reversemargin true\else false\fi^^J%
881    * (1in=72.27pt=25.4mm, 1cm=28.453pt)^^J}%
                                                  36
                    902 \newcommand*{\Gm@pageframes}{%
                    903   \vb@xt@\z@{%
                    904    \ifGm@showcrop
                    905     \vb@xt@\z@{\vskip-1\Gm@truedimen in\vskip\Gm@layoutvoffset%
                    906      \hb@xt@\z@{\hskip-1\Gm@truedimen in\hskip\Gm@layouthoffset%
                    907       \vb@xt@\Gm@layoutheight{%
                    908        \let\protect\relax
                    909        \hb@xt@\Gm@layoutwidth{\Gm@cropmark(-1,1,-3,3)\hfil\Gm@cropmark(1,1,3,3)}%
                    910        \vfil
                    911        \hb@xt@\Gm@layoutwidth{\Gm@cropmark(-1,-1,-3,-3)\hfil\Gm@cropmark(1,-1,3,-3)}}%
                    912      \hss}%
                    913     \vss}%
                    914    \fi%
                    915    \ifGm@showframe
                    916     \if@twoside
                    917      \ifodd\count\z@
                    918        \let\@themargin\oddsidemargin
                    919      \else
                    920        \let\@themargin\evensidemargin
                    921      \fi
                    922     \fi
                    923     \moveright\@themargin%
                    924     \vb@xt@\z@{%
                    925      \vskip\topmargin\vb@xt@\z@{\vss\Gm@hrule}%
                    926      \vskip\headheight\vb@xt@\z@{\vss\Gm@hruled}%
                    927      \vskip\headsep\vb@xt@\z@{\vss\Gm@hrule}%
                    928      \@tempdima\textwidth
                    929      \advance\@tempdima by \marginparsep
                    930      \advance\@tempdima by \marginparwidth
                    931      \if@mparswitch
                    932       \ifodd\count\z@
                    933        \Gm@vrules@mpi
                    934       \else
                    935        \Gm@vrules@mpii
                    936       \fi
                    937      \else
                    938       \Gm@vrules@mpi
                    939      \fi
                    940      \vb@xt@\z@{\vss\Gm@hrule}%
                    941      \vskip\footskip\vb@xt@\z@{\vss\Gm@hruled}%
                    942      \vss}%
                    943     \fi%
                    944   }}%
\ProcessOptionsKV   This macro can process class and package options using ‘key=value’ scheme. Only class options are
                    processed with an optional argument ‘c’, package options with ‘p’ , and both of them by default.
                    945 \def\ProcessOptionsKV{\@ifnextchar[%]
                    946   {\@ProcessOptionsKV}{\@ProcessOptionsKV[]}}%
                    947 \def\@ProcessOptionsKV[#1]#2{%
                    948   \let\@tempa\@empty
                    949   \@tempcnta\z@
                    950   \if#1p\@tempcnta\@ne\else\if#1c\@tempcnta\tw@\fi\fi
                    951   \ifodd\@tempcnta
                    952    \edef\@tempa{\@ptionlist{\@currname.\@currext}}%
                    953   \else
                    954     \@for\CurrentOption:=\@classoptionslist\do{%
                    955       \@ifundefined{KV@#2@\CurrentOption}%
                    956       {}{\edef\@tempa{\@tempa,\CurrentOption,}}}%
                    957     \ifnum\@tempcnta=\z@
                    958       \edef\@tempa{\@tempa,\@ptionlist{\@currname.\@currext}}%
                    959     \fi
                    960   \fi
                    961   \edef\@tempa{\noexpand\setkeys{#2}{\@tempa}}%
                    962   \@tempa
                    963   \AtEndOfPackage{\let\@unprocessedoptions\relax}}%
                                                                   37
                   964    \def\Gm@setkeys{\setkeys{Gm}}%
\Gm@processconf     \ExecuteOptions is replaced with \Gm@setkey to make it possible to deal with ’hkeyi=hvaluei’ as
                    its argument.
                   965 \def\Gm@processconfig{%
                   966   \let\Gm@origExecuteOptions\ExecuteOptions
                   967   \let\ExecuteOptions\Gm@setkeys
                   968   \InputIfFileExists{geometry.cfg}{}{}
                   969   \let\ExecuteOptions\Gm@origExecuteOptions}%
                        The original page layout before loading geometry is saved here. \Gm@restore@org is defined here
                    for reset option.
                   970 \Gm@save
                   971 \edef\Gm@restore@org{\Gm@restore}%
                   972 \Gm@initall
\AtBeginDocument    The processes for verbose, showframe and drivers are added to \AtBeginDocument. \Gm@restore@org
                    is redefined here with the paper size specified in the preamble for \newgeometry to use it. This should
                    be done before magnifying the paper size with \mag because the layout calculation would be affected
                    by changing the paper size.
                   978 \AtBeginDocument{%
                   979   \Gm@savelength{paperwidth}%
                   980   \Gm@savelength{paperheight}%
                   981   \edef\Gm@restore@org{\Gm@restore}%
                    The original paper size is used if resetpaper.
                   982      \ifGm@resetpaper
                   983        \edef\Gm@pw{\Gm@orgpw}%
                   984        \edef\Gm@ph{\Gm@orgph}%
                   985      \else
                   986        \edef\Gm@pw{\the\paperwidth}%
                   987        \edef\Gm@ph{\the\paperheight}%
                   988      \fi
                    If pass is not set, the paper size is multiplied according to the specified mag.
                   989      \ifGm@pass\else
                   990        \ifnum\mag=\@m\else
                   991          \Gm@magtooffset
                   992          \divide\paperwidth\@m
                   993          \multiply\paperwidth\the\mag
                   994          \divide\paperheight\@m
                   995          \multiply\paperheight\the\mag
                   996        \fi
                   997      \fi
                    Checking the driver options.
                   998      \Gm@detectdriver
                    If xetex and \pdfpagewidth is defined, \pdfpagewidth and \pdfpageheight would be set.
                   999      \ifx\Gm@driver\Gm@xetex
                   1000       \@ifundefined{pdfpagewidth}{}{%
                   1001         \setlength\pdfpagewidth{\Gm@pw}%
                   1002         \setlength\pdfpageheight{\Gm@ph}}%
                                                                      38
1003     \ifnum\mag=\@m\else
1004       \ifx\Gm@truedimen\Gm@true
1005         \setlength\paperwidth{\Gm@pw}%
1006         \setlength\paperheight{\Gm@ph}%
1007       \fi
1008     \fi
1009   \fi
 If pdftex is set to true, pdf-commands are set properly. To avoid pdftex magnification problem,
 \pdfhorigin and \pdfvorigin are adjusted for \mag.
1010   \ifx\Gm@driver\Gm@pdftex
1011     \@ifundefined{pdfpagewidth}{}{%
1012       \setlength\pdfpagewidth{\Gm@pw}%
1013       \setlength\pdfpageheight{\Gm@ph}}%
1014     \ifnum\mag=\@m\else
1015       \@tempdima=\mag sp%
1016       \@ifundefined{pdfhorigin}{}{%
1017         \divide\pdfhorigin\@tempdima
1018         \multiply\pdfhorigin\@m
1019         \divide\pdfvorigin\@tempdima
1020         \multiply\pdfvorigin\@m}%
1021       \ifx\Gm@truedimen\Gm@true
1022         \setlength\paperwidth{\Gm@pw}%
1023         \setlength\paperheight{\Gm@ph}%
1024       \fi
1025     \fi
1026   \fi
 If luatex is set to true, pdf-commands are set properly. To avoid luatex magnification problem,
 \horigin and \vorigin are adjusted for \mag.
1027   \ifx\Gm@driver\Gm@luatex
1028     \setlength\pagewidth{\Gm@pw}%
1029     \setlength\pageheight{\Gm@ph}%
1030     \ifnum\mag=\@m\else
1031       \@tempdima=\mag sp
1032         \edef\Gm@horigin{\pdfvariable horigin}%
1033         \edef\Gm@vorigin{\pdfvariable vorigin}%
1034         \divide\Gm@horigin\@tempdima
1035         \multiply\Gm@horigin\@m
1036         \divide\Gm@vorigin\@tempdima
1037         \multiply\Gm@vorigin\@m
1038       \ifx\Gm@truedimen\Gm@true
1039         \setlength\paperwidth{\Gm@pw}%
1040         \setlength\paperheight{\Gm@ph}%
1041       \fi
1042     \fi
1043   \fi
 With VTEX environment, VTEX variables are set here.
1044   \ifx\Gm@driver\Gm@vtex
1045     \@ifundefined{mediawidth}{}{%
1046       \mediawidth=\paperwidth
1047       \mediaheight=\paperheight}%
1048     \ifvtexdvi
1049       \AtBeginDvi{\special{papersize=\the\paperwidth,\the\paperheight}}%
1050     \fi
1051   \fi
 If dvips or dvipdfm is specified, paper size is embedded in dvi file with \special. For dvips, a
 landscape correction is added because a landscape document converted by dvips is upside-down in
 PostScript viewers.
1052   \ifx\Gm@driver\Gm@dvips
1053     \AtBeginDvi{\special{papersize=\the\paperwidth,\the\paperheight}}%
1054     \ifx\Gm@driver\Gm@dvips\ifGm@landscape
1055       \AtBeginDvi{\special{! /landplus90 true store}}%
1056     \fi\fi
                                                39
                    If dvipdfm is specified and atbegshi package in ‘oberdiek’ bundle is loaded, \AtBeginShipoutFirst
                    is used instead of \AtBeginDvi for compatibility with hyperref and dvipdfm program.
                   1057   \else\ifx\Gm@driver\Gm@dvipdfm
                   1058     \ifcase\ifx\AtBeginShipoutFirst\relax\@ne\else
                   1059         \ifx\AtBeginShipoutFirst\@undefined\@ne\else\z@\fi\fi
                   1060       \AtBeginShipoutFirst{\special{papersize=\the\paperwidth,\the\paperheight}}%
                   1061     \or
                   1062       \AtBeginDvi{\special{papersize=\the\paperwidth,\the\paperheight}}%
                   1063     \fi
                   1064   \fi\fi
                    Page frames are shipped out when showframe=true, cropmarks for showcrop=true on each page.
                    The atbegshi package is used for overloading \shipout.
                   1065   \@tempswafalse
                   1066   \ifGm@showframe
                   1067     \@tempswatrue
                   1068   \else\ifGm@showcrop
                   1069     \@tempswatrue
                   1070   \fi\fi
                   1071   \if@tempswa
                   1072     \RequirePackage{atbegshi}%
                   1073       \AtBeginShipout{\setbox\AtBeginShipoutBox=\vbox{%
                   1074         \baselineskip\z@skip\lineskip\z@skip\lineskiplimit\z@
                   1075         \Gm@pageframes\box\AtBeginShipoutBox}}%
                   1076   \fi
                    The layout dimensions for \restoregeometry are saved at the end of the \AtBeginDocument.
                   1077   \Gm@save
                   1078   \edef\Gm@restore@pkg{\Gm@restore}%
                    The package checks whether or not the marginpars overrun the page, if verbose and unless pass.
                   1079   \ifGm@verbose\ifGm@pass\else\Gm@checkmp\fi\fi
                    \Gm@showparams puts the resulting parameters and dimensions into the log file. With verbose, they
                    are shown on the terminal as well.
                   1080   \Gm@showparams{preamble}%
                    The following lines free the memories no longer needed.
                   1081   \let\Gm@pw\relax
                   1082   \let\Gm@ph\relax
                   1083   }% end of \AtBeginDocument
      \geometry     The macro \geometry can be called multiple times in the preamble (before \begin{document}).
                   1084 \newcommand{\geometry}[1]{%
                   1085   \Gm@clean
                   1086   \setkeys{Gm}{#1}%
                   1087   \Gm@process}%
                   1088 \@onlypreamble\geometry
\Gm@changelayout    The macro, which can be called from \newgeometry, \restoregeometry and \loadgeometry,
                    changes the layout in the middle of the document.
                   1089 \DeclareRobustCommand\Gm@changelayout{%
                   1090   \setlength{\@colht}{\textheight}
                   1091   \setlength{\@colroom}{\textheight}%
                   1092   \setlength{\vsize}{\textheight}
                   1093   \setlength{\columnwidth}{\textwidth}%
                   1094   \if@twocolumn%
                   1095     \advance\columnwidth-\columnsep
                   1096     \divide\columnwidth\tw@%
                   1097     \@firstcolumntrue%
                   1098   \fi%
                   1099   \setlength{\hsize}{\columnwidth}%
                   1100   \setlength{\linewidth}{\hsize}}%
   \newgeometry     The macro \newgeometry, which changes the layout, can be used only in the document. It would
                    reset the options specified in the preamble except for paper size options and \mag.
                                                                    40
                   1101 \newcommand{\newgeometry}[1]{%
                   1102   \clearpage
                   1103   \Gm@restore@org
                   1104   \Gm@initnewgm
                   1105   \Gm@newgmtrue
                   1106   \setkeys{Gm}{#1}%
                   1107   \Gm@newgmfalse
                   1108   \Gm@process
                   1109   \ifnum\mag=\@m\else\Gm@magtooffset\fi
                   1110   \Gm@changelayout
                   1111   \Gm@showparams{newgeometry}}%
\restoregeometry    The macro restores the resulting layout specified in the preamble, namely the first-page layout right
                    after \begin{document}.
                   1112 \newcommand{\restoregeometry}{%
                   1113   \clearpage
                   1114   \Gm@restore@pkg
                   1115   \Gm@changelayout}%
  \savegeometry     The macro saves the layout with the name specified with the argument. The saved layout can be
                    loaded with \loadgeometry{hnamei}.
                   1116 \newcommand*{\savegeometry}[1]{%
                   1117   \Gm@save
                   1118   \expandafter\edef\csname Gm@restore@@#1\endcsname{\Gm@restore}}%
  \loadgeometry     The macro loads the layout saved with \savegeometry{hnamei}. If the name is not found, the
                    macro would warn it and do nothing for the layout.
                   1119 \newcommand*{\loadgeometry}[1]{%
                   1120   \clearpage
                   1121   \@ifundefined{Gm@restore@@#1}{%
                   1122     \PackageError{geometry}{%
                   1123     \string\loadgeometry : name ‘#1’ undefined}{%
                   1124     The name ‘#1’ should be predefined with \string\savegeometry}%
                   1125   }{\@nameuse{Gm@restore@@#1}%
                   1126   \Gm@changelayout}}%
                   1127 h/packagei
                    12        Config file
                    In the configuration file geometry.cfg, one can use \ExecuteOptions to set the site or user default
                    settings.
                   1128   h∗configi
                   1129   %<<SAVE_INTACT
                   1130
                   1131   % Uncomment and edit the line below to set default options.
                   1132   %\ExecuteOptions{a4paper}
                   1133
                   1134   %SAVE_INTACT
                   1135   h/configi
                    13        Sample file
                    Here is a sample document for the geometry package.
                   1136 h∗samplesi
                   1137 %<<SAVE_INTACT
                   1138 \documentclass[12pt]{article}% uses letterpaper by default
                   1139 % \documentclass[12pt,a4paper]{article}% for A4 paper
                   1140 %---------------------------------------------------------------
                   1141 % Edit and uncomment one of the settings below
                   1142 %---------------------------------------------------------------
                   1143 % \usepackage{geometry}
                   1144 % \usepackage[centering]{geometry}
                                                                     41
1145 % \usepackage[width=10cm,vscale=.7]{geometry}
1146 % \usepackage[margin=1cm, papersize={12cm,19cm}, resetpaper]{geometry}
1147 % \usepackage[margin=1cm,includeheadfoot]{geometry}
1148 \usepackage[margin=1cm,includeheadfoot,includemp]{geometry}
1149 % \usepackage[margin=1cm,bindingoffset=1cm,twoside]{geometry}
1150 % \usepackage[hmarginratio=2:1, vmargin=2cm]{geometry}
1151 % \usepackage[hscale=0.5,twoside]{geometry}
1152 % \usepackage[hscale=0.5,asymmetric]{geometry}
1153 % \usepackage[hscale=0.5,heightrounded]{geometry}
1154 % \usepackage[left=1cm,right=4cm,top=2cm,includefoot]{geometry}
1155 % \usepackage[lines=20,left=2cm,right=6cm,top=2cm,twoside]{geometry}
1156 % \usepackage[width=15cm, marginparwidth=3cm, includemp]{geometry}
1157 % \usepackage[hdivide={1cm,,2cm}, vdivide={3cm,8in,}, nohead]{geometry}
1158 % \usepackage[headsep=20pt, head=40pt,foot=20pt,includeheadfoot]{geometry}
1159 % \usepackage[text={6in,8in}, top=2cm, left=2cm]{geometry}
1160 % \usepackage[centering,includemp,twoside,landscape]{geometry}
1161 % \usepackage[mag=1414,margin=2cm]{geometry}
1162 % \usepackage[mag=1414,margin=2truecm,truedimen]{geometry}
1163 % \usepackage[a5paper, landscape, twocolumn, twoside,
1164 %    left=2cm, hmarginratio=2:1, includemp, marginparwidth=43pt,
1165 %    bottom=1cm, foot=.7cm, includefoot, textheight=11cm, heightrounded,
1166 %    columnsep=1cm,verbose]{geometry}
1167 %---------------------------------------------------------------
1168 % No need to change below
1169 %---------------------------------------------------------------
1170 \geometry{verbose,showframe}% the options appended.
1171 \usepackage{lipsum}% for dummy text of 150 paragraphs
1172 \newcommand\mynote{\marginpar[\raggedright
1173 A sample margin note in the left side.]%
1174 {\raggedright A sample margin note.}}%
1175 \newcommand\myfootnote{\footnote{This is a sample footnote text.}}
1176 \begin{document}
1177 \lipsum[1-2]\mynote\lipsum[3-4]\mynote
1178 \lipsum[5-11]\mynote\lipsum[12]\myfootnote
1179 \lipsum[13-22]\mynote\lipsum[23-32]
1180 \end{document}
1181 %SAVE_INTACT
1182 h/samplesi
42