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

3
Copyright (C) 2007, 2008, 2009, 2010 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 bug-gnu-emacs@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

* Installation Changes in Emacs 23.3

* Startup Changes in Emacs 23.3

* Changes in Emacs 23.3

24 25 26
** The nextstep port can have different modifiers for the left and right
alt/option key by customizing the value for ns-right-alternate-modifier.

27 28 29 30 31 32

* Editing Changes in Emacs 23.3


* Changes in Specialized Modes and Packages in Emacs 23.3

Glenn Morris's avatar
Glenn Morris committed
33 34 35 36
---
** The appt-add command takes an optional argument for the warning time.
This can be used in place of the default appt-message-warning-time.

37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
** VC and related modes

*** New VC commands: vc-log-incoming, vc-log-outgoing, vc-find-conflicted-file.

**** vc-log-incoming for Git runs "git fetch" so that the necessary
data is available locally.

**** vc-log-incoming and vc-log-outgoing for Git require version 1.7 (or newer).

*** New key bindings: C-x v I and C-x v O bound to vc-log-incoming and
vc-log-outgoing, respectively.

*** The 'g' key in VC diff, log, log-incoming and log-outgoing buffers
reruns the corresponding VC command to compute an up to date version
of the buffer.

*** vc-dir for Bzr supports viewing shelve contents and shelving snapshots.

*** Special markup can be added to log-edit buffers.
The log-edit buffers are expected to have a format similar to email messages
with headers of the form:
  Author: <author of this change>
  Summary: <one line summary of this change>
  Fixes: <reference to the bug fixed by this change>
Some backends handle some of those headers specially, but any unknown header
is just left as is in the message, so it is not lost.

**** vc-git handles Author: and Date:
**** vc-hg handles  Author: and Date:
**** vc-bzr handles Author:, Date: and Fixes:
**** vc-mtn handles Author: and Date:

*** Pressing g in a *vc-diff* buffer reruns vc-diff, so it will
produce an up to date diff.


Glenn Morris's avatar
Glenn Morris committed
73 74 75 76 77
** Obsolete packages

+++
*** lmenu.el and cl-compat.el are now obsolete.

78 79 80 81 82 83 84 85 86

* New Modes and Packages in Emacs 23.3


* Incompatible Lisp Changes in Emacs 23.3


* Lisp changes in Emacs 23.3

87 88
** `e' and `pi' are now called `float-e' and `float-pi'.
  The old names are obsolete.
89 90
** The use of unintern without an obarray arg is declared obsolete.

91 92 93 94 95
** New function byte-to-string, like char-to-string but for bytes.


* Changes in Emacs 23.3 on non-free operating systems

96

97 98
* Installation Changes in Emacs 23.2

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

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

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

Glenn Morris's avatar
Glenn Morris committed
107 108 109
** `make install' now consistently ignores umask, creating a
world-readable install.

110
** Emacs compiles with Gconf support, if it is detected.
Chong Yidong's avatar
Chong Yidong committed
111
Use the configure option --without-gconf to disable this.
Glenn Morris's avatar
Glenn Morris committed
112
This is used by the `font-use-system-font' feature (see below).
Chong Yidong's avatar
Chong Yidong committed
113

Chong Yidong's avatar
Chong Yidong committed
114
* Startup Changes in Emacs 23.2
115

Chong Yidong's avatar
Chong Yidong committed
116 117 118 119 120
** The command-line option -Q (--quick) also inhibits loading X resources.
However, if Emacs is compiled with the Lucid or Motif toolkit, X
resource settings for the graphical widgets are still applied.
On Windows, the -Q option causes Emacs to ignore Registry settings,
but environment variables set on the Registry are still honored.
121

Chong Yidong's avatar
Chong Yidong committed
122 123
*** The new variable `inhibit-x-resources' shows whether X resources
were loaded.
124

Chong Yidong's avatar
Chong Yidong committed
125 126
** New command-line option -mm (--maximized) maximizes the initial frame.

Chong Yidong's avatar
Chong Yidong committed
127
* Changes in Emacs 23.2
128

