Mercurial > emacs
annotate man/trouble.texi @ 69824:d229a8453f37
Restored copyright.
author | J.D. Smith <jdsmith@as.arizona.edu> |
---|---|
date | Thu, 06 Apr 2006 18:52:56 +0000 |
parents | d6ae666344e2 |
children | 601830ae280c 65ca8fb66a0d |
rev | line source |
---|---|
25829 | 1 @c This is part of the Emacs manual. |
64890
3723093a21fd
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
64464
diff
changeset
|
2 @c Copyright (C) 1985, 1986, 1987, 1993, 1994, 1995, 1997, 2001, 2002, |
68639
dc2d5a6655a3
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
66503
diff
changeset
|
3 @c 2003, 2004, 2005, 2006 Free Software Foundation, Inc. |
25829 | 4 @c See file emacs.texi for copying conditions. |
5 @iftex | |
6 @chapter Dealing with Common Problems | |
7 | |
8 If you type an Emacs command you did not intend, the results are often | |
9 mysterious. This chapter tells what you can do to cancel your mistake or | |
10 recover from a mysterious situation. Emacs bugs and system crashes are | |
11 also considered. | |
12 @end iftex | |
13 | |
56812
16152de85a64
Adapt sectioning in Info to the node structure.
Luc Teirlinck <teirllm@auburn.edu>
parents:
54478
diff
changeset
|
14 @ifnottex |
16152de85a64
Adapt sectioning in Info to the node structure.
Luc Teirlinck <teirllm@auburn.edu>
parents:
54478
diff
changeset
|
15 @raisesections |
16152de85a64
Adapt sectioning in Info to the node structure.
Luc Teirlinck <teirllm@auburn.edu>
parents:
54478
diff
changeset
|
16 @end ifnottex |
16152de85a64
Adapt sectioning in Info to the node structure.
Luc Teirlinck <teirllm@auburn.edu>
parents:
54478
diff
changeset
|
17 |
25829 | 18 @node Quitting, Lossage, Customization, Top |
19 @section Quitting and Aborting | |
20 @cindex quitting | |
21 | |
22 @table @kbd | |
23 @item C-g | |
36180
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
24 @itemx C-@key{BREAK} @r{(MS-DOS only)} |
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
25 Quit: cancel running or partially typed command. |
25829 | 26 @item C-] |
27 Abort innermost recursive editing level and cancel the command which | |
28 invoked it (@code{abort-recursive-edit}). | |
29 @item @key{ESC} @key{ESC} @key{ESC} | |
30 Either quit or abort, whichever makes sense (@code{keyboard-escape-quit}). | |
31 @item M-x top-level | |
32 Abort all recursive editing levels that are currently executing. | |
33 @item C-x u | |
34 Cancel a previously made change in the buffer contents (@code{undo}). | |
35 @end table | |
36 | |
69800 | 37 There are two ways of canceling a command before it has finished: |
38 @dfn{quitting} with @kbd{C-g}, and @dfn{aborting} with @kbd{C-]} or | |
39 @kbd{M-x top-level}. Quitting cancels a partially typed command, or | |
40 one which is still running. Aborting exits a recursive editing level | |
41 and cancels the command that invoked the recursive edit. | |
25829 | 42 (@xref{Recursive Edit}.) |
43 | |
44 @cindex quitting | |
45 @kindex C-g | |
69800 | 46 Quitting with @kbd{C-g} is the way to get rid of a partially typed |
25829 | 47 command, or a numeric argument that you don't want. It also stops a |
48 running command in the middle in a relatively safe way, so you can use | |
49 it if you accidentally give a command which takes a long time. In | |
69800 | 50 particular, it is safe to quit out of a kill command; either your text |
51 will @emph{all} still be in the buffer, or it will @emph{all} be in | |
52 the kill ring, or maybe both. Quitting an incremental search does | |
53 special things, documented under searching; it may take two successive | |
54 @kbd{C-g} characters to get out of a search (@pxref{Incremental | |
55 Search}). | |
25829 | 56 |
57 On MS-DOS, the character @kbd{C-@key{BREAK}} serves as a quit character | |
58 like @kbd{C-g}. The reason is that it is not feasible, on MS-DOS, to | |
59 recognize @kbd{C-g} while a command is running, between interactions | |
60 with the user. By contrast, it @emph{is} feasible to recognize | |
60121
07602b55f1ef
(Quitting): Update xref for splitting of node in msdog.texi.
Luc Teirlinck <teirllm@auburn.edu>
parents:
60115
diff
changeset
|
61 @kbd{C-@key{BREAK}} at all times. @xref{MS-DOS Keyboard}. |
25829 | 62 |
36180
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
63 @findex keyboard-quit |
25829 | 64 @kbd{C-g} works by setting the variable @code{quit-flag} to @code{t} |
65 the instant @kbd{C-g} is typed; Emacs Lisp checks this variable | |
69800 | 66 frequently, and quits if it is non-@code{nil}. @kbd{C-g} is only |
25829 | 67 actually executed as a command if you type it while Emacs is waiting for |
36180
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
68 input. In that case, the command it runs is @code{keyboard-quit}. |
25829 | 69 |
60115
63c8eb0c25c0
(Quitting): Emergency escape only for text terminal.
Richard M. Stallman <rms@gnu.org>
parents:
56812
diff
changeset
|
70 On a text terminal, if you quit with @kbd{C-g} a second time before |
63c8eb0c25c0
(Quitting): Emergency escape only for text terminal.
Richard M. Stallman <rms@gnu.org>
parents:
56812
diff
changeset
|
71 the first @kbd{C-g} is recognized, you activate the ``emergency |
63c8eb0c25c0
(Quitting): Emergency escape only for text terminal.
Richard M. Stallman <rms@gnu.org>
parents:
56812
diff
changeset
|
72 escape'' feature and return to the shell. @xref{Emergency Escape}. |
25829 | 73 |
74 @cindex NFS and quitting | |
69800 | 75 There are some situations where you cannot quit. When Emacs is |
76 waiting for the operating system to do something, quitting is | |
77 impossible unless special pains are taken for the particular system | |
78 call within Emacs where the waiting occurs. We have done this for the | |
79 system calls that users are likely to want to quit from, but it's | |
80 possible you will a case not handled. In one very common | |
81 case---waiting for file input or output using NFS---Emacs itself knows | |
82 how to quit, but many NFS implementations simply do not allow user | |
83 programs to stop waiting for NFS when the NFS server is hung. | |
25829 | 84 |
85 @cindex aborting recursive edit | |
86 @findex abort-recursive-edit | |
87 @kindex C-] | |
88 Aborting with @kbd{C-]} (@code{abort-recursive-edit}) is used to get | |
89 out of a recursive editing level and cancel the command which invoked | |
90 it. Quitting with @kbd{C-g} does not do this, and could not do this, | |
91 because it is used to cancel a partially typed command @emph{within} the | |
92 recursive editing level. Both operations are useful. For example, if | |
93 you are in a recursive edit and type @kbd{C-u 8} to enter a numeric | |
94 argument, you can cancel that argument with @kbd{C-g} and remain in the | |
95 recursive edit. | |
96 | |
97 @findex keyboard-escape-quit | |
98 @kindex ESC ESC ESC | |
69800 | 99 The sequence @kbd{@key{ESC} @key{ESC} @key{ESC}} |
100 (@code{keyboard-escape-quit}) can either quit or abort. (We defined | |
101 it this way because @key{ESC} means ``get out'' in many PC programs.) | |
102 It can cancel a prefix argument, clear a selected region, or get out | |
103 of a Query Replace, like @kbd{C-g}. It can get out of the minibuffer | |
104 or a recursive edit, like @kbd{C-]}. It can also get out of splitting | |
105 the frame into multiple windows, as with @kbd{C-x 1}. One thing it | |
106 cannot do, however, is stop a command that is running. That's because | |
107 it executes as an ordinary command, and Emacs doesn't notice it until | |
108 it is ready for the next command. | |
25829 | 109 |
110 @findex top-level | |
111 The command @kbd{M-x top-level} is equivalent to ``enough'' @kbd{C-]} | |
112 commands to get you out of all the levels of recursive edits that you | |
113 are in. @kbd{C-]} gets you out one level at a time, but @kbd{M-x | |
114 top-level} goes out all levels at once. Both @kbd{C-]} and @kbd{M-x | |
115 top-level} are like all other commands, and unlike @kbd{C-g}, in that | |
116 they take effect only when Emacs is ready for a command. @kbd{C-]} is | |
117 an ordinary key and has its meaning only because of its binding in the | |
118 keymap. @xref{Recursive Edit}. | |
119 | |
120 @kbd{C-x u} (@code{undo}) is not strictly speaking a way of canceling | |
121 a command, but you can think of it as canceling a command that already | |
37869 | 122 finished executing. @xref{Undo}, for more information |
123 about the undo facility. | |
25829 | 124 |
125 @node Lossage, Bugs, Quitting, Top | |
126 @section Dealing with Emacs Trouble | |
127 | |
128 This section describes various conditions in which Emacs fails to work | |
38686
0d3019db87ac
(Lossage, Bugs): Mention etc/PROBLEMS and the Bugs section of the FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38245
diff
changeset
|
129 normally, and how to recognize them and correct them. For a list of |
0d3019db87ac
(Lossage, Bugs): Mention etc/PROBLEMS and the Bugs section of the FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38245
diff
changeset
|
130 additional problems you might encounter, see @ref{Bugs and problems, , |
0d3019db87ac
(Lossage, Bugs): Mention etc/PROBLEMS and the Bugs section of the FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38245
diff
changeset
|
131 Bugs and problems, efaq, GNU Emacs FAQ}, and the file @file{etc/PROBLEMS} |
54478 | 132 in the Emacs distribution. Type @kbd{C-h C-f} to read the FAQ; type |
133 @kbd{C-h C-e} to read the @file{PROBLEMS} file. | |
25829 | 134 |
135 @menu | |
46235 | 136 * DEL Does Not Delete:: What to do if @key{DEL} doesn't delete. |
38767
5889c45fd6ad
Change the name of the "DEL Doesn't Delete" node to "DEL Does Not Delete",
Eli Zaretskii <eliz@gnu.org>
parents:
38742
diff
changeset
|
137 * Stuck Recursive:: `[...]' in mode line around the parentheses. |
5889c45fd6ad
Change the name of the "DEL Doesn't Delete" node to "DEL Does Not Delete",
Eli Zaretskii <eliz@gnu.org>
parents:
38742
diff
changeset
|
138 * Screen Garbled:: Garbage on the screen. |
5889c45fd6ad
Change the name of the "DEL Doesn't Delete" node to "DEL Does Not Delete",
Eli Zaretskii <eliz@gnu.org>
parents:
38742
diff
changeset
|
139 * Text Garbled:: Garbage in the text. |
5889c45fd6ad
Change the name of the "DEL Doesn't Delete" node to "DEL Does Not Delete",
Eli Zaretskii <eliz@gnu.org>
parents:
38742
diff
changeset
|
140 * Memory Full:: How to cope when you run out of memory. |
5889c45fd6ad
Change the name of the "DEL Doesn't Delete" node to "DEL Does Not Delete",
Eli Zaretskii <eliz@gnu.org>
parents:
38742
diff
changeset
|
141 * After a Crash:: Recovering editing in an Emacs session that crashed. |
5889c45fd6ad
Change the name of the "DEL Doesn't Delete" node to "DEL Does Not Delete",
Eli Zaretskii <eliz@gnu.org>
parents:
38742
diff
changeset
|
142 * Emergency Escape:: Emergency escape--- |
5889c45fd6ad
Change the name of the "DEL Doesn't Delete" node to "DEL Does Not Delete",
Eli Zaretskii <eliz@gnu.org>
parents:
38742
diff
changeset
|
143 What to do if Emacs stops responding. |
5889c45fd6ad
Change the name of the "DEL Doesn't Delete" node to "DEL Does Not Delete",
Eli Zaretskii <eliz@gnu.org>
parents:
38742
diff
changeset
|
144 * Total Frustration:: When you are at your wits' end. |
25829 | 145 @end menu |
146 | |
38767
5889c45fd6ad
Change the name of the "DEL Doesn't Delete" node to "DEL Does Not Delete",
Eli Zaretskii <eliz@gnu.org>
parents:
38742
diff
changeset
|
147 @node DEL Does Not Delete |
25829 | 148 @subsection If @key{DEL} Fails to Delete |
36791
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
149 @cindex @key{DEL} vs @key{BACKSPACE} |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
150 @cindex @key{BACKSPACE} vs @key{DEL} |
37126
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
151 @cindex usual erasure key |
25829 | 152 |
37126
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
153 Every keyboard has a large key, a little ways above the @key{RET} or |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
154 @key{ENTER} key, which you normally use outside Emacs to erase the |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
155 last character that you typed. We call this key @dfn{the usual |
37347
bd817d6f9ba3
Minor clarifications regarding DEL key.
Richard M. Stallman <rms@gnu.org>
parents:
37126
diff
changeset
|
156 erasure key}. In Emacs, it is supposed to be equivalent to @key{DEL}, |
bd817d6f9ba3
Minor clarifications regarding DEL key.
Richard M. Stallman <rms@gnu.org>
parents:
37126
diff
changeset
|
157 and when Emacs is properly configured for your terminal, it translates |
bd817d6f9ba3
Minor clarifications regarding DEL key.
Richard M. Stallman <rms@gnu.org>
parents:
37126
diff
changeset
|
158 that key into the character @key{DEL}. |
36791
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
159 |
68702
066d88077bfc
"Graphical display", not window system.
Richard M. Stallman <rms@gnu.org>
parents:
68639
diff
changeset
|
160 When Emacs starts up on a graphical display, it determines |
36791
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
161 automatically which key should be @key{DEL}. In some unusual cases |
37126
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
162 Emacs gets the wrong information from the system. If the usual |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
163 erasure key deletes forwards instead of backwards, that is probably |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
164 what happened---Emacs ought to be treating the @key{DELETE} key as |
36791
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
165 @key{DEL}, but it isn't. |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
166 |
68702
066d88077bfc
"Graphical display", not window system.
Richard M. Stallman <rms@gnu.org>
parents:
68639
diff
changeset
|
167 On a graphical display, if the usual erasure key is labeled |
37126
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
168 @key{BACKSPACE} and there is a @key{DELETE} key elsewhere, but the |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
169 @key{DELETE} key deletes backward instead of forward, that too |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
170 suggests Emacs got the wrong information---but in the opposite sense. |
37357
ad563f9185fb
Minor clarifications of BACKSPACE vs DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37347
diff
changeset
|
171 It ought to be treating the @key{BACKSPACE} key as @key{DEL}, and |
ad563f9185fb
Minor clarifications of BACKSPACE vs DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37347
diff
changeset
|
172 treating @key{DELETE} differently, but it isn't. |
36791
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
173 |
37126
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
174 On a text-only terminal, if you find the usual erasure key prompts |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
175 for a Help command, like @kbd{Control-h}, instead of deleting a |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
176 character, it means that key is actually sending the @key{BS} |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
177 character. Emacs ought to be treating @key{BS} as @key{DEL}, but it |
6a2d75e45a87
Add concept of "usual erasure key" to explain about DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37119
diff
changeset
|
178 isn't. |
36791
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
179 |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
180 In all of those cases, the immediate remedy is the same: use the |
37498
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
181 command @kbd{M-x normal-erase-is-backspace-mode}. This toggles |
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
182 between the two modes that Emacs supports for handling @key{DEL}, so |
69800 | 183 if Emacs starts in the wrong mode, this should switch to the right |
184 mode. On a text-only terminal, if you want to ask for help when | |
185 @key{BS} is treated as @key{DEL}, use @key{F1}; @kbd{C-?} may also | |
186 work, if it sends character code 127. | |
36791
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
187 |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
188 @findex normal-erase-is-backspace-mode |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
189 To fix the problem automatically for every Emacs session, you can |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
190 put one of the following lines into your @file{.emacs} file |
37357
ad563f9185fb
Minor clarifications of BACKSPACE vs DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37347
diff
changeset
|
191 (@pxref{Init File}). For the first case above, where @key{DELETE} |
ad563f9185fb
Minor clarifications of BACKSPACE vs DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37347
diff
changeset
|
192 deletes forwards instead of backwards, use this line to make |
37498
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
193 @key{DELETE} act as @key{DEL} (resulting in behavior compatible |
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
194 with Emacs 20 and previous versions): |
36791
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
195 |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
196 @lisp |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
197 (normal-erase-is-backspace-mode 0) |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
198 @end lisp |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
199 |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
200 @noindent |
37357
ad563f9185fb
Minor clarifications of BACKSPACE vs DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37347
diff
changeset
|
201 For the other two cases, where @key{BACKSPACE} ought to act as |
ad563f9185fb
Minor clarifications of BACKSPACE vs DEL.
Richard M. Stallman <rms@gnu.org>
parents:
37347
diff
changeset
|
202 @key{DEL}, use this line: |
36791
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
203 |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
204 @lisp |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
205 (normal-erase-is-backspace-mode 1) |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
206 @end lisp |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
207 |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
208 @vindex normal-erase-is-backspace |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
209 Another way to fix the problem for every Emacs session is to |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
210 customize the variable @code{normal-erase-is-backspace}: the value |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
211 @code{t} specifies the mode where @key{BS} or @key{BACKSPACE} is |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
212 @key{DEL}, and @code{nil} specifies the other mode. @xref{Easy |
308577404dc3
DEL Gets Help: Complete rewrite to deal with automatic
Richard M. Stallman <rms@gnu.org>
parents:
36620
diff
changeset
|
213 Customization}. |
25829 | 214 |
68702
066d88077bfc
"Graphical display", not window system.
Richard M. Stallman <rms@gnu.org>
parents:
68639
diff
changeset
|
215 On a graphical display, it can also happen that the usual erasure key |
37498
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
216 is labeled @key{BACKSPACE}, there is a @key{DELETE} key elsewhere, and |
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
217 both keys delete forward. This probably means that someone has |
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
218 redefined your @key{BACKSPACE} key as a @key{DELETE} key. With X, |
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
219 this is typically done with a command to the @code{xmodmap} program |
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
220 when you start the server or log in. The most likely motive for this |
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
221 customization was to support old versions of Emacs, so we recommend |
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
222 you simply remove it now. |
0b7a984464cf
Clarify when C-? is available as Help.
Richard M. Stallman <rms@gnu.org>
parents:
37357
diff
changeset
|
223 |
25829 | 224 @node Stuck Recursive |
225 @subsection Recursive Editing Levels | |
226 | |
227 Recursive editing levels are important and useful features of Emacs, but | |
68702
066d88077bfc
"Graphical display", not window system.
Richard M. Stallman <rms@gnu.org>
parents:
68639
diff
changeset
|
228 they can seem like malfunctions if you do not understand them. |
25829 | 229 |
230 If the mode line has square brackets @samp{[@dots{}]} around the parentheses | |
231 that contain the names of the major and minor modes, you have entered a | |
232 recursive editing level. If you did not do this on purpose, or if you | |
233 don't understand what that means, you should just get out of the recursive | |
234 editing level. To do so, type @kbd{M-x top-level}. This is called getting | |
235 back to top level. @xref{Recursive Edit}. | |
236 | |
237 @node Screen Garbled | |
238 @subsection Garbage on the Screen | |
239 | |
60115
63c8eb0c25c0
(Quitting): Emergency escape only for text terminal.
Richard M. Stallman <rms@gnu.org>
parents:
56812
diff
changeset
|
240 If the text on a text terminal looks wrong, the first thing to do is |
63c8eb0c25c0
(Quitting): Emergency escape only for text terminal.
Richard M. Stallman <rms@gnu.org>
parents:
56812
diff
changeset
|
241 see whether it is wrong in the buffer. Type @kbd{C-l} to redisplay |
63c8eb0c25c0
(Quitting): Emergency escape only for text terminal.
Richard M. Stallman <rms@gnu.org>
parents:
56812
diff
changeset
|
242 the entire screen. If the screen appears correct after this, the |
63c8eb0c25c0
(Quitting): Emergency escape only for text terminal.
Richard M. Stallman <rms@gnu.org>
parents:
56812
diff
changeset
|
243 problem was entirely in the previous screen update. (Otherwise, see |
63c8eb0c25c0
(Quitting): Emergency escape only for text terminal.
Richard M. Stallman <rms@gnu.org>
parents:
56812
diff
changeset
|
244 the following section.) |
25829 | 245 |
69800 | 246 Display updating problems often result from an incorrect terminfo |
247 entry for the terminal you are using. The file @file{etc/TERMS} in | |
248 the Emacs distribution gives the fixes for known problems of this | |
249 sort. @file{INSTALL} contains general advice for these problems in | |
250 one of its sections. To investigate the possibility that you have | |
251 this sort of problem, try Emacs on another terminal made by a | |
252 different manufacturer. If problems happen frequently on one kind of | |
253 terminal but not another kind, it is likely to be a bad terminfo entry, | |
254 though it could also be due to a bug in Emacs that appears for | |
255 terminals that have or that lack specific features. | |
25829 | 256 |
257 @node Text Garbled | |
258 @subsection Garbage in the Text | |
259 | |
69800 | 260 If @kbd{C-l} shows that the text is wrong, first type @kbd{C-h l} to |
261 see what commands you typed to produce the observed results. Then try | |
262 undoing the changes step by step using @kbd{C-x u}, until it gets back | |
263 to a state you consider correct. | |
25829 | 264 |
265 If a large portion of text appears to be missing at the beginning or | |
266 end of the buffer, check for the word @samp{Narrow} in the mode line. | |
267 If it appears, the text you don't see is probably still present, but | |
268 temporarily off-limits. To make it accessible again, type @kbd{C-x n | |
269 w}. @xref{Narrowing}. | |
270 | |
271 @node Memory Full | |
272 @subsection Running out of Memory | |
273 @cindex memory full | |
274 @cindex out of memory | |
275 | |
66503
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
276 If you get the error message @samp{Virtual memory exceeded}, save |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
277 your modified buffers with @kbd{C-x s}. This method of saving them |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
278 has the smallest need for additional memory. Emacs keeps a reserve of |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
279 memory which it makes available when this error happens; that should |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
280 be enough to enable @kbd{C-x s} to complete its work. When the |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
281 reserve has been used, @samp{!MEM FULL!} appears at the beginning of |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
282 the mode line, indicating there is no more reserve. |
25829 | 283 |
66503
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
284 Once you have saved your modified buffers, you can exit this Emacs |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
285 session and start another, or you can use @kbd{M-x kill-some-buffers} |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
286 to free space in the current Emacs job. If this frees up sufficient |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
287 space, Emacs will refill its memory reserve, and @samp{!MEM FULL!} |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
288 will disappear from the mode line. That means you can safely go on |
97aa71642e9c
(Memory Full): Mention !MEM FULL! in mode line.
Richard M. Stallman <rms@gnu.org>
parents:
65034
diff
changeset
|
289 editing in the same Emacs session. |
25829 | 290 |
291 Do not use @kbd{M-x buffer-menu} to save or kill buffers when you run | |
37976
23dc2eca0bd3
Proofreading changes from Tim Goodwin <tjg@star.le.ac.uk>.
Eli Zaretskii <eliz@gnu.org>
parents:
37869
diff
changeset
|
292 out of memory, because the buffer menu needs a fair amount of memory |
25829 | 293 itself, and the reserve supply may not be enough. |
294 | |
295 @node After a Crash | |
296 @subsection Recovery After a Crash | |
297 | |
298 If Emacs or the computer crashes, you can recover the files you were | |
299 editing at the time of the crash from their auto-save files. To do | |
300 this, start Emacs again and type the command @kbd{M-x recover-session}. | |
301 | |
302 This command initially displays a buffer which lists interrupted | |
303 session files, each with its date. You must choose which session to | |
304 recover from. Typically the one you want is the most recent one. Move | |
305 point to the one you choose, and type @kbd{C-c C-c}. | |
306 | |
69800 | 307 Then @code{recover-session} considers each of the files that you |
308 were editing during that session; for each such file, it asks whether | |
309 to recover that file. If you answer @kbd{y} for a file, it shows the | |
310 dates of that file and its auto-save file, then asks once again | |
311 whether to recover that file. For the second question, you must | |
312 confirm with @kbd{yes}. If you do, Emacs visits the file but gets the | |
313 text from the auto-save file. | |
25829 | 314 |
315 When @code{recover-session} is done, the files you've chosen to | |
316 recover are present in Emacs buffers. You should then save them. Only | |
317 this---saving them---updates the files themselves. | |
318 | |
62897
6181dbed8947
(After a Crash): Mention emacs-buffer.gdb as a recovery mechanism.
Noah Friedman <friedman@splode.com>
parents:
60342
diff
changeset
|
319 As a last resort, if you had buffers with content which were not |
6181dbed8947
(After a Crash): Mention emacs-buffer.gdb as a recovery mechanism.
Noah Friedman <friedman@splode.com>
parents:
60342
diff
changeset
|
320 associated with any files, or if the autosave was not recent enough to |
6181dbed8947
(After a Crash): Mention emacs-buffer.gdb as a recovery mechanism.
Noah Friedman <friedman@splode.com>
parents:
60342
diff
changeset
|
321 have recorded important changes, you can use the |
62899
1a33c4dbb62b
(After a Crash): Describe how to use emacs-buffer.gdb more explicitly.
Noah Friedman <friedman@splode.com>
parents:
62897
diff
changeset
|
322 @file{etc/emacs-buffer.gdb} script with GDB (the GNU Debugger) to |
1a33c4dbb62b
(After a Crash): Describe how to use emacs-buffer.gdb more explicitly.
Noah Friedman <friedman@splode.com>
parents:
62897
diff
changeset
|
323 retrieve them from a core dump--provided that a core dump was saved, |
1a33c4dbb62b
(After a Crash): Describe how to use emacs-buffer.gdb more explicitly.
Noah Friedman <friedman@splode.com>
parents:
62897
diff
changeset
|
324 and that the Emacs executable was not stripped of its debugging |
1a33c4dbb62b
(After a Crash): Describe how to use emacs-buffer.gdb more explicitly.
Noah Friedman <friedman@splode.com>
parents:
62897
diff
changeset
|
325 symbols. |
1a33c4dbb62b
(After a Crash): Describe how to use emacs-buffer.gdb more explicitly.
Noah Friedman <friedman@splode.com>
parents:
62897
diff
changeset
|
326 |
69800 | 327 As soon as you get the core dump, rename it to another name such as |
328 @file{core.emacs}, so that another crash won't overwrite it. | |
329 | |
62991
b9a3bc12a80f
(After a Crash): Polish previous change.
Richard M. Stallman <rms@gnu.org>
parents:
62899
diff
changeset
|
330 To use this script, run @code{gdb} with the file name of your Emacs |
b9a3bc12a80f
(After a Crash): Polish previous change.
Richard M. Stallman <rms@gnu.org>
parents:
62899
diff
changeset
|
331 executable and the file name of the core dump, e.g. @samp{gdb |
62899
1a33c4dbb62b
(After a Crash): Describe how to use emacs-buffer.gdb more explicitly.
Noah Friedman <friedman@splode.com>
parents:
62897
diff
changeset
|
332 /usr/bin/emacs core.emacs}. At the @code{(gdb)} prompt, load the |
1a33c4dbb62b
(After a Crash): Describe how to use emacs-buffer.gdb more explicitly.
Noah Friedman <friedman@splode.com>
parents:
62897
diff
changeset
|
333 recovery script: @samp{source /usr/src/emacs/etc/emacs-buffer.gdb}. |
62991
b9a3bc12a80f
(After a Crash): Polish previous change.
Richard M. Stallman <rms@gnu.org>
parents:
62899
diff
changeset
|
334 Then type the command @code{ybuffer-list} to see which buffers are |
b9a3bc12a80f
(After a Crash): Polish previous change.
Richard M. Stallman <rms@gnu.org>
parents:
62899
diff
changeset
|
335 available. For each buffer, it lists a buffer number. To save a |
b9a3bc12a80f
(After a Crash): Polish previous change.
Richard M. Stallman <rms@gnu.org>
parents:
62899
diff
changeset
|
336 buffer, use @code{ysave-buffer}; you specify the buffer number, and |
b9a3bc12a80f
(After a Crash): Polish previous change.
Richard M. Stallman <rms@gnu.org>
parents:
62899
diff
changeset
|
337 the file name to write that buffer into. You should use a file name |
b9a3bc12a80f
(After a Crash): Polish previous change.
Richard M. Stallman <rms@gnu.org>
parents:
62899
diff
changeset
|
338 which does not already exist; if the file does exist, the script does |
64464
a40344cc40b0
(After a Crash): Delete duplicate words.
Juri Linkov <juri@jurta.org>
parents:
64083
diff
changeset
|
339 not make a backup of its old contents. |
62897
6181dbed8947
(After a Crash): Mention emacs-buffer.gdb as a recovery mechanism.
Noah Friedman <friedman@splode.com>
parents:
60342
diff
changeset
|
340 |
25829 | 341 @node Emergency Escape |
342 @subsection Emergency Escape | |
343 | |
69800 | 344 On text-only terminals, the @dfn{emergency escape} feature suspends |
345 Emacs immediately if you type @kbd{C-g} a second time before Emacs can | |
346 actually respond to the first one by quitting. This is so you can | |
347 always get out of GNU Emacs no matter how badly it might be hung. | |
348 When things are working properly, Emacs recognizes and handles the | |
349 first @kbd{C-g} so fast that the second one won't trigger emergency | |
350 escape. However, if some problem prevents Emacs from handling the | |
351 first @kbd{C-g} properly, then the second one will get you back to the | |
352 shell. | |
25829 | 353 |
69800 | 354 When you resume Emacs after a suspension caused by emergency escape, |
355 it asks two questions before going back to what it had been doing: | |
25829 | 356 |
357 @example | |
358 Auto-save? (y or n) | |
359 Abort (and dump core)? (y or n) | |
360 @end example | |
361 | |
362 @noindent | |
363 Answer each one with @kbd{y} or @kbd{n} followed by @key{RET}. | |
364 | |
69800 | 365 Saying @kbd{y} to @samp{Auto-save?} causes immediate auto-saving of |
366 all modified buffers in which auto-saving is enabled. Saying @kbd{n} | |
367 skips this. | |
25829 | 368 |
69800 | 369 Saying @kbd{y} to @samp{Abort (and dump core)?} causes Emacs to |
370 crash, dumping core. This is to enable a wizard to figure out why | |
371 Emacs was failing to quit in the first place. Execution does not | |
372 continue after a core dump. | |
373 | |
374 If you answer this question @kbd{n}, Emacs execution resumes. With | |
375 luck, Emacs will ultimately do the requested quit. If not, each | |
376 subsequent @kbd{C-g} invokes emergency escape again. | |
25829 | 377 |
378 If Emacs is not really hung, just slow, you may invoke the double | |
69800 | 379 @kbd{C-g} feature without really meaning to. Then just resume and |
380 answer @kbd{n} to both questions, and you will get back to the former | |
381 state. The quit you requested will happen by and by. | |
25829 | 382 |
69800 | 383 Emergency escape is active only for text terminals. On a graphical |
384 display that supports multiple windows, you can use the window manager | |
385 to kill Emacs, or to switch to some other program. | |
25829 | 386 |
69800 | 387 On MS-DOS, you must type @kbd{C-@key{BREAK}} (twice) to cause |
388 emergency escape---but there are cases where it won't work, when | |
389 system call hangs or when Emacs is stuck in a tight loop in C code. | |
25829 | 390 |
391 @node Total Frustration | |
392 @subsection Help for Total Frustration | |
393 @cindex Eliza | |
394 @cindex doctor | |
395 | |
396 If using Emacs (or something else) becomes terribly frustrating and none | |
397 of the techniques described above solve the problem, Emacs can still help | |
398 you. | |
399 | |
400 First, if the Emacs you are using is not responding to commands, type | |
401 @kbd{C-g C-g} to get out of it and then start a new one. | |
402 | |
403 @findex doctor | |
404 Second, type @kbd{M-x doctor @key{RET}}. | |
405 | |
69800 | 406 The Emacs psychotherapist will help you feel better. Each time you |
407 say something to the psychotherapist, you must end it by typing | |
408 @key{RET} @key{RET}. This indicates you are finished typing. | |
25829 | 409 |
410 @node Bugs, Contributing, Lossage, Top | |
411 @section Reporting Bugs | |
412 | |
413 @cindex bugs | |
414 Sometimes you will encounter a bug in Emacs. Although we cannot | |
415 promise we can or will fix the bug, and we might not even agree that it | |
416 is a bug, we want to hear about problems you encounter. Often we agree | |
417 they are bugs and want to fix them. | |
418 | |
419 To make it possible for us to fix a bug, you must report it. In order | |
420 to do so effectively, you must know when and how to do it. | |
421 | |
38686
0d3019db87ac
(Lossage, Bugs): Mention etc/PROBLEMS and the Bugs section of the FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38245
diff
changeset
|
422 Before reporting a bug, it is a good idea to see if it is already |
0d3019db87ac
(Lossage, Bugs): Mention etc/PROBLEMS and the Bugs section of the FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38245
diff
changeset
|
423 known. You can find the list of known problems in the file |
54478 | 424 @file{etc/PROBLEMS} in the Emacs distribution; type @kbd{C-h C-e} to read |
38691
5c9ec2d0b570
(Lossage, Bugs): Mention the keys which display PROBLEMS and FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38686
diff
changeset
|
425 it. Some additional user-level problems can be found in @ref{Bugs and |
5c9ec2d0b570
(Lossage, Bugs): Mention the keys which display PROBLEMS and FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38686
diff
changeset
|
426 problems, , Bugs and problems, efaq, GNU Emacs FAQ}. Looking up your |
5c9ec2d0b570
(Lossage, Bugs): Mention the keys which display PROBLEMS and FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38686
diff
changeset
|
427 problem in these two documents might provide you with a solution or a |
5c9ec2d0b570
(Lossage, Bugs): Mention the keys which display PROBLEMS and FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38686
diff
changeset
|
428 work-around, or give you additional information about related issues. |
38686
0d3019db87ac
(Lossage, Bugs): Mention etc/PROBLEMS and the Bugs section of the FAQ.
Eli Zaretskii <eliz@gnu.org>
parents:
38245
diff
changeset
|
429 |
25829 | 430 @menu |
431 * Criteria: Bug Criteria. Have you really found a bug? | |
432 * Understanding Bug Reporting:: How to report a bug effectively. | |
433 * Checklist:: Steps to follow for a good bug report. | |
434 * Sending Patches:: How to send a patch for GNU Emacs. | |
435 @end menu | |
436 | |
437 @node Bug Criteria | |
438 @subsection When Is There a Bug | |
439 | |
69800 | 440 If Emacs accesses an invalid memory location (``segmentation |
441 fault''), or exits with an operating system error message that | |
442 indicates a problem in the program (as opposed to something like | |
443 ``disk full''), then it is certainly a bug. | |
25829 | 444 |
445 If Emacs updates the display in a way that does not correspond to what is | |
446 in the buffer, then it is certainly a bug. If a command seems to do the | |
447 wrong thing but the problem corrects itself if you type @kbd{C-l}, it is a | |
448 case of incorrect display updating. | |
449 | |
450 Taking forever to complete a command can be a bug, but you must make | |
451 certain that it was really Emacs's fault. Some commands simply take a | |
452 long time. Type @kbd{C-g} (@kbd{C-@key{BREAK}} on MS-DOS) and then @kbd{C-h l} | |
453 to see whether the input Emacs received was what you intended to type; | |
454 if the input was such that you @emph{know} it should have been processed | |
455 quickly, report a bug. If you don't know whether the command should | |
456 take a long time, find out by looking in the manual or by asking for | |
457 assistance. | |
458 | |
459 If a command you are familiar with causes an Emacs error message in a | |
460 case where its usual definition ought to be reasonable, it is probably a | |
461 bug. | |
462 | |
463 If a command does the wrong thing, that is a bug. But be sure you know | |
464 for certain what it ought to have done. If you aren't familiar with the | |
465 command, or don't know for certain how the command is supposed to work, | |
466 then it might actually be working right. Rather than jumping to | |
467 conclusions, show the problem to someone who knows for certain. | |
468 | |
36388
5835d43dcf93
(Bug Criteria): Reword a sentence.
Gerd Moellmann <gerd@gnu.org>
parents:
36294
diff
changeset
|
469 Finally, a command's intended definition may not be the best |
5835d43dcf93
(Bug Criteria): Reword a sentence.
Gerd Moellmann <gerd@gnu.org>
parents:
36294
diff
changeset
|
470 possible definition for editing with. This is a very important sort |
5835d43dcf93
(Bug Criteria): Reword a sentence.
Gerd Moellmann <gerd@gnu.org>
parents:
36294
diff
changeset
|
471 of problem, but it is also a matter of judgment. Also, it is easy to |
5835d43dcf93
(Bug Criteria): Reword a sentence.
Gerd Moellmann <gerd@gnu.org>
parents:
36294
diff
changeset
|
472 come to such a conclusion out of ignorance of some of the existing |
5835d43dcf93
(Bug Criteria): Reword a sentence.
Gerd Moellmann <gerd@gnu.org>
parents:
36294
diff
changeset
|
473 features. It is probably best not to complain about such a problem |
5835d43dcf93
(Bug Criteria): Reword a sentence.
Gerd Moellmann <gerd@gnu.org>
parents:
36294
diff
changeset
|
474 until you have checked the documentation in the usual ways, feel |
5835d43dcf93
(Bug Criteria): Reword a sentence.
Gerd Moellmann <gerd@gnu.org>
parents:
36294
diff
changeset
|
475 confident that you understand it, and know for certain that what you |
69800 | 476 want is not available. Ask other Emacs users, too. If you are not |
477 sure what the command is supposed to do after a careful reading of the | |
478 manual, check the index and glossary for any terms that may be | |
479 unclear. | |
25829 | 480 |
481 If after careful rereading of the manual you still do not understand | |
482 what the command should do, that indicates a bug in the manual, which | |
483 you should report. The manual's job is to make everything clear to | |
484 people who are not Emacs experts---including you. It is just as | |
485 important to report documentation bugs as program bugs. | |
486 | |
487 If the on-line documentation string of a function or variable disagrees | |
488 with the manual, one of them must be wrong; that is a bug. | |
489 | |
490 @node Understanding Bug Reporting | |
491 @subsection Understanding Bug Reporting | |
492 | |
493 @findex emacs-version | |
494 When you decide that there is a bug, it is important to report it and to | |
495 report it in a way which is useful. What is most useful is an exact | |
496 description of what commands you type, starting with the shell command to | |
497 run Emacs, until the problem happens. | |
498 | |
499 The most important principle in reporting a bug is to report | |
500 @emph{facts}. Hypotheses and verbal descriptions are no substitute for | |
501 the detailed raw data. Reporting the facts is straightforward, but many | |
502 people strain to posit explanations and report them instead of the | |
503 facts. If the explanations are based on guesses about how Emacs is | |
504 implemented, they will be useless; meanwhile, lacking the facts, we will | |
505 have no real information about the bug. | |
506 | |
507 For example, suppose that you type @kbd{C-x C-f /glorp/baz.ugh | |
69800 | 508 @key{RET}}, visiting a file which (you know) happens to be rather |
509 large, and Emacs displays @samp{I feel pretty today}. The best way to | |
510 report the bug is with a sentence like the preceding one, because it | |
511 gives all the facts. | |
25829 | 512 |
513 A bad way would be to assume that the problem is due to the size of | |
514 the file and say, ``I visited a large file, and Emacs displayed @samp{I | |
515 feel pretty today}.'' This is what we mean by ``guessing | |
516 explanations.'' The problem is just as likely to be due to the fact | |
517 that there is a @samp{z} in the file name. If this is so, then when we | |
518 got your report, we would try out the problem with some ``large file,'' | |
519 probably with no @samp{z} in its name, and not see any problem. There | |
520 is no way in the world that we could guess that we should try visiting a | |
521 file with a @samp{z} in its name. | |
522 | |
523 Alternatively, the problem might be due to the fact that the file starts | |
524 with exactly 25 spaces. For this reason, you should make sure that you | |
525 inform us of the exact contents of any file that is needed to reproduce the | |
526 bug. What if the problem only occurs when you have typed the @kbd{C-x C-a} | |
527 command previously? This is why we ask you to give the exact sequence of | |
528 characters you typed since starting the Emacs session. | |
529 | |
530 You should not even say ``visit a file'' instead of @kbd{C-x C-f} unless | |
531 you @emph{know} that it makes no difference which visiting command is used. | |
532 Similarly, rather than saying ``if I have three characters on the line,'' | |
533 say ``after I type @kbd{@key{RET} A B C @key{RET} C-p},'' if that is | |
69800 | 534 the way you entered the text. |
25829 | 535 |
536 So please don't guess any explanations when you report a bug. If you | |
537 want to actually @emph{debug} the problem, and report explanations that | |
538 are more than guesses, that is useful---but please include the facts as | |
539 well. | |
540 | |
541 @node Checklist | |
542 @subsection Checklist for Bug Reports | |
543 | |
544 @cindex reporting bugs | |
545 The best way to send a bug report is to mail it electronically to the | |
36180
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
546 Emacs maintainers at @email{bug-gnu-emacs@@gnu.org}, or to |
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
547 @email{emacs-pretest-bug@@gnu.org} if you are pretesting an Emacs beta |
26021
4f5e4ec69f6a
Add emacs-prestest-bug@gnu.org analogous to bug-gnu-emacs@gnu.org.
Gerd Moellmann <gerd@gnu.org>
parents:
25829
diff
changeset
|
548 release. (If you want to suggest a change as an improvement, use the |
4f5e4ec69f6a
Add emacs-prestest-bug@gnu.org analogous to bug-gnu-emacs@gnu.org.
Gerd Moellmann <gerd@gnu.org>
parents:
25829
diff
changeset
|
549 same address.) |
25829 | 550 |
551 If you'd like to read the bug reports, you can find them on the | |
552 newsgroup @samp{gnu.emacs.bug}; keep in mind, however, that as a | |
553 spectator you should not criticize anything about what you see there. | |
554 The purpose of bug reports is to give information to the Emacs | |
555 maintainers. Spectators are welcome only as long as they do not | |
38245
9ada58a02f7e
Don't include data bigger than 500,000 bytes directly in the bug
Richard M. Stallman <rms@gnu.org>
parents:
38230
diff
changeset
|
556 interfere with this. In particular, some bug reports contain fairly |
9ada58a02f7e
Don't include data bigger than 500,000 bytes directly in the bug
Richard M. Stallman <rms@gnu.org>
parents:
38230
diff
changeset
|
557 large amounts of data; spectators should not complain about this. |
25829 | 558 |
559 Please do not post bug reports using netnews; mail is more reliable | |
38245
9ada58a02f7e
Don't include data bigger than 500,000 bytes directly in the bug
Richard M. Stallman <rms@gnu.org>
parents:
38230
diff
changeset
|
560 than netnews about reporting your correct address, which we may need |
9ada58a02f7e
Don't include data bigger than 500,000 bytes directly in the bug
Richard M. Stallman <rms@gnu.org>
parents:
38230
diff
changeset
|
561 in order to ask you for more information. If your data is more than |
9ada58a02f7e
Don't include data bigger than 500,000 bytes directly in the bug
Richard M. Stallman <rms@gnu.org>
parents:
38230
diff
changeset
|
562 500,000 bytes, please don't include it directly in the bug report; |
9ada58a02f7e
Don't include data bigger than 500,000 bytes directly in the bug
Richard M. Stallman <rms@gnu.org>
parents:
38230
diff
changeset
|
563 instead, offer to send it on request, or make it available by ftp and |
9ada58a02f7e
Don't include data bigger than 500,000 bytes directly in the bug
Richard M. Stallman <rms@gnu.org>
parents:
38230
diff
changeset
|
564 say where. |
25829 | 565 |
566 @findex report-emacs-bug | |
567 A convenient way to send a bug report for Emacs is to use the command | |
568 @kbd{M-x report-emacs-bug}. This sets up a mail buffer (@pxref{Sending | |
569 Mail}) and automatically inserts @emph{some} of the essential | |
570 information. However, it cannot supply all the necessary information; | |
571 you should still read and follow the guidelines below, so you can enter | |
572 the other crucial information by hand before you send the message. | |
573 | |
574 To enable maintainers to investigate a bug, your report | |
575 should include all these things: | |
576 | |
577 @itemize @bullet | |
578 @item | |
579 The version number of Emacs. Without this, we won't know whether there | |
580 is any point in looking for the bug in the current version of GNU | |
581 Emacs. | |
582 | |
583 You can get the version number by typing @kbd{M-x emacs-version | |
584 @key{RET}}. If that command does not work, you probably have something | |
585 other than GNU Emacs, so you will have to report the bug somewhere | |
586 else. | |
587 | |
588 @item | |
589 The type of machine you are using, and the operating system name and | |
590 version number. @kbd{M-x emacs-version @key{RET}} provides this | |
591 information too. Copy its output from the @samp{*Messages*} buffer, so | |
592 that you get it all and get it accurately. | |
593 | |
594 @item | |
595 The operands given to the @code{configure} command when Emacs was | |
596 installed. | |
597 | |
598 @item | |
599 A complete list of any modifications you have made to the Emacs source. | |
600 (We may not have time to investigate the bug unless it happens in an | |
601 unmodified Emacs. But if you've made modifications and you don't tell | |
602 us, you are sending us on a wild goose chase.) | |
603 | |
604 Be precise about these changes. A description in English is not | |
605 enough---send a context diff for them. | |
606 | |
607 Adding files of your own, or porting to another machine, is a | |
608 modification of the source. | |
609 | |
610 @item | |
611 Details of any other deviations from the standard procedure for installing | |
612 GNU Emacs. | |
613 | |
614 @item | |
615 The complete text of any files needed to reproduce the bug. | |
616 | |
617 If you can tell us a way to cause the problem without visiting any files, | |
618 please do so. This makes it much easier to debug. If you do need files, | |
619 make sure you arrange for us to see their exact contents. For example, it | |
69800 | 620 can matter whether there are spaces at the ends of lines, or a |
25829 | 621 newline after the last line in the buffer (nothing ought to care whether |
622 the last line is terminated, but try telling the bugs that). | |
623 | |
624 @item | |
625 The precise commands we need to type to reproduce the bug. | |
626 | |
627 @findex open-dribble-file | |
628 @cindex dribble file | |
35705
6c05ec832ecc
(Checklist): Add index entry for logging keystrokes.
Eli Zaretskii <eliz@gnu.org>
parents:
35239
diff
changeset
|
629 @cindex logging keystrokes |
69800 | 630 The easy way to record the input to Emacs precisely is to write a |
25829 | 631 dribble file. To start the file, execute the Lisp expression |
632 | |
633 @example | |
634 (open-dribble-file "~/dribble") | |
635 @end example | |
636 | |
637 @noindent | |
638 using @kbd{M-:} or from the @samp{*scratch*} buffer just after | |
639 starting Emacs. From then on, Emacs copies all your input to the | |
640 specified dribble file until the Emacs process is killed. | |
641 | |
642 @item | |
643 @findex open-termscript | |
644 @cindex termscript file | |
29107 | 645 @cindex @env{TERM} environment variable |
25829 | 646 For possible display bugs, the terminal type (the value of environment |
29107 | 647 variable @env{TERM}), the complete termcap entry for the terminal from |
25829 | 648 @file{/etc/termcap} (since that file is not identical on all machines), |
649 and the output that Emacs actually sent to the terminal. | |
650 | |
651 The way to collect the terminal output is to execute the Lisp expression | |
652 | |
653 @example | |
654 (open-termscript "~/termscript") | |
655 @end example | |
656 | |
657 @noindent | |
658 using @kbd{M-:} or from the @samp{*scratch*} buffer just after | |
659 starting Emacs. From then on, Emacs copies all terminal output to the | |
660 specified termscript file as well, until the Emacs process is killed. | |
661 If the problem happens when Emacs starts up, put this expression into | |
662 your @file{.emacs} file so that the termscript file will be open when | |
663 Emacs displays the screen for the first time. | |
664 | |
665 Be warned: it is often difficult, and sometimes impossible, to fix a | |
666 terminal-dependent bug without access to a terminal of the type that | |
69800 | 667 stimulates the bug. |
25829 | 668 |
669 @item | |
52979
3649390c0f91
Replace @sc{ascii} and ASCII with @acronym{ASCII}.
Eli Zaretskii <eliz@gnu.org>
parents:
52401
diff
changeset
|
670 If non-@acronym{ASCII} text or internationalization is relevant, the locale that |
36497
1ba3f8033b3a
(Checklist): Say that the example with LC_ALL and such is for a Unix shell.
Eli Zaretskii <eliz@gnu.org>
parents:
36388
diff
changeset
|
671 was current when you started Emacs. On GNU/Linux and Unix systems, or |
38865
62e02f5ae533
Avoid saying "Unix" in a way that includes GNU.
Richard M. Stallman <rms@gnu.org>
parents:
38767
diff
changeset
|
672 if you use a Posix-style shell such as Bash, you can use this shell |
36497
1ba3f8033b3a
(Checklist): Say that the example with LC_ALL and such is for a Unix shell.
Eli Zaretskii <eliz@gnu.org>
parents:
36388
diff
changeset
|
673 command to view the relevant values: |
35239
a4e73c75cbca
Ask for locale info in bug reports.
Richard M. Stallman <rms@gnu.org>
parents:
35188
diff
changeset
|
674 |
37580
ac2f45ecf299
Use @smallexample for the echo LC... command.
Richard M. Stallman <rms@gnu.org>
parents:
37508
diff
changeset
|
675 @smallexample |
42117
bdf2f34631aa
Finish previous change.
Richard M. Stallman <rms@gnu.org>
parents:
42110
diff
changeset
|
676 echo LC_ALL=$LC_ALL LC_COLLATE=$LC_COLLATE LC_CTYPE=$LC_CTYPE \ |
37119
a4f474cb3812
(Checklist): Include more LC_* variables in the list, as suggested
Eli Zaretskii <eliz@gnu.org>
parents:
37087
diff
changeset
|
677 LC_MESSAGES=$LC_MESSAGES LC_TIME=$LC_TIME LANG=$LANG |
37580
ac2f45ecf299
Use @smallexample for the echo LC... command.
Richard M. Stallman <rms@gnu.org>
parents:
37508
diff
changeset
|
678 @end smallexample |
35239
a4e73c75cbca
Ask for locale info in bug reports.
Richard M. Stallman <rms@gnu.org>
parents:
35188
diff
changeset
|
679 |
37087
f4039f11318f
(Checklist): Mention the `locale' command as an alternative method of
Eli Zaretskii <eliz@gnu.org>
parents:
36791
diff
changeset
|
680 Alternatively, use the @command{locale} command, if your system has it, |
f4039f11318f
(Checklist): Mention the `locale' command as an alternative method of
Eli Zaretskii <eliz@gnu.org>
parents:
36791
diff
changeset
|
681 to display your locale settings. |
f4039f11318f
(Checklist): Mention the `locale' command as an alternative method of
Eli Zaretskii <eliz@gnu.org>
parents:
36791
diff
changeset
|
682 |
f4039f11318f
(Checklist): Mention the `locale' command as an alternative method of
Eli Zaretskii <eliz@gnu.org>
parents:
36791
diff
changeset
|
683 You can use the @kbd{M-!} command to execute these commands from |
35239
a4e73c75cbca
Ask for locale info in bug reports.
Richard M. Stallman <rms@gnu.org>
parents:
35188
diff
changeset
|
684 Emacs, and then copy the output from the @samp{*Messages*} buffer into |
36620
639ad3d05eb6
(Checklist): Mention that `getenv' can be used to get at the value
Eli Zaretskii <eliz@gnu.org>
parents:
36497
diff
changeset
|
685 the bug report. Alternatively, @kbd{M-x getenv @key{RET} LC_ALL |
38870
d44abb4e68b2
Don't use "print" for displaying a message.
Richard M. Stallman <rms@gnu.org>
parents:
38865
diff
changeset
|
686 @key{RET}} will display the value of @code{LC_ALL} in the echo area, and |
36620
639ad3d05eb6
(Checklist): Mention that `getenv' can be used to get at the value
Eli Zaretskii <eliz@gnu.org>
parents:
36497
diff
changeset
|
687 you can copy its output from the @samp{*Messages*} buffer. |
35239
a4e73c75cbca
Ask for locale info in bug reports.
Richard M. Stallman <rms@gnu.org>
parents:
35188
diff
changeset
|
688 |
a4e73c75cbca
Ask for locale info in bug reports.
Richard M. Stallman <rms@gnu.org>
parents:
35188
diff
changeset
|
689 @item |
25829 | 690 A description of what behavior you observe that you believe is |
691 incorrect. For example, ``The Emacs process gets a fatal signal,'' or, | |
692 ``The resulting text is as follows, which I think is wrong.'' | |
693 | |
694 Of course, if the bug is that Emacs gets a fatal signal, then one can't | |
695 miss it. But if the bug is incorrect text, the maintainer might fail to | |
696 notice what is wrong. Why leave it to chance? | |
697 | |
698 Even if the problem you experience is a fatal signal, you should still | |
699 say so explicitly. Suppose something strange is going on, such as, your | |
700 copy of the source is out of sync, or you have encountered a bug in the | |
701 C library on your system. (This has happened!) Your copy might crash | |
702 and the copy here might not. If you @emph{said} to expect a crash, then | |
703 when Emacs here fails to crash, we would know that the bug was not | |
704 happening. If you don't say to expect a crash, then we would not know | |
705 whether the bug was happening---we would not be able to draw any | |
706 conclusion from our observations. | |
707 | |
708 @item | |
36180
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
709 If the bug is that the Emacs Manual or the Emacs Lisp Reference Manual |
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
710 fails to describe the actual behavior of Emacs, or that the text is |
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
711 confusing, copy in the text from the online manual which you think is |
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
712 at fault. If the section is small, just the section name is enough. |
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
713 |
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
714 @item |
25829 | 715 If the manifestation of the bug is an Emacs error message, it is |
716 important to report the precise text of the error message, and a | |
717 backtrace showing how the Lisp program in Emacs arrived at the error. | |
718 | |
719 To get the error message text accurately, copy it from the | |
720 @samp{*Messages*} buffer into the bug report. Copy all of it, not just | |
721 part. | |
722 | |
37347
bd817d6f9ba3
Minor clarifications regarding DEL key.
Richard M. Stallman <rms@gnu.org>
parents:
37126
diff
changeset
|
723 @findex toggle-debug-on-error |
37508
e2849d417d6d
(Checklist): Mention Edebug.
Eli Zaretskii <eliz@gnu.org>
parents:
37498
diff
changeset
|
724 @pindex Edebug |
37347
bd817d6f9ba3
Minor clarifications regarding DEL key.
Richard M. Stallman <rms@gnu.org>
parents:
37126
diff
changeset
|
725 To make a backtrace for the error, use @kbd{M-x toggle-debug-on-error} |
bd817d6f9ba3
Minor clarifications regarding DEL key.
Richard M. Stallman <rms@gnu.org>
parents:
37126
diff
changeset
|
726 before the error happens (that is to say, you must give that command |
69800 | 727 and then make the bug happen). This causes the error to start the Lisp |
37347
bd817d6f9ba3
Minor clarifications regarding DEL key.
Richard M. Stallman <rms@gnu.org>
parents:
37126
diff
changeset
|
728 debugger, which shows you a backtrace. Copy the text of the |
bd817d6f9ba3
Minor clarifications regarding DEL key.
Richard M. Stallman <rms@gnu.org>
parents:
37126
diff
changeset
|
729 debugger's backtrace into the bug report. @xref{Debugger,, The Lisp |
bd817d6f9ba3
Minor clarifications regarding DEL key.
Richard M. Stallman <rms@gnu.org>
parents:
37126
diff
changeset
|
730 Debugger, elisp, the Emacs Lisp Reference Manual}, for information on |
37508
e2849d417d6d
(Checklist): Mention Edebug.
Eli Zaretskii <eliz@gnu.org>
parents:
37498
diff
changeset
|
731 debugging Emacs Lisp programs with the Edebug package. |
25829 | 732 |
733 This use of the debugger is possible only if you know how to make the | |
734 bug happen again. If you can't make it happen again, at least copy | |
735 the whole error message. | |
736 | |
737 @item | |
738 Check whether any programs you have loaded into the Lisp world, | |
739 including your @file{.emacs} file, set any variables that may affect the | |
740 functioning of Emacs. Also, see whether the problem happens in a | |
741 freshly started Emacs without loading your @file{.emacs} file (start | |
742 Emacs with the @code{-q} switch to prevent loading the init file). If | |
743 the problem does @emph{not} occur then, you must report the precise | |
744 contents of any programs that you must load into the Lisp world in order | |
745 to cause the problem to occur. | |
746 | |
747 @item | |
748 If the problem does depend on an init file or other Lisp programs that | |
749 are not part of the standard Emacs system, then you should make sure it | |
750 is not a bug in those programs by complaining to their maintainers | |
751 first. After they verify that they are using Emacs in a way that is | |
752 supposed to work, they should report the bug. | |
753 | |
754 @item | |
755 If you wish to mention something in the GNU Emacs source, show the line | |
756 of code with a few lines of context. Don't just give a line number. | |
757 | |
758 The line numbers in the development sources don't match those in your | |
759 sources. It would take extra work for the maintainers to determine what | |
760 code is in your version at a given line number, and we could not be | |
761 certain. | |
762 | |
763 @item | |
764 Additional information from a C debugger such as GDB might enable | |
765 someone to find a problem on a machine which he does not have available. | |
766 If you don't know how to use GDB, please read the GDB manual---it is not | |
767 very long, and using GDB is easy. You can find the GDB distribution, | |
768 including the GDB manual in online form, in most of the same places you | |
769 can find the Emacs distribution. To run Emacs under GDB, you should | |
770 switch to the @file{src} subdirectory in which Emacs was compiled, then | |
771 do @samp{gdb emacs}. It is important for the directory @file{src} to be | |
772 current so that GDB will read the @file{.gdbinit} file in this | |
773 directory. | |
774 | |
775 However, you need to think when you collect the additional information | |
776 if you want it to show what causes the bug. | |
777 | |
778 @cindex backtrace for bug reports | |
779 For example, many people send just a backtrace, but that is not very | |
780 useful by itself. A simple backtrace with arguments often conveys | |
781 little about what is happening inside GNU Emacs, because most of the | |
782 arguments listed in the backtrace are pointers to Lisp objects. The | |
783 numeric values of these pointers have no significance whatever; all that | |
784 matters is the contents of the objects they point to (and most of the | |
785 contents are themselves pointers). | |
786 | |
787 @findex debug_print | |
788 To provide useful information, you need to show the values of Lisp | |
789 objects in Lisp notation. Do this for each variable which is a Lisp | |
790 object, in several stack frames near the bottom of the stack. Look at | |
791 the source to see which variables are Lisp objects, because the debugger | |
792 thinks of them as integers. | |
793 | |
794 To show a variable's value in Lisp syntax, first print its value, then | |
795 use the user-defined GDB command @code{pr} to print the Lisp object in | |
796 Lisp syntax. (If you must use another debugger, call the function | |
797 @code{debug_print} with the object as an argument.) The @code{pr} | |
798 command is defined by the file @file{.gdbinit}, and it works only if you | |
799 are debugging a running process (not with a core dump). | |
800 | |
801 To make Lisp errors stop Emacs and return to GDB, put a breakpoint at | |
802 @code{Fsignal}. | |
803 | |
27729 | 804 For a short listing of Lisp functions running, type the GDB |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
46235
diff
changeset
|
805 command @code{xbacktrace}. |
27729 | 806 |
25829 | 807 The file @file{.gdbinit} defines several other commands that are useful |
808 for examining the data types and contents of Lisp objects. Their names | |
809 begin with @samp{x}. These commands work at a lower level than | |
810 @code{pr}, and are less convenient, but they may work even when | |
811 @code{pr} does not, such as when debugging a core dump or when Emacs has | |
812 had a fatal signal. | |
813 | |
35874
99572fa1c8c3
Remove the more arcane part of Emacs debug instructions. Replace
Eli Zaretskii <eliz@gnu.org>
parents:
35705
diff
changeset
|
814 @cindex debugging Emacs, tricks and techniques |
99572fa1c8c3
Remove the more arcane part of Emacs debug instructions. Replace
Eli Zaretskii <eliz@gnu.org>
parents:
35705
diff
changeset
|
815 More detailed advice and other useful techniques for debugging Emacs |
99572fa1c8c3
Remove the more arcane part of Emacs debug instructions. Replace
Eli Zaretskii <eliz@gnu.org>
parents:
35705
diff
changeset
|
816 are available in the file @file{etc/DEBUG} in the Emacs distribution. |
99572fa1c8c3
Remove the more arcane part of Emacs debug instructions. Replace
Eli Zaretskii <eliz@gnu.org>
parents:
35705
diff
changeset
|
817 That file also includes instructions for investigating problems |
99572fa1c8c3
Remove the more arcane part of Emacs debug instructions. Replace
Eli Zaretskii <eliz@gnu.org>
parents:
35705
diff
changeset
|
818 whereby Emacs stops responding (many people assume that Emacs is |
36180
252e21b04fb1
Suggest copying problematical manual text into the bug report.
Richard M. Stallman <rms@gnu.org>
parents:
35874
diff
changeset
|
819 ``hung,'' whereas in fact it might be in an infinite loop). |
25829 | 820 |
38130
7aad2fda759d
Update how to find etc/DEBUG.
Richard M. Stallman <rms@gnu.org>
parents:
37976
diff
changeset
|
821 To find the file @file{etc/DEBUG} in your Emacs installation, use the |
7aad2fda759d
Update how to find etc/DEBUG.
Richard M. Stallman <rms@gnu.org>
parents:
37976
diff
changeset
|
822 directory name stored in the variable @code{data-directory}. |
25829 | 823 @end itemize |
824 | |
825 Here are some things that are not necessary in a bug report: | |
826 | |
827 @itemize @bullet | |
828 @item | |
829 A description of the envelope of the bug---this is not necessary for a | |
830 reproducible bug. | |
831 | |
832 Often people who encounter a bug spend a lot of time investigating | |
833 which changes to the input file will make the bug go away and which | |
834 changes will not affect it. | |
835 | |
836 This is often time-consuming and not very useful, because the way we | |
38130
7aad2fda759d
Update how to find etc/DEBUG.
Richard M. Stallman <rms@gnu.org>
parents:
37976
diff
changeset
|
837 will find the bug is by running a single example under the debugger |
7aad2fda759d
Update how to find etc/DEBUG.
Richard M. Stallman <rms@gnu.org>
parents:
37976
diff
changeset
|
838 with breakpoints, not by pure deduction from a series of examples. |
7aad2fda759d
Update how to find etc/DEBUG.
Richard M. Stallman <rms@gnu.org>
parents:
37976
diff
changeset
|
839 You might as well save time by not searching for additional examples. |
7aad2fda759d
Update how to find etc/DEBUG.
Richard M. Stallman <rms@gnu.org>
parents:
37976
diff
changeset
|
840 It is better to send the bug report right away, go back to editing, |
7aad2fda759d
Update how to find etc/DEBUG.
Richard M. Stallman <rms@gnu.org>
parents:
37976
diff
changeset
|
841 and find another bug to report. |
25829 | 842 |
843 Of course, if you can find a simpler example to report @emph{instead} of | |
844 the original one, that is a convenience. Errors in the output will be | |
845 easier to spot, running under the debugger will take less time, etc. | |
846 | |
847 However, simplification is not vital; if you can't do this or don't have | |
848 time to try, please report the bug with your original test case. | |
849 | |
850 @item | |
38230
ec2015ba505d
Explain why don't mail a core dump.
Richard M. Stallman <rms@gnu.org>
parents:
38130
diff
changeset
|
851 A core dump file. |
ec2015ba505d
Explain why don't mail a core dump.
Richard M. Stallman <rms@gnu.org>
parents:
38130
diff
changeset
|
852 |
ec2015ba505d
Explain why don't mail a core dump.
Richard M. Stallman <rms@gnu.org>
parents:
38130
diff
changeset
|
853 Debugging the core dump might be useful, but it can only be done on |
ec2015ba505d
Explain why don't mail a core dump.
Richard M. Stallman <rms@gnu.org>
parents:
38130
diff
changeset
|
854 your machine, with your Emacs executable. Therefore, sending the core |
ec2015ba505d
Explain why don't mail a core dump.
Richard M. Stallman <rms@gnu.org>
parents:
38130
diff
changeset
|
855 dump file to the Emacs maintainers won't be useful. Above all, don't |
ec2015ba505d
Explain why don't mail a core dump.
Richard M. Stallman <rms@gnu.org>
parents:
38130
diff
changeset
|
856 include the core file in an email bug report! Such a large message |
ec2015ba505d
Explain why don't mail a core dump.
Richard M. Stallman <rms@gnu.org>
parents:
38130
diff
changeset
|
857 can be extremely inconvenient. |
ec2015ba505d
Explain why don't mail a core dump.
Richard M. Stallman <rms@gnu.org>
parents:
38130
diff
changeset
|
858 |
ec2015ba505d
Explain why don't mail a core dump.
Richard M. Stallman <rms@gnu.org>
parents:
38130
diff
changeset
|
859 @item |
25829 | 860 A system-call trace of Emacs execution. |
861 | |
862 System-call traces are very useful for certain special kinds of | |
863 debugging, but in most cases they give little useful information. It is | |
864 therefore strange that many people seem to think that @emph{the} way to | |
865 report information about a crash is to send a system-call trace. Perhaps | |
866 this is a habit formed from experience debugging programs that don't | |
867 have source code or debugging symbols. | |
868 | |
869 In most programs, a backtrace is normally far, far more informative than | |
870 a system-call trace. Even in Emacs, a simple backtrace is generally | |
871 more informative, though to give full information you should supplement | |
872 the backtrace by displaying variable values and printing them as Lisp | |
873 objects with @code{pr} (see above). | |
874 | |
875 @item | |
876 A patch for the bug. | |
877 | |
878 A patch for the bug is useful if it is a good one. But don't omit the | |
879 other information that a bug report needs, such as the test case, on the | |
880 assumption that a patch is sufficient. We might see problems with your | |
881 patch and decide to fix the problem another way, or we might not | |
882 understand it at all. And if we can't understand what bug you are | |
883 trying to fix, or why your patch should be an improvement, we mustn't | |
884 install it. | |
885 | |
886 @ifinfo | |
887 @xref{Sending Patches}, for guidelines on how to make it easy for us to | |
888 understand and install your patches. | |
889 @end ifinfo | |
890 | |
891 @item | |
892 A guess about what the bug is or what it depends on. | |
893 | |
894 Such guesses are usually wrong. Even experts can't guess right about | |
895 such things without first using the debugger to find the facts. | |
896 @end itemize | |
897 | |
898 @node Sending Patches | |
899 @subsection Sending Patches for GNU Emacs | |
900 | |
901 @cindex sending patches for GNU Emacs | |
902 @cindex patches, sending | |
903 If you would like to write bug fixes or improvements for GNU Emacs, | |
904 that is very helpful. When you send your changes, please follow these | |
905 guidelines to make it easy for the maintainers to use them. If you | |
906 don't follow these guidelines, your information might still be useful, | |
907 but using it will take extra work. Maintaining GNU Emacs is a lot of | |
908 work in the best of circumstances, and we can't keep up unless you do | |
909 your best to help. | |
910 | |
911 @itemize @bullet | |
912 @item | |
913 Send an explanation with your changes of what problem they fix or what | |
914 improvement they bring about. For a bug fix, just include a copy of the | |
915 bug report, and explain why the change fixes the bug. | |
916 | |
917 (Referring to a bug report is not as good as including it, because then | |
918 we will have to look it up, and we have probably already deleted it if | |
919 we've already fixed the bug.) | |
920 | |
921 @item | |
922 Always include a proper bug report for the problem you think you have | |
923 fixed. We need to convince ourselves that the change is right before | |
924 installing it. Even if it is correct, we might have trouble | |
925 understanding it if we don't have a way to reproduce the problem. | |
926 | |
927 @item | |
928 Include all the comments that are appropriate to help people reading the | |
929 source in the future understand why this change was needed. | |
930 | |
931 @item | |
932 Don't mix together changes made for different reasons. | |
933 Send them @emph{individually}. | |
934 | |
935 If you make two changes for separate reasons, then we might not want to | |
936 install them both. We might want to install just one. If you send them | |
937 all jumbled together in a single set of diffs, we have to do extra work | |
938 to disentangle them---to figure out which parts of the change serve | |
939 which purpose. If we don't have time for this, we might have to ignore | |
940 your changes entirely. | |
941 | |
942 If you send each change as soon as you have written it, with its own | |
943 explanation, then two changes never get tangled up, and we can consider | |
944 each one properly without any extra work to disentangle them. | |
945 | |
946 @item | |
947 Send each change as soon as that change is finished. Sometimes people | |
948 think they are helping us by accumulating many changes to send them all | |
949 together. As explained above, this is absolutely the worst thing you | |
950 could do. | |
951 | |
952 Since you should send each change separately, you might as well send it | |
953 right away. That gives us the option of installing it immediately if it | |
954 is important. | |
955 | |
956 @item | |
957 Use @samp{diff -c} to make your diffs. Diffs without context are hard | |
958 to install reliably. More than that, they are hard to study; we must | |
959 always study a patch to decide whether we want to install it. Unidiff | |
960 format is better than contextless diffs, but not as easy to read as | |
961 @samp{-c} format. | |
962 | |
963 If you have GNU diff, use @samp{diff -c -F'^[_a-zA-Z0-9$]+ *('} when | |
964 making diffs of C code. This shows the name of the function that each | |
965 change occurs in. | |
966 | |
967 @item | |
968 Avoid any ambiguity as to which is the old version and which is the new. | |
969 Please make the old version the first argument to diff, and the new | |
970 version the second argument. And please give one version or the other a | |
971 name that indicates whether it is the old version or your new changed | |
972 one. | |
973 | |
974 @item | |
975 Write the change log entries for your changes. This is both to save us | |
976 the extra work of writing them, and to help explain your changes so we | |
977 can understand them. | |
978 | |
979 The purpose of the change log is to show people where to find what was | |
980 changed. So you need to be specific about what functions you changed; | |
981 in large functions, it's often helpful to indicate where within the | |
982 function the change was. | |
983 | |
984 On the other hand, once you have shown people where to find the change, | |
985 you need not explain its purpose in the change log. Thus, if you add a | |
986 new function, all you need to say about it is that it is new. If you | |
987 feel that the purpose needs explaining, it probably does---but put the | |
988 explanation in comments in the code. It will be more useful there. | |
989 | |
69800 | 990 Please read the @file{ChangeLog} files in the @file{src} and |
991 @file{lisp} directories to see what sorts of information to put in, | |
992 and to learn the style that we use. @xref{Change Log}. | |
25829 | 993 |
994 @item | |
995 When you write the fix, keep in mind that we can't install a change that | |
996 would break other systems. Please think about what effect your change | |
997 will have if compiled on another type of system. | |
998 | |
999 Sometimes people send fixes that @emph{might} be an improvement in | |
1000 general---but it is hard to be sure of this. It's hard to install | |
1001 such changes because we have to study them very carefully. Of course, | |
1002 a good explanation of the reasoning by which you concluded the change | |
1003 was correct can help convince us. | |
1004 | |
1005 The safest changes are changes to the configuration files for a | |
1006 particular machine. These are safe because they can't create new bugs | |
1007 on other machines. | |
1008 | |
1009 Please help us keep up with the workload by designing the patch in a | |
1010 form that is clearly safe to install. | |
1011 @end itemize | |
1012 | |
1013 @node Contributing, Service, Bugs, Top | |
1014 @section Contributing to Emacs Development | |
1015 | |
1016 If you would like to help pretest Emacs releases to assure they work | |
1017 well, or if you would like to work on improving Emacs, please contact | |
60342
0f12295e50a4
(Contributing): Mention Savannah. Direct users to
Nick Roberts <nickrob@snap.net.nz>
parents:
60121
diff
changeset
|
1018 the maintainers at @email{emacs-devel@@gnu.org}. A pretester |
25829 | 1019 should be prepared to investigate bugs as well as report them. If you'd |
1020 like to work on improving Emacs, please ask for suggested projects or | |
1021 suggest your own ideas. | |
1022 | |
1023 If you have already written an improvement, please tell us about it. If | |
1024 you have not yet started work, it is useful to contact | |
60342
0f12295e50a4
(Contributing): Mention Savannah. Direct users to
Nick Roberts <nickrob@snap.net.nz>
parents:
60121
diff
changeset
|
1025 @email{emacs-devel@@gnu.org} before you start; it might be |
25829 | 1026 possible to suggest ways to make your extension fit in better with the |
1027 rest of Emacs. | |
1028 | |
60342
0f12295e50a4
(Contributing): Mention Savannah. Direct users to
Nick Roberts <nickrob@snap.net.nz>
parents:
60121
diff
changeset
|
1029 The development version of Emacs can be downloaded from the CVS |
0f12295e50a4
(Contributing): Mention Savannah. Direct users to
Nick Roberts <nickrob@snap.net.nz>
parents:
60121
diff
changeset
|
1030 repository where it is actively maintained by a group of developers. |
69800 | 1031 See the Emacs project page |
1032 @url{http://savannah.gnu.org/projects/emacs/} for details. | |
60342
0f12295e50a4
(Contributing): Mention Savannah. Direct users to
Nick Roberts <nickrob@snap.net.nz>
parents:
60121
diff
changeset
|
1033 |
56812
16152de85a64
Adapt sectioning in Info to the node structure.
Luc Teirlinck <teirllm@auburn.edu>
parents:
54478
diff
changeset
|
1034 @node Service, Copying, Contributing, Top |
25829 | 1035 @section How To Get Help with GNU Emacs |
1036 | |
1037 If you need help installing, using or changing GNU Emacs, there are two | |
1038 ways to find it: | |
1039 | |
1040 @itemize @bullet | |
1041 @item | |
1042 Send a message to the mailing list | |
29107 | 1043 @email{help-gnu-emacs@@gnu.org}, or post your request on |
25829 | 1044 newsgroup @code{gnu.emacs.help}. (This mailing list and newsgroup |
1045 interconnect, so it does not matter which one you use.) | |
1046 | |
1047 @item | |
1048 Look in the service directory for someone who might help you for a fee. | |
1049 The service directory is found in the file named @file{etc/SERVICE} in the | |
1050 Emacs distribution. | |
1051 @end itemize | |
52401 | 1052 |
56812
16152de85a64
Adapt sectioning in Info to the node structure.
Luc Teirlinck <teirllm@auburn.edu>
parents:
54478
diff
changeset
|
1053 @ifnottex |
16152de85a64
Adapt sectioning in Info to the node structure.
Luc Teirlinck <teirllm@auburn.edu>
parents:
54478
diff
changeset
|
1054 @lowersections |
16152de85a64
Adapt sectioning in Info to the node structure.
Luc Teirlinck <teirllm@auburn.edu>
parents:
54478
diff
changeset
|
1055 @end ifnottex |
16152de85a64
Adapt sectioning in Info to the node structure.
Luc Teirlinck <teirllm@auburn.edu>
parents:
54478
diff
changeset
|
1056 |
52401 | 1057 @ignore |
1058 arch-tag: c9cba76d-b2cb-4e0c-ae3f-19d5ef35817c | |
1059 @end ignore |