Fix up comments.
[bpt/emacs.git] / etc / NEWS
CommitLineData
29b7722a 1GNU Emacs NEWS -- history of user-visible changes.
5b87ad55 2
dcb8ac09 3Copyright (C) 2007, 2008 Free Software Foundation, Inc.
5b87ad55 4See the end of the file for license conditions.
a933dad1 5
3f7194ed 6Please send Emacs bug reports to emacs-pretest-bug@gnu.org.
9a21d88b
KS
7If possible, use M-x report-emacs-bug.
8
0bfd685e 9This file is about changes in Emacs version 23.
9a21d88b 10
0bfd685e
GM
11See files NEWS.22, NEWS.21, NEWS.20, NEWS.19, NEWS.18, and NEWS.1-17
12for changes in older Emacs versions.
9a21d88b
KS
13
14You can narrow news to a specific version by calling `view-emacs-news'
15with a prefix argument or by typing C-u C-h C-n.
3f7194ed
GM
16
17Temporary note:
18 +++ indicates that the appropriate manual has already been updated.
19 --- means no change in the manuals is called for.
20When you add a new item, please add it without either +++ or ---
21so we will look at it and add it to the manual.
22
05197f40 23\f
9c576ea0
KS
24* About external Lisp packages
25
9c576ea0 26\f
0bfd685e 27* Installation Changes in Emacs 23.1
c58dccad 28
3f7194ed
GM
29** The default X toolkit is now Gtk+, rather than Lucid.
30
79475ffb
GM
31** Fonts are handled by new code capable of dealing with multiple font
32backends. This requires the freetype and fontconfig libraries, and
33supports local fonts (fonts installed on the machine where Emacs is
34running). Additionally, the Xft library can be used for antialiasing
e4434ecc 35support, the otf library for complex text layout by OpenType fonts,
0408f858
CY
36and the m17n library for text shaping. Emacs now accepts font names
37supplied in the fontconfig format (e.g. "monospace-12:bold") and GTK
38format (e.g. "Monospace Bold 12").
2b7a2553 39
1abe3a1e
DN
40** The new configuration option "--with-dbus" enables D-Bus language
41bindings for Emacs.
42
15f02f65 43** The Mac Carbon port is no longer supported.
79475ffb 44Instead, use... [FIXME what?]
15f02f65 45
9d3cc9b2
GM
46** configure now checks for libgif before libungif when searching for
47a GIF library.
b5ac89f8 48
36e625ec
GM
49** Support for systems without alloca has been removed.
50
07e5c0b0
DN
51** Support for Sun windows has been removed.
52
bb9f7948
EZ
53** Support for many obsolete platforms has been removed.
54See the list at the end of etc/MACHINES for details.
55
48a8be40
GM
56** The `emacstool' utility has been removed.
57
a46ee55c
GM
58** The configure options `--with-gcc', `--without-gcc' have been removed.
59Configure will use gcc by default. Set the CC environment variable if
60you need control over which C compiler is used.
61
0caa490b 62** The configure option `--with-gtk' has been removed. Gtk is now the
a46ee55c 63default toolkit, but you can use --with-x-toolkit=gtk if necessary.
4e5cdb4f 64\f
6dadd99f
NR
65* Changes in Emacs 23.1
66
a56fc145
SM
67** `underline-minimum-offset' keeps the underline away from the baseline.
68
fdeb777a
SM
69** Info displays breadcrumbs in the header of the page.
70See Info-breadcrumbs-depth to control it.
71
07d99e75
GM
72** Emacs now supports serial port access on GNU/Linux, Unix, and
73Windows. `serial-term' starts an interactive terminal,
74`make-serial-process' and `serial-process-configure' provide a Lisp
75interface. The serial port can be configured at runtime with the
76mode-line mouse menu.
77
1d69bd9b
SM
78** Apropos
79*** `apropos-library' describes the elements defined in a given library.
80*** Set `apropos-compact-layout' is you want a more compact (but wider) layout.
2e3d43ac 81
c876b227 82** scroll-preserve-screen-position also preserves the column position.
34200787 83** Completion.
14c24780
SM
84*** `completion-styles' can be customized to choose your favorite completion.
85*** The default completion styles include a form of partial-completion.
86*** The new command `minibuffer-force-complete chooses one of the possible
87completions, rather than stopping at the common prefix.
34200787 88*** `completion-auto-help' can be set to `lazy' to list the completions only
ba5ff07b
SM
89if you repeat the completion. This was already supported in
90`partial-completion-mode'.
91
780d7bb9 92** Emacs now supports using both X displays and ttys in one session.
1abe3a1e
DN
93Start the server (M-x server-start). Then `emacsclient -t' creates a
94tty frame connected to the running emacs server. You can also use any
95number of different ttys. `emacsclient -c' creates a new X11 frame on
96the current $DISPLAY or a tty frame if $DISPLAY is not set.
780d7bb9
RS
97
98You can test for the presence of this feature in your Lisp code by
99testing for the `multi-tty' feature.
100
0caa490b 101** The Emacs character set is now a superset of Unicode.
d82c3d44
GM
102(It has about four times the code space, which should be plenty).
103
104The internal encoding used for buffers and strings is now
105Unicode-based and called `utf-8-emacs'. utf-8-emacs is backwards
106compatible with the UTF-8 encoding of Unicode. The `emacs-mule'
107coding system can still read and write data in the old internal encoding.
108
109Since the internal encoding is also used by default for byte-compiled
110files -- i.e. the normal coding system for byte-compiled Lisp files is
111now utf-8-Emacs -- Lisp containing non-ASCII characters which is
112compiled by Emacs 23 can't be read by earlier versions of Emacs. Files
113compiled by Emacs 20, 21, or 22 are loaded correctly as emacs-mule
114(whether or not they contain multibyte characters), which makes loading
115them somewhat slower than Emacs 23-compiled files. Thus it may be worth
116recompiling existing .elc files which don't need to be shared with older
117Emacsen.
118
d82c3d44
GM
119** There are assorted new coding systems/aliases -- see M-x list-coding-systems.
120
121** There is a new charset implementation with many new charsets.
122See M-x list-character-sets. New charsets can be defined conveniently
123as tables of unicodes.
124
125The dimension of a charset is now 1, 2, 3, or 4, and the size of each
126dimension is no longer limited to 94 or 96.
127
128A dynamic charset priority list is used to infer the charset of
129characters for display.
130
19095422
KH
131** There are new Chinese-GBK, Chinese-GB18030, Khmer, Bengali,
132Punjabi, Gujarati, Oriya, Telugu, Sinhala, and TaiViet language
d82c3d44
GM
133environments.
134
7b476dbe
JD
135** Emacs now supports the XEmbed specification.
136You can embed Emacs in another application on X11. The new command line option
137--parent-id is used to pass the parent window id to Emacs. See
138http://standards.freedesktop.org/xembed-spec/xembed-spec-latest.html
139for details about XEmbed.
140
55f9bad5 141** Controlling the frame opacity
ed25242f
GM
142The opacity of a frame can now be controlled by setting
143the `alpha' frame parameter, on a compositing window manager
144(e.g. Compiz, Beryl and Compiz Fusion) for the X Window System.
55f9bad5
GM
145
146The alpha parameter should be an integer between 0 (transparent) and
147100 (opaque) or a float number between 0.0 and 1.0. Optionally, the
148opacity can be set by a cons cell; the first item controls the
149opacity of an active frame, and the second item controls that of
150non-active frames.
151
152 (set-frame-parameter nil 'alpha 80)
153 (set-frame-parameter nil 'alpha 0.8)
154 (set-frame-parameter nil 'alpha '(100 70)) ; (<active> [<inactive>])
155 (set-frame-parameter nil 'alpha nil)
156
157Note that the threshold opacity of a frame is defined by the variable
158`frame-alpha-lower-limit' (default 20), so that the user may not lose
159control of the frame.
fec8ef06 160
58e707fe
GM
161** Emacs comes with a new set of default icons.
162Various resolutions are available as etc/images/icons/hicolor/*/apps/emacs.png.
163The Emacs 22 icon is available as `emacs22.png' in the same location.
251ad2de 164
f664fee9
MC
165** Built-in functions (subr) can now have an interactive specification
166that is not a prompt string. If the `intspec' parameter of a `DEFUN'
167starts with a `(', the string is evaluated as a Lisp form.
168
169** set-file-modes is now interactive and can take the mode value in
170symbolic notation thanks to auxiliary functions.
171
e3a35600
MR
172** Changes affecting display-buffer
173*** New value nil for split-height-threshold inhibits vertical splitting
174unless there's no other window.
175*** New option split-width-threshold controls horizontal splitting.
176*** A window can be split horizontally even when it's not full-width.
177*** New option split-window-preferred-function can be set to a function
178to override the default splitting mechanism of display-buffer.
90ab5c62 179
0408f858
CY
180** Menu Bar changes
181
182*** The Options menu contains a new entry to turn on Longlines mode.
183
184*** In the Options menu, the "Set Default Font" item applies the
185selected font to the `default' face on all frames, not just the
186current frame. This font setting will be saved if the "Save Options"
187item is used. Furthermore, if Emacs is compiled with both GTK and
188Fontconfig support, the "Set Default Font" item uses the GTK font
189selection dialog instead of an Emacs pop-up menu.
190
24cdde13
GM
191** Emacsclient has been extended to support opening a new terminal
192frame. Its behavior has been changed to open a new Emacs frame by
193default. Use the -c option to get the old behavior of opening files in
194the currently selected Emacs frame.
195
c0dadae9
MC
196** The refcards are now shipped as PDF files.
197
795a2a94
GM
198** Emacs now supports the SVG image format through librsvg2.
199
75f6af19 200** If you set find-file-confirm-nonexistent-file to t, then C-x C-f
0a963185
SM
201requires confirmation before opening a non-existent file.
202
6dadd99f
NR
203** If the gpm mouse server is running and t-mouse-mode enabled, Emacs uses a
204Unix socket in a GNU/Linux console to talk to server, rather than faking events
205using the client program mev. This C level approach provides mouse
206highlighting, and help echoing in the minibuffer.
207
3ae459e5
CY
208** Recentering changes
209
210*** The new variable next-error-recenter specifies how next-error should
c2e8590b
TTN
211recenter the visited source file. Its value can be a number (for example,
2120 for top line, -1 for bottom line), or nil for no recentering.
213
3ae459e5 214*** New command recenter-top-bottom moves the current line to window
1abe3a1e
DN
215center, top and bottom on successive invokations.
216
3ae459e5 217*** C-l is bound to the new command recenter-top-bottom, rather than recenter.
eb28688c 218
d87b5ced 219** The mode-line displays a `@' if the default-directory for the current buffer
1f2e1c75 220is on a remote machine, or a hyphen otherwise.
6c5d503f 221
c9447ae1
GM
222** The mode-line displays a mode menu when mouse-1 is clicked on a minor mode,
223in the same way as it already did for major modes.
224
de3054d5 225** The new command balance-windows-area balances windows both vertically
62e3c31f 226and horizontally.
d466e9fc
SM
227
228** The new command close-display-connection can be used to close a connection
229to a remote display, e.g. because the display is about to become unreachable.
6c5d503f
MA
230
231** The command shell prompts for the default directory, when it is
232called with a prefix, and the default directory is a remote file name.
de3054d5 233This is because some file name handlers (like ange-ftp) are not able to
6c5d503f 234run processes remotely.
aff2ba04
RS
235
236** The new command `display-time-world' starts an updating time display
237using several time zones, in a buffer.
c4c9b6f9 238
1b21ee06
MO
239** Directory-local variables are now found in .dir-settings.el. See
240also `set-directory-project' and `define-project-bindings'.
241
5c4a15b3
GM
242** The new function `format-seconds' converts a number of seconds into a
243readable string of days, hours, etc.
244
9f871ce2
GM
245** The new variables `before-init-time' and `after-init-time' record the
246value of `current-time' before and after Emacs loads the init files.
c4c9b6f9
GM
247
248** The new function `emacs-uptime' returns the uptime of an Emacs instance.
249
b3cf10d7
JL
250** The new function `emacs-init-time' returns the duration of the
251Emacs initialization.
252
d82c3d44
GM
253** The minor modes unify-8859-on-encoding-mode, unify-8859-on-decoding-mode
254are obsolete.
255
307f3501
GM
256** The new commands `pp-macroexpand-expression' and `pp-macroexpand-last-sexp'
257pretty-print macro expansions.
258
6dadd99f 259\f
0bfd685e 260* Startup Changes in Emacs 23.1
21f7b9d8 261
3063e326
JL
262** The option `inhibit-startup-screen' (with aliases to old names
263`inhibit-splash-screen' and `inhibit-startup-message') doesn't inhibit
264display of the initial message in the *scratch* buffer. If you don't
265want to display the initial message in the *scratch* buffer at startup,
266you can set the option `initial-scratch-message' to nil.
267
56e1896b
JL
268** New user option `initial-buffer-choice' specifies what to display
269after starting Emacs: startup screen, *scratch* buffer, visiting a
270file or directory.
271
aa5310e4
DK
272** New alias `argv' for `command-line-args-left'
273This is a convenience alias, so that one can write `(pop argv)'
274inside of --eval command line arguments in order to access
275following arguments.
f8fd7ed3
GM
276
277** The abbrev file is no longer read at startup in batch mode.
c44da964 278\f
0bfd685e 279* Incompatible Editing Changes in Emacs 23.1
b58cb59f 280
117907d4
JL
281+++
282** In Dired-x, all command guesses for ! are now added to the default
283list accessible by M-n instead of pushing all guesses temporarily into
284the history list.
285
e405fa5f 286** The following input methods were removed in Emacs 22.2, but this was
9a930d75 287not advertised: danish-alt-postfix, esperanto-alt-postfix,
e405fa5f
RS
288finnish-alt-postfix, german-alt-postfix, icelandic-alt-postfix,
289norwegian-alt-postfix, scandinavian-alt-postfix, spanish-alt-postfix,
290and swedish-alt-postfix. Use the versions without "alt-", which are
291identical.
0b0914ae 292
406c0f12 293\f
0bfd685e 294* Editing Changes in Emacs 23.1
406c0f12 295
3ae459e5
CY
296** Mark changes
297
59b5d020 298+++
3ae459e5
CY
299*** Transient Mark mode is now on by default.
300
301+++
302*** mark-even-if-inactive now defaults to t
303
304+++
305*** When Transient Mark mode is on, C-SPC C-SPC pushes a mark without activating it.
59b5d020 306
1ac03a31 307+++
3ae459e5
CY
308*** When Transient Mark mode is on, M-q now fills the region if the
309region is active. Otherwise, it fills the current paragraph.
1ac03a31 310
ecde850a 311+++
3ae459e5
CY
312*** When Transient Mark mode is on, M-$ now checks spelling of the
313region if the region is active. Otherwise, it checks spelling of the
dc868f13
JL
314word at point.
315
3ae459e5
CY
316*** When Transient Mark mode is on, TAB now indents the region if the
317region is active.
6dd697d9 318
3ae459e5
CY
319*** `use-empty-active-region' controls whether an empty active region
320in Transient Mark mode should make commands operate on that empty
321region.
322
323** Temporarily active regions
324
325*** The new variable shift-select-mode, non-nil by default, controls
326shift-selection. When Shift Select mode is on, shift-translated
327motion keys (e.g. S-left and S-down) activate and extend a temporary
328region, similar to mouse-selection.
329
330*** Temporarily active regions, created using shift-selection or
331mouse-selection, are not necessarily deactivated in the next command.
332They are only deactivated after point motion commands that are not
333shift-translated, or after commands that would ordinarily deactivate
334the mark in Transient Mark mode (e.g., any command that modifies the
335buffer).
336
337+++
338** C-M-% now shows replacement as it would look in the buffer, with
339`\N' and `\&' substituted according to the match. Old behavior can be
340restored by customizing `query-replace-show-replacement'.
d03b9b31 341
24cdde13
GM
342** C-z now invokes `suspend-frame', C-x C-c now invokes
343`save-buffers-kill-terminal'.
344
a151f82c
SS
345** New command kill-matching-buffers kills buffers whose name matches a regexp.
346
63571b5a
RS
347** You can disable kill ring commands from accessing the primary selection
348by setting `x-select-enable-primary' to nil.
349
350** If `select-active-regions' is t, setting the mark automatically
351makes the new region into the primary selection (for interaction with
352other window applications). If you enable this, you might want to bind
353`mouse-yank-primary' to Mouse-2.
539f5bda 354
4496b02b
RS
355** If `yank-pop-change-selection' is t, rotating the kill ring
356also updates the selection or clipboard to the current yank,
357just as M-w would do so with the text it copies to the kill ring.
358
505d8756 359** Minibuffer changes
297b8ccd 360
23d2b215
JL
361*** Minibuffer input of shell commands now comes with completion.
362
363*** Operations like C-x b and C-x C-f which use switch-to-buffer do not fail
364any more when used in a minibuffer or a dedicated window. Instead, they
365fallback on using pop-to-buffer which will use some other window.
366
d47a29c1
JL
367*** When M-n in the minibuffer reaches the end of the list of defaults,
368it adds the completion list to the end, so next M-n continues putting
369completion items to the minibuffer. The same principle applies to
370incremental search commands as well: C-s or C-M-s starts searching
371the default values and after the end of defaults they continue
372searching minibuffer completion items.
f3ed2b83 373
dc2f6c05
JL
374*** In C-x d, if you type M-n you get the visited file name of the
375current buffer.
376
a300181f
JL
377*** A list of default commands extracted from mailcap according to
378file extensions are available in the list of default values
379accessible by M-n in the minibuffer that reads a shell command
380for M-! (shell-command) and fills a list of commands for the current
381file, and in Dired for ! (dired-do-shell-command) that fills a list of
382commands for the intersection of file types of marked Dired files.
117907d4
JL
383
384*** A list of regexp default values is available via M-n for `occur',
385`keep-lines', `flush-lines' and `how-many'. This list includes the active
386region in transient-mark-mode, the word under the cursor, the last isearch
387regexp, the last isearch string and the last replacement regexp.
388
297b8ccd
JL
389*** isearch started in the minibuffer searches in the minibuffer history.
390Reverse isearch commands (C-r, C-M-r) search in previous minibuffer
391history elements, and forward isearch commands (C-s, C-M-s) search in
392next history elements. When the reverse search reaches the first history
393element, it wraps to the last history element, and the forward search
394wraps to the first history element. When the search is terminated, the
395history element containing the search string becomes the current.
396
505d8756
GM
397** New faces
398
399*** `mode-line-emphasis' is used to highlight certain mode-line information;
400for example while waiting for a VC command to finish.
401
505d8756
GM
402** Face changes
403
404*** The new function `face-all-attributes' returns an alist describing
405all the basic attributes of a given face.
406
d2d160bd
CY
407*** S-down-mouse-1 now pops up a menu for changing the default font
408and text size of the default face in the current buffer. The face is
409changed via face remapping (see below).
410
f20186fd
GM
411*** FIXME face-remap
412
0bfd685e
GM
413\f
414* New Modes and Packages in Emacs 23.1
0091c67e 415
c160dc76
SM
416** rst-mode for ReSTructured-Text files.
417
2e282009 418** FIXME add details of new packages imported from lisp/gnus.
143cecdb 419[Maybe some information from doc/misc/gnus-coding.texi can be reused]
2e282009 420
1816bda7
MC
421** The package doc-view.el has been added. It supports viewing of PDF,
422PostScript and DVI documents inside an Emacs buffer by converting the
423document to a set of PNG images first. One can also search for a
424regular expression in the document. The commentary of the file explains
425its usage.
426
c06c430f
MO
427** The nXML package has been added. It is a new mode for editing XML
428documents. nXML mode allows a schema to be associated with the XML
429document being edited. nXML mode uses Relax NG as its schema
430language. The schema is used to provide two key features:
431
432*** Continuous validation. nXML validates as you type, highlighting
433any invalid parts of your document.
434
435*** Completion. nXML can assist you in entering an element name,
436attribute name or data value by using information about what is
437allowed by the schema in that context.
a2e0b5dd 438
0329d8a3
GM
439** A new game called `bubbles' has been added. This is a version of
440the "Same Game" with configurable difficulty level.
a0818148 441
dcd6e8d7 442** minibuffer-indicate-depth-mode shows the minibuffer depth in the prompt.
3f7194ed 443
15f3eb73
MO
444** Remember Mode (remember.el) is now included with Emacs. It is a
445mode for quickly jotting down things to remember. Included with
446remember.el is a backend that can save notes to a Diary file. Please
447consult the Remember Manual for usage details.
448
9264ee6a
MA
449** D-Bus language bindings for Elisp are provided by the package
450dbus.el and by extensions to the C modules of Emacs. D-Bus is an
451inter-process communication mechanism for applications residing on the
452same host, based on messages. See the manual for further details.
c154c0be 453
8f377a4b 454** zeroconf.el offers service discovery and service publishing
b2ca37cd
MA
455interfaces according to the zeroconf specification. It communicates
456with Avahi, a zeroconf implementation, via D-Bus messages on systems
457which have installed this software.
8f377a4b 458
c6588a85
MO
459** EasyPG is now part of the Emacs distribution. It is an all-in-one
460GnuPG interface which includes GnuPG keyring browser, cryptographic
461operations on regions and files, and automatic encryption of *.gpg
462files. See the EasyPG Assistant User's Manual for further details.
e11910e2 463
c06c430f
MO
464** json.el is now included with Emacs. It is a library for parsing
465and generating JSON (JavaScript Object Notation). JSON is a
466lightweight data-interchange format.
467
e11910e2
GM
468** Auto Composition Mode is a minor mode that composes characters
469automatically when they are displayed. It is globally on by default.
470It uses `auto-composition-function' (default `auto-compose-chars').
471
85efdcf3
JB
472** The package linum.el is now included with Emacs. It it a new minor
473mode to display line numbers for the current buffer.
474
f6b26818
RW
475** proced.el has been added. It operates on processes like dired.
476Proced makes an Emacs buffer containing a listing of the current processes
477(using ps(1)). You can use the normal Emacs commands to move around in
478this buffer, and special Proced commands to operate on the processes listed.
479
7ef39c6e
GM
480** bug-reference.el provides clickable links to bug reports.
481
0bfd685e
GM
482\f
483* Changes in Specialized Modes and Packages in Emacs 23.1
61d244ca 484
c2d0b538
SM
485** Icomplete: `icomplete-prospects-height' supercedes `icomplete-prospects-length'.
486
c934813f
GM
487** A new `whitespace' package has been installed, and the pre-existing one
488renamed to `old-whitespace'.
489[FIXME someone explain why this is good, if it is...]
490
e047f448
SM
491** abbrev was rewritten in Elisp and extended with more flexibility.
492*** New functions: abbrev-get, abbrev-put, abbrev-table-get, abbrev-table-put,
a3709a8c 493 abbrev-table-p, abbrev-insert, abbrev-table-menu.
e047f448
SM
494*** Special hook `abbrev-expand-functions' obsoletes `pre-abbrev-expand-hook'.
495*** `make-abbrev-table', `define-abbrev', `define-abbrev-table' all take
496 extra arguments for arbitrary properties.
497*** New variable `abbrev-minor-mode-table-alist'.
498*** `local-abbrev-table' can hold a list of abbrev-tables.
499*** Abbrevs have now the following special properties:
79415279 500 `:count', `:system', `:enable-function', `:case-fixed'.
e047f448
SM
501*** Abbrev-tables have now the following special properties:
502 `:parents', `:case-fixed', `:enable-function', `:regexp',
503 `abbrev-table-modiff'.
504
505d8756 505** Help mode
0253fffa
MR
506*** New macro `with-help-window' should set up help windows better
507than `with-output-to-temp-buffer' with `print-help-return-message'.
508*** New option `help-window-select' permits to customize whether help
509window shall be automatically selected when invoking help.
510*** New variable `help-window-point-marker' permits to specify new
b0d2d4e8 511position of point in help window (for example in `view-lossage').
0253fffa
MR
512
513** view-remove-frame-by-deleting is now by default t
b0d2d4e8 514since users found iconification of view-mode frames distracting.
0253fffa 515
bafbec39
JL
516** Isearch mode
517
518*** New command `isearch-occur' bound to `M-s o' in isearch mode
519runs `occur' with the current search string.
520
521*** isearch can now search through multiple ChangeLog files.
12bbb989
JL
522When running isearch in a ChangeLog file, if the search fails,
523then another C-s tries searching the previous ChangeLog,
524if there is one (e.g. go from ChangeLog to ChangeLog.12).
525
9097e8af
RS
526This is enabled if isearch-buffers-multi is non-nil.
527
4c24d241
GM
528*** The part of an isearch that failed to match is highlighted in `isearch-fail'
529face.
530
320bc739
JL
531*** `C-h C-h' in isearch mode displays isearch-specific Help screen,
532`C-h b' displays all isearch key bindings, `C-h k' displays the full
533documentation of the given isearch key sequence, `C-h m' displays
534documentation of isearch mode. All the rest Help commands exit isearch mode
535and execute their global definitions.
536
e6a01e4e 537** archive-mode has basic support to browse Rar archives.
c3bb6fdb 538
24cdde13
GM
539** talk.el has been extended for multiple tty support.
540
76be286d
DN
541** Compile and grep modes
542
543*** The mode-line entry for the *compilation* and *grep* buffer is color coded.
544It has different colors for to show that: (a) the command is still
545running, (b) successful completion, (c) error.
546
547*** compilation-auto-jump-to-first-error tells `compile' to jump to
813fb3fe
SM
548the first error encountered during compilations.
549
b68769f2 550** In the `copyright' package, you can specify your copyright holders' names.
b649d2e4
SM
551Only copyright lines with holders matching copyright-names-regexp will be
552considered for update.
553
59ba20a2
GM
554** The `copyright' package looks for copyright at the end of the buffer
555if `copyright-at-end-flag' is non-nil (change-log-mode sets this).
556
e7ce8577
GM
557** eldoc highlights the function argument under point
558with the face `eldoc-highlight-function-argument'.
559
ef6d86b5
MR
560** hide-ifdef-mode permits to shadow ifdef-blocks instead of hiding them.
561See option `hide-ifdef-shadow' and function `hide-ifdef-toggle-shadowing'.
562
b68769f2 563+++
8d5cc579 564** defcustom accepts new keyword arguments, `:safe' and `:risky', which
b68769f2
GM
565set a variable's `safe-local-variable' and `risky-local-variable' property.
566
505d8756 567** Etags changes
b0d2d4e8
FP
568*** The --members option is now the default.
569
570Use --no-members if you want the old default behaviour of not tagging
571struct members in C, members variables in C++ and variables in PHP.
572
56dada42 573** VC
76be286d 574
082c5622 575*** VC now supports applying VC operations to a set of files at a time.
4a11b6b5 576This enables VC to work much more effectively with changeset-oriented
494da8c4
DN
577version-control systems such as Subversion, GNU Arch, Mercurial, Git
578and Bzr. VC will now pass a multiple-file commit to these systems as
579a single changeset.
4a11b6b5 580
e1aec6fb 581*** vc-dir is a new command that displays file names and their VC
15947a44 582status. It allows to apply various VC operations to a file or a
a4586856
DN
583set of files.
584
585*** Clicking on the VC mode-line entry now pops the VC menu.
586
587*** The VC mode-line entry now has a tooltip that explains the VC file status.
588
38b627ce
DN
589*** In VC Annotate mode, for VC systems that support changesets, you can
590see the diff for the whole changeset (not only for the current file)
591by using the vc-annotate-show-changeset-diff-revision-at-line function.
592
b58a65fa
TTN
593*** In VC Annotate mode, you can type V to toggle the annotation visibility.
594
f3ff0fe9
DN
595*** In VC Annotate mode, you can type f to show the file revision on
596the current line.
597
117d3cc5
DN
598*** vc-git supports the "git grep" command.
599
76be286d
DN
600*** Asynchronous VC commands display [Waiting...] in the mode-line
601of the corresponding buffer as long as the asynchronous process is
602active.
603
494da8c4
DN
604*** Log entries can be modified using the key "e" in log-view.
605For now only CVS, RCS, SCCS and SVN support this functionality.
606This is done by the `modify-change-comment' backend function.
b592c357 607
6653c6b7
DN
608*** In log-view-mode, for VC systems that support changesets, you can
609see the diff for the whole changeset (not only for the current file)
610by typing the D key or using the "Changeset Diff" menu entry.
611
db86064f
ER
612*** VC Support for Meta-CVS has been removed for lack of maintainer able
613to update it to the new VC.
614
15947a44
DN
615** smerge-refine highlights word-level details of changes in conflict.
616It's used automatically as you move through conflicts, see smerge-auto-refine.
617
618** Diff mode
619
620*** diff-refine-hunk highlights word-level details of changes in a diff hunk.
621It's used automatically as you move through hunks, see
622diff-auto-refine. It is bound to `C-c C-b'.
623
624*** diff-add-change-log-entries-other-window iterates through the diff
625buffer and tries to create ChangeLog entries for each change.
626It is bound to `C-x 4 A'.
627
93a142e1
DN
628** log-edit now has a command bound to C-c C-d to show the diff for
629the files involved.
630
15947a44
DN
631** In Change Log mode, the new function `change-log-find-file', bound to
632C-c C-f, finds the file associated with the current log entry.
633
5d503af9
SM
634** sgml-electric-tag-pair-mode lets you simultaneously edit matched tag pairs.
635
332de56f
GM
636** The appearance of superscript and subscript in TeX is more customizable.
637See the documentation of the variables: tex-fontify-script,
638tex-font-script-display, tex-suscript-height-ratio, and
639tex-suscript-height-minimum.
640
505d8756 641** BibTeX mode
2793c9bb 642
0caa490b 643*** New command `bibtex-initialize' (re)initializes BibTeX buffers.
c5578d5f 644
2793c9bb
RW
645*** New `bibtex-entry-format' options `whitespace', `braces', and
646`string', disabled by default.
647
648*** New variable `bibtex-cite-matcher-alist' contains rules to
0f3cd6b2 649identify cited keys in BibTeX entries, used by `bibtex-find-crossref'.
2793c9bb 650
c5578d5f 651*** Command `bibtex-url' allows multiple URLs per entry.
2793c9bb 652
cc213f24
MA
653+++
654** Tramp
655
656*** New connection methods.
657The new methods "plinkx", "plink2", "psftp", "sftp" and "fish" have
658been introduced. There are also new so-called gateway methods
659"tunnel" and "socks".
660
661*** Multihop syntax has been removed.
662The pseudo-method "multi" has been removed. Instead of, multi hops
663can be specified by the new variable `tramp-default-proxies-alist'.
664
665*** More default settings.
666Default values can be set via the variables `tramp-default-user',
667`tramp-default-user-alist' and `tramp-default-host'.
668
669*** Connection information is cached.
670In order to reduce connection setup, information about used
671connections are kept persistent in a file. The name of this file is
672defined in the variable `tramp-persistency-file-name'.
673
674*** Control of remote processes.
675Running processes on a remote host can be controlled by settings in
676`tramp-remote-path' and `tramp-remote-process-environment'.
677
678*** Success of remote copy is checked.
679When the variable `file-precious-flag' is set, the success of a remote
680file copy is checked via the file's checksum.
681
7cba69f2
MA
682*** Passwords can be read from an authentification file.
683Tramp uses the package `auth-source' to read passwords from a file, if
684necessary.
685
dc7f8d57
GM
686** Calendar and diary
687
571388b0 688+++
dc7f8d57
GM
689*** There is a new date style, `iso', essentially year/month/day.
690The variable `european-calendar-style' is obsolete - use `calendar-date-style'.
691Similarly, the commands `american-calendar' and `european-calendar'
692should be replaced by `calendar-set-date-style'.
693
36c0514c 694+++
eee6134c
GM
695*** The calendar namespace has been rationalized.
696All functions and variables now begin with a `calendar-', `diary-', or
697`holiday-' prefix. The various calendar systems have secondary
698prefixes, eg `calendar-french-'. The old names you are likely to use
699directly still exist, for the time being, as aliases, but please start
700using the new names.
701
95d8772f
GM
702*** The function `holiday-chinese' computes holidays on the Chinese calendar.
703It has been used to add items to the list `holiday-oriental-holidays'.
704
705*** `diary-remind' accepts a negative number -DAYS as a shorthand for
706the list (1 2 ... DAYS).
707
d15f7b68
GM
708** Miscellaneous programming mode changes
709
da26ea8d
GM
710*** The file etc/emacs.py now supports both Python 2 and 3, meaning
711that either version can be used as inferior Python by python.el.
c3f01f42 712
4c24d241
GM
713*** Python mode now has `pdbtrack' functionality. When using pdb to
714debug a Python program, pdbtrack notices the pdb prompt and displays
715the source file and line that the program is stopped at, much the same
716way as gud-mode does for debugging C programs with gdb.
717
d15f7b68
GM
718*** The variable `fortran-line-length' can change the fixed-form line-length.
719
a9f480e8
GM
720*** In Fortran mode, M-; is now bound to the standard comment-dwim,
721rather than fortran-indent-comment.
722
b68769f2
GM
723+++
724*** (The increasingly misnamed) F90 mode supports Fortran 2003 syntax.
2fb6c6be 725
d5d381e2
NR
726*** The function `gdb' only works with the graphical interface now.
727Use `gud-gdb' if you want the (old) text command mode.
728
cf944fa4
RS
729** Gnus package
730
731*** The Gnus package has been updated
732
143cecdb
RS
733*** In Emacs 23, Gnus uses Emacs' new internal coding system `utf-8-emacs' for
734saving articles drafts and ~/.newsrc.eld. These file may not be read
735correctly in Emacs 22 and below. If you want to Gnus across different Emacs
736versions, you may set `mm-auto-save-coding-system' to `emacs-mule'.
737
cf944fa4
RS
738*** There are many news features, bug fixes and improvements.
739
740See the file GNUS-NEWS or the node "No Gnus" in the Gnus manual for details.
741
d15f7b68
GM
742** Miscellaneous
743
7ef39c6e
GM
744*** goto-address.el provides two new minor modes, goto-address-mode and
745goto-address-prog-mode, which buttonize URLS and email addresses.
746
d15f7b68 747*** comint-mode uses `start-file-process' now (see Lisp Changes).
cc213f24
MA
748If `default-directory' is a remote file name, subprocesses are started
749on the corresponding remote system.
750
d15f7b68 751*** C-x C-q in dired-mode now runs the command wdired-change-to-wdired-mode,
40aa8257
JL
752and C-x C-q in wdired-mode exits it with asking a question about
753saving changes.
d15f7b68 754
4596901f
GM
755*** The new command `eshell/info' runs info in an eshell buffer.
756
1752e205
GM
757*** The pcmpl-unix package supports hostname completion for ssh and scp.
758
3cf86f00
GM
759*** WoMan tries to add locale-specific manual page directories to the
760search path. This can be disabled by setting `woman-locale' to nil.
761
4d1e89e3
GM
762*** The new variable `ffap-rfc-directories' specifies a list of local
763directories in which `ffap-rfc' will first search for RFCs.
764
d2c98acc 765*** net-utils has an `iwconfig' command, similar to the existing `ifconfig'.
b7bfcc8a 766It is used to configure wireless interfaces.
d2c98acc 767
0bfd685e
GM
768\f
769* Changes in Emacs 23.1 on non-free operating systems
8ab314f9 770
203553fd
JPW
771** Case is now considered significant in completion on MS-Windows.
772The default value of `completion-ignore-case' is now nil on
773MS-Windows, the same as it is for other operating systems. The
774variable doesn't apply to reading a file name -- in that case Emacs
775heeds `read-file-name-completion-ignore-case' instead.
776
672f99b6
JR
777---
778** IPv6 is supported on MS-Windows.
779Emacs now supports IPv6 on Windows XP and later, and earlier versions
2660a9da 780of Windows with third party IPv6 stacks installed. In Emacs 22, IPv6 was
672f99b6
JR
781supported on other platforms, but not on Windows due to using the winsock
7821.1 header file, even though Emacs was linking to the winsock 2 library.
783
0d22595d 784---
6e344060
JR
785** Busy cursor (hourglass) now displays on MS-Windows.
786When Emacs is busy, an hourglass mouse cursor is displayed on Windows.
2660a9da
JR
787In Emacs 22 only X supported the busy cursor.
788
789---
790** Battery status is available on MS-Windows
791Emacs can now display the battery status in the mode-line when enabled with
792display-battery-mode or from the Options menu. More verbose battery
793information is also available with the command `battery'. In Emacs 22
794battery status was supported only on GNU/Linux and Mac.
6e344060 795
3280c5c5
JR
796** More keys available on MS-Windows.
797Keys normally associated with IMEs, and some exotic keys not normally found
798on standard keyboards have been given names so they can be bound to functions
799inside Emacs. If there are keys on your keyboard that have not been exposed
800to Emacs in the past, try C-h k to see if they are available now.
801
802Emacs can now bind functions to the extra buttons for media player and
803browser control present on some keyboards. These buttons are disabled
804by default, since enabling them prevents their system-wide use when
805Emacs has focus. To enable them, set the variable
0caa490b 806w32-pass-multimedia-buttons to nil. See the doc string of that variable
3280c5c5 807for the list of extra keys that are available.
2660a9da 808
0bfd685e
GM
809\f
810* Incompatible Lisp Changes in Emacs 23.1
8ec65cd7 811
fd9440c5 812** Variables cannot be both buffer-local and frame-local any more.
a9b08254
JL
813** The argument DEFAULT of minibuffer input functions `read-from-minibuffer',
814`read-string', `completing-read', `read-buffer', `read-command',
815`read-variable' now can be a list of default values. The elements of
816this list are available for inserting to the minibuffer with `M-n'.
817If the user enters empty input, the first element is used as the default.
818
fc944cd4 819** `functionp' returns nil for special forms.
65f81a0b 820I.e., it only returns t for objects that can be passed to `funcall'.
fc944cd4 821
58555d81 822+++
4972c361
SM
823** The multibyteness of process filters is determined by the coding-system
824used for decoding. The functions `process-filter-multibyte-p' and
825`set-process-filter-multibyte' are obsolete.
826
d82c3d44
GM
827** The behavior of map-char-table has changed. It may call the
828specified function with a cons (FROM . TO) as a key if characters in
829that range have the same value.
830
831** The value of the function `charset-id' is now always 0.
832
833** The functions `register-char-codings' and `coding-system-spec'
834have been removed.
835
6a6b4d7d
KH
836** The cpXXX coding systems are now supported automatically. The
837functions cp-...-codepage, which you had to use in Emacs 22 to enable
838support for these coding systems, have been deleted.
d82c3d44 839
03605a28
MA
840+++
841** The function `dired-call-process' has been removed.
842
777ea444 843** The variable `byte-compile-warnings' can now be a list starting with `not',
0caa490b 844meaning to disable the specified warnings. The meaning of this list
777ea444 845may therefore be the reverse of what you expect (of course, this is
0caa490b 846only an issue if you make use of the new `not' syntax). Rather than
777ea444
GM
847checking/manipulating elements directly, use the new functions
848`byte-compile-warning-enabled-p', `byte-compile-disable-warning', and
849`byte-compile-enable-warning.'
850
69df9d6d
GM
851** `mode-name' is no longer guaranteed to be a string.
852Use `(format-mode-line mode-name)' to ensure a string value.
853
85a1f98d
GM
854** The following features have been removed. They were used for
855displaying various scripts with specific fonts, and are no longer
856needed now that OpenType font support is available:
857
858*** `devanagari' and `devan-util', and all associated devanagari-* and
859dev-* functions and variables (formerly used for Devanagari script).
860
861*** `kannada' and `knd-util', and all associated kannada-* and knd-*
862functions and variables (formerly used for Kannada script).
863
864*** `malayalam' and `mlm-util', and all associated malayalam-* and
865mlm-* functions and variables (formerly used for Malayalam script).
866
867*** `tamil' and `tml-util, and all associated tamil-* and tml-*
868functions and variables (formerly used for Tamil script).
6a6b4d7d 869
0bfd685e
GM
870\f
871* Lisp Changes in Emacs 23.1
8ab314f9 872
a1562258
SM
873** The variable window-point-insertion-type determines the insertion-type
874of the marker used for window-point.
875
8ba31f36
SM
876** minibuffer-local-must-match-filename-map is now named
877minibuffer-local-filename-must-match-map.
878
e2947429
SM
879** `all-completions' may now return the base size in the last cdr.
880Since this means the returned list is not properly nil-terminated, this
881is an incompatible change and is thus enabled by the new variable
882completion-all-completions-with-base-size.
883
884** New function `apply-partially' for curried application.
885
d87be1df
SM
886** `fill-forward-paragraph-function' specifies which function the filling
887code should use to find paragraph boundaries.
888
3ae459e5
CY
889** The variable `this-command-keys-shift-translated' is non-nil if the
890key sequence invoking the current command was found by
891shift-translation.
892
893** The new interactive spec code ^ says to first call
894handle-shift-selection if shift-select-mode is non-nil, before reading
895the command arguments.
896
8bf5c8a6
GM
897** When deleting a terminal, the special hook `delete-terminal-functions'
898is run.
58555d81 899
e5c4079c
SM
900** The `read-shell-command' function does what its name says, with completion.
901It uses the minibuffer-local-shell-command-map for that.
902
903** The `buffer-swap-text' function can swap the text between two buffers.
13cda5f9
SM
904This can be useful for modes such as tar-mode, archive-mode, RMAIL.
905
a2bc5bdd
SM
906** `clear-image-cache' can be told to flush only images of a specific file.
907
64663f06 908** clone-indirect-buffer now runs the clone-indirect-buffer-hook.
d82c3d44 909
50bfa18a 910** `beginning-of-defun-function' now takes one argument, the count
d82c3d44 911 given to `beginning-of-defun'.
50bfa18a 912
39d0bf74
RS
913** The variable `inhibit-changing-match-data', if non-nil, prevents the
914search and match primitives from changing the match data.
915
59b5d020
JL
916+++
917** New function `match-substitute-replacement' returns the result of
918`replace-match' without actually using it in the buffer.
919
426e6ba0
CY
920** The new variable `replace-search-function' determines the function
921to use for searching in query-replace and replace-string.
922
923** The new variable `replace-re-search-function' determines the
924function to use for searching in `query-replace-regexp',
925`replace-regexp', + `query-replace-regexp-eval', and
926`map-query-replace-regexp'.
927
2d105adf
RS
928** If a local hook function has a non-nil `permanent-local-hook'
929property, then `kill-all-local-variables' does not remove it from
930the local value of the hook variable. This means it remains
931even if you change major modes.
932
b9694062
JL
933+++
934** A list of default values can be specified for the DEFAULT argument of
935functions `read-from-minibuffer', `read-string', `read-command',
936`read-variable', `read-buffer', `completing-read'. Elements of this list
937are available for inserting into the minibuffer by typing `M-n'.
938For empty input these functions return the first element of this list.
939
66dc1ca2
RS
940** `custom-note-var-changed' tells Custom to treat the change in a certain
941variable as having been made within Custom.
942
ab6198b2
SM
943** `frame-inherited-parameters' lets new frames inherit parameters from
944the selected frame.
66dc1ca2 945
c60d543d 946** Commands should use `use-region-p' to test whether there is
d03b9b31
RS
947an active region that they should operate on.
948
c60d543d
RS
949** `region-active-p' returns non-nil when Transient Mark mode
950is enabled and there is an active region. This is NOT the best function
951to use to test whether a command should operate on the region instead
952of the usual behavior -- for that, use `use-region-p'.
953
3ae459e5
CY
954** If a command sets `transient-mark-mode' to (only . OLDVAL), that
955means to activate transient-mark-mode temporarily, until the next
956unshifted point motion command or mark deactivation. Afterwards,
957reset transient-mark-mode to the value OLDVAL. The values `only' and
958`identity', introduced in Emacs 22, are now deprecated.
959
4f4a84ec
SM
960** New keymap `input-decode-map' overrides like key-translation-map, but
961applies before function-key-map. Also it is terminal-local contrary to
962key-translation-map. Terminal-specific key-sequences are generally added to
963this map rather than to function-key-map now.
964
967b2682
GM
965** The new macro `declare-function' suppresses compiler warnings about
966undefined functions. The new `check-declare' package verifies that such
967statements are accurate (i.e. the functions are actually defined in
968the specified files).
969
8bf5c8a6
GM
970** `ignore-errors' is now a standard macro (does not require the CL package).
971
d9774611
RS
972** The new function `read-color' reads a color name using the minibuffer.
973
63571b5a
RS
974** `interprogram-paste-function' can now return one string or a list
975of strings. In the latter case, Emacs puts the second and following
976strings on the kill ring.
977
d82c3d44
GM
978** Character code, representation, and charset changes.
979
0caa490b 980The character code space is now 0x0..0x3FFFFF with no gap.
d82c3d44
GM
981Characters of code 0x0..0x10FFFF are Unicode characters of the same code points.
982Characters of code 0x3FFF80..0x3FFFFF are raw 8-bit bytes.
983
0caa490b 984Generic characters no longer exist.
d82c3d44
GM
985
986In buffer and string, characters are represented by UTF-8 byte
987sequence in a multibyte buffer/string.
988
989The concept of a charset has changed. A single character may belong to
990multiple charsets (e.g. a-grave, U+00E0, belongs to charsets unicode,
991iso-8859-1, iso-8859-3, etc).
992
993*** The new function `characterp' returns t if and only if the argument
db4f9d2a 994is a character. This replaces `char-valid-p', which is now obsolete.
d82c3d44
GM
995
996*** The new function `max-char' returns the maximum character code
997(currently it is #x3FFFFF).
998
999*** The functions `encode-char' and `decode-char' now accept any character sets.
1000
1001*** The function `define-charset' now accepts a completely different
1002form of arguments (old-style arguments still work).
1003
1004*** The new function `define-charset-alias' defines an alias of a charset.
1005
1006*** The value of the function `char-charset' depends on the current
1007priorities of charsets.
1008
1009*** The new function `charset-priority-list' returns the list of
1010charsets ordered by priority.
1011
1012*** The new function `set-charset-priority' sets priorities of charsets.
1013
d82c3d44
GM
1014*** The new function `unibyte-string' make a unibyte string from bytes.
1015
1016*** The new function `define-char-code-property' defines a character
1017code property.
1018
1019*** The new function `char-code-property-description' returns the
1020description string of a character code property.
1021
1022*** The function get-char-code-property now accepts many Unicode base
1023character properties. They are `name', `general-category',
1024`canonical-combining-class', `bidi-class', `decomposition',
1025`decimal-digit-value', `digit-value', `numeric-value', `mirrored',
1026`old-name', `iso-10646-comment', `uppercase', `lowercase', and
1027`titlecase'.
1028
1029*** The new variable `find-word-boundary-function-table' is a
1030char-table of functions to search for a word boundary.
1031
1032*** The new variable `char-script-table' is a char-table of script names.
1033
1034*** The new variable `char-width-table' is a char-table of character widths.
1035
1036*** The new variable `print-charset-text-property' controls how to
1037handle `charset' text property on printing a string.
1038
1039*** The new variable `printable-chars' is a char-table defining if a
1040character is printable or not.
1041
1042*** The functions `modify-syntax-entry' and `modify-category-entry' now
1043accepts a cons of characters as the first argument, and modify all
1044entries in that range of characters.
ca7871a3
SM
1045+++
1046*** `translation-table-for-input' is now obsolete.
d82c3d44 1047
505d8756 1048** Code conversion changes
d82c3d44
GM
1049
1050*** The new function `define-coding-system' should be used to define a
1051coding system instead of `make-coding-system' (which is now obsolete).
1052
1053*** The functions `encode-coding-region' and `decode-coding-region'
1054have an optional 4th argument to specify where the result of
1055conversion should go.
1056
1057*** The functions `encode-coding-string' and `decode-coding-string'
1058have an optional 4th argument specifying a buffer to store the result
1059of conversion.
1060
1061*** The new function `with-coding-priority' executes the body part with
1062the specified coding system priority order.
1063
1064*** The new function `check-coding-systems-region' checks if the text
1065in the region is encodable by the specified coding systems.
1066
1067*** The new function `coding-system-aliases' returns a list of aliases
1068of a coding system.
1069
1070*** The new function `coding-system-charset-list' returns a list of
1071charsets supported by a coding system.
1072
1073*** The new function `coding-system-priority-list' returns a list of
1074coding systems ordered by their priorities.
1075
1076*** The new function `set-coding-system-priority' sets priorities of
1077coding systems.
1078
1079*** The functions `set-coding-priority' and `make-coding-system' are obsolete.
1080
1081** There is a new input method, Robin, different from Quail.
0caa490b 1082It has three functionalities:
d82c3d44
GM
1083 i) a simple input method (converts an ASCII sequence into a string).
1084ii) converts an existing buffer substring into another string
1085iii) reverse conversion (each character produced by a
1086robin rule can hold the original ASCII sequence as a char-code-property)
1087
1088*** The new function `robin-define-package' defines a Robin package.
1089
1090*** The new function `robin-modify-package' modifies an existing Robin package.
1091
1092*** The new function `robin-use-package' starts using a Robin package
1093as an input method.
1094
505d8756 1095** Changes related to the new font backend
2b7a2553 1096
b19aa6dd
GM
1097Which font backends to use can be specified by the X resource "FontBackend".
1098For instance, to use both X core fonts and Xft fonts:
2b7a2553 1099
b19aa6dd 1100Emacs.FontBackend: x,xft
2b7a2553 1101
b19aa6dd
GM
1102If this resource is not set, Emacs tries to use all font backends
1103available on your graphic device.
d82c3d44
GM
1104
1105*** New frame parameter `font-backend' specifies a list of
1106font-backends supported by the frame's graphic device. On X, they are
1107currently `x' and `xft'.
1108
1109*** New function `fontp' checks if the argument is a font-spec or font-entity.
1110
1111*** New function `font-spec' creates a new font-spec object.
1112
1113*** New function `font-get' returns a font property value.
1114
d54b8954
CY
1115*** New function `font-face-attributes' returns a plist of face
1116attributes set by a font.
1117
d82c3d44
GM
1118*** New function `font-put' sets a font property value.
1119
1120*** New function `list-fonts' returns a list of font-entities matching
1121the given specification.
1122
1123*** New function `list-families' returns a list of family names of
1124available fonts.
1125
1126*** New function `font-font' returns a font-entity best matching with
1127the given specification.
1128
1129*** New function `font-xlfd-name' returns an XLFD name of a given font
1130(font-spec, font-entity, or font-object).
1131
1132*** New function `clear-font-cache' clears all font caches.
1133
1134*** The function `set-fontset-font' now accepts a script name as the
1135second argument, and has an optional 5th argument to control how to
1136set the font.
1137
505d8756 1138** Changes related to multiple tty support
24cdde13 1139
b12f6e85
SM
1140*** $TERM is now set to `dumb' for subprocesses. If you want to know the
1141$TERM inherited by Emacs you will have to look inside initial-environment.
1142
6168122d
SM
1143*** $DISPLAY is now dynamically inherited from the frame's `display'.
1144
0caa490b 1145*** The `window-system' variable has been made frame-local. The new
24cdde13 1146`initial-window-system' variable contains the `window-system' value
bbe3eb99
GM
1147for the first frame. `window-system' is also now a function that
1148takes a frame argument.
24cdde13
GM
1149
1150*** You can specify a terminal device (`tty' parameter) and a terminal
1151type (`tty-type' parameter) to `make-terminal-frame'.
1152
1153*** The new function `make-frame-on-tty' allows you to create a new
1154frame on another tty device interactively.
1155
1156*** The function `make-frame-on-display' now works during a tty
1157session, and `make-frame-on-tty' works during a graphical session.
1158
da406961 1159*** New functions: `delete-tty', `suspend-tty', `resume-tty'.
24cdde13 1160
419f8f49
SM
1161*** A new data type for terminals with functions: `get-device-terminal',
1162`terminal-parameters', `terminal-parameter', `set-terminal-parameter'.
24cdde13 1163
1816bda7 1164*** New hooks: `suspend-tty-functions' and `resume-tty-functions'
92cd6a7c 1165are called after a tty frame has been suspended or resumed,
de3054d5 1166respectively. The functions are called with the terminal id of the frame
92cd6a7c
DN
1167being suspended/resumed as a parameter.
1168
01ff458e 1169*** New function: `environment'.
da406961 1170
4f4a84ec 1171*** New variable: `local-function-key-map'.
01ff458e
SM
1172This in addition to the global function-key-map variable that
1173already existed. The global variable is not used directly any more;
1174instead, the local-function-key-map is initialized so as to inherit from
1175function-key-map.
da406961 1176
82866ad5
SM
1177*** `initial-environment' holds the environment inherited from Emacs's parent.
1178
24cdde13
GM
1179*** The `keyboard-translate-table' variable and the terminal and
1180keyboard coding systems have been made terminal-local.
1181
1aa423e9
SM
1182*** In addition to the global function-key-map, Emacs has terminal-local
1183local-function-key-map variables, and uses them instead of the
24cdde13
GM
1184global keymaps to set up translations and function key sequences
1185relevant to a specific terminal device.
1186
1187
90ab5c62
SM
1188** You can now also pass the value of the `invisible' property to invisible-p
1189to check whether it would cause the text to be invisible. Convenient when
1190checking invisibility of text which has no buffer position
1191(e.g. in before/after-strings).
9f44d41a 1192
ea2e3ef4
RS
1193** Non-breaking space now acts as whitespace.
1194
41bd52f7 1195+++
8d371994
RS
1196** In `condition-case', a handler can specify "let the debugger run first".
1197
1198You do this by writing `debug' in the list of conditions to be handled,
1199like this:
1200
1201 (condition-case nil
1202 (foo bar)
1203 ((debug error) nil))
1204
0a963185
SM
1205** The `require-match' argument to `completing-read' accepts a new value
1206`confirm-only'.
1207
c69b0314
SM
1208+++
1209** The regexp form \(?<num>:<regexp>\) specifies the group number explicitly.
1210
9f44d41a
RS
1211** New function `window-full-width-p' returns t if a window is as wide
1212as its frame.
1213
1214** The new function `split-string-and-unquote' does (what?)
1215
1216** The new function `combine-and-quote-strings' does (what?)
1217
1218** The new function `image-refresh' refreshes all images associated
1219with a given image specification.
1220
abf13a8b
CY
1221+++
1222** New variable `user-emacs-directory'.
1223Use this instead of "~/.emacs.d".
1224
b2b387f9 1225+++
0f3cd6b2 1226** The new function `start-file-process' is similar to `start-process',
b2b387f9 1227but obeys file handlers. The file handler is chosen based on
6dbe7eb4
MA
1228`default-directory'. The functions `start-file-process-shell-command'
1229and `process-file-shell-command' are also new; they call internally
0f3cd6b2 1230`start-file-process' and `process-file', respectively.
b2b387f9 1231
967b2682
GM
1232** The new function `process-lines' executes an external program and
1233returns its output as a list of lines.
1234
64639e26 1235+++
41bd52f7
MA
1236** `file-remote-p' has new optional parameters IDENTIFICATION and CONNECTED.
1237IDENTIFICATION specifies which part of the remote identifier has to be
1238returned. With CONNECTED passed non-nil, it is checked whether a
1239remote connection has been established already.
64639e26 1240
45595a4f
RS
1241** The two new functions `looking-at-p' and `string-match-p' can do
1242the same matching as `looking-at' and `string-match' without changing
1243the match data.
89835619
SM
1244
1245** The interactive-form of a function can be added post-facto via the
1246`interactive-form' symbol property. Mostly useful to add complex interactive
1247forms to subroutines.
9bae34bf 1248\f
0bfd685e 1249* New Packages for Lisp Programming in Emacs 23.1
efeb796b 1250
d445b3f8
SM
1251** The new major mode `special-mode' is intended as a parent for
1252major modes such as those that set the "'mode-class 'special" property.
1253
20202f5e 1254** find-cmd.el can build `find' commands using lisp syntax.
6dfcbe31 1255
9097e8af
RS
1256** The package isearch-multi.el has been added. It implements a new mode
1257`isearch-buffers-minor-mode' that allows isearch to search through
1258multiple buffers. In this mode a new variable
1259`isearch-buffers-next-buffer-function' defines the function to call
1260to get the next buffer to search in the series of multiple buffers.
1261
d53a60a6
TTN
1262** The new package avl-tree.el deals with the AVL tree data structure.
1263
05197f40 1264\f
a933dad1 1265----------------------------------------------------------------------
5b87ad55 1266This file is part of GNU Emacs.
a933dad1 1267
ab73e885 1268GNU Emacs is free software: you can redistribute it and/or modify
5b87ad55 1269it under the terms of the GNU General Public License as published by
ab73e885
GM
1270the Free Software Foundation, either version 3 of the License, or
1271(at your option) any later version.
5b87ad55
GM
1272
1273GNU Emacs is distributed in the hope that it will be useful,
1274but WITHOUT ANY WARRANTY; without even the implied warranty of
1275MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1276GNU General Public License for more details.
a933dad1 1277
5b87ad55 1278You should have received a copy of the GNU General Public License
ab73e885 1279along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
a933dad1 1280
05197f40 1281\f
a933dad1
DL
1282Local variables:
1283mode: outline
1284paragraph-separate: "[ \f]*$"
1285end:
ab5796a9 1286
a533413c 1287arch-tag: e759449d-88b3-4de4-9900-3a6c3dfa23e2