Chong Yidong's avatar
Chong Yidong committed
129
** The maximum size of buffers (and the largest fixnum) is doubled.
130 131
On typical 32bit systems, buffers can now be up to 512MB.

Chong Yidong's avatar
Chong Yidong committed
132 133
** The default value of `trash-directory' is now nil.
This means that `move-file-to-trash' trashes files according to
134 135 136 137
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.)

138
** The pointer now becomes invisible when typing.
Chong Yidong's avatar
Chong Yidong committed
139
Customize `make-pointer-invisible' to disable this feature.
140

Chong Yidong's avatar
Chong Yidong committed
141
** Font changes
142

Chong Yidong's avatar
Chong Yidong committed
143 144 145 146 147 148
*** Emacs can use the system default monospaced font in Gnome.
To enable this feature, set `font-use-system-font' to non-nil (it is
nil by default).  If the system default changes, Emacs changes also.
This feature requires Gconf support, which is automatically included
at compile-time if configure detects the gconf libraries (you can
disable this with the configure option --without-gconf).
149

Chong Yidong's avatar
Chong Yidong committed
150 151 152
*** On X11, Emacs reacts to Xft changes made by configuration tools,
via the XSETTINGS mechanism.  This includes antialias, hinting,
hintstyle, RGBA, DPI and lcdfilter changes.
153

Chong Yidong's avatar
Chong Yidong committed
154 155 156 157
** Killing a buffer with a running process now asks for confirmation.
To remove this query, remove `process-kill-buffer-query-function' from
`kill-buffer-query-functions', or set the appropriate process flag
with `set-process-query-on-exit-flag'.
158

159
** File-local variable changes
160

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

165
*** There are new commands for adding and removing file-local variables:
166 167 168 169
`add-file-local-variable', `delete-file-local-variable',
`add-file-local-variable-prop-line', and
`delete-file-local-variable-prop-line'.

170
*** There are new commands for adding and removing directory-local variables,
171 172 173
and copying them to and from file-local variable lists:
`add-dir-local-variable', `delete-dir-local-variable',
`copy-dir-locals-to-file-locals',
174 175 176
`copy-dir-locals-to-file-locals-prop-line' and
`copy-file-locals-to-dir-locals'.

Chong Yidong's avatar
Chong Yidong committed
177
** Internationalization changes
178

Chong Yidong's avatar
Chong Yidong committed
179 180 181 182 183
*** Unibyte sessions are now considered obsolete.
This refers to the EMACS_UNIBYTE environment variable as well as the
--unibyte, --multibyte, --no-multibyte, and --no-unibyte command line
arguments.  Customizing enable-multibyte-characters and setting
default-enable-multibyte-characters are also deprecated.
184

Chong Yidong's avatar
Chong Yidong committed
185 186 187 188 189 190
*** New coding system `utf-8-hfs'.
This is suitable for default-file-name-coding-system on Mac OS X; see
international/ucs-normalize.el.

** Function arguments in *Help* buffers are now shown in upper-case.
Customize `help-downcase-arguments' to t to show them in lower-case.
191

192 193 194 195 196 197 198 199 200 201 202
** New command `async-shell-command', bound globally to `M-&'.
This executes the command asynchronously, similar to calling `M-!' and
manually adding an ampersand to the end of the command.  With `M-&',
you don't need the ampersand.  The output appears in the buffer
`*Async Shell Command*'.

** When running in a new enough xterm (newer than version 242), Emacs
asks xterm what the background color is and it sets up faces
accordingly for a dark background if needed (the current default is to
consider the background light).

Glenn Morris's avatar
Glenn Morris committed
203 204 205

* Editing Changes in Emacs 23.2

Chong Yidong's avatar
Chong Yidong committed
206
** Kill-ring and selection changes
207

Chong Yidong's avatar
Chong Yidong committed
208 209 210 211
*** 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.
212

Chong Yidong's avatar
Chong Yidong committed
213 214 215
*** When `save-interprogram-paste-before-kill' is non-nil, the kill
commands save the interprogram-paste selection into the kill ring
before doing anything else.  This avoids losing the selection.
216

