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