NEWS 81.1 KB
Newer Older
1
GNU Emacs NEWS -- history of user-visible changes.
2

Glenn Morris's avatar
Glenn Morris committed
3
Copyright (C) 2007, 2008, 2009 Free Software Foundation, Inc.
4
See the end of the file for license conditions.
Dave Love's avatar
#  
Dave Love committed
5

6
Please send Emacs bug reports to emacs-pretest-bug@gnu.org.
7 8
If possible, use M-x report-emacs-bug.

9
This file is about changes in Emacs version 23.
10

11 12
See files NEWS.22, NEWS.21, NEWS.20, NEWS.19, NEWS.18, and NEWS.1-17
for changes in older Emacs versions.
13 14 15

You can narrow news to a specific version by calling `view-emacs-news'
with a prefix argument or by typing C-u C-h C-n.
16

17 18 19 20 21 22 23 24

Temporary note:
 +++ indicates that the appropriate manual has already been updated.
 --- means no change in the manuals is called for.
When you add a new item, please add it without either +++ or ---
so we will look at it and add it to the manual.


25 26 27 28 29 30 31 32 33 34
* Installation Changes in Emacs 23.2

** New configure options for Emacs developers
These are not new features; only the configure flags are new.

*** --enable-profiling builds Emacs with profiling enabled.
This might not work on all platforms.

*** --enable-checking[=OPTIONS] builds emacs with extra runtime checks.

35 36
* Changes in Emacs 23.2

37 38 39 40 41 42
** The default value of `trash-directory' has changed to nil, which
means that `move-file-to-trash' trashes files according to
freedesktop.org specifications, the same method used by the Gnome,
KDE, and XFCE desktops.  (This change has no effect on Windows, which
uses `system-move-file-to-trash' for trashing.)

43 44 45 46 47
+++
** Emacs frames can be maximized.
The command line arguments -mm/--maximized and the value maximized to the
frame parameter fullscreen makes the Emacs frame maximized.

Jan Djärv's avatar
Jan Djärv committed
48 49 50
+++
** New frame parameter sticky makes Emacs frames sticky in virtual desktops.

51 52 53
** The pointer now becomes invisible when typing.
Customize make-pointer-invisible to turn it off.

54 55 56 57
---
** On MS-Windows, `display-time' now displays the system load average
as well as the time, as it does on GNU and Unix.

58 59 60 61 62
** Killing a buffer with a running process now asks a confirmation.
You can remove this query in two ways: either removing
`process-kill-buffer-query-function' from `kill-buffer-query-functions' or
setting the appropriate process flag with `set-process-query-on-exit-flag'.

63
+++
64 65 66 67 68
** If `select-active-regions' is t, any active region automatically
becomes the primary selection (for interaction with other window
applications).  If you enable this, you might want to bind
`mouse-yank-primary' to Mouse-2.

69 70 71 72 73 74 75
** The variable `load-in-progress' won't get corrupted by binding it
with `let'.  In certain situations, loading an Emacs Lisp file from
source while in the midst of loading another file (e.g., with
`require' or `autoload') could cause the value of `load-in-progress'
to be corrupted once the outer load completed.  Most code doesn't care
about this, but some (like c-mode) may check it.

Glenn Morris's avatar
Glenn Morris committed
76 77 78 79
** FIXME save-interprogram-paste-before-kill

** FIXME kill-do-not-save-duplicates

80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
** File-local variable changes

*** Specifying a minor mode as a local variables enables that mode,
unconditionally.  The previous behavior, toggling the mode, was
neither reliable nor generally desirable.

*** New commands for adding and removing file-local variables:
`add-file-local-variable', `delete-file-local-variable',
`add-file-local-variable-prop-line', and
`delete-file-local-variable-prop-line'.

*** New commands for adding and removing directory-local variables,
and copying them to and from file-local variable lists:
`add-dir-local-variable', `delete-dir-local-variable',
`copy-dir-locals-to-file-locals',
95 96 97
`copy-dir-locals-to-file-locals-prop-line' and
`copy-file-locals-to-dir-locals'.

98 99 100 101
** New coding system `utf-8-hfs' is available in
international/ucs-normalize.el.  It is suitable for
default-file-name-coding-system on Mac OS X.

Glenn Morris's avatar
Glenn Morris committed
102 103 104 105 106 107

* Editing Changes in Emacs 23.2

+++
** The default value for `blink-matching-paren-distance' has been increased.

108 109 110

* Changes in Specialized Modes and Packages in Emacs 23.2

111 112 113 114
** Calc graphing commands (`g f' etc.) now work on MS-Windows,
if you have the native Windows port of Gnuplot version 3.8 or later
installed.

Glenn Morris's avatar
Glenn Morris committed
115 116 117
** FIXME mail-user-agent change
This probably affects a lot of documentation.

Glenn Morris's avatar
Glenn Morris committed
118 119
** FIXME gdb-mi

120 121 122 123 124
** Info

*** The new command `Info-virtual-index' bound to "I" displays a menu of
matched topics found in the index.

Juri Linkov's avatar
Juri Linkov committed
125 126 127 128
*** The new command `info-finder' replaces finder.el with a virtual Info
manual that generates an Info file which gives the same information
through a menu structure.

129 130
+++
** New connection methods in Tramp.
131 132 133
The new connection method "rsyncc" has been introduced.  On systems
which support GVFS-Fuse, Tramp offers also the new connection methods
"dav", "davs", "obex" and "synce".
134

135 136 137 138
+++
** Autorevert Tail mode
Autorevert Tail mode works now for remote files.

139 140 141 142
** VC and related modes

*** When a file is not found, VC will not try to check it out of RCS anymore.

Dan Nicolaescu's avatar
Dan Nicolaescu committed
143 144 145
*** vc-git changes

**** The new variable vc-git-add-signoff can be used to add a
Dan Nicolaescu's avatar
Dan Nicolaescu committed
146 147
Signed-off-by line when committing.

Dan Nicolaescu's avatar
Dan Nicolaescu committed
148 149
**** vc-dir displays the stash status