Chong Yidong's avatar
Chong Yidong committed
217 218
*** When `kill-do-not-save-duplicates' is non-nil, identical
subsequent kills are not duplicated in the `kill-ring'.
Chong Yidong's avatar
Chong Yidong committed
219

Chong Yidong's avatar
Chong Yidong committed
220
** Completion changes
Glenn Morris's avatar
Glenn Morris committed
221

222
*** The new command `completion-at-point' provides mode-sensitive completion.
223

224
*** tab-always-indent set to `complete' lets TAB do completion as well.
225

Chong Yidong's avatar
Chong Yidong committed
226
*** The new completion-style `initials' is available.
Chong Yidong's avatar
Chong Yidong committed
227
For instance, this can complete M-x lch to list-command-history.
228

Chong Yidong's avatar
Chong Yidong committed
229 230 231 232 233
*** The new variable `completions-format' determines how completions
are displayed in the *Completions* buffer.  If you set it to
`vertical', completions are sorted vertically in columns.

** The default value of `blink-matching-paren-distance' is increased.
Juri Linkov's avatar
Juri Linkov committed
234

Chong Yidong's avatar
Chong Yidong committed
235 236 237 238 239 240
** M-n provides more default values in the minibuffer for commands
that read file names.  These include the file name at point (when ffap
is loaded without ffap-bindings), the file name on the current line
(in Dired buffers), and the directory names of adjacent Dired windows
(for Dired commands that operate on several directories, such as copy,
rename, or diff).
241

