File: FAQ-addtoreset.html

package info (click to toggle)
tetex-base 3.0.dfsg.3-5
  • links: PTS
  • area: main
  • in suites: etch-m68k
  • size: 239,540 kB
  • ctags: 10,610
  • sloc: xml: 103,461; perl: 9,398; ruby: 2,850; python: 1,551; php: 1,067; sh: 981; lisp: 494; makefile: 371; awk: 88
file content (75 lines) | stat: -rw-r--r-- 4,004 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<head>
<title>UK TeX FAQ -- question label addtoreset</title>
</head><body>
<h3>Master and slave counters</h3>
<p>It's common to have things numbered "per chapter" (for example, in
the standard <i>book</i> and <i>report</i> classes, figures, tables
and footnotes are all numbered thus).  The process of resetting is
done automatically, when the "master" counter is stepped (when the
<code>\</code><code>chapter</code> command that starts chapter &lt;<i>n</i>&gt; happens, the
<code>chapter</code> counter is stepped, and all the dependent counters are set
to zero).
<p>How would you do that for yourself?  You might want to number
algorithms per section, or corrolaries per theorem, for example.  If
you're defining these things by hand, you declare the relationship
when you define the counter in the first place:
<blockquote>
<code>\</code><code>newcounter{</code><em>new-name</em><code>}[</code><em>master</em><code>]</code>
</blockquote>
says that every time counter &lt;<i>master</i>&gt; is stepped, counter
&lt;<i>new-name</i>&gt; will be reset.
<p>But what if you have an uncooperative package, that defines the
objects for you, but doesn't provide a programmer interface to make
the counters behave as you want?
<p>The <code>\</code><code>newcounter</code> command uses a LaTeX internal command, and you
can also use it:
<blockquote>
<code>\</code><code>@addtoreset{</code><em>new-name</em><code>}{</code><em>master</em><code>}</code>
</blockquote>
(but remember that it needs to be between <code>\</code><code>makeatletter</code> and
<code>\</code><code>makeatother</code>, or in a package of your own).
<p>The <i>chngcntr</i> package encapsulates the <code>\</code><code>@addtoreset</code>
command into a command <code>\</code><code>counterwithin</code>.  So:
<blockquote>
<pre>
\counterwithin*{corrolary}{theorem}
</pre>
</blockquote>
will make the corrolary counter slave to theorem counters.  The
command without its asterisk:
<blockquote>
<pre>
\counterwithin{corrolary}{theorem}
</pre>
</blockquote>
will do the same, and also redefine <code>\</code><code>thecorrolary</code> as 
&lt;<i>theorem number</i>&gt;.&lt;<i>corrolary number</i>&gt;, which is a good scheme
if you ever want to refer to the corrolaries - there are potentially
many "corrolary 1" in any document, so it's as well to tie its number
to the counter of the theorem it belongs to.  This is true of pretty
much any such counter-within-another; if you're not using the
<i>chngcntr</i>, refer to the answer to 
<a href="FAQ-the-commands.html">redefining counters' <code>\</code><code>the-</code>commands</a> for
the necessary techniques.
<p>Note that the technique doesn't work if the master counter is <code>page</code>,
the number of the current page.  The <code>page</code> counter is stepped deep
inside the output routine, which usually gets called some time after
the text for the new page has started to appear: so special
techniques are required to deal with that.  One special case is dealt
with elsewhere: <a href="FAQ-footnpp.html">footnotes numbered per page</a>.  One
of the techniques described there, using package <i>perpage</i>,
may be applied to any counter.  The command:
<blockquote>
<code>\</code><code>MakePerPage{</code><em>counter</em><code>}</code>
</blockquote>
will cause &lt;<i>counter</i>&gt; to be reset for each page.  The package uses
a label-like mechanism, and may require more than one run of LaTeX
to stabilise counter values - LaTeX will generate the usual
warnings about labels changing.
<dl>
<dt><tt><i>chngcntr.sty</i></tt><dd><a href="ftp://cam.ctan.org/tex-archive/macros/latex/contrib/misc/chngcntr.sty">macros/latex/contrib/misc/chngcntr.sty</a>
<dt><tt><i>perpage.sty</i></tt><dd><a href="ftp://cam.ctan.org/tex-archive/macros/latex/contrib/misc/perpage.sty">macros/latex/contrib/misc/perpage.sty</a>
</dl>
<p>
<p>This question on the Web: <a href="http://www.tex.ac.uk/cgi-bin/texfaq2html?label=addtoreset">http://www.tex.ac.uk/cgi-bin/texfaq2html?label=addtoreset</a>
</body>