150 151 152
*** log-edit-strip-single-file-name controls whether or not single filenames
are stripped when copying text from the ChangeLog to the *VC-Log* buffer.

Glenn Morris's avatar
Glenn Morris committed
153 154 155 156 157 158
** Calendar and diary

---
*** The command `calendar-current-date' accepts an optional argument
giving an offset from today.

159 160 161
** Desktop

---
162 163 164 165 166 167
*** The default value for `desktop-buffers-not-to-save' is nil.
This means Desktop will try restoring all buffers, when you restart
your Emacs session.  Also, `desktop-buffers-not-to-save' is only
effective for buffers that have no associated file.  If you want to
exempt buffers that do correspond to files, customize the value of
`desktop-files-not-to-save' instead.
168

169 170 171 172 173 174
** Miscellaneous

*** The new command `async-shell-command' bound globally to `M-&' executes
the command asynchronously without the need to manually add ampersand to
the end of the command.  Its output appears in the buffer `*Async Shell
Command*'.
Glenn Morris's avatar
Glenn Morris committed
175 176 177 178

---
*** Elint now uses compilation-mode, and recognizes more built-in
functions and variables.
Steve Yegge's avatar
Steve Yegge committed
179 180 181 182


* New Modes and Packages in Emacs 23.2

183
** js.el is a new major mode for JavaScript files.
184 185 186 187


* Lisp changes in Emacs 23.2

188 189 190
** All the default-FOO variables that hold the default value of the FOO
variable, are now declared obsolete.

191 192
** read-key is a function halfway between read-event and read-key-sequence.
It reads a single key, but obeys input and escape sequence decoding.
193

194 195
** start-process-shell-command start-file-process-shell-command only
take a single `command' argument any more.
196 197 198 199 200

** The variable `process-file-side-effects' shall be bound to nil, if
a `process-file' call does not change a remote file.  By this, file
name handlers like Tramp can apply optimizations.

201 202 203
** Hash tables have a new printed representation that is readable.
The feature `hashtable-print-readable' identifies this new
functionality.
204 205 206 207 208 209 210 211

** Functions performing Unicode normalization are added.  They are:
ucs-normalize-NFD-region, ucs-normalize-NFD-string,
ucs-normalize-NFC-region, ucs-normalize-NFC-string,
ucs-normalize-NFKD-region, ucs-normalize-NFKD-string,
ucs-normalize-NFKC-region, ucs-normalize-NFKC-string,
ucs-normalize-HFS-NFD-region, ucs-normalize-HFS-NFD-string,
ucs-normalize-HFS-NFC-region, ucs-normalize-HFS-NFC-string.
212

213

214
* Installation Changes in Emacs 23.1
215

216
** The default X toolkit is now Gtk+, rather than Lucid.
Chong Yidong's avatar
Chong Yidong committed
217 218
The configure option `--with-gtk' has been removed.  Gtk is now the
default toolkit, but you can use --with-x-toolkit=gtk if necessary.
219

Chong Yidong's avatar
Chong Yidong committed
220 221
** New font code.
Fonts are handled by new code capable of dealing with multiple font
222
backends.  This uses the freetype and fontconfig libraries.
223

Chong Yidong's avatar
Chong Yidong committed
224 225
*** Emacs now accepts font names supplied in the fontconfig format
(e.g. "monospace-12:bold") and GTK format (e.g. "Monospace Bold 12").
Dan Nicolaescu's avatar
Dan Nicolaescu committed
226

Chong Yidong's avatar
Chong Yidong committed
227 228 229 230 231 232 233 234 235
*** Added support for local fonts (fonts installed on the machine
where Emacs is running).

*** Added support for the Xft library for antialiasing.

*** Added support for the otf library for complex text layout by
OpenType fonts.

*** Added support for the m17n library for text shaping.
236

Chong Yidong's avatar
Chong Yidong committed
237
** Changes to image support
238

Chong Yidong's avatar
Chong Yidong committed
239
*** configure now checks for libgif before libungif when searching for
240
a GIF library.
241

Chong Yidong's avatar
Chong Yidong committed
242 243
*** Emacs now supports the SVG image format through librsvg2.

Jason Rumney's avatar
Jason Rumney committed
244 245
*** Emacs now supports multi-page TIFF images.

Chong Yidong's avatar
Chong Yidong committed
246
** New NeXTSTEP-based port
Glenn Morris's avatar
Glenn Morris committed
247
This provides support for GNUstep (via the GNUstep libraries) and Mac
Michael Albinus's avatar
Michael Albinus committed
248
OS X (via the Cocoa libraries).
249

Glenn Morris's avatar
Glenn Morris committed
250
Specify --with-ns to configure for this.  By default, a self-contained
251 252 253
app will be built (containing all lisp).  To install/share lisp with
other emacsen (e.g. X11 build) use --disable-ns-self-contained.  See
nextstep/README and nextstep/INSTALL in the Emacs source directory.
Chong Yidong's avatar
Chong Yidong committed
254 255 256

** Mac OS X is no longer supported via Carbon.
Use the NeXTSTEP port, described above.
Glenn Morris's avatar
Glenn Morris committed
257

Chong Yidong's avatar
Chong Yidong committed
258 259
** The new configuration option "--with-dbus" enables D-Bus language
bindings for Emacs.
260

261 262
** Support for many obsolete platforms has been removed.
See the list at the end of etc/MACHINES for details.
263

Chong Yidong's avatar
Chong Yidong committed
264
*** Support for systems without alloca has been removed.
265

Chong Yidong's avatar
Chong Yidong committed
266
*** Support for Sun windows has been removed.
267