Chong Yidong's avatar
Chong Yidong committed
242 243 244 245
** M-r is bound to the new `move-to-window-line-top-bottom'.
This moves point to the window center, top and bottom on successive
invocations, in the same spirit as the C-l (recenter-top-bottom)
command.
246

Chong Yidong's avatar
Chong Yidong committed
247 248
** The new variable `recenter-positions' determines the default
cycling order of C-l (`recenter-top-bottom').
249

250 251 252
** The abbrevs file is now a file named abbrev_defs in
user-emacs-directory; but the old location, ~/.abbrev_defs, is used if
that file exists.
253

254 255 256

* Changes in Specialized Modes and Packages in Emacs 23.2

257 258
** The bookmark menu has a narrowing search via bookmark-bmenu-search.

259
** Calc
260

261 262 263
*** The Calc settings file is now a file named calc.el in
user-emacs-directory; but the old location, ~/.calc.el, is used if
that file exists.
264

265 266
*** 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.
267

Chong Yidong's avatar
Chong Yidong committed
268
** Calendar and diary
269

Chong Yidong's avatar
Chong Yidong committed
270 271
*** Fancy diary display is now the default.
If you prefer the simple display, customize `diary-display-function'.
272

Chong Yidong's avatar
Chong Yidong committed
273
*** The diary's fancy display now enables view-mode.
274

Chong Yidong's avatar
Chong Yidong committed
275 276 277 278
*** The command `calendar-current-date' accepts an optional argument
giving an offset from today.

** Desktop
279

Chong Yidong's avatar
Chong Yidong committed
280 281 282 283 284 285 286
*** 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.

287
** Dired
288

289 290
*** The new variable `dired-auto-revert-buffer', if non-nil, causes
Dired buffers to be reverted automatically on revisiting them.
291

292
** DocView
293

Juri Linkov's avatar
Juri Linkov committed
294
*** When `doc-view-continuous' is non-nil, scrolling a line
295 296
on the page edge advances to the next/previous page.

297 298 299 300 301 302 303 304 305 306 307 308 309 310 311
** Elint

*** Elint now uses compilation-mode.

*** Elint can now scan individual files and whole directories,
and can be run in batch mode.

*** Elint does a more thorough initialization, and recognizes more built-in
functions and variables.  Customize `elint-scan-preloaded' if you want
to sacrifice some accuracy for a faster startup.

*** Elint attempts some basic understanding of featurep and (f)boundp tests.

*** Customize `elint-ignored-warnings' to suppress some warnings.

312
** GDB-UI
313

Juanma Barranquero's avatar
Juanma Barranquero committed
314
*** Toolbar functionality for reverse debugging.  Display of STL
Glenn Morris's avatar
Glenn Morris committed
315
collections as watch expressions.  These features require GDB 7.0 or later.
Glenn Morris's avatar
Glenn Morris committed
316

317
** Grep
318

319
*** A new command `zrgrep' searches recursively in gzipped files.
320

321 322 323 324 325
** 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
326 327 328 329
*** 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.

330 331
** LaTeX mode now provides completion (via completion-at-point).

332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347
** Message mode is now the default mode for composing mail.

The default for `mail-user-agent' is now message-user-agent, so the
C-x m (`compose-mail') command uses Message mode instead of Mail mode.

Message mode has been included in Emacs, as part of the Gnus package,
for several years.  It provides several features that are absent in
Mail mode, such as MIME handling.

*** If the user has not customized mail-user-agent, `compose-mail'
checks for Mail mode customizations, and issues a warning if these
customizations are found.  This alerts users who may otherwise be
unaware that their mail configuration has changed.

To disable this check, set compose-mail-user-agent-warnings to nil.

348 349 350 351 352
** The default value of mail-interactive is t, since Emacs 23.1.
(This was not announced at the time.)  It means that when sending mail,
Emacs will wait for the process sending mail to return.  If you
experience delays when sending mail, you may wish to set this to nil.

353 354
** nXML mode is now the default for editing XML files.

355 356 357
** pcomplete provides a new command `pcomplete-std-completion' which
is similar to `pcomplete' but using the standard completion UI code.

358
** Shell (and other comint modes)
359

360
*** M-s is no longer bound to `comint-next-matching-input'.
361

362 363
*** M-r is now bound to `comint-history-isearch-backward-regexp'.
This starts an incremental search of the comint/shell input history.
364

365
*** ansi-color is now enabled by default in Shell mode.
366 367 368
To disable it, set ansi-color-for-comint-mode to nil.

** Tramp
369

370 371 372
*** New connection methods "rsyncc", "imap" and "imaps".
On systems which support GVFS-Fuse, Tramp offers also the new
connection methods "dav", "davs", "obex" and "synce".
373

374
** VC and related modes
375

376 377 378 379
*** When using C-x v v or C-x v i on a unregistered file that is in a
directory not controlled by any VCS, ask the user what VC backend to
use to create a repository, create a new repository and register the
file.
380

381 382 383
*** New command `vc-root-print-log', bound to `C-x v L'.
This displays a `*vc-change-log*' buffer showing the history of the
version-controlled directory tree as a whole.
384

385 386 387
*** New command `vc-root-diff', bound to `C-x v D'.
This is similar to `vc-diff', but compares the entire directory tree
of the current VC directory with its working revision.
388

389 390 391 392 393 394
*** `C-x v l' and `C-x v L' do not show the full log by default.
The number of entries shown can be chosen interactively with a prefix
argument, or by customizing vc-log-show-limit.  The `*vc-change-log*'
buffer now contains buttons at the end of the buffer, which can be
used to increase the number of entries shown.  RCS, SCCS, and CVS do
not support this feature.
395

396 397 398 399
*** vc-annotate supports annotations through file copies and renames,
it displays the old names for the files and it can show logs/diffs for
the corresponding lines.  Currently only Git and Mercurial take
advantage of this feature.
400

401 402 403
*** The log command in vc-annotate can display a single log entry
instead of redisplaying the full log.  The RCS, CVS and SCCS VC
backends do not support this.
404

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

407
*** Diff and log operations can be used from Dired buffers.
408

Dan Nicolaescu's avatar
Dan Nicolaescu committed
409 410
*** vc-git changes

411 412 413 414 415
**** The short log format for git makes use of the graph display,
so it's not supported on git versions earlier than 1.5.6.

**** vc-dir uses the --relative option of git, and so requires at least
git version 1.5.5.
Dan Nicolaescu's avatar
Dan Nicolaescu committed
416

Glenn Morris's avatar
Glenn Morris committed
417 418 419
**** Support for operating with stashes has been added to vc-dir:
the stash list is displayed in the *vc-dir* header, stashes can be
created, removed, applied and their content displayed.
420

421 422
*** vc-bzr supports operating with shelves: the shelve list is
displayed in the *vc-dir* header, shelves can be created, removed and applied.
423

424 425 426
*** 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.

427
** Miscellaneous
428

Juri Linkov's avatar
Juri Linkov committed
429 430 431 432 433 434 435
*** Interactively `multi-isearch-buffers' and `multi-isearch-buffers-regexp'
read buffer names to search, one by one, ended with RET.  With a prefix
argument, they ask for a regexp, and search in buffers whose names match
the specified regexp.  Interactively `multi-isearch-files' and
`multi-isearch-files-regexp' read file names to search, one by one,
ended with RET.  With a prefix argument, they ask for a wildcard, and
search in file buffers whose file names match the specified wildcard.
436

437
*** Autorevert Tail mode now works also for remote files.
438

439
*** The new eshell built-in commands `su' and `sudo' support Tramp.
440 441
Thus, they change `default-directory' to reflect the new user id, and
let commands run under that user's permissions.  This works even when
442
`default-directory' is already remote.  Calling the external commands
443 444 445 446 447 448 449
is possible via `*su' or `*sudo', respectively.

** Obsolete packages

*** sym-comp.el is now obsolete, superseded by completion-at-point.

*** lucid.el and levents.el are now obsolete.
450

Steve Yegge's avatar
Steve Yegge committed
451 452 453

* New Modes and Packages in Emacs 23.2

454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478
** CEDET (the Collection of Emacs Development Tools) is now in Emacs.
This is a collection of packages to aid with using Emacs as an IDE
(integrated development environment):

*** The Semantic package allows the use of parsers to intelligently
edit and navigate source code.  Parsers for C/C++, Java, Javascript,
and several other languages are included by default, and Semantic can
also interface with external tools such as GNU Global and GNU Idutils.

To enable Semantic, use the global minor mode `semantic-mode'.
See the Semantic manual for details.

*** EDE (Emacs Development Environment) is a package for managing code
projects, including features such as automatic Makefile generation.

To enable EDE, use the minor mode `global-ede-mode'.
See the EDE manual for details.

*** SRecode is a library for recoding Semantic tags back into source
code.  It is currently used by some parts of Semantic and EDE; in the
future, it may be used for code generation features.

*** The EIEIO library implements a subset of the Common Lisp Object
System (CLOS).  It is used by the other CEDET packages.

Stefan Monnier's avatar
Stefan Monnier committed
479
** mpc.el is a front end for the Music Player Daemon.  Run it with M-x mpc.
Chong Yidong's avatar
Chong Yidong committed
480

Stefan Monnier's avatar
Stefan Monnier committed
481 482
** htmlfontify.el turns a fontified Emacs buffer into an HTML page.

483
** js.el is a new major mode for JavaScript files.
484

485 486
** imap-hash.el is a new library to address IMAP mailboxes as hashtables.

487 488 489

* Incompatible Lisp Changes in Emacs 23.2

490 491 492
** The Lisp reader turns integers that are too large/small into floats.
For instance, on machines where `536870911' is the largest integer,
reading `536870912' gives the floating-point object `536870912.0'.
Chong Yidong's avatar
Chong Yidong committed
493 494 495

This change only concerns the Lisp reader; it does not affect how
actual integer objects overflow.
496

497 498 499 500 501 502 503 504 505 506 507 508
** Several obsolete functions removed.
The functions have been obsolete since Emacs 19, and are unlikely to
be in use:

  time-stamp-month-dd-yyyy, time-stamp-dd/mm/yyyy, time-stamp-mon-dd-yyyy
  time-stamp-dd-mon-yy, time-stamp-yy/mm/dd, time-stamp-yyyy/mm/dd,
  time-stamp-yyyy-mm-dd, time-stamp-yymmdd, time-stamp-hh:mm:ss,
  time-stamp-hhmm, baud-rate

** Support for generating Emacs 18 compatible bytecode (by setting
the variable `byte-compile-compatibility') has been removed.

Glenn Morris's avatar
Glenn Morris committed
509 510 511 512 513 514 515
** In image-mode.el `image-mode-maybe' is obsolete.
Instead, you can either use `image-mode' (which displays an image file
as the actual image initially), or `image-mode-as-text' (when you want
to display an image file as text initially).  `image-mode-as-text' is a
combination of a non-image mode from `auto-mode-alist' (or Fundamental
mode) and `image-minor-mode'.  `image-minor-mode' provides a `C-c C-c'
key binding to toggle image display.
516 517
`image-toggle-display-text' removes image properties.
`image-toggle-display-image' adds image properties.
Glenn Morris's avatar
Glenn Morris committed
518
`image-toggle-display' toggles between `image-mode-as-text' and `image-mode'.
519

520 521

* Lisp changes in Emacs 23.2
522

523 524
** All the default-FOO variables that hold the default value of the FOO
variable, are now declared obsolete.
525

526 527
** 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.
528

Chong Yidong's avatar
Chong Yidong committed
529
** Frame parameter changes
530

Chong Yidong's avatar
Chong Yidong committed
531 532
*** You can give the `fullscreen' frame parameter the value `maximized'.
This maximizes the frame.
533

Chong Yidong's avatar
Chong Yidong committed
534 535 536
*** The new frame parameter `sticky' makes Emacs frames sticky in
virtual desktops.

537
** Completion changes
538

539
*** completion-base-size is obsoleted by completion-base-position.
540 541 542 543
This change causes a few backward incompatibilities, mostly with
choose-completion-string-functions where the `mini-p' argument has
been replaced by a `base-position' argument, and where the `base-size'
argument is now always nil.
544

545 546
*** New function `completion-in-region' to use the standard completion
facilities on a particular region of text.
547

548
*** The 4th arg to all-completions (aka hide-spaces) is declared obsolete.
549

550 551 552 553
*** completion-annotate-function specifies how to compute annotations
for completions displayed in *Completions*.

** Minibuffer changes
554

555 556 557 558 559 560
*** read-file-name-predicate is obsolete.  It was used to pass the predicate
to read-file-name-internal because read-file-name-internal abused its `pred'
argument to pass the current directory, but this hack is not needed
any more.

