]> code.delx.au - gnu-emacs/blob - etc/NEWS
Remove all references to buffer-file-type and related features.
[gnu-emacs] / etc / NEWS
1 GNU Emacs NEWS -- history of user-visible changes.
2
3 Copyright (C) 2010-2013 Free Software Foundation, Inc.
4 See the end of the file for license conditions.
5
6 Please send Emacs bug reports to bug-gnu-emacs@gnu.org.
7 If possible, use M-x report-emacs-bug.
8
9 This file is about changes in Emacs version 24.
10
11 See files NEWS.23, NEWS.22, NEWS.21, NEWS.20, NEWS.19, NEWS.18,
12 and NEWS.1-17 for changes in older Emacs versions.
13
14 You can narrow news to a specific version by calling `view-emacs-news'
15 with a prefix argument or by typing C-u C-h C-n.
16
17 Temporary note:
18 +++ indicates that the appropriate manual has already been updated.
19 --- means no change in the manuals is called for.
20 When you add a new item, please add it without either +++ or ---
21 so we will look at it and add it to the manual.
22
23 \f
24 * Installation Changes in Emacs 24.4
25
26 ** Emacs can be compiled with POSIX ACL support.
27 This happens by default if a suitable support library is found at
28 build time, like libacl on GNU/Linux. To prevent this, use the
29 configure option `--without-acl'.
30
31 * Startup Changes in Emacs 24.4
32 * Changes in Emacs 24.4
33
34 +++
35 ** `apropos-variable' is now `apropos-user-option'
36 `apropos-user-option' shows all user options while `apropos-variable'
37 shows all variables. When called with a universal prefix argument,
38 the two commands swap their behaviors. When `apropos-do-all' is
39 non-nil, they output the same results.
40
41 +++
42 ** `eval-defun' on an already defined defcustom calls the :set function,
43 if there is one.
44
45 ** The option `set-mark-default-inactive' has been deleted.
46 This unfinished feature was introduced by accident in Emacs 23.1;
47 simply disabling Transient Mark mode does the same thing.
48
49 ** `initial-buffer-choice' can now specify a function to set up the
50 initial buffer.
51
52 ** ACL support has been added.
53 +++
54 *** Emacs preserves the ACL entries of files when backing up.
55 +++
56 *** New functions `file-acl' and `set-file-acl' get and set the ACL
57 entries of a file. On GNU/Linux, the POSIX ACL interface is used via
58 libacl. On MS-Windows, the NT Security APIs are used to emulate the
59 POSIX ACL interfaces.
60
61 ** New option `scroll-bar-adjust-thumb-portion'.
62 Available only on X, this option allows to control over-scrolling
63 using the scroll bar (i.e. dragging the thumb down even when the end
64 of the buffer is visible).
65
66 ** Nextstep (GNUstep / Mac OS X) port
67
68 *** Improved fullscreen support.
69 Both native (>= OSX 10.7) and "old style" fullscreen are supported.
70 Customize ns-use-native-fullscreen to change style. For >= 10.7
71 native is the default.
72
73 * Editing Changes in Emacs 24.4
74
75 ** New commands `toggle-frame-fullscreen' and `toggle-frame-maximized',
76 bound to <f11> and M-<f10>, respectively.
77
78 \f
79 * Changes in Specialized Modes and Packages in Emacs 24.4
80
81 ** Delphi mode is now called OPascal mode.
82 *** All delphi-* variables and functions have been renamed to opascal-*.
83 *** `delphi-newline-always-indents' is not supported any more
84 use `electric-indent-mode' instead.
85 *** `delphi-tab' is gone, replaced by `indent-for-tab-command'.
86
87 ** jit-lock-debug-mode lets you use the debuggers on code run via jit-lock.
88
89 ** completing-read-multiple's separator can now be a regexp.
90 The default separator is changed to allow surrounding spaces around the comma.
91
92 ** Battery
93
94 *** Battery information via the BSD `apm' utility is now supported.
95
96 ** cl-lib
97
98 *** New macro cl-tagbody.
99
100 +++
101 *** letf is now just an alias for cl-letf.
102
103 ** Calc
104
105 *** Calc by default now uses the Gregorian calendar for all dates, and
106 uses January 1, 1 AD as its day number 1. Previously Calc used the
107 Julian calendar for dates before September 14, 1752, and it used
108 December 31, 1 BC as its day number 1; the new scheme is more
109 consistent with Calendar's calendrical system and day numbering.
110
111 *** The new variable `calc-gregorian-switch' lets you configure the
112 date when Calc switches from the Julian to the Gregorian calendar.
113 Nil, the default value, means to always use the Gregorian calendar.
114 The value (YEAR MONTH DAY) means to start using the Gregorian calendar
115 on the given date.
116
117 *** Support for ISO 8601 dates.
118
119 ** ERC
120
121 *** New option `erc-accidental-paste-threshold-seconds'.
122 If set to a number, this can be used to avoid accidentally paste large
123 amounts of data into the ERC input.
124
125 ** Icomplete is a bit more like IDO.
126 *** key bindings to navigate through and select the completions.
127 *** The icomplete-separator is customizable, and its default has changed.
128 *** Removed icomplete-show-key-bindings.
129
130 ** Image mode
131
132 *** New commands `n' (`image-next-file') and `p' (`image-previous-file')
133 visit the next image file and the previous image file in the same
134 directory, respectively.
135
136 ---
137 *** The command `image-mode-fit-frame' deletes other windows.
138 When toggling, it restores the frame's previous window configuration.
139 It also has an optional frame argument, which can be used by Lisp
140 callers to fit the image to a frame other than the selected frame.
141
142 ** Isearch
143
144 *** `C-x 8 RET' in Isearch mode reads a character by its Unicode name
145 and adds it to the search string.
146
147 ** MH-E has been updated to MH-E version 8.4.
148 See MH-E-NEWS for details.
149
150 ---
151 ** The unrmail command converts from BABYL to mboxrd rather than mboxo.
152 Customize `unrmail-mbox-format' to change this.
153
154 ---
155 ** Similarly, customize `rmail-mbox-format' to influence some minor aspects
156 of how Rmail displays non-MIME messages.
157
158 +++
159 ** New function `ses-rename-cell' to give SES cells arbitrary names.
160
161 ** trace-function was largely rewritten.
162 New features include:
163 - no prompting for the destination buffer, unless a prefix-arg was used.
164 - additionally to prompting for a destination buffer, when a prefix-arg is
165 used, the user can enter a "context", i.e. Lisp expression whose value at the
166 time the function is entered/exited will be printed along with the function
167 name and arguments. Useful to trace the value of (current-buffer) or
168 (point) when the function is invoked.
169
170 ** New command `delete-duplicate-lines' has two types of operation:
171 when its arg ADJACENT is non-nil (when called interactively with C-u C-u)
172 it works like the utility `uniq'. Otherwise by default it deletes
173 duplicate lines everywhere in the region without regard to adjacency.
174
175 ** New `cycle-spacing' command allows cycling between having just one
176 space, no spaces, or reverting to the original spacing. Like
177 `just-one-space' command it can handle or ignore newlines and
178 leave different number of spaces.
179
180 ** Tramp
181 +++
182 *** New connection method "adb", which allows to access Android
183 devices by the Android Debug Bridge. The variable `tramp-adb-sdk-dir'
184 must be set to the Android SDK installation directory.
185 +++
186 *** Handlers for `file-acl' and `set-file-acl' for remote machines
187 which support POSIX ACLs.
188
189 ** Woman
190
191 *** The commands `woman-default-faces' and `woman-monochrome-faces'
192 are obsolete. Customize the `woman-* faces instead.
193
194 ** Obsolete packages:
195
196 *** longlines.el is obsolete; use visual-line-mode instead.
197
198 *** terminal.el is obsolete; use term.el instead.
199
200 \f
201 * New Modes and Packages in Emacs 24.4
202 ** New nadvice.el package offering lighter-weight advice facilities.
203 It is layered as:
204 - add-function/remove-function which can be used to add/remove code on any
205 function-carrying place, such as process-filters or `<foo>-function' hooks.
206 - advice-add/advice-remove to add/remove a piece of advice on a named function,
207 much like `defadvice' does.
208
209 * Incompatible Lisp Changes in Emacs 24.4
210
211 ** frame-local variables that affect redisplay do not work any more.
212 More specifically, the redisplay does not bother to check for a frame-local
213 value when looking up variables.
214
215 ** nil and "unbound" are indistinguishable in symbol-function.
216 `symbol-function' never signals `void-function' any more.
217 `fboundp' returns non-nil if the symbol was `fset' to nil.
218
219 ** `defadvice' does not honor the `freeze' flag and cannot advise
220 special-forms any more.
221
222 ** `dolist' in lexical-binding mode does not bind VAR in RESULT any more.
223 VAR was bound to nil which was not tremendously useful and just lead to
224 spurious warnings about an unused var.
225
226 ** The return value of `backup-buffer' has changed.
227 The second argument is no longer an SELinux context, instead it is an
228 alist of extended attributes as returned by the new function
229 `file-extended-attributes'. The attributes can be applied to another
230 file using `set-file-extended-attributes'.
231
232 * Lisp changes in Emacs 24.4
233
234 ** Support for filesystem notifications.
235 Emacs now supports notifications of filesystem changes, such as
236 creation, modification, and deletion of files. This requires the
237 'inotify' API on GNU/Linux systems. On MS-Windows systems, this is
238 supported for Windows XP and newer versions.
239
240 ** Face changes
241
242 *** The `face-spec-set' is now analogous to `setq' for face specs.
243 Its third arg now accepts values specifying exactly which face spec to
244 set (defface, custom, or user spec), and it directly sets the relevant
245 property using the supplied face spec.
246
247 *** Face specs set via Custom themes now replace the `defface' spec
248 rather than inheriting from it (as do face specs set via Customize).
249
250 *** New face characteristic (supports :underline (:style wave))
251 specifies whether or not the terminal can display a wavy line.
252
253 ** time-to-seconds is not obsolete any more.
254 ** New function special-form-p.
255 ** Docstrings can be made dynamic by adding a `dynamic-docstring-function'
256 text-property on the first char.
257
258 ** The `defalias-fset-function' property lets you catch calls to defalias
259 and redirect them to your own function instead of `fset'.
260
261 ** The 9th element returned by `file-attributes' is now unspecified.
262 Formerly, it was t if the file's gid would change if file were deleted
263 and recreated. This value has been inaccurate for years on many
264 platforms, and nobody seems to have noticed or cared.
265
266 ** The function `file-ownership-preserved-p' now has an optional
267 argument GROUP which causes it check for file group too. This can be
268 used in place of the 9th element of `file-attributes'.
269
270 ** New functions `group-gid' and `group-real-gid'.
271
272 ** The 6th argument to `copy-file' has been renamed to
273 `preserve-extended-attributes' as it now handles both SELinux context
274 and ACL entries.
275
276 * Changes in Emacs 24.4 on non-free operating systems
277
278 +++
279 ** The "generate a backtrace on fatal error" feature now works on MS Windows.
280 The backtrace is written to the 'emacs_backtrace.txt' file in the
281 directory where Emacs was running.
282
283 +++
284 ** The variable `buffer-file-type' is no longer supported.
285 Setting it has no effect, and %t in the mode-line format is ignored.
286 Likewise, `file-name-buffer-file-type-alist' is now obsolete, and
287 modifying it has no effect.
288
289 \f
290 * Installation Changes in Emacs 24.3
291
292 ** The default X toolkit is now Gtk+ version 3.
293 If you don't pass `--with-x-toolkit' to configure, or if you use
294 `--with-x-toolkit=gtk' or `--with-x-toolkit=yes', configure will try
295 to build with Gtk+ version 3, and if that fails, try Gtk+ version 2.
296 You can explicitly require a specific version by passing
297 `--with-x-toolkit=gtk2' or `--with-x-toolkit=gtk3' to configure.
298
299 ** New configure option `--enable-link-time-optimization', to utilize
300 an appropriate feature provided by GCC since version 4.5.0.
301
302 ** New configure option `--without-all' to disable most of the optional
303 features (image support, etc.) that are normally enabled by default.
304
305 ** New configure option `--enable-gcc-warnings' (for developing/debugging
306 Emacs). If building with GCC, this enables compile-time checks that
307 warn/give errors about possibly-questionable C code. On a recent GNU
308 system there should be no warnings; on older and on non-GNU systems
309 the results may be useful to developers.
310
311 ** The configure option `--enable-use-lisp-union-type' has been
312 renamed to `--enable-check-lisp-object-type', as the resulting
313 Lisp_Object type no longer uses a union to implement the compile time
314 check that this option enables.
315
316 ** The configure option `--disable-maintainer-mode' has been removed,
317 as it was confusingly-named and rarely useful.
318
319 ** The configure options `--program-prefix', `--program-suffix', and
320 `--program-transform-name' apply to more than just the installed
321 binaries. Now they also affect the man pages, icons, and the
322 etc/emacs.desktop file; but not the info pages, since this would break
323 links between the various manuals.
324
325 ** You can use `NO_BIN_LINK=t make install' to prevent the installation
326 overwriting "emacs" in the installation bin/ directory with a link
327 to "emacs-VERSION".
328
329 ** Emacs uses libtinfo in preference to libncurses, if available.
330
331 ** On FreeBSD and NetBSD, configure no longer adds /usr/local/lib and
332 /usr/pkg/lib to the linker search path. You must add them yourself if
333 you want them.
334
335 ** The standalone scripts `rcs-checkin' and `vcdiff' have been removed
336 (from the bin and libexec directories, respectively). The former is
337 no longer relevant, the latter is replaced by lisp (in vc-sccs.el).
338
339 \f
340 * Startup Changes in Emacs 24.3
341
342 ** Emacs no longer searches for `leim-list.el' files beneath the standard
343 lisp/ directory. There should not be any there anyway. If you have
344 been adding them there, put them somewhere else; e.g., site-lisp.
345
346 ** The `--no-site-lisp' command line option now works for Nextstep builds.
347
348 \f
349 * Changes in Emacs 24.3
350
351 ** Help
352
353 *** `C-h f' (`describe-function') can now perform autoloading.
354 When this command is called for an autoloaded function whose docstring
355 contains a key substitution construct, that function's library is
356 automatically loaded, so that the documentation can be shown
357 correctly. To disable this, set `help-enable-auto-load' to nil.
358
359 *** `C-h f' now reports previously-autoloaded functions as "autoloaded",
360 even after their associated libraries have been loaded (and the
361 autoloads have been redefined as functions).
362
363 ** ImageMagick
364
365 *** Images displayed via ImageMagick now support transparency and the
366 :background image specification property.
367
368 *** When available, ImageMagick support is automatically enabled.
369 It is no longer necessary to call `imagemagick-register-types'
370 explicitly to install ImageMagick image types; that function is called
371 automatically at startup, or when customizing an imagemagick- option.
372
373 *** Setting `imagemagick-types-inhibit' to t now disables the use of
374 ImageMagick to view images. (You must call `imagemagick-register-types'
375 afterwards if you do not use customize to change this.)
376
377 *** The new variable `imagemagick-enabled-types' also affects which
378 ImageMagick types are treated as images. The function
379 `imagemagick-filter-types' returns the list of types that will be
380 treated as images.
381
382 ** Minibuffer
383
384 *** In minibuffer filename prompts, `C-M-f' and `C-M-b' now move to the
385 next and previous path separator, respectively.
386
387 *** `minibuffer-electric-default-mode' can shorten "(default ...)" to "[...]"
388 in minibuffer prompts. Just set `minibuffer-eldef-shorten-default'
389 non-nil before enabling the mode.
390
391 ** Mode line
392
393 *** New option `mode-line-default-help-echo' specifies the help text
394 (shown in a tooltip or in the echo area) for any part of the mode line
395 that does not have its own specialized help text.
396
397 *** You can now click mouse-3 in the coding system indicator to invoke
398 `set-buffer-file-coding-system'.
399
400 ** Server and client
401
402 *** emacsclient now obeys string values for `initial-buffer-choice',
403 if it is told to open a new frame without specifying any file to visit
404 or expression to evaluate.
405
406 *** New option `server-auth-key' specifies a shared server key.
407
408 ** Emacs now generates backtraces on fatal errors.
409 On encountering a fatal error, Emacs now outputs a textual description
410 of the fatal signal, and a short backtrace on platforms like glibc
411 that support backtraces.
412
413 ** `C-x C-q' is now bound to the new minor mode `read-only-mode'.
414 This minor mode replaces `toggle-read-only', which is now obsolete.
415
416 ** Most `y-or-n' prompts now allow you to scroll the selected window.
417 Typing `C-v' or `M-v' at a y-or-n prompt scrolls forward or backward
418 respectively, without exiting from the prompt.
419
420 ** In the Package Menu, newly-available packages are listed as "new",
421 and sorted above the other "available" packages by default.
422
423 ** If your Emacs was built from a bzr checkout, the new variable
424 `emacs-bzr-version' contains information about the bzr revision used.
425
426 ** New option `create-lockfiles' specifies usage of lockfiles.
427 It defaults to t. Changing it to nil inhibits the creation of lock
428 files (use this with caution).
429
430 ** New option `enable-remote-dir-locals', if non-nil, allows directory-local
431 variables on remote hosts.
432
433 ** The entry for PCL-CVS has been removed from the Tools menu.
434 The PCL-CVS commands are still available via the keyboard.
435
436 ** Using "unibyte: t" in Lisp source files is obsolete.
437 Use "coding: raw-text" instead.
438
439 ** Internationalization
440
441 *** New language environment: Persian.
442
443 *** New input method `vietnamese-vni'.
444
445 ** Nextstep (GNUstep / Mac OS X) port
446
447 *** Support for fullscreen and the frame parameter fullscreen.
448
449 *** A file dialog is used for open/save operations initiated from the
450 menu/toolbar.
451
452 \f
453 * Editing Changes in Emacs 24.3
454
455 ** Search and Replace
456
457 *** Non-regexp Isearch now performs "lax" space matching.
458 Each sequence of spaces in the supplied search string may match any
459 sequence of one or more whitespace characters, as specified by the
460 variable `search-whitespace-regexp'. (This variable is also used by a
461 similar existing feature for regexp Isearch.)
462
463 *** New Isearch command `M-s SPC' toggles lax space matching.
464 This applies to both ordinary and regexp Isearch.
465
466 *** New option `replace-lax-whitespace'.
467 If non-nil, `query-replace' uses flexible whitespace matching too.
468 The default is nil.
469
470 *** Global `M-s _' starts a symbol (identifier) incremental search,
471 and `M-s _' in Isearch toggles symbol search mode.
472 `M-s c' in Isearch toggles search case-sensitivity.
473
474 ** Navigation commands
475
476 *** New binding `M-g c' for `goto-char'.
477
478 *** New binding `M-g TAB' for `move-to-column'.
479
480 *** `M-g TAB' (`move-to-column') prompts for a column number if called
481 interactively with no prefix arg. Previously, it moved to column 1.
482
483 ** New option `yank-handled-properties' allows processing of text
484 properties on yanked text, in ways that are more general than just
485 removing them (as is done by `yank-excluded-properties').
486
487 ** New option `delete-trailing-lines' specifies whether
488 M-x delete-trailing-whitespace should delete trailing lines at the end
489 of the buffer. It defaults to t.
490
491 ** `C-u M-=' now counts lines/words/characters in the entire buffer.
492
493 ** `C-x 8 RET' is now bound to `insert-char', which is now a command.
494 `ucs-insert' is now an obsolete alias for `insert-char'.
495
496 ** The `z' key no longer has a binding in most special modes.
497 It used to be bound to `kill-this-buffer', but `z' is too easy to
498 accidentally type.
499
500 ** New command `C-x r M-w' (`copy-rectangle-as-kill').
501 It copies the region-rectangle as the last rectangle kill.
502
503 ** Registers
504
505 *** `C-x r +' is now overloaded to invoke `append-to-register'.
506
507 *** New option `register-separator' specifies the register containing
508 the text to put between collected texts for use with
509 M-x append-to-register and M-x prepend-to-register.
510
511 \f
512 * Changes in Specialized Modes and Packages in Emacs 24.3
513
514 ** Common Lisp emulation (CL)
515
516 *** CL's main entry is now (require 'cl-lib).
517 `cl-lib' is like the old `cl' except that it uses the namespace cleanly;
518 i.e., all its definitions have the "cl-" prefix (and internal definitions
519 use the "cl--" prefix).
520
521 If `cl' provided a feature under the name `foo', then `cl-lib'
522 provides it under the name `cl-foo' instead; with the exceptions of the
523 few `cl' definitions that had to use `foo*' to avoid conflicts with
524 pre-existing Elisp entities. These have been renamed to `cl-foo'
525 rather than `cl-foo*'.
526
527 The old `cl' is now deprecated and is mainly just a bunch of aliases that
528 provide the old, non-prefixed names. Some exceptions are listed below:
529
530 *** `cl-flet' is not like `flet' (which is deprecated).
531 Instead it obeys the behavior of Common-Lisp's `flet'.
532 In particular, in cl-flet function definitions are lexically scoped,
533 whereas in flet the scoping is dynamic.
534
535 *** `cl-labels' is slightly different from `labels'.
536 The difference is that it relies on the `lexical-binding' machinery
537 (as opposed to the `lexical-let' machinery used previously) to capture
538 definitions in closures, so such closures will only work if `lexical-binding'
539 is in use.
540
541 *** `cl-letf' is not exactly like `letf'.
542 The only difference is in details that relate to some deprecated usage
543 of `symbol-function' in place forms.
544
545 *** `progv' was rewritten to use the `let' machinery.
546 A side effect is that variables without corresponding values are bound
547 to nil rather than being made unbound.
548
549 *** The following methods of extending `setf' are obsolete
550 (use features from gv.el instead):
551 `define-modify-macro' (use `gv-letplace')
552 `defsetf' (use `gv-define-simple-setter' or `gv-define-setter')
553 `define-setf-expander' (use `gv-define-setter' or `gv-define-expander')
554 `get-setf-method' no longer exists (see "Incompatible Lisp Changes")
555
556 ** Diff mode
557
558 *** Changes are now highlighted using the same color scheme as in
559 modern VCSes. Deletions are displayed in red (new faces
560 `diff-refine-removed' and `smerge-refined-removed', and new definition
561 of `diff-removed'), insertions in green (new faces `diff-refine-added'
562 and `smerge-refined-added', and new definition of `diff-added').
563
564 *** The variable `diff-use-changed-face' defines whether to use the
565 face `diff-changed', or `diff-removed' and `diff-added' to highlight
566 changes in context diffs.
567
568 *** The new command `diff-delete-trailing-whitespace' removes trailing
569 whitespace introduced by a diff.
570
571 ** Ediff now uses the same color scheme as Diff mode.
572
573 ** Python mode
574
575 A new version of python.el, which provides several new features, including:
576 per-buffer shells, better indentation, Python 3 support, and improved
577 shell-interaction compatible with iPython (and virtually any other
578 text based shell).
579
580 *** Some user options have been replaced/renamed, including (old -> new):
581 **** python-indent -> python-indent-offset
582 **** python-guess-indent -> python-indent-guess-indent-offset
583 **** python-pdbtrack-do-tracking-p -> python-pdbtrack-activate
584 **** python-use-skeletons -> python-skeleton-autoinsert
585
586 *** Some user options have been removed, including:
587
588 **** `python-indent-string-contents': Strings are never indented.
589
590 **** `python-honour-comment-indentation':
591 Comments are always considered as indentation markers.
592
593 **** `python-continuation-offset': Indentation is automatically
594 calculated in a pep8 compliant way depending on the context.
595
596 **** `python-shell-prompt-alist', `python-shell-continuation-prompt-alist':
597 Have no direct mapping as the shell interaction is completely different.
598
599 **** `python-python-command', `python-jython-command':
600 Replaced by `python-shell-interpreter'.
601
602 **** `inferior-python-filter-regexp', `python-remove-cwd-from-path',
603 `python-pdbtrack-minor-mode-string', `python-source-modes':
604 No longer relevant.
605
606 *** Some commands have been replaced (old -> new):
607 **** python-insert-class -> python-skeleton-class
608 **** python-insert-def -> python-skeleton-def
609 **** python-insert-for -> python-skeleton-for
610 **** python-insert-if -> python-skeleton-if
611 **** python-insert-try/except -> python-skeleton-try
612 **** python-insert-try/finally -> python-skeleton-try
613 **** python-insert-while -> python-skeleton-while
614 **** python-find-function -> python-nav-jump-to-defun
615 **** python-next-statement -> python-nav-forward-sentence
616 **** python-previous-statement -> python-nav-backward-sentence
617 **** python-beginning-of-defun-function -> python-nav-beginning-of-defun
618 **** python-end-of-defun-function -> python-nav-end-of-defun
619 **** python-send-buffer -> python-shell-send-buffer
620 **** python-send-defun -> python-shell-send-defun
621 **** python-send-region -> python-shell-send-region
622 **** python-send-region-and-go -> emulate with python-shell-send-region
623 and python-shell-switch-to-shell
624 **** python-send-string -> python-shell-send-string
625 **** python-switch-to-python -> python-shell-switch-to-shell
626 **** python-describe-symbol -> python-eldoc-at-point
627
628 ** D-Bus
629
630 *** New variables `dbus-compiled-version' and `dbus-runtime-version'.
631
632 *** The D-Bus object manager interface is implemented.
633
634 *** Variables of type :(u)int32 and :(u)int64 accept floating points,
635 if their value does not fit into Emacs's integer range.
636
637 *** The function `dbus-call-method' is now non-blocking.
638 It can be interrupted by `C-g'. `dbus-call-method-non-blocking' is obsolete.
639
640 *** Signals can also be sent as unicast messages.
641
642 *** The argument list of `dbus-register-signal' has been extended,
643 according to the new match rule types of D-Bus.
644
645 *** `dbus-init-bus' supports private connections.
646
647 *** There is a new function `dbus-setenv'.
648
649 ** `desktop-path' no longer includes the "." directory.
650 Desktop files are now located in ~/.emacs.d by default.
651
652 ** Dired
653
654 *** `dired-do-async-shell-command' executes each file sequentially
655 if the command ends in `;' (when operating on multiple files).
656 Otherwise, it executes the command on each file in parallel.
657
658 *** Typing `M-n' in the minibuffer of `dired-do-chmod', `dired-do-chgrp',
659 `dired-do-chown', and `dired-do-touch' yanks the attributes of the
660 file at point.
661
662 *** When the region is active, `m' (`dired-mark'), `u' (`dired-unmark'),
663 `DEL' (`dired-unmark-backward'), and `d' (`dired-flag-file-deletion')
664 mark/unmark/flag all files in the active region.
665
666 *** The minibuffer default for `=' (`dired-diff) has changed.
667 It is now the backup file for the file at point, if one exists.
668 In Transient Mark mode the default is the file at the active mark.
669
670 *** `M-=' is no longer bound to `dired-backup-diff' in Dired buffers.
671 The global binding for `M-=', `count-words-region' is in effect.
672
673 ** ERC
674
675 *** New module "notifications", which can send a notification when you
676 receive a private message or your nickname is mentioned.
677
678 *** ERC will look up server/channel names via auth-source and use any
679 channel keys found.
680
681 *** New option `erc-lurker-hide-list', similar to `erc-hide-list', but
682 only applies to messages sent by lurkers.
683
684 ** reStructuredText mode
685
686 *** Keybindings (see `C-c C-h'), TAB indentation, filling and auto-filling,
687 fontification, comment handling, and customization have all been revised
688 and improved.
689
690 *** Support for `imenu' and `which-function-mode'.
691
692 *** The reStructuredText syntax is more closely covered.
693 Sphinx support has been improved.
694
695 *** `rst-insert-list' inserts new list or continues existing lists.
696
697 *** A negative prefix argument always works for `rst-adjust'.
698
699 *** The window configuration is reset after displaying a TOC.
700
701 *** The constant `rst-version' describes the rst.el package version.
702
703 ** Shell Script mode
704
705 *** Pairing of parens/quotes uses `electric-pair-mode' instead of skeleton-pair.
706
707 *** `sh-electric-here-document-mode' now controls auto-insertion of here-docs.
708
709 *** `sh-use-smie' lets you choose a new indentation and navigation code.
710
711 ** VHDL mode
712
713 *** The free software compiler GHDL is supported (and now the default).
714
715 *** Support for the VHDL-AMS packages has been added/updated.
716
717 *** Updated to the 2002 revision of the VHDL standard.
718
719 *** Accepts \r and \f as whitespace.
720
721 ** Apropos
722
723 *** The faces used by Apropos are now directly customizable.
724 These faces are named `apropos-symbol', `apropos-keybinding', and so on;
725 see the `apropos' Custom group for details.
726
727 *** The old options whose values specified faces to use have been removed
728 (i.e. `apropos-symbol-face', `apropos-keybinding-face', etc.).
729
730 ** Buffer Menu
731
732 *** This package has been rewritten to use Tabulated List mode.
733
734 *** Option `Buffer-menu-buffer+size-width' is now obsolete.
735 Use `Buffer-menu-name-width' and `Buffer-menu-size-width' instead.
736
737 ** Calc
738
739 *** Algebraic simplification mode is now the default.
740 To restrict to the limited simplifications given by the former
741 default simplification mode, use `m I'.
742
743 ** Calendar
744
745 *** You can customize the header text that appears above each calendar month.
746 See the variable `calendar-month-header'.
747
748 *** New LaTeX calendar style, produced by `cal-tex-cursor-week2-summary'.
749
750 *** The calendars produced by cal-html include holidays.
751 Customize `cal-html-holidays' to change this.
752
753 ** Compile has a new option `compilation-always-kill'.
754
755 ** Customize
756
757 *** `custom-reset-button-menu' now defaults to t.
758
759 *** Non-option variables are never matched in `customize-apropos' and
760 `customize-apropos-options' (i.e., the prefix argument does nothing for
761 these commands now).
762
763 ** Term
764
765 *** The variables `term-default-fg-color' and `term-default-bg-color'
766 are now deprecated in favor of the customizable face `term'.
767
768 *** You can customize how to display ANSI terminal colors and styles
769 by customizing the corresponding `term-color-<COLOR>',
770 `term-color-underline' and `term-color-bold' faces.
771
772 ** Tramp
773
774 *** The syntax has been extended in order to allow ad-hoc proxy definitions.
775
776 *** Remote processes are now also supported on remote MS-Windows hosts.
777
778 ** URL
779
780 *** Structs made by `url-generic-parse-url' have nil `attributes' slot.
781 Previously, this slot stored semicolon-separated attribute-value pairs
782 appended to some imap URLs, but this is not compatible with RFC 3986.
783 So now the `filename' slot stores the entire path and query components,
784 and the `attributes' slot is always nil.
785
786 *** New function `url-encode-url' for encoding a URI string.
787 The `url-retrieve' function now uses this to encode its URL argument,
788 in case that is not properly encoded.
789
790 ** notifications.el supports now version 1.2 of the Notifications API.
791 The function `notifications-get-capabilities' returns the supported
792 server properties.
793
794 ** Flymake uses fringe bitmaps to indicate errors and warnings.
795 See `flymake-fringe-indicator-position', `flymake-error-bitmap' and
796 `flymake-warning-bitmap'.
797
798 ** The FFAP option `ffap-url-unwrap-remote' can now be a list of strings,
799 specifying URL types that should be converted to remote file names at
800 the FFAP prompt. The default is now '("ftp").
801
802 ** New Ibuffer `derived-mode' filter, bound to `/ M'.
803 The old binding for `/ M' (filter by used-mode) is now bound to `/ m'.
804
805 ** New option `mouse-avoidance-banish-position' specifies where the
806 `banish' mouse avoidance setting moves the mouse.
807
808 ** In Perl mode, new option `perl-indent-parens-as-block' causes non-block
809 closing brackets to be aligned with the line of the opening bracket.
810
811 ** In Proced mode, new command `proced-renice' renices marked processes.
812
813 ** New option `async-shell-command-buffer' specifies the buffer to use
814 for a new asynchronous `shell-command' when the default output buffer
815 `*Async Shell Command*' is already in use.
816
817 ** SQL mode has a new option `sql-db2-escape-newlines'.
818 If non-nil, newlines sent to the command interpreter will be escaped
819 by a backslash. The default does not escape the newlines and assumes
820 that the sql statement will be terminated by a semicolon.
821
822 ** New command `tabulated-list-sort', bound to `S' in Tabulated List mode
823 (and modes that derive from it), sorts the column at point, or the Nth
824 column if a numeric prefix argument is given.
825
826 ** `which-func-modes' now defaults to t, so Which Function mode, when
827 enabled, applies to all applicable major modes.
828
829 ** `winner-mode-hook' now runs when the mode is disabled, as well as when
830 it is enabled.
831
832 ** Follow mode no longer works by using advice.
833 The option `follow-intercept-processes' has been removed.
834
835 ** `javascript-generic-mode' is now an obsolete alias for `js-mode'.
836
837 ** Hooks renamed to avoid obsolete "-hooks" suffix:
838 *** semantic-lex-reset-hooks -> semantic-lex-reset-functions
839 *** semantic-change-hooks -> semantic-change-functions
840 *** semantic-edits-new-change-hooks -> semantic-edits-new-change-functions
841 *** semantic-edits-delete-change-hooks -> semantic-edits-delete-change-functions
842 *** semantic-edits-reparse-change-hooks -> semantic-edits-reparse-change-functions
843 *** semanticdb-save-database-hooks -> semanticdb-save-database-functions
844 *** c-prepare-bug-report-hooks -> c-prepare-bug-report-hook
845 *** rcirc-sentinel-hooks -> rcirc-sentinel-functions
846 *** rcirc-receive-message-hooks -> rcirc-receive-message-functions
847 *** rcirc-activity-hooks -> rcirc-activity-functions
848 *** rcirc-print-hooks -> rcirc-print-functions
849 *** dbus-event-error-hooks -> dbus-event-error-functions
850 *** eieio-pre-method-execution-hooks -> eieio-pre-method-execution-functions
851 *** checkdoc-style-hooks -> checkdoc-style-functions
852 *** checkdoc-comment-style-hooks -> checkdoc-comment-style-functions
853 *** archive-extract-hooks -> archive-extract-hook
854 *** filesets-cache-fill-content-hooks -> filesets-cache-fill-content-hook
855 *** hfy-post-html-hooks -> hfy-post-html-hook
856 *** nndiary-request-create-group-hooks -> nndiary-request-create-group-functions
857 *** nndiary-request-update-info-hooks -> nndiary-request-update-info-functions
858 *** nndiary-request-accept-article-hooks -> nndiary-request-accept-article-functions
859 *** gnus-subscribe-newsgroup-hooks -> gnus-subscribe-newsgroup-functions
860
861 ** Obsolete packages
862
863 *** assoc.el
864 In most cases, assoc+member+push+delq work just as well.
865 And in any case it's just a terrible package: ugly semantics, terrible
866 inefficiency, and not namespace-clean.
867 *** bruce.el
868 *** cust-print.el
869 *** ledit.el
870 *** mailpost.el
871 *** mouse-sel.el
872 *** patcomp.el
873
874 \f
875 * Incompatible Lisp Changes in Emacs 24.3
876
877 ** Docstrings starting with `*' no longer indicate user options.
878 Only variables defined using `defcustom' are considered user options.
879 The function `user-variable-p' is now an obsolete alias for
880 `custom-variable-p'.
881
882 ** The return values of `defalias', `defun' and `defmacro' have changed,
883 and are now undefined. For backwards compatibility, `defun' and
884 `defmacro' currently return the name of the newly defined
885 function/macro, but this should not be relied upon.
886
887 ** `random' by default now returns a different random sequence in
888 every Emacs run. Use `(random S)', where S is a string, to set the
889 random seed to a value based on S, in order to get a repeatable
890 sequence in later calls.
891
892 ** If the NEWTEXT arg to `replace-match' contains a substring "\?",
893 that substring is inserted literally even if the LITERAL arg is
894 non-nil, instead of causing an error to be signaled.
895
896 ** `select-window' now always makes the window's buffer current.
897 It does so even if the window was selected before.
898
899 ** The function `x-select-font' can return a font spec, instead of a
900 font name as a string. Whether it returns a font spec or a font name
901 depends on the graphical library.
902
903 ** `face-spec-set' no longer sets frame-specific attributes when the
904 third argument is a frame (that usage was obsolete since Emacs 22.2).
905
906 ** `set-buffer-multibyte' now signals an error in narrowed buffers.
907
908 ** The CL package's `get-setf-method' function no longer exists.
909 Generalized variables are now part of core Emacs Lisp, and implemented
910 differently to the way cl.el used to do it. It is not possible to
911 define a compatible replacement for `get-setf-method'. See the file
912 gv.el for internal details of the new implementation.
913
914 ** The arguments of `dbus-register-signal' are no longer just strings,
915 but keywords or keyword-string pairs. The old argument list will
916 still be supported for Emacs 24.x.
917
918 ** Miscellaneous name changes
919 Some Lisp symbols have been renamed to correct their spelling,
920 or to be more consistent with standard Emacs terminology.
921
922 *** Renamed functions
923 **** hangul-input-method-inactivate -> hangul-input-method-deactivate
924 **** inactivate-input-method -> deactivate-input-method
925 **** quail-inactivate -> quail-deactivate
926 **** robin-inactivate -> robin-deactivate
927 **** viper-inactivate-input-method -> viper-deactivate-input-method
928 **** viper-inactivate-input-method-action ->
929 viper-deactivate-input-method-action
930 **** ucs-input-inactivate -> ucs-input-deactivate
931
932 *** Renamed hooks
933 The old hooks are still supported for backward compatibility, but they
934 are deprecated and will be removed eventually.
935 **** input-method-inactivate-hook -> input-method-deactivate-hook
936 **** robin-inactivate-hook -> robin-deactivate-hook
937 **** quail-inactivate-hook -> quail-deactivate-hook
938
939 *** Renamed variables
940 **** follow-deactive-menu -> follow-inactive-menu
941 **** inactivate-current-input-method-function ->
942 deactivate-current-input-method-function
943
944 ** Some obsolete functions, variables, and faces have been removed:
945 *** `last-input-char', `last-command-char', `unread-command-char'
946 *** `facemenu-unlisted-faces'
947 *** `rmail-decode-mime-charset'
948 *** `iswitchb-read-buffer'
949 *** `sc-version', `sc-submit-bug-report'
950 *** `set-char-table-default'
951 *** `string-to-sequence' (use `string-to-list' or `string-to-vector')
952 *** `compile-internal'
953 *** `modeline'
954 *** `mode-line-inverse-video'
955 *** `follow-mode-off-hook'
956 *** `cvs-commit-buffer-require-final-newline'
957 (use `log-edit-require-final-newline' instead)
958 *** `cvs-changelog-full-paragraphs'
959 (use `log-edit-changelog-full-paragraphs' instead)
960 *** `cvs-diff-ignore-marks', `cvs-diff-buffer-name'
961 *** `vc-ignore-vc-files' (use `vc-handled-backends' instead)
962 *** `vc-master-templates' (use `vc-handled-backends' instead)
963 *** `vc-checkout-carefully'
964
965 \f
966 * Lisp changes in Emacs 24.3
967
968 ** CL-style generalized variables are now in core Elisp.
969 `setf' is autoloaded; `push' and `pop' accept generalized variables.
970 You can define your own generalized variables using `gv-define-simple-setter',
971 `gv-define-setter', etc.
972
973 ** Emacs tries to macroexpand interpreted (non-compiled) files during load.
974 This can significantly speed up execution of non-byte-compiled code,
975 but can also bump into previously unnoticed cyclic dependencies.
976 These are generally harmless: they will simply cause the macro calls
977 to be left for later expansion (as before), but will result in a
978 warning ("Eager macro-expansion skipped due to cycle") describing the cycle.
979 You may wish to restructure your code so this does not happen.
980
981 ** New sampling-based Elisp profiler.
982 Try M-x profiler-start, do some work, and then call M-x profiler-report.
983 When finished, use M-x profiler-stop. The sampling rate can be based on
984 CPU time or memory allocations.
985
986 ** `defun' also accepts a (declare DECLS) form, like `defmacro'.
987 The interpretation of the DECLS is determined by `defun-declarations-alist'.
988
989 ** New macros `setq-local' and `defvar-local'.
990
991 ** Face underlining can now use a wave.
992
993 ** `read-regexp' has a new argument HISTORY; the first argument PROMPT
994 of `read-regexp' accepts a string ending with a colon and space, and its
995 second argument DEFAULTS can be a list of strings accessible via `M-n'
996 in the minibuffer ahead of other hard-coded useful regexp-related values.
997 More commands use `read-regexp' now to read their regexp arguments.
998
999 ** Completion
1000
1001 *** New function `completion-table-with-quoting' to handle completion
1002 in the presence of quoting, such as file completion in shell buffers.
1003
1004 *** New function `completion-table-subvert' to use an existing completion
1005 table, but with a different prefix.
1006
1007 ** Debugger
1008
1009 *** New error type and new function `user-error'.
1010 These do not trigger the debugger.
1011
1012 *** New option `debugger-bury-or-kill', saying what to do with the
1013 debugger buffer when exiting debug.
1014
1015 *** Set `debug-on-message' to enter the debugger when a certain
1016 message is displayed in the echo area. This can be useful when trying
1017 to work out which code is doing something.
1018
1019 *** New var `inhibit-debugger', automatically set to prevent accidental
1020 recursive invocations.
1021
1022 ** Window handling
1023
1024 *** New command `fit-frame-to-buffer' adjusts the frame height to
1025 fit the contents.
1026
1027 *** The command `fit-window-to-buffer' can adjust the frame height
1028 if the new option `fit-frame-to-buffer' is non-nil.
1029
1030 *** New macro `with-temp-buffer-window', similar to
1031 `with-output-to-temp-buffer'.
1032
1033 *** `temp-buffer-resize-mode' no longer resizes windows that have been
1034 reused.
1035
1036 *** New option `switch-to-buffer-preserve-window-point' to restore a
1037 window's point when switching buffers.
1038
1039 *** New display action alist entries `window-height' and `window-width'
1040 specify the size of new windows created by `display-buffer'.
1041
1042 *** New display action alist entry `pop-up-frame-parameters', if
1043 non-nil, specifies frame parameters to give any newly-created frame.
1044
1045 *** New display action alist entry `inhibit-switch-frame', if non-nil,
1046 tells display action functions to avoid changing which frame is
1047 selected.
1048
1049 *** New display action alist entry `previous-window', if non-nil,
1050 specifies window to reuse in `display-buffer-in-previous-window'.
1051
1052 *** New display action functions `display-buffer-below-selected',
1053 and `display-buffer-in-previous-window'.
1054
1055 *** The functions `get-lru-window', `get-mru-window' and `get-largest-window'
1056 now accept a third argument to avoid choosing the selected window.
1057
1058 *** Additional values recognized for option `window-combination-limit'.
1059
1060 *** The following variables are obsolete, as they can be replaced by
1061 appropriate entries in the `display-buffer-alist' function introduced
1062 in Emacs 24.1:
1063 **** `dired-shrink-to-fit'
1064 **** `display-buffer-reuse-frames'
1065 **** `display-buffer-function'
1066 **** `special-display-buffer-names'
1067 **** `special-display-frame-alist'
1068 **** `special-display-function'
1069 **** `special-display-regexps'
1070
1071 ** Time
1072
1073 *** `current-time-string' no longer requires that its argument's year
1074 must be in the range 1000..9999. It now works with any year supported
1075 by the underlying C implementation.
1076
1077 *** `current-time' now returns extended-format time stamps
1078 (HIGH LOW USEC PSEC), where the new PSEC slot specifies picoseconds.
1079 PSEC is typically a multiple of 1000 on current machines. Other
1080 functions that use this format, such as `file-attributes' and
1081 `format-time-string', have been changed accordingly. Old-format time
1082 stamps are still accepted.
1083
1084 *** The format of timers in `timer-list' and `timer-idle-list' is now
1085 [TRIGGERED-P HI-SECS LO-SECS USECS REPEAT-DELAY FUNCTION ARGS IDLE-DELAY PSECS].
1086 The PSECS slot is new, and uses picosecond resolution. It can be
1087 accessed via the new `timer--psecs' accessor.
1088
1089 *** Last-modified time stamps in undo lists now are of the form
1090 (t HI-SECS LO-SECS USECS PSECS) instead of (t HI-SECS . LO-SECS).
1091
1092 ** Floating point functions now always return special values like NaN,
1093 instead of signaling errors, if given invalid args; e.g., (log -1.0).
1094 Previously, they returned NaNs on some platforms but signaled errors
1095 on others. The affected functions are acos, asin, tan, exp, expt,
1096 log, log10, sqrt, and mod.
1097
1098 ** New fringe bitmap `exclamation-mark'.
1099
1100 ** Miscellaneous changes to special forms and macros
1101
1102 *** `defun' and `defmacro' are now macros rather than special forms.
1103
1104 *** `kbd' is now a function rather than a macro.
1105
1106 ** Miscellaneous new functions
1107
1108 *** `set-temporary-overlay-map' sets up a temporary keymap that
1109 takes precedence over most other maps for a short while (normally one key).
1110
1111 *** `autoloadp' tests if its argument is an autoloaded object.
1112
1113 *** `autoload-do-load' performs the autoloading operation.
1114
1115 *** `buffer-narrowed-p' tests if the buffer is narrowed.
1116
1117 *** `file-name-base' returns a file name sans directory and extension.
1118
1119 *** `function-get' fetches a function property, following aliases.
1120
1121 *** `posnp' tests if an object is a `posn'.
1122
1123 *** `system-users' returns the user names on the system.
1124
1125 *** `system-groups' returns the group names on the system.
1126
1127 *** `tty-top-frame' returns the topmost frame of a text terminal.
1128
1129 ** The following functions and variables are obsolete:
1130 *** `automount-dir-prefix' (use `directory-abbrev-alist')
1131 *** `buffer-has-markers-at'
1132 *** `macro-declaration-function' (use `macro-declarations-alist')
1133 *** `window-system-version' (provides no useful information)
1134 *** `dired-pop-to-buffer' (use `dired-mark-pop-up')
1135 *** `query-replace-interactive'
1136 *** `font-list-limit' (has had no effect since Emacs < 23)
1137
1138 \f
1139 * Changes in Emacs 24.3 on non-free operating systems
1140
1141 ** Cygwin builds can use the native MS Windows user interface.
1142 Pass `--with-w32' to configure. The default remains the X11 interface.
1143
1144 ** Two new functions are available in Cygwin builds:
1145 `cygwin-convert-file-name-from-windows' and
1146 `cygwin-convert-file-name-to-windows'. These functions allow Lisp
1147 code to access the Cygwin file-name mapping machinery to convert
1148 between Cygwin and Windows-native file and directory names.
1149
1150 ** When invoked with the -nw switch to run on the Windows text-mode terminal,
1151 Emacs now supports `mouse-highlight', help-echo (in the echo area), and
1152 `mouse-autoselect-window'.
1153
1154 ** On MS Windows Vista and later Emacs now supports symbolic links.
1155
1156 ** On MS Windows, you can pass `--without-libxml2' to configure.bat to omit
1157 support for libxml2, even if its presence is detected.
1158
1159 ** On Mac OS X, the Nextstep port requires OS X 10.4 or later.
1160
1161 ** On Mac OS X, configure no longer automatically adds the Fink "/sw"
1162 directories to the search path. You must add them yourself if you want them.
1163
1164 \f
1165 * Changes in Emacs 24.2
1166
1167 ** This is mainly a bug-fix release.
1168
1169 \f
1170 * Installation Changes in Emacs 24.1
1171
1172 ** Emacs can be compiled with Gtk+ 3.0 if you pass --with-x-toolkit=gtk3
1173 to configure. Note that other libraries used by Emacs, RSVG and GConf,
1174 also depend on Gtk+. You can disable them with --without-rsvg and
1175 --without-gconf.
1176
1177 ** Emacs can be compiled with GnuTLS support.
1178 This happens by default if a suitably recent version of the library is
1179 found at build time. To prevent this, use the configure option
1180 `--without-gnutls'. See below for GnuTLS features.
1181
1182 ** Emacs can be compiled with SELinux support.
1183 This happens by default if a suitably recent version of the library is
1184 found at build time. To prevent this, use the configure option
1185 `--without-selinux'. See below for SELinux features.
1186
1187 ** Emacs can be compiled with ImageMagick support.
1188 This happens by default if a suitably recent version of the library is
1189 found at build time. To prevent this, use the configure option
1190 `--without-imagemagick'. See below for ImageMagick features.
1191 This feature is not available for the Nextstep or MS ports.
1192
1193 ** Emacs can be compiled with libxml2 support.
1194 This happens by default if a suitably recent version of the library is
1195 found at build time. To prevent this, use the configure option
1196 `--without-xml2'. See below for libxml2 features.
1197
1198 ** By default, the installed Info and man pages are compressed.
1199 You can disable this by configuring --without-compress-info.
1200
1201 ** New configure option --with-wide-int.
1202 With it, Emacs integers typically have 62 bits, even on 32-bit machines.
1203 On 32-bit hosts, this raises the limit on buffer sizes from about 512 MiB
1204 to about 2 GiB.
1205
1206 ** New configure options: --with-mmdf, --with-mail-unlink, --with-mailhost.
1207 These provide no new functionality, they just remove the need to edit
1208 lib-src/Makefile by hand in order to use the associated features.
1209
1210 ** New configure option --enable-use-lisp-union-type.
1211 This is only useful for Emacs developers to debug certain types of bugs.
1212 This is not a new feature; only the configure flag is new.
1213
1214 ** The standalone programs digest-doc and sorted-doc are removed.
1215 Emacs now uses Lisp commands `doc-file-to-man' and `doc-file-to-info'.
1216
1217 ** The standalone program `fakemail' is removed.
1218 If you need it, feedmail.el provides a superset of the functionality.
1219
1220 \f
1221 * Startup Changes in Emacs 24.1
1222
1223 ** The --unibyte, --multibyte, --no-multibyte, and --no-unibyte
1224 command line arguments, and the EMACS_UNIBYTE environment variable, no
1225 longer have any effect. (They were declared obsolete in Emacs 23.)
1226
1227 ** New command line option `--no-site-lisp' removes site-lisp directories
1228 from load-path. -Q now implies this. This option does not affect the
1229 EMACSLOADPATH environment variable (and hence has no effect for
1230 Nextstep builds).
1231
1232 \f
1233 * Changes in Emacs 24.1
1234
1235 ** Completion
1236
1237 *** Many packages now use the `completion-at-point' command,
1238 rather than implementing separate completion commands.
1239
1240 *** `completion-at-point' now handles tags and semantic completion.
1241
1242 *** Completion in a non-minibuffer now tries to detect the end of completion
1243 and pops down the *Completions* buffer accordingly.
1244
1245 *** New option `completion-cycle-threshold' allows completion cycling.
1246
1247 *** New option `completion-category-overrides' for overriding the
1248 default completion style in certain circumstances.
1249
1250 *** New completion style `substring'.
1251
1252 *** Completion of buffer names uses `substring' completion by default.
1253
1254 *** The option `widget-complete-field' has been removed.
1255
1256 ** Mail changes
1257
1258 *** The first time you try sending mail, Emacs asks for a mail method.
1259 This is implemented by a new default for `send-mail-function', which
1260 is `sendmail-query-once'. This offers to use the smtpmail package, or
1261 to use the old defaults relying on external mail facilities
1262 (`sendmail-send-it' on GNU/Linux and other Unix-like systems, and
1263 `mailclient-send-it' on Windows).
1264
1265 *** Typing C-c m in the buffer made by M-x report-emacs-bug transfers
1266 the report to your desktop's preferred mail client, if there is one.
1267 This uses either the "xdg-email" utility, or Mac OS's "open" command.
1268
1269 *** See Changes in Specialized Modes and Packages for SMTPmail changes
1270 and Mail mode changes
1271
1272 ** Emacs server and client changes
1273
1274 *** New option `server-port' specifies the port for TCP Emacs servers.
1275
1276 *** New emacsclient argument -q/--quiet suppresses some status messages.
1277
1278 *** New emacsclient argument --frame-parameters specifies the frame
1279 parameters of any newly-created graphical frame.
1280
1281 *** If emacsclient shuts down due to Emacs signaling an error,
1282 its exit status is 1.
1283
1284 *** New emacsclient argument --parent-id ID.
1285 This opens a client frame in parent X window ID, via XEmbed, similar
1286 to the --parent-id argument to Emacs.
1287
1288 ** Internationalization changes
1289
1290 *** Emacs now supports display and editing of bidirectional text.
1291 Right-to-left (RTL) scripts, such as Arabic, Farsi, and Hebrew, are
1292 displayed in the correct visual order as expected by users of those
1293 scripts. The display reordering is a "full bidirectionality" class
1294 implementation of the Unicode Bidirectional Algorithm (UBA). Buffers
1295 with no RTL text should look exactly the same as before.
1296
1297 **** New buffer-local variable `bidi-display-reordering'.
1298 To disable display reordering in a buffer, change this to nil.
1299
1300 **** New buffer-local variable `bidi-paragraph-direction'.
1301 If nil (the default), Emacs determines the base direction of each
1302 paragraph from its text, as specified by the UBA. Setting the value
1303 to `right-to-left' or `left-to-right' forces a base direction on each
1304 paragraph.
1305
1306 Paragraphs with right-to-left base direction are displayed starting at
1307 the right window edge.
1308
1309 *** Enhanced support for characters with no glyphs in available fonts,
1310 or, on text terminals, characters that cannot be encoded by the
1311 terminal coding system. The new option `glyphless-char-display-control'
1312 specifies how to display them: as a hexadecimal code in a box, a thin
1313 1-pixel space, an empty box, etc.
1314
1315 *** New input methods for Farsi and Bulgarian
1316 (farsi-isiri-9147, farsi-transliterate-banan, bulgarian-alt-phonetic).
1317
1318 *** `nobreak-char-display' now also highlights Unicode hyphen chars
1319 (U+2010 and U+2011).
1320
1321 *** New Hebrew translation of the Emacs Tutorial.
1322 Type `C-u C-h t' to choose it in case your language setup doesn't
1323 automatically select it.
1324
1325 ** An Emacs Lisp package manager is now included.
1326 This is a convenient way to download and install additional packages,
1327 from a package repository at http://elpa.gnu.org.
1328
1329 *** M-x list-packages shows a list of packages, which can be
1330 selected for installation.
1331
1332 *** New command `describe-package', bound to `C-h P'.
1333
1334 *** By default, all installed packages are loaded automatically when
1335 Emacs starts up. To disable this, set `package-enable-at-startup' to
1336 nil. To specify the packages to load, customize `package-load-list'.
1337
1338 ** Custom theme changes
1339
1340 *** New command `M-x customize-themes', which provides a convenient
1341 interface for enabling and disabling Custom themes.
1342
1343 *** New option `custom-theme-load-path' is the load path for themes.
1344 Emacs no longer looks for Custom themes in `load-path'. The default
1345 value of `custom-theme-load-path' says to look for themes in
1346 `custom-theme-directory', followed by a subdirectory of
1347 `data-directory' named "themes/", which contains a small selection of
1348 built-in Custom themes.
1349
1350 *** New option `custom-safe-themes' records known-safe theme files.
1351 If a theme is not in this list, Emacs queries before loading it, and
1352 offers to save the theme to `custom-safe-themes' automatically. By
1353 default, all themes included in Emacs are treated as safe.
1354
1355 ** Improved GTK integration
1356
1357 *** GTK scroll-bars are now placed on the right by default.
1358 The function `set-scroll-bar-mode' can change this.
1359
1360 *** GTK tool bars can have just text, just images or images and text.
1361 Customize `tool-bar-style' to choose the style. On a Gnome desktop,
1362 the default is taken from desktop settings.
1363
1364 *** GTK tool bars can be placed on any edge of the frame.
1365 The frame-parameter tool-bar-position controls this. It takes the
1366 values top, left, right or bottom. The Options => Show/Hide menu has
1367 entries for this.
1368
1369 *** The default colors for selected text (the `region' face) are taken
1370 from the GTK theme when Emacs is built with GTK.
1371
1372 *** Emacs uses GTK tooltips by default if built with GTK.
1373 You can disable this by changing `x-gtk-use-system-tooltips' to nil.
1374
1375 ** Graphical interface changes
1376
1377 *** On graphical displays, the mode-line no longer ends in dashes.
1378 Also, the first dash (which does not indicate anything) is just
1379 displayed as a space.
1380
1381 *** `menu-bar-select-buffer-function' lets you choose another operation
1382 instead of `switch-to-buffer' when selecting an item in the Buffers menu.
1383
1384 *** Lucid menus and dialogs can display antialiased fonts if Emacs is
1385 built with Xft. These fonts can be set via X resources, for example:
1386 Emacs.pane.menubar.font: Courier-12
1387
1388 ** Exiting changes
1389
1390 *** Emacs now calls `kill-emacs' if it receives SIGTERM or SIGHUP,
1391 or if it receives a SIGINT signal in batch mode.
1392
1393 *** `kill-emacs-hook' is now also run in batch mode.
1394 Third-party code which adds to `kill-emacs-hook' should check if they
1395 do the right thing in batch mode.
1396
1397 ** Scrolling changes
1398
1399 *** New scrolling commands `scroll-up-command' and `scroll-down-command'
1400 (bound to C-v/[next] and M-v/[prior]) do not signal errors at top/bottom
1401 of buffer at first key-press (instead they move to top/bottom of buffer)
1402 when `scroll-error-top-bottom' is non-nil.
1403
1404 *** New option `scroll-error-top-bottom' (see above).
1405
1406 *** New scrolling commands `scroll-up-line' and `scroll-down-line'
1407 scroll a line instead of full screen.
1408
1409 *** New property `scroll-command' should be set on a command's symbol to
1410 define it as a scroll command affected by `scroll-preserve-screen-position'.
1411
1412 *** If you customize `scroll-conservatively' to a value greater than 100,
1413 Emacs will never recenter point in the window when it scrolls due to
1414 cursor motion commands or commands that move point (e.f., `M-g M-g').
1415 Previously, you needed to use `most-positive-fixnum' as the value of
1416 `scroll-conservatively' to achieve the same effect.
1417
1418 *** "Aggressive" scrolling now honors the scroll margins.
1419 If you customize `scroll-up-aggressively' or
1420 `scroll-down-aggressively' and move point off the window, Emacs now
1421 scrolls the window so as to avoid positioning point inside the scroll
1422 margin.
1423
1424 ** Basic SELinux support has been added.
1425 This requires Emacs to be linked with libselinux at build time.
1426
1427 *** Emacs preserves the SELinux file context when backing up.
1428 Also, the function `copy-file' has an extra optional argument for
1429 preserving SELinux context, and the return value of `backup-buffer'
1430 now includes the SELinux context.
1431
1432 *** New functions `file-selinux-context' and `set-file-selinux-context'
1433 get and set the SELinux context of a file.
1434
1435 ** Trash changes
1436
1437 *** `delete-by-moving-to-trash' now only affects commands that specify
1438 trashing. This avoids inadvertently trashing temporary files.
1439
1440 *** Calling `delete-file' or `delete-directory' with a prefix argument
1441 now forces true deletion, regardless of `delete-by-moving-to-trash'.
1442
1443 ** File- and directory-local variable changes
1444
1445 *** You can stop directory local vars from applying to subdirectories.
1446 Add an element (subdirs . nil) to the alist portion of any variables
1447 settings to indicate that the section should not apply to
1448 subdirectories.
1449
1450 *** Directory local variables can apply to some file-less buffers.
1451 Affected modes include dired, vc-dir, and log-edit. For example,
1452 adding "(diff-mode . ((mode . whitespace)))" to .dir-locals.el will
1453 turn on `whitespace-mode' for *vc-diff* buffers. Modes should call
1454 `hack-dir-local-variables-non-file-buffer' to support this.
1455
1456 *** Using "mode: MINOR-MODE" to enable a minor mode is deprecated.
1457 Instead, use "eval: (minor-mode 1)".
1458
1459 *** The variable `inhibit-first-line-modes-regexps' has been renamed
1460 to `inhibit-local-variables-regexps'. As the name suggests, it now
1461 applies to ALL file local variables, not just -*- lines. The
1462 associated `inhibit-first-line-modes-suffixes' has been renamed in the
1463 corresponding way.
1464
1465 ** Window changes
1466
1467 *** The `quit-window' command now restores the last buffer displayed
1468 in the quitted window.
1469
1470 *** Resizing an Emacs frame now preserves proportional window sizes,
1471 modulo restrictions like window minimum sizes and fixed-size windows.
1472
1473 *** The behavior of `display-buffer' is now customizable in detail.
1474
1475 **** New option `display-buffer-base-action' specifies a list of
1476 user-determined display "actions" (functions and optional arguments
1477 for choosing the displaying window).
1478
1479 This takes precedence over the default display action, which is
1480 specified by `display-buffer-fallback-action'.
1481
1482 **** New option `display-buffer-alist' maps buffer name regexps to
1483 display actions, taking precedence over `display-buffer-base-action'.
1484
1485 *** New option `window-combination-limit'.
1486 The new option `window-combination-limit' allows to return the space
1487 obtained for resizing or creating a window more reliably to the window
1488 from which such space was obtained.
1489
1490 *** New option `window-combination-resize'.
1491 The new option `window-combination-resize' allows to split a window that
1492 otherwise cannot be split because it's too small by stealing space from
1493 other windows in the same combination. Subsequent resizing or deletion
1494 of the window will resize all windows in the same combination as well.
1495
1496 *** New option `frame-auto-hide-function' lets you choose between
1497 iconifying or deleting a frame when burying a buffer in a dedicated
1498 frame, or quitting a window showing a buffer in a frame of its own.
1499
1500 *** New commands `maximize-window' and `minimize-window'.
1501 These maximize and minimize the size of a window within its frame.
1502
1503 *** New commands `switch-to-prev-buffer' and `switch-to-next-buffer'.
1504 These functions allow to navigate through the live buffers that have
1505 been shown in a specific window.
1506
1507 ** Minibuffer changes
1508
1509 *** The inactive minibuffer has its own major mode `minibuffer-inactive-mode'.
1510 This is handy for minibuffer-only frames, and is also used for the feature
1511 where mouse-1 pops up *Messages*"', which can now easily be changed.
1512
1513 *** Minibuffers set `truncate-lines' to nil.
1514 If you want to change the value to something else, you could use
1515 for example `minibuffer-setup-hook'.
1516
1517 ** `auto-mode-case-fold' is now enabled by default.
1518
1519 ** `backup-by-copying-when-mismatch' now defaults to t.
1520
1521 ** New basic faces `error', `warning', `success'.
1522 These are used to highlight text indicating failure, caution or
1523 successful operation.
1524
1525 ** New option `list-colors-sort' defines the color sort order
1526 for `list-colors-display'.
1527
1528 ** The variable `focus-follows-mouse' now always defaults to nil.
1529
1530 \f
1531 * Editing Changes in Emacs 24.1
1532
1533 ** Search changes
1534
1535 *** C-y in Isearch is now bound to `isearch-yank-kill', instead of
1536 `isearch-yank-line'.
1537
1538 *** M-y in Isearch is now bound to `isearch-yank-pop', instead of
1539 `isearch-yank-kill'.
1540
1541 *** M-s C-e in Isearch is now bound to `isearch-yank-line'.
1542
1543 ** New commands `count-words-region' and `count-words'.
1544
1545 *** M-= is bound to `count-words-region', not `count-lines-region'.
1546 The `count-words-region' command, when called interactively, reports
1547 the number of lines, words, and characters in the region. It is a
1548 superset of the old `count-lines-region', which is now an obsolete
1549 alias for it.
1550
1551 ** The command `just-one-space' (M-SPC), if given a negative argument,
1552 also deletes newlines around point.
1553
1554 ** Deletion changes
1555
1556 *** New option `delete-active-region'.
1557 If non-nil, [delete] and DEL delete the region if it is active and no
1558 prefix argument is given. If set to `kill', those commands kill
1559 instead.
1560
1561 *** New command `delete-forward-char', bound to [delete].
1562 This is meant for interactive use, and obeys `delete-active-region'.
1563 The command `delete-char' does not obey `delete-active-region'.
1564
1565 *** `delete-backward-char' is now a Lisp function.
1566 Apart from obeying `delete-active-region', its behavior is unchanged.
1567 However, the byte compiler now warns if it is called from Lisp; Lisp
1568 callers should use delete-char with a negative argument instead.
1569
1570 *** The option `mouse-region-delete-keys' has been deleted.
1571
1572 ** Selection changes.
1573
1574 The default handling of clipboard and primary selections has been
1575 changed to conform with modern X applications. In short, most
1576 commands for killing and yanking text now use the clipboard, while
1577 mouse commands use the primary selection.
1578
1579 In the following, we provide a list of these changes, followed by a
1580 list of steps to get the old behavior back if you prefer that.
1581
1582 *** `select-active-regions' now defaults to t.
1583 Merely selecting text (e.g. with drag-mouse-1) no longer puts it in
1584 the kill ring. The selected text is put in the primary selection, if
1585 the system possesses a separate primary selection facility (e.g. X).
1586
1587 **** `select-active-regions' also accepts a new value, `only'.
1588 This means to only set the primary selection for temporarily active
1589 regions (usually made by mouse-dragging or shift-selection);
1590 "ordinary" active regions, such as those made with C-SPC followed by
1591 point motion, do not alter the primary selection.
1592
1593 **** `mouse-drag-copy-region' now defaults to nil.
1594
1595 *** mouse-2 is now bound to `mouse-yank-primary'.
1596 This pastes from the primary selection, ignoring the kill-ring.
1597 Previously, mouse-2 was bound to `mouse-yank-at-click'.
1598
1599 *** `x-select-enable-clipboard' now defaults to t on all platforms.
1600
1601 *** `x-select-enable-primary' now defaults to nil.
1602 Thus, commands that kill text or copy it to the kill-ring (such as
1603 M-w, C-w, and C-k) also use the clipboard---not the primary selection.
1604
1605 **** The "Copy", "Cut", and "Paste" items in the "Edit" menu are now
1606 exactly equivalent to M-w, C-w, and C-y respectively.
1607
1608 **** Note that on MS-Windows, `x-select-enable-clipboard' was already
1609 non-nil by default, as Windows does not support the primary selection
1610 between applications.
1611
1612 *** To return to the previous behavior, do the following:
1613
1614 **** Change `select-active-regions' to nil.
1615 **** Change `mouse-drag-copy-region' to t.
1616 **** Change `x-select-enable-primary' to t (on X only).
1617 **** Change `x-select-enable-clipboard' to nil.
1618 **** Bind `mouse-yank-at-click' to mouse-2.
1619
1620 *** Support for X cut buffers has been removed.
1621
1622 *** X clipboard managers are now supported.
1623 To inhibit this, change `x-select-enable-clipboard-manager' to nil.
1624
1625 ** New command `C-x r N' (`rectangle-number-lines') numbers the lines
1626 in the current rectangle. With a prefix argument, this prompts for a
1627 number to count from and for a format string.
1628
1629 ** `redisplay-dont-pause' now defaults to t.
1630 This makes Emacs feel more responsive to editing commands that arrive
1631 at high rate, e.g. if you lean on some key, because stopping redisplay
1632 in the middle (when this variable is nil) forces more expensive
1633 updates later on, and Emacs appears to be unable to keep up.
1634
1635 ** The behavior of <TAB> for active regions in Text mode has changed.
1636 In Text and related modes, typing <TAB> (`indent-for-tab-command')
1637 when the region is active causes Emacs to indent all the lines in the
1638 region, aligning them with the line previous to the first line in the
1639 region (or with the left margin if there is no previous line).
1640
1641 ** When `occur' is called with a prefix argument, matching strings are
1642 collected into the `*Occur*' buffer without line numbers. If there
1643 are parenthesized subexpressions in the specified regexp, `occur'
1644 reads replacement text that may contain \\& and \\N whose convention
1645 follows `replace-match'.
1646
1647 \f
1648 * Changes in Specialized Modes and Packages in Emacs 24.1
1649
1650 ** Archive Mode has basic support for browsing and updating 7z archives.
1651
1652 ** BibTeX mode
1653
1654 *** BibTeX mode now supports biblatex.
1655 Use the variable `bibtex-dialect' to select different BibTeX dialects.
1656 `bibtex-entry-field-alist' is now an obsolete alias for
1657 `bibtex-BibTeX-entry-alist'.
1658
1659 *** New command `bibtex-search-entries', bound to C-c C-a.
1660
1661 *** New `bibtex-entry-format' option `sort-fields', disabled by default.
1662
1663 *** New variable `bibtex-search-entry-globally'.
1664
1665 ** Browse-url
1666
1667 *** New option `browse-url-mailto-function' specifies how to handle "mailto:"s.
1668
1669 *** The default browser used by the package is now the "xdg-open" program,
1670 on platforms that support it. This calls your desktop's preferred browser.
1671
1672 ** Calc
1673
1674 *** Support for musical notes.
1675
1676 *** Support for logarithmic units.
1677
1678 *** No longer uses the tex prefix for TeX specific unit names when
1679 using TeX or LaTeX mode.
1680
1681 *** New option to highlight selections using faces.
1682
1683 *** `calc-histogram' has the option of using a vector to determine the bins.
1684
1685 *** New "O" option prefix.
1686
1687 *** Use the "O" prefix to "d r" (`calc-radix') to turn on twos-complement mode.
1688
1689 ** Calendar, Diary, and Appt
1690
1691 *** Diary entries can contain non-printing "comments".
1692 See the variable `diary-comment-start'.
1693
1694 *** Appointments can specify their individual warning times.
1695 See the variable `appt-warning-time-regexp'.
1696
1697 *** The function specified by `appt-disp-window-function' may be passed
1698 lists of arguments if multiple appointments are due at similar times.
1699 If you are using a custom function for this, you should update it.
1700
1701 *** New function `diary-hebrew-birthday'.
1702
1703 *** Elements of `calendar-day-abbrev-array' and `calendar-month-abbrev-array'
1704 may no longer be nil, but must all be strings.
1705
1706 *** The obsolete (since Emacs 22.1) method of enabling the appt
1707 package by adding `appt-make-list' to `diary-hook' has been removed.
1708 Use `appt-activate' instead.
1709
1710 *** Some appt variables (obsolete since Emacs 22.1) have been removed:
1711 appt-issue-message (use the function appt-activate)
1712 appt-visible/appt-msg-window (use the variable appt-display-format)
1713
1714 *** Some diary function aliases (obsolete since Emacs 22.1) have been removed:
1715 view-diary-entries, list-diary-entries, show-all-diary-entries
1716
1717 ** CC Mode
1718
1719 *** New feature to "guess" the style in an existing buffer.
1720 The main entry point is M-x c-guess.
1721
1722 *** Java Mode now supports Java 5.0 (Tiger) and 6 (Mustang).
1723
1724 *** `c-beginning-of-defun' and `c-end-of-defun' now respect nested scopes.
1725 Thus C-M-a will, by default, go to the beginning of the immediate function,
1726 not the top level.
1727
1728 *** "Macros with semicolons" can be registered for correct indentation.
1729 Where such a macro ends a line (no semicolon) the next statement is no longer
1730 parsed as a statement continuation.
1731
1732 ** Comint and modes derived from it use the standard completion code.
1733
1734 ** Compilation mode
1735
1736 *** Compilation mode can be used without Font Lock mode.
1737 `compilation-parse-errors-function' is now obsolete.
1738
1739 *** New variable `compilation-filter-start', which is bound while
1740 `compilation-filter-hook' runs. It records the start position of the
1741 text inserted by `compilation-filter'.
1742
1743 *** `compilation-error-screen-columns' and `compilation-first-column'
1744 are obeyed in the editing buffer. So programming language modes can
1745 set them, whereas previously only the value in the *Compilation*
1746 buffer was used.
1747
1748 ** Customize
1749
1750 *** Customize buffers now contain a search field.
1751 The search is performed using `customize-apropos'.
1752 To turn off the search field, set `custom-search-field' to nil.
1753
1754 *** Options in customize group buffers start out hidden if not customized.
1755 Use the arrow to the left of the option name to toggle visibility.
1756
1757 *** custom-buffer-sort-alphabetically now defaults to t.
1758
1759 *** The color widget now has a "Choose" button, which allows you to
1760 choose a color via `list-colors-display'.
1761
1762 ** D-Bus
1763
1764 *** It is now possible to access buses other than the default system
1765 or session bus.
1766
1767 *** The `dbus-register-method' and `dbus-register-property' functions
1768 optionally do not register names.
1769
1770 *** The new function `dbus-register-service' registers a known service
1771 name on a D-Bus without also registering a property or a method.
1772
1773 ** Dired-x
1774
1775 *** C-x C-j (`dired-jump') and C-x 4 C-j (`dired-jump-other-window'),
1776 if called with a prefix argument, read a file name from the minibuffer
1777 instead of using the current buffer.
1778
1779 *** The "dired local variables" feature of Dired-x is obsolete.
1780 The standard directory local variables feature replaces it.
1781
1782 ** ERC changes
1783
1784 *** New options `erc-autojoin-timing' and `erc-autojoin-delay',
1785 controlling attempts to autojoin a channel.
1786
1787 *** New variable `erc-coding-system-precedence': If we use `undecided'
1788 as the server coding system, this variable will then be consulted.
1789 The default is to decode strings that can be decoded as utf-8 as
1790 utf-8, and do the normal `undecided' decoding for the rest.
1791
1792 ** Eshell changes
1793
1794 *** The default value of `eshell-directory-name' has changed
1795 to be an "eshell" directory in `user-emacs-directory'.
1796 The old "~/.eshell/" directory is still used if it exists, though.
1797
1798 ** gdb-mi
1799
1800 *** The M-x gdb command now uses the GDB Machine Interface protocol.
1801 It now supports multithread non-stop debugging and simultaneous
1802 debugging of several threads.
1803
1804 ** Image mode
1805
1806 *** RET (`image-toggle-animation') toggles animation, if applicable.
1807 Animation plays once, unless the option `image-animate-loop' is non-nil.
1808
1809 ** Info
1810
1811 *** New command M-x info-display-manual displays a named Info manual.
1812 If that manual is already visited in some Info buffer, it displays
1813 that buffer. (This is handy if you have many manuals in many *info*
1814 buffers, and don't remember the name of the buffer visiting the manual
1815 you want to consult.) Otherwise, it loads and displays the manual.
1816
1817 *** `e' is now bound to `end-of-buffer' rather than to `Info-edit'.
1818 This is for compatibility with the stand-alone Info reader program,
1819 and also because `Info-edit' is a rarely used command that is disabled
1820 by default.
1821
1822 ** Mail mode changes (not Message mode)
1823
1824 *** New command M-x mail-add-attachment for adding MIME attachments
1825
1826 *** The command M-x mail-attach-file was renamed to M-x mail-insert-file.
1827 (Its name is misleading, since it has nothing to do with MIME
1828 attachments.) The old name is now an obsolete alias to the new name.
1829
1830 ** MH-E has been updated to MH-E version 8.3.1.
1831 See MH-E-NEWS for details.
1832
1833 ** Modula-2 mode provides auto-indentation.
1834
1835 ** mpc.el: Can use pseudo tags of the form tag1|tag2 as a union of two tags.
1836
1837 ** nXML mode no longer binds C-RET to `nxml-complete'.
1838 Completion is now performed via `completion-at-point', bound to C-M-i
1839 or M-TAB. If `nxml-bind-meta-tab-to-complete-flag' is non-nil (the
1840 default), this performs tag completion.
1841
1842 ** Org mode has been updated to version 7.8.09.
1843 See ORG-NEWS for details.
1844
1845 ** Prolog mode has been completely revamped, with lots of additional
1846 functionality such as more intelligent indentation, electricity,
1847 support for more variants, including Mercury, and a lot more.
1848
1849 ** Rmail
1850
1851 *** The command `rmail-epa-decrypt' decrypts OpenPGP data
1852 in the Rmail incoming message.
1853
1854 *** The variable `rmail-message-filter' no longer has any effect.
1855 This change was made in Emacs 23.1 but was not advertised at the time.
1856 Try using `rmail-show-message-hook' instead.
1857
1858 ** Shell mode
1859
1860 *** M-x shell prompts for the shell path name if the default directory
1861 is a remote file name and neither the environment variable $ESHELL nor
1862 the variable `explicit-shell-file-name' is set.
1863
1864 *** TAB is now bound to the standard `completion-at-point' command,
1865 which now implements the pcomplete rules for shell command completion.
1866
1867 ** SMTPmail
1868
1869 *** SMTPmail now uses encrypted connections (via STARTTLS) by default
1870 if the mail server supports them. This uses either built-in GnuTLS
1871 support, or the starttls.el library. Customize `smtpmail-stream-type'
1872 to change this.
1873
1874 *** The variable `smtpmail-auth-credentials' has been removed.
1875 By default, the information is now stored in the file ~/.authinfo.
1876 This was the default value of smtpmail-auth-credentials. If you had
1877 customized smtpmail-auth-credentials to a list of user names and
1878 passwords, those settings are not used. During your first connection
1879 to the smtp server, Emacs will prompt for the user name and password,
1880 and offer to save them to ~/.authinfo. Or you can manually copy the
1881 credentials to ~/.authinfo. For example, if you had
1882
1883 (setq smtpmail-auth-credentials
1884 '(("mail.example.org" 25 "jim" "s!cret")))
1885
1886 then the equivalent line in ~/.authinfo would be
1887
1888 machine mail.example.org port 25 login jim password s!cret
1889
1890 See the auth-source manual for more information, e.g. on encrypting
1891 the credentials file.
1892
1893 *** The variable `smtpmail-starttls-credentials' has been removed.
1894 If you had that set, you need to put
1895
1896 machine smtp.whatever.foo port 25 key "~/.my_smtp_tls.key" cert "~/.my_smtp_tls.cert"
1897
1898 in your ~/.authinfo file instead.
1899
1900 *** SMTPmail defaults to using the address in the From: header as the
1901 SMTP MAIL FROM envelope. To override this, set `mail-envelope-from'
1902 to the address you wish to use instead.
1903
1904 ** SQL mode
1905
1906 *** New options `sql-port', `sql-connection-alist', `sql-send-terminator',
1907 and `sql-oracle-scan-on'.
1908
1909 *** New options controlling prompting for login parameters.
1910 Each supported product has a custom variable `sql-*-login-params',
1911 which is a list of the parameters to be prompted for before a
1912 connection is established.
1913
1914 *** The command `sql-product-interactive' now takes a prefix argument,
1915 which causes it to prompt for an SQL product.
1916
1917 *** Product-specific SQL interactive commands now take prefix arguments.
1918 These commands (`sql-sqlite', `sql-postgres', `sql-mysql', etc.),
1919 given a prefix argument, prompt for a name for the SQL interactive
1920 buffer. This reduces the need for calling `sql-rename-buffer'.
1921
1922 *** SQL interactive modes suppress command continuation prompts, and
1923 replace tabs with spaces. The first change impacts multiple line SQL
1924 statements entered with C-j between each line, statements yanked into
1925 the buffer and statements sent with `sql-send-*' functions. The
1926 second prevents the MySQL and Postgres interpreters from listing
1927 object name completions when sent text via `sql-send-*' functions.
1928
1929 *** New command `sql-connect' starts a predefined SQLi session,
1930 using the login parameters from `sql-connection-alist'.
1931
1932 *** New "Save Connection" menu item in SQLi buffers.
1933 This gathers the login params specified for the SQLi session, if it
1934 was not started by a connection, and saves them as a new connection.
1935
1936 *** New commands for listing database objects and details:
1937 sql-list-all and sql-list-table.
1938
1939 *** An API for manipulating SQL product definitions has been added.
1940
1941 ** TeX modes
1942
1943 *** latex-electric-env-pair-mode keeps \begin..\end matched on the fly.
1944
1945 ** Tramp
1946
1947 *** New inline access method "ksu" (kerberized su).
1948
1949 *** The following access methods are discontinued: "ssh1_old",
1950 "ssh2_old", "scp1_old", "scp2_old", "imap", "imaps" and "fish".
1951
1952 *** The user option `remote-file-name-inhibit-cache' controls whether
1953 remote file attributes are cached for better performance.
1954
1955 *** The option `ange-ftp-binary-file-name-regexp' has changed its
1956 default value to "".
1957
1958 *** Handlers for `file-selinux-context' and `set-file-selinux-context'
1959 for remote machines which support SELinux.
1960
1961 ** New function `url-queue-retrieve', which behaves like url-retrieve,
1962 but with limits (`url-queue-parallel-processes', `url-queue-timeout') on
1963 the degree of parallelism.
1964
1965 ** VC and related modes
1966
1967 *** Support for pulling on distributed version control systems.
1968 The command C-x v + (`vc-pull') runs a "pull" operation, if it is
1969 supported (currently with Bzr, Git, and Mercurial), to update the
1970 current branch and working tree. A prefix argument means to prompt
1971 the user for specifics, e.g. a pull location.
1972
1973 *** `vc-update' is now an alias for `vc-pull'.
1974
1975 *** Support for merging on distributed version control systems.
1976 The command C-x v m (`vc-merge') now runs a "merge" operation, if it
1977 is supported (currently with Bzr, Git, and Mercurial), to merge
1978 changes from another branch into the current one. It prompts for
1979 specifics, e.g. a merge source.
1980
1981 *** New option `vc-revert-show-diff' controls whether `vc-revert'
1982 shows a diff while querying the user. It defaults to t.
1983
1984 *** Log entries in some Log View buffers can be toggled to display a
1985 longer description by typing RET (log-view-toggle-entry-display).
1986 This is currently supported for Bzr, Git, and Mercurial (to support
1987 another backend, define a `log-view-expanded-log-entry-function').
1988 In the Log View buffers made by C-x v L (`vc-print-root-log'), you can
1989 use this to display the full log entry for the revision at point.
1990
1991 *** New command `vc-ediff' allows visual comparison of two revisions
1992 of a file similar to `vc-diff', but using ediff backend.
1993
1994 *** The option `vc-initial-comment' was removed in Emacs 23.2, but
1995 this was not advertised at the time.
1996
1997 *** `vc-toggle-read-only' is an obsolete alias for `toggle-read-only'.
1998 Since Emacs 23, it has done the same thing as `toggle-read-only', but
1999 this was not advertised at the time.
2000
2001 ** Obsolete modes
2002
2003 *** abbrevlist.el
2004
2005 *** erc-hecomplete.el (use erc-pcomplete.el instead)
2006
2007 *** partial-completion-mode (complete.el) is obsolete.
2008 You can get a comparable behavior with:
2009 (setq completion-styles '(partial-completion initials))
2010 (setq completion-pcm-complete-word-inserts-delimiters t)
2011
2012 *** pc-mode.el is obsolete (CUA mode is much more comprehensive).
2013
2014 *** pgg is obsolete (use EasyPG instead).
2015
2016 *** sregex.el is obsolete, since rx.el is a strict superset.
2017
2018 *** s-region.el and pc-select.el are obsolete.
2019 They are superseded by shift-select-mode, enabled by default since 23.1.
2020
2021 *** vc-mcvs.el is obsolete (for lack of a maintainer).
2022
2023 ** Miscellaneous
2024
2025 *** The Landmark game is now invoked with `landmark', not `lm'.
2026 Its functions and variables have been similarly renamed.
2027
2028 *** In `ido-file-completion-map', C-v is no longer bound to `ido-toggle-vc'.
2029 (This interfered with cua-mode.)
2030
2031 *** f90.el has some support for Fortran 2008 syntax.
2032
2033 *** `copyright-fix-years' can optionally convert consecutive years to ranges.
2034
2035 *** New command `nato-region' converts text to NATO phonetic alphabet.
2036
2037 \f
2038 * New Modes and Packages in Emacs 24.1
2039
2040 ** Occur Edit mode applies edits made in *Occur* buffers to the
2041 original buffers. It is bound to "e" in Occur mode.
2042
2043 ** New global minor mode electric-pair-mode.
2044 When enabled, typing an open parenthesis automatically inserts the
2045 matching closing one.
2046
2047 ** New global minor mode electric-indent-mode.
2048 When enabled, typing certain characters triggers reindentation.
2049 Major modes wishing to use this can set electric-indent-chars or
2050 electric-indent-functions.
2051
2052 ** New global minor mode electric-layout-mode.
2053 When enabled, typing certain characters automatically inserts newlines.
2054 Major modes wishing to use this can set electric-layout-rules.
2055
2056 ** tabulated-list.el provides a generic major mode for tabulated data,
2057 from which other modes can be derived.
2058
2059 ** pcase.el provides the ML-style pattern matching macro `pcase'.
2060
2061 ** secrets.el is an implementation of the Secret Service API, an
2062 interface to password managers like GNOME Keyring or KDE Wallet. The
2063 Secret Service API requires D-Bus for communication. The command
2064 `secrets-show-secrets' offers a buffer with a visualization of the
2065 secrets.
2066
2067 ** notifications.el provides an implementation of the Desktop
2068 Notifications API. It requires D-Bus for communication.
2069
2070 ** soap-client.el supports access to SOAP web services from Emacs.
2071 soap-inspect.el is an interactive inspector for SOAP WSDL structures.
2072
2073 ** New generic mode, xmodmap-generic-mode, for xmodmap files.
2074
2075 ** New emacs-lock.el package.
2076 The previous version has been moved to obsolete/old-emacs-lock.el.
2077 Now, there is a proper minor mode `emacs-lock-mode'. Protection
2078 against exiting Emacs and killing the buffer can be set separately.
2079 The mechanism for automatically turning off protection for buffers
2080 with dead inferior processes has been generalized.
2081
2082 \f
2083 * Incompatible Lisp Changes in Emacs 24.1
2084
2085 ** Passing a nil argument to a minor mode function call now ENABLES
2086 the minor mode unconditionally. This is so that you can write e.g.
2087
2088 (add-hook 'text-mode-hook 'foo-mode)
2089
2090 to enable foo-mode in Text mode buffers, removing the need for
2091 `turn-on-foo-mode' style functions. This affects all mode commands
2092 defined by `define-minor-mode'. If called interactively, the mode
2093 command still toggles the minor mode.
2094
2095 ** The return value of `backup-buffer' has changed.
2096 It is now a list of three elements, where the second element is a list
2097 describing the original file's SELinux context. If Emacs or the
2098 system lacks SELinux support, the context list is (nil nil nil nil).
2099 See "Basic SELinux support" above, under "Changes in Emacs 24.1".
2100
2101 ** `char-direction-table' and the `char-direction' function were deleted.
2102 They were buggy and inferior to the new support of bidirectional
2103 editing introduced in Emacs 24. If you need the bidirectional
2104 properties of a character, use `get-char-code-property' with the last
2105 argument `bidi-class'.
2106
2107 ** `copy-directory' now copies the source directory as a subdirectory
2108 of the target directory, if the latter is an existing directory. The
2109 new optional arg COPY-CONTENTS, if non-nil, makes the function copy
2110 the contents directly into a pre-existing target directory.
2111
2112 ** For mouse click input events in the text area, the Y pixel
2113 coordinate in the POSITION list now counts from the top of the text
2114 area, excluding any header line. Previously, it counted from the top
2115 of the header line.
2116
2117 ** Support for "old-style" backquotes, obsolete for 10+ years, has
2118 been further reduced. Now a backquote not followed by a space is
2119 always treated as a "new-style" backquote. Please remove all
2120 "old-style" backquotes from your code. If your code uses backquotes
2121 as documented in the Elisp manual, and compiles without warning, then
2122 you have nothing to do in this regard. Code not following the
2123 appropriate conventions may fail to compile.
2124
2125 The most common cause of trouble seems to be an old-style backquote
2126 followed by a newline. Another cause of trouble is vector notation
2127 for key sequence notation: instead of [(control ,)] and [(control ')],
2128 you should write [(control ?,)] and [(control ?')], which will work in
2129 older Emacsen too.
2130
2131 ** The macro `eval-at-startup' was removed in Emacs 23.2, but this
2132 was not advertised at the time. The function `custom-initialize-delay'
2133 replaced all known uses.
2134
2135 ** `view-buffer' now treats special mode-class in the same way that
2136 `view-file' has since Emacs 22 (i.e. it won't enable View mode if the
2137 major mode is special).
2138
2139 ** Menu and tool bar changes
2140
2141 *** During startup, Emacs no longer adds entries for `menu-bar-lines'
2142 and `tool-bar-lines' to `default-frame-alist' and `initial-frame-alist'.
2143 With these alist entries omitted, `make-frame' checks the value of the
2144 variable `menu-bar-mode'/`tool-bar-mode' to determine whether to create
2145 a menu-bar or tool-bar, respectively. If the alist entries are added,
2146 they override the value of `menu-bar-mode'/`tool-bar-mode'.
2147
2148 *** The menu bar bindings's caches are not used any more.
2149 Use (where-is-internal <def> nil t) instead.
2150
2151 ** Regions created by mouse dragging are now normal active regions,
2152 similar to those created by shift-selection (see Selection changes
2153 above). In previous Emacs versions, these regions were delineated by
2154 `mouse-drag-overlay'; that variable has been removed.
2155
2156 ** The fourth argument of `filter-buffer-substring' has been removed.
2157 If you want to remove text properties from the final result, simply
2158 pass the result through substring-no-properties.
2159
2160 ** cl.el no longer provides `cl-19'.
2161
2162 ** The following obsolete functions and aliases have been removed
2163 (the appropriate new function is given in parentheses; "not needed"
2164 means you can just remove all calls to the function in question):
2165
2166 *** `comint-kill-output' (`comint-delete-output')
2167 *** `decompose-composite-char' (`char-to-string')
2168 *** `outline-visible' (`outline-invisible-p')
2169 *** `internal-find-face' (`facep')
2170 *** `internal-get-face' (`facep and check-face')
2171 *** `frame-update-faces' (not needed)
2172 *** `frame-update-face-colors' (`frame-set-background-mode')
2173 *** `x-frob-font-weight' and `x-frob-font-slant' (`make-face-*' functions)
2174 *** `x-make-font-bold and x-make-font-demibold (`make-face-bold')
2175 *** `x-make-font-italic' and `x-make-font-oblique' (`make-face-italic')
2176 *** `x-make-font-bold-italic' (`make-face-bold-italic')
2177 *** `x-make-font-unbold' (`make-face-unbold')
2178 *** `x-make-font-unitalic' (`make-face-unitalic')
2179 *** `mldrag-drag-mode-line' (`mouse-drag-mode-line')
2180 *** `mldrag-drag-vertical-line' (`mouse-drag-vertical-line')
2181 *** `iswitchb-default-keybindings' (`iswitchb-mode')
2182 *** `char-bytes' (== 1)
2183 *** `isearch-return-char' (`isearch-printing-char')
2184 *** `make-local-hook' (not needed)
2185 *** `set-screen-height' (`set-frame-height')
2186 *** `set-screen-width' (`set-frame-width')
2187
2188 ** The following obsolete variables and varaliases have been removed
2189 (the appropriate new variable is given in parentheses):
2190
2191 *** `checkdoc-minor-keymap' (`checkdoc-minor-mode-map')
2192 *** `vc-header-alist' (`vc-BACKEND-header')
2193 *** `directory-sep-char' (== ?/)
2194 *** `font-lock-defaults-alist' (`font-lock-defaults')
2195 *** `e' (`float-e').
2196
2197 ** The following obsolete files were removed:
2198 sc.el, x-menu.el, rnews.el, rnewspost.el
2199
2200 ** The format of the finder-inf.el file has changed, since the Finder
2201 mechanism is now based on the package system. The variable
2202 `finder-package-info' is replaced by `package--builtins' and
2203 `finder-keywords-hash'.
2204
2205 ** When generating autoloads, `update-directory-autoloads' no longer
2206 assumes every inspected file is in your `load-path'. It instead
2207 generates relative names according to the current `load-path'.
2208
2209 \f
2210 * Lisp changes in Emacs 24.1
2211
2212 ** Code can now use lexical scoping by default instead of dynamic scoping.
2213 The `lexical-binding' variable enables lexical scoping for local
2214 variables. It is typically set via a file-local variable in the first
2215 line of the file, in which case it applies to all the code in that
2216 file.
2217
2218 *** `eval' takes a new optional argument `lexical' to choose the new lexical
2219 binding instead of the old dynamic binding mode.
2220
2221 *** Lexically scoped interpreted functions are represented with a new form
2222 of function value which looks like (closure ENV ARGS &rest BODY).
2223
2224 *** New macro `letrec' to define recursive local functions.
2225
2226 *** `defvar' and `defconst' now mark the variable as special (dynamic).
2227 So do `defcustom' and other forms that call `defvar' as a subroutine.
2228
2229 *** New function `special-variable-p' to check whether a variable is
2230 declared as dynamically bound.
2231
2232 *** The form ((lambda ...) ...) is deprecated.
2233
2234 ** An Emacs Lisp testing tool is now included.
2235 Emacs Lisp developers can use this tool to write automated tests for
2236 their code. See the ERT info manual for details.
2237
2238 ** Changes for bidirectional display and editing
2239
2240 *** New function `current-bidi-paragraph-direction'.
2241 This returns the base direction of the paragraph at point.
2242
2243 *** New function `bidi-string-mark-left-to-right'.
2244 Given a string containing characters from right-to-left scripts, this
2245 function returns another string which can be safely inserted into a
2246 buffer, such that any following text will be always displayed to the
2247 right of that string. (This works by appending an invisible Unicode
2248 "LEFT-TO-RIGHT MARK" character if the argument string might need it.)
2249
2250 This is useful when the buffer has overall left-to-right paragraph
2251 direction and you need to insert a string whose contents are not known
2252 in advance, without disrupting the layout of the line.
2253
2254 ** Window changes
2255
2256 *** Window tree functions are accessible in Elisp.
2257 Functions are provided to return the parent, siblings or child windows
2258 of any window including internal windows (windows not associated with a
2259 buffer) in the window tree.
2260
2261 **** New function `window-valid-p' gives non-nil for live and internal
2262 windows.
2263
2264 **** Window manipulation can deal with internal windows.
2265 Many window handling functions like `split-window', `delete-window', or
2266 `delete-other-windows' as well as the window resizing functions can now
2267 act on any window including internal ones.
2268
2269 *** window-total-height/-width vs window-body-height/-width.
2270 The function `window-height' has been renamed to `window-total-height'
2271 and `window-width' has been renamed to `window-body-width'. The old
2272 names are provided as aliases. Two new functions `window-total-width'
2273 and `window-body-height' are provided.
2274
2275 *** Window parameters specific to window handling functions.
2276 For each window you can specify a parameter to override the default
2277 behavior of a number of functions like `split-window', `delete-window'
2278 and `delete-other-windows'. The variable `ignore-window-parameters'
2279 allows to ignore processing such parameters.
2280
2281 *** New semantics of third argument of `split-window'.
2282 The third argument of `split-window' has been renamed to SIDE and can be
2283 set to any of the values 'below, 'right, 'above, or 'left to make the
2284 new window appear on the corresponding side of the window that shall be
2285 split. Any other value of SIDE will cause `split-window' to split the
2286 window into two side-by-side windows as before.
2287
2288 *** Window resizing functions.
2289 A new standard function for resizing windows called `window-resize' has
2290 been introduced. This and all other functions for resizing windows no
2291 longer delete any windows when they become too small.
2292
2293 *** Deleting the selected window now selects the most recently selected
2294 live window on that frame instead.
2295
2296 *** `adjust-window-trailing-edge' adjustments.
2297 `adjust-window-trailing-edge' can now deal with fixed-size windows and
2298 is able to resize other windows if a window adjacent to the trailing
2299 edge cannot be shrunk any more. This makes its behavior more similar to
2300 that of Emacs 21 without compromising, however, its inability to delete
2301 windows which was introduced in Emacs 22.
2302
2303 *** Window-local buffer lists.
2304 Windows now have local buffer lists. This means that removing a buffer
2305 from display in a window will preferably show the buffer previously
2306 shown in that window with its previous window-start and window-point
2307 positions. This also means that the same buffer may be automatically
2308 shown twice even if it already appears in another window.
2309
2310 *** `switch-to-buffer' has a new optional argument FORCE-SAME-WINDOW,
2311 which if non-nil requires the buffer to be displayed in the currently
2312 selected window, signaling an error otherwise. If nil, another window
2313 can be used, e.g. if the selected one is strongly dedicated.
2314
2315 *** `split-window-vertically' and `split-window-horizontally' renamed
2316 to `split-window-below' and `split-window-right' respectively.
2317 The old names are kept as aliases.
2318
2319 *** Display actions
2320
2321 **** The second arg to `display-buffer' and `pop-to-buffer' is now
2322 named ACTION, and takes a display action of the same form as
2323 `display-buffer-base-action' (see Changes, above). A non-nil,
2324 non-list value is treated specially, as the old meaning.
2325
2326 **** New variable `display-buffer-overriding-action'.
2327
2328 **** The procedure of `display-buffer' etc. to choose a window is
2329 determined by combining `display-buffer-overriding-action',
2330 `display-buffer-alist', the ACTION arg, `display-buffer-base-action',
2331 and `display-buffer-fallback-action'. The second and fourth of these
2332 are user-customizable variables.
2333
2334 See the docstring of `display-buffer' for details.
2335
2336 *** New functions `window-state-get' and `window-state-put'.
2337 These functions allow to save and restore the state of an arbitrary
2338 frame or window as an Elisp object.
2339
2340 ** Completion
2341
2342 *** New variable `completion-extra-properties' used to specify extra
2343 properties of the current completion:
2344 - :annotate-function, same as the old completion-annotate-function.
2345 - :exit-function, function to call after completion took place.
2346
2347 *** Functions on `completion-at-point-functions' can return any of the
2348 properties valid for `completion-extra-properties'.
2349
2350 *** `completion-annotate-function' is obsolete.
2351
2352 *** New `metadata' method for completion tables. The metadata thus returned
2353 can specify various details of the data returned by `all-completions':
2354 - `category' is the kind of objects returned (e.g., `buffer', `file', ...),
2355 used to select a style in completion-category-overrides.
2356 - `annotation-function' to add annotations in *Completions*.
2357 - `display-sort-function' to specify how to sort entries in *Completions*.
2358 - `cycle-sort-function' to specify how to sort entries when cycling.
2359
2360 *** `minibuffer-local-filename-must-match-map' is not used any more.
2361 Instead, the bindings in `minibuffer-local-filename-completion-map'
2362 are combined with `minibuffer-local-must-match-map'.
2363
2364 *** New variable `completing-read-function' allows overriding the
2365 behavior of `completing-read'.
2366
2367 ** `glyphless-char-display' can now distinguish between graphical and
2368 text terminal display, via a char-table entry that is a cons cell.
2369
2370 ** `pre-command-hook'/`post-command-hook' are not reset to nil on error.
2371 Instead, the offending function is removed.
2372
2373 ** New hook types
2374
2375 *** New function `run-hook-wrapped' for running an abnormal hook by
2376 passing the hook functions as arguments to a "wrapping" function.
2377 Like `run-hook-with-args-until-success', it stops at the first
2378 non-nil return value.
2379
2380 *** New macro `with-wrapper-hook' for running an abnormal hook as a
2381 set of "wrapping" filters, similar to around advice.
2382 (A version of this macro was actually added in Emacs 23.2 but was not
2383 advertised at the time.)
2384
2385 ** Debugger changes
2386
2387 *** New macro `condition-case-unless-debug' (this was actually added in
2388 Emacs 23.1 as condition-case-no-debug, but not advertised)
2389
2390 *** The macro `with-demoted-errors' was added in Emacs 23.1, but not advertised.
2391
2392 *** Variable `stack-trace-on-error' removed.
2393
2394 *** The debugger can now "continue" from an error, which means it will
2395 jump to the error handler as if the debugger had not been invoked
2396 instead of jumping all the way to the top-level.
2397
2398 *** Set `debug-on-event' to enter the debugger on events like SIGUSR1.
2399 This can be useful when `inhibit-quit' is set.
2400
2401 ** The new function `server-eval-at' allows evaluation of Lisp forms on
2402 named Emacs server instances.
2403
2404 ** `call-process' and `call-process-region' allow a `(:file "file")' spec
2405 to redirect STDOUT to a file.
2406
2407 ** The function `format-time-string' now supports the %N directive,
2408 for higher-resolution time stamps.
2409
2410 ** New input reading functions
2411
2412 *** New function `read-char-choice' reads a restricted set of
2413 characters, discarding any inputs not inside the set.
2414
2415 *** The command `read-color' now requires a match for a color name
2416 or RGB triplet, instead of signaling an error if the user provides
2417 invalid input.
2418
2419 **** `facemenu-read-color' is now an alias for `read-color'.
2420
2421 ** `image-library-alist' is renamed to `dynamic-library-alist'.
2422 The variable is now used to load all kind of supported dynamic libraries,
2423 not just image libraries. The previous name is still available as an
2424 obsolete alias.
2425
2426 ** Syntax parsing changes
2427
2428 *** New variable `syntax-propertize-function'.
2429 This replaces `font-lock-syntactic-keywords' which is now obsolete.
2430 This allows syntax-table properties to be set independently from font-lock:
2431 just call syntax-propertize to make sure the text is propertized.
2432 Together with this new variable come a new hook
2433 syntax-propertize-extend-region-functions, as well as two helper functions:
2434 syntax-propertize-via-font-lock to reuse old font-lock-syntactic-keywords
2435 as-is; and syntax-propertize-rules which provides a new way to specify
2436 syntactic rules.
2437
2438 *** Syntax tables support a new "comment style c" additionally to style b.
2439
2440 ** New hook `post-self-insert-hook', run after `self-insert-command'.
2441
2442 ** frame-local variables cannot be let-bound any more.
2443
2444 ** Major and minor mode changes
2445
2446 *** `set-auto-mode' now respects mode: local variables at the end of files,
2447 as well as those in the -*- line.
2448
2449 *** `prog-mode' is a new major mode from which programming modes
2450 should be derived.
2451
2452 **** `prog-mode-hook' can be used to enable features for programming
2453 modes, e.g. (add-hook 'prog-mode-hook 'flyspell-prog-mode) to enable
2454 on-the-fly spell checking for comments and strings.
2455
2456 *** New hook `change-major-mode-after-body-hook', run by
2457 `run-mode-hooks' just before any other mode hooks.
2458
2459 *** Enabled globalized minor modes can be disabled in specific major modes.
2460 If the global mode is global-FOO-mode, then run (FOO-mode -1) in the
2461 major mode's hook, where FOO-mode toggles the mode on a per-buffer basis.
2462
2463 *** `define-minor-mode' accepts new keywords :variable, :after-hook.
2464
2465 ** File-handling changes
2466
2467 *** `delete-file' and `delete-directory' now accept optional arg TRASH.
2468 Trashing is performed if TRASH and `delete-by-moving-to-trash' are
2469 both non-nil. Interactively, TRASH defaults to t, unless a prefix
2470 argument is supplied (see Trash changes, above).
2471
2472 *** New file predicates: `file-equal-p', `file-in-directory-p'.
2473
2474 ** Tool-bars can display separators.
2475 Tool-bar separators are handled like menu separators in menu-bar maps,
2476 i.e. via menu entries of the form `(menu-item "--")'.
2477
2478 ** Image API
2479
2480 *** Animated images support (currently animated gifs only).
2481
2482 **** `image-animated-p' returns non-nil if an image can be animated.
2483
2484 **** `image-animate' animates a supplied image spec.
2485
2486 **** `image-animate-timer' returns the timer object for an image that
2487 is being animated.
2488
2489 *** `image-extension-data' has been renamed to `image-metadata'.
2490 The old name is an obsolete alias to the new one.
2491
2492 *** Image mode can view any image type that ImageMagick supports.
2493 This requires Emacs to be built with ImageMagick support.
2494
2495 **** New function `imagemagick-types', defined if ImageMagick support
2496 is enabled, returns a list of image file extensions that your
2497 ImageMagick installation supports.
2498
2499 **** New function `imagemagick-register-types' enables ImageMagick
2500 image types in Image mode and in `create-image' and other helper
2501 functions.
2502
2503 **** New option `imagemagick-types-inhibit' excludes certain
2504 ImageMagick image types from `imagemagick-register-types'.
2505
2506 **** With ImageMagick support, there are extra Image mode commands to
2507 resize and rotate images: `image-transform-fit-to-height',
2508 `image-transform-fit-to-width', `image-transform-set-rotation', and
2509 `image-transform-set-scale'.
2510
2511 ** `compose-mail' now accepts an optional 8th arg, RETURN-ACTION, and
2512 passes it to the mail user agent function. This argument specifies an
2513 action for returning to the caller after finishing with the mail. For
2514 example, this is used by Rmail to optionally delete a mail window.
2515
2516 ** XML and HTML parsing
2517 If Emacs is compiled with libxml2 support, there are two new
2518 functions: `libxml-parse-html-region' (which parses "real world" HTML)
2519 and `libxml-parse-xml-region' (which parses XML). Both return an
2520 Emacs Lisp parse tree.
2521
2522 ** Networking and encryption changes
2523
2524 *** `open-network-stream' can now be used to open an encrypted stream.
2525 It now accepts an optional `:type' parameter for initiating a TLS
2526 connection, directly or via STARTTLS. To do STARTTLS, additional
2527 parameters (`:end-of-command', `:success', `:capabilities-command')
2528 must also be supplied.
2529
2530 *** New library gnutls.el.
2531 The new function `gnutls-available-p' returns non-nil if Emacs is
2532 built with GnuTLS support. The main entry points are
2533 `open-gnutls-stream' and `gnutls-negotiate'. It's easiest to use
2534 these functions through `open-network-stream', because that can
2535 upgrade connections through STARTTLS opportunistically or use plain
2536 SSL, depending on your needs. For debugging, set `gnutls-log-level'
2537 greater than 0.
2538
2539 *** New primitive `secure-hash' that supports many secure hash algorithms:
2540 md5, sha1, sha2, sha224, sha256, sha384, and sha512. The lisp library
2541 sha1.el has been removed. The `sha1' feature is provided by default.
2542
2543 ** Isearch
2544
2545 *** New hook `isearch-update-post-hook' that runs in `isearch-update'.
2546
2547 ** Progress reporters can now "spin".
2548 The MIN-VALUE and MAX-VALUE arguments of `make-progress-reporter' can
2549 now be nil, or omitted. This makes a "non-numeric" reporter. Each
2550 time you call `progress-reporter-update' on that progress reporter,
2551 with a nil or omitted VALUE argument, the reporter message is
2552 displayed with a "spinning bar".
2553
2554 ** New variable `revert-buffer-in-progress-p' is true while a buffer is
2555 being reverted, even if the buffer has a local `revert-buffer-function'.
2556
2557 ** New variables `delayed-warnings-list' and `delayed-warnings-hook'.
2558 If delayed-warnings-list is non-nil, the command loop calls
2559 `delayed-warnings-hook' after `post-command-hook'. At present, this
2560 is only used by Emacs on some platforms to display warnings during
2561 startup, which might otherwise not be noticed. This uses the
2562 functions `display-delayed-warnings' and `collapse-delayed-warnings'.
2563
2564 ** rx.el has a new `group-n' construct for explicitly numbered groups.
2565
2566 ** New function `make-composed-keymap' that constructs a new keymap
2567 from multiple input maps. You can use this to make a keymap that
2568 inherits from multiple maps, eg:
2569 (set-keymap-parent newmap (make-composed-keymap othermap parent))
2570
2571 ** New function `string-prefix-p'.
2572 (This was actually added in Emacs 23.2 but was not advertised at the time.)
2573
2574 ** New reader macro ## that stands for the empty symbol.
2575 This means that the empty symbol can now be read back. Also, #: by itself
2576 (when not immediately followed by a possible symbol character) stands for
2577 an empty uninterned symbol.
2578
2579 ** New math functions `isnan', `copysign', `frexp', `ldexp'.
2580
2581 ** The following functions and variables are obsolete:
2582
2583 *** `tooltip-use-echo-area' is obsolete.
2584 Rather than setting this to t, disable Tooltip mode instead.
2585
2586 *** buffer-substring-filters is obsolete.
2587 Use `filter-buffer-substring-functions' instead.
2588
2589 *** `byte-compile-disable-print-circle' is obsolete.
2590
2591 *** `deferred-action-list' and `deferred-action-function' are obsolete.
2592 Use `post-command-hook' instead.
2593
2594 *** `font-lock-maximum-size' is obsolete.
2595
2596 \f
2597 * Changes in Emacs 24.1 on non-free operating systems
2598
2599 ** On MS Windows, Emacs warns when using the obsolete init file _emacs,
2600 and also when HOME is set to C:\ by default.
2601
2602 ** New configure.bat options
2603
2604 *** --enable-checking builds Emacs with extra runtime checks.
2605
2606 *** --distfiles specifies files to be included in binary distribution.
2607
2608 *** --without-gnutls disables automatic GnuTLS detection.
2609
2610 *** --lib for general library linkage, works with the USER_LIBS build variable.
2611
2612 ** New make target `dist' to create binary distribution for MS Windows.
2613
2614 ** The Lisp function `w32-default-color-map' is now obsolete.
2615 (It is only used internally in the Emacs C code.)
2616
2617 ** Customize ns-auto-hide-menu-bar to have the menu-bar hidden, but
2618 reappear on mouse-over. (Requires OS X 10.6 or later.)
2619
2620 ** On Mac OS X, dragging a file into Emacs visits the file, like on
2621 other platforms, rather than inserting its contents into the buffer.
2622
2623 \f
2624 ----------------------------------------------------------------------
2625 This file is part of GNU Emacs.
2626
2627 GNU Emacs is free software: you can redistribute it and/or modify
2628 it under the terms of the GNU General Public License as published by
2629 the Free Software Foundation, either version 3 of the License, or
2630 (at your option) any later version.
2631
2632 GNU Emacs is distributed in the hope that it will be useful,
2633 but WITHOUT ANY WARRANTY; without even the implied warranty of
2634 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2635 GNU General Public License for more details.
2636
2637 You should have received a copy of the GNU General Public License
2638 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
2639
2640 \f
2641 Local variables:
2642 mode: outline
2643 paragraph-separate: "[ \f]*$"
2644 end: