]> code.delx.au - gnu-emacs/blob - doc/emacs/glossary.texi
* doc/emacs/glossary.texi (Glossary): Add some entries.
[gnu-emacs] / doc / emacs / glossary.texi
1 @c This is part of the Emacs manual.
2 @c Copyright (C) 1985-1987, 1993-1995, 1997, 2001-2013 Free Software
3 @c Foundation, Inc.
4 @c See file emacs.texi for copying conditions.
5 @node Glossary
6 @unnumbered Glossary
7 @cindex glossary
8
9 @table @asis
10 @anchor{Glossary---Abbrev}
11 @item Abbrev
12 An abbrev is a text string that expands into a different text string
13 when present in the buffer. For example, you might define a few letters
14 as an abbrev for a long phrase that you want to insert frequently.
15 @xref{Abbrevs}.
16
17 @item Aborting
18 Aborting means getting out of a recursive edit (q.v.). The
19 commands @kbd{C-]} and @kbd{M-x top-level} are used for this.
20 @xref{Quitting}.
21
22 @item Active Region
23 Setting the mark (q.v.) at a position in the text also activates it.
24 When the mark is active, we call the region an active region.
25 @xref{Mark}.
26
27 @item Alt
28 Alt is the name of a modifier bit that a keyboard input character may
29 have. To make a character Alt, type it while holding down the @key{ALT}
30 key. Such characters are given names that start with @kbd{Alt-}
31 (usually written @kbd{A-} for short). (Note that many terminals have a
32 key labeled @key{ALT} that is really a @key{META} key.) @xref{User
33 Input, Alt}.
34
35 @item Argument
36 @xref{Glossary---Numeric Argument}.
37
38 @item @acronym{ASCII} character
39 An @acronym{ASCII} character is either an @acronym{ASCII} control
40 character or an @acronym{ASCII} printing character. @xref{User Input}.
41
42 @item @acronym{ASCII} control character
43 An @acronym{ASCII} control character is the Control version of an upper-case
44 letter, or the Control version of one of the characters @samp{@@[\]^_?}.
45
46 @item @acronym{ASCII} printing character
47 @acronym{ASCII} letters, digits, space, and the following punctuation
48 characters: @samp{!@@#$%^&*()_-+=|\~`@{@}[]:;"'<>,.?/}.
49
50 @item Auto Fill Mode
51 Auto Fill mode is a minor mode (q.v.@:) in which text that you insert is
52 automatically broken into lines of a given maximum width.
53 @xref{Filling}.
54
55 @item Auto Saving
56 Auto saving is the practice of periodically saving the contents of an
57 Emacs buffer in a specially-named file, so that the information will
58 be preserved if the buffer is lost due to a system error or user error.
59 @xref{Auto Save}.
60
61 @item Autoloading
62 Emacs can automatically load Lisp libraries when a Lisp program requests a
63 function from those libraries. This is called `autoloading'.
64 @xref{Lisp Libraries}.
65
66 @item Backtrace
67 A backtrace is a trace of a series of function calls showing how a
68 program arrived at a certain point. It is used mainly for finding and
69 correcting bugs (q.v.). Emacs can display a backtrace when it signals
70 an error or when you type @kbd{C-g} (@pxref{Glossary---Quitting}).
71 @xref{Checklist}.
72
73 @item Backup File
74 A backup file records the contents that a file had before the current
75 editing session. Emacs makes backup files automatically to help you
76 track down or cancel changes you later regret making. @xref{Backup}.
77
78 @item Balancing Parentheses
79 Emacs can balance parentheses (or other matching delimiters) either
80 manually or automatically. You do manual balancing with the commands
81 to move over parenthetical groupings (@pxref{Moving by Parens}).
82 Automatic balancing works by blinking or highlighting the delimiter
83 that matches the one you just inserted, or inserting the matching
84 delimiter for you (@pxref{Matching,,Matching Parens}).
85
86 @anchor{Glossary---Balanced Expression}
87 @item Balanced Expressions
88 A balanced expression is a syntactically recognizable expression, such
89 as a symbol, number, string constant, block, or parenthesized expression
90 in C@. @xref{Expressions,Balanced Expressions}.
91
92 @item Balloon Help
93 @xref{Glossary---Tooltips}.
94
95 @item Base Buffer
96 A base buffer is a buffer whose text is shared by an indirect buffer
97 (q.v.).
98
99 @item Bidirectional Text
100 Some human languages, such as English, are written from left to right.
101 Others, such as Arabic, are written from right to left. Emacs
102 supports both of these forms, as well as any mixture of them---this
103 is `bidirectional text'. @xref{Bidirectional Editing}.
104
105 @item Bind
106 To bind a key sequence means to give it a binding (q.v.).
107 @xref{Rebinding}.
108
109 @anchor{Glossary---Binding}
110 @item Binding
111 A key sequence gets its meaning in Emacs by having a binding, which is a
112 command (q.v.), a Lisp function that is run when you type that
113 sequence. @xref{Commands,Binding}. Customization often involves
114 rebinding a character to a different command function. The bindings of
115 all key sequences are recorded in the keymaps (q.v.). @xref{Keymaps}.
116
117 @item Blank Lines
118 Blank lines are lines that contain only whitespace. Emacs has several
119 commands for operating on the blank lines in the buffer. @xref{Blank Lines}.
120
121 @item Bookmark
122 Bookmarks are akin to registers (q.v.@:) in that they record positions
123 in buffers to which you can return later. Unlike registers, bookmarks
124 persist between Emacs sessions. @xref{Bookmarks}.
125
126 @item Border
127 A border is a thin space along the edge of the frame, used just for
128 spacing, not for displaying anything. An Emacs frame has an ordinary
129 external border, outside of everything including the menu bar, plus an
130 internal border that surrounds the text windows, their scroll bars
131 and fringes, and separates them from the menu bar and tool bar. You
132 can customize both borders with options and resources (@pxref{Borders
133 X}). Borders are not the same as fringes (q.v.).
134
135 @item Buffer
136 The buffer is the basic editing unit; one buffer corresponds to one text
137 being edited. You normally have several buffers, but at any time you are
138 editing only one, the `current buffer', though several can be visible
139 when you are using multiple windows or frames (q.v.). Most buffers
140 are visiting (q.v.@:) some file. @xref{Buffers}.
141
142 @item Buffer Selection History
143 Emacs keeps a buffer selection history that records how recently each
144 Emacs buffer has been selected. This is used for choosing a buffer to
145 select. @xref{Buffers}.
146
147 @item Bug
148 A bug is an incorrect or unreasonable behavior of a program, or
149 inaccurate or confusing documentation. Emacs developers treat bug
150 reports, both in Emacs code and its documentation, very seriously and
151 ask you to report any bugs you find. @xref{Bugs}.
152
153 @item Button Down Event
154 A button down event is the kind of input event (q.v.@:) generated
155 right away when you press down on a mouse button. @xref{Mouse Buttons}.
156
157 @item By Default
158 @xref{Glossary---Default}.
159
160 @item Byte Compilation
161 @xref{Glossary---Compilation}.
162
163 @anchor{Glossary---C-}
164 @item @kbd{C-}
165 @kbd{C-} in the name of a character is an abbreviation for Control.
166 @xref{User Input,C-}.
167
168 @item @kbd{C-M-}
169 @kbd{C-M-} in the name of a character is an abbreviation for
170 Control-Meta. If your terminal lacks a real @key{META} key, you type
171 a Control-Meta character by typing @key{ESC} and then typing the
172 corresponding Control character. @xref{User Input,C-M-}.
173
174 @item Case Conversion
175 Case conversion means changing text from upper case to lower case or
176 vice versa. @xref{Case}.
177
178 @item Character
179 Characters form the contents of an Emacs buffer. Also, key sequences
180 (q.v.@:) are usually made up of characters (though they may include
181 other input events as well). @xref{User Input}.
182
183 @item Character Set
184 Emacs supports a number of character sets, each of which represents a
185 particular alphabet or script. @xref{International}.
186
187 @item Character Terminal
188 @xref{Glossary---Text Terminal}.
189
190 @item Chord
191 A chord is a key sequence (q.v.) in which the keys are pressed at the
192 same time. For example: @kbd{S-M-C-a}. You can hold down a chord to
193 repeat its command.
194
195 @item Click Event
196 A click event is the kind of input event (q.v.@:) generated when you
197 press a mouse button and release it without moving the mouse.
198 @xref{Mouse Buttons}.
199
200 @item Client
201 @xref{Glossary---Server}.
202
203 @item Clipboard
204 A clipboard is a buffer provided by the window system for transferring
205 text between applications. On the X Window System, the clipboard is
206 provided in addition to the primary selection (q.v.); on MS-Windows and Mac,
207 the clipboard is used @emph{instead} of the primary selection.
208 @xref{Clipboard}.
209
210 @item Coding System
211 A coding system is an encoding for representing text characters in a
212 file or in a stream of information. Emacs has the ability to convert
213 text to or from a variety of coding systems when reading or writing it.
214 @xref{Coding Systems}.
215
216 @item Command
217 A command is a Lisp function specially defined to be able to serve as a
218 key binding in Emacs. When you type a key sequence (q.v.), its
219 binding (q.v.@:) is looked up in the relevant keymaps (q.v.@:) to find
220 the command to run. @xref{Commands}.
221
222 @item Command History
223 @xref{Glossary---Minibuffer History}.
224
225 @item Command Name
226 A command name is the name of a Lisp symbol that is a command
227 (@pxref{Commands}). You can invoke any command by its name using
228 @kbd{M-x} (@pxref{M-x,M-x,Running Commands by Name}).
229
230 @item Comment
231 A comment is text in a program which is intended only for humans reading
232 the program, and which is specially marked so that it will be ignored
233 when the program is loaded or compiled. Emacs offers special commands
234 for creating, aligning and killing comments. @xref{Comments}.
235
236 @item Common Lisp
237 Common Lisp is a dialect of Lisp (q.v.@:) much larger and more powerful
238 than Emacs Lisp. Emacs provides a subset of Common Lisp in the CL
239 package. @xref{Top, Common Lisp, Overview, cl, Common Lisp Extensions}.
240
241 @anchor{Glossary---Compilation}
242 @item Compilation
243 Compilation is the process of creating an executable program from source
244 code. Emacs has commands for compiling files of Emacs Lisp code
245 (@pxref{Byte Compilation,,, elisp, the Emacs Lisp
246 Reference Manual}) and programs in C and other languages
247 (@pxref{Compilation}).
248
249 @item Complete Key
250 A complete key is a key sequence that fully specifies one action to be
251 performed by Emacs. For example, @kbd{X} and @kbd{C-f} and @kbd{C-x m}
252 are complete keys. Complete keys derive their meanings from being bound
253 (q.v.@:) to commands (q.v.). Thus, @kbd{X} is conventionally bound to
254 a command to insert @samp{X} in the buffer; @kbd{C-x m} is
255 conventionally bound to a command to begin composing a mail message.
256 @xref{Keys}.
257
258 @item Completion
259 Completion is what Emacs does when it automatically expands an
260 abbreviation for a name into the entire name. Completion is done for
261 minibuffer (q.v.@:) arguments when the set of possible valid inputs
262 is known; for example, on command names, buffer names, and
263 file names. Completion usually occurs when @key{TAB}, @key{SPC} or
264 @key{RET} is typed. @xref{Completion}.@refill
265
266 @anchor{Glossary---Continuation Line}
267 @item Continuation Line
268 When a line of text is longer than the width of the window, it
269 normally (but see @ref{Glossary---Truncation}) takes up more than one
270 screen line when displayed. We say that the text line is continued, and all
271 screen lines used for it after the first are called continuation
272 lines. @xref{Continuation Lines}. A related Emacs feature is
273 `filling' (q.v.).
274
275 @item Control Character
276 A control character is a character that you type by holding down the
277 @key{CTRL} key. Some control characters also have their own keys, so
278 that you can type them without using @key{CTRL}. For example,
279 @key{RET}, @key{TAB}, @key{ESC} and @key{DEL} are all control
280 characters. @xref{User Input}.
281
282 @item Copyleft
283 A copyleft is a notice giving the public legal permission to
284 redistribute and modify a program or other work of art, but requiring
285 modified versions to carry similar permission. Copyright is normally
286 used to keep users divided and helpless; with copyleft we turn that
287 around to empower users and encourage them to cooperate.
288
289 The particular form of copyleft used by the GNU project is called the
290 GNU General Public License. @xref{Copying}.
291
292 @item @key{CTRL}
293 The @key{CTRL} or ``control'' key is what you hold down
294 in order to enter a control character (q.v.). @xref{Glossary---C-}.
295
296 @item Current Buffer
297 The current buffer in Emacs is the Emacs buffer on which most editing
298 commands operate. You can select any Emacs buffer as the current one.
299 @xref{Buffers}.
300
301 @item Current Line
302 The current line is the line that point is on (@pxref{Point}).
303
304 @item Current Paragraph
305 The current paragraph is the paragraph that point is in. If point is
306 between two paragraphs, the current paragraph is the one that follows
307 point. @xref{Paragraphs}.
308
309 @item Current Defun
310 The current defun is the defun (q.v.@:) that point is in. If point is
311 between defuns, the current defun is the one that follows point.
312 @xref{Defuns}.
313
314 @item Cursor
315 The cursor is the rectangle on the screen which indicates the position
316 (called point; q.v.@:) at which insertion and deletion takes place.
317 The cursor is on or under the character that follows point. Often
318 people speak of `the cursor' when, strictly speaking, they mean
319 `point'. @xref{Point,Cursor}.
320
321 @item Customization
322 Customization is making minor changes in the way Emacs works, to
323 reflect your preferences or needs. It is often done by setting
324 variables (@pxref{Variables}) or faces (@pxref{Face Customization}),
325 or by rebinding key sequences (@pxref{Keymaps}).
326
327 @cindex cut and paste
328 @item Cut and Paste
329 @xref{Glossary---Killing}, and @ref{Glossary---Yanking}.
330
331 @anchor{Glossary---Daemon}
332 @item Daemon
333 A daemon is a standard term for a system-level process that runs in the
334 background. Daemons are often started when the system first starts up.
335 When Emacs runs in daemon-mode, it runs in the background and does not
336 open a display. You can then connect to it with the
337 @command{emacsclient} program. @xref{Emacs Server}.
338
339 @item Default Argument
340 The default for an argument is the value that will be assumed if you
341 do not specify one. When the minibuffer is used to read an argument,
342 the default argument is used if you just type @key{RET}.
343 @xref{Minibuffer}.
344
345 @anchor{Glossary---Default}
346 @item Default
347 A default is the value that is used for a certain purpose when
348 you do not explicitly specify a value to use.
349
350 @item Default Directory
351 When you specify a file name that does not start with @samp{/} or @samp{~},
352 it is interpreted relative to the current buffer's default directory.
353 (On MS systems, file names that start with a drive letter
354 @samp{@var{x}:} are treated as absolute, not relative.)
355 @xref{Minibuffer File,Default Directory}.
356
357 @item Defun
358 A defun is a major definition at the top level in a program. The name
359 `defun' comes from Lisp, where most such definitions use the construct
360 @code{defun}. @xref{Defuns}.
361
362 @item @key{DEL}
363 @key{DEL} is a character that runs the command to delete one character
364 of text before the cursor. It is typically either the @key{DELETE}
365 key or the @key{BACKSPACE} key, whichever one is easy to type.
366 @xref{Erasing,DEL}.
367
368 @item Deletion
369 Deletion means erasing text without copying it into the kill ring
370 (q.v.). The alternative is killing (q.v.). @xref{Killing,Deletion}.
371
372 @anchor{Glossary---Deletion of Files}
373 @item Deletion of Files
374 Deleting a file means erasing it from the file system.
375 (Note that some systems use the concept of a ``trash can'', or ``recycle
376 bin'', to allow you to ``undelete'' files.)
377 @xref{Misc File Ops,Misc File Ops,Miscellaneous File Operations}.
378
379 @item Deletion of Messages
380 Deleting a message (in Rmail, and other mail clients) means flagging
381 it to be eliminated from your mail file. Until you expunge (q.v.@:)
382 the Rmail file, you can still undelete the messages you have deleted.
383 @xref{Rmail Deletion}.
384
385 @item Deletion of Windows
386 Deleting a window means eliminating it from the screen. Other windows
387 expand to use up the space. The text that was in the window is not
388 lost, and you can create a new window with the same dimensions as the
389 old if you wish. @xref{Windows}.
390
391 @item Directory
392 File directories are named collections in the file system, within which
393 you can place individual files or subdirectories. They are sometimes
394 referred to as ``folders''. @xref{Directories}.
395
396 @anchor{Glossary---Directory Local Variable}
397 @item Directory Local Variable
398 A directory local variable is a local variable (q.v.@:) that applies
399 to all the files within a certain directory. @xref{Directory
400 Variables}.
401
402 @item Dired
403 Dired is the Emacs facility that displays the contents of a file
404 directory and allows you to ``edit the directory'', performing
405 operations on the files in the directory. @xref{Dired}.
406
407 @item Disabled Command
408 A disabled command is one that you may not run without special
409 confirmation. The usual reason for disabling a command is that it is
410 confusing for beginning users. @xref{Disabling}.
411
412 @item Down Event
413 Short for `button down event' (q.v.).
414
415 @item Drag Event
416 A drag event is the kind of input event (q.v.@:) generated when you
417 press a mouse button, move the mouse, and then release the button.
418 @xref{Mouse Buttons}.
419
420 @item Dribble File
421 A dribble file is a file into which Emacs writes all the characters that
422 you type on the keyboard. Dribble files can be used to make a record
423 for debugging Emacs bugs. Emacs does not make a dribble file unless you
424 tell it to. @xref{Bugs}.
425
426 @c TODO? Not really appropriate for the user manual I think.
427 @c Dynamic Binding
428
429 @item Echo Area
430 The echo area is the bottom line of the screen, used for echoing the
431 arguments to commands, for asking questions, and showing brief messages
432 (including error messages). The messages are stored in the buffer
433 @file{*Messages*} so you can review them later. @xref{Echo Area}.
434
435 @item Echoing
436 Echoing is acknowledging the receipt of input events by displaying
437 them (in the echo area). Emacs never echoes single-character key
438 sequences; longer key sequences echo only if you pause while typing
439 them.
440
441 @item Electric
442 We say that a character is electric if it is normally self-inserting
443 (q.v.), but the current major mode (q.v.@:) redefines it to do something
444 else as well. For example, some programming language major modes define
445 particular delimiter characters to reindent the line, or insert one or
446 more newlines in addition to self-insertion.
447
448 @anchor{Glossary---End Of Line}
449 @item End Of Line
450 End of line is a character or a sequence of characters that indicate
451 the end of a text line. On GNU and Unix systems, this is a newline
452 (q.v.), but other systems have other conventions. @xref{Coding
453 Systems,end-of-line}. Emacs can recognize several end-of-line
454 conventions in files and convert between them.
455
456 @item Environment Variable
457 An environment variable is one of a collection of variables stored by
458 the operating system, each one having a name and a value. Emacs can
459 access environment variables set by its parent shell, and it can set
460 variables in the environment it passes to programs it invokes.
461 @xref{Environment}.
462
463 @item EOL
464 @xref{Glossary---End Of Line}.
465
466 @item Error
467 An error occurs when an Emacs command cannot execute in the current
468 circumstances. When an error occurs, execution of the command stops
469 (unless the command has been programmed to do otherwise) and Emacs
470 reports the error by displaying an error message (q.v.).
471 @c Not helpful?
472 @c Type-ahead is discarded. Then Emacs is ready to read another
473 @c editing command.
474
475 @item Error Message
476 An error message is output displayed by Emacs when you ask it to do
477 something impossible (such as, killing text forward when point is at
478 the end of the buffer), or when a command malfunctions in some way.
479 Such messages appear in the echo area, accompanied by a beep.
480
481 @item @key{ESC}
482 @key{ESC} is a character used as a prefix for typing Meta characters on
483 keyboards lacking a @key{META} key. Unlike the @key{META} key (which,
484 like the @key{SHIFT} key, is held down while another character is
485 typed), you press the @key{ESC} key as you would press a letter key, and
486 it applies to the next character you type.
487
488 @item Expression
489 @xref{Glossary---Balanced Expression}.
490
491 @item Expunging
492 Expunging an Rmail, Gnus newsgroup, or Dired buffer is an operation
493 that truly discards the messages or files you have previously flagged
494 for deletion.
495
496 @item Face
497 A face is a style of displaying characters. It specifies attributes
498 such as font family and size, foreground and background colors,
499 underline and strike-through, background stipple, etc. Emacs provides
500 features to associate specific faces with portions of buffer text, in
501 order to display that text as specified by the face attributes.
502 @xref{Faces}.
503
504 @item File Local Variable
505 A file local variable is a local variable (q.v.@:) specified in a
506 given file. @xref{File Variables}, and @ref{Glossary---Directory
507 Local Variable}.
508
509 @anchor{Glossary---File Locking}
510 @item File Locking
511 Emacs uses file locking to notice when two different users
512 start to edit one file at the same time. @xref{Interlocking}.
513
514 @item File Name
515 @c This is fairly tautological...
516 A file name is a name that refers to a file. File names may be relative
517 or absolute; the meaning of a relative file name depends on the current
518 directory, but an absolute file name refers to the same file regardless
519 of which directory is current. On GNU and Unix systems, an absolute
520 file name starts with a slash (the root directory) or with @samp{~/} or
521 @samp{~@var{user}/} (a home directory). On MS-Windows/MS-DOS, an
522 absolute file name can also start with a drive letter and a colon, e.g.,
523 @samp{@var{d}:}.
524
525 Some people use the term ``pathname'' for file names, but we do not;
526 we use the word ``path'' only in the term ``search path'' (q.v.).
527
528 @item File-Name Component
529 A file-name component names a file directly within a particular
530 directory. On GNU and Unix systems, a file name is a sequence of
531 file-name components, separated by slashes. For example, @file{foo/bar}
532 is a file name containing two components, @samp{foo} and @samp{bar}; it
533 refers to the file named @samp{bar} in the directory named @samp{foo} in
534 the current directory. MS-DOS/MS-Windows file names can also use
535 backslashes to separate components, as in @file{foo\bar}.
536
537 @item Fill Prefix
538 The fill prefix is a string that should be expected at the beginning
539 of each line when filling is done. It is not regarded as part of the
540 text to be filled. @xref{Filling}.
541
542 @anchor{Glossary---Filling}
543 @item Filling
544 Filling text means adjusting the position of line-breaks to shift text
545 between consecutive lines, so that all the lines are approximately the
546 same length. @xref{Filling}. Some other editors call this feature
547 ``line wrapping''.
548
549 @anchor{Glossary---Font Lock}
550 @item Font Lock
551 Font Lock is a mode that highlights parts of buffer text in different
552 faces, according to the syntax. Some other editors refer to this as
553 ``syntax highlighting''. For example, all comments (q.v.@:)
554 might be colored red. @xref{Font Lock}.
555
556 @item Fontset
557 A fontset is a named collection of fonts. A fontset specification lists
558 character sets and which font to use to display each of them. Fontsets
559 make it easy to change several fonts at once by specifying the name of a
560 fontset, rather than changing each font separately. @xref{Fontsets}.
561
562 @item Formfeed Character
563 @xref{Glossary---Page}.
564
565 @item Frame
566 A frame is a rectangular cluster of Emacs windows. Emacs starts out
567 with one frame, but you can create more. You can subdivide each frame
568 into Emacs windows (q.v.). When you are using a window system
569 (q.v.), more than one frame can be visible at the same time.
570 @xref{Frames}. Some other editors use the term ``window'' for this,
571 but in Emacs a window means something else.
572
573 @item Free Software
574 Free software is software that gives you the freedom to share, study
575 and modify it. Emacs is free software, part of the GNU project
576 (q.v.), and distributed under a copyleft (q.v.@:) license called the
577 GNU General Public License. @xref{Copying}.
578
579 @anchor{Glossary---Free Software Foundation}
580 @item Free Software Foundation
581 The Free Software Foundation (FSF) is a charitable foundation
582 dedicated to promoting the development of free software (q.v.).
583 For more information, see @uref{http://fsf.org/, the FSF website}.
584
585 @item Fringe
586 On a graphical display (q.v.), there's a narrow portion of the frame
587 (q.v.@:) between the text area and the window's border. These
588 ``fringes'' are used to display symbols that provide information about
589 the buffer text (@pxref{Fringes}). Emacs displays the fringe using a
590 special face (q.v.@:) called @code{fringe}. @xref{Faces,fringe}.
591
592 @item FSF
593 @xref{Glossary---Free Software Foundation}.
594
595 @item FTP
596 FTP is an acronym for File Transfer Protocol. This is one standard
597 method for retrieving remote files (q.v.).
598
599 @item Function Key
600 A function key is a key on the keyboard that sends input but does not
601 correspond to any character. @xref{Function Keys}.
602
603 @item Global
604 Global means ``independent of the current environment; in effect
605 throughout Emacs''. It is the opposite of local (q.v.). Particular
606 examples of the use of `global' appear below.
607
608 @item Global Abbrev
609 A global definition of an abbrev (q.v.@:) is effective in all major
610 modes that do not have local (q.v.@:) definitions for the same abbrev.
611 @xref{Abbrevs}.
612
613 @item Global Keymap
614 The global keymap (q.v.@:) contains key bindings that are in effect
615 everywhere, except when overridden by local key bindings in a major
616 mode's local keymap (q.v.). @xref{Keymaps}.
617
618 @item Global Mark Ring
619 The global mark ring records the series of buffers you have recently
620 set a mark (q.v.@:) in. In many cases you can use this to backtrack
621 through buffers you have been editing, or in which you have found
622 tags (@pxref{Glossary---Tags Table}). @xref{Global Mark Ring}.
623
624 @anchor{Glossary---Global Substitution}
625 @item Global Substitution
626 Global substitution means replacing each occurrence of one string by
627 another string throughout a large amount of text. @xref{Replace}.
628
629 @item Global Variable
630 The global value of a variable (q.v.@:) takes effect in all buffers
631 that do not have their own local (q.v.@:) values for the variable.
632 @xref{Variables}.
633
634 @item GNU
635 GNU is a recursive acronym for GNU's Not Unix, and it refers to a
636 Unix-compatible operating system which is free software (q.v.).
637 @xref{Manifesto}. GNU is normally used with Linux as the kernel since
638 Linux works better than the GNU kernel. For more information, see
639 @uref{http://www.gnu.org/, the GNU website}.
640
641 @item Graphic Character
642 Graphic characters are those assigned pictorial images rather than
643 just names. All the non-Meta (q.v.@:) characters except for the
644 Control (q.v.@:) characters are graphic characters. These include
645 letters, digits, punctuation, and spaces; they do not include
646 @key{RET} or @key{ESC}. In Emacs, typing a graphic character inserts
647 that character (in ordinary editing modes). @xref{Inserting Text}.
648
649 @item Graphical Display
650 A graphical display is one that can display images and multiple fonts.
651 Usually it also has a window system (q.v.).
652
653 @item Highlighting
654 Highlighting text means displaying it with a different foreground and/or
655 background color to make it stand out from the rest of the text in the
656 buffer.
657
658 Emacs uses highlighting in several ways. It highlights the region
659 whenever it is active (@pxref{Mark}). Incremental search also
660 highlights matches (@pxref{Incremental Search}). @xref{Glossary---Font Lock}.
661
662 @item Hardcopy
663 Hardcopy means printed output. Emacs has various commands for
664 printing the contents of Emacs buffers. @xref{Printing}.
665
666 @item @key{HELP}
667 @key{HELP} is the Emacs name for @kbd{C-h} or @key{F1}. You can type
668 @key{HELP} at any time to ask what options you have, or to ask what a
669 command does. @xref{Help}.
670
671 @item Help Echo
672 Help echo is a short message displayed in the echo area (q.v.@:) when
673 the mouse pointer is located on portions of display that require some
674 explanations. Emacs displays help echo for menu items, parts of the
675 mode line, tool-bar buttons, etc. On graphical displays, the messages
676 can be displayed as tooltips (q.v.). @xref{Tooltips}.
677
678 @item Home Directory
679 Your home directory contains your personal files. On a multi-user GNU
680 or Unix system, each user has his or her own home directory. When you
681 start a new login session, your home directory is the default
682 directory in which to start. A standard shorthand for your home
683 directory is @samp{~}. Similarly, @samp{~@var{user}} represents the
684 home directory of some other user.
685
686 @item Hook
687 A hook is a list of functions to be called on specific occasions, such
688 as saving a buffer in a file, major mode activation, etc. By
689 customizing the various hooks, you can modify Emacs's behavior without
690 changing any of its code. @xref{Hooks}.
691
692 @item Hyper
693 Hyper is the name of a modifier bit that a keyboard input character may
694 have. To make a character Hyper, type it while holding down the
695 @key{HYPER} key. Such characters are given names that start with
696 @kbd{Hyper-} (usually written @kbd{H-} for short). @xref{User Input}.
697
698 @item Iff
699 ``Iff'' means ``if and only if''. This terminology comes from
700 mathematics. Try to avoid using this term in documentation, since
701 many are unfamiliar with it and mistake it for a typo.
702
703 @item Inbox
704 An inbox is a file in which mail is delivered by the operating system.
705 Rmail transfers mail from inboxes to Rmail files in which the
706 mail is then stored permanently or until explicitly deleted.
707 @xref{Rmail Inbox}.
708
709 @anchor{Glossary---Incremental Search}
710 @item Incremental Search
711 Emacs provides an incremental search facility, whereby Emacs begins
712 searching for a string as soon as you type the first character.
713 As you type more characters, it refines the search. @xref{Incremental Search}.
714
715 @item Indentation
716 Indentation means blank space at the beginning of a line. Most
717 programming languages have conventions for using indentation to
718 illuminate the structure of the program, and Emacs has special
719 commands to adjust indentation.
720 @xref{Indentation}.
721
722 @item Indirect Buffer
723 An indirect buffer is a buffer that shares the text of another buffer,
724 called its base buffer (q.v.). @xref{Indirect Buffers}.
725
726 @item Info
727 Info is the hypertext format used by the GNU project for writing
728 documentation.
729
730 @item Input Event
731 An input event represents, within Emacs, one action taken by the user on
732 the terminal. Input events include typing characters, typing function
733 keys, pressing or releasing mouse buttons, and switching between Emacs
734 frames. @xref{User Input}.
735
736 @item Input Method
737 An input method is a system for entering non-@acronym{ASCII} text characters by
738 typing sequences of @acronym{ASCII} characters (q.v.). @xref{Input Methods}.
739
740 @item Insertion
741 Insertion means adding text into the buffer, either from the keyboard
742 or from some other place in Emacs.
743
744 @item Interlocking
745 @xref{Glossary---File Locking}.
746
747 @item Isearch
748 @xref{Glossary---Incremental Search}.
749
750 @item Justification
751 Justification means adding extra spaces within lines of text in order
752 to adjust the position of the text edges. @xref{Fill Commands}.
753
754 @item Key Binding
755 @xref{Glossary---Binding}.
756
757 @item Keyboard Macro
758 Keyboard macros are a way of defining new Emacs commands from
759 sequences of existing ones, with no need to write a Lisp program.
760 You can use a macro to record a sequence of commands, then
761 play them back as many times as you like.
762 @xref{Keyboard Macros}.
763
764 @cindex keyboard shortcuts
765 @item Keyboard Shortcut
766 A keyboard shortcut is a key sequence (q.v.@:) that invokes a
767 command. What some programs call ``assigning a keyboard shortcut'',
768 Emacs calls ``binding a key sequence''. @xref{Glossary---Binding}.
769
770 @item Key Sequence
771 A key sequence (key, for short) is a sequence of input events (q.v.@:)
772 that are meaningful as a single unit. If the key sequence is enough to
773 specify one action, it is a complete key (q.v.); if it is not enough,
774 it is a prefix key (q.v.). @xref{Keys}.
775
776 @item Keymap
777 The keymap is the data structure that records the bindings (q.v.@:) of
778 key sequences to the commands that they run. For example, the global
779 keymap binds the character @kbd{C-n} to the command function
780 @code{next-line}. @xref{Keymaps}.
781
782 @item Keyboard Translation Table
783 The keyboard translation table is an array that translates the character
784 codes that come from the terminal into the character codes that make up
785 key sequences.
786
787 @item Kill Ring
788 The kill ring is where all text you have killed (@pxref{Glossary---Killing})
789 recently is saved. You can reinsert any of the killed text still in
790 the ring; this is called yanking (q.v.). @xref{Yanking}.
791
792 @anchor{Glossary---Killing}
793 @item Killing
794 Killing means erasing text and saving it on the kill ring so it can be
795 yanked (q.v.@:) later. Some other systems call this ``cutting''.
796 Most Emacs commands that erase text perform killing, as opposed to
797 deletion (q.v.). @xref{Killing}.
798
799 @item Killing a Job
800 Killing a job (such as, an invocation of Emacs) means making it cease
801 to exist. Any data within it, if not saved in a file, is lost.
802 @xref{Exiting}.
803
804 @item Language Environment
805 Your choice of language environment specifies defaults for the input
806 method (q.v.@:) and coding system (q.v.). @xref{Language
807 Environments}. These defaults are relevant if you edit
808 non-@acronym{ASCII} text (@pxref{International}).
809
810 @c TODO? Not really appropriate for the user manual I think.
811 @c Lexical Binding
812
813 @item Line Wrapping
814 @xref{Glossary---Filling}.
815
816 @item Lisp
817 Lisp is a programming language. Most of Emacs is written in a dialect
818 of Lisp, called Emacs Lisp, which is extended with special features that
819 make it especially suitable for text editing tasks.
820
821 @item List
822 A list is, approximately, a text string beginning with an open
823 parenthesis and ending with the matching close parenthesis. In C mode
824 and other non-Lisp modes, groupings surrounded by other kinds of matched
825 delimiters appropriate to the language, such as braces, are also
826 considered lists. Emacs has special commands for many operations on
827 lists. @xref{Moving by Parens}.
828
829 @item Local
830 Local means ``in effect only in a particular context''; the relevant
831 kind of context is a particular function execution, a particular
832 buffer, or a particular major mode. It is the opposite of `global'
833 (q.v.). Specific uses of `local' in Emacs terminology appear below.
834
835 @item Local Abbrev
836 A local abbrev definition is effective only if a particular major mode
837 is selected. In that major mode, it overrides any global definition
838 for the same abbrev. @xref{Abbrevs}.
839
840 @item Local Keymap
841 A local keymap is used in a particular major mode; the key bindings
842 (q.v.@:) in the current local keymap override global bindings of the
843 same key sequences. @xref{Keymaps}.
844
845 @item Local Variable
846 A local value of a variable (q.v.@:) applies to only one buffer.
847 @xref{Locals}.
848
849 @item @kbd{M-}
850 @kbd{M-} in the name of a character is an abbreviation for @key{META},
851 one of the modifier keys that can accompany any character.
852 @xref{User Input,M-}.
853
854 @item @kbd{M-C-}
855 @kbd{M-C-} in the name of a character is an abbreviation for
856 Control-Meta; it means the same thing as `@kbd{C-M-}' (q.v.).
857
858 @item @kbd{M-x}
859 @kbd{M-x} is the key sequence that is used to call an Emacs command by
860 name. This is how you run commands that are not bound to key sequences.
861 @xref{M-x,M-x,Running Commands by Name}.
862
863 @anchor{Glossary---Mail}
864 @item Mail
865 Mail means messages sent from one user to another through the computer
866 system, to be read at the recipient's convenience. Emacs has commands for
867 composing and sending mail, and for reading and editing the mail you have
868 received. @xref{Sending Mail}. @xref{Rmail}, for one way to read
869 mail with Emacs.
870
871 @item Mail Composition Method
872 A mail composition method is a program runnable within Emacs for editing
873 and sending a mail message. Emacs lets you select from several
874 alternative mail composition methods. @xref{Mail Methods}.
875
876 @item Major Mode
877 The Emacs major modes are a mutually exclusive set of options, each of
878 which configures Emacs for editing a certain sort of text. Ideally,
879 each programming language has its own major mode. @xref{Major Modes}.
880
881 @item Margin
882 The space between the usable part of a window (including the
883 fringe) and the window edge.
884
885 @item Mark
886 The mark points to a position in the text. It specifies one end of the
887 region (q.v.), point being the other end. Many commands operate on
888 all the text from point to the mark. Each buffer has its own mark.
889 @xref{Mark}.
890
891 @item Mark Ring
892 The mark ring is used to hold several recent previous locations of the
893 mark, in case you want to move back to them. Each buffer has its
894 own mark ring; in addition, there is a single global mark ring (q.v.).
895 @xref{Mark Ring}.
896
897 @item Menu Bar
898 The menu bar is a line at the top of an Emacs frame. It contains
899 words you can click on with the mouse to bring up menus, or you can use
900 a keyboard interface to navigate it. @xref{Menu Bars}.
901
902 @item Message
903 @xref{Glossary---Mail}.
904
905 @item Meta
906 Meta is the name of a modifier bit which you can use in a command
907 character. To enter a meta character, you hold down the @key{META}
908 key while typing the character. We refer to such characters with
909 names that start with @kbd{Meta-} (usually written @kbd{M-} for
910 short). For example, @kbd{M-<} is typed by holding down @key{META}
911 and at the same time typing @kbd{<} (which itself is done, on most
912 terminals, by holding down @key{SHIFT} and typing @kbd{,}).
913 @xref{User Input,Meta}.
914
915 On some terminals, the @key{META} key is actually labeled @key{ALT}
916 or @key{EDIT}.
917
918 @item Meta Character
919 A Meta character is one whose character code includes the Meta bit.
920
921 @item Minibuffer
922 The minibuffer is the window that appears when necessary inside the
923 echo area (q.v.), used for reading arguments to commands.
924 @xref{Minibuffer}.
925
926 @anchor{Glossary---Minibuffer History}
927 @item Minibuffer History
928 The minibuffer history records the text you have specified in the past
929 for minibuffer arguments, so you can conveniently use the same text
930 again. @xref{Minibuffer History}.
931
932 @item Minor Mode
933 A minor mode is an optional feature of Emacs, which can be switched on
934 or off independently of all other features. Each minor mode has a
935 command to turn it on or off. Some minor modes are global (q.v.),
936 and some are local (q.v.). @xref{Minor Modes}.
937
938 @item Minor Mode Keymap
939 A minor mode keymap is a keymap that belongs to a minor mode and is
940 active when that mode is enabled. Minor mode keymaps take precedence
941 over the buffer's local keymap, just as the local keymap takes
942 precedence over the global keymap. @xref{Keymaps}.
943
944 @item Mode Line
945 The mode line is the line at the bottom of each window (q.v.), giving
946 status information on the buffer displayed in that window. @xref{Mode
947 Line}.
948
949 @item Modified Buffer
950 A buffer (q.v.@:) is modified if its text has been changed since the
951 last time the buffer was saved (or since it was created, if it
952 has never been saved). @xref{Saving}.
953
954 @item Moving Text
955 Moving text means erasing it from one place and inserting it in
956 another. The usual way to move text is by killing (q.v.@:) it and then
957 yanking (q.v.@:) it. @xref{Killing}.
958
959 @item MULE
960 MULE refers to the Emacs features for editing multilingual
961 non-@acronym{ASCII} text using multibyte characters (q.v.).
962 @xref{International}.
963
964 @item Multibyte Character
965 A multibyte character is a character that takes up several bytes in a
966 buffer. Emacs uses multibyte characters to represent non-@acronym{ASCII} text,
967 since the number of non-@acronym{ASCII} characters is much more than 256.
968 @xref{International Chars, International Characters}.
969
970 @item Named Mark
971 A named mark is a register (q.v.), in its role of recording a
972 location in text so that you can move point to that location.
973 @xref{Registers}.
974
975 @item Narrowing
976 Narrowing means creating a restriction (q.v.@:) that limits editing in
977 the current buffer to only a part of the text. Text outside that part
978 is inaccessible for editing (or viewing) until the boundaries are
979 widened again, but it is still there, and saving the file saves it
980 all. @xref{Narrowing}.
981
982 @item Newline
983 Control-J characters in the buffer terminate lines of text and are
984 therefore also called newlines. @xref{Glossary---End Of Line}.
985
986 @cindex nil
987 @cindex t
988 @item @code{nil}
989 @code{nil} is a value usually interpreted as a logical ``false''. Its
990 opposite is @code{t}, interpreted as ``true''.
991
992 @anchor{Glossary---Numeric Argument}
993 @item Numeric Argument
994 A numeric argument is a number, specified before a command, to change
995 the effect of the command. Often the numeric argument serves as a
996 repeat count. @xref{Arguments}.
997
998 @item Overwrite Mode
999 Overwrite mode is a minor mode. When it is enabled, ordinary text
1000 characters replace the existing text after point rather than pushing
1001 it to one side. @xref{Minor Modes}.
1002
1003 @item Package
1004 A package is a collection of Lisp code that you download and
1005 automatically install from within Emacs. Packages provide a
1006 convenient way to add new features. @xref{Packages}.
1007
1008 @anchor{Glossary---Page}
1009 @item Page
1010 A page is a unit of text, delimited by formfeed characters (@acronym{ASCII}
1011 control-L, code 014) at the beginning of a line. Some Emacs
1012 commands are provided for moving over and operating on pages.
1013 @xref{Pages}.
1014
1015 @item Paragraph
1016 Paragraphs are the medium-size unit of human-language text. There are
1017 special Emacs commands for moving over and operating on paragraphs.
1018 @xref{Paragraphs}.
1019
1020 @item Parsing
1021 We say that certain Emacs commands parse words or expressions in the
1022 text being edited. Really, all they know how to do is find the other
1023 end of a word or expression.
1024
1025 @item Point
1026 Point is the place in the buffer at which insertion and deletion
1027 occur. Point is considered to be between two characters, not at one
1028 character. The terminal's cursor (q.v.@:) indicates the location of
1029 point. @xref{Point}.
1030
1031 @item Prefix Argument
1032 @xref{Glossary---Numeric Argument}.
1033
1034 @item Prefix Key
1035 A prefix key is a key sequence (q.v.@:) whose sole function is to
1036 introduce a set of longer key sequences. @kbd{C-x} is an example of
1037 prefix key; any two-character sequence starting with @kbd{C-x} is
1038 therefore a legitimate key sequence. @xref{Keys}.
1039
1040 @c I don't think this kind of thing needs to be here.
1041 @ignore
1042 @item Primary Rmail File
1043 Your primary Rmail file is the file named @samp{RMAIL} in your home
1044 directory. That's where Rmail stores your incoming mail, unless you
1045 specify a different file name. @xref{Rmail}.
1046 @end ignore
1047
1048 @item Primary Selection
1049 The primary selection is one particular X selection (q.v.); it is the
1050 selection that most X applications use for transferring text to and from
1051 other applications.
1052
1053 The Emacs kill commands set the primary selection and the yank command
1054 uses the primary selection when appropriate. @xref{Killing}.
1055
1056 @item Prompt
1057 A prompt is text used to ask you for input. Displaying a prompt
1058 is called prompting. Emacs prompts always appear in the echo area
1059 (q.v.). One kind of prompting happens when the minibuffer is used to
1060 read an argument (@pxref{Minibuffer}); the echoing that happens when
1061 you pause in the middle of typing a multi-character key sequence is also
1062 a kind of prompting (@pxref{Echo Area}).
1063
1064 @item Query-Replace
1065 Query-replace is an interactive string replacement feature provided by
1066 Emacs. @xref{Query Replace}.
1067
1068 @anchor{Glossary---Quitting}
1069 @item Quitting
1070 Quitting means canceling a partially typed command or a running
1071 command, using @kbd{C-g} (or @kbd{C-@key{BREAK}} on MS-DOS). @xref{Quitting}.
1072
1073 @item Quoting
1074 Quoting means depriving a character of its usual special significance.
1075 The most common kind of quoting in Emacs is with @kbd{C-q}. What
1076 constitutes special significance depends on the context and on
1077 convention. For example, an ``ordinary'' character as an Emacs command
1078 inserts itself; so in this context, a special character is any character
1079 that does not normally insert itself (such as @key{DEL}, for example),
1080 and quoting it makes it insert itself as if it were not special. Not
1081 all contexts allow quoting. @xref{Inserting Text,Quoting}.
1082
1083 @item Quoting File Names
1084 Quoting a file name turns off the special significance of constructs
1085 such as @samp{$}, @samp{~} and @samp{:}. @xref{Quoted File Names}.
1086
1087 @item Read-Only Buffer
1088 A read-only buffer is one whose text you are not allowed to change.
1089 Normally Emacs makes buffers read-only when they contain text which
1090 has a special significance to Emacs; for example, Dired buffers.
1091 Visiting a file that is write-protected also makes a read-only buffer.
1092 @xref{Buffers}.
1093
1094 @item Rectangle
1095 A rectangle consists of the text in a given range of columns on a given
1096 range of lines. Normally you specify a rectangle by putting point at
1097 one corner and putting the mark at the diagonally opposite corner.
1098 @xref{Rectangles}.
1099
1100 @item Recursive Editing Level
1101 A recursive editing level is a state in which part of the execution of
1102 a command involves asking you to edit some text. This text may
1103 or may not be the same as the text to which the command was applied.
1104 The mode line indicates recursive editing levels with square brackets
1105 (@samp{[} and @samp{]}). @xref{Recursive Edit}.
1106
1107 @item Redisplay
1108 Redisplay is the process of correcting the image on the screen to
1109 correspond to changes that have been made in the text being edited.
1110 @xref{Screen,Redisplay}.
1111
1112 @item Regexp
1113 @xref{Glossary---Regular Expression}.
1114
1115 @item Region
1116 The region is the text between point (q.v.@:) and the mark (q.v.).
1117 Many commands operate on the text of the region. @xref{Mark,Region}.
1118
1119 @item Register
1120 Registers are named slots in which text, buffer positions, or
1121 rectangles can be saved for later use. @xref{Registers}. A related
1122 Emacs feature is `bookmarks' (q.v.).
1123
1124 @anchor{Glossary---Regular Expression}
1125 @item Regular Expression
1126 A regular expression is a pattern that can match various text strings;
1127 for example, @samp{a[0-9]+} matches @samp{a} followed by one or more
1128 digits. @xref{Regexps}.
1129
1130 @item Remote File
1131 A remote file is a file that is stored on a system other than your own.
1132 Emacs can access files on other computers provided that they are
1133 connected to the same network as your machine, and (obviously) that
1134 you have a supported method to gain access to those files.
1135 @xref{Remote Files}.
1136
1137 @item Repeat Count
1138 @xref{Glossary---Numeric Argument}.
1139
1140 @item Replacement
1141 @xref{Glossary---Global Substitution}.
1142
1143 @item Restriction
1144 A buffer's restriction is the amount of text, at the beginning or the
1145 end of the buffer, that is temporarily inaccessible. Giving a buffer a
1146 nonzero amount of restriction is called narrowing (q.v.); removing
1147 a restriction is called widening (q.v.). @xref{Narrowing}.
1148
1149 @item @key{RET}
1150 @key{RET} is a character that in Emacs runs the command to insert a
1151 newline into the text. It is also used to terminate most arguments
1152 read in the minibuffer (q.v.). @xref{User Input,Return}.
1153
1154 @item Reverting
1155 Reverting means returning to the original state. Emacs lets you
1156 revert a buffer by re-reading its file from disk. @xref{Reverting}.
1157
1158 @c Seems too obvious, also there is nothing special about the format
1159 @c these days.
1160 @ignore
1161 @item Rmail File
1162 An Rmail file is a file containing text in the format used by
1163 Rmail for storing mail. @xref{Rmail}.
1164 @end ignore
1165
1166 @item Saving
1167 Saving a buffer means copying its text into the file that was visited
1168 (q.v.@:) in that buffer. This is the way text in files actually gets
1169 changed by your Emacs editing. @xref{Saving}.
1170
1171 @item Scroll Bar
1172 A scroll bar is a tall thin hollow box that appears at the side of a
1173 window. You can use mouse commands in the scroll bar to scroll the
1174 window. The scroll bar feature is supported only under windowing
1175 systems. @xref{Scroll Bars}.
1176
1177 @item Scrolling
1178 Scrolling means shifting the text in the Emacs window so as to see a
1179 different part of the buffer. @xref{Scrolling}.
1180
1181 @item Searching
1182 Searching means moving point to the next occurrence of a specified
1183 string or the next match for a specified regular expression.
1184 @xref{Search}.
1185
1186 @item Search Path
1187 A search path is a list of directory names, to be used for searching for
1188 files for certain purposes. For example, the variable @code{load-path}
1189 holds a search path for finding Lisp library files. @xref{Lisp Libraries}.
1190
1191 @item Secondary Selection
1192 The secondary selection is one particular X selection (q.v.); some X
1193 applications can use it for transferring text to and from other
1194 applications. Emacs has special mouse commands for transferring text
1195 using the secondary selection. @xref{Secondary Selection}.
1196
1197 @item Selected Frame
1198 The selected frame is the one your input currently operates on.
1199 @xref{Frames}.
1200
1201 @item Selected Window
1202 The selected window is the one your input currently operates on.
1203 @xref{Basic Window}.
1204
1205 @item Selecting a Buffer
1206 Selecting a buffer means making it the current (q.v.@:) buffer.
1207 @xref{Select Buffer}.
1208
1209 @item Selection
1210 Windowing systems allow an application program to specify
1211 selections whose values are text. A program can also read the
1212 selections that other programs have set up. This is the principal way
1213 of transferring text between window applications. Emacs has commands to
1214 work with the primary (q.v.@:) selection and the secondary (q.v.@:)
1215 selection, and also with the clipboard (q.v.).
1216
1217 @item Self-Documentation
1218 Self-documentation is the feature of Emacs that can tell you what any
1219 command does, or give you a list of all commands related to a topic
1220 you specify. You ask for self-documentation with the help character,
1221 @kbd{C-h}. @xref{Help}.
1222
1223 @item Self-Inserting Character
1224 A character is self-inserting if typing that character inserts that
1225 character in the buffer. Ordinary printing and whitespace characters
1226 are self-inserting in Emacs, except in certain special major modes.
1227
1228 @item Sentences
1229 Emacs has commands for moving by or killing by sentences.
1230 @xref{Sentences}.
1231
1232 @anchor{Glossary---Server}
1233 @item Server
1234 Within Emacs, you can start a `server' process, which listens for
1235 connections from `clients'. This offers a faster alternative to
1236 starting several Emacs instances. @xref{Emacs Server}, and
1237 @ref{Glossary---Daemon}.
1238
1239 @c This is only covered in the lispref, not the user manual.
1240 @ignore
1241 @item Session Manager
1242 Some window systems (q.v.@:) provide a tool called a `session manager'.
1243 This offers the ability to save your windows when you log off,
1244 and restore them after you log in again.
1245 @end ignore
1246
1247 @item Sexp
1248 A sexp (short for ``s-expression'') is the basic syntactic unit of
1249 Lisp in its textual form: either a list, or Lisp atom. Sexps are also
1250 the balanced expressions (q.v.@:) of the Lisp language; this is why
1251 the commands for editing balanced expressions have `sexp' in their
1252 name. @xref{Expressions,Sexps}.
1253
1254 @item Simultaneous Editing
1255 Simultaneous editing means two users modifying the same file at once.
1256 Simultaneous editing, if not detected, can cause one user to lose his
1257 or her work. Emacs detects all cases of simultaneous editing, and
1258 warns one of the users to investigate.
1259 @xref{Interlocking,Interlocking,Simultaneous Editing}.
1260
1261 @item @key{SPC}
1262 @key{SPC} is the space character, which you enter by pressing the
1263 space bar.
1264
1265 @item Speedbar
1266 The speedbar is a special tall frame that provides fast access to Emacs
1267 buffers, functions within those buffers, Info nodes, and other
1268 interesting parts of text within Emacs. @xref{Speedbar}.
1269
1270 @item Spell Checking
1271 Spell checking means checking correctness of the written form of each
1272 one of the words in a text. Emacs can use various external
1273 spelling-checker programs to check the spelling of parts of a buffer
1274 via a convenient user interface. @xref{Spelling}.
1275
1276 @item String
1277 A string is a kind of Lisp data object that contains a sequence of
1278 characters. Many Emacs variables are intended to have strings as
1279 values. The Lisp syntax for a string consists of the characters in the
1280 string with a @samp{"} before and another @samp{"} after. A @samp{"}
1281 that is part of the string must be written as @samp{\"} and a @samp{\}
1282 that is part of the string must be written as @samp{\\}. All other
1283 characters, including newline, can be included just by writing them
1284 inside the string; however, backslash sequences as in C, such as
1285 @samp{\n} for newline or @samp{\241} using an octal character code, are
1286 allowed as well.
1287
1288 @item String Substitution
1289 @xref{Glossary---Global Substitution}.
1290
1291 @item Syntax Highlighting
1292 @xref{Glossary---Font Lock}.
1293
1294 @item Syntax Table
1295 The syntax table tells Emacs which characters are part of a word,
1296 which characters balance each other like parentheses, etc.
1297 @xref{Syntax Tables,, Syntax Tables, elisp, The Emacs Lisp Reference
1298 Manual}.
1299
1300 @item Super
1301 Super is the name of a modifier bit that a keyboard input character may
1302 have. To make a character Super, type it while holding down the
1303 @key{SUPER} key. Such characters are given names that start with
1304 @kbd{Super-} (usually written @kbd{s-} for short). @xref{User Input}.
1305
1306 @item Suspending
1307 Suspending Emacs means stopping it temporarily and returning control
1308 to its parent process, which is usually a shell. Unlike killing a job
1309 (q.v.), you can later resume the suspended Emacs job without losing
1310 your buffers, unsaved edits, undo history, etc. @xref{Exiting}.
1311
1312 @item @key{TAB}
1313 @key{TAB} is the tab character. In Emacs it is typically used for
1314 indentation or completion.
1315
1316 @anchor{Glossary---Tags Table}
1317 @item Tags Table
1318 A tags table is a file that serves as an index to the function
1319 definitions in one or more other files. @xref{Tags}.
1320
1321 @item Termscript File
1322 A termscript file contains a record of all characters sent by Emacs to
1323 the terminal. It is used for tracking down bugs in Emacs redisplay.
1324 Emacs does not make a termscript file unless you tell it to.
1325 @xref{Bugs}.
1326
1327 @item Text
1328 `Text' has two meanings (@pxref{Text}):
1329
1330 @itemize @bullet
1331 @item
1332 Data consisting of a sequence of characters, as opposed to binary
1333 numbers, executable programs, and the like. The basic contents of an
1334 Emacs buffer (aside from the text properties, q.v.@:) are always text
1335 in this sense.
1336 @item
1337 Data consisting of written human language (as opposed to programs),
1338 or following the stylistic conventions of human language.
1339 @end itemize
1340
1341 @anchor{Glossary---Text Terminal}
1342 @item Text Terminal
1343 A text terminal, or character terminal, is a display that is limited
1344 to displaying text in character units. Such a terminal cannot control
1345 individual pixels it displays. Emacs supports a subset of display
1346 features on text terminals.
1347
1348 @item Text Properties
1349 Text properties are annotations recorded for particular characters in
1350 the buffer. Images in the buffer are recorded as text properties;
1351 they also specify formatting information. @xref{Editing Format Info}.
1352
1353 @item Theme
1354 A theme is a set of customizations (q.v.@:) that give Emacs a
1355 particular appearance or behavior. For example, you might use a theme
1356 for your favorite set of faces (q.v.).
1357
1358 @item Tool Bar
1359 The tool bar is a line (sometimes multiple lines) of icons at the top
1360 of an Emacs frame. Clicking on one of these icons executes a command.
1361 You can think of this as a graphical relative of the menu bar (q.v.).
1362 @xref{Tool Bars}.
1363
1364 @anchor{Glossary---Tooltips}
1365 @item Tooltips
1366 Tooltips are small windows displaying a help echo (q.v.@:) text, which
1367 explains parts of the display, lists useful options available via mouse
1368 clicks, etc. @xref{Tooltips}.
1369
1370 @item Top Level
1371 Top level is the normal state of Emacs, in which you are editing the
1372 text of the file you have visited. You are at top level whenever you
1373 are not in a recursive editing level (q.v.@:) or the minibuffer
1374 (q.v.), and not in the middle of a command. You can get back to top
1375 level by aborting (q.v.@:) and quitting (q.v.). @xref{Quitting}.
1376
1377 @item Transient Mark Mode
1378 Transient Mark mode gives you much of the standard
1379 selection-highlighting behavior of other editors. In GNU Emacs 23 and
1380 onwards, it is enabled by default. @xref{Disabled Transient Mark}.
1381
1382 @item Transposition
1383 Transposing two units of text means putting each one into the place
1384 formerly occupied by the other. There are Emacs commands to transpose
1385 two adjacent characters, words, balanced expressions (q.v.@:) or lines
1386 (@pxref{Transpose}).
1387
1388 @item Trash Can
1389 @xref{Glossary---Deletion of Files}.
1390
1391 @anchor{Glossary---Truncation}
1392 @item Truncation
1393 Truncating text lines in the display means leaving out any text on a
1394 line that does not fit within the right margin of the window
1395 displaying it. @xref{Continuation Lines,Truncation}, and
1396 @ref{Glossary---Continuation Line}.
1397
1398 @item TTY
1399 @xref{Glossary---Text Terminal}.
1400
1401 @item Undoing
1402 Undoing means making your previous editing go in reverse, bringing
1403 back the text that existed earlier in the editing session.
1404 @xref{Undo}.
1405
1406 @item Unix
1407 Unix is a class of multi-user computer operating systems with a long
1408 history. There are several implementations today. The GNU project
1409 (q.v.@:) aims to develop a complete Unix-like operating system that
1410 is free software (q.v.).
1411
1412 @item User Option
1413 A user option is a face (q.v.@:) or a variable (q.v.@:) that exists so
1414 that you can customize Emacs by setting it to a new value.
1415 @xref{Easy Customization}.
1416
1417 @item Variable
1418 A variable is an object in Lisp that can store an arbitrary value.
1419 Emacs uses some variables for internal purposes, and has others (known
1420 as `user options'; q.v.@:) just so that you can set their values to
1421 control the behavior of Emacs. The variables used in Emacs that you
1422 are likely to be interested in are listed in the Variables Index in
1423 this manual (@pxref{Variable Index}). @xref{Variables}, for
1424 information on variables.
1425
1426 @item Version Control
1427 Version control systems keep track of multiple versions of a source file.
1428 They provide a more powerful alternative to keeping backup files (q.v.).
1429 @xref{Version Control}.
1430
1431 @item Visiting
1432 Visiting a file means loading its contents into a buffer (q.v.@:)
1433 where they can be edited. @xref{Visiting}.
1434
1435 @item Whitespace
1436 Whitespace is any run of consecutive formatting characters (space,
1437 tab, newline, and backspace).
1438
1439 @item Widening
1440 Widening is removing any restriction (q.v.@:) on the current buffer;
1441 it is the opposite of narrowing (q.v.). @xref{Narrowing}.
1442
1443 @item Window
1444 Emacs divides a frame (q.v.@:) into one or more windows, each of which
1445 can display the contents of one buffer (q.v.@:) at any time.
1446 @xref{Screen}, for basic information on how Emacs uses the screen.
1447 @xref{Windows}, for commands to control the use of windows. Some
1448 other editors use the term ``window'' for what we call a `frame'
1449 (q.v.@:) in Emacs.
1450
1451 @item Window System
1452 A window system is software that operates on a graphical display
1453 (q.v.), to subdivide the screen so that multiple applications can
1454 have their] own windows at the same time. All modern operating systems
1455 include a window system.
1456
1457 @item Word Abbrev
1458 @xref{Glossary---Abbrev}.
1459
1460 @item Word Search
1461 Word search is searching for a sequence of words, considering the
1462 punctuation between them as insignificant. @xref{Word Search}.
1463
1464 @anchor{Glossary---Yanking}
1465 @item Yanking
1466 Yanking means reinserting text previously killed (q.v.). It can be
1467 used to undo a mistaken kill, or for copying or moving text. Some
1468 other systems call this ``pasting''. @xref{Yanking}.
1469 @end table