annotate etc/TUTORIAL @ 159:3bb7ccffb0c0 r20-3b6

Import from CVS: tag r20-3b6
author cvs
date Mon, 13 Aug 2007 09:41:43 +0200
parents 131b0175ea99
children 28f395d8dc7a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
1 Copyright (c) 1985 Free Software Foundation, Inc; See end for conditions.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2 You are looking at the Emacs tutorial.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
4 Emacs commands generally involve the CONTROL key (sometimes labeled
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
5 CTRL or CTL) or the META key (sometimes labeled EDIT or ALT). Rather than
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
6 write that in full each time, we'll use the following abbreviations:
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
7
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
8 C-<chr> means hold the CONTROL key while typing the character <chr>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
9 Thus, C-f would be: hold the CONTROL key and type f.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
10 M-<chr> means hold the META or EDIT or ALT key down while typing <chr>.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
11 If there is no META, EDIT or ALT key, instead press and release the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
12 ESC key and then type <chr>. We write <ESC> for the ESC key.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
13
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
14 Important note: to end the Emacs session, type C-x C-c. (Two characters.)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
15 The characters ">>" at the left margin indicate directions for you to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
16 try using a command. For instance:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
17 <<Blank lines inserted here by startup of help-with-tutorial>>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
18 >> Now type C-v (View next screen) to move to the next screen.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
19 (go ahead, do it by holding down the control key while typing v).
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
20 From now on, you should do this again whenever you finish
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
21 reading the screen.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
22
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
23 Note that there is an overlap of two lines when you move from screen
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
24 to screen; this provides some continuity so you can continue reading
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
25 the text.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
26
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
27 The first thing that you need to know is how to move around from place
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
28 to place in the text. You already know how to move forward one screen,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
29 with C-v. To move backwards one screen, type M-v (hold down the META key
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
30 and type v, or type <ESC>v if you do not have a META, EDIT, or ALT key).
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
31
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
32 >> Try typing M-v and then C-v, a few times.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
33
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
34
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
35 * SUMMARY
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
36 ---------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
37
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
38 The following commands are useful for viewing screenfuls:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
39
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
40 C-v Move forward one screenful
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
41 M-v Move backward one screenful
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
42 C-l Clear screen and redisplay all the text,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
43 moving the text around the cursor
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
44 to the center of the screen.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
45 (That's control-L, not control-1.)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
46
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
47 >> Find the cursor, and note what text is near it.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
48 Then type C-l.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
49 Find the cursor again and notice that the same text
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
50 is near the cursor now.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
51
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
52
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
53 * BASIC CURSOR CONTROL
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
54 ----------------------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
55
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
56 Moving from screenful to screenful is useful, but how do you
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
57 move to a specific place within the text on the screen?
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
58
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
59 There are several ways you can do this. The most basic way is to use
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
60 the commands C-p, C-b, C-f, and C-n. Each of these commands moves the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
61 cursor one row or column in a particular direction on the screen.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
62 Here is a table showing these four commands and shows the directions
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
63 they move:
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
64
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
65 Previous line, C-p
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
66 :
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
67 :
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
68 Backward, C-b .... Current cursor position .... Forward, C-f
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
69 :
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
70 :
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
71 Next line, C-n
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
72
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
73 >> Move the cursor to the line in the middle of that diagram
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
74 using C-n or C-p. Then type C-l to see the whole diagram
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
75 centered in the screen.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
76
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
77 You'll probably find it easy to think of these by letter: P for
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
78 previous, N for next, B for backward and F for forward. These are the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
79 basic cursor positioning commands, and you'll be using them ALL the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
80 time, so it would be of great benefit if you learn them now.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
81
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
82 >> Do a few C-n's to bring the cursor down to this line.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
83
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
84 >> Move into the line with C-f's and then up with C-p's.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
85 See what C-p does when the cursor is in the middle of the line.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
86
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
87 Each of text line ends with a Newline character, which serves to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
88 separate it from the following line. The last line in your file ought
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
89 to have a Newline at the end (but Emacs does not require it to have
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
90 one).
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
91
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
92 >> Try to C-b at the beginning of a line. It should move to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
93 the end of the previous line. This is because it moves back
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
94 across the Newline character.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
95
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
96 C-f can move across a Newline just like C-b.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
97
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
98 >> Do a few more C-b's, so you get a feel for where the cursor is.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
99 Then do C-f's to return to the end of the line.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
100 Then do one more C-f to move to the following line.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
101
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
102 When you move past the top or bottom of the screen, the text beyond
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
103 the edge shifts onto the screen. This is called "scrolling". It
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
104 enables Emacs to move the cursor to the specified place in the text
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
105 without moving it off the screen.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
106
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
107 >> Try to move the cursor off the bottom of the screen with C-n, and
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
108 see what happens.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
109
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
110 If moving by characters is too slow, you can move by words. M-f
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
111 (Meta-f) moves forward a word and M-b moves back a word.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
112
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
113 >> Type a few M-f's and M-b's.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
114
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
115 When you are in the middle of a word, M-f moves to the end of the word.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
116 When you are in whitespace between words, M-f moves to the end of the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
117 following word. M-b works likewise in the opposite direction.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
118
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
119 >> Type M-f and M-b a few times, interspersed with C-f's and C-b's
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
120 so that you can observe the action of M-f and M-b from various
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
121 places inside and between words.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
122
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
123 Notice the parallel between C-f and C-b on the one hand, and M-f and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
124 M-b on the other hand. Very often Meta characters are used for
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
125 operations related to the units defined by language (words, sentences,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
126 paragraphs), while Control characters operate on basic units that are
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
127 independent of what you are editing (characters, lines, etc).
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
128
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
129 This parallel applies between lines and sentences: C-a and C-e move to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
130 the beginning or end of a line, and M-a and M-e move to the beginning
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
131 or end of a sentence.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
132
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
133 >> Try a couple of C-a's, and then a couple of C-e's.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
134 Try a couple of M-a's, and then a couple of M-e's.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
135
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
136 See how repeated C-a's do nothing, but repeated M-a's keep moving one
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
137 more sentence. Although these are not quite analogous, each one seems
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
138 natural.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
139
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
140 The location of the cursor in the text is also called "point". To
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
141 paraphrase, the cursor shows on the screen where point is located in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
142 the text.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
143
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
144 Here is a summary of simple cursor-moving operations, including the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
145 word and sentence moving commands:
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
146
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
147 C-f Move forward a character
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
148 C-b Move backward a character
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
149
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
150 M-f Move forward a word
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
151 M-b Move backward a word
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
152
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
153 C-n Move to next line
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
154 C-p Move to previous line
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
155
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
156 C-a Move to beginning of line
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
157 C-e Move to end of line
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
158
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
159 M-a Move back to beginning of sentence
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
160 M-e Move forward to end of sentence
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
161
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
162 >> Try all of these commands now a few times for practice.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
163 These are the most often used commands.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
164
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
165 Two other important cursor motion commands are M-< (Meta Less-than),
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
166 which moves to the beginning of the whole text, and M-> (Meta
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
167 Greater-than), which moves to the end of the whole text.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
168
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
169 On most terminals, the "<" is above the comma, so you must use the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
170 shift key to type it. On these terminals you must use the shift key
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
171 to type M-< also; without the shift key, you would be typing M-comma.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
172
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
173 >> Try M-< now, to move to the beginning of the tutorial.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
174 Then use C-v repeatedly to move back here.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
175
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
176 >> Try M-> now, to move to the end of the tutorial.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
177 Then use M-v repeatedly to move back here.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
178
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
179 You can also move the cursor with the arrow keys, if your terminal has
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
180 arrow keys. We recommend learning C-b, C-f, C-n and C-p for three
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
181 reasons. First, they work on all kinds of terminals. Second, once
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
182 you gain practice at using Emacs, you will find that typing these CTRL
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
183 characters is faster than typing the arrow keys (because you do not
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
184 have to move your hands away from touch-typing position). Third, once
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
185 you form the habit of using these CTRL character commands, you can
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
186 easily learn to use other advanced cursor motion commands as well.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
187
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
188 Most Emacs commands accept a numeric argument; for most commands, this
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
189 serves as a repeat-count. The way you give a command a repeat count
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
190 is by typing C-u and then the digits before you type the command. If
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
191 you have a META (or EDIT or ALT) key, there is another alternative way
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
192 to enter a numeric argument: type the digits while holding down the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
193 META key. We recommend learning the C-u method because it works on
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
194 any terminal.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
195
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
196 For instance, C-u 8 C-f moves forward eight characters.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
197
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
198 >> Try using C-n or C-p with a numeric argument, to move the cursor
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
199 to a line near this one with just one command.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
200
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
201 Most commands use the numeric argument as a repeat count. Certain
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
202 exceptional commands use it differently. C-v and M-v are among the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
203 exceptions. When given an argument, they scroll the screen up or down
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
204 by that many lines, rather than by a screenfuls. For example, C-u 4
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
205 C-v scrolls the screen by 4 lines.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
206
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
207 >> Try typing C-u 8 C-v now.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
208
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
209 This should have scrolled the screen up by 8 lines. If you would like
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
210 to scroll it down again, you can give an argument to M-v.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
211
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
212 If you are using X Windows, there should be a tall rectangular area
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
213 called a scroll bar at the left hand side of the Emacs window. You
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
214 can scroll the text by clicking the mouse in the scroll bar.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
215
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
216 >> Try pressing the middle button at the top of the highlighted area
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
217 within the scroll bar. This should scroll the text to a position
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
218 determined by how high or low you click.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
219
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
220 >> Try moving the mouse up and down, while holding the middle button
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
221 pressed down. You'll see that the text scrolls up and down as
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
222 you move the mouse.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
223
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
224
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
225 * WHEN EMACS IS HUNG
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
226 --------------------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
227
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
228 If Emacs stops responding to your commands, you can stop it safely by
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
229 typing C-g. You can use C-g to stop a command which is taking too
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
230 long to execute.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
231
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
232 You can also use C-g to discard a numeric argument or the beginning of
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
233 a command that you do not want to finish.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
234
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
235 >> Type C-u 100 to make a numeric arg of 100, then type C-g.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
236 Now type C-f. It should move just one character,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
237 because you canceled the argument with C-g.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
238
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
239 If you have typed an <ESC> by mistake, you can get rid of it
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
240 with a C-g.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
241
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
242
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
243 * DISABLED COMMANDS
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
244 -------------------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
245
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
246 Some Emacs commands are "disabled" so that beginning users cannot use
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
247 them by accident.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
248
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
249 If you type one of the disabled commands, Emacs displays a message
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
250 saying what the command was, and asking you whether you want to go
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
251 ahead and execute the command.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
252
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
253 If you really want to try the command, type Space in answer to the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
254 question. Normally, if you do not want to execute the disabled
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
255 command, answer the question with "n".
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
256
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
257 >> Type <ESC> : (which is a disabled command),
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
258 then type n to answer the question.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
259
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
260
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
261 * WINDOWS
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
262 ---------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
263
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
264 Emacs can have several windows, each displaying its own text. We will
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
265 explain later on how to use multiple windows. Right now we want to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
266 explain how to get rid of extra windows and go back to basic
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
267 one-window editing. It is simple:
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
268
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
269 C-x 1 One window (i.e., kill all other windows).
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
270
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
271 That is Control-x followed by the digit 1. C-x 1 expands the window
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
272 which contains the cursor, to occupy the full screen. It deletes all
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
273 other windows.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
274
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
275 >> Move the cursor to this line and type C-u 0 C-l.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
276 >> Type Control-h k Control-f.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
277 See how this window shrinks, while a new one appears
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
278 to display documentation on the Control-f command.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
279
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
280 >> Type C-x 1 and see the documentation listing window disappear.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
281
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
282
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
283 * INSERTING AND DELETING
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
284 ------------------------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
285
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
286 If you want to insert text, just type the text. Characters which you
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
287 can see, such as A, 7, *, etc. are taken by Emacs as text and inserted
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
288 immediately. Type <Return> (the carriage-return key) to insert a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
289 Newline character.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
290
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
291 You can delete the last character you typed by typing <Delete>.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
292 <Delete> is a key on the keyboard, which may be labeled "Del". In
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
293 some cases, the "Backspace" key serves as <Delete>, but not always!
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
294
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
295 More generally, <Delete> deletes the character immediately before the
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
296 current cursor position.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
297
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
298 >> Do this now--type a few characters, then delete them
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
299 by typing <Delete> a few times. Don't worry about this file
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
300 being changed; you will not alter the master tutorial. This is
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
301 your personal copy of it.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
302
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
303 When a line of text gets too big for one line on the screen, the line
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
304 of text is "continued" onto a second screen line. A backslash ("\")
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
305 at the right margin indicates a line which has been continued.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
306
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
307 >> Insert text until you reach the right margin, and keep on inserting.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
308 You'll see a continuation line appear.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
309
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
310 >> Use <Delete>s to delete the text until the line fits on one screen
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
311 line again. The continuation line goes away.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
312
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
313 You can delete a Newline character just like any other character.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
314 Deleting the Newline character between two lines merges them into
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
315 one line. If the resulting combined line is too long to fit in the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
316 screen width, it will be displayed with a continuation line.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
317
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
318 >> Move the cursor to the beginning of a line and type <Delete>. This
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
319 merges that line with the previous line.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
320
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
321 >> Type <Return> to reinsert the Newline you deleted.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
322
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
323 Remember that most Emacs commands can be given a repeat count;
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
324 this includes text characters. Repeating a text character inserts
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
325 it several times.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
326
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
327 >> Try that now -- type C-u 8 * to insert ********.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
328
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
329 You've now learned the most basic way of typing something in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
330 Emacs and correcting errors. You can delete by words or lines
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
331 as well. Here is a summary of the delete operations:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
332
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
333 <Delete> delete the character just before the cursor
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
334 C-d delete the next character after the cursor
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
335
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
336 M-<Delete> kill the word immediately before the cursor
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
337 M-d kill the next word after the cursor
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
338
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
339 C-k kill from the cursor position to end of line
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
340 M-k kill to the end of the current sentence
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
341
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
342 Notice that <Delete> and C-d vs M-<Delete> and M-d extend the parallel
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
343 started by C-f and M-f (well, <Delete> is not really a control
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
344 character, but let's not worry about that). C-k and M-k are like C-e
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
345 and M-e, sort of, in that lines are opposite sentences.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
346
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
347 When you delete more than one character at a time, Emacs saves the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
348 deleted text so that you can bring it back. Bringing back killed text
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
349 is called "yanking". You can yank the killed text either at the same
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
350 place where it was killed, or at some other place in the text. You
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
351 can yank the text several times in order to make multiple copies of
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
352 it. The command to yank is C-y.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
353
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
354 Note that the difference between "Killing" and "Deleting" something is
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
355 that "Killed" things can be yanked back, and "Deleted" things cannot.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
356 Generally, the commands that can remove a lot of text save the text,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
357 while the commands that delete just one character, or just blank lines
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
358 and spaces, do not save the deleted text.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
359
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
360 >> Move the cursor to the beginning of a line which is not empty.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
361 Then type C-k to kill the text on that line.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
362 >> Type C-k a second time. You'll see that it kills the Newline
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
363 which follows that line.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
364
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
365 Note that a single C-k kills the contents of the line, and a second
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
366 C-k kills the line itself, and make all the other lines move up. C-k
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
367 treats a numeric argument specially: it kills that many lines AND
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
368 their contents. This is not mere repetition. C-u 2 C-k kills two
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
369 lines and their newlines; typing C-k twice would not do that.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
370
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
371 To retrieve the last killed text and put it where the cursor currently
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
372 is, type C-y.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
373
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
374 >> Try it; type C-y to yank the text back.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
375
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
376 Think of C-y as if you were yanking something back that someone took
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
377 away from you. Notice that if you do several C-k's in a row, all of
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
378 the killed text is saved together, so that one C-y will yank all of
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
379 the lines.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
380
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
381 >> Do this now, type C-k several times.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
382
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
383 Now to retrieve that killed text:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
384
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
385 >> Type C-y. Then move the cursor down a few lines and type C-y
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
386 again. You now see how to copy some text.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
387
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
388 What do you do if you have some text you want to yank back, and then
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
389 you kill something else? C-y would yank the more recent kill. But
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
390 the previous text is not lost. You can get back to it using the M-y
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
391 command. After you have done C-y to get the most recent kill, typing
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
392 M-y replaces that yanked text with the previous kill. Typing M-y
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
393 again and again brings in earlier and earlier kills. When you have
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
394 reached the text you are looking for, you do not have to do anything to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
395 keep it. Just go on with your editing, leaving the yanked text where
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
396 it is.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
397
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
398 If you M-y enough times, you come back to the starting point (the most
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
399 recent kill).
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
400
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
401 >> Kill a line, move around, kill another line.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
402 Then do C-y to get back the second killed line.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
403 Then do M-y and it will be replaced by the first killed line.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
404 Do more M-y's and see what you get. Keep doing them until
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
405 the second kill line comes back, and then a few more.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
406 If you like, you can try giving M-y positive and negative
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
407 arguments.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
408
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
409
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
410 * UNDO
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
411 ------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
412
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
413 If you make a change to the text, and then decide that it was a
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
414 mistake, you can undo the change with the undo command, C-x u.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
415
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
416 Normally, C-x u undoes the changes made by one command; if you repeat
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
417 the C-x u several times in a row, each repetition undoes one
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
418 additional command.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
419
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
420 But there are two exceptions: commands that do not change the text do
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
421 not count (this includes cursor motion commands and scrolling
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
422 command), and self-inserting characters are usually handled in groups
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
423 of up to 20. (This is to reduce the number of C-x u's you have to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
424 type to undo insertion of text.)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
425
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
426 >> Kill this line with C-k, then type C-x u and it should reappear.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
427
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
428 C-_ is an alternative undo command; it works just the same as C-x u,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
429 but it is easier to type several times in a row. The disadvantage of
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
430 C-_ is that on some keyboards it is not obvious how to type it. That
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
431 is why we provide C-x u as well. On some terminals, you can type C-_
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
432 by typing / while holding down CTRL.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
433
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
434 A numeric argument to C-_ or C-x u acts as a repeat count.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
435
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
436
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
437 * FILES
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
438 -------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
439
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
440 In order to make the text you edit permanent, you must put it in a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
441 file. Otherwise, it will go away when your invocation of Emacs goes
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
442 away. You put your editing in a file by "finding" the file. (This is
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
443 also called "visiting" the file.)
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
444
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
445 Finding a file means that you see the contents of the file within
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
446 Emacs. In many ways, it is as if you were editing the file itself.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
447 However, the changes you make using Emacs do not become permanent
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
448 until you "save" the file. This is so you can avoid leaving a
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
449 half-changed file on the system when you do not want to. Even when
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
450 you save, Emacs leaves the original file under a changed name in case
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
451 you later decide that your changes were a mistake.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
452
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
453 If you look near the bottom of the screen you will see a line that
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
454 begins and ends with dashes, and contains the string "Emacs:
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
455 TUTORIAL". This part of the screen always shows the name of the file
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
456 that you are visiting. Right now, you are visiting a file called
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
457 "TUTORIAL" which is your personal scratch copy of the Emacs tutorial.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
458 Whatever file you find, that file's name will appear in that precise
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
459 spot.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
460
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
461 The commands for finding and saving files are unlike the other
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
462 commands you have learned in that they consist of two characters.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
463 They both start with the character Control-x. There is a whole series
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
464 of commands that start with Control-x; many of them have to do with
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
465 files, buffers, and related things. These commands are two, three or
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
466 four characters long.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
467
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
468 Another thing about the command for finding a file is that you have
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
469 to say what file name you want. We say the command "reads an argument
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
470 from the terminal" (in this case, the argument is the name of the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
471 file). After you type the command
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
472
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
473 C-x C-f Find a file
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
474
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
475 Emacs asks you to type the file name. The file name you type appears
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
476 on the bottom line of the screen. The bottom line is called the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
477 minibuffer when it is used for this sort of input. You can use
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
478 ordinary Emacs editing commands to edit the file name.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
479
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
480 While you are entering the file name (or any minibuffer input),
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
481 you can cancel the command with C-g.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
482
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
483 >> Type C-x C-f, then type C-g. This cancels the minibuffer,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
484 and also cancels the C-x C-f command that was using the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
485 minibuffer. So you do not find any file.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
486
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
487 When you have finished entering the file name, type <Return> to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
488 terminate it. Then C-x C-f command goes to work, and finds the file
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
489 you chose. The minibuffer disappears when the C-x C-f command is
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
490 finished.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
491
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
492 In a little while the file contents appear on the screen, and you can
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
493 edit the contents. When you wish to make your changes permanent,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
494 type the command
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
495
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
496 C-x C-s Save the file
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
497
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
498 This copies the text within Emacs into the file. The first time you
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
499 do this, Emacs renames the original file to a new name so that it is
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
500 not lost. The new name is made by adding "~" to the end of the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
501 original file's name.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
502
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
503 When saving is finished, Emacs prints the name of the file written.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
504 You should save fairly often, so that you will not lose very much
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
505 work if the system should crash.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
506
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
507 >> Type C-x C-s, saving your copy of the tutorial.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
508 This should print "Wrote ...TUTORIAL" at the bottom of the screen.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
509
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
510 NOTE: On some systems, typing C-x C-s will freeze the screen and you
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
511 will see no further output from Emacs. This indicates that an
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
512 operating system "feature" called "flow control" is intercepting the
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
513 C-s and not letting it get through to Emacs. To unfreeze the screen,
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
514 type C-q. Then see the section "Spontaneous Entry to Incremental
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
515 Search" in the Emacs manual for advice on dealing with this "feature".
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
516
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
517 You can find an existing file, to view it or edit it. You can also
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
518 find a file which does not already exist. This is the way to create a
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
519 file with Emacs: find the file, which will start out empty, and then
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
520 begin inserting the text for the file. When you ask to "save" the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
521 file, Emacs will really create the file with the text that you have
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
522 inserted. From then on, you can consider yourself to be editing an
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
523 already existing file.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
524
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
525
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
526 * BUFFERS
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
527 ---------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
528
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
529 If you find a second file with C-x C-f, the first file remains
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
530 inside Emacs. You can switch back to it by finding it again with
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
531 C-x C-f. This way you can get quite a number of files inside Emacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
532
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
533 >> Create a file named "foo" by typing C-x C-f foo <Return>.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
534 Then insert some text, edit it, and save "foo" by typing C-x C-s.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
535 Finally, type C-x C-f TUTORIAL <Return>
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
536 to come back to the tutorial.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
537
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
538 Emacs stores each file's text inside an object called a "buffer."
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
539 Finding a file makes a new buffer inside Emacs. To see a list of the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
540 buffers that current exist in your Emacs job, type
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
541
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
542 C-x C-b List buffers
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
543
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
544 >> Try C-x C-b now.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
545
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
546 See how each buffer has a name, and it may also have a file name
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
547 for the file whose contents it holds. Some buffers do not correspond
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
548 to files. For example, the buffer named "*Buffer List*" does
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
549 not have any file. It is the buffer which contains the buffer
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
550 list that was made by C-x C-b. ANY text you see in an Emacs window
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
551 is always part of some buffer.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
552
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
553 >> Type C-x 1 to get rid of the buffer list.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
554
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
555 If you make changes to the text of one file, then find another file,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
556 this does not save the first file. Its changes remain inside Emacs,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
557 in that file's buffer. The creation or editing of the second file's
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
558 buffer has no effect on the first file's buffer. This is very useful,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
559 but it also means that you need a convenient way to save the first
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
560 file's buffer. It would be a nuisance to have to switch back to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
561 it with C-x C-f in order to save it with C-x C-s. So we have
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
562
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
563 C-x s Save some buffers
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
564
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
565 C-x s asks you about each buffer which contains changes that you have
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
566 not saved. It asks you, for each such buffer, whether to save the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
567 buffer.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
568
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
569 >> Insert a line of text, then type C-x s.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
570 It should ask you whether to save the buffer named TUTORIAL.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
571 Answer yes to the question by typing "y".
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
572
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
573 * EXTENDING THE COMMAND SET
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
574 ---------------------------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
575
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
576 There are many, many more Emacs commands than could possibly be put
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
577 on all the control and meta characters. Emacs gets around this with
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
578 the X (eXtend) command. This comes in two flavors:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
579
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
580 C-x Character eXtend. Followed by one character.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
581 M-x Named command eXtend. Followed by a long name.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
582
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
583 These are commands that are generally useful but used less than the
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
584 commands you have already learned about. You have already seen two of
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
585 them: the file commands C-x C-f to Find and C-x C-s to Save. Another
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
586 example is the command to end the Emacs session--this is the command
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
587 C-x C-c. (Do not worry about losing changes you have made; C-x C-c
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
588 offers to save each changed file before it kills the Emacs.)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
589
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
590 C-z is the command to exit Emacs *temporarily*--so that you can go
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
591 back to the same Emacs session afterward.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
592
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
593 On systems which allow it, C-z "suspends" Emacs; that is, it returns
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
594 to the shell but does not destroy the Emacs. In the most common
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
595 shells, you can resume Emacs with the `fg' command or with `%emacs'.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
596
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
597 On systems which do not implement suspending, C-z creates a subshell
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
598 running under Emacs to give you the chance to run other programs and
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
599 return to Emacs afterward; it does not truly "exit" from Emacs. In
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
600 this case, the shell command `exit' is the usual way to get back to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
601 Emacs from the subshell.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
602
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
603 The time to use C-x C-c is when you are about to log out. It's also
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
604 the right thing to use to exit an Emacs invoked under mail handling
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
605 programs and other miscellaneous utilities, since they may not know
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
606 how to cope with suspension of Emacs. In ordinary circumstances,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
607 though, if you are not about to log out, it is better to suspend Emacs
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
608 with C-z instead of exiting Emacs.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
609
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
610 There are many C-x commands. Here is a list of the ones you have learned:
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
611
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
612 C-x C-f Find file.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
613 C-x C-s Save file.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
614 C-x C-b List buffers.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
615 C-x C-c Quit Emacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
616 C-x u Undo.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
617
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
618 Named eXtended commands are commands which are used even less
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
619 frequently, or commands which are used only in certain modes. An
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
620 example is the command replace-string, which globally replaces one
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
621 string with another. When you type M-x, Emacs prompts you at the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
622 bottom of the screen with M-x and you should type the name of the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
623 command; in this case, "replace-string". Just type "repl s<TAB>" and
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
624 Emacs will complete the name. End the command name with <Return>.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
625
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
626 The replace-string command requires two arguments--the string to be
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
627 replaced, and the string to replace it with. You must end each
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
628 argument with <Return>.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
629
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
630 >> Move the cursor to the blank line two lines below this one.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
631 Then type M-x repl s<Return>changed<Return>altered<Return>.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
632
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
633 Notice how this line has changed: you've replaced
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
634 the word c-h-a-n-g-e-d with "altered" wherever it occurred,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
635 after the initial position of the cursor.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
636
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
637
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
638 * AUTO SAVE
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
639 -----------
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
640
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
641 When you have made changes in a file, but you have not saved them yet,
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
642 they could be lost if your computer crashes. To protect you from
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
643 this, Emacs periodically writes an "auto save" file for each file that
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
644 you are editing. The auto save file name has a # at the beginning and
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
645 the end; for example, if your file is named "hello.c", its auto save
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
646 file's name is "#hello.c#". When you save the file in the normal way,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
647 Emacs deletes its auto save file.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
648
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
649 If the computer crashes, you can recover your auto-saved editing by
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
650 finding the file normally (the file you were editing, not the auto
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
651 save file) and then typing M-x recover file<return>. When it asks for
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
652 confirmation, type yes<return> to go ahead and recover the auto-save
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
653 data.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
654
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
655
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
656 * ECHO AREA
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
657 -----------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
658
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
659 If Emacs sees that you are typing commands slowly it shows them to you
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
660 at the bottom of the screen in an area called the "echo area." The echo
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
661 area contains the bottom line of the screen.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
662
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
663
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
664 * MODE LINE
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
665 -----------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
666
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
667 The line immediately above the echo area it is called the "mode line".
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
668 The mode line says something like this:
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
669
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
670 --**-Emacs: TUTORIAL (Fundamental)--L670--58%----------------
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
671
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
672 This line gives useful information about the status of Emacs and
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
673 the text you are editing.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
674
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
675 You already know what the filename means--it is the file you have
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
676 found. -NN%-- indicates your current position in the text; it means
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
677 that NN percent of the text is above the top of the screen. If the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
678 top of the file is on the screen, it will say --Top-- instead of
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
679 --00%--. If the bottom of the text is on the screen, it will say
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
680 --Bot--. If you are looking at text so small that all of it fits on
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
681 the screen, the mode line says --All--.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
682
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
683 The stars near the front mean that you have made changes to the text.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
684 Right after you visit or save a file, that part of the mode line shows
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
685 no stars, just dashes.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
686
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
687 The part of the mode line inside the parentheses is to tell you what
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
688 editing modes you are in. The default mode is Fundamental which is
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
689 what you are using now. It is an example of a "major mode".
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
690
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
691 Emacs has many different major modes. Some of them are meant for
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
692 editing different languages and/or kinds of text, such as Lisp mode,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
693 Text mode, etc. At any time one and only one major mode is active,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
694 and its name can always be found in the mode line just where
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
695 "Fundamental" is now.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
696
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
697 Each major mode makes a few commands behave differently. For example,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
698 there are commands for creating comments in a program, and since each
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
699 programming language has a different idea of what a comment should
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
700 look like, each major mode has to insert comments differently. Each
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
701 major mode is the name of an extended command, which is how you can
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
702 switch to that mode. For example, M-x fundamental-mode is a command to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
703 switch to Fundamental mode.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
704
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
705 If you are going to be editing English text, such as this file, you
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
706 should probably use Text Mode.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
707 >> Type M-x text-mode<Return>.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
708
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
709 Don't worry, none of the commands you have learned changes Emacs in
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
710 any great way. But you can observe that M-f and M-b now treat
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
711 apostrophes as part of words. Previously, in Fundamental mode,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
712 M-f and M-b treated apostrophes as word-separators.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
713
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
714 Major modes usually make subtle changes like that one: most commands
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
715 do "the same job" in each major mode, but they work a little bit
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
716 differently.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
717
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
718 To view documentation on your current major mode, type C-h m.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
719
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
720 >> Use C-u C-v once or more to bring this line near the top of screen.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
721 >> Type C-h m, to see how Text mode differs from Fundamental mode.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
722 >> Type C-x 1 to remove the documentation from the screen.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
723
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
724 Major modes are called major because there are also minor modes.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
725 Minor modes are alternatives not to the major modes, just minor
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
726 modifications of them. Each minor mode can be turned on or off by
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
727 itself, independent of all other minor modes, and independent of your
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
728 major mode. So you can use no minor modes, or one minor mode, or any
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
729 combination of several minor modes.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
730
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
731 One minor mode which is very useful, especially for editing English
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
732 text, is Auto Fill mode. When this mode is on, Emacs breaks the line
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
733 in between words automatically whenever you insert text and make a
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
734 line that is too wide.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
735
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
736 You can turn Auto Fill mode on by doing M-x auto-fill-mode<Return>.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
737 When the mode is on, you can turn it off by doing M-x
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
738 auto-fill-mode<Return>. If the mode is off, this command turns it on,
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
739 and if the mode is on, this command turns it off. We say that the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
740 command "toggles the mode".
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
741
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
742 >> Type M-x auto-fill-mode<Return> now. Then insert a line of "asdf "
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
743 over again until you see it divide into two lines. You must put in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
744 spaces between them because Auto Fill breaks lines only at spaces.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
745
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
746 The margin is usually set at 70 characters, but you can change it
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
747 with the C-x f command. You should give the margin setting you want
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
748 as a numeric argument.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
749
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
750 >> Type C-x f with an argument of 20. (C-u 2 0 C-x f).
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
751 Then type in some text and see Emacs fill lines of 20
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
752 characters with it. Then set the margin back to 70 using
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
753 C-x f again.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
754
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
755 If you makes changes in the middle of a paragraph, Auto Fill mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
756 does not re-fill it for you.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
757 To re-fill the paragraph, type M-q (Meta-q) with the cursor inside
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
758 that paragraph.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
759
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
760 >> Move the cursor into the previous paragraph and type M-q.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
761
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
762 * SEARCHING
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
763 -----------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
764
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
765 Emacs can do searches for strings (these are groups of contiguous
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
766 characters or words) either forward through the text or backward
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
767 through it. Searching for a string is a cursor motion command;
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
768 it moves the cursor to the next place where that string appears.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
769
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
770 The Emacs search command is different from the search commands
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
771 of most editors, in that it is "incremental". This means that the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
772 search happens while you type in the string to search for.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
773
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
774 The command to initiate a search is C-s for forward search, and C-r
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
775 for reverse search. BUT WAIT! Don't try them now.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
776
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
777 When you type C-s you'll notice that the string "I-search" appears as
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
778 a prompt in the echo area. This tells you that Emacs is in what is
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
779 called an incremental search waiting for you to type the thing that
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
780 you want to search for. <RET> terminates a search.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
781
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
782 >> Now type C-s to start a search. SLOWLY, one letter at a time,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
783 type the word 'cursor', pausing after you type each
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
784 character to notice what happens to the cursor.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
785 Now you have searched for "cursor", once.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
786 >> Type C-s again, to search for the next occurrence of "cursor".
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
787 >> Now type <Delete> four times and see how the cursor moves.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
788 >> Type <RET> to terminate the search.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
789
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
790 Did you see what happened? Emacs, in an incremental search, tries to
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
791 go to the occurrence of the string that you've typed out so far. To
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
792 go to the next occurrence of 'cursor' just type C-s again. If no such
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
793 occurrence exists Emacs beeps and tells you the search is currently
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
794 "failing", C-g would also terminate the search.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
795
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
796 NOTE: On some systems, typing C-s will freeze the screen and you will
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
797 see no further output from Emacs. This indicates that an operating
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
798 system "feature" called "flow control" is intercepting the C-s and not
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
799 letting it get through to Emacs. To unfreeze the screen, type C-q.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
800 Then see the section "Spontaneous Entry to Incremental Search" in the
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
801 Emacs manual for advice on dealing with this "feature".
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
802
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
803 If you are in the middle of an incremental search and type <Delete>,
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
804 you'll notice that the last character in the search string is erased
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
805 and the search backs up to the last place of the search. For
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
806 instance, suppose you have typed "c", to search for the first
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
807 occurrence of "c". Now if you type "u", the cursor will move
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
808 to the first occurrence of "cu". Now type <Delete>. This erases
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
809 the "u" from the search string, and the cursor moves back to
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
810 the first occurrence of "c".
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
811
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
812 If you are in the middle of a search and type a control or meta
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
813 character (with a few exceptions--characters that are special in
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
814 a search, such as C-s and C-r), the search is terminated.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
815
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
816 The C-s starts a search that looks for any occurrence of the search
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
817 string AFTER the current cursor position. If you want to search for
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
818 something earlier in the text, type C-r instead. Everything that we
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
819 have said about C-s also applies to C-r, except that the direction of
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
820 the search is reversed.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
821
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
822
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
823 * MULTIPLE WINDOWS
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
824 ------------------
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
825
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
826 One of the nice features of Emacs is that you can display more than one
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
827 window on the screen at the same time.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
828
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
829 >> Move the cursor to this line and type C-u 0 C-l.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
830
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
831 >> Now type C-x 2 which splits the screen into two windows.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
832 Both windows display this tutorial. The cursor stays in the top window.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
833
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
834 >> Type C-M-v to scroll the bottom window.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
835 (If you do not have a real Meta key, type ESC C-v.)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
836
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
837 >> Type C-x o ("o" for "other") to move the cursor to the bottom window.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
838 >> Use C-v and M-v in the bottom window to scroll it.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
839 Keep reading these directions in the top window.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
840
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
841 >> Type C-x o again to move the cursor back to the top window.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
842 The cursor in the top window is just where it was before.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
843
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
844 You can keep using C-x o to switch between the windows. Each
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
845 window has its own cursor position, but only one window actually
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
846 shows the cursor. All the ordinary editing commands apply to the
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
847 window that the cursor is in. We call this the "selected window".
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
848
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
849 The command C-M-v is very useful when you are editing text in one
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
850 window and using the other window just for reference. You can keep
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
851 the cursor always in the window where you are editing, and advance
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
852 through the other window sequentially with C-M-v.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
853
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
854 C-M-v is an example of a CONTROL-META character. If you have a real
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
855 META key, you can type C-M-v by holding down both CTRL and META while
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
856 typing v. It does not matter whether CTRL or META "comes first,"
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
857 because both of these keys act by modifying the characters you type.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
858
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
859 If you do not have a real META key, and you use ESC instead, the order
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
860 does matter: you must type ESC followed by CTRL-v; CTRL-ESC v will not
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
861 work. This is because ESC is a character in its own right, not a
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
862 modifier key.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
863
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
864 >> Type C-x 1 (in the top window) to get rid of the bottom window.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
865
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
866 (If you had typed C-x 1 in the bottom window, that would get rid
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
867 of the top one. Think of this command as "Keep just one
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
868 window--the window I am already in.")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
869
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
870 You do not have to display the same buffer in both windows. If you
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
871 use C-x C-f to find a file in one window, the other window does not
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
872 change. You can find a file in each window independently.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
873
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
874 Here is another way to use two windows to display two different
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
875 things:
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
876
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
877 >> Type C-x 4 C-f followed by the name of one of your files.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
878 End with <Return>. See the specified file appear in the bottom
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
879 window. The cursor goes there, too.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
880
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
881 >> Type C-x o to go back to the top window, and C-x 1 to delete
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
882 the bottom window.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
883
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
884
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
885 * RECURSIVE EDITING LEVELS
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
886 --------------------------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
887
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
888 Sometimes you will get into what is called a "recursive editing
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
889 level". This is indicated by square brackets in the mode line,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
890 surrounding the parentheses around the major mode name. For
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
891 example, you might see [(Fundamental)] instead of (Fundamental).
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
892
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
893 To get out of the recursive editing level, type ESC ESC ESC. That is
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
894 an all-purpose "get out" command. You can also use it for eliminating
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
895 extra windows, and getting out of the minibuffer.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
896
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
897 >> Type M-x to get into a minibuffer; then type ESC ESC ESC to get out.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
898
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
899 You cannot use C-g to get out of a recursive editing level. This is
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
900 because C-g is used for canceling commands and arguments WITHIN the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
901 recursive editing level.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
902
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
903
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
904 * GETTING MORE HELP
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
905 -------------------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
906
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
907 In this tutorial we have tried to supply just enough information to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
908 get you started using Emacs. There is so much available in Emacs that
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
909 it would be impossible to explain it all here. However, you may want
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
910 to learn more about Emacs since it has many other useful features.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
911 Emacs provides commands for reading documentation about Emacs
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
912 commands. These "help" commands all start with the character
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
913 Control-h, which is called "the Help character".
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
914
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
915 To use the Help features, type the C-h character, and then a
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
916 character saying what kind of help you want. If you are REALLY lost,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
917 type C-h ? and Emacs will tell you what kinds of help it can give.
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
918 If you have typed C-h and decide you do not want any help, just
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
919 type C-g to cancel it.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
920
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
921 (Some sites rebind the character C-h. They really should not do this
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
922 as a blanket measure, so complain to the system administrator.
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
923 Meanwhile, if C-h does not display a message about help at the bottom
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
924 of the screen, try typing M-x help RET instead.)
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
925
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
926 The most basic HELP feature is C-h c. Type C-h, a c, and a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
927 command character or sequence, and Emacs displays a very brief
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
928 description of the command.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
929
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
930 >> Type C-h c Control-p.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
931 The message should be something like
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
932
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
933 C-p runs the command previous-line
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
934
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
935 This tells you the "name of the function". Function names are used
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
936 mainly for customizing and extending Emacs. But since function names
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
937 are chosen to indicate what the command does, they can serve also as
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
938 very brief documentation--sufficient to remind you of commands you
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
939 have already learned.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
940
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
941 Multi-character commands such as C-x C-s and (if you have no META or
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
942 EDIT or ALT key) <ESC>v are also allowed after C-h c.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
943
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
944 To get more information about a command, use C-h k instead of C-h c.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
945
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
946 >> Type C-h k Control-p.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
947
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
948 This displays the documentation of the function, as well as its
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
949 name, in an Emacs window. When you are finished reading the
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
950 output, type C-x 1 to get rid of the help text. You do not have
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
951 to do this right away. You can do some editing while referring
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
952 to the help text, and then type C-x 1.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
953
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
954 Here are some other useful C-h options:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
955
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
956 C-h f Describe a function. You type in the name of the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
957 function.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
958
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
959 >> Try typing C-h f previous-line<Return>.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
960 This prints all the information Emacs has about the
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
961 function which implements the C-p command.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
962
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
963 C-h a Command Apropos. Type in a keyword and Emacs will list
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
964 all the commands whose names contain that keyword.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
965 These commands can all be invoked with Meta-x.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
966 For some commands, Command Apropos will also list a one
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
967 or two character sequence which runs the same command.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
968
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
969 >> Type C-h a file<Return>.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
970
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
971 This displays in another window a list of all M-x commands with "file"
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
972 in their names. You will see character-commands like C-x C-f listed
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
973 beside the corresponding command names such as find-file.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
974
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
975 >> Type C-M-v to scroll the help window. Do this a few times.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
976
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
977 >> Type C-x 1 to delete the help window.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
978
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
979
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
980 * CONCLUSION
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
981 ------------
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
982
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
983 Remember, to exit Emacs permanently use C-x C-c. To exit to a shell
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
984 temporarily, so that you can come back to Emacs afterward, use C-z.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
985
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
986 This tutorial is meant to be understandable to all new users, so if
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
987 you found something unclear, don't sit and blame yourself - complain!
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
988
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
989
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
990 COPYING
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
991 -------
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
992
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
993 This tutorial descends from a long line of Emacs tutorials
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
994 starting with the one written by Stuart Cracraft for the original Emacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
995
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
996 This version of the tutorial, like GNU Emacs, is copyrighted, and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
997 comes with permission to distribute copies on certain conditions:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
998
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 0
diff changeset
999 Copyright (c) 1985, 1996 Free Software Foundation
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1000
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1001 Permission is granted to anyone to make or distribute verbatim copies
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1002 of this document as received, in any medium, provided that the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1003 copyright notice and permission notice are preserved,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1004 and that the distributor grants the recipient permission
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1005 for further redistribution as permitted by this notice.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1006
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1007 Permission is granted to distribute modified versions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1008 of this document, or of portions of it,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1009 under the above conditions, provided also that they
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1010 carry prominent notices stating who last altered them.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1011
159
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
1012 The conditions for copying Emacs itself are more complex, but in the
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
1013 same spirit. Please read the file COPYING and then do give copies of
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
1014 GNU Emacs to your friends. Help stamp out software obstructionism
3bb7ccffb0c0 Import from CVS: tag r20-3b6
cvs
parents: 70
diff changeset
1015 ("ownership") by using, writing, and sharing free software!