Chong Yidong's avatar
Chong Yidong committed
268
*** The `emacstool' utility has been removed.
Chong Yidong's avatar
Chong Yidong committed
269

Chong Yidong's avatar
Chong Yidong committed
270
** The following platforms will be removed in a future Emacs version:
271 272
If you are still using Emacs on one of these platforms, please email
emacs-devel@gnu.org to inform the Emacs developers.
Chong Yidong's avatar
Chong Yidong committed
273

274
*** Old GNU/Linux systems based on libc version 5.
Chong Yidong's avatar
Chong Yidong committed
275

276 277
*** Old FreeBSD, NetBSD, and OpenBSD systems based on the COFF
    executable format.
Chong Yidong's avatar
Chong Yidong committed
278 279 280

*** Solaris versions 2.6 and below.

281 282 283 284
*** Solaris on IBM RS6000 machines.

*** UNIX System V (the original SysV, not later platforms based on it).

285 286
*** Unixware on non-x86 machines.

287 288
*** Platforms not supporting shared libraries (i.e., requiring the
NO_SHARED_LIBS compilation flag).
Chong Yidong's avatar
Chong Yidong committed
289

290 291 292 293
** The configure options `--with-gcc', `--without-gcc' have been removed.
Configure will use gcc by default.  Set the CC environment variable if
you need control over which C compiler is used.

Chong Yidong's avatar
Chong Yidong committed
294 295
** The refcards are now shipped as PDF files.

Glenn Morris's avatar
Glenn Morris committed
296 297 298
** The manuals are now licensed under the GNU Free Documentation License v1.3,
or any later version.