** Changes to file-manipulation functions
561

562
*** `delete-directory' has an optional parameter RECURSIVE.
563

564 565
*** New function `copy-directory', which copies a directory recursively.

566 567
** called-interactively-p now takes one argument and replaces interactive-p
which is now marked obsolete.
568

569 570
** New function set-advertised-calling-convention makes it possible
to obsolete arguments as well as make some arguments mandatory.
571

572 573 574 575 576
** You can control which binding is preferentially shown in menus and
docstrings by adding a `:advertised-binding' property to the corresponding
command's symbol.  That property can hold a single binding or a list
of bindings.

577
** Network and process changes
578

579
*** start-process-shell-command and start-file-process-shell-command
Glenn Morris's avatar
Glenn Morris committed
580
now only take a single `command' argument.
581

582 583 584
*** The new variable `process-file-side-effects' should be set to nil
if a `process-file' call does not change a remote file.  This allows
file name handlers such as Tramp to optimizations.
585

586
*** make-network-process can now also create `seqpacket' Unix sockets.
587 588

** Loading changes
589

590
*** eval-next-after-load is obsolete.
591

592 593 594
*** New hook `after-load-functions' run after loading an Elisp file.

** Byte compilation changes
595

596 597 598
*** Changing the file-names generated by byte-compilation by redefining
the function `byte-compile-dest-file' before loading bytecomp.el is obsolete.
Instead, customize byte-compile-dest-file-function.
599

600 601 602 603 604
*** `byte-compile-warnings' has new members, `constants' and `suspicious'.

** New macro with-silent-modifications to tweak text properties without
affecting the buffer's modification state.

605 606 607
** Hash tables have a new printed representation that is readable.
The feature `hashtable-print-readable' identifies this new
functionality.
608

