/usr/share/doc/texinfo/html/Debugging-with-TeX.html is in texinfo-doc-nonfree 6.1.0-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<!-- This manual is for GNU Texinfo (version 6.1, 6 February 2016),
a documentation system that can produce both online information and a
printed manual from a single source using semantic markup.
Copyright (C) 1988, 1990, 1991, 1992, 1993, 1995, 1996, 1997,
1998, 1999, 2001, 2001, 2003, 2004, 2005, 2006, 2007, 2008, 2009,
2010, 2011, 2012, 2013, 2014, 2015, 2016 Free Software Foundation, Inc.
Permission is granted to copy, distribute and/or modify this document
under the terms of the GNU Free Documentation License, Version 1.3 or
any later version published by the Free Software Foundation; with no
Invariant Sections, with the Front-Cover Texts being "A GNU Manual",
and with the Back-Cover Texts as in (a) below. A copy of the license
is included in the section entitled "GNU Free Documentation
License".
(a) The FSF's Back-Cover Text is: "You have the freedom to copy and
modify this GNU manual. Buying copies from the FSF supports it in
developing GNU and promoting software freedom." -->
<!-- Created by GNU Texinfo 6.1, http://www.gnu.org/software/texinfo/ -->
<head>
<title>GNU Texinfo 6.1: Debugging with TeX</title>
<meta name="description" content="GNU Texinfo 6.1: Debugging with TeX">
<meta name="keywords" content="GNU Texinfo 6.1: Debugging with TeX">
<meta name="resource-type" content="document">
<meta name="distribution" content="global">
<meta name="Generator" content="makeinfo">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<link href="index.html#Top" rel="start" title="Top">
<link href="Command-and-Variable-Index.html#Command-and-Variable-Index" rel="index" title="Command and Variable Index">
<link href="index.html#SEC_Contents" rel="contents" title="Table of Contents">
<link href="Catching-Mistakes.html#Catching-Mistakes" rel="up" title="Catching Mistakes">
<link href="Using-texinfo_002dshow_002dstructure.html#Using-texinfo_002dshow_002dstructure" rel="next" title="Using texinfo-show-structure">
<link href="Debugging-with-Info.html#Debugging-with-Info" rel="prev" title="Debugging with Info">
<style type="text/css">
<!--
a.summary-letter {text-decoration: none}
blockquote.indentedblock {margin-right: 0em}
blockquote.smallindentedblock {margin-right: 0em; font-size: smaller}
blockquote.smallquotation {font-size: smaller}
div.display {margin-left: 3.2em}
div.example {margin-left: 3.2em}
div.lisp {margin-left: 3.2em}
div.smalldisplay {margin-left: 3.2em}
div.smallexample {margin-left: 3.2em}
div.smalllisp {margin-left: 3.2em}
kbd {font-style: oblique}
pre.display {font-family: inherit}
pre.format {font-family: inherit}
pre.menu-comment {font-family: serif}
pre.menu-preformatted {font-family: serif}
pre.smalldisplay {font-family: inherit; font-size: smaller}
pre.smallexample {font-size: smaller}
pre.smallformat {font-family: inherit; font-size: smaller}
pre.smalllisp {font-size: smaller}
span.nolinebreak {white-space: nowrap}
span.roman {font-family: initial; font-weight: normal}
span.sansserif {font-family: sans-serif; font-weight: normal}
ul.no-bullet {list-style: none}
-->
</style>
</head>
<body lang="en">
<a name="Debugging-with-TeX"></a>
<div class="header">
<p>
Next: <a href="Using-texinfo_002dshow_002dstructure.html#Using-texinfo_002dshow_002dstructure" accesskey="n" rel="next">Using <code>texinfo-show-structure</code></a>, Previous: <a href="Debugging-with-Info.html#Debugging-with-Info" accesskey="p" rel="prev">Debugging with Info</a>, Up: <a href="Catching-Mistakes.html#Catching-Mistakes" accesskey="u" rel="up">Catching Mistakes</a> [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Command-and-Variable-Index.html#Command-and-Variable-Index" title="Index" rel="index">Index</a>]</p>
</div>
<hr>
<a name="Debugging-with-TeX-1"></a>
<h3 class="section">F.3 Debugging with TeX</h3>
<a name="index-Catching-errors-with-TeX-formatting"></a>
<a name="index-Debugging-with-TeX-formatting"></a>
<p>You can also catch mistakes when you format a file with TeX.
</p>
<p>Usually, you will want to do this after you have run
<code>texinfo-format-buffer</code> (or, better, <code>makeinfo-buffer</code>) on
the same file, because <code>texinfo-format-buffer</code> sometimes displays
error messages that make more sense than TeX. (See <a href="Debugging-with-Info.html#Debugging-with-Info">Debugging with Info</a>, for more information.)
</p>
<p>For example, TeX was run on a Texinfo file, part of which is shown
here:
</p>
<div class="example">
<pre class="example">---------- Buffer: texinfo.texi ----------
name of the Texinfo file as an extension. The
@samp{??} are `wildcards' that cause the shell to
substitute all the raw index files. (@xref{sorting
indices, for more information about sorting
indices.)@refill
---------- Buffer: texinfo.texi ----------
</pre></div>
<p>(The cross-reference lacks a closing brace.)
TeX produced the following output, after which it stopped:
</p>
<div class="example">
<pre class="example">---------- Buffer: *tex-shell* ----------
Runaway argument?
{sorting indices, for more information about sorting
indices.) @refill @ETC.
! Paragraph ended before @xref was complete.
<to be read again>
@par
l.27
?
---------- Buffer: *tex-shell* ----------
</pre></div>
<p>In this case, TeX produced an accurate and
understandable error message:
</p>
<div class="example">
<pre class="example">Paragraph ended before @xref was complete.
</pre></div>
<p>‘<samp>@par</samp>’ is an internal TeX command of no relevance to Texinfo.
‘<samp>l.27</samp>’ means that TeX detected the problem on line 27 of the
Texinfo file. The ‘<samp>?</samp>’ is the prompt TeX uses in this
circumstance.
</p>
<p>Unfortunately, TeX is not always so helpful, and sometimes you must
truly be a Sherlock Holmes to discover what went wrong.
</p>
<p>In any case, if you run into a problem like this, you can do one of three
things.
</p>
<ol>
<li> You can tell TeX to continue running and ignore just this error by
typing <tt class="key">RET</tt> at the ‘<samp>?</samp>’ prompt.
</li><li> You can tell TeX to continue running and to ignore all errors as best
it can by typing <kbd>r <span class="key">RET</span></kbd> at the ‘<samp>?</samp>’ prompt.
<p>This is often the best thing to do. However, beware: the one error
may produce a cascade of additional error messages as its consequences
are felt through the rest of the file. To stop TeX when it is
producing such an avalanche of error messages, type <kbd>C-c</kbd> (or
<kbd>C-c C-c</kbd>, if you are running a shell inside Emacs).
</p>
</li><li> You can tell TeX to stop this run by typing <kbd>x <span class="key">RET</span></kbd>
at the ‘<samp>?</samp>’ prompt.
</li></ol>
<p>If you are running TeX inside Emacs, you need to switch to the shell
buffer and line at which TeX offers the ‘<samp>?</samp>’ prompt.
</p>
<p>Sometimes TeX will format a file without producing error messages even
though there is a problem. This usually occurs if a command is not ended
but TeX is able to continue processing anyhow. For example, if you fail
to end an itemized list with the <code>@end itemize</code> command, TeX will
write a DVI file that you can print out. The only error message that
TeX will give you is the somewhat mysterious comment:
</p>
<div class="example">
<pre class="example">(@end occurred inside a group at level 1)
</pre></div>
<p>However, if you print the DVI file, you will find that the text
of the file that follows the itemized list is entirely indented as if
it were part of the last item in the itemized list. The error message
is the way TeX says that it expected to find an <code>@end</code>
command somewhere in the file; but that it could not determine where
it was needed.
</p>
<p>Another source of notoriously hard-to-find errors is a missing
<code>@end group</code> command. If you ever are stumped by
incomprehensible errors, look for a missing <code>@end group</code> command
first.
</p>
<p>If the Texinfo file lacks header lines,
TeX may stop in the
beginning of its run and display output that looks like the following.
The ‘<samp>*</samp>’ indicates that TeX is waiting for input.
</p>
<div class="example">
<pre class="example">This is TeX, Version 3.14159 (Web2c 7.0)
(test.texinfo [1])
*
</pre></div>
<p>In this case, simply type <kbd>\end <span class="key">RET</span></kbd> after the asterisk. Then
write the header lines in the Texinfo file and run the TeX command
again. (Note the use of the backslash, ‘<samp>\</samp>’. TeX uses ‘<samp>\</samp>’
instead of ‘<samp>@</samp>’; and in this circumstance, you are working
directly with TeX, not with Texinfo.)
</p>
<hr>
<div class="header">
<p>
Next: <a href="Using-texinfo_002dshow_002dstructure.html#Using-texinfo_002dshow_002dstructure" accesskey="n" rel="next">Using <code>texinfo-show-structure</code></a>, Previous: <a href="Debugging-with-Info.html#Debugging-with-Info" accesskey="p" rel="prev">Debugging with Info</a>, Up: <a href="Catching-Mistakes.html#Catching-Mistakes" accesskey="u" rel="up">Catching Mistakes</a> [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Command-and-Variable-Index.html#Command-and-Variable-Index" title="Index" rel="index">Index</a>]</p>
</div>
</body>
</html>
|