Chong Yidong's avatar
Chong Yidong committed
299 300 301
** Emacs 23 comes with a new set of default icons.
Various resolutions are available as etc/images/icons/hicolor/*/apps/emacs.png.
The Emacs 22 icon is available as `emacs22.png' in the same location.
Nick Roberts's avatar
Nick Roberts committed
302 303 304

* Changes in Emacs 23.1

Chong Yidong's avatar
Chong Yidong committed
305
** Improved X Window System support
306

Chong Yidong's avatar
Chong Yidong committed
307 308 309 310 311
*** Emacs now supports using both X displays and ttys in one session.
With an Emacs server active (M-x server-start), `emacsclient -t'
creates a tty frame connected to the running emacs server.  You can
use any number of different ttys.  `emacsclient -c' creates a new X11
frame on the current $DISPLAY (or a tty frame if $DISPLAY is not set).
312 313
There may be problems if a display exits unexpectedly and Emacs is compiled
with Gtk+, see etc/PROBLEMS.
314 315 316

You can test for the presence of this feature in your Lisp code by
testing for the `multi-tty' feature.
317 318

*** Emacs starts in the background, as a daemon, when given the
319 320 321
--daemon command line argument.  It disconnects from the terminal and
starts the server.  Clients can connect and create graphical or
terminal frames using emacsclient.
322

323
**** emacsclient starts emacs in daemon mode and connects to it when
324 325
--alternate-editor="" is used (or when the evironment variable
ALTERNATE_EDITOR is set to "") and emacsclient cannot connect to an
326 327
emacs server.

Chong Yidong's avatar
Chong Yidong committed
328
*** The new command close-display-connection closes a connection to a
329
remote display.  There are some bugs for Gtk+.  See etc/PROBLEMS.
330

Chong Yidong's avatar
Chong Yidong committed
331 332 333
*** Emacs now supports the XEmbed specification.
You can embed Emacs in another application on X11.  The new command line
option --parent-id is used to pass the parent window id to Emacs.  See
Jan Djärv's avatar
Jan Djärv committed
334 335
http://standards.freedesktop.org/xembed-spec/xembed-spec-latest.html
for details about XEmbed.
336

Chong Yidong's avatar
Chong Yidong committed
337 338 339
*** Emacs can now set the frame opacity.
The opacity of a frame can be controlled by setting the `alpha' frame
parameter.  This only takes effect on a compositing window manager for
340 341
the X Window System, such as Compiz, Beryl and Compiz Fusion, on Mac
OS X, or on Windows 2000 and later versions of Windows.
342 343

The alpha parameter should be an integer between 0 (transparent) and
Chong Yidong's avatar
Chong Yidong committed
344 345
100 (opaque), or a float number between 0.0 and 1.0.  It can also be a
cons cell (ACTIVE . INACTIVE), where ACTIVE is the opacity of an
346
active frame and INACTIVE is the opacity of non-active frames.
347

Chong Yidong's avatar
Chong Yidong committed
348 349
The variable `frame-alpha-lower-limit' defines a lower bound for the
opacity; the default is 20.
350

Chong Yidong's avatar
Chong Yidong committed
351
** Internationalization changes
352

Chong Yidong's avatar
Chong Yidong committed
353 354
*** The Emacs character set is now a superset of Unicode.
(It has about four times the code space, which should be plenty).
Stefan Monnier's avatar
Stefan Monnier committed
355

Chong Yidong's avatar
Chong Yidong committed
356
The internal encoding used for buffers and strings is now
357 358 359 360
Unicode-based and called `utf-8-emacs' (`emacs-internal' is an alias
for this).  This encoding is backward-compatible with Unicode's UTF-8
encoding.  The internal encoding previously used by Emacs,
`emacs-mule', is still available for reading and writing files.
Nick Roberts's avatar
Nick Roberts committed
361

Chong Yidong's avatar
Chong Yidong committed
362 363 364
During byte-compilation, Emacs 23 uses `utf-8-emacs' to write files.
As a result, byte-compiled files containing non-ASCII characters can't
be read by earlier versions of Emacs.  Files compiled by Emacs 20, 21,
365 366 367 368
or 22 are loaded correctly as `emacs-mule' (whether or not they
contain multibyte characters).  This takes somewhat more time, so it
may be worth recompiling existing .elc files which don't need to be
shared with older Emacsen.
369

Chong Yidong's avatar
Chong Yidong committed
370
*** There are new coding systems/aliases; see M-x list-coding-systems.
371

Chong Yidong's avatar
Chong Yidong committed
372 373 374
*** There is a new charset implementation with many new charsets.
See M-x list-character-sets.  New charsets can be defined conveniently
as tables of unicodes.
Dan Nicolaescu's avatar
Dan Nicolaescu committed
375

Chong Yidong's avatar
Chong Yidong committed
376 377 378
*** There are new language environments for Chinese-GBK,
Chinese-GB18030, Khmer, Bengali, Punjabi, Gujarati, Oriya, Telugu,
Sinhala, and TaiViet.
379

Chong Yidong's avatar
Chong Yidong committed
380 381
*** The minor modes unify-8859-on-encoding-mode and
unify-8859-on-decoding-mode are obsolete.
382

383 384 385
*** `ucs-insert' is bound to `C-x 8 RET' and in addition to hex numbers
accepts numbers in hash notation (e.g. #o21430 for octal, or #10r8984 for
decimal).  It also accepts Unicode character names with completion.
386

387 388 389 390 391
*** The `cyrillic-translit' input method supports many new characters.
Common typographical characters available from Unicode were added to
`cyrillic-translit': punctuation marks, accented characters, fractions,
and others.

Chong Yidong's avatar
Chong Yidong committed
392
** Emacs now supports serial port access on GNU/Linux, Unix, and
393 394 395
Windows.  The new command `serial-term' starts an interactive terminal
on a serial port.  The serial port can be configured at runtime with
the mode-line mouse menu.
396

Chong Yidong's avatar
Chong Yidong committed
397
** Menu Bar changes
398

Chong Yidong's avatar
Chong Yidong committed
399 400 401 402 403
*** In the Options menu, the "Set Default Font" item applies the
selected font to the `default' face on all frames, not just the
current frame.  Furthermore, if Emacs is compiled with both GTK and
Fontconfig support, the "Set Default Font" item uses the GTK font
selection dialog instead of an Emacs pop-up menu.
404

Chong Yidong's avatar
Chong Yidong committed
405 406
*** The font setting chosen by "Set Default Font" is saved if the
"Save Options" item is used.
407

408 409 410
*** The Tools menu contains a new Encryption/Decryption submenu.
This contains commands provided by EasyPG, the newly-included
interface to GnuPG (see New Modes and Packages).
411

412 413 414
*** In the Options menu, the "Truncate Long Lines in the Buffer" entry
has been replaced with a submenu offering three different ways to
handle long lines: truncation, continuation at the window edge, and
415
the new word wrapping behavior (see Editing Changes, below).
416

Dan Nicolaescu's avatar
Dan Nicolaescu committed
417 418 419 420
*** Improvements to menus for major and minor modes
More major and minor modes now have a mode specific menu, and existing
mode menus have been improved to include more functionality.

Chong Yidong's avatar
Chong Yidong committed
421
** Mode-line changes
422

Chong Yidong's avatar
Chong Yidong committed
423 424
*** The mode-line displays a `@', instead of `-', if the
default-directory for the current buffer is on a remote machine.
425

Chong Yidong's avatar
Chong Yidong committed
426 427
*** The mode-line displays a mode menu when mouse-1 is clicked on a
minor mode, in the same way as it already did for major modes.
428

Chong Yidong's avatar
Chong Yidong committed
429 430
*** The `mode-line-emphasis' face is used to highlight certain
mode-line information (e.g. waiting for a VC command to finish).
431

Dan Nicolaescu's avatar
Dan Nicolaescu committed
432
*** The mode-line tooltips have been improved to provide more details.
433

Dan Nicolaescu's avatar
Dan Nicolaescu committed
434 435 436
*** The VC, line/colum number and minor mode indicators on the mode
line are now interactive: mouse-1 can be used on them to pop up a menu.

437 438
** File deletion can make use of the Recycle Bin or system Trash folder.
Set `delete-by-moving-to-trash' non-nil to use this.  Deleted files
439
and directories will then be sent to the Recycle Bin on Windows, and
440 441
to `trash-directory' on other systems.

Chong Yidong's avatar
Chong Yidong committed
442
** Directory-local variables can now be defined.
443 444 445
By default, Emacs looks in .dir-locals.el for directory-local
variables.  For more information, see `dir-locals-set-directory-class'
and `dir-locals-set-class-variables'.
446

447 448 449 450 451 452 453
** Emacs can now use `auth-source' for authentication.
`smtpmail' and `url' (Tramp and Gnus also) use `auth-source' to obtain
login names and passwords.  The match, if found, is reported
in *Messages* with the password blanked out.

** `where-is-preferred-modifier' can specify your favorite modifier.

454

455
* Startup Changes in Emacs 23.1
456

457 458 459 460 461 462
** The option `inhibit-startup-screen' (with aliases to old names
`inhibit-splash-screen' and `inhibit-startup-message') doesn't inhibit
display of the initial message in the *scratch* buffer.  If you don't
want to display the initial message in the *scratch* buffer at startup,
you can set the option `initial-scratch-message' to nil.

463 464 465 466
** New user option `initial-buffer-choice' specifies what to display
after starting Emacs: startup screen, *scratch* buffer, visiting a
file or directory.

467 468 469 470
** New alias `argv' for `command-line-args-left'
This is a convenience alias, so that one can write `(pop argv)'
inside of --eval command line arguments in order to access
following arguments.
471 472

** The abbrev file is no longer read at startup in batch mode.
473 474 475 476 477 478

** Emacs now supports invocation by an X session manager.
It can save a session and restore it later.  See the documentation of
the functions `emacs-session-save' and `emacs-session-restore'.
(Actually, this feature was introduced with Emacs 22, but it was not
documented.)
479

480
* Incompatible Editing Changes in Emacs 23.1
Kim F. Storm's avatar
Kim F. Storm committed
481

482 483 484
** In Dired, `dired-flag-garbage-files' is rebound from `&' to `%&'
on the regexp command prefix map.

485 486 487 488
** In Dired-x, all command guesses for ! are now added to the default
list accessible by M-n instead of pushing all guesses temporarily into
the history list.

489 490 491 492
** In Isearch mode, a special case of typing `C-w' at the beginning of
the minibuffer that toggles word search (i.e. using key sequences
`C-s RET C-w' or `C-s M-e C-w') is obsolete.  You can use the global key
`M-s w' to start word search, or type `M-s w' in Isearch mode to
493 494
toggle word search.  To start nonincremental word search you can now use
`M-s w RET' and `M-s w C-r RET' instead of `C-s RET C-w' and `C-r RET C-w'.
495

Juri Linkov's avatar
Juri Linkov committed
496 497 498 499 500 501 502
** In Info, `Info-search' is unbound from `M-s' to allow using `M-s w'
for word search as well as other search commands from the global prefix
key `M-s'.  `Info-search' is still bound to `s', and also incremental
search commands `C-s', `C-M-s', `C-r', `C-M-r' are available for searching
through multiple Info nodes, together with their nonincremental versions
`C-s RET', `C-r RET', `C-M-s RET', `C-M-r RET', `M-s w RET'.

503 504 505
** In Text mode, `center-line' and `center-paragraph' are rebound from
`M-s' and `M-S' to global keys `M-o M-s' and `M-o M-S' on the global
prefix map `M-o', which is intended for such formatting commands.
506

Reiner Steib's avatar
Reiner Steib committed
507
** The following input methods were removed in Emacs 22.2, but this was
Juanma Barranquero's avatar
Juanma Barranquero committed
508
not advertised: danish-alt-postfix, esperanto-alt-postfix,
Reiner Steib's avatar
Reiner Steib committed
509 510 511 512
finnish-alt-postfix, german-alt-postfix, icelandic-alt-postfix,
norwegian-alt-postfix, scandinavian-alt-postfix, spanish-alt-postfix,
and swedish-alt-postfix.  Use the versions without "alt-", which are
identical.
513

Richard M. Stallman's avatar
Richard M. Stallman committed
514

515
* Editing Changes in Emacs 23.1
Richard M. Stallman's avatar
Richard M. Stallman committed
516

517 518 519
** The C-n and C-p line-motion commands now move by screen lines,
taking continued lines and variable-width characters into account.
Setting `line-move-visual' to nil reverts this to the previous
520 521
behavior (i.e., motion by logical lines based on buffer contents
alone).
522

Chong Yidong's avatar
Chong Yidong committed
523
** C-x C-c now invokes `save-buffers-kill-terminal', and C-z now
524
invokes `suspend-frame'.  These changes are for compatibility with the
Chong Yidong's avatar
Chong Yidong committed
525
new multi-tty support (see `Improved X Window System support' above).
526

Chong Yidong's avatar
Chong Yidong committed
527
** Mark changes
528

529
*** Transient Mark mode is now on by default.
530

531
*** mark-even-if-inactive now defaults to t
532

533 534
*** When Transient Mark mode is on, C-SPC C-SPC pushes a mark without
activating it.
535

536 537
*** When Transient Mark mode is on, M-q now fills the region if the
region is active.  Otherwise, it fills the current paragraph.
538

539 540
*** When Transient Mark mode is on, M-$ now checks spelling of the
region if the region is active.  Otherwise, it checks spelling of the
Juri Linkov's avatar
Juri Linkov committed
541
word at point.
542

543 544
*** When Transient Mark mode is on, TAB now indents the region if the
region is active.
545 546 547 548

*** The variable `use-empty-active-region' controls whether an empty
active region in Transient Mark mode should make commands operate on
that empty region.
549 550

** Temporarily active regions
551

552 553 554 555
*** The new variable shift-select-mode, non-nil by default, controls
shift-selection.  When Shift Select mode is on, shift-translated
motion keys (e.g. S-left and S-down) activate and extend a temporary
region, similar to mouse-selection.
556

557 558 559 560 561 562 563
*** Temporarily active regions, created using shift-selection or
mouse-selection, are not necessarily deactivated in the next command.
They are only deactivated after point motion commands that are not
shift-translated, or after commands that would ordinarily deactivate
the mark in Transient Mark mode (e.g., any command that modifies the
buffer).

564
** Minibuffer and completion changes
565

566 567 568 569 570 571 572 573 574 575 576 577
*** Emacs may ask for confirmation before opening a non-existent file
or buffer.  By default, Emacs requests confirmation if you type RET
immediately after TAB, and the resulting input is not an existing file
or buffer; this usually happens when the minibuffer input did not
complete far enough and you entered RET by mistake.  In that case,
Emacs puts the message "[Confirm]" in the minibuffer; type RET again
to create the file or buffer.

The new variable confirm-nonexistent-file-or-buffer determines whether
Emacs asks for confirmation.  The default value is `after-completion'.
If you change it to t, Emacs always asks for confirmation; if you
change it to nil, Emacs never asks for confirmation.
578

579 580 581 582 583 584 585 586 587 588 589 590
*** The rules for performing completion have been changed.
When generating completion alternatives, Emacs now takes the
minibuffer text after point, if any, into account: this text is
treated as a substring of the remaining part of the completion
alternative (i.e., the part not matched by the minibuffer text before
point).  If no completion alternatives are found this way, Emacs
attempts to perform partial-completion.  If still no completion
alternatives are found, we fall back on the Emacs 22 rules for
performing completion.

The new variable `completion-styles' can be customized to choose your
favorite completion style.
591

592 593 594 595 596 597
*** When M-n in the minibuffer reaches the end of the list of defaults,
it adds the completion list to the end, so next M-n continues putting
completion items to the minibuffer.  The same principle applies to
incremental search commands as well: C-s or C-M-s starts searching
the default values and after the end of defaults they continue
searching minibuffer completion items.
598

Chong Yidong's avatar
Chong Yidong committed
599
*** Minibuffer input of shell commands now comes with completion.
600

Chong Yidong's avatar
Chong Yidong committed
601 602
*** In the `C-x d' (Dired) prompt, typing M-n gives the visited file
name of the current buffer.
603

Chong Yidong's avatar
Chong Yidong committed
604 605 606 607 608
*** In the M-! (shell-command) prompt, M-n provides some default commands.
These are guessed using the file extension of the current file, based
on the file-handlers specified in the operating system's `mailcap'
file.  The ! command in Dired (dired-do-shell-command) works
similarly, using the file displayed on the current line.
609 610 611

*** A list of regexp default values is available via M-n for `occur',
`keep-lines', `flush-lines' and `how-many'.  This list includes the active
Juri Linkov's avatar
Juri Linkov committed
612 613
region in transient-mark-mode, the word under the cursor, the last Isearch
regexp, the last Isearch string and the last replacement regexp.
614

615 616 617 618 619
*** When enable-recursive-minibuffers is non-nil, operations which use
switch-to-buffer (such as C-x b and C-x C-f) do not fail any more when
used in a minibuffer or a dedicated window.  Instead, they fallback on
using pop-to-buffer, which will use some other window.  This change
has no effect when enable-recursive-minibuffers is nil (the default).
620

Juri Linkov's avatar
Juri Linkov committed
621 622 623
*** Isearch started in the minibuffer searches in the minibuffer history.
Reverse Isearch commands (C-r, C-M-r) search in previous minibuffer
history elements, and forward Isearch commands (C-s, C-M-s) search in
624 625 626 627
next history elements.  When the reverse search reaches the first history
element, it wraps to the last history element, and the forward search
wraps to the first history element.  When the search is terminated, the
history element containing the search string becomes the current.
628

629 630
*** The variable read-file-name-completion-ignore-case overrides
completion-ignore-case for file name completion.
631

632 633
*** The variable read-buffer-completion-ignore-case overrides
completion-ignore-case for buffer name completion.
634

635 636
*** The new command `minibuffer-force-complete' chooses one of the
possible completions, rather than stopping at the common prefix.
637

638 639 640
*** If `completion-auto-help' is `lazy', Emacs shows the completions
buffer only on the second attempt to complete.  This was already
supported in `partial-completion-mode'.
641

642
** Face changes
643

644 645
*** S-down-mouse-1 now pops up a menu for changing the font and text
size of the default face in the current buffer.  The face is changed
Chong Yidong's avatar
Chong Yidong committed
646
via face remapping (see Lisp changes, below).
647

648 649 650
*** New commands to change the default face size in the current buffer.
To increase it, type `C-x C-+' or `C-x C-='.  To decrease it, type
`C-x C--'.  To restore the default (global) face size, type `C-x C-0'.
651 652 653 654 655 656 657
These work via Text Scale mode, a new minor mode.

The final key in the above commands may be repeated without the
leading `C-x', e.g. `C-x C-= C-= C-=' increases the face height by
three steps.  Each step scales the height of the default face by the
value of the variable `text-scale-mode-step'.

658 659 660
*** The commands buffer-face-mode and buffer-face-set can be used to
remap the default face in the current buffer.  See "Buffer Face mode",
under New Modes and Packages.
Glenn Morris's avatar
Glenn Morris committed
661

Chong Yidong's avatar
Chong Yidong committed
662
** Primary selection changes
663

664 665
*** You can disable kill ring commands from accessing the primary
selection by setting `x-select-enable-primary' to nil.
666

667 668 669 670 671 672 673 674
** Continuation lines can now be wrapped at word boundaries
(word-wrapping).  This is controlled by the new per-buffer variable
`word-wrap'.  Word wrapping does not take place if continuation lines
are not shown, e.g. if truncate-lines is non-nil.  The most convenient
way to enable word-wrapping is using the new minor mode Visual Line
mode; in addition to setting `word-wrap' to t, this rebinds some
editing commands to work on screen lines rather than text lines.  See
New Modes and Packages, below.
Chong Yidong's avatar
Chong Yidong committed
675

676
** Window management changes
677

678 679
*** truncate-partial-width-windows now accepts integer values, which
specify a minimum window width for partial-width windows, below which
680
lines are truncated.  The default has been changed to 50.
681 682 683

*** The new command balance-windows-area balances windows both
vertically and horizontally.
684

Martin Rudalics's avatar
Martin Rudalics committed
685 686 687
*** pop-to-buffer now always sets input focus when the popped-to window
is on a different frame.

Chong Yidong's avatar
Chong Yidong committed
688
** Miscellaneous changes:
689

Chong Yidong's avatar
Chong Yidong committed
690 691
*** C-l is bound to the new command recenter-top-bottom, rather than recenter.
This moves the current line to window center, top and bottom on
Chong Yidong's avatar
Chong Yidong committed
692
successive invocations.
693

Chong Yidong's avatar
Chong Yidong committed
694
*** scroll-preserve-screen-position also preserves the column position.
695

Chong Yidong's avatar
Chong Yidong committed
696 697 698
*** If `yank-pop-change-selection' is t, rotating the kill ring also
updates the selection or clipboard to the current yank, just as M-w
would do so with the text it copies to the kill ring.
699

Chong Yidong's avatar
Chong Yidong committed
700 701 702 703 704 705 706 707
*** C-M-% now shows replacement as it would look in the buffer, with
`\N' and `\&' substituted according to the match.  Old behavior can be
restored by customizing `query-replace-show-replacement'.

*** The command shell prompts for the default directory, when it is
called with a prefix and the default directory is a remote file name.
This is because some file name handlers (like ange-ftp) are not able to
run processes remotely.
708

Chong Yidong's avatar
Chong Yidong committed
709 710
*** The new command kill-matching-buffers kills buffers whose name
matches a regexp.
711

712 713 714
*** The value of comment-style now defaults to `indent'.
Thefore, comment-start markers are inserted at the current indentation
of the region to comment, rather than the leftmost column.
715

716 717
*** The new commands `pp-macroexpand-expression' and
`pp-macroexpand-last-sexp' pretty-print macro expansions.
718

719 720
*** The new command `set-file-modes' allows to set file's mode bits.
The mode bits can be specified in symbolic notation, like with GNU
721 722
Coreutils, in addition to an octal number.  `chmod' is a new
convenience alias for this function.
Eli Zaretskii's avatar
Eli Zaretskii committed
723

Eli Zaretskii's avatar
Eli Zaretskii committed
724 725 726
*** `next-error-recenter' specifies how next-error should recenter the
visited source file.  Its value can be a number (for example, 0 for
top line, -1 for bottom line), or nil for no recentering.
727

728 729
*** When typing in a password in the echo area, C-y yanks the current
kill into the password.
730

731 732
*** Tooltip frame parameters `font' and `color' in `tooltip-frame-parameters'
are ignored.  Customize the `tooltip' face instead.
733

Dan Nicolaescu's avatar
Dan Nicolaescu committed
734
*** `mkdir' is a new convenience alias for `make-directory'.
Chong Yidong's avatar
Chong Yidong committed
735 736

* New Modes and Packages in Emacs 23.1
737 738 739 740 741

** Auto Composition Mode is a minor mode that composes characters
automatically when they are displayed.  It is globally on by default.
It uses `auto-composition-function' (default `auto-compose-chars').

Chong Yidong's avatar
Chong Yidong committed
742
** Bubbles, a new game, is similar to SameGame.
743 744 745 746 747 748 749 750

** Buffer Face mode is a minor mode for remapping the default face in
the current buffer.  The variable `buffer-face-mode-face' specifies
the face to remap to.  The command `buffer-face-set' prompts for a
face name, sets `buffer-face-mode-face' to it, and enables
buffer-face-mode.  See "Face changes", under Editing Changes, for a
description of face remapping.

Juri Linkov's avatar
Juri Linkov committed
751 752
** butterfly flips the desired bit on the drive platter.
See http://xkcd.com/378/
753

754 755
** bug-reference.el provides clickable links to bug reports.

Chong Yidong's avatar
Chong Yidong committed
756 757
** dbus.el provides D-Bus language bindings.
D-Bus is an inter-process communication mechanism for applications
758
residing on the same host.  See the manual for details.
Chong Yidong's avatar
Chong Yidong committed
759

760
** DocView mode allows viewing of PDF, PostScript and DVI documents.
761 762
One can also search for a regular expression in the document.  For
details, see the commentary in doc-view.el.
Chong Yidong's avatar
Chong Yidong committed
763

764 765 766 767
PDF and DVI files are now opened in Doc View mode by default.

In Postcript mode, C-c C-c launches Doc View minor mode for viewing
the postscript file.
768

769 770 771 772
** EasyPG provides an interface to the GNU Privacy Guard (GnuPG).
It includes a GnuPG keyring browser, cryptographic operations on
regions and files, and automatic encryption of *.gpg files.  For
details, see the EasyPG Assistant User's Manual.
Chong Yidong's avatar
Chong Yidong committed
773 774 775 776 777 778 779

** json.el is a library for parsing and generating JSON
(JavaScript Object Notation), a lightweight data-interchange format.

** linum.el is a new minor mode to display line numbers for the
current buffer.

780 781 782 783 784 785
** mairix.el is an interface to mairix, a free tool for indexing and
searching locally stored mail.  It allows you to query mairix and
display the search results with Rmail, Gnus and VM.  Note that there
is an existing Gnus back end, nnmairix.el, which should be used with
Maildir/MH setups.

786
** minibuffer-depth-indicate-mode shows the minibuffer depth in the prompt.
Chong Yidong's avatar
Chong Yidong committed
787 788 789 790 791 792 793 794 795 796 797 798 799

** nXML Mode
This is a new mode for editing XML documents.  It allows a schema to
be associated with the XML document being edited, using Relax NG as
the schema language.  The schema is used to provide two key features:

*** Continuous validation.  nXML validates as you type, highlighting
any invalid parts of your document.

*** Completion.  nXML can assist you in entering an element name,
attribute name or data value by using information about what is
allowed by the schema in that context.

800 801 802 803 804 805
** proced.el provides a Dired-like interface for operating on
processes.  Proced makes an Emacs buffer containing a listing of the
current processes.  You can use the normal Emacs commands to move
around in this buffer, and special Proced commands to operate on the
processes listed.  It is currently only functional on GNU/Linux,
MS-Windows and Solaris.
Chong Yidong's avatar
Chong Yidong committed
806 807 808 809 810

** Remember Mode is a mode for jotting down things to remember.
Notes can be saved to a Diary file.  For details, see the Remember
Manual.

811
** RST mode is a major mode for editing reStructuredText files.
812

Chong Yidong's avatar
Chong Yidong committed
813 814
** Ruby mode is a major mode for Ruby files.

Chong Yidong's avatar
Chong Yidong committed
815 816 817 818
** Visual Line mode provides support for editing by visual lines.
It turns on word-wrapping in the current buffer, and rebinds C-a, C-e,
and C-k to commands that operate by visual lines instead of logical
lines.  This is a more reliable replacement for longlines-mode.
819 820
This can also be turned on using the menu bar, via
Options -> Line Wrapping in this Buffer -> Word Wrap
Chong Yidong's avatar
Chong Yidong committed
821

Michael Albinus's avatar
Michael Albinus committed
822 823 824 825
** xesam.el is an implementation of Xesam, an interface to (desktop)
search engines like Beagle, Strigi, and Tracker.  The Xesam API
requires D-Bus for communication.

Chong Yidong's avatar
Chong Yidong committed
826 827 828 829 830
** zeroconf.el offers service discovery and service publishing
interfaces according to the zeroconf specification.  It communicates
with Avahi, a zeroconf implementation, via D-Bus messages on systems
which have installed this software.

831 832 833 834 835 836 837 838 839
** There is a new `whitespace' package.
(The pre-existing one has been renamed to `old-whitespace'.)
Now, besides reporting bogus blanks, the whitespace package has a
minor mode and a global minor mode to visualize blanks (TAB, (HARD)
SPACE and NEWLINE).  The visualization is made via faces and/or display
table.  It can also indicate lines that extend beyond a given column,
trailing blanks, and empty lines at the start or end of a buffer.
See `whitespace-style' for more details.  The `whitespace-action' option
specifies what to do when a buffer is visited, killed, or written.
840

Chong Yidong's avatar
Chong Yidong committed
841 842 843 844

* Changes in Specialized Modes and Packages in Emacs 23.1

** Abbrev has been rewritten in Elisp and extended with more flexibility.
845

Stefan Monnier's avatar
Stefan Monnier committed
846
*** New functions: abbrev-get, abbrev-put, abbrev-table-get, abbrev-table-put,
847
    abbrev-table-p, abbrev-insert, abbrev-table-menu.
848

Stefan Monnier's avatar
Stefan Monnier committed
849
*** Special hook `abbrev-expand-functions' obsoletes `pre-abbrev-expand-hook'.
850

Stefan Monnier's avatar
Stefan Monnier committed
851 852
*** `make-abbrev-table', `define-abbrev', `define-abbrev-table' all take
    extra arguments for arbitrary properties.
853

Stefan Monnier's avatar
Stefan Monnier committed
854
*** New variable `abbrev-minor-mode-table-alist'.
855

Stefan Monnier's avatar
Stefan Monnier committed
856
*** `local-abbrev-table' can hold a list of abbrev-tables.
857

Stefan Monnier's avatar
Stefan Monnier committed
858
*** Abbrevs have now the following special properties:
859
    `:count', `:system', `:enable-function', `:case-fixed'.
860

Stefan Monnier's avatar
Stefan Monnier committed
861 862 863 864
*** Abbrev-tables have now the following special properties:
    `:parents', `:case-fixed', `:enable-function', `:regexp',
    `abbrev-table-modiff'.

Chong Yidong's avatar
Chong Yidong committed
865
** Apropos
866

Chong Yidong's avatar
Chong Yidong committed
867
*** `apropos-library' describes the elements defined in a given library.
868

Chong Yidong's avatar
Chong Yidong committed
869
*** Set `apropos-compact-layout' is you want a more compact (but wider) layout.
Martin Rudalics's avatar
Martin Rudalics committed
870

Chong Yidong's avatar
Chong Yidong committed
871
** Archive Mode has basic support to browse Rar archives.
872 873
Note, however, that the free version of the unrar command only handles
versions 1 and 2 of the Rar format.
Martin Rudalics's avatar
Martin Rudalics committed
874

Chong Yidong's avatar
Chong Yidong committed
875
** BibTeX mode
Juri Linkov's avatar
Juri Linkov committed
876

Chong Yidong's avatar
Chong Yidong committed
877
*** New command `bibtex-initialize' (re)initializes BibTeX buffers.
Juri Linkov's avatar
Juri Linkov committed
878

Chong Yidong's avatar
Chong Yidong committed
879 880
*** New `bibtex-entry-format' options `whitespace', `braces', and
`string', disabled by default.
Juri Linkov's avatar
Juri Linkov committed
881

Chong Yidong's avatar
Chong Yidong committed
882 883
*** New variable `bibtex-cite-matcher-alist' contains rules to
identify cited keys in BibTeX entries, used by `bibtex-find-crossref'.
884

Chong Yidong's avatar
Chong Yidong committed
885
*** Command `bibtex-url' allows multiple URLs per entry.
Glenn Morris's avatar
Glenn Morris committed
886

Chong Yidong's avatar
Chong Yidong committed
887
** Calendar and diary
Juri Linkov's avatar
Juri Linkov committed
888

Chong Yidong's avatar
Chong Yidong committed
889 890 891 892
*** There is a new date style, `iso', essentially year/month/day.
The variable `european-calendar-style' is obsolete - use `calendar-date-style'.
Similarly, the commands `american-calendar' and `european-calendar'
should be replaced by `calendar-set-date-style'.
Stefan Monnier's avatar
Stefan Monnier committed
893

Chong Yidong's avatar
Chong Yidong committed
894 895 896 897 898 899 900
*** The calendar namespace has been rationalized.
All functions and variables now begin with a `calendar-', `diary-', or
`holiday-' prefix.  The various calendar systems have secondary
prefixes, eg `calendar-french-'.  The old names you are likely to use
directly still exist, for the time being, as aliases, but please start
using the new names.

901 902 903 904 905 906 907 908
*** The whitespace in the calendar layout can be customized.
See the variables:
calendar-left-margin, calendar-intermonth-spacing, calendar-column-width,
calendar-day-header-width, and calendar-day-digit-width.

*** Text (e.g. ISO weeks) can be displayed between the calendar months.
See the variables calendar-intermonth-header and calendar-intermonth-text.

Chong Yidong's avatar
Chong Yidong committed
909 910 911 912 913
*** The function `holiday-chinese' computes holidays on the Chinese calendar.
It has been used to add items to the list `holiday-oriental-holidays'.

*** `diary-remind' accepts a negative number -DAYS as a shorthand for
the list (1 2 ... DAYS).
914

915 916 917 918 919 920 921 922
** Change Log mode

*** The new command C-c C-f (change-log-find-file) finds the file
associated with the current log entry.

*** The new command C-c C-c (change-log-goto-source) goes to the
source code associated with a log entry.

Dan Nicolaescu's avatar
Dan Nicolaescu committed
923
** Compile and grep modes
924

Dan Nicolaescu's avatar
Dan Nicolaescu committed
925 926 927
*** The mode-line entry for the *compilation* and *grep* buffer is color coded.
It has different colors for to show that: (a) the command is still
running, (b) successful completion, (c) error.
928

Dan Nicolaescu's avatar
Dan Nicolaescu committed
929
*** compilation-auto-jump-to-first-error tells `compile' to jump to
930
the first error encountered during compilations.
931

932 933
*** compilation-scroll-output accepts a new value, `first-error', which
says to stop auto scrolling at the first error that occurs.
934

Dan Nicolaescu's avatar
Dan Nicolaescu committed
935
*** The `cc' alias for C++ files in `grep-file-aliases' has been
Glenn Morris's avatar
Glenn Morris committed
936
improved.  `hh' can be used to match C++ header files and `cchh' both
Dan Nicolaescu's avatar
Dan Nicolaescu committed
937 938
C++ sources and headers.

939 940 941 942 943 944 945 946 947
** Copyright

*** You can specify your copyright holders' names.
Only copyright lines with holders matching `copyright-names-regexp' are
considered for update.

*** Copyrights can be at the end of the buffer.
This is controlled by `copyright-at-end-flag' (used by, e.g., change-log-mode).

Chong Yidong's avatar
Chong Yidong committed
948
** Custom
949

Chong Yidong's avatar
Chong Yidong committed
950
*** defcustom accepts new keyword arguments, `:safe' and `:risky', which
951 952
set a variable's `safe-local-variable' and `risky-local-variable' property.

Chong Yidong's avatar
Chong Yidong committed
953
** Diff mode
954

Chong Yidong's avatar
Chong Yidong committed
955 956
*** diff-refine-hunk highlights word-level details of changes in a diff hunk.
It's used automatically as you move through hunks, see
957
diff-auto-refine-mode.  It is bound to `C-c C-b'.
958