609
** New functions for performing Unicode normalization:
610 611 612 613 614 615
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.
Stefan Monnier's avatar
.  
Stefan Monnier committed
616

617 618
** Face aliases can now be marked as obsolete, using the macro
`define-obsolete-face-alias'.
619

Glenn Morris's avatar
Glenn Morris committed
620 621
** New function `window-full-height-p', analogous to the full-width version.

622

Chong Yidong's avatar
Chong Yidong committed
623 624 625 626
* Changes in Emacs 23.2 on non-free operating systems

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

628

629
* Installation Changes in Emacs 23.1
630

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

Chong Yidong's avatar
Chong Yidong committed
635 636
** New font code.
Fonts are handled by new code capable of dealing with multiple font
637
backends.  This uses the freetype and fontconfig libraries.
638

Chong Yidong's avatar
Chong Yidong committed
639 640
*** 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
641

Chong Yidong's avatar
Chong Yidong committed
642 643 644 645 646 647 648 649 650
*** 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.
651

Chong Yidong's avatar
Chong Yidong committed
652
** Changes to image support
653

Chong Yidong's avatar
Chong Yidong committed
654
*** configure now checks for libgif before libungif when searching for
655
a GIF library.
656

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

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

Juanma Barranquero's avatar
Juanma Barranquero committed
661
** New NeXTSTEP-based port.
Glenn Morris's avatar
Glenn Morris committed
662
This provides support for GNUstep (via the GNUstep libraries) and Mac
Michael Albinus's avatar
Michael Albinus committed
663
OS X (via the Cocoa libraries).
664

Glenn Morris's avatar
Glenn Morris committed
665
Specify --with-ns to configure for this.  By default, a self-contained
666 667 668
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
669 670 671

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

Chong Yidong's avatar
Chong Yidong committed
673 674
** The new configuration option "--with-dbus" enables D-Bus language
bindings for Emacs.
675

676 677
** Support for many obsolete platforms has been removed.
See the list at the end of etc/MACHINES for details.
678

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

Chong Yidong's avatar
Chong Yidong committed
681
*** Support for Sun windows has been removed.
682

Chong Yidong's avatar
Chong Yidong committed
683
*** The `emacstool' utility has been removed.
Chong Yidong's avatar
Chong Yidong committed
684

Chong Yidong's avatar
Chong Yidong committed
685
** The following platforms will be removed in a future Emacs version:
686 687
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
688

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

691
*** Old FreeBSD, NetBSD, and OpenBSD systems based on the COFF
Juanma Barranquero's avatar
Juanma Barranquero committed
692
executable format.
Chong Yidong's avatar
Chong Yidong committed
693 694 695

*** Solaris versions 2.6 and below.

696 697 698 699
*** Solaris on IBM RS6000 machines.

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

700 701
*** Unixware on non-x86 machines.

702 703
*** Platforms not supporting shared libraries (i.e., requiring the
NO_SHARED_LIBS compilation flag).
Chong Yidong's avatar
Chong Yidong committed
704

705 706 707 708
** 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
709 710
** The refcards are now shipped as PDF files.

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

Chong Yidong's avatar
Chong Yidong committed
714 715 716
** 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
717 718 719

* Changes in Emacs 23.1

Chong Yidong's avatar
Chong Yidong committed
720
** Improved X Window System support
721

Chong Yidong's avatar
Chong Yidong committed
722 723 724 725 726
*** 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).
727 728
There may be problems if a display exits unexpectedly and Emacs is compiled
with Gtk+, see etc/PROBLEMS.
729 730 731

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

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

738
**** emacsclient starts emacs in daemon mode and connects to it when
739 740
--alternate-editor="" is used (or when the evironment variable
ALTERNATE_EDITOR is set to "") and emacsclient cannot connect to an
741 742
emacs server.

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

Chong Yidong's avatar
Chong Yidong committed
746 747 748
*** 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
749 750
http://standards.freedesktop.org/xembed-spec/xembed-spec-latest.html
for details about XEmbed.
751

Chong Yidong's avatar
Chong Yidong committed
752 753 754
*** 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
755 756
the X Window System, such as Compiz, Beryl and Compiz Fusion, on Mac
OS X, or on Windows 2000 and later versions of Windows.
757 758

The alpha parameter should be an integer between 0 (transparent) and
Chong Yidong's avatar
Chong Yidong committed
759 760
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
761
active frame and INACTIVE is the opacity of non-active frames.
762

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

Chong Yidong's avatar
Chong Yidong committed
766
** Internationalization changes
767

Chong Yidong's avatar
Chong Yidong committed
768 769
*** 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
770

Chong Yidong's avatar
Chong Yidong committed
771
The internal encoding used for buffers and strings is now
772 773 774 775
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
776

Chong Yidong's avatar
Chong Yidong committed
777 778 779
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,
780 781 782 783
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.
784

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

Chong Yidong's avatar
Chong Yidong committed
787 788 789
*** 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
790

Chong Yidong's avatar
Chong Yidong committed
791 792 793
*** There are new language environments for Chinese-GBK,
Chinese-GB18030, Khmer, Bengali, Punjabi, Gujarati, Oriya, Telugu,
Sinhala, and TaiViet.
794

Chong Yidong's avatar
Chong Yidong committed
795 796
*** The minor modes unify-8859-on-encoding-mode and
unify-8859-on-decoding-mode are obsolete.
797

798 799 800
*** `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.
801

802 803 804 805 806
*** 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
807
** Emacs now supports serial port access on GNU/Linux, Unix, and
808 809 810
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.
811

Chong Yidong's avatar
Chong Yidong committed
812
** Menu Bar changes
813

Chong Yidong's avatar
Chong Yidong committed
814 815 816 817 818
*** 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.
819

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

823 824 825
*** 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).
826

827 828 829
*** 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
830
the new word wrapping behavior (see Editing Changes, below).
831

Dan Nicolaescu's avatar
Dan Nicolaescu committed
832 833 834 835
*** 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
836
** Mode-line changes
837

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

Chong Yidong's avatar
Chong Yidong committed
841 842
*** 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.
843

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

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

Dan Nicolaescu's avatar
Dan Nicolaescu committed
849 850 851
*** 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.

852 853
** 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
854
and directories will then be sent to the Recycle Bin on Windows, and
855 856
to `trash-directory' on other systems.

Chong Yidong's avatar
Chong Yidong committed
857
** Directory-local variables can now be defined.
858 859 860
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'.
861

862 863 864 865 866 867 868
** 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.

869

870
* Startup Changes in Emacs 23.1
871

872 873 874 875 876 877
** 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.

878 879 880 881
** New user option `initial-buffer-choice' specifies what to display
after starting Emacs: startup screen, *scratch* buffer, visiting a
file or directory.

882 883 884 885
** 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.
886 887

** The abbrev file is no longer read at startup in batch mode.
888 889 890 891 892 893

** 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.)
894

895
* Incompatible Editing Changes in Emacs 23.1
Kim F. Storm's avatar
Kim F. Storm committed
896

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

900 901 902 903
** 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.

904 905 906 907
** 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
908 909
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'.
910

Juri Linkov's avatar
Juri Linkov committed
911 912 913 914 915 916 917
** 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'.

918 919 920
** 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.
921

Reiner Steib's avatar
Reiner Steib committed
922
** The following input methods were removed in Emacs 22.2, but this was
Juanma Barranquero's avatar
Juanma Barranquero committed
923
not advertised: danish-alt-postfix, esperanto-alt-postfix,
Reiner Steib's avatar
Reiner Steib committed
924 925 926 927
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.
928

Richard M. Stallman's avatar
Richard M. Stallman committed
929

930
* Editing Changes in Emacs 23.1
Richard M. Stallman's avatar
Richard M. Stallman committed
931