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